Add auth-menu fragment handler to account app
All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 42s
All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 42s
Phase 2 of fragment composition: account exposes auth-menu fragment (sign-in button or user email for desktop + mobile) via /internal/fragments/ endpoint. Updates shared submodule. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -2,11 +2,14 @@
|
|||||||
|
|
||||||
Exposes HTML fragments at ``/internal/fragments/<type>`` for consumption
|
Exposes HTML fragments at ``/internal/fragments/<type>`` for consumption
|
||||||
by other coop apps via the fragment client.
|
by other coop apps via the fragment client.
|
||||||
|
|
||||||
|
Fragments:
|
||||||
|
auth-menu Desktop + mobile auth menu (sign-in or user link)
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
from quart import Blueprint, Response, request
|
from quart import Blueprint, Response, request, render_template
|
||||||
|
|
||||||
from shared.infrastructure.fragments import FRAGMENT_HEADER
|
from shared.infrastructure.fragments import FRAGMENT_HEADER
|
||||||
|
|
||||||
@@ -14,7 +17,24 @@ from shared.infrastructure.fragments import FRAGMENT_HEADER
|
|||||||
def register():
|
def register():
|
||||||
bp = Blueprint("fragments", __name__, url_prefix="/internal/fragments")
|
bp = Blueprint("fragments", __name__, url_prefix="/internal/fragments")
|
||||||
|
|
||||||
_handlers: dict[str, object] = {}
|
# ---------------------------------------------------------------
|
||||||
|
# Fragment handlers
|
||||||
|
# ---------------------------------------------------------------
|
||||||
|
|
||||||
|
async def _auth_menu():
|
||||||
|
user_email = request.args.get("email", "")
|
||||||
|
return await render_template(
|
||||||
|
"fragments/auth_menu.html",
|
||||||
|
user_email=user_email,
|
||||||
|
)
|
||||||
|
|
||||||
|
_handlers = {
|
||||||
|
"auth-menu": _auth_menu,
|
||||||
|
}
|
||||||
|
|
||||||
|
# ---------------------------------------------------------------
|
||||||
|
# Routing
|
||||||
|
# ---------------------------------------------------------------
|
||||||
|
|
||||||
@bp.before_request
|
@bp.before_request
|
||||||
async def _require_fragment_header():
|
async def _require_fragment_header():
|
||||||
@@ -29,6 +49,4 @@ def register():
|
|||||||
html = await handler()
|
html = await handler()
|
||||||
return Response(html, status=200, content_type="text/html")
|
return Response(html, status=200, content_type="text/html")
|
||||||
|
|
||||||
bp._fragment_handlers = _handlers
|
|
||||||
|
|
||||||
return bp
|
return bp
|
||||||
|
|||||||
2
shared
2
shared
Submodule shared updated: b882770828...2a9dfaa749
36
templates/fragments/auth_menu.html
Normal file
36
templates/fragments/auth_menu.html
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
{# Desktop auth menu #}
|
||||||
|
<span id="auth-menu-desktop">
|
||||||
|
{% if user_email %}
|
||||||
|
<a
|
||||||
|
href="{{ account_url('/') }}"
|
||||||
|
class="justify-center cursor-pointer flex flex-row items-center p-3 gap-2 rounded bg-stone-200 text-black {{ select_colours }}"
|
||||||
|
data-close-details
|
||||||
|
>
|
||||||
|
<i class="fa-solid fa-user"></i>
|
||||||
|
<span>{{ user_email }}</span>
|
||||||
|
</a>
|
||||||
|
{% else %}
|
||||||
|
<a
|
||||||
|
href="{{ account_url('/') }}"
|
||||||
|
class="justify-center cursor-pointer flex flex-row items-center p-3 gap-2 rounded bg-stone-200 text-black {{ select_colours }}"
|
||||||
|
data-close-details
|
||||||
|
>
|
||||||
|
<i class="fa-solid fa-key"></i>
|
||||||
|
<span>sign in or register</span>
|
||||||
|
</a>
|
||||||
|
{% endif %}
|
||||||
|
</span>
|
||||||
|
{# Mobile auth menu #}
|
||||||
|
<span id="auth-menu-mobile">
|
||||||
|
{% if user_email %}
|
||||||
|
<a href="{{ account_url('/') }}" data-close-details>
|
||||||
|
<i class="fa-solid fa-user"></i>
|
||||||
|
<span>{{ user_email }}</span>
|
||||||
|
</a>
|
||||||
|
{% else %}
|
||||||
|
<a href="{{ account_url('/') }}">
|
||||||
|
<i class="fa-solid fa-key"></i>
|
||||||
|
<span>sign in or register</span>
|
||||||
|
</a>
|
||||||
|
{% endif %}
|
||||||
|
</span>
|
||||||
Reference in New Issue
Block a user