2023-09-28 20:59:17 -04:00
|
|
|
// function anchorToId(anchor: HTMLAnchorElement) {
|
|
|
|
|
// return anchor.href.replace("./", "");
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// const stored = localStorage.getItem("expanded") ?? "[]";
|
|
|
|
|
// let parsed: string[];
|
|
|
|
|
// try {
|
|
|
|
|
// parsed = JSON.parse(stored) as string[];
|
|
|
|
|
// }
|
|
|
|
|
// catch (e) {
|
|
|
|
|
// parsed = [];
|
|
|
|
|
// }
|
|
|
|
|
// const state = new Set(parsed);
|
|
|
|
|
// const submenus = Array.from(document.querySelectorAll("#menu .submenu-item"));
|
|
|
|
|
// for (const sub of submenus) {
|
|
|
|
|
// try {
|
|
|
|
|
// if (state.has(anchorToId(sub.children[0] as HTMLAnchorElement))) sub.classList.add("expanded");
|
|
|
|
|
// }
|
|
|
|
|
// catch (e) {
|
|
|
|
|
// // TODO: create logger
|
|
|
|
|
// console.warn("Could not restore expanded state"); // eslint-disable-line no-console
|
|
|
|
|
// console.error(e); // eslint-disable-line no-console
|
|
|
|
|
// }
|
|
|
|
|
// }
|
2023-09-28 00:14:44 -04:00
|
|
|
|
2023-09-28 20:59:17 -04:00
|
|
|
// TODO: Swap this system to use type-book for full-link category
|
|
|
|
|
|
|
|
|
|
// In case a linked article lead to a new tree
|
|
|
|
|
const activeLink = document.querySelector("#menu a.active");
|
|
|
|
|
if (activeLink) {
|
|
|
|
|
let parent = activeLink.parentElement;
|
|
|
|
|
const mainMenu = document.getElementById("#menu");
|
|
|
|
|
while (parent && parent !== mainMenu) {
|
|
|
|
|
if (parent.matches(".submenu-item") && !parent.classList.contains("expanded")) {
|
|
|
|
|
parent.classList.add("expanded");
|
|
|
|
|
}
|
|
|
|
|
parent = parent.parentElement;
|
2023-09-28 00:14:44 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-27 23:18:03 -04:00
|
|
|
export default function setupExpanders() {
|
2023-09-28 20:59:17 -04:00
|
|
|
const expanders = Array.from(document.querySelectorAll("#menu .submenu-item"));
|
2023-09-27 23:18:03 -04:00
|
|
|
for (const ex of expanders) {
|
|
|
|
|
ex.addEventListener("click", e => {
|
2023-09-28 20:59:17 -04:00
|
|
|
if ((e.target as Element).closest(".submenu-item,.item") !== ex) return;
|
2023-09-27 23:18:03 -04:00
|
|
|
e.preventDefault();
|
|
|
|
|
e.stopPropagation();
|
|
|
|
|
// ex.parentElement.parentElement.classList.toggle("expanded");
|
2023-09-28 20:59:17 -04:00
|
|
|
ex.classList.toggle("expanded");
|
|
|
|
|
// const id = anchorToId(ex.closest("a")!);
|
|
|
|
|
// if (state.has(id)) state.delete(id);
|
|
|
|
|
// else state.add(id);
|
|
|
|
|
// // TODO: be able to remove all submenus of currently collapsed
|
|
|
|
|
// localStorage.setItem("expanded", JSON.stringify([...state]));
|
2023-09-27 23:18:03 -04:00
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-28 20:59:17 -04:00
|
|
|
|
2023-09-27 23:18:03 -04:00
|
|
|
}
|