159 lines
3.6 KiB
QML
159 lines
3.6 KiB
QML
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
import QtQuick
|
|
import QtQuick.Layouts
|
|
import Fk.Pages
|
|
|
|
GraphicsBox {
|
|
id: root
|
|
|
|
title.text: Backend.callLuaFunction("PoxiPrompt", [poxi_type, card_data, extra_data])
|
|
|
|
// TODO: Adjust the UI design in case there are more than 7 cards
|
|
width: 70 + 700
|
|
height: 64 + Math.min(cardView.contentHeight, 400) + 30
|
|
|
|
signal cardSelected(int cid)
|
|
signal cardsSelected(var ids)
|
|
property var selected_ids: []
|
|
property string poxi_type
|
|
property var card_data
|
|
property bool cancelable: true
|
|
property var extra_data
|
|
|
|
ListModel {
|
|
id: cardModel
|
|
}
|
|
|
|
ListView {
|
|
id: cardView
|
|
anchors.fill: parent
|
|
anchors.topMargin: 40
|
|
anchors.leftMargin: 20
|
|
anchors.rightMargin: 20
|
|
anchors.bottomMargin: 30
|
|
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: {
|
|
return root.selected_ids.includes(model.cid) || JSON.parse(Backend.callLuaFunction(
|
|
"PoxiFilter",
|
|
[root.poxi_type, model.cid, root.selected_ids, root.card_data, root.extra_data]
|
|
));
|
|
}
|
|
onSelectedChanged: {
|
|
if (selected) {
|
|
chosenInBox = true;
|
|
root.selected_ids.push(cid);
|
|
} else {
|
|
chosenInBox = false;
|
|
root.selected_ids.splice(root.selected_ids.indexOf(cid), 1);
|
|
}
|
|
root.selected_ids = root.selected_ids;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Row {
|
|
anchors.margins: 8
|
|
anchors.bottom: parent.bottom
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
spacing: 32
|
|
|
|
MetroButton {
|
|
width: 120
|
|
height: 35
|
|
text: Backend.translate("OK")
|
|
enabled: {
|
|
return JSON.parse(Backend.callLuaFunction(
|
|
"PoxiFeasible",
|
|
[root.poxi_type, root.selected_ids, root.card_data, root.extra_data]
|
|
));
|
|
}
|
|
onClicked: root.cardsSelected(root.selected_ids)
|
|
}
|
|
|
|
MetroButton {
|
|
width: 120
|
|
height: 35
|
|
text: Backend.translate("Cancel")
|
|
visible: root.cancelable
|
|
onClicked: root.cardsSelected([])
|
|
}
|
|
|
|
}
|
|
|
|
|
|
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 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);
|
|
}
|
|
}
|
|
}
|