diff options
author | Mikko Portti <mportti2@local> | 2023-11-16 00:29:31 +0200 |
---|---|---|
committer | Mikko Portti <mportti2@local> | 2023-11-16 00:29:31 +0200 |
commit | 93a927b130ba09cea29aba2077848f785ac48844 (patch) | |
tree | 05c7ae4b7df861e1efd03637c9f0cb6c45787d4b /static/menu.js | |
parent | 92b368c3486fd20e550a2ec7b8e7717f7e061c96 (diff) |
Fixing navigation on site in case of redirect
Diffstat (limited to 'static/menu.js')
-rw-r--r-- | static/menu.js | 18 |
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`) |