Files
familienarchiv/frontend/src/lib/person
Marcel d48a89ba5c test(timeline): assert submit-disabled transition and ≥44px chip targets
Tighten the review-flagged test gaps (no production change):
- submitting state: the old test only asserted the button was initially
  enabled (a tautology). Now stub a never-resolving fetch, click Speichern, and
  assert the button gains `disabled` — exercising the double-submit guard
  (Decision 8).
- the two redirect-throwing save tests now use `await expect(...).rejects` so a
  future missing redirect fails loudly instead of being swallowed by try/catch.
- the YEAR end-date-hide assertion uses getByLabelText('Enddatum') not-present,
  symmetric with the RANGE reveal, instead of a raw #eventDateEnd querySelector.
- PersonMultiSelect + DocumentMultiSelect: assert the chip remove button carries
  the min-h-[44px]/min-w-[44px] target the rtm cites for REQ-017.

Addresses PR #832 review (Tester + Requirements Engineer test-coverage concerns).

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-06-14 00:33:01 +02:00
..

person (frontend)

UI for historical family members: typeahead selection, chip display, hover cards, genealogy graph, relationship management.

What this domain owns

Components: PersonTypeahead.svelte, PersonMultiSelect.svelte, PersonChip.svelte, PersonChipRow.svelte, PersonHoverCard.svelte, PersonTypeBadge.svelte, PersonTypeSelector.svelte. Utilities: personFormat.ts (full-name formatting), personLifeDates.ts (birth/death display), person-validation.ts (form validation), personHoverCard.ts (hover-card controller). Sub-folders: genealogy/ (Stammbaum view components), relationship/ (relationship graph components).

What this domain does NOT own

  • Document content — displayed in document/
  • AppUser accounts — managed in user/

Key components

Component Used in Notes
PersonTypeahead.svelte document edit, geschichte, search filters Single-person selector with debounced typeahead. Exported for use by other domains.
PersonMultiSelect.svelte document edit (receivers) Chip-based multi-person selector
PersonChip.svelte document rows, conversation view Compact display chip with link and hover card
PersonHoverCard.svelte person chips Floating card with person summary on hover

Cross-domain imports

  • shared/primitives/ — generic UI primitives
  • shared/hooks/useTypeahead.svelte.ts — typeahead keyboard/focus logic

Accessibility notes

  • PersonChip focus ring: focus-visible:ring-2 focus-visible:ring-brand-navy
  • PersonTypeahead dropdown navigable via keyboard (↑↓ Enter Escape)

Backend counterpart

backend/src/main/java/org/raddatz/familienarchiv/person/README.md