Includes all work to date: - local_backend: FastAPI backend with products, orders, tables, shifts, cloud sync - manager_dashboard: React manager UI with product/category management, reports, settings - waiter_pwa: React PWA for waiter devices - Category reparent endpoint and UI - Waiter domain: local_ip sent on heartbeat, waiter_domain persisted from cloud response - QR code modal in AppInfoTab for waiter domain - Product form: number input spinners removed, category pre-selected on new product - Category row: count badge moved to far right Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
48 lines
1.0 KiB
Python
48 lines
1.0 KiB
Python
from pydantic import BaseModel
|
|
from typing import Optional, List
|
|
from datetime import datetime
|
|
|
|
|
|
class FlagDefCreate(BaseModel):
|
|
name: str
|
|
emoji: Optional[str] = None
|
|
color: Optional[str] = "#6b7280"
|
|
text_color: Optional[str] = None
|
|
sort_order: Optional[int] = 0
|
|
|
|
|
|
class FlagDefUpdate(BaseModel):
|
|
name: Optional[str] = None
|
|
emoji: Optional[str] = None
|
|
color: Optional[str] = None
|
|
text_color: Optional[str] = None
|
|
sort_order: Optional[int] = None
|
|
is_active: Optional[bool] = None
|
|
|
|
|
|
class FlagDefOut(BaseModel):
|
|
id: int
|
|
name: str
|
|
emoji: Optional[str] = None
|
|
color: Optional[str] = None
|
|
text_color: Optional[str] = None
|
|
sort_order: int
|
|
is_active: bool
|
|
|
|
model_config = {"from_attributes": True}
|
|
|
|
|
|
class FlagAssignmentOut(BaseModel):
|
|
id: int
|
|
table_id: int
|
|
flag_id: int
|
|
flag_def: Optional[FlagDefOut] = None
|
|
assigned_at: datetime
|
|
assigned_by: Optional[int] = None
|
|
|
|
model_config = {"from_attributes": True}
|
|
|
|
|
|
class SetTableFlagsRequest(BaseModel):
|
|
flag_ids: List[int]
|