Replaces block-count progress with a wall-clock progress bar driven by configurable day start/end hours on each schedule template. - ScheduleTemplate: add day_start_time / day_end_time (TIME, nullable) - Startup migration: idempotent ALTER TABLE for existing DBs - Dashboard snapshot: includes day_start_time / day_end_time from template - Admin → Schedules: time pickers in block editor to set day hours - Dashboard view: time-based progress bar with start/current/end labels - TV view: full-width day progress strip between header and main content Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
48 lines
1.2 KiB
Python
48 lines
1.2 KiB
Python
from datetime import date, datetime, time
|
|
from pydantic import BaseModel
|
|
from app.schemas.schedule import ScheduleBlockOut
|
|
from app.schemas.child import ChildOut
|
|
|
|
|
|
class SessionStart(BaseModel):
|
|
child_id: int
|
|
template_id: int | None = None
|
|
session_date: date | None = None # defaults to today
|
|
|
|
|
|
class TimerAction(BaseModel):
|
|
event_type: str # start | pause | resume | complete | skip
|
|
block_id: int | None = None
|
|
|
|
|
|
class TimerEventOut(BaseModel):
|
|
id: int
|
|
block_id: int | None
|
|
event_type: str
|
|
occurred_at: datetime
|
|
|
|
model_config = {"from_attributes": True}
|
|
|
|
|
|
class DailySessionOut(BaseModel):
|
|
id: int
|
|
child_id: int
|
|
template_id: int | None
|
|
session_date: date
|
|
is_active: bool
|
|
current_block_id: int | None
|
|
current_block: ScheduleBlockOut | None = None
|
|
|
|
model_config = {"from_attributes": True}
|
|
|
|
|
|
class DashboardSnapshot(BaseModel):
|
|
"""Public TV dashboard payload — no auth required."""
|
|
session: DailySessionOut | None
|
|
child: ChildOut
|
|
blocks: list[ScheduleBlockOut] = []
|
|
completed_block_ids: list[int] = []
|
|
block_elapsed_seconds: int = 0 # seconds already elapsed for the current block
|
|
day_start_time: time | None = None
|
|
day_end_time: time | None = None
|