Files
homeschool/backend/app/schemas/session.py
derekc 3efecfda49 Fix paused timer auto-resuming on page navigation
applySnapshot was always setting isPaused = false and blockStartedAt =
Date.now() regardless of the actual timer state, causing a paused block
to appear running whenever the dashboard was reloaded.

- Add is_paused field to DashboardSnapshot schema
- Dashboard endpoint derives is_paused by checking whether the last
  start/resume/pause event for the current block is a pause
- applySnapshot now reads is_paused from the snapshot instead of
  resetting to false, and only sets blockStartedAt when the block is
  actually running (not paused)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-01 14:27:05 -08:00

49 lines
1.3 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
is_paused: bool = False # whether the current block's timer is paused
day_start_time: time | None = None
day_end_time: time | None = None