@adia-ai/web-components 0.4.7 → 0.4.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (211) hide show
  1. package/README.md +39 -0
  2. package/components/accordion/accordion.a2ui.json +3 -0
  3. package/components/accordion/accordion.d.ts +12 -2
  4. package/components/accordion/accordion.yaml +4 -0
  5. package/components/action-list/action-list.a2ui.json +3 -0
  6. package/components/action-list/action-list.d.ts +12 -2
  7. package/components/action-list/action-list.yaml +4 -0
  8. package/components/agent-artifact/agent-artifact.a2ui.json +4 -0
  9. package/components/agent-artifact/agent-artifact.d.ts +12 -2
  10. package/components/agent-artifact/agent-artifact.yaml +5 -0
  11. package/components/agent-feedback-bar/agent-feedback-bar.a2ui.json +3 -0
  12. package/components/agent-feedback-bar/agent-feedback-bar.d.ts +14 -2
  13. package/components/agent-feedback-bar/agent-feedback-bar.yaml +4 -0
  14. package/components/agent-questions/agent-questions.a2ui.json +3 -0
  15. package/components/agent-questions/agent-questions.d.ts +12 -2
  16. package/components/agent-questions/agent-questions.yaml +4 -0
  17. package/components/agent-reasoning/agent-reasoning.a2ui.json +4 -0
  18. package/components/agent-reasoning/agent-reasoning.d.ts +16 -2
  19. package/components/agent-reasoning/agent-reasoning.yaml +5 -0
  20. package/components/agent-suggestions/agent-suggestions.a2ui.json +3 -0
  21. package/components/agent-suggestions/agent-suggestions.d.ts +12 -2
  22. package/components/agent-suggestions/agent-suggestions.yaml +4 -0
  23. package/components/agent-trace/agent-trace.a2ui.json +1 -0
  24. package/components/agent-trace/agent-trace.d.ts +12 -2
  25. package/components/alert/alert.a2ui.json +1 -0
  26. package/components/alert/alert.d.ts +12 -2
  27. package/components/aside/aside.a2ui.json +1 -0
  28. package/components/avatar/avatar.a2ui.json +3 -0
  29. package/components/avatar/avatar.d.ts +3 -2
  30. package/components/avatar/avatar.yaml +4 -0
  31. package/components/badge/badge.a2ui.json +3 -0
  32. package/components/badge/badge.d.ts +3 -2
  33. package/components/badge/badge.yaml +4 -0
  34. package/components/block/block.a2ui.json +1 -0
  35. package/components/block/block.d.ts +3 -2
  36. package/components/breadcrumb/breadcrumb.a2ui.json +5 -0
  37. package/components/breadcrumb/breadcrumb.d.ts +3 -2
  38. package/components/breadcrumb/breadcrumb.yaml +6 -0
  39. package/components/button/button.a2ui.json +3 -0
  40. package/components/button/button.d.ts +12 -2
  41. package/components/button/button.yaml +5 -0
  42. package/components/calendar-picker/calendar-picker.a2ui.json +1 -0
  43. package/components/canvas/canvas.a2ui.json +1 -0
  44. package/components/canvas/canvas.d.ts +18 -2
  45. package/components/canvas/canvas.yaml +10 -0
  46. package/components/card/card.a2ui.json +1 -0
  47. package/components/card/card.d.ts +12 -2
  48. package/components/chart/chart.a2ui.json +1 -0
  49. package/components/chart/chart.d.ts +16 -2
  50. package/components/chart-legend/chart-legend.a2ui.json +4 -0
  51. package/components/chart-legend/chart-legend.d.ts +12 -2
  52. package/components/chart-legend/chart-legend.yaml +5 -0
  53. package/components/chat-thread/chat-thread.a2ui.json +1 -0
  54. package/components/chat-thread/chat-thread.d.ts +12 -2
  55. package/components/check/check.a2ui.json +1 -0
  56. package/components/code/code.a2ui.json +1 -0
  57. package/components/col/col.a2ui.json +1 -0
  58. package/components/col/col.d.ts +3 -2
  59. package/components/color-picker/color-picker.a2ui.json +3 -0
  60. package/components/color-picker/color-picker.yaml +4 -0
  61. package/components/command/command.a2ui.json +1 -0
  62. package/components/command/command.d.ts +14 -2
  63. package/components/demo-toggle/demo-toggle.a2ui.json +1 -0
  64. package/components/demo-toggle/demo-toggle.d.ts +12 -2
  65. package/components/description-list/description-list.a2ui.json +1 -0
  66. package/components/description-list/description-list.d.ts +3 -2
  67. package/components/divider/divider.a2ui.json +1 -0
  68. package/components/divider/divider.d.ts +3 -2
  69. package/components/drawer/drawer.a2ui.json +1 -0
  70. package/components/drawer/drawer.d.ts +12 -2
  71. package/components/embed/embed.a2ui.json +1 -0
  72. package/components/embed/embed.d.ts +3 -2
  73. package/components/empty-state/empty-state.a2ui.json +3 -0
  74. package/components/empty-state/empty-state.d.ts +3 -2
  75. package/components/empty-state/empty-state.yaml +4 -0
  76. package/components/feed/feed.a2ui.json +9 -1
  77. package/components/feed/feed.d.ts +12 -2
  78. package/components/feed/feed.yaml +8 -1
  79. package/components/field/field.a2ui.json +1 -0
  80. package/components/field/field.d.ts +3 -2
  81. package/components/fields/fields.a2ui.json +1 -0
  82. package/components/fields/fields.d.ts +3 -2
  83. package/components/footer/footer.a2ui.json +1 -0
  84. package/components/grid/grid.a2ui.json +1 -0
  85. package/components/grid/grid.d.ts +3 -2
  86. package/components/header/header.a2ui.json +1 -0
  87. package/components/heatmap/heatmap.a2ui.json +1 -0
  88. package/components/heatmap/heatmap.d.ts +14 -2
  89. package/components/icon/icon.a2ui.json +1 -0
  90. package/components/icon/icon.d.ts +3 -2
  91. package/components/image/image.a2ui.json +3 -0
  92. package/components/image/image.d.ts +3 -2
  93. package/components/image/image.yaml +4 -0
  94. package/components/index.js +8 -0
  95. package/components/input/input.a2ui.json +4 -0
  96. package/components/input/input.yaml +6 -0
  97. package/components/inspector/inspector.a2ui.json +5 -0
  98. package/components/inspector/inspector.d.ts +3 -2
  99. package/components/inspector/inspector.yaml +6 -0
  100. package/components/kbd/kbd.a2ui.json +1 -0
  101. package/components/kbd/kbd.d.ts +3 -2
  102. package/components/link/link.a2ui.json +1 -0
  103. package/components/link/link.d.ts +12 -2
  104. package/components/list/list.a2ui.json +3 -0
  105. package/components/list/list.d.ts +12 -2
  106. package/components/list/list.yaml +4 -0
  107. package/components/menu/menu.a2ui.json +3 -0
  108. package/components/menu/menu.d.ts +12 -2
  109. package/components/menu/menu.yaml +4 -0
  110. package/components/modal/modal.a2ui.json +1 -0
  111. package/components/modal/modal.d.ts +12 -2
  112. package/components/nav/nav.a2ui.json +1 -0
  113. package/components/nav/nav.d.ts +12 -2
  114. package/components/nav-group/nav-group.a2ui.json +1 -0
  115. package/components/nav-group/nav-group.d.ts +12 -2
  116. package/components/nav-item/nav-item.a2ui.json +1 -0
  117. package/components/nav-item/nav-item.d.ts +12 -2
  118. package/components/noodles/noodles.a2ui.json +1 -0
  119. package/components/noodles/noodles.d.ts +16 -2
  120. package/components/option-card/option-card.a2ui.json +3 -0
  121. package/components/option-card/option-card.yaml +4 -0
  122. package/components/otp-input/otp-input.a2ui.json +1 -0
  123. package/components/page/page.a2ui.json +1 -0
  124. package/components/page/page.d.ts +3 -2
  125. package/components/pagination/pagination.a2ui.json +1 -0
  126. package/components/pagination/pagination.d.ts +12 -2
  127. package/components/pane/pane.a2ui.json +8 -1
  128. package/components/pane/pane.d.ts +12 -2
  129. package/components/pane/pane.yaml +7 -1
  130. package/components/pipeline-status/pipeline-status.a2ui.json +1 -0
  131. package/components/pipeline-status/pipeline-status.d.ts +3 -2
  132. package/components/popover/popover.a2ui.json +1 -0
  133. package/components/popover/popover.d.ts +3 -2
  134. package/components/progress/progress.a2ui.json +1 -0
  135. package/components/progress/progress.d.ts +3 -2
  136. package/components/progress-row/progress-row.a2ui.json +3 -0
  137. package/components/progress-row/progress-row.d.ts +3 -2
  138. package/components/progress-row/progress-row.yaml +4 -0
  139. package/components/radio/radio.a2ui.json +1 -0
  140. package/components/range/range.a2ui.json +1 -0
  141. package/components/rating/rating.a2ui.json +1 -0
  142. package/components/richtext/richtext.a2ui.json +1 -0
  143. package/components/richtext/richtext.d.ts +3 -2
  144. package/components/row/row.a2ui.json +1 -0
  145. package/components/row/row.d.ts +12 -2
  146. package/components/search/search.a2ui.json +1 -0
  147. package/components/section/section.a2ui.json +1 -0
  148. package/components/segment/segment.a2ui.json +3 -0
  149. package/components/segment/segment.d.ts +3 -2
  150. package/components/segment/segment.yaml +4 -0
  151. package/components/segmented/segmented.a2ui.json +1 -0
  152. package/components/select/select.a2ui.json +3 -0
  153. package/components/select/select.yaml +4 -0
  154. package/components/skeleton/skeleton.a2ui.json +1 -0
  155. package/components/skeleton/skeleton.d.ts +3 -2
  156. package/components/slider/slider.a2ui.json +1 -0
  157. package/components/stack/stack.a2ui.json +1 -0
  158. package/components/stack/stack.d.ts +3 -2
  159. package/components/stat/stat.a2ui.json +1 -0
  160. package/components/step-progress/step-progress.a2ui.json +1 -0
  161. package/components/step-progress/step-progress.d.ts +3 -2
  162. package/components/stepper/stepper.a2ui.json +3 -0
  163. package/components/stepper/stepper.d.ts +3 -2
  164. package/components/stepper/stepper.yaml +4 -0
  165. package/components/stream/stream.a2ui.json +1 -0
  166. package/components/stream/stream.d.ts +16 -2
  167. package/components/swatch/swatch.a2ui.json +1 -0
  168. package/components/swatch/swatch.d.ts +3 -2
  169. package/components/swiper/swiper.a2ui.json +3 -0
  170. package/components/swiper/swiper.d.ts +16 -2
  171. package/components/swiper/swiper.yaml +4 -0
  172. package/components/switch/switch.a2ui.json +1 -0
  173. package/components/table/table.a2ui.json +7 -0
  174. package/components/table/table.d.ts +20 -2
  175. package/components/table/table.yaml +8 -0
  176. package/components/table-toolbar/table-toolbar.a2ui.json +12 -0
  177. package/components/table-toolbar/table-toolbar.d.ts +18 -2
  178. package/components/table-toolbar/table-toolbar.yaml +13 -0
  179. package/components/tabs/tabs.a2ui.json +3 -0
  180. package/components/tabs/tabs.d.ts +12 -2
  181. package/components/tabs/tabs.yaml +4 -0
  182. package/components/tag/tag.a2ui.json +1 -0
  183. package/components/tag/tag.d.ts +12 -2
  184. package/components/text/text.a2ui.json +1 -0
  185. package/components/text/text.d.ts +3 -2
  186. package/components/textarea/textarea.a2ui.json +1 -0
  187. package/components/timeline/timeline.a2ui.json +18 -1
  188. package/components/timeline/timeline.d.ts +19 -2
  189. package/components/timeline/timeline.yaml +14 -1
  190. package/components/toast/toast.a2ui.json +1 -0
  191. package/components/toast/toast.d.ts +12 -2
  192. package/components/toggle-group/toggle-group.a2ui.json +1 -0
  193. package/components/toggle-group/toggle-group.d.ts +12 -2
  194. package/components/toggle-scheme/toggle-scheme.a2ui.json +3 -0
  195. package/components/toggle-scheme/toggle-scheme.d.ts +12 -2
  196. package/components/toggle-scheme/toggle-scheme.yaml +4 -0
  197. package/components/toolbar/toolbar.a2ui.json +3 -0
  198. package/components/toolbar/toolbar.d.ts +3 -2
  199. package/components/toolbar/toolbar.yaml +4 -0
  200. package/components/tooltip/tooltip.a2ui.json +1 -0
  201. package/components/tooltip/tooltip.d.ts +3 -2
  202. package/components/tree/tree.a2ui.json +3 -0
  203. package/components/tree/tree.d.ts +12 -2
  204. package/components/tree/tree.yaml +4 -0
  205. package/components/upload/upload.a2ui.json +1 -0
  206. package/core/icons-phosphor.js +93 -0
  207. package/core/icons.js +92 -90
  208. package/core/index.js +5 -0
  209. package/index.d.ts +78 -77
  210. package/index.js +7 -0
  211. package/package.json +3 -2
@@ -5,12 +5,17 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
13
14
 
15
+ export type NoodlesNoodleConnectEvent = CustomEvent<unknown>;
16
+ export type NoodlesNoodleDisconnectEvent = CustomEvent<unknown>;
17
+ export type NoodlesNoodleDragEvent = CustomEvent<unknown>;
18
+
14
19
  export class UINoodles extends UIElement {
15
20
  /** Flowing dash animation on noodles */
16
21
  animated: boolean;
@@ -30,4 +35,13 @@ export class UINoodles extends UIElement {
30
35
  strokeWidth: number;
31
36
  /** Bezier control point distance (0-1). Higher = wider curves */
32
37
  tension: number;
38
+
39
+ addEventListener<K extends keyof HTMLElementEventMap>(
40
+ type: K,
41
+ listener: (this: UINoodles, ev: HTMLElementEventMap[K]) => unknown,
42
+ options?: boolean | AddEventListenerOptions,
43
+ ): void;
44
+ addEventListener(type: 'noodle-connect', listener: (ev: NoodlesNoodleConnectEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
45
+ addEventListener(type: 'noodle-disconnect', listener: (ev: NoodlesNoodleDisconnectEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
46
+ addEventListener(type: 'noodle-drag', listener: (ev: NoodlesNoodleDragEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
33
47
  }
@@ -73,6 +73,9 @@
73
73
  "x-adiaui": {
74
74
  "anti_patterns": [],
75
75
  "category": "input",
76
+ "composes": [
77
+ "icon-ui"
78
+ ],
76
79
  "events": {
77
80
  "change": {
78
81
  "description": "Fired when this card becomes selected (bubbles)."
@@ -12,6 +12,10 @@ description: >-
12
12
  radiogroup. The whole card is the click target; a CSS-rendered radio
13
13
  circle in the top-left signals state. Form-associated, so `name=value`
14
14
  submits with the parent form when checked.
15
+ # Per ADR-0027 — primitives that programmatically create other primitives
16
+ # do NOT auto-import them. Consumer (or demo shell) must explicitly import.
17
+ composes:
18
+ - icon-ui
15
19
  props:
16
20
  name:
17
21
  description: Form control name. Siblings sharing a name form a radiogroup.
@@ -44,6 +44,7 @@
44
44
  "x-adiaui": {
45
45
  "anti_patterns": [],
46
46
  "category": "input",
47
+ "composes": [],
47
48
  "events": {
48
49
  "complete": {
49
50
  "description": "Fired when all digits are filled. Detail contains { code }."
@@ -51,6 +51,7 @@
51
51
  "x-adiaui": {
52
52
  "anti_patterns": [],
53
53
  "category": "container",
54
+ "composes": [],
54
55
  "events": {},
55
56
  "examples": [
56
57
  {
@@ -11,8 +11,9 @@ primitives (`<header-ui>`, `<section-ui>`, `<footer-ui>`); the page's
11
11
  *
12
12
  * Type declarations generated by scripts/build/dts-codegen.mjs from
13
13
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
14
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
15
- * or hand-author this file fully if rich event types are needed.
14
+ * run `npm run build:components`, then `npm run codegen:dts` to
15
+ * regenerate; or hand-author this file fully if rich event types are
16
+ * needed beyond what the yaml `events:` block can express.
16
17
  */
17
18
 
18
19
  import { UIElement } from '../../core/element.js';
@@ -44,6 +44,7 @@
44
44
  "x-adiaui": {
45
45
  "anti_patterns": [],
46
46
  "category": "navigation",
47
+ "composes": [],
47
48
  "events": {
48
49
  "page-change": {
49
50
  "description": "Fired when a page button is clicked. detail contains { page }."
@@ -5,12 +5,15 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
13
14
 
15
+ export type PaginationPageChangeEvent = CustomEvent<unknown>;
16
+
14
17
  export class UIPagination extends UIElement {
15
18
  /** Current active page number. */
16
19
  page: number;
@@ -20,4 +23,11 @@ export class UIPagination extends UIElement {
20
23
  total: number;
21
24
  /** Visual variant */
22
25
  variant: string;
26
+
27
+ addEventListener<K extends keyof HTMLElementEventMap>(
28
+ type: K,
29
+ listener: (this: UIPagination, ev: HTMLElementEventMap[K]) => unknown,
30
+ options?: boolean | AddEventListenerOptions,
31
+ ): void;
32
+ addEventListener(type: 'page-change', listener: (ev: PaginationPageChangeEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
23
33
  }
@@ -54,7 +54,14 @@
54
54
  "x-adiaui": {
55
55
  "anti_patterns": [],
56
56
  "category": "layout",
57
- "events": {},
57
+ "composes": [
58
+ "icon-ui"
59
+ ],
60
+ "events": {
61
+ "toggle": {
62
+ "description": "Fired when the pane's collapsed state flips (via button press, keyboard, or programmatic toggle()). Bubbles."
63
+ }
64
+ },
58
65
  "examples": [
59
66
  {
60
67
  "description": "Split pane with TextArea for editing markdown on the left and a preview card on the right.",
@@ -5,12 +5,15 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
13
14
 
15
+ export type PaneToggleEvent = CustomEvent<unknown>;
16
+
14
17
  export class UIPane extends UIElement {
15
18
  /** Component property: collapsed. */
16
19
  collapsed: boolean;
@@ -28,4 +31,11 @@ Unset keeps the pane-intrinsic chrome (full border, right-edge
28
31
  grabber when resizable).
29
32
  */
30
33
  side: '' | 'leading' | 'trailing';
34
+
35
+ addEventListener<K extends keyof HTMLElementEventMap>(
36
+ type: K,
37
+ listener: (this: UIPane, ev: HTMLElementEventMap[K]) => unknown,
38
+ options?: boolean | AddEventListenerOptions,
39
+ ): void;
40
+ addEventListener(type: 'toggle', listener: (ev: PaneToggleEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
31
41
  }
@@ -5,6 +5,10 @@ component: Pane
5
5
  category: layout
6
6
  version: 1
7
7
  description: Collapsible, resizable panel.
8
+ # Per ADR-0027 — primitives that programmatically create other primitives
9
+ # do NOT auto-import them. Consumer (or demo shell) must explicitly import.
10
+ composes:
11
+ - icon-ui
8
12
  props:
9
13
  collapsed:
10
14
  description: 'Component property: collapsed.'
@@ -45,7 +49,9 @@ props:
45
49
  - leading
46
50
  - trailing
47
51
  reflect: true
48
- events: {}
52
+ events:
53
+ toggle:
54
+ description: Fired when the pane's collapsed state flips (via button press, keyboard, or programmatic toggle()). Bubbles.
49
55
  slots:
50
56
  header:
51
57
  description: Auto-created header element with label text and toggle arrow
@@ -39,6 +39,7 @@
39
39
  "x-adiaui": {
40
40
  "anti_patterns": [],
41
41
  "category": "agent",
42
+ "composes": [],
42
43
  "events": {},
43
44
  "examples": [
44
45
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -59,6 +59,7 @@
59
59
  "x-adiaui": {
60
60
  "anti_patterns": [],
61
61
  "category": "container",
62
+ "composes": [],
62
63
  "events": {},
63
64
  "examples": [
64
65
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -43,6 +43,7 @@
43
43
  "x-adiaui": {
44
44
  "anti_patterns": [],
45
45
  "category": "display",
46
+ "composes": [],
46
47
  "events": {},
47
48
  "examples": [
48
49
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -52,6 +52,9 @@
52
52
  "x-adiaui": {
53
53
  "anti_patterns": [],
54
54
  "category": "data",
55
+ "composes": [
56
+ "progress-ui"
57
+ ],
55
58
  "events": {},
56
59
  "examples": [
57
60
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -8,6 +8,10 @@ category: data
8
8
  version: 1
9
9
  description: Inline labeled progress row with label, progress bar, and meta text. Used for storage
10
10
  quotas, capacity breakdowns, usage indicators.
11
+ # Per ADR-0027 — primitives that programmatically create other primitives
12
+ # do NOT auto-import them. Consumer (or demo shell) must explicitly import.
13
+ composes:
14
+ - progress-ui
11
15
  props:
12
16
  label:
13
17
  description: Left-hand label text
@@ -76,6 +76,7 @@
76
76
  }
77
77
  ],
78
78
  "category": "input",
79
+ "composes": [],
79
80
  "events": {
80
81
  "change": {
81
82
  "description": "Fired when this radio becomes selected (bubbles)"
@@ -74,6 +74,7 @@
74
74
  "x-adiaui": {
75
75
  "anti_patterns": [],
76
76
  "category": "input",
77
+ "composes": [],
77
78
  "events": {
78
79
  "change": {
79
80
  "description": "Fired on drag end or keyboard commit"
@@ -74,6 +74,7 @@
74
74
  "x-adiaui": {
75
75
  "anti_patterns": [],
76
76
  "category": "form",
77
+ "composes": [],
77
78
  "events": {
78
79
  "[object Object]": {
79
80
  "description": "Fired on [object Object]."
@@ -34,6 +34,7 @@
34
34
  "x-adiaui": {
35
35
  "anti_patterns": [],
36
36
  "category": "forms",
37
+ "composes": [],
37
38
  "events": {},
38
39
  "examples": [
39
40
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -54,6 +54,7 @@
54
54
  "x-adiaui": {
55
55
  "anti_patterns": [],
56
56
  "category": "layout",
57
+ "composes": [],
57
58
  "events": {
58
59
  "drag-end": {
59
60
  "description": "Fired when a drag completes."
@@ -5,12 +5,15 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
13
14
 
15
+ export type RowDragEndEvent = CustomEvent<unknown>;
16
+
14
17
  export class UIRow extends UIElement {
15
18
  /** Align items */
16
19
  align: string;
@@ -24,4 +27,11 @@ export class UIRow extends UIElement {
24
27
  justify: string;
25
28
  /** Enable flex wrap */
26
29
  wrap: boolean;
30
+
31
+ addEventListener<K extends keyof HTMLElementEventMap>(
32
+ type: K,
33
+ listener: (this: UIRow, ev: HTMLElementEventMap[K]) => unknown,
34
+ options?: boolean | AddEventListenerOptions,
35
+ ): void;
36
+ addEventListener(type: 'drag-end', listener: (ev: RowDragEndEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
27
37
  }
@@ -54,6 +54,7 @@
54
54
  "x-adiaui": {
55
55
  "anti_patterns": [],
56
56
  "category": "input",
57
+ "composes": [],
57
58
  "events": {
58
59
  "clear": {
59
60
  "description": "Fired when the clear button is clicked"
@@ -34,6 +34,7 @@
34
34
  "x-adiaui": {
35
35
  "anti_patterns": [],
36
36
  "category": "container",
37
+ "composes": [],
37
38
  "events": {},
38
39
  "examples": [
39
40
  {
@@ -49,6 +49,9 @@
49
49
  "x-adiaui": {
50
50
  "anti_patterns": [],
51
51
  "category": "navigation",
52
+ "composes": [
53
+ "icon-ui"
54
+ ],
52
55
  "events": {},
53
56
  "examples": [
54
57
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -7,6 +7,10 @@ component: Segment
7
7
  category: navigation
8
8
  version: 1
9
9
  description: Individual segment option, child of segmented-ui.
10
+ # Per ADR-0027 — primitives that programmatically create other primitives
11
+ # do NOT auto-import them. Consumer (or demo shell) must explicitly import.
12
+ composes:
13
+ - icon-ui
10
14
  props:
11
15
  disabled:
12
16
  description: Disables this segment.
@@ -29,6 +29,7 @@
29
29
  "x-adiaui": {
30
30
  "anti_patterns": [],
31
31
  "category": "navigation",
32
+ "composes": [],
32
33
  "events": {
33
34
  "change": {
34
35
  "description": "Fired when the selected segment changes. detail contains { value }."
@@ -140,6 +140,9 @@
140
140
  "x-adiaui": {
141
141
  "anti_patterns": [],
142
142
  "category": "input",
143
+ "composes": [
144
+ "icon-ui"
145
+ ],
143
146
  "events": {
144
147
  "change": {
145
148
  "description": "Fired when selected value changes"
@@ -7,6 +7,10 @@ component: Select
7
7
  category: input
8
8
  version: 1
9
9
  description: Alias for ChoicePicker. Dropdown select with options.
10
+ # Per ADR-0027 — primitives that programmatically create other primitives
11
+ # do NOT auto-import them. Consumer (or demo shell) must explicitly import.
12
+ composes:
13
+ - icon-ui # chevron + option-row affixes (created in render)
10
14
  props:
11
15
  name:
12
16
  description: Form control name for form data submission
@@ -51,6 +51,7 @@
51
51
  "x-adiaui": {
52
52
  "anti_patterns": [],
53
53
  "category": "display",
54
+ "composes": [],
54
55
  "events": {},
55
56
  "examples": [
56
57
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -74,6 +74,7 @@
74
74
  "x-adiaui": {
75
75
  "anti_patterns": [],
76
76
  "category": "input",
77
+ "composes": [],
77
78
  "events": {
78
79
  "change": {
79
80
  "description": "Fired when the value changes (on blur for inputs, on selection for pickers)."
@@ -29,6 +29,7 @@
29
29
  "x-adiaui": {
30
30
  "anti_patterns": [],
31
31
  "category": "layout",
32
+ "composes": [],
32
33
  "events": {},
33
34
  "examples": [
34
35
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -49,6 +49,7 @@
49
49
  "x-adiaui": {
50
50
  "anti_patterns": [],
51
51
  "category": "display",
52
+ "composes": [],
52
53
  "events": {},
53
54
  "examples": [
54
55
  {
@@ -39,6 +39,7 @@
39
39
  "x-adiaui": {
40
40
  "anti_patterns": [],
41
41
  "category": "feedback",
42
+ "composes": [],
42
43
  "events": {},
43
44
  "examples": [
44
45
  {
@@ -11,8 +11,9 @@ primitive.
11
11
  *
12
12
  * Type declarations generated by scripts/build/dts-codegen.mjs from
13
13
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
14
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
15
- * or hand-author this file fully if rich event types are needed.
14
+ * run `npm run build:components`, then `npm run codegen:dts` to
15
+ * regenerate; or hand-author this file fully if rich event types are
16
+ * needed beyond what the yaml `events:` block can express.
16
17
  */
17
18
 
18
19
  import { UIElement } from '../../core/element.js';
@@ -34,6 +34,9 @@
34
34
  "x-adiaui": {
35
35
  "anti_patterns": [],
36
36
  "category": "navigation",
37
+ "composes": [
38
+ "icon-ui"
39
+ ],
37
40
  "events": {},
38
41
  "examples": [
39
42
  {
@@ -5,8 +5,9 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
@@ -7,6 +7,10 @@ component: Stepper
7
7
  category: navigation
8
8
  version: 1
9
9
  description: Wizard / process stepper — parent step index drives numbered children.
10
+ # Per ADR-0027 — primitives that programmatically create other primitives
11
+ # do NOT auto-import them. Consumer (or demo shell) must explicitly import.
12
+ composes:
13
+ - icon-ui
10
14
  props:
11
15
  orientation:
12
16
  description: horizontal | vertical
@@ -39,6 +39,7 @@
39
39
  "x-adiaui": {
40
40
  "anti_patterns": [],
41
41
  "category": "agent",
42
+ "composes": [],
42
43
  "events": {
43
44
  "stream-end": {
44
45
  "description": "Fired when stream completes naturally"
@@ -5,15 +5,29 @@
5
5
  *
6
6
  * Type declarations generated by scripts/build/dts-codegen.mjs from
7
7
  * the component's `.a2ui.json` sidecar. Edit the source `.yaml`,
8
- * run `npm run components`, then `npm run codegen:dts` to regenerate;
9
- * or hand-author this file fully if rich event types are needed.
8
+ * run `npm run build:components`, then `npm run codegen:dts` to
9
+ * regenerate; or hand-author this file fully if rich event types are
10
+ * needed beyond what the yaml `events:` block can express.
10
11
  */
11
12
 
12
13
  import { UIElement } from '../../core/element.js';
13
14
 
15
+ export type StreamEndEvent = CustomEvent<unknown>;
16
+ export type StreamErrorEvent = CustomEvent<unknown>;
17
+ export type StreamStartEvent = CustomEvent<unknown>;
18
+
14
19
  export class UIStream extends UIElement {
15
20
  /** Milliseconds between character renders. 0 = real-time. */
16
21
  pace: number;
17
22
  /** Read-only reflected state, true while stream is active */
18
23
  streaming: boolean;
24
+
25
+ addEventListener<K extends keyof HTMLElementEventMap>(
26
+ type: K,
27
+ listener: (this: UIStream, ev: HTMLElementEventMap[K]) => unknown,
28
+ options?: boolean | AddEventListenerOptions,
29
+ ): void;
30
+ addEventListener(type: 'stream-end', listener: (ev: StreamEndEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
31
+ addEventListener(type: 'stream-error', listener: (ev: StreamErrorEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
32
+ addEventListener(type: 'stream-start', listener: (ev: StreamStartEvent) => unknown, options?: boolean | AddEventListenerOptions): void;
19
33
  }