- Implemented a new HTML page for generating service contract reports. - Added CSS styles for report layout and components. - Developed JavaScript functionality for loading customers and contracts, fetching report data, and rendering metrics and cases. - Included buttons for downloading reports in PDF and Excel formats. docs: Create Route Auth Audit for route access control - Generated an audit report detailing route access requirements. - Classified routes based on authentication needs and documented them in a markdown file. feat: Introduce buzzwords and mission projects tables in the database - Created `buzzwords` and `sag_buzzwords` tables for managing keywords related to SAG cases. - Established `mission_projects`, `mission_project_milestones`, and `mission_project_blockers` tables for project management. - Updated `sag_sager` table to link with mission projects and milestones, including necessary foreign key constraints.
43 lines
1.2 KiB
Python
43 lines
1.2 KiB
Python
"""
|
|
Email Frontend Views
|
|
Serves the email management UI
|
|
"""
|
|
|
|
from fastapi import APIRouter, Request
|
|
from fastapi.responses import HTMLResponse
|
|
from fastapi.templating import Jinja2Templates
|
|
import logging
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
router = APIRouter()
|
|
|
|
# Setup Jinja2 templates
|
|
templates = Jinja2Templates(directory="app")
|
|
|
|
@router.get("/emails", response_class=HTMLResponse)
|
|
async def emails_page(request: Request):
|
|
"""Email management UI - 3-column modern email interface"""
|
|
return templates.TemplateResponse(
|
|
"emails/frontend/emails.html",
|
|
{"request": request, "email_ui_version": "v1"}
|
|
)
|
|
|
|
|
|
@router.get("/emails/v1", response_class=HTMLResponse)
|
|
async def emails_page_v1(request: Request):
|
|
"""Email management UI v1 (legacy/stable)."""
|
|
return templates.TemplateResponse(
|
|
"emails/frontend/emails.html",
|
|
{"request": request, "email_ui_version": "v1"}
|
|
)
|
|
|
|
|
|
@router.get("/emails/v2", response_class=HTMLResponse)
|
|
async def emails_page_v2(request: Request):
|
|
"""Email management UI v2 (simplified workflow)."""
|
|
return templates.TemplateResponse(
|
|
"emails/frontend/emails_v2.html",
|
|
{"request": request, "email_ui_version": "v2"}
|
|
)
|