From 64d51af021294ab4903928b4c7b005ee3d7edb4a Mon Sep 17 00:00:00 2001 From: Kaustubh Maske Patil <37668193+nikochiko@users.noreply.github.com> Date: Thu, 19 Oct 2023 04:16:26 +0530 Subject: [PATCH] Add better error handling for UI --- routers/root.py | 19 +++++++++++++++++++ templates/404.html | 11 ----------- templates/errors/404.html | 8 ++++++++ templates/errors/unknown.html | 8 ++++++++ 4 files changed, 35 insertions(+), 11 deletions(-) delete mode 100644 templates/404.html create mode 100644 templates/errors/404.html create mode 100644 templates/errors/unknown.html diff --git a/routers/root.py b/routers/root.py index cdbfac43b..f02c2b1c5 100644 --- a/routers/root.py +++ b/routers/root.py @@ -72,6 +72,25 @@ async def favicon(): return FileResponse("static/favicon.ico") +@app.post("/handleError/") +async def handle_error(request: Request): + context = {"request": request, "settings": settings} + + def not_found(): + st.html(templates.get_template("errors/404.html").render(**context)) + + def unknown_error(): + st.html(templates.get_template("errors/unknown.html").render(**context)) + + body = await request.json() + + match body["status"]: + case 404: + return st.runner(lambda: page_wrapper(request, not_found)) + case _: + return st.runner(lambda: page_wrapper(request, unknown_error)) + + @app.get("/login/") def login(request: Request): if request.user and not request.user.is_anonymous: diff --git a/templates/404.html b/templates/404.html deleted file mode 100644 index 7389e5072..000000000 --- a/templates/404.html +++ /dev/null @@ -1,11 +0,0 @@ -{% extends 'base.html' %} - -{% block content %} - {% include 'login_container.html' %} -