- GET /api/portal/appointments now also returns the client's ACTIVE
waitlist_entries as synthetic `waitlisted` cards (id prefixed `waitlist:`,
status hard-set to waitlisted, startTime derived from preferred date/time)
so the portal can render Waitlisted cards in the Upcoming list (item 2).
- Seed one active waitlist entry for the UAT customer. waitlist_entries is
NOT truncated on the hourly reset, so the entry is upserted by fixed id and
its preferred date refreshed to a future-relative value each reset to stay
Upcoming. (The existing scheduled row already carries confirmationStatus
pending, which drives the live Pending badge.)
- portal.test.ts: GET /portal/appointments waitlist-surfacing tests.
- UAT_PLAYBOOK.md TC-API-8.19 for the surfaced waitlist entries.
Co-Authored-By: Paperclip <noreply@paperclip.ing>