mirror of
https://github.com/pagefaultgames/pokerogue.git
synced 2025-02-02 22:27:15 +00:00
bac6c22973
* eslint config + packages * updated eslint config * fix the issue eslint adding ;;;; at interfaces * first round with eslint --fix . * removed config for unused export * Revert "first round with eslint --fix ." This reverts commit 77a88e0895f7c3389cb223651b90d918af778fe9. * removed config for camelCase * for real this time, first round of eslint --fix . * halfway to manual eslint fix * eslint done * added "how to setup" the hook to eslint --fix each new file before commit (if wanted) * removed eslintrc config file duplicat * fix human error + ignore build folder + merge overrides * added curly brace style + eslint * applied double quote linter rule * added lefthook * test precommit * test precommit * test precommit * test precommit * test precommit * test precommit * test precommit * github action to run eslint * added node_modules to ignore eslint * different action for typescript * no need for different glob (default src) * node 20 * node 20 * removed no longer needed install file * remove hooks part from README * eslint fixes --------- Co-authored-by: Frederico Santos <frederico.f.santos@tecnico.ulisboa.pt>
51 lines
1.7 KiB
TypeScript
51 lines
1.7 KiB
TypeScript
import { bypassLogin } from "./battle-scene";
|
|
import * as Utils from "./utils";
|
|
|
|
export interface UserInfo {
|
|
username: string;
|
|
lastSessionSlot: integer;
|
|
}
|
|
|
|
export let loggedInUser: UserInfo = null;
|
|
export const clientSessionId = Utils.randomString(32);
|
|
|
|
export function updateUserInfo(): Promise<[boolean, integer]> {
|
|
return new Promise<[boolean, integer]>(resolve => {
|
|
if (bypassLogin) {
|
|
loggedInUser = { username: "Guest", lastSessionSlot: -1 };
|
|
let lastSessionSlot = -1;
|
|
for (let s = 0; s < 5; s++) {
|
|
if (localStorage.getItem(`sessionData${s ? s : ""}_${loggedInUser.username}`)) {
|
|
lastSessionSlot = s;
|
|
break;
|
|
}
|
|
}
|
|
loggedInUser.lastSessionSlot = lastSessionSlot;
|
|
// Migrate old data from before the username was appended
|
|
[ "data", "sessionData", "sessionData1", "sessionData2", "sessionData3", "sessionData4" ].map(d => {
|
|
if (localStorage.hasOwnProperty(d)) {
|
|
if (localStorage.hasOwnProperty(`${d}_${loggedInUser.username}`)) {
|
|
localStorage.setItem(`${d}_${loggedInUser.username}_bak`, localStorage.getItem(`${d}_${loggedInUser.username}`));
|
|
}
|
|
localStorage.setItem(`${d}_${loggedInUser.username}`, localStorage.getItem(d));
|
|
localStorage.removeItem(d);
|
|
}
|
|
});
|
|
return resolve([ true, 200 ]);
|
|
}
|
|
Utils.apiFetch("account/info", true).then(response => {
|
|
if (!response.ok) {
|
|
resolve([ false, response.status ]);
|
|
return;
|
|
}
|
|
return response.json();
|
|
}).then(jsonResponse => {
|
|
loggedInUser = jsonResponse;
|
|
resolve([ true, 200 ]);
|
|
}).catch(err => {
|
|
console.error(err);
|
|
resolve([ false, 500 ]);
|
|
});
|
|
});
|
|
}
|