# app/modules/orders/routes/pages/store.py """ Orders Store Page Routes (HTML rendering). Store pages for order management: - Orders list - Order detail """ from fastapi import APIRouter, Depends, Path, Request from fastapi.responses import HTMLResponse from sqlalchemy.orm import Session from app.api.deps import ( get_current_store_from_cookie_or_header, get_db, get_resolved_store_code, ) from app.modules.core.utils.page_context import get_store_context from app.modules.tenancy.models import User from app.templates_config import templates router = APIRouter() # ============================================================================ # ORDER MANAGEMENT # ============================================================================ @router.get( "/orders", response_class=HTMLResponse, include_in_schema=False ) async def store_orders_page( request: Request, store_code: str = Depends(get_resolved_store_code), current_user: User = Depends(get_current_store_from_cookie_or_header), db: Session = Depends(get_db), ): """ Render orders management page. JavaScript loads order list via API. """ return templates.TemplateResponse( "orders/store/orders.html", get_store_context(request, db, current_user, store_code), ) @router.get( "/orders/{order_id}", response_class=HTMLResponse, include_in_schema=False, ) async def store_order_detail_page( request: Request, store_code: str = Depends(get_resolved_store_code), order_id: int = Path(..., description="Order ID"), current_user: User = Depends(get_current_store_from_cookie_or_header), db: Session = Depends(get_db), ): """ Render order detail page. Shows comprehensive order information including: - Order header and status - Customer and shipping details - Order items with shipment status - Invoice creation/viewing - Partial shipment controls JavaScript loads order details via API. """ return templates.TemplateResponse( "orders/store/order-detail.html", get_store_context(request, db, current_user, store_code, order_id=order_id), )