FreeKill/Fk/LobbyElement/BanGeneralSetting.qml

244 lines
5.7 KiB
QML

// SPDX-License-Identifier: GPL-3.0-or-later
import QtQuick
import QtQuick.Controls
import QtQuick.Layouts
Item {
id: root
clip: true
ColumnLayout {
anchors.fill: parent
RowLayout {
Layout.fillWidth: true
anchors.rightMargin: 8
spacing: 16
Text {
text: luatr("Ban List")
}
ComboBox {
id: banCombo
textRole: "name"
Layout.fillWidth: true
model: ListModel {
id: banComboList
}
onCurrentIndexChanged: {
word.text = "";
config.disableSchemes[config.currentDisableIdx] = config.curScheme;
config.currentDisableIdx = currentIndex;
config.curScheme = config.disableSchemes[currentIndex];
}
}
GridLayout {
columns: 2
Button {
text: luatr("New")
onClicked: {
const i = config.disableSchemes.length;
banComboList.append({
name: luatr("List") + (i + 1),
});
config.disableSchemes.push({
name: "",
banPkg: {},
normalPkg: {},
banCardPkg: [],
});
}
}
Button {
text: luatr("Clear")
onClicked: {
config.curScheme.banPkg = {};
config.curScheme.normalPkg = {};
config.curScheme.banCardPkg = [];
config.curSchemeChanged();
}
}
Button {
text: luatr("Export")
onClicked: {
Backend.copyToClipboard(JSON.stringify(config.curScheme));
toast.show(luatr("Export Success"));
}
}
Button {
text: luatr("Import")
onClicked: {
const str = Backend.readClipboard();
let data;
try {
data = JSON.parse(str);
} catch (e) {
toast.show(luatr("Not Legal"));
return;
}
if (!data instanceof Object || !data.banPkg || !data.normalPkg
|| !data.banCardPkg) {
toast.show(luatr("Not JSON"));
return;
}
config.curScheme = data;
if (data.name) {
banComboList.get(banCombo.currentIndex).name = data.name;
}
}
}
}
TextField {
id: word
clip: true
leftPadding: 5
rightPadding: 5
}
Button {
text: luatr("Rename")
enabled: word.text !== ""
onClicked: {
banComboList.get(banCombo.currentIndex).name = word.text;
config.curScheme.name = word.text;
word.text = "";
}
}
}
Text {
Layout.fillWidth: true
Layout.margins: 8
wrapMode: Text.WrapAnywhere
text: luatr("Help_Ban_List")
}
GridLayout {
id: grid
flow: GridLayout.TopToBottom
rows: 2
Layout.fillWidth: true
Layout.fillHeight: true
Text {
wrapMode: Text.WrapAnywhere
text: luatr("Ban_Generals")
font.pixelSize: 18
font.bold: true
}
GridView {
Layout.fillWidth: true
Layout.fillHeight: true
clip: true
cellWidth: width / 2
cellHeight: 24
model: {
let ret = [], k;
const s = config.curScheme;
for (k in s.normalPkg) {
ret.push(...s.normalPkg[k]);
}
return ret;
}
delegate: Text {
//width: banChara.width
text: {
const prefix = modelData.split("__")[0];
let name = luatr(modelData);
if (prefix !== modelData) {
name += (" (" + luatr(prefix) + ")");
}
return name;
}
font.pixelSize: 16
}
}
Text {
wrapMode: Text.WrapAnywhere
text: luatr("Ban_Packages")
font.pixelSize: 18
font.bold: true
}
GridView {
Layout.fillWidth: true
Layout.fillHeight: true
clip: true
cellWidth: width / 2
cellHeight: 24
model: {
let ret = [], k;
const s = config.curScheme;
for (k in s.banPkg) {
ret.push(k);
}
ret.push(...s.banCardPkg)
return ret;
}
delegate: Text {
width: parent.width / 2
wrapMode: Text.WordWrap
fontSizeMode: Text.HorizontalFit
minimumPixelSize: 14
elide: Text.ElideRight
height: 24
text: luatr(modelData)
font.pixelSize: 16
}
}
Text {
wrapMode: Text.WrapAnywhere
text: luatr("Whitelist_Generals")
font.pixelSize: 18
font.bold: true
}
GridView {
Layout.fillWidth: true
Layout.fillHeight: true
clip: true
cellWidth: width / 2
cellHeight: 24
model: {
let ret = [], k;
const s = config.curScheme;
for (k in s.banPkg) {
ret.push(...s.banPkg[k]);
}
return ret;
}
delegate: Text {
text: {
const prefix = modelData.split("__")[0];
let name = luatr(modelData);
if (prefix !== modelData) {
name += (" (" + luatr(prefix) + ")");
}
return name;
}
font.pixelSize: 16
}
}
}
}
Component.onCompleted: {
for (let i = 0; i < config.disableSchemes.length; i++) {
banComboList.append({
name: config.disableSchemes[i]?.name || (luatr("List") + (i + 1)),
});
}
banCombo.currentIndex = config.currentDisableIdx;
}
}