2024-07-11 18:34:40 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Window 2.15
|
|
|
|
import QtQuick.Layouts 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
|
|
|
|
|
|
|
Window {
|
|
|
|
SystemPalette { id: activeColors; colorGroup: SystemPalette.Active }
|
|
|
|
SystemPalette { id: inactiveColors; colorGroup: SystemPalette.Inactive }
|
|
|
|
SystemPalette { id: disabledColors; colorGroup: SystemPalette.Disabled }
|
|
|
|
|
|
|
|
function getColors() {
|
|
|
|
return dataScreen.active ? activeColors : inactiveColors;
|
|
|
|
}
|
|
|
|
|
|
|
|
id: dataScreen
|
|
|
|
width: 640
|
|
|
|
height: 480
|
|
|
|
visible: true
|
|
|
|
color: getColors().window
|
|
|
|
|
|
|
|
title: qsTr("Alisa - Add License")
|
|
|
|
|
|
|
|
property string authToken: ""
|
|
|
|
|
2024-07-11 23:08:34 +02:00
|
|
|
ListModel {
|
|
|
|
id: groupsModel
|
|
|
|
}
|
|
|
|
|
2024-07-11 18:34:40 +02:00
|
|
|
TextField {
|
|
|
|
id: nameT
|
|
|
|
anchors {
|
|
|
|
horizontalCenter: parent.horizontalCenter
|
|
|
|
topMargin: 5
|
|
|
|
top: parent.top // Assuming there's no loginL defined in your code
|
|
|
|
}
|
|
|
|
placeholderText: qsTr("Name")
|
|
|
|
Keys.onReturnPressed: keyT.focus = true
|
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: keyT
|
|
|
|
anchors {
|
|
|
|
horizontalCenter: parent.horizontalCenter
|
|
|
|
topMargin: 5
|
|
|
|
top: nameT.bottom
|
|
|
|
}
|
|
|
|
placeholderText: qsTr("Key")
|
|
|
|
Keys.onReturnPressed: amountT.focus = true
|
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
|
|
|
id: amountT
|
|
|
|
anchors {
|
|
|
|
horizontalCenter: parent.horizontalCenter
|
|
|
|
topMargin: 5
|
|
|
|
top: keyT.bottom
|
|
|
|
}
|
|
|
|
placeholderText: qsTr("Amount")
|
|
|
|
inputMethodHints: Qt.ImhDigitsOnly
|
|
|
|
|
|
|
|
validator: DoubleValidator {
|
|
|
|
bottom: 0
|
|
|
|
top: 1000000
|
|
|
|
}
|
|
|
|
|
|
|
|
onTextChanged: {
|
|
|
|
text = text.replace(/[^0-9]/g, "")
|
|
|
|
}
|
|
|
|
|
2024-07-12 10:49:41 +02:00
|
|
|
Keys.onReturnPressed: noteT.focus = true
|
2024-07-12 10:28:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TextField {
|
2024-07-12 10:49:41 +02:00
|
|
|
id: noteT
|
2024-07-12 10:28:08 +02:00
|
|
|
anchors {
|
|
|
|
horizontalCenter: parent.horizontalCenter
|
|
|
|
topMargin: 5
|
|
|
|
top: amountT.bottom
|
|
|
|
}
|
2024-07-12 10:49:41 +02:00
|
|
|
placeholderText: qsTr("Notes")
|
2024-07-11 23:08:34 +02:00
|
|
|
Keys.onReturnPressed: groupSelector.focus = true
|
|
|
|
}
|
|
|
|
|
|
|
|
ComboBox {
|
|
|
|
id: groupSelector
|
|
|
|
anchors {
|
|
|
|
horizontalCenter: parent.horizontalCenter
|
|
|
|
topMargin: 5
|
2024-07-12 10:49:41 +02:00
|
|
|
top: noteT.bottom
|
2024-07-11 23:08:34 +02:00
|
|
|
}
|
2024-07-12 10:28:08 +02:00
|
|
|
|
2024-07-11 23:08:34 +02:00
|
|
|
model: groupsModel
|
|
|
|
textRole: "name"
|
2024-07-11 18:34:40 +02:00
|
|
|
Keys.onReturnPressed: submitB.focus = true
|
|
|
|
}
|
|
|
|
|
|
|
|
Button {
|
|
|
|
id: submitB
|
|
|
|
anchors {
|
|
|
|
horizontalCenter: parent.horizontalCenter
|
|
|
|
topMargin: 5
|
2024-07-11 23:08:34 +02:00
|
|
|
top: groupSelector.bottom
|
2024-07-11 18:34:40 +02:00
|
|
|
}
|
|
|
|
text: qsTr("Submit")
|
|
|
|
|
|
|
|
onClicked: submit()
|
|
|
|
Keys.onReturnPressed: submit()
|
|
|
|
}
|
|
|
|
|
|
|
|
function submit() {
|
|
|
|
var xhr = new XMLHttpRequest();
|
|
|
|
xhr.open("POST", "https://api.clan-war.net/api/v1/licenses");
|
|
|
|
xhr.setRequestHeader("Content-Type", "application/json");
|
|
|
|
xhr.setRequestHeader("Authorization", "Bearer " + authToken);
|
|
|
|
xhr.onreadystatechange = function() {
|
|
|
|
if (xhr.readyState === XMLHttpRequest.DONE) {
|
|
|
|
if (xhr.status != 200) {
|
|
|
|
console.log("Submission failed: " + xhr.status);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var data = JSON.stringify({
|
|
|
|
name: nameT.text,
|
|
|
|
key: keyT.text,
|
2024-07-12 10:49:41 +02:00
|
|
|
note: noteT.text,
|
2024-07-11 18:34:40 +02:00
|
|
|
amount: parseInt(amountT.text),
|
2024-07-11 23:08:34 +02:00
|
|
|
group_id: groupSelector.currentIndex !== -1 ? groupsModel.get(groupSelector.currentIndex).id : "",
|
2024-07-11 18:34:40 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
xhr.send(data);
|
2024-07-12 09:27:17 +02:00
|
|
|
dataScreen.close()
|
|
|
|
|
2024-07-11 18:34:40 +02:00
|
|
|
}
|
2024-07-11 23:08:34 +02:00
|
|
|
|
|
|
|
function fetchGroups() {
|
|
|
|
var xhr = new XMLHttpRequest();
|
|
|
|
xhr.open("GET", "https://api.clan-war.net/api/v1/licenses");
|
|
|
|
xhr.setRequestHeader("Authorization", "Bearer " + authToken);
|
|
|
|
xhr.onreadystatechange = function() {
|
|
|
|
if (xhr.readyState === XMLHttpRequest.DONE) {
|
|
|
|
if (xhr.status === 200) {
|
|
|
|
var response = JSON.parse(xhr.responseText);
|
|
|
|
groupsModel.clear();
|
|
|
|
for (var i = 0; i < response.length; i++) {
|
|
|
|
groupsModel.append(response[i]);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
console.log("Failed to fetch groups: " + xhr.status);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
xhr.send();
|
|
|
|
}
|
|
|
|
|
|
|
|
Component.onCompleted: fetchGroups()
|
2024-07-11 18:34:40 +02:00
|
|
|
}
|