mirror of
https://github.com/hrfee/jfa-go.git
synced 2025-01-07 17:00:11 +00:00
Compare commits
No commits in common. "25451eb76318550689120447b818468286f3a25d" and "4deb45df3c6368d4d9e16b68d876c9d07e2a4099" have entirely different histories.
25451eb763
...
4deb45df3c
14
css/base.css
14
css/base.css
@ -181,18 +181,6 @@ 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;
|
||||||
@ -320,7 +308,7 @@ sup.\~critical, .text-critical {
|
|||||||
padding-left: 0px;
|
padding-left: 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.block {
|
.block {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -81,19 +81,19 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div id="notification-box"></div>
|
<div id="notification-box"></div>
|
||||||
<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="flex-form heading mr-5">
|
<span class="col heading">
|
||||||
{{ if .passwordReset }}
|
{{ if .passwordReset }}
|
||||||
{{ .strings.passwordReset }}
|
{{ .strings.passwordReset }}
|
||||||
{{ else }}
|
{{ else }}
|
||||||
{{ .strings.createAccountHeader }}
|
{{ .strings.createAccountHeader }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
</span>
|
</span>
|
||||||
<span class="flex-form subheading">
|
<span class="col 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="flex-form">
|
<div class="col">
|
||||||
{{ 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 }}
|
||||||
@ -112,35 +112,35 @@
|
|||||||
{{ .strings.username }}
|
{{ .strings.username }}
|
||||||
<input type="text" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.username }}" id="create-username" aria-label="{{ .strings.username }}">
|
<input type="text" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.username }}" id="create-username" aria-label="{{ .strings.username }}">
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
<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 }} {{ if .telegramRequired }}({{ .strings.required }}){{ end }}</span>
|
<span class="button ~info @low full-width center mb-4" id="link-telegram">{{ .strings.linkTelegram }}</span>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .discordEnabled }}
|
{{ if .discordEnabled }}
|
||||||
<span class="button ~info @low full-width center mb-4" id="link-discord">{{ .strings.linkDiscord }} {{ if .discordRequired }}({{ .strings.required }}){{ end }}</span>
|
<span class="button ~info @low full-width center mb-4" id="link-discord">{{ .strings.linkDiscord }}</span>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .matrixEnabled }}
|
{{ if .matrixEnabled }}
|
||||||
<span class="button ~info @low full-width center mb-4" id="link-matrix">{{ .strings.linkMatrix }} {{ if .matrixRequired }}({{ .strings.required }}){{ end }}</span>
|
<span class="button ~info @low full-width center mb-4" id="link-matrix">{{ .strings.linkMatrix }}</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 unfocused">
|
<label class="row switch pb-4">
|
||||||
<input type="radio" name="contact-via" value="email" id="contact-via-email" class="mr-2"><span>Contact through Email</span>
|
<input type="radio" name="contact-via" value="email" class="mr-2"><span>Contact through Email</span>
|
||||||
</label>
|
</label>
|
||||||
{{ if .telegramEnabled }}
|
{{ if .telegramEnabled }}
|
||||||
<label class="row switch pb-4 unfocused">
|
<label class="row switch pb-4">
|
||||||
<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 unfocused">
|
<label class="row switch pb-4">
|
||||||
<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 unfocused">
|
<label class="row switch pb-4">
|
||||||
<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 }}
|
||||||
@ -149,7 +149,7 @@
|
|||||||
{{ end }}
|
{{ end }}
|
||||||
<label class="label supra" for="create-password">{{ .strings.password }}</label>
|
<label class="label supra" for="create-password">{{ .strings.password }}</label>
|
||||||
<input type="password" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.password }}" id="create-password" aria-label="{{ .strings.password }}">
|
<input type="password" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.password }}" id="create-password" aria-label="{{ .strings.password }}">
|
||||||
|
|
||||||
<label class="label supra" for="create-reenter-password">{{ .strings.reEnterPassword }}</label>
|
<label class="label supra" for="create-reenter-password">{{ .strings.reEnterPassword }}</label>
|
||||||
<input type="password" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.password }}" id="create-reenter-password" aria-label="{{ .strings.reEnterPassword }}">
|
<input type="password" class="input ~neutral @high mt-2 mb-4" placeholder="{{ .strings.password }}" id="create-reenter-password" aria-label="{{ .strings.reEnterPassword }}">
|
||||||
<label>
|
<label>
|
||||||
|
@ -23,7 +23,6 @@
|
|||||||
"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,8 +31,6 @@
|
|||||||
"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": {
|
||||||
|
130
ts/form.ts
130
ts/form.ts
@ -70,11 +70,8 @@ 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);
|
||||||
}
|
}
|
||||||
@ -133,11 +130,8 @@ 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);
|
||||||
}
|
}
|
||||||
@ -194,11 +188,8 @@ 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");
|
||||||
document.getElementById("contact-via-email").parentElement.classList.remove("unfocused");
|
const radio = document.getElementById("contact-via-discord") as HTMLInputElement;
|
||||||
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");
|
||||||
@ -236,86 +227,26 @@ 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;
|
||||||
|
|
||||||
let captchaVerified = false;
|
|
||||||
let captchaID = "";
|
|
||||||
let captchaInput = document.getElementById("captcha-input") as HTMLInputElement;
|
|
||||||
const captchaCheckbox = document.getElementById("captcha-success") as HTMLSpanElement;
|
|
||||||
let prevCaptcha = "";
|
|
||||||
|
|
||||||
function baseValidator(oncomplete: (valid: boolean) => void): void {
|
|
||||||
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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let r = initValidator(passwordField, rePasswordField, submitButton, submitSpan, baseValidator);
|
|
||||||
var requirements = r[0];
|
|
||||||
var validatorFunc = r[1] as () => void;
|
|
||||||
|
|
||||||
if (window.emailRequired) {
|
if (window.emailRequired) {
|
||||||
emailField.addEventListener("keyup", validatorFunc)
|
emailField.addEventListener("keyup", () => {
|
||||||
|
if (emailField.value.includes("@")) {
|
||||||
|
submitButton.disabled = false;
|
||||||
|
submitSpan.removeAttribute("disabled");
|
||||||
|
} else {
|
||||||
|
submitButton.disabled = true;
|
||||||
|
submitSpan.setAttribute("disabled", "");
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var requirements = initValidator(passwordField, rePasswordField, submitButton, submitSpan)
|
||||||
|
|
||||||
interface respDTO {
|
interface respDTO {
|
||||||
response: boolean;
|
response: boolean;
|
||||||
error: string;
|
error: string;
|
||||||
@ -336,6 +267,10 @@ 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) {
|
||||||
@ -353,7 +288,27 @@ 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;
|
||||||
captchaInput.onkeyup = validatorFunc;
|
const input = document.querySelector("input[type=submit]") as HTMLInputElement;
|
||||||
|
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) => {
|
||||||
@ -406,15 +361,9 @@ 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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -427,18 +376,17 @@ 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 = submitText; }, 1000);
|
setTimeout(() => { submitSpan.textContent = old; }, 1000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
validatorFunc();
|
|
||||||
|
|
||||||
form.onsubmit = create;
|
form.onsubmit = create;
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
interface valWindow extends Window {
|
interface valWindow extends Window {
|
||||||
validationStrings: pwValStrings;
|
validationStrings: pwValStrings;
|
||||||
invalidPassword: string;
|
invalidPassword: string;
|
||||||
messages: { [key: string]: string };
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface pwValString {
|
interface pwValString {
|
||||||
@ -60,7 +59,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, validatorFunc?: (oncomplete: (valid: boolean) => void) => void): ({ [category: string]: Requirement }|(() => void))[] {
|
export function initValidator(passwordField: HTMLInputElement, rePasswordField: HTMLInputElement, submitButton: HTMLInputElement, submitSpan: HTMLSpanElement): { [category: string]: Requirement } {
|
||||||
var defaultPwValStrings: pwValStrings = {
|
var defaultPwValStrings: pwValStrings = {
|
||||||
length: {
|
length: {
|
||||||
singular: "Must have at least {n} character",
|
singular: "Must have at least {n} character",
|
||||||
@ -85,30 +84,18 @@ export function initValidator(passwordField: HTMLInputElement, rePasswordField:
|
|||||||
}
|
}
|
||||||
|
|
||||||
const checkPasswords = () => {
|
const checkPasswords = () => {
|
||||||
return passwordField.value == rePasswordField.value;
|
if (passwordField.value != rePasswordField.value) {
|
||||||
}
|
rePasswordField.setCustomValidity(window.invalidPassword);
|
||||||
|
submitButton.disabled = true;
|
||||||
const checkValidity = () => {
|
submitSpan.setAttribute("disabled", "");
|
||||||
const pw = checkPasswords();
|
} else {
|
||||||
validatorFunc((valid: boolean) => {
|
rePasswordField.setCustomValidity("");
|
||||||
if (pw && valid) {
|
submitButton.disabled = false;
|
||||||
rePasswordField.setCustomValidity("");
|
submitSpan.removeAttribute("disabled");
|
||||||
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);
|
||||||
rePasswordField.addEventListener("keyup", checkValidity);
|
passwordField.addEventListener("keyup", checkPasswords);
|
||||||
passwordField.addEventListener("keyup", checkValidity);
|
|
||||||
|
|
||||||
|
|
||||||
// Incredible code right here
|
// Incredible code right here
|
||||||
@ -163,5 +150,5 @@ export function initValidator(passwordField: HTMLInputElement, rePasswordField:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return [requirements, checkValidity]
|
return requirements
|
||||||
}
|
}
|
||||||
|
1
views.go
1
views.go
@ -316,7 +316,6 @@ 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