82 lines
3.3 KiB
Python
82 lines
3.3 KiB
Python
from fastapi import APIRouter, Depends, HTTPException
|
|
from sqlalchemy.orm import Session
|
|
from datetime import datetime, timezone
|
|
|
|
from database import get_db
|
|
from models.settings import PosSettings
|
|
from schemas.settings import UpdateSettingRequest
|
|
from routers.deps import get_current_user, require_manager
|
|
from models.user import User
|
|
|
|
router = APIRouter()
|
|
|
|
VALID_SETTINGS = {
|
|
"shifts.waiter_self_start": "Allow waiters to start their own shifts without manager action",
|
|
"shifts.waiter_self_end": "Allow waiters to end their own shifts without manager action",
|
|
"business_day.force_close_allowed": "Allow force-closing business day with open tables",
|
|
"system.timezone": "IANA timezone name used by the backend container (e.g. Europe/Athens). Requires container restart to take effect.",
|
|
"ui.table_colours": "JSON blob of table card colour scheme (light + dark modes) for the Waiter PWA.",
|
|
"dev.spoof_printing": "When enabled, all print jobs are silently dropped. Devices behave as if printing succeeded.",
|
|
# Print font settings — values are "SIZE:BOLD" where SIZE is ESC ! base byte (0/16/32/48) and BOLD is 0 or 1
|
|
"print.font_item_name": "Font for item name lines: SIZE:BOLD (e.g. '16:0')",
|
|
"print.font_options": "Font for option/modifier lines: SIZE:BOLD",
|
|
"print.font_table": "Font for table/waiter header lines: SIZE:BOLD",
|
|
"print.font_order_number": "Font for order number header: SIZE:BOLD",
|
|
"print.font_header": "Font for top header block: SIZE:BOLD",
|
|
"print.divider_style": "Divider character used between sections: dash, equals, star, or empty",
|
|
}
|
|
|
|
DEFAULTS = {
|
|
"shifts.waiter_self_start": "true",
|
|
"shifts.waiter_self_end": "true",
|
|
"business_day.force_close_allowed": "true",
|
|
"system.timezone": "Europe/Athens",
|
|
"ui.table_colours": "",
|
|
"dev.spoof_printing": "false",
|
|
"print.font_item_name": "16:0", # double-height, no bold
|
|
"print.font_options": "0:0", # normal
|
|
"print.font_table": "16:0", # double-height
|
|
"print.font_order_number": "48:1", # double-height + double-width + bold
|
|
"print.font_header": "48:1", # double-height + double-width + bold
|
|
"print.divider_style": "dash",
|
|
}
|
|
|
|
|
|
@router.get("/")
|
|
def get_all_settings(
|
|
db: Session = Depends(get_db),
|
|
user: User = Depends(get_current_user),
|
|
):
|
|
stored = {s.key: s.value for s in db.query(PosSettings).all()}
|
|
result = {}
|
|
for key, description in VALID_SETTINGS.items():
|
|
result[key] = {
|
|
"value": stored.get(key, DEFAULTS.get(key, "true")),
|
|
"description": description,
|
|
}
|
|
return result
|
|
|
|
|
|
@router.put("/{key}")
|
|
def update_setting(
|
|
key: str,
|
|
body: UpdateSettingRequest,
|
|
db: Session = Depends(get_db),
|
|
user: User = Depends(require_manager),
|
|
):
|
|
if key not in VALID_SETTINGS:
|
|
raise HTTPException(status_code=400, detail=f"Unknown setting key: {key}")
|
|
|
|
setting = db.query(PosSettings).filter(PosSettings.key == key).first()
|
|
if setting:
|
|
setting.value = body.value
|
|
setting.updated_at = datetime.now(timezone.utc)
|
|
setting.updated_by_id = user.id
|
|
else:
|
|
setting = PosSettings(key=key, value=body.value, updated_by_id=user.id)
|
|
db.add(setting)
|
|
|
|
db.commit()
|
|
db.refresh(setting)
|
|
return {"key": setting.key, "value": setting.value}
|