mirror of
https://github.com/hrfee/jfa-go.git
synced 2025-01-08 17:30:11 +00:00
Harvey Tindall
301f502052
web UI now uses modules, and relies less on bodge to make things work. Also fixes an issue where invites where "failed to send to xx" appeared in invite form.
131 lines
4.7 KiB
TypeScript
131 lines
4.7 KiB
TypeScript
import { serializeForm, _post, _get, _delete, addAttr, rmAttr } from "./modules/common.js";
|
|
import { BS5 } from "./modules/bs5.js";
|
|
import { BS4 } from "./modules/bs4.js";
|
|
|
|
interface formWindow extends Window {
|
|
usernameEnabled: boolean;
|
|
validationStrings: pwValStrings;
|
|
}
|
|
|
|
declare var window: formWindow;
|
|
|
|
interface pwValString {
|
|
singular: string;
|
|
plural: string;
|
|
}
|
|
|
|
interface pwValStrings {
|
|
length, uppercase, lowercase, number, special: pwValString;
|
|
}
|
|
|
|
var defaultPwValStrings: pwValStrings = {
|
|
length: {
|
|
singular: "Must have at least {n} character",
|
|
plural: "Must have a least {n} characters"
|
|
},
|
|
uppercase: {
|
|
singular: "Must have at least {n} uppercase character",
|
|
plural: "Must have at least {n} uppercase characters"
|
|
},
|
|
lowercase: {
|
|
singular: "Must have at least {n} lowercase character",
|
|
plural: "Must have at least {n} lowercase characters"
|
|
},
|
|
number: {
|
|
singular: "Must have at least {n} number",
|
|
plural: "Must have at least {n} numbers"
|
|
},
|
|
special: {
|
|
singular: "Must have at least {n} special character",
|
|
plural: "Must have at least {n} special characters"
|
|
}
|
|
}
|
|
|
|
const toggleSpinner = (): void => {
|
|
const submitButton = document.getElementById('submitButton') as HTMLButtonElement;
|
|
if (document.getElementById('createAccountSpinner')) {
|
|
submitButton.innerHTML = `<span>Create Account</span>`;
|
|
submitButton.disabled = false;
|
|
} else {
|
|
submitButton.innerHTML = `
|
|
<span id="createAccountSpinner" class="spinner-border spinner-border-sm" role="status" aria-hidden="true"></span>Creating...
|
|
`;
|
|
}
|
|
};
|
|
|
|
for (let key in window.validationStrings) {
|
|
if (window.validationStrings[key].singular == "" || !(window.validationStrings[key].plural.includes("{n}"))) {
|
|
window.validationStrings[key].singular = defaultPwValStrings[key].singular;
|
|
}
|
|
if (window.validationStrings[key].plural == "" || !(window.validationStrings[key].plural.includes("{n}"))) {
|
|
window.validationStrings[key].plural = defaultPwValStrings[key].plural;
|
|
}
|
|
let el = document.getElementById(key) as HTMLUListElement;
|
|
if (el) {
|
|
const min: number = +el.getAttribute("min");
|
|
let text = "";
|
|
if (min == 1) {
|
|
text = window.validationStrings[key].singular.replace("{n}", "1");
|
|
} else {
|
|
text = window.validationStrings[key].plural.replace("{n}", min.toString());
|
|
}
|
|
(document.getElementById(key).children[0] as HTMLDivElement).textContent = text;
|
|
}
|
|
}
|
|
|
|
window.BS = window.bs5 ? new BS5 : new BS4;
|
|
var successBox: BSModal = window.BS.newModal('successBox');;
|
|
|
|
var code = window.location.href.split('/').pop();
|
|
|
|
(document.getElementById('accountForm') as HTMLFormElement).addEventListener('submit', (event: any): boolean => {
|
|
event.preventDefault();
|
|
const el = document.getElementById('errorMessage');
|
|
if (el) {
|
|
el.remove();
|
|
}
|
|
toggleSpinner();
|
|
let send: Object = serializeForm('accountForm');
|
|
send["code"] = code;
|
|
if (!window.usernameEnabled) {
|
|
send["email"] = send["username"];
|
|
}
|
|
_post("/newUser", send, function (): void {
|
|
if (this.readyState == 4) {
|
|
toggleSpinner();
|
|
let data: Object = this.response;
|
|
const errorGiven = ("error" in data)
|
|
if (errorGiven || data["success"] === false) {
|
|
let errorMessage = "Unknown Error";
|
|
if (errorGiven && errorGiven != true) {
|
|
errorMessage = data["error"];
|
|
}
|
|
document.getElementById('errorBox').innerHTML += `
|
|
<button id="errorMessage" class="btn btn-outline-danger" disabled>${errorMessage}</button>
|
|
`;
|
|
} else {
|
|
let valid = true;
|
|
for (let key in data) {
|
|
if (data.hasOwnProperty(key)) {
|
|
const criterion = document.getElementById(key);
|
|
if (criterion) {
|
|
if (data[key] === false) {
|
|
valid = false;
|
|
addAttr(criterion, "list-group-item-danger");
|
|
rmAttr(criterion, "list-group-item-success");
|
|
} else {
|
|
addAttr(criterion, "list-group-item-success");
|
|
rmAttr(criterion, "list-group-item-danger");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (valid) {
|
|
successBox.show();
|
|
}
|
|
}
|
|
}
|
|
}, true);
|
|
return false;
|
|
});
|