# app/modules/orders/routes/pages/vendor.py """ Orders Vendor Page Routes (HTML rendering). Vendor 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_vendor_from_cookie_or_header, get_db from app.modules.core.utils.page_context import get_vendor_context from app.templates_config import templates from app.modules.tenancy.models import User router = APIRouter() # ============================================================================ # ORDER MANAGEMENT # ============================================================================ @router.get( "/{vendor_code}/orders", response_class=HTMLResponse, include_in_schema=False ) async def vendor_orders_page( request: Request, vendor_code: str = Path(..., description="Vendor code"), current_user: User = Depends(get_current_vendor_from_cookie_or_header), db: Session = Depends(get_db), ): """ Render orders management page. JavaScript loads order list via API. """ return templates.TemplateResponse( "orders/vendor/orders.html", get_vendor_context(request, db, current_user, vendor_code), ) @router.get( "/{vendor_code}/orders/{order_id}", response_class=HTMLResponse, include_in_schema=False, ) async def vendor_order_detail_page( request: Request, vendor_code: str = Path(..., description="Vendor code"), order_id: int = Path(..., description="Order ID"), current_user: User = Depends(get_current_vendor_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/vendor/order-detail.html", get_vendor_context(request, db, current_user, vendor_code, order_id=order_id), )