2022-09-14 05:01:10 +00:00
|
|
|
import QtQuick
|
|
|
|
import QtQuick.Layouts
|
|
|
|
import Qt5Compat.GraphicalEffects
|
2022-03-23 11:40:28 +00:00
|
|
|
|
|
|
|
RowLayout {
|
2022-04-30 07:27:56 +00:00
|
|
|
id: root
|
2022-03-23 11:40:28 +00:00
|
|
|
|
2022-04-30 07:27:56 +00:00
|
|
|
property alias self: selfPhoto
|
|
|
|
property alias handcardArea: handcardAreaItem
|
|
|
|
property alias equipArea: selfPhoto.equipArea
|
|
|
|
property alias delayedTrickArea: selfPhoto.delayedTrickArea
|
|
|
|
property alias specialArea: selfPhoto.specialArea
|
2022-04-14 10:22:00 +00:00
|
|
|
|
2022-04-30 07:27:56 +00:00
|
|
|
property bool selected: selfPhoto.selected
|
|
|
|
|
|
|
|
property bool is_pending: false
|
|
|
|
property string pending_skill: ""
|
|
|
|
property var pending_card
|
|
|
|
property var pendings: [] // int[], store cid
|
|
|
|
property int selected_card: -1
|
|
|
|
|
2022-09-14 05:01:10 +00:00
|
|
|
property alias skillButtons: skillPanel.skill_buttons
|
|
|
|
|
|
|
|
property var expanded_piles: ({}) // name -> int[]
|
|
|
|
|
2022-04-30 07:27:56 +00:00
|
|
|
signal cardSelected(var card)
|
|
|
|
|
2022-09-14 05:01:10 +00:00
|
|
|
Item { width: 5 }
|
2022-04-30 07:27:56 +00:00
|
|
|
|
|
|
|
HandcardArea {
|
|
|
|
id: handcardAreaItem
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.preferredHeight: 130
|
2022-09-14 05:01:10 +00:00
|
|
|
Layout.alignment: Qt.AlignBottom
|
|
|
|
Layout.bottomMargin: 24
|
|
|
|
onWidthChanged: updateCardPosition(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
SkillArea {
|
|
|
|
Layout.fillHeight: true
|
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.maximumWidth: width
|
|
|
|
Layout.maximumHeight: height
|
|
|
|
Layout.alignment: Qt.AlignBottom
|
|
|
|
Layout.bottomMargin: 32
|
|
|
|
Layout.rightMargin: -16
|
|
|
|
id: skillPanel
|
2022-04-30 07:27:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Photo {
|
|
|
|
id: selfPhoto
|
2022-09-14 05:01:10 +00:00
|
|
|
Layout.rightMargin: -175 / 8 + (roomArea.width - 175 * 0.75 * 7) / 8
|
2022-04-30 07:27:56 +00:00
|
|
|
handcards: handcardAreaItem.length
|
|
|
|
}
|
|
|
|
|
|
|
|
Connections {
|
|
|
|
target: handcardAreaItem
|
|
|
|
function onCardSelected(cardId, selected) {
|
|
|
|
dashboard.selectCard(cardId, selected);
|
2022-04-14 10:22:00 +00:00
|
|
|
}
|
2022-04-30 07:27:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function disableAllCards() {
|
|
|
|
handcardAreaItem.enableCards([]);
|
|
|
|
}
|
2022-03-23 11:40:28 +00:00
|
|
|
|
2022-04-30 07:27:56 +00:00
|
|
|
function unSelectAll(expectId) {
|
|
|
|
handcardAreaItem.unselectAll(expectId);
|
|
|
|
}
|
|
|
|
|
2022-09-14 05:01:10 +00:00
|
|
|
function expandPile(pile) {
|
|
|
|
let expanded_pile_names = Object.keys(expanded_piles);
|
|
|
|
if (expanded_pile_names.indexOf(pile) !== -1)
|
|
|
|
return;
|
|
|
|
|
|
|
|
let component = Qt.createComponent("CardItem.qml");
|
|
|
|
let parentPos = roomScene.mapFromItem(selfPhoto, 0, 0);
|
|
|
|
|
|
|
|
// FIXME: only expand equip area here. modify this if need true pile
|
|
|
|
expanded_piles[pile] = [];
|
|
|
|
if (pile === "_equip") {
|
|
|
|
let equips = selfPhoto.equipArea.getAllCards();
|
|
|
|
equips.forEach(data => {
|
|
|
|
data.x = parentPos.x;
|
|
|
|
data.y = parentPos.y;
|
|
|
|
let card = component.createObject(roomScene, data);
|
|
|
|
handcardAreaItem.add(card);
|
|
|
|
})
|
|
|
|
handcardAreaItem.updateCardPosition();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function retractPile(pile) {
|
|
|
|
let expanded_pile_names = Object.keys(expanded_piles);
|
|
|
|
if (expanded_pile_names.indexOf(pile) === -1)
|
|
|
|
return;
|
|
|
|
|
|
|
|
let parentPos = roomScene.mapFromItem(selfPhoto, 0, 0);
|
|
|
|
|
|
|
|
delete expanded_piles[pile];
|
|
|
|
if (pile === "_equip") {
|
|
|
|
let equips = selfPhoto.equipArea.getAllCards();
|
|
|
|
equips.forEach(data => {
|
|
|
|
let card = handcardAreaItem.remove([data.cid])[0];
|
|
|
|
card.origX = parentPos.x;
|
|
|
|
card.origY = parentPos.y;
|
|
|
|
card.destroyOnStop();
|
|
|
|
card.goBack(true);
|
|
|
|
})
|
|
|
|
handcardAreaItem.updateCardPosition();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-18 13:19:35 +00:00
|
|
|
// If cname is set, we are responding card.
|
|
|
|
function enableCards(cname) {
|
|
|
|
if (cname) {
|
|
|
|
let ids = [], cards = handcardAreaItem.cards;
|
|
|
|
for (let i = 0; i < cards.length; i++) {
|
|
|
|
if (cards[i].name === cname)
|
|
|
|
ids.push(cards[i].cid);
|
|
|
|
}
|
|
|
|
handcardAreaItem.enableCards(ids);
|
|
|
|
return;
|
|
|
|
}
|
2022-04-30 07:27:56 +00:00
|
|
|
// TODO: expand pile
|
|
|
|
let ids = [], cards = handcardAreaItem.cards;
|
|
|
|
for (let i = 0; i < cards.length; i++) {
|
|
|
|
if (JSON.parse(Backend.callLuaFunction("CanUseCard", [cards[i].cid, Self.id])))
|
|
|
|
ids.push(cards[i].cid);
|
|
|
|
}
|
|
|
|
handcardAreaItem.enableCards(ids)
|
2022-09-14 05:01:10 +00:00
|
|
|
if (pending_skill === "") {
|
|
|
|
cancelButton.enabled = false;
|
|
|
|
}
|
2022-04-30 07:27:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function selectCard(cardId, selected) {
|
|
|
|
if (pending_skill !== "") {
|
|
|
|
if (selected) {
|
|
|
|
pendings.push(cardId);
|
|
|
|
} else {
|
|
|
|
pendings.splice(pendings.indexOf(cardId), 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
updatePending();
|
|
|
|
} else {
|
|
|
|
if (selected) {
|
|
|
|
handcardAreaItem.unselectAll(cardId);
|
|
|
|
selected_card = cardId;
|
|
|
|
} else {
|
|
|
|
handcardAreaItem.unselectAll();
|
|
|
|
selected_card = -1;
|
|
|
|
}
|
|
|
|
cardSelected(selected_card);
|
2022-03-23 11:40:28 +00:00
|
|
|
}
|
2022-04-30 07:27:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function getSelectedCard() {
|
|
|
|
if (pending_skill !== "") {
|
|
|
|
return JSON.stringify({
|
|
|
|
skill: pending_skill,
|
|
|
|
subcards: pendings
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
return selected_card;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function updatePending() {
|
|
|
|
if (pending_skill === "") return;
|
|
|
|
|
|
|
|
let enabled_cards = [];
|
2022-09-14 05:01:10 +00:00
|
|
|
let targets = roomScene.selected_targets;
|
2022-04-30 07:27:56 +00:00
|
|
|
|
2022-09-14 05:01:10 +00:00
|
|
|
handcardAreaItem.cards.forEach((card) => {
|
|
|
|
if (card.selected || JSON.parse(Backend.callLuaFunction(
|
|
|
|
"ActiveCardFilter",
|
|
|
|
[pending_skill, card.cid, pendings, targets]
|
|
|
|
)))
|
2022-04-30 07:27:56 +00:00
|
|
|
enabled_cards.push(card.cid);
|
|
|
|
});
|
|
|
|
handcardAreaItem.enableCards(enabled_cards);
|
|
|
|
|
2022-09-14 05:01:10 +00:00
|
|
|
if (JSON.parse(Backend.callLuaFunction(
|
|
|
|
"CanViewAs",
|
|
|
|
[pending_skill, pendings]
|
|
|
|
))) {
|
2022-04-30 07:27:56 +00:00
|
|
|
pending_card = {
|
|
|
|
skill: pending_skill,
|
|
|
|
subcards: pendings
|
|
|
|
};
|
|
|
|
cardSelected(JSON.stringify(pending_card));
|
|
|
|
} else {
|
|
|
|
pending_card = -1;
|
|
|
|
cardSelected(pending_card);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function startPending(skill_name) {
|
|
|
|
pending_skill = skill_name;
|
|
|
|
pendings = [];
|
|
|
|
handcardAreaItem.unselectAll();
|
2022-09-15 03:17:13 +00:00
|
|
|
for (let i = 0; i < skillButtons.count; i++) {
|
|
|
|
let item = skillButtons.itemAt(i);
|
|
|
|
item.enabled = item.pressed;
|
|
|
|
}
|
2022-04-30 07:27:56 +00:00
|
|
|
|
|
|
|
// TODO: expand pile
|
|
|
|
|
|
|
|
// TODO: equipment
|
|
|
|
|
|
|
|
updatePending();
|
|
|
|
}
|
|
|
|
|
|
|
|
function deactivateSkillButton() {
|
2022-09-14 05:01:10 +00:00
|
|
|
for (let i = 0; i < skillButtons.count; i++) {
|
|
|
|
skillButtons.itemAt(i).pressed = false;
|
2022-04-30 07:27:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function stopPending() {
|
|
|
|
pending_skill = "";
|
|
|
|
pending_card = -1;
|
|
|
|
|
|
|
|
// TODO: expand pile
|
2022-03-23 11:40:28 +00:00
|
|
|
|
2022-09-14 05:01:10 +00:00
|
|
|
// TODO: equipment
|
2022-03-23 11:40:28 +00:00
|
|
|
|
2022-04-30 07:27:56 +00:00
|
|
|
pendings = [];
|
|
|
|
handcardAreaItem.adjustCards();
|
2022-09-14 05:01:10 +00:00
|
|
|
handcardAreaItem.unselectAll();
|
2022-04-30 07:27:56 +00:00
|
|
|
cardSelected(-1);
|
|
|
|
}
|
2022-09-14 05:01:10 +00:00
|
|
|
|
|
|
|
function addSkill(skill_name) {
|
|
|
|
skillPanel.addSkill(skill_name);
|
|
|
|
}
|
|
|
|
|
|
|
|
function loseSkill(skill_name) {
|
|
|
|
skillPanel.loseSkill(skill_name);
|
|
|
|
}
|
|
|
|
|
2022-12-18 13:19:35 +00:00
|
|
|
function enableSkills(cname) {
|
|
|
|
if (cname) {
|
|
|
|
// TODO: vs skill
|
|
|
|
return;
|
|
|
|
}
|
2022-09-14 05:01:10 +00:00
|
|
|
for (let i = 0; i < skillButtons.count; i++) {
|
|
|
|
let item = skillButtons.itemAt(i);
|
|
|
|
item.enabled = JSON.parse(Backend.callLuaFunction("ActiveCanUse", [item.orig]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function disableSkills() {
|
|
|
|
for (let i = 0; i < skillButtons.count; i++)
|
|
|
|
skillButtons.itemAt(i).enabled = false;
|
|
|
|
}
|
2022-12-20 04:51:54 +00:00
|
|
|
|
|
|
|
function tremble() {
|
|
|
|
selfPhoto.tremble();
|
|
|
|
}
|
2022-03-23 11:40:28 +00:00
|
|
|
}
|