From 93a927b130ba09cea29aba2077848f785ac48844 Mon Sep 17 00:00:00 2001 From: Mikko Portti Date: Thu, 16 Nov 2023 00:29:31 +0200 Subject: Fixing navigation on site in case of redirect --- SCHEMA.sql | 5 +++++ TABLES | 5 ----- nick.py | 2 +- routes.py | 12 +++++++----- static/menu.js | 18 ++++++++++++------ static/pages.json | 5 +++++ 6 files changed, 30 insertions(+), 17 deletions(-) create mode 100644 SCHEMA.sql delete mode 100644 TABLES diff --git a/SCHEMA.sql b/SCHEMA.sql new file mode 100644 index 0000000..1c5c372 --- /dev/null +++ b/SCHEMA.sql @@ -0,0 +1,5 @@ +CREATE TABLE users ( + id SERIAL PRIMARY KEY, + nick TEXT, + created INT +); diff --git a/TABLES b/TABLES deleted file mode 100644 index 1c5c372..0000000 --- a/TABLES +++ /dev/null @@ -1,5 +0,0 @@ -CREATE TABLE users ( - id SERIAL PRIMARY KEY, - nick TEXT, - created INT -); diff --git a/nick.py b/nick.py index 438dc8e..f476d29 100644 --- a/nick.py +++ b/nick.py @@ -16,7 +16,7 @@ def new_nick(): session["id"] = D.user_new(nick) return redirect("/") session["alert"]="Nick in not created: "+msg - return redirect("/#create") + return redirect("/#nick") def invalid_nick(nick): diff --git a/routes.py b/routes.py index fde054f..b38cf3c 100644 --- a/routes.py +++ b/routes.py @@ -7,8 +7,6 @@ def get_alert(): del session["alert"] return f"{alert}" return "" - - @app.route("/") def index(): @@ -21,21 +19,25 @@ def info(): @app.route("/pages/create.html") def create(): if "id" not in session: - return render_template("nick.html", alert=get_alert() ) + return "redirect = #nick" return render_template("create.html", alert=get_alert() ) @app.route("/pages/answer.html") def answer(): if "id" not in session: - return render_template("nick.html", alert=get_alert() ) + return "redirect = #nick" return render_template("answer.html", alert=get_alert() ) @app.route("/pages/analyse.html") def analyse(): if "id" not in session: - return render_template("nick.html", alert=get_alert() ) + return "redirect = #nick" return render_template("analyse.html", alert=get_alert() ) @app.route("/pages/moderate.html") def moderate(): return render_template("moderate.html", alert=get_alert() ) + +@app.route("/pages/nick.html") +def nick(): + return render_template("nick.html", alert=get_alert() ) 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`) diff --git a/static/pages.json b/static/pages.json index 4935c1d..4a18ca9 100644 --- a/static/pages.json +++ b/static/pages.json @@ -27,6 +27,11 @@ "pageTitle": "Moderoi sivustoa", "URL": "pages/moderate.html", "menuName": "Moderoi" + }, + "nick": { + "pageTitle": "Anna nimimerkki", + "URL": "pages/nick.html", + "hidden": "yes" } } } -- cgit v1.2.3