mirror of
https://git.tuxpa.in/a/code-server.git
synced 2025-01-06 16:58:44 +00:00
cc8c7e2cee
* Make all assets unique All CSS and JavaScript files have unique names now. I also moved the login to the /login path in order to ensure the HTML for each page is also unique. * Explicitly include assets to cache
47 lines
1.4 KiB
TypeScript
47 lines
1.4 KiB
TypeScript
//@ts-ignore
|
|
import { MDCTextField } from "@material/textfield";
|
|
//@ts-ignore
|
|
import { MDCCheckbox } from "@material/checkbox";
|
|
import "material-components-web/dist/material-components-web.css";
|
|
import "./app.scss";
|
|
|
|
document.querySelectorAll(".mdc-text-field").forEach((d) => new MDCTextField(d));
|
|
document.querySelectorAll(".mdc-checkbox").forEach((d) => new MDCCheckbox(d));
|
|
|
|
window.addEventListener("message", (event) => {
|
|
if (event.data === "app") {
|
|
document.body.classList.add("in-app");
|
|
|
|
const back = document.querySelector(".back")!;
|
|
back.addEventListener("click", () => {
|
|
(event.source as Window).postMessage("back", event.origin);
|
|
});
|
|
}
|
|
});
|
|
|
|
const password = document.getElementById("password") as HTMLInputElement;
|
|
const form = document.getElementById("login-form") as HTMLFormElement;
|
|
|
|
if (!form) {
|
|
throw new Error("No password form found");
|
|
}
|
|
|
|
form.addEventListener("submit", (e) => {
|
|
e.preventDefault();
|
|
document.cookie = `password=${password.value}; `
|
|
+ `path=${location.pathname.replace(/\/login\/?$/, "/")}; `
|
|
+ `domain=${location.hostname}`;
|
|
location.reload();
|
|
});
|
|
|
|
/**
|
|
* Notify user on load of page if previous password was unsuccessful
|
|
*/
|
|
const reg = new RegExp(`password=(\\w+);?`);
|
|
const matches = document.cookie.match(reg);
|
|
const errorDisplay = document.getElementById("error-display") as HTMLDivElement;
|
|
|
|
if (document.referrer === document.location.href && matches) {
|
|
errorDisplay.innerText = "Password is incorrect!";
|
|
}
|