FreeKill/Fk/Logic.js

217 lines
5.8 KiB
JavaScript
Raw Normal View History

// SPDX-License-Identifier: GPL-3.0-or-later
2023-08-01 13:01:01 +00:00
/*
var generalsOverviewPage, cardsOverviewPage;
var clientPageCreated = false;
function createClientPages() {
if (!clientPageCreated) {
clientPageCreated = true;
generalsOverviewPage = generalsOverview.createObject(mainWindow);
cardsOverviewPage = cardsOverview.createObject(mainWindow);
mainWindow.generalsOverviewPage = generalsOverviewPage;
mainWindow.cardsOverviewPage = cardsOverviewPage;
2023-02-26 08:51:29 +00:00
}
}
2023-08-01 13:01:01 +00:00
*/
var callbacks = {};
let sheduled_download = "";
callbacks["ServerDetected"] = (j) => {
const serverDialog = mainStack.currentItem.serverDialog;
if (!serverDialog) {
return;
}
const item = serverDialog.item;
if (item) {
toast.show(qsTr("Detected Server %1").arg(j.slice(7)), 10000);
}
}
callbacks["GetServerDetail"] = (j) => {
2023-07-01 15:14:30 +00:00
const [ver, icon, desc, capacity, count, addr] = JSON.parse(j);
const serverDialog = mainStack.currentItem.serverDialog;
if (!serverDialog) {
return;
}
const item = serverDialog.item;
if (item) {
item.updateServerDetail(addr, [ver, icon, desc, capacity, count]);
}
}
callbacks["NetworkDelayTest"] = (jsonData) => {
// jsonData: RSA pub key
let cipherText;
let aeskey;
const savedPw = config.savedPassword[config.serverAddr];
if (savedPw?.shorten_password === config.password) {
cipherText = config.savedPassword[config.serverAddr].password;
aeskey = config.savedPassword[config.serverAddr].key;
2023-04-15 04:40:07 +00:00
config.aeskey = aeskey ?? "";
Backend.setAESKey(aeskey);
if (Debugging)
console.log("use remembered password", config.password);
} else {
cipherText = Backend.pubEncrypt(jsonData, config.password);
config.aeskey = Backend.getAESKey();
}
config.cipherText = cipherText;
Backend.replyDelayTest(config.screenName, cipherText);
}
callbacks["ErrorMsg"] = (jsonData) => {
let log;
try {
const a = JSON.parse(jsonData);
log = qsTr(a[0]).arg(a[1]);
} catch (e) {
log = qsTr(jsonData);
}
console.log("ERROR: " + log);
toast.show(log, 5000);
mainWindow.busy = false;
if (sheduled_download !== "") {
mainWindow.busy = true;
2024-04-19 14:38:00 +00:00
Pacman.loadSummary(JSON.stringify(sheduled_download), true);
sheduled_download = "";
}
}
callbacks["ErrorDlg"] = (jsonData) => {
let log;
try {
const a = JSON.parse(jsonData);
log = qsTr(a[0]).arg(a[1]);
} catch (e) {
log = qsTr(jsonData);
}
console.log("ERROR: " + log);
Backend.showDialog("warning", log, jsonData);
mainWindow.busy = false;
if (sheduled_download !== "") {
mainWindow.busy = true;
Pacman.loadSummary(JSON.stringify(sheduled_download), true);
sheduled_download = "";
}
}
callbacks["UpdatePackage"] = (jsonData) => sheduled_download = jsonData;
callbacks["UpdateBusyText"] = (jsonData) => {
mainWindow.busyText = jsonData;
}
callbacks["DownloadComplete"] = () => {
mainWindow.busy = false;
mainStack.currentItem.downloadComplete(); // should be pacman page
}
callbacks["BackToStart"] = (jsonData) => {
while (mainStack.depth > 1) {
mainStack.pop();
}
}
callbacks["SetServerSettings"] = (data) => {
2023-08-27 12:21:37 +00:00
const [ motd, hiddenPacks, enableBots ] = data;
config.serverMotd = motd;
config.serverHiddenPacks = hiddenPacks;
2023-08-27 12:21:37 +00:00
config.serverEnableBot = enableBots;
};
callbacks["EnterLobby"] = (jsonData) => {
// depth == 1 means the lobby page is not present in mainStack
2023-08-01 13:01:01 +00:00
// createClientPages();
if (mainStack.depth === 1) {
// we enter the lobby successfully, so save password now.
config.lastLoginServer = config.serverAddr;
config.savedPassword[config.serverAddr] = {
username: config.screenName,
password: config.cipherText,
key: config.aeskey,
shorten_password: config.cipherText.slice(0, 8)
}
mainStack.push(lobby);
} else {
mainStack.pop();
}
mainWindow.busy = false;
2023-07-02 14:43:56 +00:00
ClientInstance.notifyServer("RefreshRoomList", "");
config.saveConf();
}
callbacks["EnterRoom"] = (data) => {
// jsonData: int capacity, int timeout
config.roomCapacity = data[0];
config.roomTimeout = data[1] - 1;
const roomSettings = data[2];
config.enableFreeAssign = roomSettings.enableFreeAssign;
config.heg = roomSettings.gameMode.includes('heg_mode');
mainStack.push(room);
mainWindow.busy = false;
}
callbacks["UpdateRoomList"] = (data) => {
const current = mainStack.currentItem; // should be lobby
if (mainStack.depth === 2) {
current.roomModel.clear();
data.forEach(room => {
const [roomId, roomName, gameMode, playerNum, capacity, hasPassword,
outdated] = room;
current.roomModel.append({
roomId, roomName, gameMode, playerNum, capacity,
hasPassword, outdated,
});
});
}
}
callbacks["UpdatePlayerNum"] = (data) => {
const current = mainStack.currentItem; // should be lobby
if (mainStack.depth === 2) {
const l = data[0];
const s = data[1];
current.lobbyPlayerNum = l;
current.serverPlayerNum = s;
}
}
callbacks["Chat"] = (data) => {
// jsonData: { string userName, string general, string time, string msg }
const current = mainStack.currentItem; // lobby or room
const pid = data.sender;
const userName = data.userName;
const general = luatr(data.general);
const time = data.time;
const msg = data.msg;
2023-04-10 13:34:23 +00:00
if (config.blockedUsers.indexOf(userName) !== -1) {
return;
}
let text;
if (general === "")
text = `<font color="#3598E8">[${time}] ${userName}:</font> ${msg}`;
else
text = `<font color="#3598E8">[${time}] ${userName}` +
`(${general}):</font> ${msg}`;
current.addToChat(pid, data, text);
}
callbacks["ServerMessage"] = (jsonData) => {
const current = mainStack.currentItem; // lobby or room
2023-10-27 14:53:25 +00:00
current.sendDanmaku('<font color="grey"><b>[Server] </b></font>' + jsonData);
}
callbacks["ShowToast"] = (j) => toast.show(j);
callbacks["InstallKey"] = (j) => Backend.installAESKey();
callbacks["AddTotalGameTime"] = (jsonData) => {
config.totalTime++;
}