entangle-ui 0.6.2 → 0.7.0

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 (152) hide show
  1. package/CHANGELOG.md +45 -0
  2. package/README.md +5 -3
  3. package/dist/esm/_virtual/_commonjsHelpers.js +6 -0
  4. package/dist/esm/_virtual/_commonjsHelpers.js.map +1 -0
  5. package/dist/esm/_virtual/cssesc.js +5 -1
  6. package/dist/esm/_virtual/cssesc.js.map +1 -1
  7. package/dist/esm/_virtual/picocolors.js +8 -0
  8. package/dist/esm/_virtual/picocolors.js.map +1 -0
  9. package/dist/esm/_virtual/picocolors2.js +4 -0
  10. package/dist/esm/_virtual/picocolors2.js.map +1 -0
  11. package/dist/esm/assets/src/components/editor/ChatPanel/{ChatPanel.css.ts.vanilla-DPIGnZ4A.css → ChatPanel.css.ts.vanilla-BI5569ZO.css} +81 -1
  12. package/dist/esm/assets/src/components/feedback/EmptyState/EmptyState.css.ts.vanilla-B_TWsTOW.css +58 -0
  13. package/dist/esm/assets/src/components/feedback/Spinner/Spinner.css.ts.vanilla-DEUewqdK.css +80 -0
  14. package/dist/esm/assets/src/components/layout/Divider/Divider.css.ts.vanilla-CPvd_RW9.css +72 -0
  15. package/dist/esm/assets/src/components/layout/ListItem/ListItem.css.ts.vanilla-BwAZrX2f.css +68 -0
  16. package/dist/esm/assets/src/components/layout/PageHeader/PageHeader.css.ts.vanilla-DdbyyWAN.css +70 -0
  17. package/dist/esm/assets/src/components/layout/SplitPane/{SplitPane.css.ts.vanilla-BFxdvwyI.css → SplitPane.css.ts.vanilla-BGFZ7zDa.css} +5 -0
  18. package/dist/esm/assets/src/components/primitives/Badge/Badge.css.ts.vanilla-DxCUcxYW.css +95 -0
  19. package/dist/esm/assets/src/components/primitives/Code/Code.css.ts.vanilla-mayBqLDM.css +19 -0
  20. package/dist/esm/assets/src/components/primitives/TextArea/TextArea.css.ts.vanilla-DTOMjGkp.css +85 -0
  21. package/dist/esm/assets/src/theme/{darkTheme.css.ts.vanilla-DCe89yCJ.css → darkTheme.css.ts.vanilla-ab1WD4dr.css} +3 -0
  22. package/dist/esm/assets/src/theme/globalScrollbars.css.ts.vanilla-BAJwnUEJ.css +21 -0
  23. package/dist/esm/assets/src/utils/animations.css.ts.vanilla-DOVlpljP.css +58 -0
  24. package/dist/esm/components/editor/ChatPanel/ChatInput.js +18 -7
  25. package/dist/esm/components/editor/ChatPanel/ChatInput.js.map +1 -1
  26. package/dist/esm/components/editor/ChatPanel/ChatMarkdownRenderer.js +268 -0
  27. package/dist/esm/components/editor/ChatPanel/ChatMarkdownRenderer.js.map +1 -0
  28. package/dist/esm/components/editor/ChatPanel/ChatMessage.js +15 -3
  29. package/dist/esm/components/editor/ChatPanel/ChatMessage.js.map +1 -1
  30. package/dist/esm/components/editor/ChatPanel/ChatMessageList.js +19 -5
  31. package/dist/esm/components/editor/ChatPanel/ChatMessageList.js.map +1 -1
  32. package/dist/esm/components/editor/ChatPanel/ChatPanel.css.js +14 -2
  33. package/dist/esm/components/editor/ChatPanel/ChatPanel.css.js.map +1 -1
  34. package/dist/esm/components/editor/ChatPanel/ChatPanel.js +15 -3
  35. package/dist/esm/components/editor/ChatPanel/ChatPanel.js.map +1 -1
  36. package/dist/esm/components/editor/ChatPanel/useChatInput.js +3 -3
  37. package/dist/esm/components/editor/ChatPanel/useChatInput.js.map +1 -1
  38. package/dist/esm/components/editor/ChatPanel/useChatScroll.js +59 -2
  39. package/dist/esm/components/editor/ChatPanel/useChatScroll.js.map +1 -1
  40. package/dist/esm/components/feedback/EmptyState/EmptyState.css.js +13 -0
  41. package/dist/esm/components/feedback/EmptyState/EmptyState.css.js.map +1 -0
  42. package/dist/esm/components/feedback/EmptyState/EmptyState.js +43 -0
  43. package/dist/esm/components/feedback/EmptyState/EmptyState.js.map +1 -0
  44. package/dist/esm/components/feedback/Spinner/Spinner.css.js +16 -0
  45. package/dist/esm/components/feedback/Spinner/Spinner.css.js.map +1 -0
  46. package/dist/esm/components/feedback/Spinner/Spinner.js +50 -0
  47. package/dist/esm/components/feedback/Spinner/Spinner.js.map +1 -0
  48. package/dist/esm/components/layout/Divider/Divider.css.js +9 -0
  49. package/dist/esm/components/layout/Divider/Divider.css.js.map +1 -0
  50. package/dist/esm/components/layout/Divider/Divider.js +51 -0
  51. package/dist/esm/components/layout/Divider/Divider.js.map +1 -0
  52. package/dist/esm/components/layout/ListItem/ListItem.css.js +10 -0
  53. package/dist/esm/components/layout/ListItem/ListItem.css.js.map +1 -0
  54. package/dist/esm/components/layout/ListItem/ListItem.js +45 -0
  55. package/dist/esm/components/layout/ListItem/ListItem.js.map +1 -0
  56. package/dist/esm/components/layout/PageHeader/PageHeader.css.js +13 -0
  57. package/dist/esm/components/layout/PageHeader/PageHeader.css.js.map +1 -0
  58. package/dist/esm/components/layout/PageHeader/PageHeader.js +29 -0
  59. package/dist/esm/components/layout/PageHeader/PageHeader.js.map +1 -0
  60. package/dist/esm/components/layout/SplitPane/SplitPane.css.js +1 -1
  61. package/dist/esm/components/navigation/Tabs/TabPanel.js +6 -3
  62. package/dist/esm/components/navigation/Tabs/TabPanel.js.map +1 -1
  63. package/dist/esm/components/navigation/Tabs/Tabs.js +3 -1
  64. package/dist/esm/components/navigation/Tabs/Tabs.js.map +1 -1
  65. package/dist/esm/components/primitives/Badge/Badge.css.js +12 -0
  66. package/dist/esm/components/primitives/Badge/Badge.css.js.map +1 -0
  67. package/dist/esm/components/primitives/Badge/Badge.js +67 -0
  68. package/dist/esm/components/primitives/Badge/Badge.js.map +1 -0
  69. package/dist/esm/components/primitives/Code/Code.css.js +7 -0
  70. package/dist/esm/components/primitives/Code/Code.css.js.map +1 -0
  71. package/dist/esm/components/primitives/Code/Code.js +24 -0
  72. package/dist/esm/components/primitives/Code/Code.js.map +1 -0
  73. package/dist/esm/components/primitives/TextArea/TextArea.css.js +10 -0
  74. package/dist/esm/components/primitives/TextArea/TextArea.css.js.map +1 -0
  75. package/dist/esm/components/primitives/TextArea/TextArea.js +97 -0
  76. package/dist/esm/components/primitives/TextArea/TextArea.js.map +1 -0
  77. package/dist/esm/index.js +12 -1
  78. package/dist/esm/index.js.map +1 -1
  79. package/dist/esm/node_modules/@emotion/hash/dist/emotion-hash.esm.js +56 -0
  80. package/dist/esm/node_modules/@emotion/hash/dist/emotion-hash.esm.js.map +1 -0
  81. package/dist/esm/node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js +32 -1
  82. package/dist/esm/node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js.map +1 -1
  83. package/dist/esm/node_modules/@vanilla-extract/css/dist/taggedTemplateLiteral-10998315.esm.js +13 -0
  84. package/dist/esm/node_modules/@vanilla-extract/css/dist/taggedTemplateLiteral-10998315.esm.js.map +1 -0
  85. package/dist/esm/node_modules/@vanilla-extract/css/dist/transformCss-fd0786e1.esm.js +837 -3
  86. package/dist/esm/node_modules/@vanilla-extract/css/dist/transformCss-fd0786e1.esm.js.map +1 -1
  87. package/dist/esm/node_modules/@vanilla-extract/css/dist/vanilla-extract-css.esm.js +244 -5
  88. package/dist/esm/node_modules/@vanilla-extract/css/dist/vanilla-extract-css.esm.js.map +1 -1
  89. package/dist/esm/node_modules/@vanilla-extract/css/fileScope/dist/vanilla-extract-css-fileScope.esm.js +18 -0
  90. package/dist/esm/node_modules/@vanilla-extract/css/fileScope/dist/vanilla-extract-css-fileScope.esm.js.map +1 -0
  91. package/dist/esm/node_modules/@vanilla-extract/css/injectStyles/dist/vanilla-extract-css-injectStyles.esm.js +23 -0
  92. package/dist/esm/node_modules/@vanilla-extract/css/injectStyles/dist/vanilla-extract-css-injectStyles.esm.js.map +1 -0
  93. package/dist/esm/node_modules/@vanilla-extract/private/dist/vanilla-extract-private.esm.js +38 -0
  94. package/dist/esm/node_modules/@vanilla-extract/private/dist/vanilla-extract-private.esm.js.map +1 -0
  95. package/dist/esm/node_modules/css-what/lib/es/parse.js +424 -0
  96. package/dist/esm/node_modules/css-what/lib/es/parse.js.map +1 -0
  97. package/dist/esm/node_modules/css-what/lib/es/types.js +29 -0
  98. package/dist/esm/node_modules/css-what/lib/es/types.js.map +1 -0
  99. package/dist/esm/node_modules/dedent/dist/dedent.js +3 -1
  100. package/dist/esm/node_modules/dedent/dist/dedent.js.map +1 -1
  101. package/dist/esm/node_modules/deep-object-diff/mjs/diff.js +40 -0
  102. package/dist/esm/node_modules/deep-object-diff/mjs/diff.js.map +1 -0
  103. package/dist/esm/node_modules/deep-object-diff/mjs/utils.js +9 -0
  104. package/dist/esm/node_modules/deep-object-diff/mjs/utils.js.map +1 -0
  105. package/dist/esm/node_modules/media-query-parser/dist/media-query-parser.esm.js +1386 -0
  106. package/dist/esm/node_modules/media-query-parser/dist/media-query-parser.esm.js.map +1 -0
  107. package/dist/esm/node_modules/modern-ahocorasick/dist/index.js +102 -0
  108. package/dist/esm/node_modules/modern-ahocorasick/dist/index.js.map +1 -0
  109. package/dist/esm/node_modules/picocolors/picocolors.js +87 -0
  110. package/dist/esm/node_modules/picocolors/picocolors.js.map +1 -0
  111. package/dist/esm/theme/ThemeProvider.js +17 -3
  112. package/dist/esm/theme/ThemeProvider.js.map +1 -1
  113. package/dist/esm/theme/contract.css.js +1 -1
  114. package/dist/esm/theme/createCustomTheme.js +33 -0
  115. package/dist/esm/theme/createCustomTheme.js.map +1 -0
  116. package/dist/esm/theme/darkTheme.css.js +2 -2
  117. package/dist/esm/theme/globalScrollbars.css.js +6 -0
  118. package/dist/esm/theme/globalScrollbars.css.js.map +1 -0
  119. package/dist/esm/utils/animations.css.js +13 -0
  120. package/dist/esm/utils/animations.css.js.map +1 -0
  121. package/dist/esm/utils/objects.js +22 -0
  122. package/dist/esm/utils/objects.js.map +1 -0
  123. package/dist/types/components/editor/ChatPanel/ChatMarkdownRenderer.d.ts +323 -0
  124. package/dist/types/components/editor/ChatPanel/ChatMarkdownRenderer.types.d.ts +46 -0
  125. package/dist/types/components/editor/ChatPanel/ChatMessage.d.ts +1 -0
  126. package/dist/types/components/editor/ChatPanel/ChatMessageList.d.ts +2 -1
  127. package/dist/types/components/editor/ChatPanel/ChatPanel.d.ts +1 -0
  128. package/dist/types/components/editor/ChatPanel/ChatPanel.types.d.ts +82 -1
  129. package/dist/types/components/feedback/EmptyState/EmptyState.d.ts +313 -0
  130. package/dist/types/components/feedback/EmptyState/EmptyState.types.d.ts +31 -0
  131. package/dist/types/components/feedback/Spinner/Spinner.d.ts +306 -0
  132. package/dist/types/components/feedback/Spinner/Spinner.types.d.ts +41 -0
  133. package/dist/types/components/layout/Divider/Divider.d.ts +307 -0
  134. package/dist/types/components/layout/Divider/Divider.types.d.ts +50 -0
  135. package/dist/types/components/layout/ListItem/ListItem.d.ts +312 -0
  136. package/dist/types/components/layout/ListItem/ListItem.types.d.ts +35 -0
  137. package/dist/types/components/layout/PageHeader/PageHeader.d.ts +311 -0
  138. package/dist/types/components/layout/PageHeader/PageHeader.types.d.ts +30 -0
  139. package/dist/types/components/navigation/Tabs/Tabs.types.d.ts +10 -0
  140. package/dist/types/components/primitives/Badge/Badge.d.ts +310 -0
  141. package/dist/types/components/primitives/Badge/Badge.types.d.ts +67 -0
  142. package/dist/types/components/primitives/Code/Code.d.ts +301 -0
  143. package/dist/types/components/primitives/Code/Code.types.d.ts +17 -0
  144. package/dist/types/components/primitives/TextArea/TextArea.d.ts +26 -0
  145. package/dist/types/components/primitives/TextArea/TextArea.types.d.ts +76 -0
  146. package/dist/types/index.d.ts +22 -2
  147. package/dist/types/theme/ThemeProvider.d.ts +14 -2
  148. package/dist/types/theme/contract.css.d.ts +3 -0
  149. package/dist/types/theme/createCustomTheme.d.ts +29 -0
  150. package/dist/types/theme/darkTheme.css.d.ts +3 -0
  151. package/dist/types/utils/animations.css.d.ts +18 -0
  152. package/package.json +1 -1
@@ -0,0 +1,301 @@
1
+ import { CodeSize } from './Code.types.js';
2
+ import React from 'react';
3
+
4
+ /**
5
+ * Small inline `<code>` primitive with theme-aware background and font.
6
+ *
7
+ * Complements `ChatCodeBlock` (block-level) — use `Code` for short inline
8
+ * snippets inside sentences and markdown renderers.
9
+ *
10
+ * @example
11
+ * ```tsx
12
+ * <Text>Run <Code>npm install</Code> to add the package.</Text>
13
+ * ```
14
+ */
15
+ declare const Code: React.NamedExoticComponent<{
16
+ children: React.ReactNode;
17
+ size?: CodeSize | undefined;
18
+ id?: string | undefined | undefined;
19
+ className?: string | undefined | undefined;
20
+ testId?: string | undefined;
21
+ style?: React.CSSProperties | undefined;
22
+ ref?: React.Ref<HTMLElement> | undefined;
23
+ defaultChecked?: boolean | undefined | undefined;
24
+ defaultValue?: string | number | readonly string[] | undefined;
25
+ suppressContentEditableWarning?: boolean | undefined | undefined;
26
+ suppressHydrationWarning?: boolean | undefined | undefined;
27
+ accessKey?: string | undefined | undefined;
28
+ autoCapitalize?: "off" | "none" | "on" | "sentences" | "words" | "characters" | undefined | (string & {}) | undefined;
29
+ autoFocus?: boolean | undefined | undefined;
30
+ contentEditable?: (boolean | "true" | "false") | "inherit" | "plaintext-only" | undefined;
31
+ contextMenu?: string | undefined | undefined;
32
+ dir?: string | undefined | undefined;
33
+ draggable?: (boolean | "true" | "false") | undefined;
34
+ enterKeyHint?: "enter" | "done" | "go" | "next" | "previous" | "search" | "send" | undefined | undefined;
35
+ hidden?: boolean | undefined | undefined;
36
+ lang?: string | undefined | undefined;
37
+ nonce?: string | undefined | undefined;
38
+ slot?: string | undefined | undefined;
39
+ spellCheck?: (boolean | "true" | "false") | undefined;
40
+ tabIndex?: number | undefined | undefined;
41
+ title?: string | undefined | undefined;
42
+ translate?: "yes" | "no" | undefined | undefined;
43
+ radioGroup?: string | undefined | undefined;
44
+ role?: React.AriaRole | undefined;
45
+ about?: string | undefined | undefined;
46
+ content?: string | undefined | undefined;
47
+ datatype?: string | undefined | undefined;
48
+ inlist?: any;
49
+ prefix?: string | undefined | undefined;
50
+ property?: string | undefined | undefined;
51
+ rel?: string | undefined | undefined;
52
+ resource?: string | undefined | undefined;
53
+ rev?: string | undefined | undefined;
54
+ typeof?: string | undefined | undefined;
55
+ vocab?: string | undefined | undefined;
56
+ autoCorrect?: string | undefined | undefined;
57
+ autoSave?: string | undefined | undefined;
58
+ color?: string | undefined | undefined;
59
+ itemProp?: string | undefined | undefined;
60
+ itemScope?: boolean | undefined | undefined;
61
+ itemType?: string | undefined | undefined;
62
+ itemID?: string | undefined | undefined;
63
+ itemRef?: string | undefined | undefined;
64
+ results?: number | undefined | undefined;
65
+ security?: string | undefined | undefined;
66
+ unselectable?: "on" | "off" | undefined | undefined;
67
+ popover?: "" | "auto" | "manual" | "hint" | undefined | undefined;
68
+ popoverTargetAction?: "toggle" | "show" | "hide" | undefined | undefined;
69
+ popoverTarget?: string | undefined | undefined;
70
+ inert?: boolean | undefined | undefined;
71
+ inputMode?: "none" | "text" | "tel" | "url" | "email" | "numeric" | "decimal" | "search" | undefined | undefined;
72
+ is?: string | undefined | undefined;
73
+ exportparts?: string | undefined | undefined;
74
+ part?: string | undefined | undefined;
75
+ "aria-activedescendant"?: string | undefined | undefined;
76
+ "aria-atomic"?: (boolean | "true" | "false") | undefined;
77
+ "aria-autocomplete"?: "none" | "inline" | "list" | "both" | undefined | undefined;
78
+ "aria-braillelabel"?: string | undefined | undefined;
79
+ "aria-brailleroledescription"?: string | undefined | undefined;
80
+ "aria-busy"?: (boolean | "true" | "false") | undefined;
81
+ "aria-checked"?: boolean | "false" | "mixed" | "true" | undefined | undefined;
82
+ "aria-colcount"?: number | undefined | undefined;
83
+ "aria-colindex"?: number | undefined | undefined;
84
+ "aria-colindextext"?: string | undefined | undefined;
85
+ "aria-colspan"?: number | undefined | undefined;
86
+ "aria-controls"?: string | undefined | undefined;
87
+ "aria-current"?: boolean | "false" | "true" | "page" | "step" | "location" | "date" | "time" | undefined | undefined;
88
+ "aria-describedby"?: string | undefined | undefined;
89
+ "aria-description"?: string | undefined | undefined;
90
+ "aria-details"?: string | undefined | undefined;
91
+ "aria-disabled"?: (boolean | "true" | "false") | undefined;
92
+ "aria-dropeffect"?: "none" | "copy" | "execute" | "link" | "move" | "popup" | undefined | undefined;
93
+ "aria-errormessage"?: string | undefined | undefined;
94
+ "aria-expanded"?: (boolean | "true" | "false") | undefined;
95
+ "aria-flowto"?: string | undefined | undefined;
96
+ "aria-grabbed"?: (boolean | "true" | "false") | undefined;
97
+ "aria-haspopup"?: boolean | "false" | "true" | "menu" | "listbox" | "tree" | "grid" | "dialog" | undefined | undefined;
98
+ "aria-hidden"?: (boolean | "true" | "false") | undefined;
99
+ "aria-invalid"?: boolean | "false" | "true" | "grammar" | "spelling" | undefined | undefined;
100
+ "aria-keyshortcuts"?: string | undefined | undefined;
101
+ "aria-label"?: string | undefined | undefined;
102
+ "aria-labelledby"?: string | undefined | undefined;
103
+ "aria-level"?: number | undefined | undefined;
104
+ "aria-live"?: "off" | "assertive" | "polite" | undefined | undefined;
105
+ "aria-modal"?: (boolean | "true" | "false") | undefined;
106
+ "aria-multiline"?: (boolean | "true" | "false") | undefined;
107
+ "aria-multiselectable"?: (boolean | "true" | "false") | undefined;
108
+ "aria-orientation"?: "horizontal" | "vertical" | undefined | undefined;
109
+ "aria-owns"?: string | undefined | undefined;
110
+ "aria-placeholder"?: string | undefined | undefined;
111
+ "aria-posinset"?: number | undefined | undefined;
112
+ "aria-pressed"?: boolean | "false" | "mixed" | "true" | undefined | undefined;
113
+ "aria-readonly"?: (boolean | "true" | "false") | undefined;
114
+ "aria-relevant"?: "additions" | "additions removals" | "additions text" | "all" | "removals" | "removals additions" | "removals text" | "text" | "text additions" | "text removals" | undefined | undefined;
115
+ "aria-required"?: (boolean | "true" | "false") | undefined;
116
+ "aria-roledescription"?: string | undefined | undefined;
117
+ "aria-rowcount"?: number | undefined | undefined;
118
+ "aria-rowindex"?: number | undefined | undefined;
119
+ "aria-rowindextext"?: string | undefined | undefined;
120
+ "aria-rowspan"?: number | undefined | undefined;
121
+ "aria-selected"?: (boolean | "true" | "false") | undefined;
122
+ "aria-setsize"?: number | undefined | undefined;
123
+ "aria-sort"?: "none" | "ascending" | "descending" | "other" | undefined | undefined;
124
+ "aria-valuemax"?: number | undefined | undefined;
125
+ "aria-valuemin"?: number | undefined | undefined;
126
+ "aria-valuenow"?: number | undefined | undefined;
127
+ "aria-valuetext"?: string | undefined | undefined;
128
+ dangerouslySetInnerHTML?: {
129
+ __html: string | TrustedHTML;
130
+ } | undefined | undefined;
131
+ onCopy?: React.ClipboardEventHandler<HTMLElement> | undefined;
132
+ onCopyCapture?: React.ClipboardEventHandler<HTMLElement> | undefined;
133
+ onCut?: React.ClipboardEventHandler<HTMLElement> | undefined;
134
+ onCutCapture?: React.ClipboardEventHandler<HTMLElement> | undefined;
135
+ onPaste?: React.ClipboardEventHandler<HTMLElement> | undefined;
136
+ onPasteCapture?: React.ClipboardEventHandler<HTMLElement> | undefined;
137
+ onCompositionEnd?: React.CompositionEventHandler<HTMLElement> | undefined;
138
+ onCompositionEndCapture?: React.CompositionEventHandler<HTMLElement> | undefined;
139
+ onCompositionStart?: React.CompositionEventHandler<HTMLElement> | undefined;
140
+ onCompositionStartCapture?: React.CompositionEventHandler<HTMLElement> | undefined;
141
+ onCompositionUpdate?: React.CompositionEventHandler<HTMLElement> | undefined;
142
+ onCompositionUpdateCapture?: React.CompositionEventHandler<HTMLElement> | undefined;
143
+ onFocus?: React.FocusEventHandler<HTMLElement> | undefined;
144
+ onFocusCapture?: React.FocusEventHandler<HTMLElement> | undefined;
145
+ onBlur?: React.FocusEventHandler<HTMLElement> | undefined;
146
+ onBlurCapture?: React.FocusEventHandler<HTMLElement> | undefined;
147
+ onChange?: React.ChangeEventHandler<HTMLElement, Element> | undefined;
148
+ onChangeCapture?: React.ChangeEventHandler<HTMLElement, Element> | undefined;
149
+ onBeforeInput?: React.InputEventHandler<HTMLElement> | undefined;
150
+ onBeforeInputCapture?: React.InputEventHandler<HTMLElement> | undefined;
151
+ onInput?: React.InputEventHandler<HTMLElement> | undefined;
152
+ onInputCapture?: React.InputEventHandler<HTMLElement> | undefined;
153
+ onReset?: React.ReactEventHandler<HTMLElement> | undefined;
154
+ onResetCapture?: React.ReactEventHandler<HTMLElement> | undefined;
155
+ onSubmit?: React.SubmitEventHandler<HTMLElement> | undefined;
156
+ onSubmitCapture?: React.SubmitEventHandler<HTMLElement> | undefined;
157
+ onInvalid?: React.ReactEventHandler<HTMLElement> | undefined;
158
+ onInvalidCapture?: React.ReactEventHandler<HTMLElement> | undefined;
159
+ onLoad?: React.ReactEventHandler<HTMLElement> | undefined;
160
+ onLoadCapture?: React.ReactEventHandler<HTMLElement> | undefined;
161
+ onError?: React.ReactEventHandler<HTMLElement> | undefined;
162
+ onErrorCapture?: React.ReactEventHandler<HTMLElement> | undefined;
163
+ onKeyDown?: React.KeyboardEventHandler<HTMLElement> | undefined;
164
+ onKeyDownCapture?: React.KeyboardEventHandler<HTMLElement> | undefined;
165
+ onKeyPress?: React.KeyboardEventHandler<HTMLElement> | undefined;
166
+ onKeyPressCapture?: React.KeyboardEventHandler<HTMLElement> | undefined;
167
+ onKeyUp?: React.KeyboardEventHandler<HTMLElement> | undefined;
168
+ onKeyUpCapture?: React.KeyboardEventHandler<HTMLElement> | undefined;
169
+ onAbort?: React.ReactEventHandler<HTMLElement> | undefined;
170
+ onAbortCapture?: React.ReactEventHandler<HTMLElement> | undefined;
171
+ onCanPlay?: React.ReactEventHandler<HTMLElement> | undefined;
172
+ onCanPlayCapture?: React.ReactEventHandler<HTMLElement> | undefined;
173
+ onCanPlayThrough?: React.ReactEventHandler<HTMLElement> | undefined;
174
+ onCanPlayThroughCapture?: React.ReactEventHandler<HTMLElement> | undefined;
175
+ onDurationChange?: React.ReactEventHandler<HTMLElement> | undefined;
176
+ onDurationChangeCapture?: React.ReactEventHandler<HTMLElement> | undefined;
177
+ onEmptied?: React.ReactEventHandler<HTMLElement> | undefined;
178
+ onEmptiedCapture?: React.ReactEventHandler<HTMLElement> | undefined;
179
+ onEncrypted?: React.ReactEventHandler<HTMLElement> | undefined;
180
+ onEncryptedCapture?: React.ReactEventHandler<HTMLElement> | undefined;
181
+ onEnded?: React.ReactEventHandler<HTMLElement> | undefined;
182
+ onEndedCapture?: React.ReactEventHandler<HTMLElement> | undefined;
183
+ onLoadedData?: React.ReactEventHandler<HTMLElement> | undefined;
184
+ onLoadedDataCapture?: React.ReactEventHandler<HTMLElement> | undefined;
185
+ onLoadedMetadata?: React.ReactEventHandler<HTMLElement> | undefined;
186
+ onLoadedMetadataCapture?: React.ReactEventHandler<HTMLElement> | undefined;
187
+ onLoadStart?: React.ReactEventHandler<HTMLElement> | undefined;
188
+ onLoadStartCapture?: React.ReactEventHandler<HTMLElement> | undefined;
189
+ onPause?: React.ReactEventHandler<HTMLElement> | undefined;
190
+ onPauseCapture?: React.ReactEventHandler<HTMLElement> | undefined;
191
+ onPlay?: React.ReactEventHandler<HTMLElement> | undefined;
192
+ onPlayCapture?: React.ReactEventHandler<HTMLElement> | undefined;
193
+ onPlaying?: React.ReactEventHandler<HTMLElement> | undefined;
194
+ onPlayingCapture?: React.ReactEventHandler<HTMLElement> | undefined;
195
+ onProgress?: React.ReactEventHandler<HTMLElement> | undefined;
196
+ onProgressCapture?: React.ReactEventHandler<HTMLElement> | undefined;
197
+ onRateChange?: React.ReactEventHandler<HTMLElement> | undefined;
198
+ onRateChangeCapture?: React.ReactEventHandler<HTMLElement> | undefined;
199
+ onSeeked?: React.ReactEventHandler<HTMLElement> | undefined;
200
+ onSeekedCapture?: React.ReactEventHandler<HTMLElement> | undefined;
201
+ onSeeking?: React.ReactEventHandler<HTMLElement> | undefined;
202
+ onSeekingCapture?: React.ReactEventHandler<HTMLElement> | undefined;
203
+ onStalled?: React.ReactEventHandler<HTMLElement> | undefined;
204
+ onStalledCapture?: React.ReactEventHandler<HTMLElement> | undefined;
205
+ onSuspend?: React.ReactEventHandler<HTMLElement> | undefined;
206
+ onSuspendCapture?: React.ReactEventHandler<HTMLElement> | undefined;
207
+ onTimeUpdate?: React.ReactEventHandler<HTMLElement> | undefined;
208
+ onTimeUpdateCapture?: React.ReactEventHandler<HTMLElement> | undefined;
209
+ onVolumeChange?: React.ReactEventHandler<HTMLElement> | undefined;
210
+ onVolumeChangeCapture?: React.ReactEventHandler<HTMLElement> | undefined;
211
+ onWaiting?: React.ReactEventHandler<HTMLElement> | undefined;
212
+ onWaitingCapture?: React.ReactEventHandler<HTMLElement> | undefined;
213
+ onAuxClick?: React.MouseEventHandler<HTMLElement> | undefined;
214
+ onAuxClickCapture?: React.MouseEventHandler<HTMLElement> | undefined;
215
+ onClick?: React.MouseEventHandler<HTMLElement> | undefined;
216
+ onClickCapture?: React.MouseEventHandler<HTMLElement> | undefined;
217
+ onContextMenu?: React.MouseEventHandler<HTMLElement> | undefined;
218
+ onContextMenuCapture?: React.MouseEventHandler<HTMLElement> | undefined;
219
+ onDoubleClick?: React.MouseEventHandler<HTMLElement> | undefined;
220
+ onDoubleClickCapture?: React.MouseEventHandler<HTMLElement> | undefined;
221
+ onDrag?: React.DragEventHandler<HTMLElement> | undefined;
222
+ onDragCapture?: React.DragEventHandler<HTMLElement> | undefined;
223
+ onDragEnd?: React.DragEventHandler<HTMLElement> | undefined;
224
+ onDragEndCapture?: React.DragEventHandler<HTMLElement> | undefined;
225
+ onDragEnter?: React.DragEventHandler<HTMLElement> | undefined;
226
+ onDragEnterCapture?: React.DragEventHandler<HTMLElement> | undefined;
227
+ onDragExit?: React.DragEventHandler<HTMLElement> | undefined;
228
+ onDragExitCapture?: React.DragEventHandler<HTMLElement> | undefined;
229
+ onDragLeave?: React.DragEventHandler<HTMLElement> | undefined;
230
+ onDragLeaveCapture?: React.DragEventHandler<HTMLElement> | undefined;
231
+ onDragOver?: React.DragEventHandler<HTMLElement> | undefined;
232
+ onDragOverCapture?: React.DragEventHandler<HTMLElement> | undefined;
233
+ onDragStart?: React.DragEventHandler<HTMLElement> | undefined;
234
+ onDragStartCapture?: React.DragEventHandler<HTMLElement> | undefined;
235
+ onDrop?: React.DragEventHandler<HTMLElement> | undefined;
236
+ onDropCapture?: React.DragEventHandler<HTMLElement> | undefined;
237
+ onMouseDown?: React.MouseEventHandler<HTMLElement> | undefined;
238
+ onMouseDownCapture?: React.MouseEventHandler<HTMLElement> | undefined;
239
+ onMouseEnter?: React.MouseEventHandler<HTMLElement> | undefined;
240
+ onMouseLeave?: React.MouseEventHandler<HTMLElement> | undefined;
241
+ onMouseMove?: React.MouseEventHandler<HTMLElement> | undefined;
242
+ onMouseMoveCapture?: React.MouseEventHandler<HTMLElement> | undefined;
243
+ onMouseOut?: React.MouseEventHandler<HTMLElement> | undefined;
244
+ onMouseOutCapture?: React.MouseEventHandler<HTMLElement> | undefined;
245
+ onMouseOver?: React.MouseEventHandler<HTMLElement> | undefined;
246
+ onMouseOverCapture?: React.MouseEventHandler<HTMLElement> | undefined;
247
+ onMouseUp?: React.MouseEventHandler<HTMLElement> | undefined;
248
+ onMouseUpCapture?: React.MouseEventHandler<HTMLElement> | undefined;
249
+ onSelect?: React.ReactEventHandler<HTMLElement> | undefined;
250
+ onSelectCapture?: React.ReactEventHandler<HTMLElement> | undefined;
251
+ onTouchCancel?: React.TouchEventHandler<HTMLElement> | undefined;
252
+ onTouchCancelCapture?: React.TouchEventHandler<HTMLElement> | undefined;
253
+ onTouchEnd?: React.TouchEventHandler<HTMLElement> | undefined;
254
+ onTouchEndCapture?: React.TouchEventHandler<HTMLElement> | undefined;
255
+ onTouchMove?: React.TouchEventHandler<HTMLElement> | undefined;
256
+ onTouchMoveCapture?: React.TouchEventHandler<HTMLElement> | undefined;
257
+ onTouchStart?: React.TouchEventHandler<HTMLElement> | undefined;
258
+ onTouchStartCapture?: React.TouchEventHandler<HTMLElement> | undefined;
259
+ onPointerDown?: React.PointerEventHandler<HTMLElement> | undefined;
260
+ onPointerDownCapture?: React.PointerEventHandler<HTMLElement> | undefined;
261
+ onPointerMove?: React.PointerEventHandler<HTMLElement> | undefined;
262
+ onPointerMoveCapture?: React.PointerEventHandler<HTMLElement> | undefined;
263
+ onPointerUp?: React.PointerEventHandler<HTMLElement> | undefined;
264
+ onPointerUpCapture?: React.PointerEventHandler<HTMLElement> | undefined;
265
+ onPointerCancel?: React.PointerEventHandler<HTMLElement> | undefined;
266
+ onPointerCancelCapture?: React.PointerEventHandler<HTMLElement> | undefined;
267
+ onPointerEnter?: React.PointerEventHandler<HTMLElement> | undefined;
268
+ onPointerLeave?: React.PointerEventHandler<HTMLElement> | undefined;
269
+ onPointerOver?: React.PointerEventHandler<HTMLElement> | undefined;
270
+ onPointerOverCapture?: React.PointerEventHandler<HTMLElement> | undefined;
271
+ onPointerOut?: React.PointerEventHandler<HTMLElement> | undefined;
272
+ onPointerOutCapture?: React.PointerEventHandler<HTMLElement> | undefined;
273
+ onGotPointerCapture?: React.PointerEventHandler<HTMLElement> | undefined;
274
+ onGotPointerCaptureCapture?: React.PointerEventHandler<HTMLElement> | undefined;
275
+ onLostPointerCapture?: React.PointerEventHandler<HTMLElement> | undefined;
276
+ onLostPointerCaptureCapture?: React.PointerEventHandler<HTMLElement> | undefined;
277
+ onScroll?: React.UIEventHandler<HTMLElement> | undefined;
278
+ onScrollCapture?: React.UIEventHandler<HTMLElement> | undefined;
279
+ onScrollEnd?: React.UIEventHandler<HTMLElement> | undefined;
280
+ onScrollEndCapture?: React.UIEventHandler<HTMLElement> | undefined;
281
+ onWheel?: React.WheelEventHandler<HTMLElement> | undefined;
282
+ onWheelCapture?: React.WheelEventHandler<HTMLElement> | undefined;
283
+ onAnimationStart?: React.AnimationEventHandler<HTMLElement> | undefined;
284
+ onAnimationStartCapture?: React.AnimationEventHandler<HTMLElement> | undefined;
285
+ onAnimationEnd?: React.AnimationEventHandler<HTMLElement> | undefined;
286
+ onAnimationEndCapture?: React.AnimationEventHandler<HTMLElement> | undefined;
287
+ onAnimationIteration?: React.AnimationEventHandler<HTMLElement> | undefined;
288
+ onAnimationIterationCapture?: React.AnimationEventHandler<HTMLElement> | undefined;
289
+ onToggle?: React.ToggleEventHandler<HTMLElement> | undefined;
290
+ onBeforeToggle?: React.ToggleEventHandler<HTMLElement> | undefined;
291
+ onTransitionCancel?: React.TransitionEventHandler<HTMLElement> | undefined;
292
+ onTransitionCancelCapture?: React.TransitionEventHandler<HTMLElement> | undefined;
293
+ onTransitionEnd?: React.TransitionEventHandler<HTMLElement> | undefined;
294
+ onTransitionEndCapture?: React.TransitionEventHandler<HTMLElement> | undefined;
295
+ onTransitionRun?: React.TransitionEventHandler<HTMLElement> | undefined;
296
+ onTransitionRunCapture?: React.TransitionEventHandler<HTMLElement> | undefined;
297
+ onTransitionStart?: React.TransitionEventHandler<HTMLElement> | undefined;
298
+ onTransitionStartCapture?: React.TransitionEventHandler<HTMLElement> | undefined;
299
+ }>;
300
+
301
+ export { Code };
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import { BaseComponent } from '../../../types/common.js';
3
+ import { Prettify } from '../../../types/utilities.js';
4
+
5
+ type CodeSize = 'xs' | 'sm' | 'md';
6
+ interface CodeBaseProps extends BaseComponent<HTMLElement> {
7
+ /** Inline code content. */
8
+ children: React.ReactNode;
9
+ /**
10
+ * Font size scale — relative to surrounding text.
11
+ * @default "sm"
12
+ */
13
+ size?: CodeSize;
14
+ }
15
+ type CodeProps = Prettify<CodeBaseProps>;
16
+
17
+ export type { CodeBaseProps, CodeProps, CodeSize };
@@ -0,0 +1,26 @@
1
+ import React from 'react';
2
+ import { TextAreaProps } from './TextArea.types.js';
3
+
4
+ /**
5
+ * Multi-line text input with optional auto-resize.
6
+ *
7
+ * Visual parity with `Input` — uses the same border, focus ring, and error
8
+ * states. Auto-resize activates when `minRows` or `maxRows` is set and
9
+ * disables the native resize handle.
10
+ *
11
+ * @example
12
+ * ```tsx
13
+ * <TextArea
14
+ * label="Description"
15
+ * minRows={3}
16
+ * maxRows={8}
17
+ * value={value}
18
+ * onChange={setValue}
19
+ * showCount
20
+ * maxLength={500}
21
+ * />
22
+ * ```
23
+ */
24
+ declare const TextArea: React.FC<TextAreaProps>;
25
+
26
+ export { TextArea };
@@ -0,0 +1,76 @@
1
+ import React from 'react';
2
+ import { BaseComponent, Size } from '../../../types/common.js';
3
+ import { Prettify } from '../../../types/utilities.js';
4
+
5
+ type TextAreaSize = Size;
6
+ type TextAreaResize = 'none' | 'vertical' | 'horizontal' | 'both';
7
+ interface TextAreaBaseProps extends Omit<BaseComponent<HTMLTextAreaElement>, 'onChange' | 'size' | 'css' | 'defaultValue'> {
8
+ /** Controlled value. */
9
+ value?: string;
10
+ /** Uncontrolled initial value. */
11
+ defaultValue?: string;
12
+ /** Placeholder text. */
13
+ placeholder?: string;
14
+ /**
15
+ * Size scale (matches Input).
16
+ * @default "md"
17
+ */
18
+ size?: TextAreaSize;
19
+ /** @default false */
20
+ disabled?: boolean;
21
+ /** @default false */
22
+ error?: boolean;
23
+ /** @default false */
24
+ required?: boolean;
25
+ /** @default false */
26
+ readOnly?: boolean;
27
+ /** Label rendered above the textarea (uses FormLabel). */
28
+ label?: string;
29
+ /** Helper text below the textarea. */
30
+ helperText?: string;
31
+ /** Error message shown when `error` is true; overrides `helperText`. */
32
+ errorMessage?: string;
33
+ /**
34
+ * User resize direction. Auto-resize (via `minRows`/`maxRows`) forces
35
+ * this to `'none'`.
36
+ * @default "vertical"
37
+ */
38
+ resize?: TextAreaResize;
39
+ /**
40
+ * Initial number of rows (used when not auto-sizing).
41
+ * @default 3
42
+ */
43
+ rows?: number;
44
+ /**
45
+ * Minimum rows when auto-sizing. Setting this (or `maxRows`) enables
46
+ * auto-resize.
47
+ */
48
+ minRows?: number;
49
+ /** Maximum rows when auto-sizing. Overflow scrolls above this. */
50
+ maxRows?: number;
51
+ /**
52
+ * Render in monospace font.
53
+ * @default false
54
+ */
55
+ monospace?: boolean;
56
+ /** Maximum allowed character count (HTML attribute). */
57
+ maxLength?: number;
58
+ /**
59
+ * Show character count below the textarea. Pair with `maxLength`
60
+ * to show `123/500`.
61
+ * @default false
62
+ */
63
+ showCount?: boolean;
64
+ /** Change handler returning the string value directly. */
65
+ onChange?: (value: string) => void;
66
+ onFocus?: (event: React.FocusEvent<HTMLTextAreaElement>) => void;
67
+ onBlur?: (event: React.FocusEvent<HTMLTextAreaElement>) => void;
68
+ onKeyDown?: (event: React.KeyboardEvent<HTMLTextAreaElement>) => void;
69
+ /** @internal passed through to the underlying <textarea>. */
70
+ name?: string;
71
+ /** @internal passed through to the underlying <textarea>. */
72
+ id?: string;
73
+ }
74
+ type TextAreaProps = Prettify<TextAreaBaseProps>;
75
+
76
+ export type { TextAreaBaseProps, TextAreaProps, TextAreaResize, TextAreaSize };
@@ -1,6 +1,6 @@
1
1
  export { ThemeVars, vars } from './theme/contract.css.js';
2
2
  export { DarkThemeValues, darkThemeValues } from './theme/darkTheme.css.js';
3
- export { Brand, DeepPartial, DeepReadonly, KeyOf, LiteralUnion, NonEmptyArray, Prettify, RequireFields, StrictExclude, ValueOf } from './types/utilities.js';
3
+ export { createCustomTheme } from './theme/createCustomTheme.js';
4
4
  export { VanillaThemeProvider, VanillaThemeProviderProps } from './theme/VanillaThemeProvider.js';
5
5
  export { ThemeProvider, ThemeProviderProps } from './theme/ThemeProvider.js';
6
6
  export { Accordion } from './components/layout/Accordion/Accordion.js';
@@ -8,8 +8,14 @@ export { AccordionItem } from './components/layout/Accordion/AccordionItem.js';
8
8
  export { AccordionTrigger } from './components/layout/Accordion/AccordionTrigger.js';
9
9
  export { AccordionContent } from './components/layout/Accordion/AccordionContent.js';
10
10
  export { AccordionContentProps, AccordionItemProps, AccordionProps, AccordionSize, AccordionTriggerProps, AccordionVariant } from './components/layout/Accordion/Accordion.types.js';
11
+ export { Divider } from './components/layout/Divider/Divider.js';
12
+ export { DividerOrientation, DividerProps, DividerSpacing, DividerVariant } from './components/layout/Divider/Divider.types.js';
11
13
  export { Flex, FlexAlign, FlexAlignContent, FlexDirection, FlexJustify, FlexProps, FlexSpacing, FlexWrap } from './components/layout/Flex/Flex.js';
12
14
  export { Grid, GridProps, GridSize, GridSpacing } from './components/layout/Grid/Grid.js';
15
+ export { ListItem } from './components/layout/ListItem/ListItem.js';
16
+ export { ListItemDensity, ListItemProps } from './components/layout/ListItem/ListItem.types.js';
17
+ export { PageHeader } from './components/layout/PageHeader/PageHeader.js';
18
+ export { PageHeaderProps, PageHeaderSize } from './components/layout/PageHeader/PageHeader.types.js';
13
19
  export { PanelSurface } from './components/layout/PanelSurface/PanelSurface.js';
14
20
  export { PanelSurfaceBodyProps, PanelSurfaceFooterProps, PanelSurfaceHeaderProps, PanelSurfaceProps, PanelSurfaceSize } from './components/layout/PanelSurface/PanelSurface.types.js';
15
21
  export { ScrollArea } from './components/layout/ScrollArea/ScrollArea.js';
@@ -19,10 +25,14 @@ export { SplitPane } from './components/layout/SplitPane/SplitPane.js';
19
25
  export { SplitPanePanel } from './components/layout/SplitPane/SplitPanePanel.js';
20
26
  export { PanelConfig, PanelSize, SplitDirection, SplitPanePanelProps, SplitPaneProps } from './components/layout/SplitPane/SplitPane.types.js';
21
27
  export { Stack } from './components/layout/Stack/Stack.js';
28
+ export { Badge } from './components/primitives/Badge/Badge.js';
29
+ export { BadgeColor, BadgeProps, BadgeSize, BadgeVariant } from './components/primitives/Badge/Badge.types.js';
22
30
  export { Button, ButtonProps, ButtonSize, ButtonVariant } from './components/primitives/Button/Button.js';
23
31
  export { Checkbox } from './components/primitives/Checkbox/Checkbox.js';
24
32
  export { CheckboxGroup } from './components/primitives/Checkbox/CheckboxGroup.js';
25
33
  export { CheckboxGroupProps, CheckboxProps, CheckboxSize, CheckboxVariant } from './components/primitives/Checkbox/Checkbox.types.js';
34
+ export { Code } from './components/primitives/Code/Code.js';
35
+ export { CodeProps, CodeSize } from './components/primitives/Code/Code.types.js';
26
36
  export { Collapsible } from './components/primitives/Collapsible/Collapsible.js';
27
37
  export { CollapsibleProps, CollapsibleSize } from './components/primitives/Collapsible/Collapsible.types.js';
28
38
  export { Icon, IconProps, IconSize } from './components/primitives/Icon/Icon.js';
@@ -36,8 +46,11 @@ export { PopoverTrigger } from './components/primitives/Popover/PopoverTrigger.j
36
46
  export { PopoverCloseProps, PopoverContentProps, PopoverPlacement, PopoverProps, PopoverTriggerProps } from './components/primitives/Popover/Popover.types.js';
37
47
  export { Switch, SwitchProps, SwitchSize } from './components/primitives/Switch/Switch.js';
38
48
  export { Text, TextAlign, TextColor, TextElement, TextLineHeight, TextProps, TextSize, TextVariant, TextWeight } from './components/primitives/Text/Text.js';
49
+ export { TextArea } from './components/primitives/TextArea/TextArea.js';
50
+ export { TextAreaProps, TextAreaResize, TextAreaSize } from './components/primitives/TextArea/TextArea.types.js';
39
51
  export { Tooltip, TooltipProps } from './components/primitives/Tooltip/Tooltip.js';
40
52
  export { CollisionAvoidance, TooltipCollisionConfig, TooltipCollisionStrategy, TooltipPlacement } from './components/primitives/Tooltip/types.js';
53
+ export { Brand, DeepPartial, DeepReadonly, KeyOf, LiteralUnion, NonEmptyArray, Prettify, RequireFields, StrictExclude, ValueOf } from './types/utilities.js';
41
54
  export { BaseComponent, Size, Variant } from './types/common.js';
42
55
  export { ColorPicker } from './components/controls/ColorPicker/ColorPicker.js';
43
56
  export { ColorSwatch } from './components/controls/ColorPicker/ColorSwatch.js';
@@ -81,6 +94,10 @@ export { DialogBody } from './components/feedback/Dialog/DialogBody.js';
81
94
  export { DialogFooter } from './components/feedback/Dialog/DialogFooter.js';
82
95
  export { DialogClose } from './components/feedback/Dialog/DialogClose.js';
83
96
  export { DialogBodyProps, DialogFooterProps, DialogHeaderProps, DialogProps, DialogSize } from './components/feedback/Dialog/Dialog.types.js';
97
+ export { EmptyState } from './components/feedback/EmptyState/EmptyState.js';
98
+ export { EmptyStateProps, EmptyStateVariant } from './components/feedback/EmptyState/EmptyState.types.js';
99
+ export { Spinner } from './components/feedback/Spinner/Spinner.js';
100
+ export { SpinnerColor, SpinnerProps, SpinnerSize, SpinnerVariant } from './components/feedback/Spinner/Spinner.types.js';
84
101
  export { ToastProvider } from './components/feedback/Toast/ToastProvider.js';
85
102
  export { useToast } from './components/feedback/Toast/useToast.js';
86
103
  export { ToastData, ToastPosition, ToastProviderProps, ToastSeverity, UseToastReturn } from './components/feedback/Toast/Toast.types.js';
@@ -106,10 +123,12 @@ export { ChatContextChip } from './components/editor/ChatPanel/ChatContextChip.j
106
123
  export { ChatEmptyState } from './components/editor/ChatPanel/ChatEmptyState.js';
107
124
  export { ChatActionBar } from './components/editor/ChatPanel/ChatActionBar.js';
108
125
  export { ChatInputToolbar } from './components/editor/ChatPanel/ChatInputToolbar.js';
126
+ export { ChatMarkdownRenderer } from './components/editor/ChatPanel/ChatMarkdownRenderer.js';
109
127
  export { useChatMessages } from './components/editor/ChatPanel/useChatMessages.js';
110
128
  export { useChatInput } from './components/editor/ChatPanel/useChatInput.js';
111
129
  export { useChatScroll } from './components/editor/ChatPanel/useChatScroll.js';
112
- export { ChatActionBarProps, ChatAttachmentChipProps, ChatAttachmentData, ChatBubbleProps, ChatCodeBlockProps, ChatContextChipProps, ChatEmptyStateProps, ChatInputProps, ChatInputToolbarProps, ChatMessageData, ChatMessageListProps, ChatMessageProps, ChatMessageRole, ChatMessageStatus, ChatPanelDensity, ChatPanelProps, ChatToolCallData, ChatToolCallProps, ChatToolCallStatus, ChatTypingIndicatorProps, UseChatInputOptions, UseChatInputReturn, UseChatMessagesOptions, UseChatMessagesReturn, UseChatScrollOptions, UseChatScrollReturn } from './components/editor/ChatPanel/ChatPanel.types.js';
130
+ export { ChatActionBarProps, ChatAttachmentChipProps, ChatAttachmentData, ChatBubbleProps, ChatCodeBlockProps, ChatContextChipProps, ChatEmptyStateProps, ChatInputProps, ChatInputToolbarProps, ChatMessageData, ChatMessageListProps, ChatMessageListScrollApi, ChatMessageProps, ChatMessageRole, ChatMessageStatus, ChatPanelDensity, ChatPanelProps, ChatToolCallData, ChatToolCallProps, ChatToolCallStatus, ChatTypingIndicatorProps, UseChatInputOptions, UseChatInputReturn, UseChatMessagesOptions, UseChatMessagesReturn, UseChatScrollOptions, UseChatScrollReturn } from './components/editor/ChatPanel/ChatPanel.types.js';
131
+ export { ChatMarkdownRendererProps } from './components/editor/ChatPanel/ChatMarkdownRenderer.types.js';
113
132
  export { AppShell, useAppShell } from './components/shell/AppShell/AppShell.js';
114
133
  export { AppShellContextValue, AppShellProps, AppShellSlotProps, AppShellToolbarSlotProps, ToolbarPosition } from './components/shell/AppShell/AppShell.types.js';
115
134
  export { FloatingManager, FloatingPanel } from './components/shell/FloatingPanel/FloatingPanel.js';
@@ -121,3 +140,4 @@ export { StatusBarItemProps, StatusBarProps, StatusBarSectionProps, StatusBarSec
121
140
  export { Toolbar } from './components/shell/Toolbar/Toolbar.js';
122
141
  export { ToolbarButtonProps, ToolbarButtonVariant, ToolbarGroupProps, ToolbarOrientation, ToolbarProps, ToolbarSeparatorProps, ToolbarSize, ToolbarSpacerProps, ToolbarToggleProps } from './components/shell/Toolbar/Toolbar.types.js';
123
142
  export { cx as cn, cx } from './utils/cx.js';
143
+ export { animBlink, animFadeIn, animPulse, animSpin, blinkKeyframe, fadeInKeyframe, pulseKeyframe, spinKeyframe } from './utils/animations.css.js';
@@ -2,12 +2,24 @@ import React from 'react';
2
2
 
3
3
  interface ThemeProviderProps {
4
4
  children: React.ReactNode;
5
+ /**
6
+ * When true, apply Entangle's dark-theme scrollbar styling globally
7
+ * (thin 8px track, muted thumb). The class is added to
8
+ * `document.body` and removed on unmount.
9
+ *
10
+ * Opt-in by design: many app shells run alongside other UI
11
+ * frameworks where forcing scrollbar styles would be invasive.
12
+ *
13
+ * @default false
14
+ */
15
+ globalScrollbars?: boolean;
5
16
  }
6
17
  /**
7
18
  * Theme provider for Entangle UI components.
8
19
  *
9
- * The dark theme is applied globally via CSS custom properties on `:root`.
10
- * This provider is a simple pass-through most apps don't need it.
20
+ * The dark theme is applied globally via CSS custom properties on `:root`,
21
+ * so this provider is a pass-through for most apps. Use it to opt into
22
+ * additional global behaviors such as native-scrollbar theming.
11
23
  *
12
24
  * For scoped theme overrides, use `VanillaThemeProvider` with a custom
13
25
  * class generated by `createCustomTheme()`.
@@ -22,6 +22,7 @@ declare const vars: {
22
22
  secondary: `var(--${string})`;
23
23
  tertiary: `var(--${string})`;
24
24
  elevated: `var(--${string})`;
25
+ inset: `var(--${string})`;
25
26
  };
26
27
  surface: {
27
28
  default: `var(--${string})`;
@@ -29,6 +30,8 @@ declare const vars: {
29
30
  active: `var(--${string})`;
30
31
  disabled: `var(--${string})`;
31
32
  whiteOverlay: `var(--${string})`;
33
+ row: `var(--${string})`;
34
+ rowHover: `var(--${string})`;
32
35
  };
33
36
  border: {
34
37
  default: `var(--${string})`;
@@ -0,0 +1,29 @@
1
+ import { DeepPartial } from '../types/utilities.js';
2
+ import { DarkThemeValues } from './darkTheme.css.js';
3
+
4
+ type ThemeValues = DarkThemeValues;
5
+ /**
6
+ * Creates a custom theme scoped to a CSS selector by deep-merging
7
+ * overrides onto the dark theme defaults.
8
+ *
9
+ * MUST be called in a .css.ts file (build-time only).
10
+ *
11
+ * @param selector - CSS selector to scope the theme to (e.g. '.my-brand', '[data-theme="light"]')
12
+ * @param overrides - Partial theme values to override
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * // my-theme.css.ts
17
+ * import { createCustomTheme } from 'entangle-ui/theme';
18
+ *
19
+ * createCustomTheme('.my-brand', {
20
+ * colors: {
21
+ * accent: { primary: '#ff6600' },
22
+ * },
23
+ * });
24
+ * ```
25
+ */
26
+ declare function createCustomTheme(selector: string, overrides: DeepPartial<ThemeValues>): void;
27
+
28
+ export { createCustomTheme };
29
+ export type { ThemeValues };
@@ -9,6 +9,7 @@ declare const darkThemeValues: {
9
9
  readonly secondary: "#2d2d2d";
10
10
  readonly tertiary: "#3a3a3a";
11
11
  readonly elevated: "#404040";
12
+ readonly inset: "rgba(0, 0, 0, 0.2)";
12
13
  };
13
14
  readonly surface: {
14
15
  readonly default: "#2d2d2d";
@@ -16,6 +17,8 @@ declare const darkThemeValues: {
16
17
  readonly active: "#404040";
17
18
  readonly disabled: "#1f1f1f";
18
19
  readonly whiteOverlay: "rgba(255, 255, 255, 0.1)";
20
+ readonly row: "transparent";
21
+ readonly rowHover: "rgba(255, 255, 255, 0.03)";
19
22
  };
20
23
  readonly border: {
21
24
  readonly default: "#4a4a4a";
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Shared keyframe and animation utility classes.
3
+ *
4
+ * Prefer these over redefining the same keyframes in every component —
5
+ * it keeps the built CSS small and ensures consistent motion across
6
+ * the library. Each utility class respects
7
+ * `@media (prefers-reduced-motion: reduce)` by disabling the animation.
8
+ */
9
+ declare const spinKeyframe: string;
10
+ declare const pulseKeyframe: string;
11
+ declare const blinkKeyframe: string;
12
+ declare const fadeInKeyframe: string;
13
+ declare const animSpin: string;
14
+ declare const animPulse: string;
15
+ declare const animBlink: string;
16
+ declare const animFadeIn: string;
17
+
18
+ export { animBlink, animFadeIn, animPulse, animSpin, blinkKeyframe, fadeInKeyframe, pulseKeyframe, spinKeyframe };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "entangle-ui",
3
- "version": "0.6.2",
3
+ "version": "0.7.0",
4
4
  "type": "module",
5
5
  "sideEffects": [
6
6
  "*.css",