From 46e8097001aa29c27a5acce59f5c2ad83e850630 Mon Sep 17 00:00:00 2001 From: Frederick Yin Date: Sun, 24 Oct 2021 23:36:37 +0800 Subject: Separate admin routes to a blueprint Because modularity --- jimbrella/admin.py | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 jimbrella/admin.py (limited to 'jimbrella/admin.py') diff --git a/jimbrella/admin.py b/jimbrella/admin.py new file mode 100644 index 0000000..df751ee --- /dev/null +++ b/jimbrella/admin.py @@ -0,0 +1,52 @@ +from flask import Blueprint, request, render_template, redirect, url_for +from user_agents import parse as user_agent +from .database import Database +from .config import * + +bp = Blueprint("admin", __name__, url_prefix="/admin") +db = Database(DATABASE_PATH) + + +@bp.route("/") +def index(): + umbrellas = db.read() + statuses = Database.group_by_status(umbrellas) + return render_template( + "admin/index.html", + umbrellas=umbrellas, + available=statuses["available"], + lent=statuses["lent"], + overdue=statuses["overdue"], + mobile=user_agent(request.user_agent.string).is_mobile, + ) + + +@bp.route("/umbrellas") +def umbrellas(): + umbrellas = db.read() + edit = request.args.get("edit") + return render_template( + "admin/umbrellas.html", + umbrellas=umbrellas, + edit=int(edit) if edit else None, + mobile=user_agent(request.user_agent.string).is_mobile, + ) + + +@bp.route("/umbrellas/edit", methods=["POST"]) +def umbrellas_edit(): + data = {} + for key in [ + "serial", + "alias", + "status", + "tenant_name", + "tenant_id", + "tenant_phone", + "tenant_email", + "lent_at", + ]: + data[key] = request.form.get(key) + + db.update(data) + return redirect(url_for("admin.umbrellas")) -- cgit v1.2.3