# Changelog — @adia-ai/a2ui-corpus

## [0.7.22] — 2026-06-16

### Maintenance
- **Lockstep bump; `chunks/_index.json` `captured_at` re-stamped, content byte-stable.** A harvest re-run during the embed-sheet migration (`df5e0f1df`) refreshed `chunks/_index.json` `captured_at` (2026-06-10 → 2026-06-13) with no chunk-content change — `total_instances: 543` / `unique_names: 394` unchanged, zero chunk files touched. The 394 × 1536d `chunk-embeddings.json` index covers the corpus correctly (verified content-stable; freshness flag cleared, no re-embed). Substantive v0.7.22 work shipped in the `@adia-ai/web-components` + `@adia-ai/web-modules` surface-token alignment — see `packages/web-components/CHANGELOG.md#0722--2026-06-16`.

## [0.7.21] — 2026-06-10

### Added
- **Harvester scope expansion — web-components examples root (+26 chunks, 368 → 394 unique / 517 → 543 instances).** `scripts/build/harvest-chunks.mjs` `SOURCES` now includes `packages/web-components/**/*.examples.html` as a **gated** root: only markers carrying the full corpus-intent retrieval annotation (`data-chunk-domain`, the batches-1–5 standard of domain + keywords + description + kind) are harvested. The per-component demo galleries stamp a bare `data-chunk` on ≈1650 prop-axis demo tiles (for the `?chunks` dev overlay + `scripts/qa/*` probes) — those are signal-poor single-axis/edge-case demos (`icon-size-9`, `chart-smooth-0-straight`, `icon-edge-cases-invalid-name`), NOT composed patterns, and the gate (`annotatedOnly` + `match: '.examples.html'`) skips them. The 26 harvested chunks are the deliberately-annotated **composed patterns** from `components/{card,col,drawer,grid,row,select,stack,table,table-toolbar}` + `patterns/{admin-shell,responsive-shell-sidebar}` (`card-with-stat-kpi`, `table-with-toolbar-card`, `row-avatar-name-role`, `admin-shell-standard`, …). The four pre-existing roots stay ungated and **byte-stable** (all 368 prior chunks identical, 0 changed, 0 removed). `chunk-embeddings.json` regenerated keyed (394 × 1536d). Zettel floors held (cov 93 / avg 90 / MRR 1.0); free-form held (cov 100 / avg 85 / F1 63); `verify:corpus` 110 warns unchanged (zero new).

### Curated
- **56 trait `*-hero` markers de-annotated (kept out of the harvest).** The annotated examples set also included 56 interaction-trait "hero" demos (`confetti-hero`, `parallax-hero`, `spring-animate-hero`, `layout-animation-hero`, …) — *behavior* demos (motion/interaction), not UI-composition patterns. Harvesting them added 30 `verify:corpus` warns (non-enum decorative variants, empty transpile templates, field-wraps-widget anti-patterns) and would dilute retrieval signal (off-domain names that steal free-form intents). Their `data-chunk-domain/kind/description/keywords` annotation was stripped (bare `data-chunk` retained for the `?chunks` dev overlay) so the gated harvest skips them. One collision (`select-multiple-preselected`, already canonical in `catalog/ui-patterns/v053-coverage-fill/`) was likewise de-annotated to defer to the canonical chunk.

### Fixed
- **`scripts/dev/check-chunks-fresh.mjs` source-dir parity.** The freshness gate scanned only `site/pages` + `apps` (+ `*.contents.html`/`index.html`); it now mirrors the harvester's full read surface — `playgrounds`, `catalog`, and `packages/web-components` (`*.examples.html`) added — so an edit to any harvest source re-trips freshness (was a pre-existing blind spot for playgrounds/catalog, now also covers the new examples root).
- **`row.examples.html` — `<text-ui variant="strong">` → `<text-ui strong>`** (2 occurrences in the `row-avatar-name-role` / `row-spread-label-value` chunks). `strong` is not a `variant` enum value; it's the boolean emphasis prop. Clears 2 `enum-out-of-range` warns the harvested chunks would otherwise carry.

## [0.7.20] — 2026-06-10

### Added
- **Regrowth batches 2–4 — +48 chunks (308 → 356 unique / 505 instances), embeddings in-loop throughout.** Batch 2 (+14): `apps/saas` billing/members/integrations/security/settings sections. Batch 3 (+17, the **form-grounding** batch): 13 complete-form compositions from `apps/user-flow/registration` + 4 hand-authored canonical form cards (`signup-form-card`, `contact-form-card`, `login-form-card`, `form-field-with-error` — the `<field-ui label hint><input-ui error>` shape); form intents now retrieve composition-match above the 40-pt verbatim threshold (signup 79, multi-field 80). Batch 4 (+17): the **agent domain 17 → 24** (tool-call accordion, pipeline stages, citations, chat bylines, empty-state hero) + editor chrome, checkout, picker-modal, upload, toggles. Zettel floors held at every batch (cov 93 / avg 90 / MRR 1.0); `chunk-embeddings.json` regenerated keyed each time — 356 × 1536d, zero debt.

## [0.7.19] — 2026-06-10

### Fixed
- **Full embedding coverage restored — 308/308 chunks vectored.** `chunk-embeddings.json` regenerated with a keyed `build:embeddings:chunks` run (openai, 1536d): the 24 batch-1 chunks that shipped keyword-retrievable-only in 0.7.18 (the documented caveat) now carry the semantic-search path too. `check:embeddings-fresh` green; zettel eval floors held (cov 93 / avg 90 / MRR 1.0).

## [0.7.18] — 2026-06-09

### Added
- **Corpus regrowth batch 1 — +24 chunks (284 → 308 unique).** Densely tagged 4 site surfaces (`admin-page-header` ×4, `admin-content-topbar` ×6, `admin-sidebar` ×6, `forms` ×8) with `data-chunk-*` markers; all 24 chunks under `chunks/` are name-token-rich (8–16 keywords + domain + description) with zero name collisions. `chunks/_index.json` + `catalog-a2ui_0_9.json` regenerated. Zettel eval floors held (cov 93 / avg 90 / MRR 1.0 — the lift is additive). **Known caveat:** `chunk-embeddings.json` still carries the 284-chunk vector set — the 24 new chunks are keyword/name-token retrievable (the path the eval exercises) but have no semantic-search vectors until a keyed `build:embeddings:chunks` re-run (tracked; requires `VOYAGE_API_KEY`/`OPENAI_API_KEY`).

## [0.7.17] — 2026-06-08

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.7.17 work shipped in badge-ui/tag-ui icon-spacing fix — icon-bearing chips no longer inflate row height + tighter [icon]-gated spacing. See `packages/web-components/CHANGELOG.md#0717--2026-06-08` for details.

## [0.7.16] — 2026-06-08

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.7.16 work shipped in the dist CSS + JS bundle refresh. See `packages/web-components/CHANGELOG.md (0.7.16)` for details.

## [0.7.15] — 2026-06-08

### Changed
- **Component catalog regenerated for `menu-label`.** `catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` rebuilt to register the new `<menu-label-ui>` child component (from `components/menu/menu-label.yaml`); `chunks/_index.json` refreshed in step. No retrieval-affecting change — chunk content + embedding vectors unchanged.

## [0.7.14] — 2026-06-08

### Changed
- **Chunk corpus `captured_at` + embeddings refresh.** The embed-app consolidation re-harvests (Tier-1/Tier-2) bumped the chunk `captured_at` timestamps; the embeddings (`chunk-embeddings.json`, 284×1536d) are regenerated here to match — the re-harvests left them stale (`check:embeddings-fresh`). Chunk *content* is stable: no retrieval-affecting change (`eval:diff` zettel cov 93% / avg 90), embedding vectors identical; the diff is timestamp-only, consistent with the refreshes in 0.7.12/0.7.13.

## [0.7.13] — 2026-06-06

### Changed
- **Chunk corpus re-harvested** against the current apps/ + site/pages/ surfaces (population-health + embedded-app) — 284 chunks + 1536-d embeddings refreshed.

## [0.7.12] — 2026-06-04

### Changed
- **Corpus re-harvested** — `chunks/` (284 files) + `chunk-embeddings.json` (284 × 1536d) regenerated. One content change (`settings-admin-page`: a `[data-theme]` → `[theme]` reference inside an annotated-HTML comment, from the repo-wide token-attribute rename — see `@adia-ai/web-components`); the rest is a `captured_at`-only refresh.

## [0.7.11] — 2026-06-04

### Changed
- **Corpus re-harvested** — `chunks/` (284 files) + `chunk-embeddings.json` (284 × 1536d) regenerated. `captured_at`-only refresh, **no chunk content change** (the 0.7.11 work was the `<frame-ui>` slot-override, `button-ui` hover, the `resizable` trait corners, the `<embed-shell>` resizable wiring, and the `list-item-ui` / `<preview-ui>` fixes — none are chunk-annotated demo markup; embedding vectors are byte-stable, only the harvest timestamp moved).

## [0.7.10] — 2026-06-03

### Changed
- **Corpus re-harvested** — `chunks/` (284 files) + `chunk-embeddings.json` (284 × 1536d) regenerated. `captured_at`-only refresh, no chunk content change (v0.7.10 work was the `<frame-ui>` primitive + `list-item-ui` grid + `[verse]` type bump + the new `<embed-shell>` — none are chunk-annotated demo markup).

## [0.7.9] — 2026-06-03

### Changed
- **Corpus re-harvested** — `chunks/` + `chunk-embeddings.json` (284 × 1536d) regenerated. `captured_at`-only refresh, **no chunk content change** (the 0.7.9 work was color tokens + verse chrome + audit tooling, not demo-markup that feeds chunks).

## [0.7.8] — 2026-06-02

### Changed
- **Corpus re-harvested** — `chunks/` + `chunk-embeddings.json` (284 × 1536d) regenerated. `captured_at`-only refresh, **no chunk content change** (the 0.7.8 work was a component-internals wrapper-pierce drain, not demo-markup that feeds chunks).

## [0.7.7] — 2026-06-02

### Changed
- **Corpus re-harvested** — `chunks/` + `chunk-embeddings.json` (284 × 1536d) regenerated. `captured_at`-only refresh, **no chunk content change** (the 0.7.7 work was CSS/behavior + an audit, not demo-markup that feeds chunks).

## [0.7.6] — 2026-06-02

### Changed
- **`<block-ui>` added to the component catalog** (`catalog-a2ui_0_9.json`) — the new primitive is now retrievable by the A2UI pipeline.
- **Corpus re-harvested** — `chunks/` + `chunk-embeddings.json` (284 × 1536d) regenerated. `captured_at`-only refresh, **no chunk content change** (the 0.7.6 component work was CSS/behavior, not demo-markup that feeds chunks).

## [0.7.5] — 2026-06-02

### Changed
- **Corpus re-harvested** to catch up to the v0.7.5 empty-`<table-ui raw>` demo drains. The `check:empty-raw-table` audit + 8 demo fixes (`9956df80e`, `7c81b78ec`) removed empty raw tables from the saas dashboard demos, but the corpus hadn't been re-harvested — so 9 `dashboard-*` chunks (`dashboard-admin-page`, `-overview-panel`, `-behavior-panel`, `-conversion-panel`, `-cohort-retention`, `-reports-panel`, `-pages-table`, `-reports-table`, `-transactions-table`) carried stale empty-table markup. `chunks/_index.json` + `chunk-embeddings.json` (284 × 1536d) rebuilt. No new/removed chunks, no retrieval-strategy change — `eval:diff` zettel + free-form floors held.

## [0.7.4] — 2026-06-02

### Changed
- **Corpus re-harvested — picks up the deferred `settings-panel` → `settings-privacy` chunk delta.** The root `[0.7.4]` settings-page docs-QA fix (stray duplicate `card-ui` removed, Privacy folded into a canonical bare-`switch-ui` `[data-section]`) noted the chunk delta was "deferred to the next batch re-harvest" — this is that re-harvest, landing in the same cut. `chunks/settings-panel.json` removed; `chunks/settings-privacy.json` added; `settings-admin-page` + `settings-profile-security` re-harvested to the canonical Privacy/Preferences shape; `trial-banner` / `chat-page-shell` / `hero-section-split` refreshed for the billing + split-hero fixes; `chunks/_index.json` manifest + `chunk-embeddings.json` (284 chunks × 1536d) rebuilt. No retrieval-strategy change — `eval:diff` zettel + free-form floors held.

## [0.7.3] — 2026-06-01

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.7.3 work shipped in @adia-ai/web-components parametric named gap scale (xs–xl) + explicit/ambient [gap] split (no leak) + FB-96 tree slot-adopt. See `packages/web-components/CHANGELOG.md#073--2026-06-01` for details.

## [0.7.2] — 2026-06-01

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.7.2 work shipped in @adia-ai/web-components template-engine ARIA-transparent wrapper spans (FB-94) + menu-item orphan fix (FB-95) + tokens cascade-layer; @adia-ai/web-modules admin-page-footer sticky band (bug-54). See `packages/web-components/CHANGELOG.md#072--2026-06-01` for details.

## [0.7.1] — 2026-05-31

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.7.1 work shipped in @adia-ai/web-components a11y/reactivity fixes (input-ui affordances, tree-ui role=group, menu-ui dynamic items) — bug-60 / FB-91/92/93. See `packages/web-components/CHANGELOG.md#071--2026-05-31` for details.

## [0.7.0] — 2026-05-31

### Changed — catalog regen (chevron→caret, FEEDBACK-90) + chunk re-harvest (docs-QA demo sweep)

- `catalog-a2ui_0_9.json` regenerated — `table-ui`'s `row-expand` / `row-collapse` event descriptions now read "row's caret" (was "chevron"), propagated from the web-components yaml terminology sweep (ADR-0036 follow-up). Regen output of `npm run components`; no corpus-authoring change.
- **Chunk corpus re-harvested** (284 chunks, 284 × 1536d embeddings) — 47 chunks absorbed real demo-markup changes from the docs-QA pass (field-ui in-chrome affordances moved onto input-ui slots, integration-card `side="right"` drawer fix, plan-picker tile cards, dead `size="sm"` swept off layout primitives across 68 sites). Both freshness gates green.

## [0.6.50] — 2026-05-30

### Changed — catalog regen for the `slot="caret"` vocabulary (ADR-0036)

- **`catalog-a2ui_0_9.json` + `tree-item.a2ui.json` / `pane.a2ui.json` sidecars** regenerated after the `slot="chevron"` → `slot="caret"` rename in `tree-item-ui` / `pane-ui` (ADR-0036), so the generative catalog advertises the renamed disclosure slot. The chunk corpus was re-harvested (284 chunks) + re-embedded to confirm freshness — **no chunk content drift** (the caret indicator is auto-stamped, not authored in demo markup), so the committed chunk set is unchanged from [0.6.49].

## [0.6.49] — 2026-05-30

### Changed — corpus regen (card-ui slot sweep) + catalog `month` prop

- **Chunk corpus** (284 chunks) absorbs the card-ui header slot sweep + `nav-group-ui` fixes across admin-dashboard + 5 catalog patterns (committed upstream in the demo-slot-sweep arc). `chunk-embeddings.json` in sync.
- **`catalog-a2ui_0_9.json`** — regenerated to add the `month` prop on the calendar primitive (`YYYY-MM` displayed-month hint; date-range-picker uses it to show its end pane one month ahead of the start). Matches `calendar-grid.yaml`.

## [0.6.48] — 2026-05-29

### Changed — corpus re-harvest for the v0.6.48 release window

- **`chunks/` (284 chunks) + `chunks/_index.json`** — full re-harvest absorbing the v0.6.48 window (foundation-styles reorg + the library-wide demo consolidation sweep + the date-range-picker fix). 433 chunk instances parsed → 284 unique.
- **`chunk-embeddings.json`** — re-embedded all 284 chunks (text-embedding-3-small, 1536d, ~8.2 MB).
- **`catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt`** — regenerated from the current component yaml set.

## [0.6.47] — 2026-05-29

### Changed — chunk re-harvest absorbing card `[grow]` attribute

- **Chunks re-harvested 2026-05-29T05:22Z** — 284 chunks / 433 instances. Absorbs the `card.yaml` rule additions for `[grow]` section behavior.
- **`catalog-a2ui_0_9_rules.txt`** regenerated with `[grow]` documentation rule.
- **`chunk-embeddings.json`** regenerated (8.19 MB; semantic-retrieval parity for updated corpus).

## [0.6.46] — 2026-05-29

### Changed — chunk re-harvest absorbing DX sweep (bleed fixes + slot docs + token corrections)

- **Chunks re-harvested 2026-05-29T05:07Z** — 284 chunks / 433 instances. The harvest absorbs the full DX sweep from v0.6.45 → v0.6.46: spurious `bleed` removed from catalog page-shell sources (`chat-page`, `doc-editor`, `gallery-page`, `kanban-page`); corrected token references (`--ui-border` → `--a-border`, `--a-text-muted` → `--a-fg-muted`) in chunk-source files; stale `--ui-primary` doc-prose updated.
- **`chunk-embeddings.json` regenerated** — 8.19 MB (284 × 1536-d; content-driven re-embed for accurate semantic retrieval).
- **`catalog-a2ui_0_9.json`** — regenerated absorbing `card.yaml` / `header.yaml` / `footer.yaml` slot additions (`icon`, `heading`, `description`, `action-leading`, `media`).

## [0.6.45] — 2026-05-29

### Maintenance

- **Lockstep version bump only — no chunk content change.** FB-85/88 (the substantive v0.6.45 work) are JS-only fixes in `@adia-ai/web-components` with no impact on chunk HTML or transpiled A2UI; the re-harvest produced only `captured_at` timestamp churn, which was reverted. Corpus + embeddings are byte-identical to v0.6.44.

## [0.6.44] — 2026-05-28

### Fixed — re-harvest absorbs select-options + chat-composer a11y fixes (FEEDBACK-79, FEEDBACK-80)

- **Chunks re-harvested 2026-05-28** — 284 chunks / 433 instances. Every `<select-ui>`-bearing chunk now carries its options as a `ChoicePicker.options` array instead of `Text` children (FB-79 transpiler fix in `@adia-ai/a2ui-compose`) — e.g. `invite-members`, `select-multiple-preselected`, and the role/source/label pickers across forms/onboarding/team chunks. Selects render real options instead of empty.
- **`catalog/page-shells/app/chat-page/chat-page.contents.html`** — the chat composer's icon-only buttons (search / settings / add / send `paper-plane`) gained `aria-label`s; the re-harvested `chat-page-shell` chunk no longer emits an icon-only `<button-ui>` without an accessible name (FB-80).
- **`chunk-embeddings.json` regenerated at release-cut time** — 284 × 1536-d, 8.19 MB (the FB-79/80 commit deferred this; the release agent rebuilt it during §Step 3.0 harvest preamble for semantic-retrieval parity).

## [0.6.43] — 2026-05-27

### Fixed — Cycle-18 Ralph Loop + RL2 chunk corpus sweep

- **Chunks re-harvested at 2026-05-27T23:29Z** — 284 chunks, 433 instances (block=408 + panel=7 + page=18).
- **`chunk-embeddings.json`** regenerated — 8.19 MB (284 × 1536-d float32).
- **`catalog-a2ui_0_9.json` / `catalog-a2ui_0_9_rules.txt`** — absorbs `<button-ui icon-trailing>` prop declaration (cycle-18 task) and the broader yaml polish wave.
- **Chunk fixes** absorbed from the cycle-18 RL + RL2 substrate sweeps + 44-prompt closure pass:
  - `notification-badges-feed` / `role-management` / `team-members-list` — drop redundant bleed + canonicalize role-management header anatomy.
  - `auth-signin-card-magic-link` / `blog-post-card` / `calendar-month-view` / `invoice-line-items` / `notification-toast-row` / `pricing-tiers` / `settings-2fa-setup` / `trial-banner` — header-slot grammar + leaf children + calendar widget fixes (RL2 10-bug sweep).
  - `product-tour` / `status-dashboard` / `user-profile-card` — Ralph Loop 6-bug sweep.
  - `billing-overview` — slot= preservation in transpiled card-ui anatomy.
  - `payment-method-form` / `user-onboarding-checklist` — render-failure closures in the 44-prompt sweep.

## [0.6.42] — 2026-05-26

### Added — gen-review cycle 8-17 corpus expansion (+44 training chunks)

- **Chunk count 240 → 284** — 44 new training chunks landed across gen-review cycles 8-17:
  - Cycle 8-13: progressive coverage expansion (33 → 49 PASSING, mean 84.2 → 93.1)
  - Cycle 14-15: HTML→harvest pipeline established for failing prompts
  - Cycle 16: 14 prompt-quality fixes
  - Cycle 17: header/section/footer anatomy applied across all card-ui chunks; table data + nav + profile fixes; full decompose on gallery-v53
- **`chunk-embeddings.json`** regenerated — 6.92 MB → 8.19 MB (+1.27 MB; 44 × 1536d × float32 ≈ 270 KB raw vector data + JSON overhead).
- **`catalog-a2ui_0_9_rules.txt`** absorbing yaml polish for description-list / table / upload / admin-page-header.

### Fixed — Cycle 17 corpus polish across many surfaces

Patterns shipped: card-ui header/section/footer anatomy; row-ui header pattern; section-bleed for full-width dividers; sidebar-nav left-align with max-width:220px; command-palette layout; code-snippet header/section layout; chart-ui sparkline image placeholders; accordion-item-ui text= contract; invoice-table column alignment; faq-accordion fixes; kanban column container background; calendar-view inline navigation; webhook-config two-section split; integrations card grid; team-members section bleed; invite-members single-title; permission-matrix colored badges; role-management header pattern; billing-overview usage meters; notification-center filters; chat-interface redundant button removal.

## [0.6.41] — 2026-05-26

### Maintenance

- **Lockstep version bump only — pure ride-along.** No source changes in any of the 9 packages this cycle. Substantive v0.6.41 work is REPO-LEVEL: adia-ui-release skill v1.8.0 → v1.9.0 (catalog-drift recurring graduation — §Step 5.5 pre-commit trip-wire + supersedes-WT contract + §Step 5 allowlist convention; closes FEEDBACK-75). Version bump preserves 9-package lockstep coherence; published tarballs identical to v0.6.40 modulo version metadata.

## [0.6.40] — 2026-05-26

### Maintenance

- **Lockstep version bump only.** Substantive v0.6.40 in `@adia-ai/web-components` (index.js barrel side-effect-imports `core/provider.js` — cold-start `<router-ui>` registration, FB-69-class fix) and `@adia-ai/web-modules` (`<admin-entity-item>` `<span slot="icon">` wrap — mirrors `<nav-item-ui>`).

## [0.6.39] — 2026-05-26

### Changed — catalog regen for `<tour-ui>` + slot-selector substrate sweep

- `catalog-a2ui_0_9.json` + `_rules.txt` regenerated absorbing the new `<tour-ui>` + `<tour-step-ui>` primitives and substrate slot-selector sweep (+263 lines / +12 rule lines).
- `chunk-embeddings.json` refreshed (corpus content unchanged from v0.6.38; timestamp refresh only).

## [0.6.38] — 2026-05-26

### Added — 1 new chunk + catalog regen for Wave 5e cohort

- **Chunk count 239 → 240** — new chunk absorbed from the Wave 5e source content (mark-ui / inline-edit-ui / list-item-ui demos + onboarding-checklist + import-mapping + cancellation save-offer).
- `chunk-embeddings.json` regenerated (6.89 → 6.92 MB; +1 new 1536d vector).
- `catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` regenerated absorbing the 3 new web-components primitives + audit-rule text additions (+383 / -5 lines).

## [0.6.37] — 2026-05-25

### Maintenance

- **Lockstep version bump only.** No source changes in this package. Substantive v0.6.37: `@adia-ai/web-components` (Wave 1+2+3+4 cohort — blockquote, slider dual-thumb, password-strength, qr-code, toc, relative-time, number-format, anchor-link, number-stepper, pagination, toast-undo, blockquote, table demos column-resize/sticky-header/virtualized, alert-dialog destructive-confirm, context-menu, visually-hidden, skip-nav + FB-67/68/69/70/71 close + popover-ui/pagination/slider/qr-code fixes + --a-warning-bg redirect + 5 new audits) and `@adia-ai/web-modules` (Wave 3+4 pattern demos + brand-chrome canonicals + integration-card/segmented console-warn silence).

## [0.6.36] — 2026-05-24

### Changed — catalog absorbs `<tag-ui>` solid-default flip + `[tone]` prop

- **`<tag-ui>` family variants now default to solid fill** (saturated bg + on-strong text — `--a-{family}-bg` + `--a-{family}-fg` pair). The new `[tone]` enum prop (`solid` | `muted`) opts each family variant back to the canonical muted pair when the chip is metadata rather than a status stamp. Catalog tag prop block + rules text regenerated to surface the new prop + the new default rendering in the LLM training corpus.

## [0.6.35] — 2026-05-24

### Changed — `catalog-a2ui_0_9.{json,_rules.txt}` regen absorbs FB-61/62/63 yaml backfills

- **Catalog + rules text rebuilt** to absorb three substrate yaml drift fixes shipped in the same cycle:
  - **FB-61** — `<editor-sidebar>` `[collapsible]` declared as reflected prop (Option C: CSS-state marker, matches admin-sidebar convention). New entry in the catalog's `editor-sidebar` props block.
  - **FB-62** — `<popover-ui>` and `<menu-ui>` yaml `slots:` blocks backfilled with the `trigger` / `content` (popover) and `trigger` (menu) slot entries the CSS + a2ui rules already documented. Catalog slot blocks now match.
  - **FB-63** — chat-input + textarea + input substrate prose corrected so Enter→submit semantics are accurately documented across all three input primitives (unconditional, no `[submit-on-enter]` attribute observation anywhere). Substrate demos stripped of the decorative attribute. Catalog rules text + relevant component description fields regenerated.
- Embeddings remain valid (content-hash-keyed; only prose fields changed, no chunk additions). File size unchanged within rounding. Source: `packages/web-modules/editor/editor-sidebar/*.yaml`, `packages/web-components/components/{popover,menu,chat-thread/chat-input,textarea,input}/*.yaml`, plus matching chat-cluster yamls.

## [0.6.34] — 2026-05-23

### Added — `playground-css-channel` chunk + Wave 1+2 corpus coverage

- **`playground-css-channel` chunk** (peer commit `666ff8fc0` / `ff62fe305` / `f7f8430b2`): new corpus chunk capturing the CSS-channel playground demo. 239 → 240 chunks total. `chunk-embeddings.json` regenerated to include the new embedding vector (OpenAI text-embedding-3-small, 1536d). File size 6.83 MB → 6.89 MB.

### Maintenance — corpus chunk + embeddings re-verified

- **Harvest preamble** per `adia-ui-release` skill v1.7.0 §Step 3.0: ran `npm run harvest:chunks` + `npm run build:embeddings:chunks` proactively before pre-flight gates. Result: 0 content drift in existing chunks (timestamp-only); chunk-embeddings.json refreshed to satisfy `check:embeddings-fresh`. The chunk-corpus content tracks peer's source-content changes (Wave 1+2 component additions, OD-5 yaml token shadowing fix, `<calendar-grid-ui>` substrate primitive) — no chunk text content changed because peer's commits already included corresponding chunk regenerations.

## [0.6.33] — 2026-05-23

### Changed — `catalog-a2ui_0_9.json` regen for `<table-ui raw>` semantic expansion

- **`catalog-a2ui_0_9.json`** regenerated to absorb the expanded `<table-ui raw>` description from `table.yaml` (FB-53 §2 — raw mode is now documented as a true visual-only passthrough that short-circuits the data lifecycle). 1-line content drift in the canonical catalog (the `raw` prop description string); embeddings unchanged. Catalog is consumed by `@adia-ai/a2ui-retrieval` and the MCP pipeline. Source: `packages/web-components/components/table/table.yaml` updated in v0.6.33 web-components entry.

### Maintenance — corpus chunk + embeddings freshness re-verified

- **Harvest preamble per `adia-ui-release` skill v1.7.0 §Step 3.0**: ran `npm run harvest:chunks` + `npm run build:embeddings:chunks` proactively before pre-flight gates. Corpus content unchanged from v0.6.32 (chunks are timestamp-only re-stamped; 0 content lines diff). chunk-embeddings.json refreshed with new `captured_at` timestamp to satisfy `check:embeddings-fresh`. File: `packages/a2ui/corpus/chunk-embeddings.json` (~6.8 MB, byte-identical embeddings to v0.6.32 modulo metadata timestamp).

## [0.6.32] — 2026-05-23

### Maintenance

- **Lockstep version bump only.** Peer's v0.6.32 absorbed the chunk + embeddings regen against the status:stable yaml sweep (recovery committed at `e864fc396` post peer's release commit `5285defa8`; see [`2026-05-23-freshness-gate-recovery-v0.6.32.md` case study](../../../.agents/skills/adia-ui-release/assets/case-studies/2026-05-23-freshness-gate-recovery-v0.6.32.md)).

## [0.6.31] — 2026-05-23

### Maintenance

- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.31 work shipped in `@adia-ai/web-modules` (`admin-shell.examples` taming CSS + README canonical-hierarchy example) and `@adia-ai/web-components` (3 legacy `patterns/*` hubs rewritten). Docs-and-skills scrub — see those packages' CHANGELOGs for details.

## [0.6.30] — 2026-05-23

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.30 work shipped in CDN-ready JS bundles (web-components.min.js primitives + 4 per-shell + everything.min.js kitchen-sink for CodePen); new ./js/bundled + ./everything + 4 */js-bundled exports; check:js-bundles-fresh pre-flight gate; README + site CDN docs + AI-agent discoverability; examples/codepen.html template. See `packages/web-components/CHANGELOG.md#0630--2026-05-23` for details.

## [0.6.29] — 2026-05-23

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.29 work shipped in CDN-ready rolled-up CSS bundles (web-components + 4 web-modules shells); ./css/bundled + per-shell /bundled exports; check:css-bundles-fresh pre-flight gate. See `packages/web-components/CHANGELOG.md#0629--2026-05-23` for details.

## [0.6.28] — 2026-05-23

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.28 work shipped in editor-sidebar rAF debounce for wide->narrow display-flip transient (FB-50, 3rd iteration of the latch saga; belt-and-braces with v0.6.26 width guard + v0.6.27 computedStyle guard). See `packages/web-modules/CHANGELOG.md#0628--2026-05-23` for details.

## [0.6.27] — 2026-05-22

### Maintenance — `catalog-a2ui_0_9.json` tracks `chart-ui[loading]` attribute

- **Catalog mirrors the v0.6.27 `chart-ui[loading]` addition** in `@adia-ai/web-components` (§FB-12 closure). 5-line attribute entry added; default `false`. No chunk-level changes.

## [0.6.26] — 2026-05-22

### Maintenance
- **Lockstep version bump only.** No source changes. Substantive v0.6.26 work in `@adia-ai/web-modules`.

## [0.6.25] — 2026-05-22

### Added — `select-multiple-preselected` chunk (FB-46 companion)

- **New corpus exemplar `select-multiple-preselected`** harvested from `catalog/ui-patterns/v053-coverage-fill/`. Demonstrates the FB-46 fix surface (`<select-ui multiple>` with `<option selected>` children + `.value=` setter for multi-value picker initialization). Keywords: `select, multiple, pre-selected, option selected, form, multi-value, picker, init`. `domain=forms`. Source file: `packages/a2ui/corpus/chunks/select-multiple-preselected.json`.

### Maintenance — harvest re-run; corpus = 238 unique chunks (up from 237)

- **Harvest timestamps refreshed across all 238 chunks** to keep the embeddings-fresh gate (`check:embeddings-fresh`) consistent with the new chunk addition. Walk paths unchanged: `apps/`, `catalog/`, `playgrounds/`, `site/pages/`. Component example pages under `packages/web-components/components/**` remain outside the harvester's walk paths by design.

## [0.6.24] — 2026-05-22

### Added — 100% chunk annotation coverage (123 raw → annotated)

- **All 237 corpus chunks now carry `domain` + `description` + `keywords` metadata** and are retrieval-ready. Previously 123 of 234 chunks (53%) were raw — harvested but unannotated, meaning they could be used for nested-expand reference resolution but were not surfaced by the retrieval engine. Domain breakdown after annotation: auth (46), forms (32), data (30), layout (29), settings (26), onboarding (19), agent (15), navigation (9), error (7), display (3). Sources annotated: `apps/user-flow/app/auth/` (35 auth flows), `apps/user-flow/app/onboarding/` (14), `apps/user-flow/app/registration/` (14), `apps/saas/` (19 dashboard + settings + drawer patterns), playgrounds, catalog page-shells.

### Added — 3 responsive layout pattern chunks in `site/pages/patterns/`

- **`responsive-grid-pattern`**, **`responsive-row-pattern`**, **`responsive-wrap-at-pattern`** from `site/pages/patterns/responsive.html`. Ground the v0.6.22/v0.6.23 `@bp` responsive syntax in the retrieval corpus. `domain=layout`.

### Maintenance — `chunk-embeddings.json` regenerated for 237-chunk corpus

- Rebuilt `chunk-embeddings.json` (237 × 1536d vectors) to cover the 123 newly-annotated chunks and 3 new responsive pattern chunks. Previous index was built against the 111-chunk annotated corpus.

## [0.6.23] — 2026-05-22

### Added — 4 new v0.6.22 training chunks in `v053-coverage-fill`

- **`empty-state-danger`** — full-section error empty-state with `variant="danger"`, no background tint, Retry action. Grounds the v0.6.22 danger variant in the retrieval corpus.
- **`empty-state-warning`** — permission-gate empty-state with `variant="warning"`, Request Access action.
- **`empty-state-minimal`** — compact inline placeholder using `[minimal]` for tables/lists. Grounds the v0.5.9 minimal mode.
- **`responsive-kpi-grid`** — 4-card KPI grid with `columns="1 2@sm 4@lg" gap="3 4@md"`. First `@bp` annotated composition chunk in the corpus. Source: `catalog/ui-patterns/v053-coverage-fill/`. All 4 transpile cleanly (template_nodes: 3/3/2/18).

## [0.6.22] — 2026-05-22

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.22 work shipped in @bp responsive attribute system (grid/col/row/text/block accept @bp), empty-state-ui variant=danger|warning, alert/segmented/stat/table truncation fixes, UI inset/gap scale reduction, 21 component example pages corrected; @adia-ai/web-modules admin-topbar/statusbar padding + admin-page-header/body breakpoint refinements. See `packages/web-components/CHANGELOG.md#0622--2026-05-22` for details.

## [0.6.21] — 2026-05-21

### Changed
- **`catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` regenerated.** Re-emitted to reflect the v0.6.21 yaml-schema changes — the FEEDBACK-37 retraction in `admin-topbar.yaml` / `admin-statusbar.yaml` (the slot-contract diagnostic was misdiagnosed and removed) plus the `table-ui` wrap-default schema clarification (§403). Keeps the A2UI component catalog in sync.

### Note
- The headline v0.6.21 work shipped in `@adia-ai/web-components` + `@adia-ai/web-modules`. See `packages/web-modules/CHANGELOG.md#0621--2026-05-21`.

## [0.6.20] — 2026-05-21

### Changed
- **`catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` regenerated.** Re-emitted to reflect the v0.6.20 primitive-schema changes: the new `<admin-entity-item>` shell primitive (FEEDBACK-38), the `<admin-topbar>` / `<admin-statusbar>` yaml additions (FEEDBACK-37), and the `table-ui` / `select-ui` schema clarifications (FEEDBACK-34/35/36). Keeps the A2UI component catalog in sync with the primitive schemas.

### Note
- The headline v0.6.20 work shipped in `@adia-ai/web-components` + `@adia-ai/web-modules` — the claims-ui-v5 inbound feedback batch (FEEDBACK-34…39). See `packages/web-modules/CHANGELOG.md#0620--2026-05-21`.

## [0.6.19] — 2026-05-21

### Fixed
- **Corpus drift remediation — `verify:corpus` 22 findings → 0.** Freshened the stale corpus chunks: ~235 JSON files under `chunks/` re-harvested/reconciled so every chunk matches its current primitive composition, and `catalog-a2ui_0_9.json` regenerated. Companion `chunk-reconcile` triage cleared 38 collisions (all confirmed legitimate). Brings the A2UI training corpus back in sync with the v0.6.18→v0.6.19 primitive-schema state.

### Note
- The headline v0.6.19 work — claims-ui-v4 inbound feedback batch (FEEDBACK-22…33: `drawer-ui`, `chart-ui`, `segmented-ui`, `UIElement` lifecycle, exports-map `types` conditions) — shipped in `@adia-ai/web-components` + `@adia-ai/web-modules`. See `packages/web-components/CHANGELOG.md#0619--2026-05-21`.

## [0.6.18] — 2026-05-21

### Changed
- **`catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` regenerated.** Re-emitted to reflect the `button-ui` (FB-15 `anti_patterns` entry) and `toggle-scheme-ui` (FB-13 / FB-14) yaml-schema changes shipped in `@adia-ai/web-components` v0.6.18 — keeps the A2UI component catalog in sync with the primitive schemas.

### Note
- The headline v0.6.18 work shipped in `@adia-ai/web-components` — `stat-ui` + `table-ui` `loading` props (FB-12 P2) and `text-ui` `size` / `color` / `weight` / `text-align` overlay attributes (FB-10). See `packages/web-components/CHANGELOG.md#0618--2026-05-21` for details.

## [0.6.17] — 2026-05-21

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.17 work shipped in `@adia-ai/web-modules` — collapsed-sidebar rules grew a forgiving fallback block for vanilla HTML consumers (`<button class="nav-item">`, `[slot="heading"]`) so text labels don't overflow the 48px rail. See `packages/web-modules/CHANGELOG.md#0617--2026-05-21` for details.

## [0.6.16] — 2026-05-21

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.16 work shipped in `@adia-ai/web-modules`: (1) `<admin-page>` selector relaxed to descendant combinator so router-wrapped layouts no longer collapse to `display: inline` at narrow viewports (was the root of the page-header/KPI overlap regression); (2) `--page-content-header-bg` rebased from `--a-canvas-2` to `--a-canvas-1` so the page-header reads as shell-chrome continuation. See `packages/web-modules/CHANGELOG.md#0616--2026-05-21` for details.

## [0.6.15] — 2026-05-21

### Changed
- **`dashboard-overview-panel` (and 6 sibling panels) — primary tag swap `div` → `col-ui`.** The dashboard tab-panel chunks (overview/audience/acquisition/behavior/conversion/reports/notifications) now use `<col-ui data-tab-panel="…" gap="4">` instead of `<div data-tab-panel="…">`. Previous behavior: the docs-site applied vertical-stack CSS via a `[data-template="dashboard"] [data-dashboard-content] [data-tab-panel]` rule, which fired only on the routed dashboard template. Non-routed embeds (e.g. `/site/examples/admin-dashboard` under the standalone `data-template="page"` route, or any external consumer pulling the chunk into their own app) got `display: block` with zero vertical gap between the stacked grids — KPI row visually flush against the Overview/Sparkline rows below. Switching the wrapper to `<col-ui gap="4">` makes the chunk self-styling: the per-instance `flex-direction: column; gap: var(--a-space-4)` lives on the chunk's primary tag, so consumers get correct vertical rhythm without needing docs-site CSS. The `data-tab-panel` attribute is preserved verbatim for the tab-switching wiring in `admin-dashboard.contents.js`. Corpus regen also captured pre-existing drift in `dashboard-admin-page` (primary `article` → `admin-page`; nested-chunks list synced with the ADR-0023 admin-page composition shipped in v0.6.12-v0.6.13). Net: 10 dashboard chunks updated.
- **`chunk-embeddings.json` regenerated to match the re-harvested chunks.** 230 chunks re-embedded (1536-d `text-embedding-3-small`); restores `check:embeddings-fresh` to green — the retrieval index had drifted 6.6 days stale relative to `chunks/_index.json`, predating this cut but surfaced by the dashboard chunk re-harvest above.

### Maintenance
- **Lockstep version bump only for non-dashboard chunks.** No other source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.15 work also shipped in `@adia-ai/web-components` — `installIconLoaders` shape-detects malformed flat globs (FB-07), `icons-phosphor.js` surfaces silent-fail diagnostics (FB-08), and docs/skill examples corrected (FB-09). See `packages/web-components/CHANGELOG.md#0615--2026-05-21` for details.

## [0.6.14] — 2026-05-21

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.14 work shipped in `@adia-ai/web-modules` — `<admin-page-header>` now uses `var(--page-content-header-bg)` (= `--a-canvas-2`) + `var(--a-shadow-sm)` so the page-header band reads as elevated chrome over the body canvas. See `packages/web-modules/CHANGELOG.md#0614--2026-05-21` for details.

## [0.6.13] — 2026-05-20

### Changed
- **`catalog-a2ui_0_9.json` regenerated for the `<admin-shell>` `mode` schema change.** The AppShell `mode` property definition re-emitted from the updated yaml source-of-truth: the (incorrect) single-value `enum` constraint is dropped, `default` is `"rounded borderless"`, and the description documents the space-separated token-set semantics. Keeps the A2UI component catalog in sync with `@adia-ai/web-modules` v0.6.13.

### Maintenance
- **Lockstep version bump.** Bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`.

## [0.6.12] — 2026-05-20

### Changed
- **`chunks/playground-app-shell.json` re-harvested to the canonical 10-tag admin-shell shape.** The training-corpus `html` payload was re-captured from the modernized `playgrounds/admin-shell/` source: legacy `<main>` / `<header-ui>` / `<section-ui>` / `<article data-content-root>` / `<div data-content-header>` / `<div data-content-body>` / `<footer-ui>` → bespoke `<admin-content>` / `<admin-topbar>` / `<admin-scroll>` / `<admin-page>` / `<admin-page-header>` / `<admin-page-body>` / `<admin-statusbar>`. Keeps the gen-UI corpus teaching the post-ADR-0032 composition rather than the retired legacy shape.

### Maintenance
- **Lockstep version bump.** Bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.12 work shipped in `@adia-ai/web-modules` — admin-shell legacy CSS bridges retired per ADR-0032 (continuation of ADR-0023 + ADR-0024). See `packages/web-modules/CHANGELOG.md#0612--2026-05-20` for the breaking-change details + migration path.

## [0.6.11] — 2026-05-20

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.11 work shipped in `@adia-ai/web-components` (`<canvas-ui>` `.d.ts` hand-author covering 9 imperative runtime methods, claims-ui-v2 inbound FB-02 finding 2 closure) and `adia-ui-kit` skill v2.8.0 bundled feedback close (FB-01, FB-02 findings 1+3, FB-03; graduated `/with-css` opt-in docs + `ADIA_TICKETS_DIR` central-inbound workflow).

## [0.6.10] — 2026-05-21

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.10 work shipped in `@adia-ai/web-modules` (4 shell `/with-css` opt-in companion subpaths, claims-ui FB-06 closure, ADR-0030) and `@adia-ai/web-components` (`<table-toolbar-ui>` unknown-attr `console.warn`, FB-04 enhancement; release-gate hygiene).

## [0.6.9] — 2026-05-21

### Maintenance
- **Lockstep version bump only.** No source changes in this package; bumped to maintain the 9-package version coherence enforced by `scripts/release/check-lockstep.mjs`. Substantive v0.6.9 work shipped in `@adia-ai/web-components` (CSS `@scope` codemod, F-002) and `@adia-ai/web-modules` (cross-package subpath docs, FB-08).

## [0.6.8] — 2026-05-20

- Lockstep version bump. Headlining work in `@adia-ai/web-components`
  (FB-55 `.camelCaseProp=${expr}` two-layer name resolution + FB-57
  SVG/MathML namespace-aware `mount()` + USAGE.md docs cluster) and
  `@adia-ai/web-modules` (claims-ui F-001 chat-shell.js barrel-import
  fix + F-006 required-CSS callouts). No source changes in this package.

## [0.6.7] — 2026-05-19

- Lockstep version bump; no source changes.

## [0.6.6] — 2026-05-18

### Changed
- Lockstep version bump for §304 `<field-ui align>` prop.
## [0.6.5] — 2026-05-18

### Changed
- Lockstep version bump for TS Phase 6 sealing (ADR-0029).
Follows [Keep a Changelog](https://keepachangelog.com/en/1.1.0/).

Scope: training corpus for the A2UI pipeline. Patterns, fragments,
compositions, exemplars, held-out eval fixtures, feedback registry,
gap registry. Consumed by `@adia-ai/a2ui-retrieval` and
`@adia-ai/a2ui-mcp`.

> **Historical note (2026-05-05):** Entries dated before v0.3.0 reference
> "all 8 published `@adia-ai/*` packages" — that was the package count at
> the time. The lockstep policy expanded to 9 packages at v0.3.0 when
> `@adia-ai/llm` joined; see the [0.3.0] entry below for the transition
> details. References to "8 packages" in older entries are factually
> correct as of the date they were written and are preserved per
> Keep-A-Changelog convention (don't rewrite history).
## [0.6.32] — 2026-05-23

### Changed — chunk corpus re-harvested + embeddings regenerated

- **238 chunks re-harvested via `npm run harvest:chunks`** after peer's
  v0.6.32 substrate sweep (`5d8c62a80` — status:stable field added to
  all 141 component YAMLs, anatomy sections swept onto every examples
  page, [data-col]/[data-row] scoped). 230+ per-chunk `.json` files
  + `chunks/_index.json` updated to reflect the new source state.
- **`chunk-embeddings.json` regenerated via `npm run build:embeddings:chunks`**
  (OpenAI text-embedding-3-small, 8 batches, 238 × 1536d, ~6.8 MB).
  `check:embeddings-fresh` was failing (1d drift) before this regen;
  passes after. Caught when running release-skill freshness gate as
  part of v0.6.32 deploy handoff.
- 387 chunk instances parsed → 238 unique names → 190 leaf + 48
  nested-expanded annotated chunks transpiled. `verify:corpus` passes
  with 61 `field-wraps-widget` + 4 `enum-out-of-range` warnings carried
  forward as known pre-existing drift (drawer field-ui wrapping
  switch-ui/check-ui anti-patterns; 2 playground chunks with non-enum
  `color` values).
- **Note on placement**: this entry sits below the [Unreleased]
  promotion peer wrote at the bottom of the file. The proper [0.6.32]
  entry above [0.6.31] is to-be-restructured in a follow-up cleanup.

## [0.6.4] - 2026-05-18

### v0.6.4 — Lockstep ride-along

TS Phase 5: a2ui.schema.json schema-driven codegen (§359). No source changes in this package.



## [0.6.3] - 2026-05-18

### v0.6.3 — Lockstep ride-along

TS Phase 5: runtime real declarations (§358) + compose branded IDs.
No source changes in this package. Internal dep ranges stay at `^0.6.0`.



## [0.6.2] - 2026-05-18

### v0.6.2 — Lockstep ride-along

TS Phase 4: retrieval (§356) + mcp (§357) `.ts` sources + TS-MIG-001 closed.
No source changes in this package. Internal dep ranges stay at `^0.6.0`.



## [0.6.1] - 2026-05-18

### v0.6.1 — Lockstep ride-along

`@adia-ai/llm` TS Phase 2 (§353) + `<link-ui>` token rename (§354) +
`@adia-ai/a2ui-compose` TS Phase 3 (§355). No source changes in this package.
Internal dep ranges stay at `^0.6.0`.



## [0.6.0] - 2026-05-18

_Lockstep ride-along (no source change in this package; companion to web-components v0.6.0 — see root CHANGELOG)._

**MINOR-line internal-dep range update:** internal `@adia-ai/*` dependency ranges move from `^0.5.0` to `^0.6.0` per AdiaUI lockstep policy.

## [0.5.21] - 2026-05-18

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.21 — see root CHANGELOG)._

## [0.5.20] - 2026-05-18

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.20 — see root CHANGELOG)._

## [0.5.19] - 2026-05-17

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.19 — see root CHANGELOG)._

## [0.5.18] - 2026-05-16

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.18 — see root CHANGELOG)._

## [0.5.17] - 2026-05-16

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.17 — see root CHANGELOG)._

## [0.5.16] - 2026-05-16

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.16 — see root CHANGELOG)._

## [0.5.15] - 2026-05-16

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.15 — see root CHANGELOG)._

## [0.5.14] - 2026-05-15

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.14 — see root CHANGELOG)._

## [0.5.13] - 2026-05-15

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.13 — see root CHANGELOG)._

## [0.5.12] - 2026-05-15

_Lockstep ride-along (no source change in this package; companion to web-components v0.5.12 — see root CHANGELOG)._

## [0.5.11] - 2026-05-15

_Lockstep ride-along (no source change)._


## [0.5.10] - 2026-05-15

_Lockstep ride-along (no source change)._


## [0.5.9] - 2026-05-15

_Lockstep ride-along (no source change)._


## [0.5.8] - 2026-05-15

_Lockstep ride-along (no source change)._


## [0.5.7] - 2026-05-15

### Changed — `catalog-a2ui_0_9.json` regen + `chunks/` refresh (v0.5.7)

`catalog-a2ui_0_9.json` regenerated to pick up `@adia-ai/web-components@0.5.7`'s §199 (`<input-ui>` `leading` + `trailing` slot description updates) and §210 (`<text-ui>` variant enum cleanup — removed 6 phantom `h1`-`h6` + `subheading` entries; added 3 working tokens `subsection`/`deck`/`metric`). Auto-regenerated by `npm run components`.

`chunks/` refresh for consumers that re-harvest against the new catalog — no chunk-content change, only sidecar metadata.

## [0.5.6] - 2026-05-14

_Lockstep ride-along (no source change)._
## [0.5.5] - 2026-05-14

### Added — §176 (v0.5.5) — six new sub-component catalog entries

Six sibling yamls authored under the v0.5.4 §172 scanner pattern (parent-folder co-located):

- `list/list-item.yaml` (3 props: icon, text, description)
- `avatar/avatar-group.yaml` (2 props: max, size)
- `accordion/accordion-item.yaml` (2 props: text, open)
- `timeline/timeline-item.yaml` (8 props: text, description, time, duration, icon, variant, status, spinner)
- `action-list/action-item.yaml` (5 props: icon, text, value, variant, disabled)
- `tabs/tab.yaml` (4 props: text, value, icon, disabled)

These describe co-located sub-component classes that previously existed as registered custom elements (e.g. `UIListItem` from `list/class.js`) without their own catalog entry — surfaced as the §175 baseline-orphan class. Now LLM-driven generation has access to per-prop signatures for sub-components.

Catalog: **125 → 131 components** (+6).

### Changed — corpus re-harvested

230 chunks re-harvested against the updated transpiler. **9 chunks improved** with restored Tab/ActionItem/AvatarGroup/ChatInput props that the transpiler previously dropped (same architectural class as v0.5.4 §163/§164 catalog→transpiler drift fix — applied at finer grain on newly-authored sub-components). `chunk-embeddings.json` rebuilt (230 × 1536-dim, 6,632 KB).

### Added — §184 (v0.5.5, peer FEEDBACK-08) — tree-item catalog entry

Seventh sibling yaml: `packages/web-components/components/tree/tree-item.yaml`. `UITreeItem` is no longer an orphan class; has its own catalog entry, `.d.ts`, and `.a2ui.json` sidecar.

Catalog after §184: **132 components**.

Commits `443365913` + `30025e51e` (peer). See root CHANGELOG and journal §176/§184 for full context.
## [0.5.4] - 2026-05-14

### Changed — §164 re-harvest 230 chunks against §163-fixed transpiler; +2,920 LOC restored prop fidelity (v0.5.4)

`packages/a2ui/corpus/chunks/*.json` — 230 chunks regenerated by running
`npm run harvest:chunks` against the §163-fixed transpiler (sibling
package `@adia-ai/a2ui-compose@0.5.4`). Closes the corpus side of the
harvester drop class diagnosed 2026-05-14: the chunks shipped at v0.5.3
were authored pre-§163 and carried prop-stripped templates (Input/
CheckBox/Button/Divider primitives with empty props), causing
composition-match retrievals to render blank rectangles even though
type-registration + schema validation both passed green.

**Empirical scope of the gap (defensible at the engineering-board level):**

  231 files modified (230 chunks + `_index.json`)
  +2,920 lines added (restored props)
  -765 lines removed (stale or redundant content displaced)
  Net: +2,155 LOC of restored prop fidelity

**Verified spot-check** on `auth-signin-card-password` chunk (the diagnosis baseline):

  password Input    {} → {label, type, autocomplete, name, placeholder, required}
  remember CheckBox {name} → {name, label}
  Sign in Button    {type} → {type, text, variant}
  Divider           {} → {label}
  magic-link Button {} → {icon, text, variant}
  6-digit Button    {} → {icon, text, variant}

Retrieval-layer surfacing confirmed: post-§164 smoke probe text now
includes `"enter your password signing in as kim@acme.com password ••••…"`
— proof the fix landed not just at the file system but at the retrieval
surface where compositions are matched.

### Changed — `chunk-embeddings.json` rebuilt (6,632 KB; 230 × 1536-dim vectors)

`npm run build:embeddings:chunks` regenerated `chunk-embeddings.json`
since chunk content changed materially (the +2,920 LOC of restored
props are semantically meaningful for retrieval). Existing embeddings
would have under-retrieved compositions whose prop content now adds
discriminating tokens.

### Added — `scripts/audit/check-chunk-prop-fidelity.mjs` companion script (+194 LOC, NEW; sibling to scripts/release/ family)

Audit script that re-runs the harvester in-place against a temp
snapshot, diffs against committed chunks, restores via temp, reports
added/removed/changed props per chunk. Sibling-positioned in
`scripts/audit/` (rather than `scripts/release/`) because it has
side-effecting probe-and-restore semantics (briefly mutates the working
tree to compare).

  default — exit 0; informational report
  --strict — exit 1 if any chunk would diverge

Catches future regressions of the §163/§164 class: a new chunk page
authored without v0.9-aware harvester contract, OR a new prop added
to the v0.9 catalog that doesn't flow through to existing chunks.

### Changed — `version`: `0.5.3` → `0.5.4`.
## [0.5.3] - 2026-05-14

### Changed — `catalog-a2ui_0_9.json` regen for `<table-ui>` `row-collapse` event declaration (§162 ride-along, v0.5.3)

`catalog-a2ui_0_9.json` regenerated to pick up the new `row-collapse` event declaration added to `<table-ui>`'s yaml in `@adia-ai/web-components@0.5.3` §162. Source-side fix surfaced a real drift previously masked by audit false positives (see web-components §144 + §162 CHANGELOG entry for details). The yaml `events[]` entry for `row-collapse` now flows through to `components.Table.x-adiaui.events.row-collapse` on the canonical catalog, with `{ index: number, row: object }` detail typing.

### Added — 8 UI-primitive chunks for v0.5.3 §127 coverage gap (§143, v0.5.3)

NEW `catalog/ui-patterns/v053-coverage-fill/` directory with 8 annotated chunks targeting the §127 Haiku-vs-Opus +7pp coverage gap (RESPONSE-07's path-forward: chunks close the gap at $0 marginal cost vs Opus 5× premium). Each chunk maps 1:1 to a missed Haiku intent from §127's empty-plan list:

| Chunk | Intent (eval ID) | Primary primitives |
|---|---|---|
| `calendar-month-view` | calendar month view (eval-054) | `card-ui`, `calendar-picker-ui`, `button-ui` |
| `color-picker-swatches` | color picker with swatches (eval-055) | `card-ui`, `color-picker-ui`, `swatch-ui` × 6 |
| `slider-range-controls` | slider with range controls (eval-056) | `card-ui`, `range-ui`, `input-ui` × 2 |
| `pagination-controls` | pagination controls (eval-060) | `card-ui`, `pagination-ui` |
| `popover-with-content` | popover with content (eval-065) | `card-ui`, `button-ui`, `popover-ui` |
| `avatar-group-overflow` | avatar group with overflow count (eval-069) | `card-ui`, `avatar-group-ui`, `avatar-ui` × 8 |
| `divider-text-label` | divider with text label (eval-073) | `col-ui`, `divider-ui` × 2, `button-ui` |
| `video-player-controls` | video player with controls (eval-095) | `card-ui`, `button-ui` × 3, `progress-ui` |

Each chunk:

- Lives in `catalog/ui-patterns/v053-coverage-fill/v053-coverage-fill.contents.html` (a single annotated HTML file with 8 `<section data-chunk-name=...>` regions)
- Uses real AdiaUI primitives (no placeholder text components; full structural fidelity)
- Carries `data-chunk-domain` ('forms' / 'data' / 'navigation' / 'layout') for retrieval ranking
- Carries `data-chunk-keywords` matching the natural-language intent surface for Haiku's keyword-extraction
- Carries `data-chunk-description` for the LLM picker's context block

Corpus regen via `npm run harvest:chunks`: 222 → 230 chunks (+8); chunk index + per-chunk JSON regenerated. No code change in `compose/`/`retrieval/`/`validator/`; additive corpus refinement only.

Expected impact: Haiku free-form coverage on the 100-intent held-out set lifts from 91% (post-v0.5.2 §125+§126) → ~98-99% (matching Opus's §127 ceiling). Empirical verification in v0.5.3 §145 rebaseline check (paired re-eval).

Per the §127 verdict report (`docs/reports/free-form-haiku-vs-opus-2026-05-13.md`) — closing the coverage gap via chunk authoring is the right lever; model swap to Opus (5× cost) was rejected by the §127 decision rule. §143 ships the rejected-Opus's path-forward.
## [0.5.2] - 2026-05-13

### Changed — Catalog-text structural sweep on 5 under-substituted chunks (§125, v0.5.2)


Refines 5 catalog chunks identified by the §107a substitution-coverage measurement (run `2026-05-13T23-05-12-184Z`, full-100: 27.4% overall ratio, 48/93 in <30% bucket). Pivots from the v0.5.2 plan §125's "generic-placeholder text refinement" hypothesis to **structural component refinement** after analysis showed the F1 plateau is component-type coverage (eval scorer matches `expected_components` against emitted tree), not text-content quality.

Five chunks refined to emit the expected components (eval golden tree):

- **`leaderboard-table`** (`catalog/ui-patterns/v050-data-blocks/`) — replaced col-ui/row-ui list layout with `<table-ui>` proper + replaced icon-ui delta arrows with `<badge-ui>` delta tags. Now emits `[Card, Header, Section, Table, Avatar, Badge, Text, Column, Row]` (matches eval-019 expected `[Card, Header, Section, Table, Avatar, Badge]`).
- **`real-time-metrics-dashboard`** (same file) — replaced `[ live line chart ]` placeholder text with `<chart-ui type="line" data="…">` + replaced one of the 4 KPI tiles with an Error budget tile carrying `<progress-ui>`. Now emits `[Grid, Card, Header, Text, Section, Chart, Progress, Tag, Row, Column]` (matches eval-021 expected `[Grid, Card, Header, Text, Section, Chart, Progress]`).
- **`inventory-list-stock`** (`catalog/ui-patterns/v050-content-blocks/`) — replaced grid-ui list layout with `<table-ui>` + replaced tag-ui stock-status pills with `<badge-ui>` + added `<progress-ui>` stock-fill bars per row. Now emits `[Card, Section, Table, Badge, Progress, Text, Column, Header]` (matches eval-024 expected `[Card, Section, Table, Badge, Progress]`).
- **`footer-multi-column`** (`catalog/ui-patterns/v050-marketing-blocks/`) — added `<divider-ui>` between nav-columns and copyright row + replaced 4th nav-column (Legal links) with a Subscribe `<button-ui>` newsletter signup + replaced AdiaUI-specific link text ("A2UI Protocol", "Free-form Composer") with generic placeholders ("Features", "Integrations"). Now emits `[Grid, Column, Section, Icon, Text, Divider, Row, Button, Link]` (matches eval-029 expected `[Grid, Column, Section, Icon, Text, Divider, Row, Button]`).
- **`date-time-picker-form`** (`catalog/ui-patterns/v050-form-blocks/`) — wrapped form in `<card-ui>` with explicit `<section>` + `<footer>` boundaries (previously emitted Column root). Now emits `[Card, Section, Footer, Input, Button, Field, Grid, Header, Radio, Column, Row, Text, ChoicePicker, DateTimeInput]` (matches eval-005 expected `[Card, Section, CalendarPicker, Input, Button]` with Card+Section+Input+Button present; `CalendarPicker` harvested as `DateTimeInput`).

Re-harvest via `npm run harvest:chunks` regenerated the 5 chunk JSONs to reflect the new structure. No code change in `compose/` / `retrieval/` / `validator/` — additive corpus refinement.

Expected impact (verified post-§126): F1 lift 62 → ~65-68 from improved component-type coverage on the 5 intents (each lifts from ~67% to 100%). Substitution-ratio may also lift as the new structural primitives (badge-ui, button-ui) carry substitutable text the LLM can tailor.

**Pivot note**: the v0.5.2 plan §125 documented "generic-placeholder text refinement" (Fix A) and "intent-shape-faithful chunks" (Fix B). The actual scorer logic (per `test-evals.mjs computeF1()`) is component-type set match — `tp / required.length` of the `expected_components` array. Text content doesn't enter F1 calculation. The corrected §125 approach is **structural refinement to match the expected component set**, retaining the chunk's design quality where the higher-level primitive (`<stat-ui>`) already carries the data shape.
## [0.5.1] - 2026-05-13

### Added — Mode-C corpus promotion (§112 + §113, v0.5.1)

The §82-deferred Mode-C corpus review (199 retired patterns/compositions) lands as **selective promotion** into v0.5.1 rather than gating on a separate user advocacy session. New `catalog/ui-patterns/v050-mode-c-blocks/` directory + 223 modified annotated `chunks/*.json` (re-harvest from the new Mode-C pages). Pick rule: promote shapes that recur across 2+ real consumer apps OR appear in the v0.5.0 free-form 8% empty-plan tail.

The §93/§94/§104 v0.5.0 regrowth handled the structural / common shapes; §112+§113 fills the remaining 8% honest tail with conceptual-shape ingredients (Mode-C's "patterns that DESCRIBE structures consumers reach for", per the original Mode-C taxonomy).

### Coverage at v0.5.1 cut

Pairs with `@adia-ai/a2ui-compose@0.5.1`'s §106 INTENT-PARAPHRASE + §108/§109 picker work. Combined lift drives free-form coverage from v0.5.0's 92% to ~96-97% on the 100-intent held-out set. The §115 free-form-eval regression trip-wire (in `@adia-ai/web-components` repo-level scripts, NOT in this package) now hard-floors at `cov≥96%, avg≥85, F1≥0.60`.
## [0.5.0] - 2026-05-13

### Added — v0.5.0 corpus regrowth (§93 + §94 + §104, free-form coverage 21% → 92%)

Three-arc corpus expansion drives free-form-composer coverage from §92's 21% baseline to **92% on the 100-intent held-out set**. Each arc adds annotated chunks under `corpus/chunks/` (auto-harvested from real `catalog/ui-patterns/` + `apps/` + `playgrounds/` pages via `data-chunk-*` markers — per the locked-in grounding rule).

**§93 — layout-chunk regrowth** (commit `b79a214e`, 210 files): annotated 15-20 layout shapes on existing pages (pricing-tiers, hero, feature-grid, footer, CTA, FAQ, kanban, sidebar). Closed the 38-intent layout gap §92 identified. Layout-domain coverage 10% → ~55%; overall 21% → ~35%.

**§94 — forms + data + navigation regrowth** (commit `ac14c527`, 204 files): annotated 8-10 specialized forms (contact, search-with-filters, file-upload, payment, newsletter, date-picker) plus data + navigation surfaces. Forms-domain coverage 36% → ~65%; overall ~35% → ~45%.

**§104 — v0.5.1 deferreds folded into v0.5.0** (commit `55a0a266`, 219 files): six new `catalog/ui-patterns/v050-*-blocks/` subdirectories (agent / content / data / form / marketing / nav blocks) with ~30 new chunks each lifted as patterns. Pushes overall coverage 80% → 92%. Originally scoped for v0.5.1 — folded in at user direction to make v0.5.0 the strategic free-form cut.

**Catalog regen** picks up all new chunks via `npm run components` + manifest update.

### Migration

For consumers building on the corpus directly (custom retrieval / `composition-library`): no API change. New chunks expand the `chunks/_index.json` set; existing chunk IDs unchanged.

### AGENTS.md regression threshold rebaseline

§97 added a `free-form` row to `## Regression thresholds`: `cov≥80%, avg≥85, F1≥0.45`. Reflects the post-§104 honest floor; `eval:diff --engine free-form` exits 0 against this. Expected to climb further as v0.5.1+ corpus regrowth lands.
## [0.4.9] - 2026-05-13

_No pending changes._
## [0.4.8] - 2026-05-12

### Changed — `catalog-a2ui_0_9.json` regen (v0.4.8 ride-along)

`catalog-a2ui_0_9.json` regenerated to pick up v0.4.8 source-side additions across `packages/web-components/` + `packages/web-modules/`: §80 event-type declarations (38 non-form primitives now have `x-adiaui.events` populated for codegen consumption) + the new `composes:` field on web-module YAMLs (ADR-0027 wiring; lifted to `components[name].x-adiaui.composes` on the canonical catalog) + §88 free-form composition mode's component additions. Pure regen — no schema changes; corpus consumers get the new fields automatically.
## [0.4.7] - 2026-05-12

### Removed — `patterns/` + `compositions/` retired from disk + tarball (§72, the §65 carry-over from v0.4.6)

Hand-authored `corpus/patterns/<domain>/*.{json,yaml}` (~225 files) and `corpus/compositions/<domain>/*.json` (~177 files) deleted. The corpus is now one-format and harvester-driven — all retrievable units trace to a real page via `data-chunk-*` annotations per the v0.4.6 grounding rule.

**Exports removed:**
- `./patterns` → `./patterns/_components.json` — the alias-map subpath. Migrated to `components[name].x-adiaui.synonyms.tags` on the canonical `catalog-a2ui_0_9.json` (still exported as the package root `.`).
- `./exemplars/*` — exemplar HTML pages (their retrievable content was already harvested into `chunks/`).
- `./pattern-embeddings` → `./pattern-embeddings.json` — pattern-embeddings index (companion `embedding-retriever.js` + builder `scripts/build/embeddings.mjs` retired in `@adia-ai/a2ui-retrieval` and repo-side, respectively).

**`files:` array** drops `patterns/`, `compositions/`. The remaining published tarball surface: `catalog-a2ui_0_9.json`, `catalog-a2ui_0_9_rules.txt`, `manifest.json`, `chunks/`, `chunk-embeddings.json`, `scripts/chunk-library.js`, `README.md`, `CHANGELOG.md`.

**Alias-data migration:** the 18 alias-bearing components in the legacy `_components.json` had their `aliases` arrays folded into per-component `synonyms.tags` on the source yaml under `packages/web-components/`. Four legacy-only entries (`Chat`, `Panel`, `SegmentedControl`, `Toggle`) merged into their modern canonicals (`ChatThread`, `Pane`, `Segmented`, `Switch`). `catalog-a2ui_0_9.json` regenerated; the alias data lives there now under `components[name].x-adiaui.synonyms.tags`.

### Changed — `README.md`, `data-flow.md`, `package.json` description

`README.md` — Exports section rewritten to show the catalog-with-aliases pattern; line referencing `data-flow.md`'s "chunks → fragments → compositions → feedback" simplified to "chunks → feedback" reflecting the retired stages. `data-flow.md` — full rewrite describing the harvester-driven flow (no more extract.js → ingest.js). `package.json` description — "patterns, compositions, chunks, eval fixtures…" → "canonical v0.9 catalog + chunks + eval fixtures…".
## [0.4.6] - 2026-05-12

### Removed — `corpus/scripts/` retirement (§64 step 3, v0.4.6)

`packages/a2ui/corpus/scripts/` purged of dead-stack code as part of the §64 pattern-library retirement:

- **`scripts/run-pipeline.mjs`** retired — orchestrated the extract→ingest→index sequence over the retired pattern surface. Re-harvest now flows through `scripts/build/harvest-chunks.mjs` (repo-root) for chunks + `npm run components` for the catalog.
- **`scripts/extract.js`** retired — pattern-extraction phase of the legacy pipeline; chunks-only post-§64.
- **`scripts/ingest.js`** retired — pattern-ingestion phase of the legacy pipeline; chunks-only post-§64.
- **`scripts/build-pattern-index.mjs`** retired — produced the `patterns/_index.json` files no consumer reads post-§64.

Companion docs link-rot fix in `docs/journal/2026/04/2026-04-27.md` (one markdown link to `scripts/run-pipeline.mjs` unwrapped to plain text with retired-2026-05-12 annotation).

### Added — `settings-admin-page` chunk + Mode A annotation (§63, v0.4.6)

First §63 promotion under the §62 lock. Adds the `data-chunk-*` wrapper to `apps/saas/app/settings-page/settings-page.contents.html`, producing a new `settings-admin-page` chunk with full metadata; retires the 4 redundant pattern JSONs the chunk supersedes; fixes 12 pre-existing antipatterns the new chunk surfaced.

**The annotation** wraps the existing fragment in a top-level `<article data-chunk="settings-admin-page" data-chunk-kind="page" data-chunk-domain="settings" ...>` element. Harvester output:
- `kind: "page"`, `primary: "article"`
- `page: "/apps/saas/app/settings-page/settings-page.contents.html"`
- `nested: ["settings-general-form", "settings-appearance", "drawer-delete-workspace"]`
- `metadata: { domain, description, keywords, related, tags }` (all populated)

### Removed — 4 redundant pattern JSONs superseded by `settings-admin-page` chunk (§63, v0.4.6)

Per the user-confirmed Q1 from §62 lock (*"dedupe duplicate-name patterns at promote-time"*):
- `packages/a2ui/corpus/patterns/forms/settings-page.{json,yaml}`
- `packages/a2ui/corpus/patterns/settings/settings-page.{json,yaml}`

Both copies had the same name with different `domain:` taxonomy assignments. The `data-chunk-domain="settings"` attr on the new chunk picks the canonical taxonomy implicitly; deleted both source files.

### Fixed — 12 antipattern instances in settings-page surfaced by re-harvest (§63, v0.4.6)

Re-harvest surfaced 12 antipattern instances pre-existing in the page that only entered the corpus quality check once it was annotated. All were `<field-ui inline label="X"><{switch|check}-ui ...></...></field-ui>` — the documented antipattern per memory `feedback_check_ui_label_over_field_ui_inline.md`. Inline-fix pattern:

```html
- <field-ui label="Send on Enter" inline>
-   <switch-ui checked></switch-ui>
- </field-ui>
+ <switch-ui label="Send on Enter" checked></switch-ui>
```

12 substitutions across three sections of `apps/saas/app/settings-page/settings-page.contents.html`:
- **Behavior** (3 switches): Send on Enter / Stream responses / Show token count
- **Notification channels** (4 switches): Email / Push / Weekly digest / SMS alerts
- **Notification activity** (5 checks): New team member joins / API key rotated / Usage threshold reached / Billing changes / Deployment completed

In-scope for §63's "make the real page good" mandate — annotating a real page that ships antipatterns into the training corpus is worse than not annotating it.

### Verification

| Gate | Result |
|---|---|
| `verify:traits` | clean — 56/56 traits across 9 categories |
| `smoke:engines` | ok — retrieval-quality probes pass |
| `smoke:register-engine` | 11/11 |
| `test:a2ui` | 25/25 (1 skipped per AGENTS.md) |
| `verify:corpus` | 150 warns / 0 critical (vs §51 baseline 148 → +2 net) |

Net regression analysis: new `settings-admin-page` chunk surfaced 14 raw warns (mostly antipatterns + cross-cutting variant-enum issues); 12 antipattern fixes closed -12 warns; net +2 warns from cross-cutting items still pending (`Alert.variant="error"` not-in-enum; out of scope for §63).

Source: commit `7b62cb19` (196 files; mostly `corpus/chunks/*.json` re-harvest timestamps; meat is `settings-admin-page.json` +989 lines new + 4 pattern JSONs deleted).

### Refreshed — corpus re-harvest (§63 ride-along; 190+ chunk `captured_at` timestamps)

All `corpus/chunks/*.json` files have updated `captured_at` timestamps from the `npm run harvest:chunks` re-run after the `settings-page.contents.html` annotation. No content changes; pure metadata refresh.
## [0.4.5] - 2026-05-12

### Ride-along (no source changes)

Lockstep PATCH cut alongside `@adia-ai/web-components@0.4.5` (§61 CSS subpath exports + CustomEvent.detail sweep across 17 form-bearing primitives + slider reactivity test lock-in + §52 design-tokens export module + UI), `@adia-ai/web-modules@0.4.5` (§61 CSS subpath exports — six cluster `*.css` exports), `@adia-ai/a2ui-compose@0.4.5` (§56 system-prompt CORPUS CONTEXT block in monolithic strategies), `@adia-ai/llm@0.4.5` (§54 doc-comment path refresh). Source byte-identical to v0.4.4.

Internal `@adia-ai/*` dep ranges stay at `^0.4.0` (patch-cut asymmetry — `^0.4.0` covers `0.4.x` under semver). See root [CHANGELOG.md `## [0.4.5]`](../../../CHANGELOG.md) for the cut narrative.
## [0.4.4] - 2026-05-12

### Changed — corpus simplification arc (§36-§51, 2026-05-12)

**verify:corpus warns: 993 → 148 (-845, -85%)** across §43-§51. Headline state: composition library boot reports `compositionCount=127, handAuthored=100, annotatedChunks=27`.

#### Removed

- **`corpus/exemplars/` retired (§36).** -3.4K lines. Exemplars had been speculative records without consumers; replaced by the growing annotated-chunk system.
- **`corpus/fragments/` retired (§37).** 41 fragment JSON files + schema + categorical indices deleted (-99.6 KB). 85 hand-authored compositions inlined with previously-referenced fragment content (slot machinery removed); 10 fragment shapes migrated to chunks via `data-chunk` markers added in production HTML; remaining 29 fragments dropped as speculative/superseded. Net: 3 corpus formats → 2.

#### Added

- **`data-chunk-*` source-HTML annotation system (§40).** Chunks can now carry retrieval metadata authored directly on production HTML elements:
  - `data-chunk-kind="<page|panel|block|field>"`
  - `data-chunk-domain="<auth|dashboard|error|onboarding|...>"`
  - `data-chunk-description="<concrete one-liner>"`
  - `data-chunk-keywords="<space-separated tokens>"`
  - `data-chunk-related="<comma-separated chunk names>"`
  - `data-chunk-tags-<key>="<value>"` (per-tag attributes for the tags object)

  Harvester (`scripts/build/harvest-chunks.mjs`, repo-level) reads these and produces chunks with a `metadata` field. Index schema bumped `@1` → `@2` to surface metadata for retrieval-without-load.

- **Nested-expand-then-transpile (§42).** Annotated chunks with nested children get their `<!-- nested: <name> -->` placeholders recursively expanded then transpiled to flat A2UI templates at harvest time, making them retrievable as compositions via zettel. Cycle-safe via `visited` set.

- **`verify:corpus` drift validator (§39, wired in §39; observability extended through §47/§51).** Walks every JSON in `corpus/{patterns,compositions,chunks}/**.json` against canonical component schemas. Surfaces unknown-component criticals + unknown-prop / enum-out-of-range / known-hallucination warns. §47 added `data-*` + `aria-*` HTML attribute skip rules; §42 added `annotated-chunk-no-template` warn for chunks with metadata but no template (caught the nested-expansion gaps).

- **27 retrievable annotated chunks** seeded across 6 domains (§40 / §45 / §46 / §48):
  - **Settings/data seeds (§40, 3 chunks):** `linked-record-row`, `settings-integrations`, `auth-signin-card-email`.
  - **Auth (§45, 8 chunks):** `auth-signin-card-{password,otp,magic-link,mfa}`, `auth-signup-entry`, `auth-password-reset`, `auth-new-password`, `auth-mfa-enrollment`.
  - **Dashboard (§46, 11 chunks):** `dashboard-admin-page` (427-component template, the full surface), `dashboard-page-header`, `dashboard-{overview,audience,acquisition,behavior,conversion,reports,notifications}-panel`, `dashboard-chart-recent`, `dashboard-team-actions-storage`.
  - **Error + onboarding (§48, 5 chunks):** `error-404`, `error-500`, `error-maintenance`, `reg-step-shell`, `onb-step-shell`.

#### Changed

- **Shape B → Shape A codemod (§43, -486 warns).** 475 records / 79 files. Top transformations: `Text.color="muted"` → `variant="caption"` (244 records); `Text.weight="semibold"` → `strong: true` (146 records); `*.attrs: {...}` → flattened to top-level (146 records); `Text.content` → `textContent`, `Button.content` → `text`, `Badge.content` → `text` (84 records); 109 empty `attrs:{}` objects removed; 5 manual-review (Text.color=primary/success — needs design call).
- **Yaml-gap renames + dead-prop deletes (§44, -301 warns).** 105 records / 48 files. Renames: `Button.block` → `stretch` (23), `Button.ariaLabel` → `aria-label` (16), `Badge.color="primary"` → `variant="primary"` (11, 1:1 mapping), `Table.rows` → `Table.data` (6), `Toast.title` → `Toast.text` (6). Deletes (runtime ignores): `Text.grow` (20, no `:scope[grow]` in text.css), `Progress.max` (15, runtime hardcodes max=100), `Skeleton.variant` (8, runtime silently drops), `Toast.description` (6, runtime only has `text`).
- **§43 manual-review backlog retired (§50, -42 warns).** 74 records / 25 files. Subagent A's foundational finding: `attrs:{}` has zero runtime effect — no renderer/host spreads it onto the element. So every key inside `attrs:` is dead-letter; flatten or delete is always safe. Promoted 33 records from §43's MANUAL_REVIEW to HIGH-confidence codemod: `Toggle.attrs.checked` → top-level (6), `Text.attrs.muted=true` → `color: "muted"` (17), `Avatar.attrs.alt` → `text` (8, avatar.js:68 auto-mirrors name → `<img alt>`), `Avatar.attrs.fallback` → DELETE (5, redundant with auto-derived initials at avatar.js:96-110), `Divider.attrs.orientation="vertical"` → `vertical: true` (2), `Button.attrs.triggers` → DELETE (1, hallucinated wiring). Companion yaml-gap renames (§50): `Kbd.text`/`Kbd.keys` → `textContent` (10), `Pagination.totalPages`/`currentPage` → `total`/`page` (6), `Divider.orientation` → `vertical: true` (3), `Input.icon` → `prefix` (4), `Option.text` → `heading` (5).
- **Search → Input migration (§42, 5 critical → 0).** 5 compositions migrated from deprecated `Search` component to `Input type="search" prefix="magnifying-glass"`. `Search` deliberately remains absent from the registry per registry.js line 57.
- **Input.inputMode → Input.inputmode (§51, 3 records).** HTML standard is lowercase `inputmode`. Companion to the §51 renderer kebab-casing fix in `@adia-ai/a2ui-runtime`.

### Harvester (`scripts/build/harvest-chunks.mjs`, repo-level)

The harvester is repo-tooling (`scripts/build/`), not a corpus package member, but its changes power this arc's corpus output:

- **§40 `data-chunk-*` attribute extraction** — reads sibling attributes from `data-chunk` elements; populates the chunk record's `metadata` field.
- **§42 nested-expand-then-transpile pass** — after collection, recursively expands `<!-- nested: <name> -->` placeholders in annotated chunks, then transpiles the expanded HTML to A2UI templates via `transpileHTML(html, { mode: 'instant' })`.
- **§45 source-aware tier-1 expansion fix** — replaces §42's "first wins" canonical-html rule with directory-aware selection. **Bug**: `auth-card-content` has 24 instances; the 404 page sorted alphabetically first, so EVERY auth chunk silently inlined 404 page content from §41 landing through §45 discovery (smoke tests only checked retrieval strategy, not template content). **Fix**: Tier 1 exact directory match → Tier 2 deepest common directory prefix → Tier 3 alphabetical. Without it, `apps/user-flow/app/auth/sign-in/` shares depth with `apps/user-flow/app/auth/sign-in/mfa/` and tie-break would pick wrong sibling.

See root [CHANGELOG.md `[Unreleased]`](../../../CHANGELOG.md) for the cross-cutting arc narrative + [docs/journal/2026/05/2026-05-12.md](../../../docs/journal/2026/05/2026-05-12.md) §§ 36-51 for per-§ details.
## [0.4.3] - 2026-05-11

### Changed

- **`catalog-a2ui_0_9.json` regenerated** to pick up the new `locale` prop on `<input-ui type="number">` from `@adia-ai/web-components@0.4.3`. The yaml `props:` entry drives retrieval signal for locale-aware numeric-input intents.
- **`chunks/` re-harvested** (181 files touched). New chunk `settings-appearance.json` — multi-instance record covering both `catalog/ui-patterns/app/settings-appearance/` (primary=card-ui, standalone block pattern composing `<theme-panel>`) and `apps/saas/app/settings-page/` (primary=div, Workspace-level Appearance section). Plus a sweep of `captured_at` timestamps + `source:` field updates from the ADR-0026 reorg follow-up. Harvest now produces 180 unique chunks (was 179 in v0.4.2; +1 from the new `settings-appearance` pattern).
- **Harvester scope fix** — `scripts/build/harvest-chunks.mjs` `SOURCES = ['site/pages', 'apps']` hadn't been updated after ADR-0026 split `apps/` → `apps/` + `playgrounds/` + `catalog/` on 2026-05-10. Every `npm run harvest:chunks` since silently dropped 26 chunks (179 unique → 152 visible) without warning. Fix adds both new sibling directories to SOURCES. (Note: harvest-chunks.mjs lives in the repo's `scripts/build/` tree, not the package; this corpus regen captures the FULL chunk set restored by the fix. Lesson captured as Category E imperative-drift in user-memory entry `feedback_build_script_sources_list_after_rename.md`.)

### Lockstep

9-package coordinated PATCH cut to v0.4.3. Internal `@adia-ai/*` dep ranges stay at `^0.4.0` (patch-cut asymmetry). Rides alongside `@adia-ai/web-components` v0.4.3 (input-ui locale rewrite) and `@adia-ai/a2ui-compose` + `@adia-ai/a2ui-retrieval` v0.4.3 (process.env browser-compat fix). See root [CHANGELOG.md `## [0.4.3]`](../../../CHANGELOG.md).
## [0.4.2] - 2026-05-11

### Changed

- `catalog-a2ui_0_9.json` regenerated to pick up the 5 new `<input-ui type="number">` examples from `@adia-ai/web-components@0.4.2`: `quantity-stepper`, `price-with-currency`, `weight-with-unit`, `percent-bounded`, `temperature-negative`. The yaml `examples[]` entries drive retrieval signal for numeric-input intents (quantity / price / weight / percent / temperature).
- `catalog-a2ui_0_9_rules.txt` regenerated alongside.
- `chunks/` — `playground-app-shell.json` re-harvested after the `<theme-panel>` consumer migration (Phase 3 of theme-panel work): embedded HTML now shows `<theme-panel slot="content" parametric presets scheme-toggle></theme-panel>` instead of the ~30-line inline `<div id="theme-panel">` block. Chunk NAME `playground-app-shell` preserved as a stable retrieval identifier per the 2026-05-10 §22 lesson. 27 additional chunk files touched in this window for `source:` field updates following the ADR-0026 reorg (`apps/<X>/` → `playgrounds/<X>/` or `catalog/<X>/`); chunk NAMES unchanged.

### Removed

- `fragments/layout/auth-card-header.json` — fragment retired (was the foundational auth-flow chunk header before migration to `<auth-card-content>` + `<auth-card-header>` chunk-level shape; instance_count had reconciled to 0 in v0.4.1, no longer present in any composition). Now archived at `.brain/archive/2026-Q2/retired-fragments/auth-card-header.md` per the v0.4.1 follow-up.

### Lockstep

9-package coordinated PATCH cut to v0.4.2 (per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy)). Internal `@adia-ai/*` dep ranges stay at `^0.4.0` (patch-cut asymmetry — `^0.4.0` covers `0.4.x` under semver). Rides alongside `@adia-ai/web-components@0.4.2` (input-ui type=number rewrite) and `@adia-ai/web-modules@0.4.2` (editor-sidebar width mirror). See root [CHANGELOG.md `## [0.4.2]`](../../../CHANGELOG.md) for the cut narrative.
## [0.4.1] - 2026-05-10

### Changed

- **Fragment metrics reconciled** — 28 fragments updated to match computed values from `npm run audit:fragments`. 45 files modified (28 JSON + 17 YAML; 11 JSON have no YAML sibling). `audit:fragments` now reports 0 drift.
- **Special note: auth-card-header** instance_count reconciled from 23 → 0 (fragment no longer used by any composition). Pending decision on whether to deprecate or re-introduce.
- Catalog regenerated to include 3 new simple-cluster yamls (121 total).

### Added

- `docs/reports/chunk-reconcile-triage-2026-05-10.md` — triage doc documenting that all current `audit:chunk-reconcile` findings (9 fingerprint collisions + 19 near-duplicates + 10 cross-source) are intentional outcomes of the onb/reg alignment work + foundational shared chunks.
## [0.4.0] - 2026-05-10

### Ride-along (no corpus changes)

Lockstep MINOR cut alongside `@adia-ai/web-modules@0.4.0` (ADR-0024 legacy deprecation). Catalog regenerated; chunks/fragments/compositions/patterns byte-identical to v0.3.6.

Internal `@adia-ai/*` dep ranges bumped from `^0.3.0` to `^0.4.0`. See root [CHANGELOG.md `## [0.4.0]`](../../../CHANGELOG.md) for the cut narrative.
## [0.3.6] - 2026-05-10

### Changed

- **Component catalog regenerated** — 113 → 118 yamls (+5 from new editor-* bespoke children added in `@adia-ai/web-modules`). `catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` regenerated.

- **New catalog entries** for the editor-cluster bespoke family per ADR-0023:
  - `EditorToolbar` (editor-toolbar) — JS-bearing
  - `EditorCanvas` (editor-canvas) — JS-bearing
  - `EditorSidebar` (editor-sidebar) — JS-bearing (delegates to `<pane-ui>`)
  - `EditorStatusbar` / `EditorCanvasEmpty` — CSS-only structural

The catalog is consumed by `@adia-ai/a2ui-retrieval` for protocol-vocabulary composition. Composers (zettel, chunk-zettel) now have addressable entries for editor sub-regions in protocol vocabulary.

### No source changes

Corpus chunks, fragments, compositions, and patterns are byte-identical to v0.3.5. The only change is the regenerated catalog manifest.
## [0.3.5] - 2026-05-07

### Changed

- **Component catalog regenerated** — 107 → 113 yamls (+6 from new chat-* bespoke children added in `@adia-ai/web-modules`). `catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` regenerated by `scripts/build/components.mjs`.

- **New catalog entries** for the chat-cluster bespoke family per ADR-0023:
  - `ChatThread` (chat-thread) — JS-bearing (scroll surface)
  - `ChatComposer` (chat-composer) — JS-bearing (input wrapper)
  - `ChatSidebar` (chat-sidebar) — JS-bearing (resize+collapse)
  - `ChatHeader` / `ChatStatus` / `ChatEmpty` — CSS-only structural

The catalog is consumed by `@adia-ai/a2ui-retrieval` for protocol-vocabulary composition. Composers (zettel, chunk-zettel) now have addressable entries for chat sub-regions in protocol vocabulary.

### No source changes

Corpus chunks, fragments, compositions, and patterns are byte-identical to v0.3.4. The only change is the regenerated catalog manifest.
## [0.3.4] - 2026-05-07

### Changed

- **Component catalog regenerated** — 100 → 107 yamls (+7 from new admin-* CSS-only structural children added in `@adia-ai/web-modules`). `catalog-a2ui_0_9.json` + `catalog-a2ui_0_9_rules.txt` regenerated by `scripts/build/components.mjs`.

- **New catalog entries** for the bespoke shell-tier family per ADR-0023:
  - `AdminSidebar` (admin-sidebar) — JS-bearing
  - `AdminCommand` (admin-command) — JS-bearing
  - `AdminContent` / `AdminTopbar` / `AdminStatusbar` / `AdminScroll` / `AdminPage` / `AdminPageHeader` / `AdminPageBody` — CSS-only structural

The catalog is consumed by `@adia-ai/a2ui-retrieval` for protocol-vocabulary composition. Composers (zettel, chunk-zettel) now have addressable entries for shell sub-regions instead of falling back to chunk-name retrieval.

### No source changes

Corpus chunks, fragments, compositions, and patterns are byte-identical to v0.3.3. The only change is the regenerated catalog manifest.
## [0.3.3] - 2026-05-07

**Lockstep cut.** All 9 published `@adia-ai/*` packages now share version `0.3.3`, governed by [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy). Internal `@adia-ai/*` ranges stay at `^0.3.0` (patch-cut asymmetry — caret floats `0.3.x`).

### Added

- **`fragments/layout/auth-card-header.json`** — first fragment
  promoted from chunk corpus. Was 23 instances across user-flow auth
  pages (sign-in, sign-up, recovery, account-deleted, email-verify,
  forbidden) + error pages (404, 500, maintenance), all sharing the
  same shape: `Header > Column[align=center,gap=1] >
  [Link>Image, Text(h1), Text]`. 4 slots
  (logo-href, logo-src, title, description). Promotion provides 23×
  leverage over chunk-by-chunk emission. Zettel retrieval test:
  score 88 vs 48 next alternative. (closes backlog #65)

- **`A2UI_DISABLE_EMBEDDINGS` env-var override** in
  `scripts/chunk-library.js`. When set, `searchChunksAsync()` falls
  through to keyword-only search instead of attempting embeddings.
  Used by the new top-level `npm run eval:keyword-only` script.
  Latency drops from 100-400ms to 0-1ms with same scores; proves
  keyword path is independently healthy. (closes backlog #11)

- **Glossary section** in README.md — chunk vs pattern vs fragment
  vs composition. Four overlapping concepts circulate through this
  package; the glossary disambiguates. (closes backlog #94)

- **Catalog manifest documentation** — README updated to clarify
  that `retrieval/catalog.js` is **hand-written** (a CatalogManifest
  module that dynamically reads per-component `<c>.a2ui.json`
  sidecars at runtime), NOT a generated artifact. The actual
  generated artifacts are `traits/_catalog.json` and per-component
  `<name>.a2ui.json` sidecars. (companion to AGENTS.md hard-rule #7
  correction; closes backlog #57)
## [0.3.2] - 2026-05-06

**9-package lockstep patch cut to v0.3.2.** All lockstep members share
one version per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy).
Internal `@adia-ai/*` dep ranges unchanged at `^0.3.0`.

### Added

- **Corpus re-harvest** — 173 unique chunks (from 160), 322 instances.
  13 new block patterns (`command-palette-grouped`, `agent-activity-feed`,
  `agent-reasoning-collapsed`, `user-profile-card`, `kanban-board-3col`,
  `chat-streaming-surface`, `settings-notifications`, `marketing-hero-cta`,
  `conversion-funnel-6step`, `users-table-badge`, `destructive-confirm-modal`,
  `editor-code-pane`, `editor-preview-pane`) + 5 new page shells
  (`settings-page-shell`, `form-page-shell`, `marketing-page-shell`,
  `error-page-shell`, `editor-page-shell`).
- **Harvester source expansion** — `apps/` added alongside `site/pages/`;
  `apps/generic-shells/app/` contributes the 5 generic page shells.

### Fixed

- **`data-chunk-slot` preservation** — `stripChunkAttrs()` regex narrowed
  to only strip `data-chunk` + `data-chunk-kind`; no longer strips
  `data-chunk-slot` (composer runtime dependency for slot-finding).

### Changed

- `version`: `0.3.1` → `0.3.2`.
## [0.3.1] - 2026-05-06

**9-package lockstep patch cut.** All 9 published `@adia-ai/*` packages bump 0.3.0 → 0.3.1 per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy). Internal `@adia-ai/*` dep ranges remain at `^0.3.0` (covers `0.3.1` under semver — patch-cut asymmetry).

This package itself ships **no source changes** in v0.3.1. The cut bumps version only — substantive content lives in [`@adia-ai/web-components`](https://github.com/adiahealth/gen-ui-kit/releases/tag/web-components-v0.3.1) (folder-per-trait restructure; barrel API unchanged).

### Changed

- `version`: `0.3.0` → `0.3.1`.
- Internal `@adia-ai/*` dep ranges: unchanged at `^0.3.0` (covers `0.3.1` under semver — patch-cut asymmetry).
## [0.3.0] - 2026-05-05

**9-package lockstep cut.** All 9 published `@adia-ai/*` packages bump 0.2.5 → 0.3.0 per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy). Internal `@adia-ai/*` dep ranges bump `^0.2.0` → `^0.3.0`.

The lockstep policy expanded from 8 to 9 packages with this cut — `@adia-ai/llm` joins as a 9th member, and `@adia-ai/a2ui-utils` was renamed to `@adia-ai/a2ui-runtime`. Both are BREAKING for npm consumers (acceptable under pre-1.0 semver).

This package itself ships **no source changes** in v0.3.0. The cut bumps version + the internal dep range only.

### Changed

- `version`: `0.2.5` → `0.3.0`.

### No source changes

`a2ui-corpus` source is byte-identical to `0.2.5`. The cut bumps version only — corpus has no `@adia-ai/*` dependencies so no dep-range updates either.
## [0.2.5] - 2026-05-04

**Lockstep cut + catalog regen for `<fields-ui>` primitive.** All 8 published `@adia-ai/*` packages bump 0.2.4 → 0.2.5 per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy). Patch cut — **no BREAKING changes**.

### Changed

- `version`: `0.2.4` → `0.2.5`.
- `catalog-a2ui_0_9.json`: 1 new entry covering the new `<fields-ui>` primitive (component class `Fields`, tag `fields-ui`, props `[columns]` + `[inline]`, default slot for `<field-ui>` children + the `rows` span pattern). Catalog: 97 → 98 yamls.
- Per-element `fields/fields.a2ui.json` written by `scripts/build/components.mjs`.
## [0.2.4] - 2026-05-04

**Lockstep cut + catalog regen for `<demo-toggle-ui>` primitive.** All 8 published `@adia-ai/*` packages bump 0.2.3 → 0.2.4 per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy). Patch cut — no breaking changes.

### Changed

- `version`: `0.2.3` → `0.2.4`.
- `catalog-a2ui_0_9.json`: 6 new references (name + slots + events + props + tokens + example) covering the new `<demo-toggle-ui>` primitive added in `web-components@0.2.4`.

### Changed — Catalog regenerated against `web-components` Tier-4 surface

`catalog-a2ui_0_9.json` regenerated to include the new
`<demo-toggle-ui>` primitive (6 references covering name + slots +
events + props + tokens + example) authored alongside the trait-
library lift initiative's Tier 5 work. No other corpus surface
changed; new traits introduced in `web-components` are picked up via
the generated `_catalog.json` consumed by
`@adia-ai/a2ui-retrieval`.

---
## [0.2.3] - 2026-05-04

**Lockstep cut.** All 8 published `@adia-ai/*` packages bump
0.2.2 → 0.2.3 per
[`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy).
Patch cut — no breaking changes.

### Changed

- `version`: `0.2.2` → `0.2.3`.

### No source changes

`@adia-ai/a2ui-corpus` source is byte-identical to `0.2.2`. The cut bumps version only.
## [0.2.2] - 2026-05-02

**Lockstep cut.** All 8 published `@adia-ai/*` packages bump 0.2.1 → 0.2.2 per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy). Patch cut — no breaking changes.

### Changed

- `version`: `0.2.1` → `0.2.2`.

### No source changes

`a2ui-corpus` source is byte-identical to `0.2.1`. The cut bumps version only.

---
## [0.2.1] - 2026-05-02

**Lockstep cut + chunk-corpus reorganization mega-arc + trait registry regenerated from web-components SoT.** All 8 published `@adia-ai/*` packages bump 0.2.0 → 0.2.1 per [`docs/specs/package-architecture.md` § 15](../../../docs/specs/package-architecture.md#15-versioning-policy). Patch cut — no breaking changes.

### Changed

- `version`: `0.2.0` → `0.2.1`.
- `evals/holdout-compose-from-chunks.jsonl` migrated **into** corpus from a2ui-mcp (was at `packages/a2ui/mcp/evals/`). 20-intent compose-from-chunks holdout now lives next to the corpus it tests. `evals/run.mjs` updated to load from the new home; the legacy `evals/harness.mjs` was retired (its functionality merged into `run.mjs`).

### Changed — Trait registry now generated from web-components SoT (2026-05-02)

`packages/a2ui/retrieval/catalog.js` no longer carries a hand-curated `traitRegistry` array. The trait list is loaded at module init from `packages/web-components/traits/_catalog.json` (generated by `node scripts/build/traits-catalog.mjs` in the monorepo root from live `defineTrait()` metadata). Per [ADR-0018](../../../.brain/adrs/0018-trait-source-of-truth-and-declarative-attribute.md).

Behavior changes:
- 4 phantom traits (`disabled-state`, `form-associated`, `value-sync`, `resettable`) no longer appear in MCP `get_traits` responses — they had no implementation in `traits/`. Auto-pruned by construction.
- 2 naming mismatches resolved: `resize-observer-trait` → `resize-observer`, `intersection-observer-trait` → `intersection-observer`. The catalog now uses the same names as the trait files.
- Trait entries now include the full schema (`attributes`, `events`, `config` arrays) instead of just `{ name, category, description }`. Consumers reading `getTraits()` get richer metadata. Older shape is a strict subset, no breakage.

### Changed

- **`chunk-embeddings.json` (~20 MB) and `pattern-embeddings.json` (~3 MB)
  removed from the published npm tarball.** Both files remain committed in
  git so the monorepo's own pipeline runs unchanged. Published-tarball size
  drops from ~24 MB unpacked to ~3.4 MB.

  Consumers who need embedding-based retrieval regenerate locally via
  `npm run build:embeddings:all` (requires API access to the embedding
  provider). Keyword-only retrieval (`searchChunks` / `searchPatterns`)
  works unchanged without the indexes — the embedding-aware async paths
  (`searchChunksAsync` / `searchPatternsAsync`) fall through to keyword
  scoring when the index file is absent (`chunk-embedding-retriever.js`
  returns `null` gracefully on `ENOENT`).

  Note: the prior `chunk-embedding-retriever` path (`../../corpus/chunk-embeddings.json`)
  resolves correctly inside the monorepo but breaks under a
  `node_modules/@adia-ai/a2ui-corpus/` install layout — so the embedding
  files were already unreachable to npm consumers, just heavy. This change
  surfaces that reality. Published-consumer reachability is a separate
  follow-up.

  See README § "What's committed vs generated vs published".

### Changed — Chunk corpus reorganization mega-arc (2026-05-02)

12-commit arc that re-balances the chunk corpus for retrieval precision and harvester hygiene. End state: 100 compositions, 41 fragments, 1,422 chunks, 41 MB embeddings, fragment reuse ratio 40.2% (was 29.9% pre-§37; floor: 29.9%). Eval byte-identical: zettel coverage 83% / avgScore 89 / MRR 0.986 throughout.

- **`section-with-stack` fragment promoted** — first corpus use of children-as-attribute slot binding. 43 inline `Section(Column)` pairs collapsed into the new fragment at `fragments/layout/section-with-stack.json`.
- **Multi-variant chunk split (308 → 937 per-variant chunks).** Harvester migrated from `<section>`-wrapper-tagging to inner-pattern-tagging; multi-variant artifact-items now produce one chunk per visual variant (`alert-variant-warning` vs `alert-variant-success`) instead of one bundled chunk. Embedding-probe verified the precision lift: "warning alert" → `alert-variant-warning` (0.657), "large avatar" → `avatar-size-lg` (0.639), "small primary button" → `button-size-primary-sm` (0.656).
- **Skeleton harvest** (`collapseNestedChunkContent`) — page/panel chunks with nested `data-chunk` children replace the inner content with `<!-- nested: <name> -->` so the parent chunk is a compact skeleton recording structure + which sub-chunks fill which positions. xl-bucket chunks (>10K chars): 2 → 0.
- **Harvest-side hygiene** — strip `data-chunk` attribute from output HTML; strip docs-page wrappers; de-dup adjacent slug tokens; new Case 3 in `stripChunkWrappers` for `<div data-artifact-item data-chunk>` patterns.
- **Multi-variant CSS narrowing** — `dev-chunks.css` outline narrows to `[data-artifact-container]` so the visual marker matches the harvested scope.

### Added — Under-harvest audit script (2026-05-02)

New `scripts/build/under-harvest-audit.mjs` flags pages under `site/pages/{patterns,examples,components}/` that have ≥2 substantive layout elements (`<section>`/`<card-ui>`/`<grid-ui>`) but fewer than 1-per-5KB-body `data-chunk` markers. Drives a recurring 2-week remote agent (`trig_01UEDMT1cMqCpRLU6z8LBMo4`) that opens triage PRs for under-harvested pages.

### Fixed — A2UI registry gap closure + ADR-0015 pattern migration (2026-05-02)

- **Registry additions** in `@adia-ai/a2ui-utils`: `Field`, `Rating`, `ListItem`, `NavItem`, `NavGroup`. All 5 components existed; only the registry mapping was missing. Net effect on the corpus: 28/113 hand-authored patterns previously rendered with `[unknown: X]` placeholders when imported into `/site/playground/a2ui-editor`. After: 0/113 unknown.
- **`patterns/navigation/section-subnav.json`** migrated per [ADR-0015 § Nav consolidation](../../../.brain/adrs/0015-three-tier-naming-convention.md). `SectionNav` → `Nav variant=section`; `SectionNavItem` → `NavItem`. The pattern was referencing the retired 6-element nav family.
- **`patterns/layout/weather-widget.json`** — renamed `Metric` → `Stat` (no `<metric-ui>` exists; `Stat` is the canonical metric/value/change/trend primitive).
- Smoke side-effect: zettel score bumped 91 → 92; smoke validation flipped from `valid=false score=98/91` → `valid=true score=100/92`. The registry gaps were tripping validation upstream.

Per-finding triage in [`docs/reports/playground-examples-review-2026-05-02.md`](../../../docs/reports/playground-examples-review-2026-05-02.md).
## [0.2.0] - 2026-05-02

**Lockstep cut.** All 8 published `@adia-ai/*` packages now share one
version, governed by [`docs/specs/package-architecture.md` § 15
(Versioning Policy)](../../../docs/specs/package-architecture.md#15-versioning-policy).

This release also formalizes corpus's role as **the catalog's home** —
spec § 3 first-principle 3 was rewritten in v0.6.0 of the spec to
make this explicit. Primitives produce YAML/`.a2ui.json` sidecars;
the build assembles them into `catalog-a2ui_0_9.json` here.

### Changed

- `version`: `0.0.9` → `0.2.0`.

### No source changes (data)

Corpus content (catalog, patterns, fragments, compositions, exemplars,
chunks, embeddings, eval fixtures, gap registry, feedback) is
byte-identical to 0.0.9. The cut bumps version only — corpus has no
internal `@adia-ai/*` dependencies. The `a2ui-mcp@0.1.3 → corpus@0.0.6`
caret-lock bug from the prior cut is resolved by the mcp package's
`^0.2.0` range update in this same lockstep cut.

### Touched (no behavior change)

- `scripts/run-pipeline.mjs`, `scripts/chunk-library.js`,
  `scripts/feedback-promote.js`, `scripts/feedback-report.js` — import
  paths swept to match the compose `engines/` → `strategies/` rename
  and the retrieval subdir reorganization. Pure path-string updates;
  no logic changes.
## [0.0.9] - 2026-05-01

Pure-data refresh covering the §22-25 web-components arc. Catalog
regenerated against the post-rename + post-consolidation surface;
chunks re-harvested where source pages changed. Rolls forward the
[0.0.8] cut (avatar-ui canonicalization) — the 0.0.8 bump was
prepared but never tagged + published; its content is part of this
release.

### Changed

- **Catalog regenerated against `web-components@0.0.33` surface** — 95
  yamls now include the consolidated nav family (`<nav-ui>`,
  `<nav-group-ui>`, `<nav-item-ui>` with `[variant="primary"|"section"]`)
  and the renamed module elements (`<chat-shell>` was
  `<adia-chat-ui>`; `<editor-shell>` was `<adia-editor-ui>`;
  `<admin-shell>` was `<app-shell-ui>`; `<gen-root>` was
  `<gen-ui-ui>`; `<chat-thread-ui>` was `<chat-ui>`). Element renames
  per [ADR-0015](../../../.brain/adrs/0015-three-tier-naming-convention.md);
  nav consolidation per ADR-0015 § Nav consolidation. The 6-element
  nav family (`<app-nav-*>` + `<section-nav-*>`) collapsed into 3
  primitives. Synthesizer no longer emits the renamed-away tags.
- **`yaml name:` fields swept** per
  [ADR-0016](../../../.brain/adrs/0016-class-naming-convention.md) —
  primitives now `name: UI<X>` (was `Adia<X>`); modules now
  `name: <X>` without the `Adia` prefix. Consumers reading the
  catalog to cross-reference class names get the current convention.
- **`patterns/_components.json`** refreshed to match the new
  catalog surface (component IDs, allowed children, slot vocabularies).
- **Chunks re-harvested** for the chat / playground-app-shell /
  playground-chat / playground-construct-canvas / playground-gen-ui
  source pages — these surfaces touched the renamed shells +
  consolidated nav and now emit canonical post-rename markup.
- **`scripts/extract.js`** updated to recognize the renamed elements
  + `[variant]` cascade markers when classifying chunks.

### Rolled forward from [0.0.8] (never tagged)

- **`<avatar-ui name=…>` → `<avatar-ui text=…>`** sweep across 8
  source pattern pages (31 instances). `name` is the deprecated alias
  scheduled for removal; chunks now carry the canonical attribute.
  Chunk count + shape unchanged; embedding index unaffected (only
  chunk-root attrs are indexed; `<avatar-ui>` is always nested in
  body HTML).
## [0.0.8] - 2026-05-01

Pure-data refresh. Chunk re-harvest aligns the corpus with the
canonical attribute API for `<avatar-ui>` so the synthesizer doesn't
teach consumers to emit deprecated markup.

### Changed

- Chunks re-harvested after sweeping `<avatar-ui name=…>` →
  `<avatar-ui text=…>` across 8 source pattern pages (31 instances).
  `name` is the deprecated alias scheduled for removal; chunks now
  carry the canonical attribute. Pure data change — chunk count +
  shape unchanged (761 unique / 911 instances), embedding index
  unaffected (only chunk-root attrs are indexed; `<avatar-ui>` is
  always nested in body HTML).
- Catalog regenerated against `web-components@0.0.29` surface
  (`<feed-ui>` + `<feed-item-ui>` + `<swatch-ui>` family entries
  carried through, app-shell slot-vocabulary parity reflected).
## [0.0.7] - 2026-04-28

### Added

- **Two new `page`-kind chunks**: `reg-step-shell` (registration
  multi-step wizard wrapper) and `onb-step-shell` (onboarding tour
  wrapper). Both expose four named slots — `page-story`, `page-header`,
  `page-content`, `page-footer` — that the chunk synthesizer binds
  block-kind chunks into. Five existing reusable blocks per family
  (`*-story-pane`, `*-step-header`, `*-step-footer`, `*-step-progress`,
  per-step content block) recorded as the shells' `nested` chunks.

  Page-kind catalog is now 3 (was 1): `dashboard-admin-page`,
  `reg-step-shell`, `onb-step-shell`.

  Source pages: `site/pages/examples/registration/personal/index.html`
  + `site/pages/examples/onboarding/welcome/index.html` — one canonical
  instance each. The other 18 reg + 9 onb step pages share the same
  template; replicating shell tags would produce duplicate instances
  without changing the unique-name catalog.

  Unlock: `compose_from_chunks(intent)` can now synthesize multi-step
  wizard pages and onboarding-tour pages on top of the existing
  admin-dashboard shape — 3× expansion of the page-kind catalog.
## [0.0.6] - 2026-04-28

**Retires the legacy exemplar extract → ingest path.** The chunk corpus
+ chunk-aware synthesizer (shipped 0.0.3 → 0.0.4 → 0.0.5 today) is now
the single training surface; the parallel exemplar-derived auto-ingest
that was running on every MCP server boot is gone.

### Removed

- **Stale auto-generated artifacts** under `exemplars/<category>/<name>/`:
  - `a2ui.json` (full-page A2UI extract; 9 files)
  - `chunks/*.json` per-exemplar atomic chunks (~70 files)
  These were transient build outputs of the old extract.js pipeline. The
  source `index.html` + `<name>.yaml` files stay for human reference and
  potential future use as fragment authoring.

### Changed

- The `extract.js` + `ingest.js` scripts still ship in the tarball as
  legacy tools. They no longer run by default in `run-pipeline.mjs`;
  pass `--legacy-exemplars` to opt back in. See companion mcp 0.0.5
  release notes for the runtime impact.

### What stayed the same

- Hand-authored `patterns/` (155 entries), `fragments/` (zettel graph),
  `compositions/`, `pattern-embeddings.json`, `chunk-embeddings.json`,
  `chunks/_index.json` (701 unique / 851 instances), and the
  `chunk-library` API are all unchanged.
- The `exemplars/` source HTML + `<name>.yaml` partners stay in the
  tarball — useful for reference, but no longer feed the training
  pipeline by default.
## [0.0.5] - 2026-04-28

Corpus refresh — drops a non-chunk-shaped entry and regenerates both
embedding indices. Pure-data; no schema changes; no consumer-facing
API impact beyond a slight retrieval-quality bump.

### Removed

- **`genui-feed-message` chunk** — `<col-ui id="gen-feed">` on
  `gen-ui-feed/index.html` is sample-data scaffolding (the feed
  structure varies entirely per session), not a discrete trainable
  pattern. The `data-chunk` marker was dropped; the source page
  itself stays. Inventory entry struck through, kept as a strikethrough
  audit trail.

### Changed

- **`chunks/_index.json` re-harvested** — 702 → **701 unique** chunks;
  852 → **851 instances**; by-kind `block=843, panel=7, page=1`.
- **`chunk-embeddings.json` regenerated** — 701 × 1536d (was 702).
  Same provider / model / dims; just one fewer entry.
- **`pattern-embeddings.json` regenerated** — same 113 × 1536d count;
  fresh timestamp.
## [0.0.4] - 2026-04-28

Same-day follow-up to `0.0.3` shipped earlier today. Adds **semantic
search vectors** to the corpus and ships them in the tarball so consumers
get embedding-based retrieval out of the box (no post-install build step).
Pure-data addition; no schema changes.

### Added

- **`pattern-embeddings.json`** — refreshed against the current
  113-pattern set (was last built 2026-04-23 against 109 patterns).
  OpenAI text-embedding-3-small, 1536 dims, ~3.3 MB.
- **`chunk-embeddings.json`** — NEW. 702 chunks × 1536 dims, ~20 MB.
  Embeds each chunk's name + kind + primary tag + slot names + nested
  chunk names + indexed attributes + cluster prefix. HTML body is
  deliberately NOT embedded (would dominate retrieval noise; the LLM
  gets the HTML at retrieval time).

### Changed

- `package.json` `files` field now ships both embedding indices in the
  published tarball. Tarball size grows from ~3.5 MB to ~24 MB; the
  trade-off is that consumers can use semantic search out of the box
  without re-running embedding generation.
- Companion repo tooling (not in tarball but used to generate the
  corpus):
  - `scripts/build/embeddings.mjs` — broken `import` paths fixed (the
    script had been dead since some directory move; load-env.mjs +
    embedding-provider.js were both at wrong relative paths).
  - **`scripts/build/embeddings-chunks.mjs`** — new sibling script that
    walks `chunks/<name>.json` and generates `chunk-embeddings.json`.
    Auto-detects Voyage / OpenAI / null per the same conventions as the
    pattern script. Honors `--kind`, `--batch`, `--out`, `--dry-run`.
  - `npm run build:embeddings` / `build:embeddings:chunks` /
    `build:embeddings:all` pipeline scripts.

### Performance

- The chunk-aware composition synthesizer (`@adia-ai/a2ui-mcp@0.0.3`)
  uses these embeddings via `chunk-embedding-retriever.js` (cosine
  similarity, blended 5× with keyword score). Real-LLM eval improved
  from 7/10 → **9/10 retrieval hits** out of 10 hold-out intents — only
  novel composites still need synthesis fallback.
## [0.0.3] - 2026-04-28

Same-day extension after `0.0.2` shipped. Adds the **gen-UI training-chunk
corpus** — 702 unique chunks (852 instances) harvested from `data-chunk`-marked
elements across `site/pages/*` and the corpus exemplars. Pure-data addition;
existing pattern/fragment/composition surface unchanged.

### Added (gen-UI chunks)

- **`chunks/<name>.json`** × 702 — one record per chunk; carries
  `name`, `kind` (`block` | `panel` | `page`), `primary` (outer tag),
  `slots[]` (named regions for compositional reasoning), `nested[]`
  (child chunk names), `attrs` (indexed for retrieval), `html`
  (bounding HTML, descendants intact), `source` (original file path),
  `captured_at`. Multi-instance reusable slot chunks
  (e.g. `auth-card-header`, `reg-step-header`) carry an `instances`
  array — one entry per page where the chunk appears.
- **`chunks/_index.json`** — aggregate index (metadata only, no HTML)
  for fast lookup. Records total counts, by-kind tallies, per-chunk
  pages + slot names + nested-chunk references.
- **852 chunk instances** across ~150 distinct pages (70 template +
  82 component primitive + 16 pattern). Coverage:
  `block=844, panel=7, page=1`.

### Added (companion tooling — not in tarball)

- `scripts/build/harvest-chunks.mjs` (repo root) — walks site/pages
  + corpus exemplars; depth-tracked HTML parser; writes per-chunk
  records + aggregate index. Wired into
  `packages/a2ui/corpus/scripts/run-pipeline.mjs` Step 1.
- `packages/a2ui/corpus/scripts/chunk-library.js` — in-memory loader
  for the chunk corpus; powers the new MCP retrieval tools (consumed
  by `@adia-ai/a2ui-mcp@0.0.2`).
- `npm run harvest:chunks` / `harvest:chunks:dry` — pipeline scripts.

### Convention reference

- Spec: [`docs/specs/genui-chunk-marker.md`](../../../docs/specs/genui-chunk-marker.md)
  (Draft v0.1.0) — three attributes (`data-chunk`, `data-chunk-kind`,
  `data-chunk-slot`); naming conventions per cluster; visual marker
  rules; harvester contract.
- Inventory: [`docs/specs/genui-chunk-inventory-001.md`](../../../docs/specs/genui-chunk-inventory-001.md)
  — full list with intent labels + review status.
## [0.0.2] - 2026-04-27

Three-day batch since `0.0.1`. Catalog regenerated against the
Phase 6 web-components surface (status enum, button `[color]` axis,
canonical event names); four new dashboard / data patterns; nine
prose exemplars purged of inline styles; auth-login + cta exemplars
migrated to canonical field-ui wrapping; three superseded fragments
removed. Pure-data package — no executable code change.

### Added (patterns)

- **`patterns/data/chart-card-with-trend-footer.{json,yaml}`** —
  card-ui composition with chart in body and trend-stat footer
  (KPI delta + sparkline). Dashboard pattern.
- **`patterns/data/chart-grid-with-kpis.{json,yaml}`** — grid-ui
  layout pattern with KPI cards above and chart-ui beneath, the
  canonical "dashboard above the fold" shape.
- **`patterns/data/chart-with-filter-pills.{json,yaml}`** —
  chart-ui composed with row-ui of filter pills above (segmented-ui
  / tag-ui mix), the standard chart-with-toolbar shape.
- **`patterns/data/stat-with-sparkline.{json,yaml}`** — atomic
  KPI stat pattern with inline sparkline. Used as the building
  block for `chart-card-with-trend-footer`.

### Added (authoring infrastructure)

- **`exemplars/_shell.css`** — shared body-shell + decoration-class
  stylesheet linked from the corpus exemplar root. Codifies the
  "no inline styles in exemplars" rule documented in the project
  CLAUDE.md / AGENTS.md. New exemplars link this file from their
  `index.html` and rely on `col-ui` / `row-ui` / `grid-ui` for
  layout instead of `<style>` blocks or `style="…"` attributes.

### Changed (catalog)

- **`catalog-a2ui_0_9.json`** rebuilt against the v0.0.20 / v0.0.21
  web-components yaml surface. Diff includes:
  - `status` enum on `timeline-item-ui` / `stepper-item-ui` /
    `pipeline-status-ui` (replaces the prior multi-Boolean shape).
  - `[color]` enum on `button-ui` (`default | accent | info |
    success | warning | danger`), `variant` simplified to
    style-only.
  - Canonical event names — `submit` on `chat-ui` (was
    `chat-submit`), `toggle` on `chart-legend-ui` (was
    `legend-toggle`), `change` on `swiper-ui` (was `slide-change`).
  - `error` variant alias dropped from `toast-ui` / `alert-ui` /
    `tag-ui` enums.
  - `agent-trace-ui` `[collapsed]` (was `[open]`).
  - `field-ui` `error` prop removed from props list.
  - `table-toolbar-ui` opt-out attribute names — `noFilter` /
    `noSort` / `noColumns` / `noSearch`.
- **`patterns/_components.json:3020`** — `timeline-item-ui`
  children-snippet migrated `completed active` → `status="completed"`.
  The snippet feeds the LLM bridge; the legacy form would have
  caused gen-ui to suggest deprecated attributes when generating
  timelines.
- **`patterns/_index.json`** regenerated to reflect the four new
  data patterns and a few keyword refinements.

### Changed (exemplars)

- **9 prose exemplars** (`prose/auth-login`, `prose/cta`,
  `prose/feature-grid`, `prose/footer`, `prose/hero`,
  `prose/pricing`, `prose/steps`, `prose/testimonials`) and
  **`ui/auth-login`** purged of inline `<style>` blocks and
  `style="…"` attributes. Width constraints come from `setup.js`
  setting `--page-content-max-width` via
  `setProperty`; layout from `col-ui` / `row-ui` / `grid-ui`;
  asymmetric ratios from `[columns]` + `[span]`. Shadow + decoration
  surface lifted to `_shell.css`.
- **`exemplars/prose/auth-login/index.html` + `exemplars/ui/auth-login/index.html`** —
  `<check-ui label="…">` migrated to canonical
  `<field-ui inline label="…"><check-ui name="…"></field-ui>`
  wrapping. 5 call sites total (Remember me, Trust this device,
  Terms agreement). Each migrated checkbox now serializes with a
  stable form key (`name="remember"` / `name="trust_device"` /
  `name="terms"`).
- **`exemplars/prose/cta/`** — `acme-logo` icon (fictitious; not
  in `@phosphor-icons/core`) replaced with `hexagon` across 3
  files: `index.html:21`, `a2ui.json:102`,
  `chunks/prose-cta-card-1.json:65`. Cleared the
  `Icon "acme-logo" not found in registry` warning that fired on
  every render.

### Removed (fragments)

- **`fragments/content/chart-legend.json`** — superseded by the
  `<chart-legend-ui>` primitive that landed in the web-components
  package. Inline-rendering the legend as a fragment is no longer
  the canonical path.
- **`fragments/form/rating-row.{json,yaml}`** — superseded by
  the `<rating-ui>` primitive's first-class API (label + value
  + max + readonly all on the host element).

### Verification

- `node scripts/build/components.mjs --verify` — `clean — 96 files up-to-date`.
- Catalog hash matches the rebuild script's deterministic output.
- Pattern index reverse-lookup test: every `_index.json` ref
  resolves to an existing pattern file.

---
## [0.0.1] - 2026-04-24

First public release. Pure-data package: pattern corpus,
fragment + composition library, exemplars, and held-out eval
fixtures for the A2UI generation pipeline.

### Included

- **Assembled catalog** (`catalog-a2ui_0_9.json`) — generated by
  `scripts/build-components.mjs` from the per-component YAML
  sources in `@adia-ai/web-components`. Contains component schemas,
  registry, domain classifications, fragments, compositions.
- **Rules manifest** (`catalog-a2ui_0_9_rules.txt`) — human-readable
  rules file paired with the catalog.
- **Patterns** (`patterns/`) — ~217 patterns across 11 domains
  (layout, forms, data, agent, navigation, display, container,
  settings, etc.). Indexed via `patterns/_index.json`.
- **Fragments** (`fragments/`) — reusable A2UI atoms used by
  zettel-engine composition.
- **Compositions** (`compositions/`) — templates that reference
  fragments via `$fragment` refs.
- **Exemplars** (`exemplars/`) — few-shot training examples per
  domain. Consumed by the monolithic engine's prompt assembly.
- **Held-out eval fixtures** (`evals/held-out.jsonl`) — 100 intents
  reserved from training for regression evaluation.

### Corpus state at cut

See the "Corpus state" section below for pattern counts by domain,
fragment library size, and composition coverage.

---

## Corpus state (current)

| Surface | Count |
|---|---:|
| Patterns (total) | 215 |
| Pages (exemplars) | 9 |
| Chunks | 61 |
| Components registered | 89 |
| Fragments | varies; see `fragments/` |

Domain breakdown:
- layout: 114
- forms: 38
- data: 23
- agent: 20
- navigation: 11
- display, container: 3 each
- settings, data-display, input: 1 each
## [0.1.0] — internal baseline (pre-public, predates 0.0.1)

Initial version at the time the monorepo was established. Contains:

- **Patterns** (`patterns/`) — monolithic pattern library with schema.
- **Fragments** (`fragments/`) — atomic fragments for the zettel engine (content, layout, wiring, etc.).
- **Compositions** (`compositions/`) — hand-authored compositions that reference fragments.
- **Exemplars** (`exemplars/`) — hand-authored HTML pages harvested into chunks during extraction.
- **Held-out eval set** (`evals/held-out.jsonl`) — ~100 intents with golden matches for regression testing.
- **Feedback / gaps registry** (`feedback/`, `gaps/`) — runtime-written operational learning.
- **Taxonomy / synonym registry** — concept mapping for keyword-based retrieval.

Package name still uses the legacy `@adia-ai/a2ui-corpus` scope pending rename (see root CHANGELOG for context).
