achievements_project/frontend/webpage/static/scripts/common.js

120 lines
3.2 KiB
JavaScript
Raw Normal View History

2021-02-16 19:11:12 +00:00
let root = null;
const loadRoot = () => {
const rootElement = document.documentElement;
root = {};
root.getProperty = (name) => window.getComputedStyle(document.documentElement).getPropertyValue(name);
root.setProperty = (name, value) => {
rootElement.style.setProperty(name, value);
}
};
2021-02-19 20:49:24 +00:00
let session = { id: null };
const clearSession = () => session = { id: null };
2021-02-16 19:11:12 +00:00
const loadSession = async () => {
window.addEventListener('beforeunload', (beforeUnloadEvent) => {
2021-02-19 20:49:24 +00:00
window.sessionStorage.setItem('session', JSON.stringify(session));
2021-02-16 19:11:12 +00:00
});
2021-02-19 20:49:24 +00:00
session = JSON.parse(window.sessionStorage.getItem('session')) || { id: -1 };
if (session.hue) {
2021-02-16 19:11:12 +00:00
root.setProperty('--accent-hue', session.hue);
2021-02-19 20:49:24 +00:00
}
2021-02-16 19:11:12 +00:00
2021-02-19 20:49:24 +00:00
if (session.id !== null) {
2021-02-16 19:11:12 +00:00
await fetch(`/api/auth/refresh`, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
2021-02-19 20:49:24 +00:00
body: JSON.stringify({ key: session.key, id: session.id })
2021-02-16 19:11:12 +00:00
})
.then(async response => ({ status: response.status, data: await response.json() }))
.then(response => {
2021-02-19 20:49:24 +00:00
if (response.status !== 200 && window.location.pathname !== "/login") {
session.id = null;
session.key = null;
if (session.id !== -1) {
window.location.href = "/login";
}
} else {
session.key = response.data.key;
session.id = response.data.id;
if (session.id === -1 && window.location.pathname !== '/import') {
window.location.href = '/import';
}
2021-02-16 19:11:12 +00:00
}
});
}
};
2021-02-19 20:49:24 +00:00
const authenticate = (obj) => {
obj.sessionKey = session.key;
obj.userId = session.id;
return obj;
}
2021-02-16 19:11:12 +00:00
const loadCommon = async () => {
loadRoot();
await loadSession();
}
const commonTemplates = async () => {
template.apply("navbar").values([
{ section: "left" },
{ section: "right" }
]);
template.apply("navbar-section-left").values([
{ item: "achievements", title: "Achievements" },
{ item: "users", title: "Users" },
{ item: "games", title: "Games" },
{ item: "import", title: "Import" }
2021-02-16 19:11:12 +00:00
]);
2021-02-19 20:49:24 +00:00
if (session.id !== -1 && session.id !== null) {
2021-02-16 19:11:12 +00:00
template.apply("navbar-section-right").values([
{ item: "profile", title: "Profile" },
{ item: "logout", title: "Logout" }
]);
} else {
template.apply("navbar-section-right").values([
{ item: "login", title: "Login / Create Account" }
2021-02-16 19:11:12 +00:00
]);
}
};
const loadLazyImages = () => {
const imgs = document.querySelectorAll(".lazy-img");
for (const img of imgs) {
img.src = img.dataset.src;
}
}
2021-02-16 19:11:12 +00:00
const connectNavbar = () => {
2021-02-19 20:49:24 +00:00
if (session.id !== -1) {
const navItems = document.querySelectorAll(".navbar-item");
2021-02-16 19:11:12 +00:00
2021-02-19 20:49:24 +00:00
if (!session.admin) {
document.querySelector("#navbar-item-import").remove();
}
2021-02-19 20:49:24 +00:00
for (const item of navItems) {
if (item.dataset.pageName === "logout") {
item.addEventListener("click", (clickEvent) => {
fetch(`/api/auth/logout`, {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({ key: session.key })
});
clearSession();
window.location.href = "/login";
2021-02-16 19:11:12 +00:00
});
2021-02-19 20:49:24 +00:00
} else if (item.dataset.pageName === "profile") {
item.addEventListener("click", (clickEvent) => window.location.href = `/user/${session.id}`);
} else {
item.addEventListener("click", (clickEvent) => window.location.href = `/${item.dataset.pageName}`);
}
2021-02-16 19:11:12 +00:00
}
}
};