// SPDX-License-Identifier: GPL-3.0-or-later import QtQuick import QtQuick.Layouts import Fk.Pages GraphicsBox { id: root title.text: root.multiChoose ? Backend.translate("$ChooseCards").arg(root.min).arg(root.max) : Backend.translate("$ChooseCard") // TODO: Adjust the UI design in case there are more than 7 cards width: 70 + 700 height: 50 + Math.min(cardView.contentHeight, 400) + (multiChoose ? 20 : 0) signal cardSelected(int cid) signal cardsSelected(var ids) property bool multiChoose: false property int min: 0 property int max: 1 property var selected_ids: [] ListModel { id: cardModel } ListView { id: cardView anchors.fill: parent anchors.topMargin: 40 anchors.leftMargin: 20 anchors.rightMargin: 20 anchors.bottomMargin: 20 spacing: 20 model: cardModel clip: true delegate: RowLayout { spacing: 15 visible: areaCards.count > 0 Rectangle { border.color: "#A6967A" radius: 5 color: "transparent" width: 18 height: 130 Layout.alignment: Qt.AlignTop Text { color: "#E4D5A0" text: Backend.translate(areaName) anchors.fill: parent wrapMode: Text.WrapAnywhere verticalAlignment: Text.AlignVCenter horizontalAlignment: Text.AlignHCenter font.pixelSize: 15 } } GridLayout { columns: 7 Repeater { model: areaCards CardItem { cid: model.cid name: model.name || "" suit: model.suit || "" number: model.number || 0 autoBack: false known: model.cid !== -1 selectable: true onClicked: { if (!root.multiChoose) { root.cardSelected(cid); } } onSelectedChanged: { if (selected) { virt_name = "$Selected"; root.selected_ids.push(cid); } else { virt_name = ""; root.selected_ids.splice(root.selected_ids.indexOf(cid), 1); } root.selected_ids = root.selected_ids; } } } } } } MetroButton { anchors.bottom: parent.bottom text: Backend.translate("OK") visible: root.multiChoose enabled: root.selected_ids.length <= root.max && root.selected_ids.length >= root.min onClicked: root.cardsSelected(root.selected_ids) } onCardSelected: finished(); function findAreaModel(name) { let ret; for (let i = 0; i < cardModel.count; i++) { let item = cardModel.get(i); if (item.areaName == name) { ret = item; break; } } if (!ret) { ret = { areaName: name, areaCards: [], } cardModel.append(ret); ret = findAreaModel(name); } return ret; } function addHandcards(cards) { let handcards = findAreaModel('$Hand').areaCards; if (cards instanceof Array) { for (let i = 0; i < cards.length; i++) handcards.append(cards[i]); } else { handcards.append(cards); } } function addEquips(cards) { let equips = findAreaModel('$Equip').areaCards; if (cards instanceof Array) { for (let i = 0; i < cards.length; i++) equips.append(cards[i]); } else { equips.append(cards); } } function addDelayedTricks(cards) { let delayedTricks = findAreaModel('$Judge').areaCards; if (cards instanceof Array) { for (let i = 0; i < cards.length; i++) delayedTricks.append(cards[i]); } else { delayedTricks.append(cards); } } function addCustomCards(name, cards) { let area = findAreaModel(name).areaCards; if (cards instanceof Array) { for (let i = 0; i < cards.length; i++) area.append(cards[i]); } else { area.append(cards); } } }