# app/modules/tenancy/routes/pages/merchant.py """ Tenancy Merchant Page Routes (HTML rendering). Merchant portal pages for tenancy-related views: - Stores list (merchant's own stores) - Profile management Auto-discovered by the route system (merchant.py in routes/pages/). """ from fastapi import APIRouter, Depends, Request from fastapi.responses import HTMLResponse from sqlalchemy.orm import Session from app.api.deps import get_current_merchant_from_cookie_or_header, get_db from app.modules.core.utils.page_context import get_context_for_frontend from app.modules.enums import FrontendType from app.modules.tenancy.schemas.auth import UserContext from app.templates_config import templates router = APIRouter() ROUTE_CONFIG = { "prefix": "/account", } @router.get("/stores", response_class=HTMLResponse, include_in_schema=False) async def merchant_stores_page( request: Request, current_user: UserContext = Depends(get_current_merchant_from_cookie_or_header), db: Session = Depends(get_db), ): """ Render the merchant's stores list page. Shows all stores owned by the authenticated merchant with status and basic information. """ context = get_context_for_frontend( FrontendType.MERCHANT, request, db, user=current_user, ) return templates.TemplateResponse( "tenancy/merchant/stores.html", context, ) @router.get("/profile", response_class=HTMLResponse, include_in_schema=False) async def merchant_profile_page( request: Request, current_user: UserContext = Depends(get_current_merchant_from_cookie_or_header), db: Session = Depends(get_db), ): """ Render the merchant profile page. Shows merchant business details and allows editing contact info, business address, and tax information. """ context = get_context_for_frontend( FrontendType.MERCHANT, request, db, user=current_user, ) return templates.TemplateResponse( "tenancy/merchant/profile.html", context, )