summaryrefslogtreecommitdiff
path: root/static/menu.js
diff options
context:
space:
mode:
authorMikko Portti <mportti2@local>2023-11-16 00:29:31 +0200
committerMikko Portti <mportti2@local>2023-11-16 00:29:31 +0200
commit93a927b130ba09cea29aba2077848f785ac48844 (patch)
tree05c7ae4b7df861e1efd03637c9f0cb6c45787d4b /static/menu.js
parent92b368c3486fd20e550a2ec7b8e7717f7e061c96 (diff)
Fixing navigation on site in case of redirect
Diffstat (limited to 'static/menu.js')
-rw-r--r--static/menu.js18
1 files changed, 12 insertions, 6 deletions
diff --git a/static/menu.js b/static/menu.js
index a014793..ee8f977 100644
--- a/static/menu.js
+++ b/static/menu.js
@@ -76,7 +76,7 @@ createMenu = () => {
menuNav.className = 'menuHidden'
Object.keys(pages).forEach(p => {
-
+
const entryDiv = document.createElement('div')
entryDiv.className = 'menuItem'
entryDiv.id = `${p}_menuEntry`
@@ -92,6 +92,8 @@ createMenu = () => {
name === "" ? ' menuSpacer' : ' menuTitle'
else entryDiv.onclick = () => window.location.hash = p;
+ if ( pages[p].hidden ) entryDiv.style.display = 'none';
+
menuNav.append( entryDiv )
})
document.documentElement.lastChild.append( menuNav )
@@ -114,7 +116,7 @@ toggleMenu = () => {
if (menuNav.className === '') window.scrollTo(0,0)
}
-hashToPage = () => {
+hashToPage = async () => {
const p = !document.location.hash
? Object.keys(pages)[0] : document.location.hash.substr(1) in pages
? document.location.hash.substr(1) : Object.keys(pages)[0]
@@ -130,15 +132,19 @@ hashToPage = () => {
else document.getElementById(`${currentPage}_page`).className = 'page'
pageElement.className = 'page pageActive'
- if ( !pageElement.loaded ) fetch( pages[p].URL )
+ if ( !pageElement.loaded ) await fetch( pages[p].URL )
.then( response => {
if (!response.ok) return `ERROR loading "${pages[p].URL}"!`
return response.text()
} )
.then( text => {
- pageElement.innerHTML = text
- pageElement.loaded = true
- } )
+ pageElement.innerHTML = text;
+ pageElement.loaded = true;
+ } )
+ if ( pageElement.innerHTML.startsWith("redirect = ") ) {
+ pageElement.loaded = false;
+ window.location.assign( pageElement.innerHTML.slice( 11 ) );
+ }
document.getElementById(`${currentPage}_menuEntry`)
.className = 'menuItem'
document.getElementById(`${p}_menuEntry`)