feat(detail): full event read — surface every readable field (v0.6.0)
Round out the read-only model so the detail view shows everything CalendarContract actually stores, ahead of write support. Data layer: - New domain types: Reminder, EventStatus, Availability, AccessLevel, AttendeeRelationship, AttendeeType; EventDetail gains reminders, status, availability, accessLevel, eventTimezone, selfStatus and Attendee gains relationship + type (all defaulted so existing callers compile) - EventDetailProjection reads STATUS / AVAILABILITY / ACCESS_LEVEL / EVENT_TIMEZONE / SELF_ATTENDEE_STATUS; AttendeeProjection reads RELATIONSHIP + TYPE; new ReminderProjection queries CalendarContract.Reminders - Mappers translate each provider integer code, guarding STATUS's null-vs-0 ambiguity (0 == TENTATIVE) so an absent status reads as Confirmed - Mapper unit tests cover every new column's codes Detail UI: - Status / availability / access chips under the title; cancelled also strikes the title through - Reminders card with humanised lead times (plurals, DE + EN) - Foreign-timezone card, shown only for timed events in a non-device zone - Attendee role badges + the user's own "Your response: …" line - http(s) URLs in the description are now tappable URL field cut: CalendarContract exposes no Events.URL column (only the CUSTOM_APP_URI app deep-link), so URLs are surfaced by linkifying the description instead. Recorded in ROADMAP/CHANGELOG. Version bumped to 0.6.0 / 6. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -1,13 +1,13 @@
|
||||
# Calendula — Current State
|
||||
|
||||
*Last updated: 2026-06-10*
|
||||
*Last updated: 2026-06-11*
|
||||
|
||||
## Status
|
||||
|
||||
**Milestone:** v0.5 — Calendar filter (M3) + Settings (M4) (complete)
|
||||
**Phase:** All V1 screens done. Jump-to-date (date-picker half of M2) cut from
|
||||
scope. Next up is v0.6 — full event read (surface every readable
|
||||
`CalendarContract` field) — then a polish/QA pass before v1.0
|
||||
**Milestone:** v0.6 — Full event read (complete)
|
||||
**Phase:** All V1 screens done and the read model is now complete — the detail
|
||||
view surfaces every readable `CalendarContract` field. Next up is a UI
|
||||
polish/QA pass before v1.0
|
||||
|
||||
## Progress
|
||||
|
||||
@@ -23,12 +23,12 @@ scope. Next up is v0.6 — full event read (surface every readable
|
||||
- [x] Filter sheet (M3) — per-calendar visibility, grouped by account, persisted, applied centrally in the repository
|
||||
- [x] Settings (M4) — appearance (theme, dynamic colour, week start), language (per-app locales), about
|
||||
- [~] Jump-to-date (M2) — **cut from scope**; "Today" half shipped in v0.5, date-picker dropped
|
||||
- [x] Full event read (v0.6) — reminders, status, availability, access level,
|
||||
attendee role + self-response, foreign timezone, and linkified description
|
||||
URLs in the detail view; new domain enums + mapper unit tests. (A dedicated
|
||||
URL field was cut — no `CalendarContract` column backs it.)
|
||||
|
||||
## Next
|
||||
|
||||
1. v0.6 — full event read: reminders, status, availability, attendee role +
|
||||
self-status, timezone (when it differs), URL, access level. Read the
|
||||
`CalendarContract` columns we don't yet pull and show them in the detail
|
||||
view. (Planned, not started — implement another day.)
|
||||
2. UI polish / QA pass across all views before v1.0
|
||||
3. F-Droid release of v1.0
|
||||
1. UI polish / QA pass across all views before v1.0
|
||||
2. F-Droid release of v1.0
|
||||
|
||||
Reference in New Issue
Block a user