mirror of
https://github.com/hrfee/jfa-go.git
synced 2025-01-07 17:00:11 +00:00
Compare commits
4 Commits
4deb45df3c
...
25451eb763
Author | SHA1 | Date | |
---|---|---|---|
25451eb763 | |||
dbefb80f63 | |||
|
42dbc04ff9 | ||
|
82c8ef1e4b |
12
css/base.css
12
css/base.css
@ -181,6 +181,18 @@ span.sm:not(.heading) {
|
|||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.flex-form {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media screen and (min-width: 768px) {
|
||||||
|
.flex-form {
|
||||||
|
flex: 1;
|
||||||
|
margin: 0.5rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@media screen and (max-width: 400px) {
|
@media screen and (max-width: 400px) {
|
||||||
.row {
|
.row {
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
|
@ -86,14 +86,14 @@
|
|||||||
<div class="page-container">
|
<div class="page-container">
|
||||||
<div class="card dark:~d_neutral @low">
|
<div class="card dark:~d_neutral @low">
|
||||||
<div class="row baseline">
|
<div class="row baseline">
|
||||||
<span class="col heading">
|
<span class="flex-form heading mr-5">
|
||||||
{{ if .passwordReset }}
|
{{ if .passwordReset }}
|
||||||
{{ .strings.passwordReset }}
|
{{ .strings.passwordReset }}
|
||||||
{{ else }}
|
{{ else }}
|
||||||
{{ .strings.createAccountHeader }}
|
{{ .strings.createAccountHeader }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
</span>
|
</span>
|
||||||
<span class="col subheading">
|
<span class="flex-form subheading">
|
||||||
{{ if .passwordReset }}
|
{{ if .passwordReset }}
|
||||||
{{ .strings.enterYourPassword }}
|
{{ .strings.enterYourPassword }}
|
||||||
{{ else }}
|
{{ else }}
|
||||||
@ -102,7 +102,7 @@
|
|||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col">
|
<div class="flex-form">
|
||||||
{{ if .userExpiry }}
|
{{ if .userExpiry }}
|
||||||
<aside class="col aside sm ~warning" id="user-expiry-message"></aside>
|
<aside class="col aside sm ~warning" id="user-expiry-message"></aside>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
@ -116,31 +116,31 @@
|
|||||||
<label class="label supra" for="create-email">{{ .strings.emailAddress }}</label>
|
<label class="label supra" for="create-email">{{ .strings.emailAddress }}</label>
|
||||||
<input type="email" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.emailAddress }}" id="create-email" aria-label="{{ .strings.emailAddress }}" value="{{ .email }}">
|
<input type="email" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.emailAddress }}" id="create-email" aria-label="{{ .strings.emailAddress }}" value="{{ .email }}">
|
||||||
{{ if .telegramEnabled }}
|
{{ if .telegramEnabled }}
|
||||||
<span class="button ~info @low full-width center mb-4" id="link-telegram">{{ .strings.linkTelegram }}</span>
|
<span class="button ~info @low full-width center mb-4" id="link-telegram">{{ .strings.linkTelegram }} {{ if .telegramRequired }}({{ .strings.required }}){{ end }}</span>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .discordEnabled }}
|
{{ if .discordEnabled }}
|
||||||
<span class="button ~info @low full-width center mb-4" id="link-discord">{{ .strings.linkDiscord }}</span>
|
<span class="button ~info @low full-width center mb-4" id="link-discord">{{ .strings.linkDiscord }} {{ if .discordRequired }}({{ .strings.required }}){{ end }}</span>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .matrixEnabled }}
|
{{ if .matrixEnabled }}
|
||||||
<span class="button ~info @low full-width center mb-4" id="link-matrix">{{ .strings.linkMatrix }}</span>
|
<span class="button ~info @low full-width center mb-4" id="link-matrix">{{ .strings.linkMatrix }} {{ if .matrixRequired }}({{ .strings.required }}){{ end }}</span>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if or (.telegramEnabled) (or .discordEnabled .matrixEnabled) }}
|
{{ if or (.telegramEnabled) (or .discordEnabled .matrixEnabled) }}
|
||||||
<div id="contact-via" class="unfocused">
|
<div id="contact-via" class="unfocused">
|
||||||
<label class="row switch pb-4">
|
<label class="row switch pb-4 unfocused">
|
||||||
<input type="radio" name="contact-via" value="email" class="mr-2"><span>Contact through Email</span>
|
<input type="radio" name="contact-via" value="email" id="contact-via-email" class="mr-2"><span>Contact through Email</span>
|
||||||
</label>
|
</label>
|
||||||
{{ if .telegramEnabled }}
|
{{ if .telegramEnabled }}
|
||||||
<label class="row switch pb-4">
|
<label class="row switch pb-4 unfocused">
|
||||||
<input type="radio" name="contact-via" value="telegram" id="contact-via-telegram" class="mr-2"><span>Contact through Telegram</span>
|
<input type="radio" name="contact-via" value="telegram" id="contact-via-telegram" class="mr-2"><span>Contact through Telegram</span>
|
||||||
</label>
|
</label>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .discordEnabled }}
|
{{ if .discordEnabled }}
|
||||||
<label class="row switch pb-4">
|
<label class="row switch pb-4 unfocused">
|
||||||
<input type="radio" name="contact-via" value="discord" id="contact-via-discord" class="mr-2"><span>Contact through Discord</span>
|
<input type="radio" name="contact-via" value="discord" id="contact-via-discord" class="mr-2"><span>Contact through Discord</span>
|
||||||
</label>
|
</label>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .matrixEnabled }}
|
{{ if .matrixEnabled }}
|
||||||
<label class="row switch pb-4">
|
<label class="row switch pb-4 unfocused">
|
||||||
<input type="radio" name="contact-via" value="matrix" id="contact-via-matrix" class="mr-2"><span>Contact through Matrix</span>
|
<input type="radio" name="contact-via" value="matrix" id="contact-via-matrix" class="mr-2"><span>Contact through Matrix</span>
|
||||||
</label>
|
</label>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
"linkMatrix": "Link Matrix",
|
"linkMatrix": "Link Matrix",
|
||||||
"contactDiscord": "Contact through Discord",
|
"contactDiscord": "Contact through Discord",
|
||||||
"theme": "Theme",
|
"theme": "Theme",
|
||||||
"refresh": "Refresh"
|
"refresh": "Refresh",
|
||||||
|
"required": "Required"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -31,6 +31,8 @@
|
|||||||
"errorUnknown": "Unknown error.",
|
"errorUnknown": "Unknown error.",
|
||||||
"errorNoEmail": "Email required.",
|
"errorNoEmail": "Email required.",
|
||||||
"errorCaptcha": "Captcha incorrect.",
|
"errorCaptcha": "Captcha incorrect.",
|
||||||
|
"errorPassword": "Check password requirements.",
|
||||||
|
"errorNoMatch": "Passwords don't match.",
|
||||||
"verified": "Account verified."
|
"verified": "Account verified."
|
||||||
},
|
},
|
||||||
"validationStrings": {
|
"validationStrings": {
|
||||||
|
128
ts/form.ts
128
ts/form.ts
@ -70,8 +70,11 @@ if (window.telegramEnabled) {
|
|||||||
setTimeout(window.telegramModal.close, 2000);
|
setTimeout(window.telegramModal.close, 2000);
|
||||||
telegramButton.classList.add("unfocused");
|
telegramButton.classList.add("unfocused");
|
||||||
document.getElementById("contact-via").classList.remove("unfocused");
|
document.getElementById("contact-via").classList.remove("unfocused");
|
||||||
|
document.getElementById("contact-via-email").parentElement.classList.remove("unfocused");
|
||||||
const radio = document.getElementById("contact-via-telegram") as HTMLInputElement;
|
const radio = document.getElementById("contact-via-telegram") as HTMLInputElement;
|
||||||
|
radio.parentElement.classList.remove("unfocused");
|
||||||
radio.checked = true;
|
radio.checked = true;
|
||||||
|
validatorFunc();
|
||||||
} else if (!modalClosed) {
|
} else if (!modalClosed) {
|
||||||
setTimeout(checkVerified, 1500);
|
setTimeout(checkVerified, 1500);
|
||||||
}
|
}
|
||||||
@ -130,8 +133,11 @@ if (window.discordEnabled) {
|
|||||||
setTimeout(window.discordModal.close, 2000);
|
setTimeout(window.discordModal.close, 2000);
|
||||||
discordButton.classList.add("unfocused");
|
discordButton.classList.add("unfocused");
|
||||||
document.getElementById("contact-via").classList.remove("unfocused");
|
document.getElementById("contact-via").classList.remove("unfocused");
|
||||||
|
document.getElementById("contact-via-email").parentElement.classList.remove("unfocused");
|
||||||
const radio = document.getElementById("contact-via-discord") as HTMLInputElement;
|
const radio = document.getElementById("contact-via-discord") as HTMLInputElement;
|
||||||
|
radio.parentElement.classList.remove("unfocused")
|
||||||
radio.checked = true;
|
radio.checked = true;
|
||||||
|
validatorFunc();
|
||||||
} else if (!modalClosed) {
|
} else if (!modalClosed) {
|
||||||
setTimeout(checkVerified, 1500);
|
setTimeout(checkVerified, 1500);
|
||||||
}
|
}
|
||||||
@ -188,8 +194,11 @@ if (window.matrixEnabled) {
|
|||||||
matrixPIN = input.value;
|
matrixPIN = input.value;
|
||||||
matrixButton.classList.add("unfocused");
|
matrixButton.classList.add("unfocused");
|
||||||
document.getElementById("contact-via").classList.remove("unfocused");
|
document.getElementById("contact-via").classList.remove("unfocused");
|
||||||
const radio = document.getElementById("contact-via-discord") as HTMLInputElement;
|
document.getElementById("contact-via-email").parentElement.classList.remove("unfocused");
|
||||||
|
const radio = document.getElementById("contact-via-matrix") as HTMLInputElement;
|
||||||
|
radio.parentElement.classList.remove("unfocused");
|
||||||
radio.checked = true;
|
radio.checked = true;
|
||||||
|
validatorFunc();
|
||||||
} else {
|
} else {
|
||||||
window.notifications.customError("errorInvalidPIN", window.messages["errorInvalidPIN"]);
|
window.notifications.customError("errorInvalidPIN", window.messages["errorInvalidPIN"]);
|
||||||
submitButton.classList.add("~critical");
|
submitButton.classList.add("~critical");
|
||||||
@ -227,25 +236,85 @@ if (window.userExpiryEnabled) {
|
|||||||
const form = document.getElementById("form-create") as HTMLFormElement;
|
const form = document.getElementById("form-create") as HTMLFormElement;
|
||||||
const submitButton = form.querySelector("input[type=submit]") as HTMLInputElement;
|
const submitButton = form.querySelector("input[type=submit]") as HTMLInputElement;
|
||||||
const submitSpan = form.querySelector("span.submit") as HTMLSpanElement;
|
const submitSpan = form.querySelector("span.submit") as HTMLSpanElement;
|
||||||
|
const submitText = submitSpan.textContent;
|
||||||
let usernameField = document.getElementById("create-username") as HTMLInputElement;
|
let usernameField = document.getElementById("create-username") as HTMLInputElement;
|
||||||
const emailField = document.getElementById("create-email") as HTMLInputElement;
|
const emailField = document.getElementById("create-email") as HTMLInputElement;
|
||||||
if (!window.usernameEnabled) { usernameField.parentElement.remove(); usernameField = emailField; }
|
if (!window.usernameEnabled) { usernameField.parentElement.remove(); usernameField = emailField; }
|
||||||
const passwordField = document.getElementById("create-password") as HTMLInputElement;
|
const passwordField = document.getElementById("create-password") as HTMLInputElement;
|
||||||
const rePasswordField = document.getElementById("create-reenter-password") as HTMLInputElement;
|
const rePasswordField = document.getElementById("create-reenter-password") as HTMLInputElement;
|
||||||
|
|
||||||
if (window.emailRequired) {
|
let captchaVerified = false;
|
||||||
emailField.addEventListener("keyup", () => {
|
let captchaID = "";
|
||||||
if (emailField.value.includes("@")) {
|
let captchaInput = document.getElementById("captcha-input") as HTMLInputElement;
|
||||||
submitButton.disabled = false;
|
const captchaCheckbox = document.getElementById("captcha-success") as HTMLSpanElement;
|
||||||
submitSpan.removeAttribute("disabled");
|
let prevCaptcha = "";
|
||||||
} else {
|
|
||||||
submitButton.disabled = true;
|
function baseValidator(oncomplete: (valid: boolean) => void): void {
|
||||||
submitSpan.setAttribute("disabled", "");
|
let captchaChecked = false;
|
||||||
|
let captchaChange = false;
|
||||||
|
if (window.captcha) {
|
||||||
|
captchaChange = captchaInput.value != prevCaptcha;
|
||||||
|
if (captchaChange) {
|
||||||
|
prevCaptcha = captchaInput.value;
|
||||||
|
_post("/captcha/verify/" + window.code + "/" + captchaID + "/" + captchaInput.value, null, (req: XMLHttpRequest) => {
|
||||||
|
if (req.readyState == 4) {
|
||||||
|
if (req.status == 204) {
|
||||||
|
captchaCheckbox.innerHTML = `<i class="ri-check-line"></i>`;
|
||||||
|
captchaCheckbox.classList.add("~positive");
|
||||||
|
captchaCheckbox.classList.remove("~critical");
|
||||||
|
captchaVerified = true;
|
||||||
|
captchaChecked = true;
|
||||||
|
} else {
|
||||||
|
captchaCheckbox.innerHTML = `<i class="ri-close-line"></i>`;
|
||||||
|
captchaCheckbox.classList.add("~critical");
|
||||||
|
captchaCheckbox.classList.remove("~positive");
|
||||||
|
captchaVerified = false;
|
||||||
|
captchaChecked = true;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
|
if (window.emailRequired) {
|
||||||
|
if (!emailField.value.includes("@")) {
|
||||||
|
oncomplete(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (window.discordEnabled && window.discordRequired && !discordVerified) {
|
||||||
|
oncomplete(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (window.telegramEnabled && window.telegramRequired && !telegramVerified) {
|
||||||
|
oncomplete(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (window.matrixEnabled && window.matrixRequired && !matrixVerified) {
|
||||||
|
oncomplete(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (window.captcha) {
|
||||||
|
if (!captchaChange) {
|
||||||
|
oncomplete(captchaVerified);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
while (!captchaChecked) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
oncomplete(captchaVerified);
|
||||||
|
} else {
|
||||||
|
oncomplete(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var requirements = initValidator(passwordField, rePasswordField, submitButton, submitSpan)
|
let r = initValidator(passwordField, rePasswordField, submitButton, submitSpan, baseValidator);
|
||||||
|
var requirements = r[0];
|
||||||
|
var validatorFunc = r[1] as () => void;
|
||||||
|
|
||||||
|
if (window.emailRequired) {
|
||||||
|
emailField.addEventListener("keyup", validatorFunc)
|
||||||
|
}
|
||||||
|
|
||||||
interface respDTO {
|
interface respDTO {
|
||||||
response: boolean;
|
response: boolean;
|
||||||
@ -267,10 +336,6 @@ interface sendDTO {
|
|||||||
captcha_text?: string;
|
captcha_text?: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
let captchaVerified = false;
|
|
||||||
let captchaID = "";
|
|
||||||
let captchaInput = document.getElementById("captcha-input") as HTMLInputElement;
|
|
||||||
|
|
||||||
const genCaptcha = () => {
|
const genCaptcha = () => {
|
||||||
_get("/captcha/gen/"+window.code, null, (req: XMLHttpRequest) => {
|
_get("/captcha/gen/"+window.code, null, (req: XMLHttpRequest) => {
|
||||||
if (req.readyState == 4) {
|
if (req.readyState == 4) {
|
||||||
@ -288,27 +353,7 @@ const genCaptcha = () => {
|
|||||||
if (window.captcha) {
|
if (window.captcha) {
|
||||||
genCaptcha();
|
genCaptcha();
|
||||||
(document.getElementById("captcha-regen") as HTMLSpanElement).onclick = genCaptcha;
|
(document.getElementById("captcha-regen") as HTMLSpanElement).onclick = genCaptcha;
|
||||||
const input = document.querySelector("input[type=submit]") as HTMLInputElement;
|
captchaInput.onkeyup = validatorFunc;
|
||||||
const checkbox = document.getElementById("captcha-success") as HTMLSpanElement;
|
|
||||||
captchaInput.onkeyup = () => _post("/captcha/verify/" + window.code + "/" + captchaID + "/" + captchaInput.value, null, (req: XMLHttpRequest) => {
|
|
||||||
if (req.readyState == 4) {
|
|
||||||
if (req.status == 204) {
|
|
||||||
input.disabled = false;
|
|
||||||
input.nextElementSibling.removeAttribute("disabled");
|
|
||||||
checkbox.innerHTML = `<i class="ri-check-line"></i>`;
|
|
||||||
checkbox.classList.add("~positive");
|
|
||||||
checkbox.classList.remove("~critical");
|
|
||||||
} else {
|
|
||||||
input.disabled = true;
|
|
||||||
input.nextElementSibling.setAttribute("disabled", "true");
|
|
||||||
checkbox.innerHTML = `<i class="ri-close-line"></i>`;
|
|
||||||
checkbox.classList.add("~critical");
|
|
||||||
checkbox.classList.remove("~positive");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, );
|
|
||||||
input.disabled = true;
|
|
||||||
input.nextElementSibling.setAttribute("disabled", "true");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const create = (event: SubmitEvent) => {
|
const create = (event: SubmitEvent) => {
|
||||||
@ -361,9 +406,15 @@ const create = (event: SubmitEvent) => {
|
|||||||
} else {
|
} else {
|
||||||
submitSpan.classList.add("~critical");
|
submitSpan.classList.add("~critical");
|
||||||
submitSpan.classList.remove("~urge");
|
submitSpan.classList.remove("~urge");
|
||||||
|
if (req.response["error"] as string) {
|
||||||
|
submitSpan.textContent = window.messages[req.response["error"]];
|
||||||
|
} else {
|
||||||
|
submitSpan.textContent = window.messages["errorPassword"];
|
||||||
|
}
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
submitSpan.classList.add("~urge");
|
submitSpan.classList.add("~urge");
|
||||||
submitSpan.classList.remove("~critical");
|
submitSpan.classList.remove("~critical");
|
||||||
|
submitSpan.textContent = submitText;
|
||||||
}, 1000);
|
}, 1000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -376,17 +427,18 @@ const create = (event: SubmitEvent) => {
|
|||||||
window.confirmationModal.show();
|
window.confirmationModal.show();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const old = submitSpan.textContent;
|
|
||||||
if (req.response["error"] in window.messages) {
|
if (req.response["error"] in window.messages) {
|
||||||
submitSpan.textContent = window.messages[req.response["error"]];
|
submitSpan.textContent = window.messages[req.response["error"]];
|
||||||
} else {
|
} else {
|
||||||
submitSpan.textContent = req.response["error"];
|
submitSpan.textContent = req.response["error"];
|
||||||
}
|
}
|
||||||
setTimeout(() => { submitSpan.textContent = old; }, 1000);
|
setTimeout(() => { submitSpan.textContent = submitText; }, 1000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
validatorFunc();
|
||||||
|
|
||||||
form.onsubmit = create;
|
form.onsubmit = create;
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
interface valWindow extends Window {
|
interface valWindow extends Window {
|
||||||
validationStrings: pwValStrings;
|
validationStrings: pwValStrings;
|
||||||
invalidPassword: string;
|
invalidPassword: string;
|
||||||
|
messages: { [key: string]: string };
|
||||||
}
|
}
|
||||||
|
|
||||||
interface pwValString {
|
interface pwValString {
|
||||||
@ -59,7 +60,7 @@ class Requirement {
|
|||||||
validate = (count: number) => { this.valid = (count >= this._minCount); }
|
validate = (count: number) => { this.valid = (count >= this._minCount); }
|
||||||
}
|
}
|
||||||
|
|
||||||
export function initValidator(passwordField: HTMLInputElement, rePasswordField: HTMLInputElement, submitButton: HTMLInputElement, submitSpan: HTMLSpanElement): { [category: string]: Requirement } {
|
export function initValidator(passwordField: HTMLInputElement, rePasswordField: HTMLInputElement, submitButton: HTMLInputElement, submitSpan: HTMLSpanElement, validatorFunc?: (oncomplete: (valid: boolean) => void) => void): ({ [category: string]: Requirement }|(() => void))[] {
|
||||||
var defaultPwValStrings: pwValStrings = {
|
var defaultPwValStrings: pwValStrings = {
|
||||||
length: {
|
length: {
|
||||||
singular: "Must have at least {n} character",
|
singular: "Must have at least {n} character",
|
||||||
@ -84,18 +85,30 @@ export function initValidator(passwordField: HTMLInputElement, rePasswordField:
|
|||||||
}
|
}
|
||||||
|
|
||||||
const checkPasswords = () => {
|
const checkPasswords = () => {
|
||||||
if (passwordField.value != rePasswordField.value) {
|
return passwordField.value == rePasswordField.value;
|
||||||
rePasswordField.setCustomValidity(window.invalidPassword);
|
}
|
||||||
submitButton.disabled = true;
|
|
||||||
submitSpan.setAttribute("disabled", "");
|
const checkValidity = () => {
|
||||||
} else {
|
const pw = checkPasswords();
|
||||||
rePasswordField.setCustomValidity("");
|
validatorFunc((valid: boolean) => {
|
||||||
submitButton.disabled = false;
|
if (pw && valid) {
|
||||||
submitSpan.removeAttribute("disabled");
|
rePasswordField.setCustomValidity("");
|
||||||
}
|
submitButton.disabled = false;
|
||||||
|
submitSpan.removeAttribute("disabled");
|
||||||
|
} else if (!pw) {
|
||||||
|
rePasswordField.setCustomValidity(window.invalidPassword);
|
||||||
|
submitButton.disabled = true;
|
||||||
|
submitSpan.setAttribute("disabled", "");
|
||||||
|
} else {
|
||||||
|
rePasswordField.setCustomValidity("");
|
||||||
|
submitButton.disabled = true;
|
||||||
|
submitSpan.setAttribute("disabled", "");
|
||||||
|
}
|
||||||
|
});
|
||||||
};
|
};
|
||||||
rePasswordField.addEventListener("keyup", checkPasswords);
|
|
||||||
passwordField.addEventListener("keyup", checkPasswords);
|
rePasswordField.addEventListener("keyup", checkValidity);
|
||||||
|
passwordField.addEventListener("keyup", checkValidity);
|
||||||
|
|
||||||
|
|
||||||
// Incredible code right here
|
// Incredible code right here
|
||||||
@ -150,5 +163,5 @@ export function initValidator(passwordField: HTMLInputElement, rePasswordField:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return requirements
|
return [requirements, checkValidity]
|
||||||
}
|
}
|
||||||
|
1
views.go
1
views.go
@ -316,6 +316,7 @@ func (app *appContext) GenCaptcha(gc *gin.Context) {
|
|||||||
captchaID := genAuthToken()
|
captchaID := genAuthToken()
|
||||||
inv.Captchas[captchaID] = capt
|
inv.Captchas[captchaID] = capt
|
||||||
app.storage.invites[code] = inv
|
app.storage.invites[code] = inv
|
||||||
|
app.storage.storeInvites()
|
||||||
gc.JSON(200, genCaptchaDTO{captchaID})
|
gc.JSON(200, genCaptchaDTO{captchaID})
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user