@openuidev/react-ui 0.9.16 → 0.9.18

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 (287) hide show
  1. package/README.md +174 -4
  2. package/dist/components/Charts/ScatterChart/ScatterChart.d.ts.map +1 -1
  3. package/dist/components/Charts/ScatterChart/ScatterChart.js +2 -5
  4. package/dist/components/Charts/ScatterChart/ScatterChart.js.map +1 -1
  5. package/dist/components/FollowUpBlock/FollowUpBlock.d.ts.map +1 -1
  6. package/dist/components/FollowUpBlock/FollowUpBlock.js +2 -2
  7. package/dist/components/FollowUpBlock/FollowUpBlock.js.map +1 -1
  8. package/dist/components/FollowUpBlock/followUpBlock.css +1 -1
  9. package/dist/components/ImageBlock/imageBlock.css +1 -1
  10. package/dist/components/OpenUIChat/GenUIAssistantMessage.d.ts +1 -1
  11. package/dist/components/OpenUIChat/GenUIAssistantMessage.d.ts.map +1 -1
  12. package/dist/components/OpenUIChat/GenUIAssistantMessage.js +49 -6
  13. package/dist/components/OpenUIChat/GenUIAssistantMessage.js.map +1 -1
  14. package/dist/components/OpenUIChat/GenUIUserMessage.d.ts +9 -0
  15. package/dist/components/OpenUIChat/GenUIUserMessage.d.ts.map +1 -0
  16. package/dist/components/OpenUIChat/GenUIUserMessage.js +79 -0
  17. package/dist/components/OpenUIChat/GenUIUserMessage.js.map +1 -0
  18. package/dist/components/OpenUIChat/index.d.ts +1 -0
  19. package/dist/components/OpenUIChat/index.d.ts.map +1 -1
  20. package/dist/components/OpenUIChat/index.js +1 -0
  21. package/dist/components/OpenUIChat/index.js.map +1 -1
  22. package/dist/components/OpenUIChat/types.d.ts +2 -2
  23. package/dist/components/OpenUIChat/types.d.ts.map +1 -1
  24. package/dist/components/OpenUIChat/withChatProvider.d.ts.map +1 -1
  25. package/dist/components/OpenUIChat/withChatProvider.js +10 -0
  26. package/dist/components/OpenUIChat/withChatProvider.js.map +1 -1
  27. package/dist/components/SectionBlock/FoldableSection.d.ts +24 -0
  28. package/dist/components/SectionBlock/FoldableSection.d.ts.map +1 -0
  29. package/dist/components/SectionBlock/FoldableSection.js +17 -0
  30. package/dist/components/SectionBlock/FoldableSection.js.map +1 -0
  31. package/dist/components/SectionBlock/SectionV2.d.ts +9 -0
  32. package/dist/components/SectionBlock/SectionV2.d.ts.map +1 -0
  33. package/dist/components/SectionBlock/SectionV2.js +7 -0
  34. package/dist/components/SectionBlock/SectionV2.js.map +1 -0
  35. package/dist/components/SectionBlock/foldableSection.css +1 -0
  36. package/dist/components/SectionBlock/index.d.ts +3 -0
  37. package/dist/components/SectionBlock/index.d.ts.map +1 -0
  38. package/dist/components/SectionBlock/index.js +3 -0
  39. package/dist/components/SectionBlock/index.js.map +1 -0
  40. package/dist/components/SectionBlock/sectionBlock.css +1 -0
  41. package/dist/components/SectionBlock/sectionV2.css +1 -0
  42. package/dist/components/Shell/shell.css +1 -1
  43. package/dist/components/Shell/thread.css +1 -1
  44. package/dist/components/index.css +1 -1
  45. package/dist/genui-lib/Accordion/index.d.ts +578 -238
  46. package/dist/genui-lib/Accordion/index.d.ts.map +1 -1
  47. package/dist/genui-lib/Accordion/index.js +1 -1
  48. package/dist/genui-lib/Accordion/schema.d.ts +284 -114
  49. package/dist/genui-lib/Accordion/schema.d.ts.map +1 -1
  50. package/dist/genui-lib/Action/schema.d.ts +14 -0
  51. package/dist/genui-lib/Action/schema.d.ts.map +1 -0
  52. package/dist/genui-lib/Action/schema.js +19 -0
  53. package/dist/genui-lib/Action/schema.js.map +1 -0
  54. package/dist/genui-lib/Button/index.d.ts +12 -2
  55. package/dist/genui-lib/Button/index.d.ts.map +1 -1
  56. package/dist/genui-lib/Button/index.js +21 -6
  57. package/dist/genui-lib/Button/index.js.map +1 -1
  58. package/dist/genui-lib/Button/schema.d.ts +11 -1
  59. package/dist/genui-lib/Button/schema.d.ts.map +1 -1
  60. package/dist/genui-lib/Button/schema.js +3 -1
  61. package/dist/genui-lib/Button/schema.js.map +1 -1
  62. package/dist/genui-lib/Buttons/index.d.ts +23 -5
  63. package/dist/genui-lib/Buttons/index.d.ts.map +1 -1
  64. package/dist/genui-lib/Buttons/index.js +1 -1
  65. package/dist/genui-lib/Buttons/schema.d.ts +22 -4
  66. package/dist/genui-lib/Buttons/schema.d.ts.map +1 -1
  67. package/dist/genui-lib/Callout/index.d.ts +1 -1
  68. package/dist/genui-lib/Callout/index.js +1 -1
  69. package/dist/genui-lib/Card/index.d.ts +1135 -257
  70. package/dist/genui-lib/Card/index.d.ts.map +1 -1
  71. package/dist/genui-lib/Card/index.js +1 -1
  72. package/dist/genui-lib/Card/schema.d.ts +2597 -841
  73. package/dist/genui-lib/Card/schema.d.ts.map +1 -1
  74. package/dist/genui-lib/CardHeader/index.d.ts +1 -1
  75. package/dist/genui-lib/CardHeader/index.js +1 -1
  76. package/dist/genui-lib/Carousel/index.d.ts +552 -14
  77. package/dist/genui-lib/Carousel/index.d.ts.map +1 -1
  78. package/dist/genui-lib/Carousel/index.js +5 -5
  79. package/dist/genui-lib/Carousel/index.js.map +1 -1
  80. package/dist/genui-lib/Charts/AreaChartCondensed.d.ts +1 -1
  81. package/dist/genui-lib/Charts/AreaChartCondensed.js +1 -1
  82. package/dist/genui-lib/Charts/BarChartCondensed.d.ts +1 -1
  83. package/dist/genui-lib/Charts/BarChartCondensed.js +1 -1
  84. package/dist/genui-lib/Charts/HorizontalBarChart.d.ts +1 -1
  85. package/dist/genui-lib/Charts/HorizontalBarChart.js +1 -1
  86. package/dist/genui-lib/Charts/LineChartCondensed.d.ts +1 -1
  87. package/dist/genui-lib/Charts/LineChartCondensed.js +1 -1
  88. package/dist/genui-lib/Charts/PieChart.d.ts +1 -1
  89. package/dist/genui-lib/Charts/PieChart.js +1 -1
  90. package/dist/genui-lib/Charts/Point.d.ts +1 -1
  91. package/dist/genui-lib/Charts/Point.js +1 -1
  92. package/dist/genui-lib/Charts/RadarChart.d.ts +1 -1
  93. package/dist/genui-lib/Charts/RadarChart.js +1 -1
  94. package/dist/genui-lib/Charts/RadialChart.d.ts +1 -1
  95. package/dist/genui-lib/Charts/RadialChart.js +1 -1
  96. package/dist/genui-lib/Charts/ScatterChart.d.ts +1 -1
  97. package/dist/genui-lib/Charts/ScatterChart.d.ts.map +1 -1
  98. package/dist/genui-lib/Charts/ScatterChart.js +19 -11
  99. package/dist/genui-lib/Charts/ScatterChart.js.map +1 -1
  100. package/dist/genui-lib/Charts/ScatterSeries.d.ts +1 -1
  101. package/dist/genui-lib/Charts/ScatterSeries.js +1 -1
  102. package/dist/genui-lib/Charts/Series.d.ts +1 -1
  103. package/dist/genui-lib/Charts/Series.js +1 -1
  104. package/dist/genui-lib/Charts/SingleStackedBarChart.d.ts +1 -1
  105. package/dist/genui-lib/Charts/SingleStackedBarChart.js +1 -1
  106. package/dist/genui-lib/Charts/Slice.d.ts +1 -1
  107. package/dist/genui-lib/Charts/Slice.js +1 -1
  108. package/dist/genui-lib/CheckBoxGroup/index.d.ts +14 -4
  109. package/dist/genui-lib/CheckBoxGroup/index.d.ts.map +1 -1
  110. package/dist/genui-lib/CheckBoxGroup/index.js +29 -30
  111. package/dist/genui-lib/CheckBoxGroup/index.js.map +1 -1
  112. package/dist/genui-lib/CheckBoxGroup/schema.d.ts +15 -0
  113. package/dist/genui-lib/CheckBoxGroup/schema.d.ts.map +1 -1
  114. package/dist/genui-lib/CheckBoxGroup/schema.js +6 -0
  115. package/dist/genui-lib/CheckBoxGroup/schema.js.map +1 -1
  116. package/dist/genui-lib/CodeBlock/index.d.ts +1 -1
  117. package/dist/genui-lib/CodeBlock/index.js +1 -1
  118. package/dist/genui-lib/DatePicker/index.d.ts +12 -2
  119. package/dist/genui-lib/DatePicker/index.d.ts.map +1 -1
  120. package/dist/genui-lib/DatePicker/index.js +2 -2
  121. package/dist/genui-lib/DatePicker/index.js.map +1 -1
  122. package/dist/genui-lib/DatePicker/schema.d.ts +11 -1
  123. package/dist/genui-lib/DatePicker/schema.d.ts.map +1 -1
  124. package/dist/genui-lib/DatePicker/schema.js +2 -2
  125. package/dist/genui-lib/DatePicker/schema.js.map +1 -1
  126. package/dist/genui-lib/FollowUpBlock/index.d.ts +9 -0
  127. package/dist/genui-lib/FollowUpBlock/index.d.ts.map +1 -0
  128. package/dist/genui-lib/FollowUpBlock/index.js +23 -0
  129. package/dist/genui-lib/FollowUpBlock/index.js.map +1 -0
  130. package/dist/genui-lib/FollowUpItem/index.d.ts +5 -0
  131. package/dist/genui-lib/FollowUpItem/index.d.ts.map +1 -0
  132. package/dist/genui-lib/FollowUpItem/index.js +12 -0
  133. package/dist/genui-lib/FollowUpItem/index.js.map +1 -0
  134. package/dist/genui-lib/Form/index.d.ts +217 -65
  135. package/dist/genui-lib/Form/index.d.ts.map +1 -1
  136. package/dist/genui-lib/Form/index.js +1 -1
  137. package/dist/genui-lib/Form/schema.d.ts +216 -64
  138. package/dist/genui-lib/Form/schema.d.ts.map +1 -1
  139. package/dist/genui-lib/Form/schema.js +1 -1
  140. package/dist/genui-lib/Form/schema.js.map +1 -1
  141. package/dist/genui-lib/FormControl/index.d.ts +177 -43
  142. package/dist/genui-lib/FormControl/index.d.ts.map +1 -1
  143. package/dist/genui-lib/FormControl/index.js +3 -2
  144. package/dist/genui-lib/FormControl/index.js.map +1 -1
  145. package/dist/genui-lib/FormControl/schema.d.ts +176 -42
  146. package/dist/genui-lib/FormControl/schema.d.ts.map +1 -1
  147. package/dist/genui-lib/Image/index.d.ts +1 -1
  148. package/dist/genui-lib/Image/index.js +1 -1
  149. package/dist/genui-lib/ImageBlock/index.d.ts +1 -1
  150. package/dist/genui-lib/ImageBlock/index.js +1 -1
  151. package/dist/genui-lib/ImageGallery/index.d.ts +1 -1
  152. package/dist/genui-lib/ImageGallery/index.js +1 -1
  153. package/dist/genui-lib/Input/index.d.ts +12 -2
  154. package/dist/genui-lib/Input/index.d.ts.map +1 -1
  155. package/dist/genui-lib/Input/index.js +2 -2
  156. package/dist/genui-lib/Input/index.js.map +1 -1
  157. package/dist/genui-lib/Input/schema.d.ts +11 -1
  158. package/dist/genui-lib/Input/schema.d.ts.map +1 -1
  159. package/dist/genui-lib/Input/schema.js +2 -2
  160. package/dist/genui-lib/Input/schema.js.map +1 -1
  161. package/dist/genui-lib/Label/index.d.ts +1 -1
  162. package/dist/genui-lib/Label/index.js +1 -1
  163. package/dist/genui-lib/ListBlock/index.d.ts +46 -0
  164. package/dist/genui-lib/ListBlock/index.d.ts.map +1 -0
  165. package/dist/genui-lib/ListBlock/index.js +47 -0
  166. package/dist/genui-lib/ListBlock/index.js.map +1 -0
  167. package/dist/genui-lib/ListItem/index.d.ts +21 -0
  168. package/dist/genui-lib/ListItem/index.d.ts.map +1 -0
  169. package/dist/genui-lib/ListItem/index.js +22 -0
  170. package/dist/genui-lib/ListItem/index.js.map +1 -0
  171. package/dist/genui-lib/MarkDownRenderer/index.d.ts +1 -1
  172. package/dist/genui-lib/MarkDownRenderer/index.js +1 -1
  173. package/dist/genui-lib/RadioGroup/index.d.ts +15 -5
  174. package/dist/genui-lib/RadioGroup/index.d.ts.map +1 -1
  175. package/dist/genui-lib/RadioGroup/index.js +19 -17
  176. package/dist/genui-lib/RadioGroup/index.js.map +1 -1
  177. package/dist/genui-lib/SectionBlock/index.d.ts +616 -0
  178. package/dist/genui-lib/SectionBlock/index.d.ts.map +1 -0
  179. package/dist/genui-lib/SectionBlock/index.js +58 -0
  180. package/dist/genui-lib/SectionBlock/index.js.map +1 -0
  181. package/dist/genui-lib/SectionItem/index.d.ts +609 -0
  182. package/dist/genui-lib/SectionItem/index.d.ts.map +1 -0
  183. package/dist/genui-lib/SectionItem/index.js +15 -0
  184. package/dist/genui-lib/SectionItem/index.js.map +1 -0
  185. package/dist/genui-lib/Select/index.d.ts +20 -17
  186. package/dist/genui-lib/Select/index.d.ts.map +1 -1
  187. package/dist/genui-lib/Select/index.js +4 -10
  188. package/dist/genui-lib/Select/index.js.map +1 -1
  189. package/dist/genui-lib/Select/schema.d.ts +11 -1
  190. package/dist/genui-lib/Select/schema.d.ts.map +1 -1
  191. package/dist/genui-lib/Select/schema.js +2 -1
  192. package/dist/genui-lib/Select/schema.js.map +1 -1
  193. package/dist/genui-lib/Separator/index.d.ts +1 -1
  194. package/dist/genui-lib/Separator/index.js +1 -1
  195. package/dist/genui-lib/Slider/index.d.ts +13 -3
  196. package/dist/genui-lib/Slider/index.d.ts.map +1 -1
  197. package/dist/genui-lib/Slider/index.js +4 -4
  198. package/dist/genui-lib/Slider/index.js.map +1 -1
  199. package/dist/genui-lib/Slider/schema.d.ts +12 -2
  200. package/dist/genui-lib/Slider/schema.d.ts.map +1 -1
  201. package/dist/genui-lib/Slider/schema.js +3 -3
  202. package/dist/genui-lib/Slider/schema.js.map +1 -1
  203. package/dist/genui-lib/Stack/index.d.ts +1 -1
  204. package/dist/genui-lib/Stack/index.js +1 -1
  205. package/dist/genui-lib/Steps/index.d.ts +4 -4
  206. package/dist/genui-lib/Steps/index.js +1 -1
  207. package/dist/genui-lib/SwitchGroup/index.d.ts +9 -16
  208. package/dist/genui-lib/SwitchGroup/index.d.ts.map +1 -1
  209. package/dist/genui-lib/SwitchGroup/index.js +24 -3
  210. package/dist/genui-lib/SwitchGroup/index.js.map +1 -1
  211. package/dist/genui-lib/SwitchGroup/schema.d.ts +10 -4
  212. package/dist/genui-lib/SwitchGroup/schema.d.ts.map +1 -1
  213. package/dist/genui-lib/SwitchGroup/schema.js +6 -4
  214. package/dist/genui-lib/SwitchGroup/schema.js.map +1 -1
  215. package/dist/genui-lib/Table/index.d.ts +4 -4
  216. package/dist/genui-lib/Table/index.js +1 -1
  217. package/dist/genui-lib/Tabs/index.d.ts +578 -238
  218. package/dist/genui-lib/Tabs/index.d.ts.map +1 -1
  219. package/dist/genui-lib/Tabs/index.js +1 -1
  220. package/dist/genui-lib/Tabs/schema.d.ts +284 -114
  221. package/dist/genui-lib/Tabs/schema.d.ts.map +1 -1
  222. package/dist/genui-lib/Tag/index.d.ts +1 -1
  223. package/dist/genui-lib/Tag/index.js +1 -1
  224. package/dist/genui-lib/TagBlock/index.d.ts +1 -1
  225. package/dist/genui-lib/TagBlock/index.js +1 -1
  226. package/dist/genui-lib/TextArea/index.d.ts +12 -2
  227. package/dist/genui-lib/TextArea/index.d.ts.map +1 -1
  228. package/dist/genui-lib/TextArea/index.js +2 -2
  229. package/dist/genui-lib/TextArea/index.js.map +1 -1
  230. package/dist/genui-lib/TextArea/schema.d.ts +11 -1
  231. package/dist/genui-lib/TextArea/schema.d.ts.map +1 -1
  232. package/dist/genui-lib/TextArea/schema.js +2 -2
  233. package/dist/genui-lib/TextArea/schema.js.map +1 -1
  234. package/dist/genui-lib/TextCallout/index.d.ts +1 -1
  235. package/dist/genui-lib/TextCallout/index.js +1 -1
  236. package/dist/genui-lib/TextContent/index.d.ts +1 -1
  237. package/dist/genui-lib/TextContent/index.d.ts.map +1 -1
  238. package/dist/genui-lib/TextContent/index.js +3 -2
  239. package/dist/genui-lib/TextContent/index.js.map +1 -1
  240. package/dist/genui-lib/helpers.d.ts.map +1 -1
  241. package/dist/genui-lib/helpers.js +18 -0
  242. package/dist/genui-lib/helpers.js.map +1 -1
  243. package/dist/genui-lib/index.d.ts +2 -1
  244. package/dist/genui-lib/index.d.ts.map +1 -1
  245. package/dist/genui-lib/index.js +2 -1
  246. package/dist/genui-lib/index.js.map +1 -1
  247. package/dist/genui-lib/openuiChatLibrary.d.ts +7 -0
  248. package/dist/genui-lib/openuiChatLibrary.d.ts.map +1 -0
  249. package/dist/genui-lib/openuiChatLibrary.js +315 -0
  250. package/dist/genui-lib/openuiChatLibrary.js.map +1 -0
  251. package/dist/genui-lib/openuiLibrary.d.ts +7 -0
  252. package/dist/genui-lib/openuiLibrary.d.ts.map +1 -0
  253. package/dist/genui-lib/{defaultLibrary.js → openuiLibrary.js} +17 -17
  254. package/dist/genui-lib/openuiLibrary.js.map +1 -0
  255. package/dist/genui-lib/rules.d.ts +19 -0
  256. package/dist/genui-lib/rules.d.ts.map +1 -0
  257. package/dist/genui-lib/rules.js +20 -0
  258. package/dist/genui-lib/rules.js.map +1 -0
  259. package/dist/genui-lib/sectionContentUnion.d.ts +605 -0
  260. package/dist/genui-lib/sectionContentUnion.d.ts.map +1 -0
  261. package/dist/genui-lib/sectionContentUnion.js +50 -0
  262. package/dist/genui-lib/sectionContentUnion.js.map +1 -0
  263. package/dist/genui-lib/unions.d.ts +1494 -105
  264. package/dist/genui-lib/unions.d.ts.map +1 -1
  265. package/dist/genui-lib/unions.js +12 -0
  266. package/dist/genui-lib/unions.js.map +1 -1
  267. package/dist/hooks/useResponsiveContainer.d.ts.map +1 -1
  268. package/dist/hooks/useResponsiveContainer.js +5 -1
  269. package/dist/hooks/useResponsiveContainer.js.map +1 -1
  270. package/dist/index.d.ts +2 -1
  271. package/dist/index.d.ts.map +1 -1
  272. package/dist/index.js +2 -1
  273. package/dist/index.js.map +1 -1
  274. package/dist/styles/followUpBlock.css +1 -1
  275. package/dist/styles/imageBlock.css +1 -1
  276. package/dist/styles/index.css +1 -1
  277. package/dist/styles/sectionBlock.css +1 -0
  278. package/dist/styles/shell.css +1 -1
  279. package/dist/utils/contentParser.d.ts +11 -0
  280. package/dist/utils/contentParser.d.ts.map +1 -0
  281. package/dist/utils/contentParser.js +27 -0
  282. package/dist/utils/contentParser.js.map +1 -0
  283. package/package.json +23 -7
  284. package/dist/genui-lib/defaultLibrary.d.ts +0 -7
  285. package/dist/genui-lib/defaultLibrary.d.ts.map +0 -1
  286. package/dist/genui-lib/defaultLibrary.js.map +0 -1
  287. package/dist/styles/openUiChat.css +0 -1
@@ -0,0 +1,616 @@
1
+ import { z } from "zod";
2
+ export declare const SectionBlock: import("@openuidev/react-lang").DefinedComponent<z.ZodObject<{
3
+ sections: z.ZodArray<z.ZodType<import("@openuidev/react-lang").SubComponentOf<{
4
+ value: string;
5
+ trigger: string;
6
+ content: (import("@openuidev/react-lang").SubComponentOf<{
7
+ buttons: import("@openuidev/react-lang").SubComponentOf<{
8
+ label: string;
9
+ action?: {
10
+ type: import("@openuidev/react-lang").BuiltinActionType.ContinueConversation;
11
+ context?: string | undefined;
12
+ } | {
13
+ type: import("@openuidev/react-lang").BuiltinActionType.OpenUrl;
14
+ url: string;
15
+ } | {
16
+ type: string;
17
+ params?: Record<string, any> | undefined;
18
+ } | undefined;
19
+ variant?: "primary" | "secondary" | "tertiary" | undefined;
20
+ type?: "normal" | "destructive" | undefined;
21
+ size?: "small" | "extra-small" | "medium" | "large" | undefined;
22
+ }>[];
23
+ direction?: "row" | "column" | undefined;
24
+ }> | import("@openuidev/react-lang").SubComponentOf<{
25
+ text: string;
26
+ size?: "small" | "large" | "default" | "small-heavy" | "large-heavy" | undefined;
27
+ }> | import("@openuidev/react-lang").SubComponentOf<{
28
+ textMarkdown: string;
29
+ variant?: "clear" | "card" | "sunk" | undefined;
30
+ }> | import("@openuidev/react-lang").SubComponentOf<{
31
+ title?: string | undefined;
32
+ subtitle?: string | undefined;
33
+ }> | import("@openuidev/react-lang").SubComponentOf<{
34
+ variant: "neutral" | "info" | "warning" | "success" | "error";
35
+ title: string;
36
+ description: string;
37
+ }> | import("@openuidev/react-lang").SubComponentOf<{
38
+ variant?: "neutral" | "info" | "danger" | "warning" | "success" | undefined;
39
+ title?: string | undefined;
40
+ description?: string | undefined;
41
+ }> | import("@openuidev/react-lang").SubComponentOf<{
42
+ language: string;
43
+ codeString: string;
44
+ }> | import("@openuidev/react-lang").SubComponentOf<{
45
+ alt: string;
46
+ src?: string | undefined;
47
+ }> | import("@openuidev/react-lang").SubComponentOf<{
48
+ src: string;
49
+ alt?: string | undefined;
50
+ }> | import("@openuidev/react-lang").SubComponentOf<{
51
+ images: {
52
+ src: string;
53
+ alt?: string | undefined;
54
+ details?: string | undefined;
55
+ }[];
56
+ }> | import("@openuidev/react-lang").SubComponentOf<{
57
+ orientation?: "horizontal" | "vertical" | undefined;
58
+ decorative?: boolean | undefined;
59
+ }> | import("@openuidev/react-lang").SubComponentOf<{
60
+ labels: string[];
61
+ series: {
62
+ category: string;
63
+ values: number[];
64
+ }[];
65
+ variant?: "stacked" | "grouped" | undefined;
66
+ xLabel?: string | undefined;
67
+ yLabel?: string | undefined;
68
+ }> | import("@openuidev/react-lang").SubComponentOf<{
69
+ labels: string[];
70
+ series: {
71
+ category: string;
72
+ values: number[];
73
+ }[];
74
+ }> | import("@openuidev/react-lang").SubComponentOf<{
75
+ slices: {
76
+ category: string;
77
+ value: number;
78
+ }[];
79
+ variant?: "pie" | "donut" | undefined;
80
+ }> | import("@openuidev/react-lang").SubComponentOf<{
81
+ slices: {
82
+ category: string;
83
+ value: number;
84
+ }[];
85
+ }> | import("@openuidev/react-lang").SubComponentOf<{
86
+ slices: {
87
+ category: string;
88
+ value: number;
89
+ }[];
90
+ }> | import("@openuidev/react-lang").SubComponentOf<{
91
+ datasets: {
92
+ name: string;
93
+ points: {
94
+ x: number;
95
+ y: number;
96
+ z?: number | undefined;
97
+ }[];
98
+ }[];
99
+ xLabel?: string | undefined;
100
+ yLabel?: string | undefined;
101
+ }> | import("@openuidev/react-lang").SubComponentOf<{
102
+ labels: string[];
103
+ series: {
104
+ category: string;
105
+ values: number[];
106
+ }[];
107
+ variant?: "step" | "linear" | "natural" | undefined;
108
+ xLabel?: string | undefined;
109
+ yLabel?: string | undefined;
110
+ }> | import("@openuidev/react-lang").SubComponentOf<{
111
+ labels: string[];
112
+ series: {
113
+ category: string;
114
+ values: number[];
115
+ }[];
116
+ variant?: "stacked" | "grouped" | undefined;
117
+ xLabel?: string | undefined;
118
+ yLabel?: string | undefined;
119
+ }> | import("@openuidev/react-lang").SubComponentOf<{
120
+ labels: string[];
121
+ series: {
122
+ category: string;
123
+ values: number[];
124
+ }[];
125
+ variant?: "step" | "linear" | "natural" | undefined;
126
+ xLabel?: string | undefined;
127
+ yLabel?: string | undefined;
128
+ }> | import("@openuidev/react-lang").SubComponentOf<{
129
+ columns: import("@openuidev/react-lang").SubComponentOf<{
130
+ label: string;
131
+ type?: "string" | "number" | "action" | undefined;
132
+ }>[];
133
+ rows: (string | number | boolean)[][];
134
+ }> | import("@openuidev/react-lang").SubComponentOf<{
135
+ tags: string[];
136
+ }> | import("@openuidev/react-lang").SubComponentOf<{
137
+ name: string;
138
+ buttons: import("@openuidev/react-lang").SubComponentOf<{
139
+ buttons: import("@openuidev/react-lang").SubComponentOf<{
140
+ label: string;
141
+ action?: {
142
+ type: import("@openuidev/react-lang").BuiltinActionType.ContinueConversation;
143
+ context?: string | undefined;
144
+ } | {
145
+ type: import("@openuidev/react-lang").BuiltinActionType.OpenUrl;
146
+ url: string;
147
+ } | {
148
+ type: string;
149
+ params?: Record<string, any> | undefined;
150
+ } | undefined;
151
+ variant?: "primary" | "secondary" | "tertiary" | undefined;
152
+ type?: "normal" | "destructive" | undefined;
153
+ size?: "small" | "extra-small" | "medium" | "large" | undefined;
154
+ }>[];
155
+ direction?: "row" | "column" | undefined;
156
+ }>;
157
+ fields: import("@openuidev/react-lang").SubComponentOf<{
158
+ label: string;
159
+ input: import("@openuidev/react-lang").SubComponentOf<{
160
+ name: string;
161
+ placeholder?: string | undefined;
162
+ type?: "number" | "text" | "url" | "email" | "password" | undefined;
163
+ rules?: {
164
+ required?: boolean | undefined;
165
+ email?: boolean | undefined;
166
+ url?: boolean | undefined;
167
+ numeric?: boolean | undefined;
168
+ min?: number | undefined;
169
+ max?: number | undefined;
170
+ minLength?: number | undefined;
171
+ maxLength?: number | undefined;
172
+ pattern?: string | undefined;
173
+ } | undefined;
174
+ }> | import("@openuidev/react-lang").SubComponentOf<{
175
+ name: string;
176
+ placeholder?: string | undefined;
177
+ rows?: number | undefined;
178
+ rules?: {
179
+ required?: boolean | undefined;
180
+ email?: boolean | undefined;
181
+ url?: boolean | undefined;
182
+ numeric?: boolean | undefined;
183
+ min?: number | undefined;
184
+ max?: number | undefined;
185
+ minLength?: number | undefined;
186
+ maxLength?: number | undefined;
187
+ pattern?: string | undefined;
188
+ } | undefined;
189
+ }> | import("@openuidev/react-lang").SubComponentOf<{
190
+ name: string;
191
+ items: unknown[];
192
+ placeholder?: string | undefined;
193
+ rules?: {
194
+ required?: boolean | undefined;
195
+ email?: boolean | undefined;
196
+ url?: boolean | undefined;
197
+ numeric?: boolean | undefined;
198
+ min?: number | undefined;
199
+ max?: number | undefined;
200
+ minLength?: number | undefined;
201
+ maxLength?: number | undefined;
202
+ pattern?: string | undefined;
203
+ } | undefined;
204
+ }> | import("@openuidev/react-lang").SubComponentOf<{
205
+ name: string;
206
+ mode: "single" | "range";
207
+ rules?: {
208
+ required?: boolean | undefined;
209
+ email?: boolean | undefined;
210
+ url?: boolean | undefined;
211
+ numeric?: boolean | undefined;
212
+ min?: number | undefined;
213
+ max?: number | undefined;
214
+ minLength?: number | undefined;
215
+ maxLength?: number | undefined;
216
+ pattern?: string | undefined;
217
+ } | undefined;
218
+ }> | import("@openuidev/react-lang").SubComponentOf<{
219
+ name: string;
220
+ variant: "continuous" | "discrete";
221
+ min: number;
222
+ max: number;
223
+ step?: number | undefined;
224
+ defaultValue?: number[] | undefined;
225
+ rules?: {
226
+ required?: boolean | undefined;
227
+ email?: boolean | undefined;
228
+ url?: boolean | undefined;
229
+ numeric?: boolean | undefined;
230
+ min?: number | undefined;
231
+ max?: number | undefined;
232
+ minLength?: number | undefined;
233
+ maxLength?: number | undefined;
234
+ pattern?: string | undefined;
235
+ } | undefined;
236
+ }> | import("@openuidev/react-lang").SubComponentOf<{
237
+ name: string;
238
+ items: import("@openuidev/react-lang").SubComponentOf<{
239
+ label: string;
240
+ description: string;
241
+ name: string;
242
+ defaultChecked?: boolean | undefined;
243
+ }>[];
244
+ rules?: {
245
+ required?: boolean | undefined;
246
+ email?: boolean | undefined;
247
+ url?: boolean | undefined;
248
+ numeric?: boolean | undefined;
249
+ min?: number | undefined;
250
+ max?: number | undefined;
251
+ minLength?: number | undefined;
252
+ maxLength?: number | undefined;
253
+ pattern?: string | undefined;
254
+ } | undefined;
255
+ }> | import("@openuidev/react-lang").SubComponentOf<{
256
+ name: string;
257
+ items: import("@openuidev/react-lang").SubComponentOf<{
258
+ label: string;
259
+ description: string;
260
+ value: string;
261
+ }>[];
262
+ defaultValue?: string | undefined;
263
+ rules?: {
264
+ required?: boolean | undefined;
265
+ email?: boolean | undefined;
266
+ url?: boolean | undefined;
267
+ numeric?: boolean | undefined;
268
+ min?: number | undefined;
269
+ max?: number | undefined;
270
+ minLength?: number | undefined;
271
+ maxLength?: number | undefined;
272
+ pattern?: string | undefined;
273
+ } | undefined;
274
+ }>;
275
+ hint?: string | undefined;
276
+ }>[];
277
+ }> | import("@openuidev/react-lang").SubComponentOf<{
278
+ items: import("@openuidev/react-lang").SubComponentOf<{
279
+ title: string;
280
+ details: string;
281
+ }>[];
282
+ }> | import("@openuidev/react-lang").SubComponentOf<{
283
+ items: import("@openuidev/react-lang").SubComponentOf<{
284
+ title: string;
285
+ subtitle?: string | undefined;
286
+ image?: {
287
+ src: string;
288
+ alt: string;
289
+ } | undefined;
290
+ actionLabel?: string | undefined;
291
+ action?: {
292
+ type: import("@openuidev/react-lang").BuiltinActionType.ContinueConversation;
293
+ context?: string | undefined;
294
+ } | {
295
+ type: import("@openuidev/react-lang").BuiltinActionType.OpenUrl;
296
+ url: string;
297
+ } | {
298
+ type: string;
299
+ params?: Record<string, any> | undefined;
300
+ } | undefined;
301
+ }>[];
302
+ variant?: "number" | "image" | undefined;
303
+ }> | import("@openuidev/react-lang").SubComponentOf<{
304
+ items: import("@openuidev/react-lang").SubComponentOf<{
305
+ text: string;
306
+ }>[];
307
+ }>)[];
308
+ }>, unknown, z.core.$ZodTypeInternals<import("@openuidev/react-lang").SubComponentOf<{
309
+ value: string;
310
+ trigger: string;
311
+ content: (import("@openuidev/react-lang").SubComponentOf<{
312
+ buttons: import("@openuidev/react-lang").SubComponentOf<{
313
+ label: string;
314
+ action?: {
315
+ type: import("@openuidev/react-lang").BuiltinActionType.ContinueConversation;
316
+ context?: string | undefined;
317
+ } | {
318
+ type: import("@openuidev/react-lang").BuiltinActionType.OpenUrl;
319
+ url: string;
320
+ } | {
321
+ type: string;
322
+ params?: Record<string, any> | undefined;
323
+ } | undefined;
324
+ variant?: "primary" | "secondary" | "tertiary" | undefined;
325
+ type?: "normal" | "destructive" | undefined;
326
+ size?: "small" | "extra-small" | "medium" | "large" | undefined;
327
+ }>[];
328
+ direction?: "row" | "column" | undefined;
329
+ }> | import("@openuidev/react-lang").SubComponentOf<{
330
+ text: string;
331
+ size?: "small" | "large" | "default" | "small-heavy" | "large-heavy" | undefined;
332
+ }> | import("@openuidev/react-lang").SubComponentOf<{
333
+ textMarkdown: string;
334
+ variant?: "clear" | "card" | "sunk" | undefined;
335
+ }> | import("@openuidev/react-lang").SubComponentOf<{
336
+ title?: string | undefined;
337
+ subtitle?: string | undefined;
338
+ }> | import("@openuidev/react-lang").SubComponentOf<{
339
+ variant: "neutral" | "info" | "warning" | "success" | "error";
340
+ title: string;
341
+ description: string;
342
+ }> | import("@openuidev/react-lang").SubComponentOf<{
343
+ variant?: "neutral" | "info" | "danger" | "warning" | "success" | undefined;
344
+ title?: string | undefined;
345
+ description?: string | undefined;
346
+ }> | import("@openuidev/react-lang").SubComponentOf<{
347
+ language: string;
348
+ codeString: string;
349
+ }> | import("@openuidev/react-lang").SubComponentOf<{
350
+ alt: string;
351
+ src?: string | undefined;
352
+ }> | import("@openuidev/react-lang").SubComponentOf<{
353
+ src: string;
354
+ alt?: string | undefined;
355
+ }> | import("@openuidev/react-lang").SubComponentOf<{
356
+ images: {
357
+ src: string;
358
+ alt?: string | undefined;
359
+ details?: string | undefined;
360
+ }[];
361
+ }> | import("@openuidev/react-lang").SubComponentOf<{
362
+ orientation?: "horizontal" | "vertical" | undefined;
363
+ decorative?: boolean | undefined;
364
+ }> | import("@openuidev/react-lang").SubComponentOf<{
365
+ labels: string[];
366
+ series: {
367
+ category: string;
368
+ values: number[];
369
+ }[];
370
+ variant?: "stacked" | "grouped" | undefined;
371
+ xLabel?: string | undefined;
372
+ yLabel?: string | undefined;
373
+ }> | import("@openuidev/react-lang").SubComponentOf<{
374
+ labels: string[];
375
+ series: {
376
+ category: string;
377
+ values: number[];
378
+ }[];
379
+ }> | import("@openuidev/react-lang").SubComponentOf<{
380
+ slices: {
381
+ category: string;
382
+ value: number;
383
+ }[];
384
+ variant?: "pie" | "donut" | undefined;
385
+ }> | import("@openuidev/react-lang").SubComponentOf<{
386
+ slices: {
387
+ category: string;
388
+ value: number;
389
+ }[];
390
+ }> | import("@openuidev/react-lang").SubComponentOf<{
391
+ slices: {
392
+ category: string;
393
+ value: number;
394
+ }[];
395
+ }> | import("@openuidev/react-lang").SubComponentOf<{
396
+ datasets: {
397
+ name: string;
398
+ points: {
399
+ x: number;
400
+ y: number;
401
+ z?: number | undefined;
402
+ }[];
403
+ }[];
404
+ xLabel?: string | undefined;
405
+ yLabel?: string | undefined;
406
+ }> | import("@openuidev/react-lang").SubComponentOf<{
407
+ labels: string[];
408
+ series: {
409
+ category: string;
410
+ values: number[];
411
+ }[];
412
+ variant?: "step" | "linear" | "natural" | undefined;
413
+ xLabel?: string | undefined;
414
+ yLabel?: string | undefined;
415
+ }> | import("@openuidev/react-lang").SubComponentOf<{
416
+ labels: string[];
417
+ series: {
418
+ category: string;
419
+ values: number[];
420
+ }[];
421
+ variant?: "stacked" | "grouped" | undefined;
422
+ xLabel?: string | undefined;
423
+ yLabel?: string | undefined;
424
+ }> | import("@openuidev/react-lang").SubComponentOf<{
425
+ labels: string[];
426
+ series: {
427
+ category: string;
428
+ values: number[];
429
+ }[];
430
+ variant?: "step" | "linear" | "natural" | undefined;
431
+ xLabel?: string | undefined;
432
+ yLabel?: string | undefined;
433
+ }> | import("@openuidev/react-lang").SubComponentOf<{
434
+ columns: import("@openuidev/react-lang").SubComponentOf<{
435
+ label: string;
436
+ type?: "string" | "number" | "action" | undefined;
437
+ }>[];
438
+ rows: (string | number | boolean)[][];
439
+ }> | import("@openuidev/react-lang").SubComponentOf<{
440
+ tags: string[];
441
+ }> | import("@openuidev/react-lang").SubComponentOf<{
442
+ name: string;
443
+ buttons: import("@openuidev/react-lang").SubComponentOf<{
444
+ buttons: import("@openuidev/react-lang").SubComponentOf<{
445
+ label: string;
446
+ action?: {
447
+ type: import("@openuidev/react-lang").BuiltinActionType.ContinueConversation;
448
+ context?: string | undefined;
449
+ } | {
450
+ type: import("@openuidev/react-lang").BuiltinActionType.OpenUrl;
451
+ url: string;
452
+ } | {
453
+ type: string;
454
+ params?: Record<string, any> | undefined;
455
+ } | undefined;
456
+ variant?: "primary" | "secondary" | "tertiary" | undefined;
457
+ type?: "normal" | "destructive" | undefined;
458
+ size?: "small" | "extra-small" | "medium" | "large" | undefined;
459
+ }>[];
460
+ direction?: "row" | "column" | undefined;
461
+ }>;
462
+ fields: import("@openuidev/react-lang").SubComponentOf<{
463
+ label: string;
464
+ input: import("@openuidev/react-lang").SubComponentOf<{
465
+ name: string;
466
+ placeholder?: string | undefined;
467
+ type?: "number" | "text" | "url" | "email" | "password" | undefined;
468
+ rules?: {
469
+ required?: boolean | undefined;
470
+ email?: boolean | undefined;
471
+ url?: boolean | undefined;
472
+ numeric?: boolean | undefined;
473
+ min?: number | undefined;
474
+ max?: number | undefined;
475
+ minLength?: number | undefined;
476
+ maxLength?: number | undefined;
477
+ pattern?: string | undefined;
478
+ } | undefined;
479
+ }> | import("@openuidev/react-lang").SubComponentOf<{
480
+ name: string;
481
+ placeholder?: string | undefined;
482
+ rows?: number | undefined;
483
+ rules?: {
484
+ required?: boolean | undefined;
485
+ email?: boolean | undefined;
486
+ url?: boolean | undefined;
487
+ numeric?: boolean | undefined;
488
+ min?: number | undefined;
489
+ max?: number | undefined;
490
+ minLength?: number | undefined;
491
+ maxLength?: number | undefined;
492
+ pattern?: string | undefined;
493
+ } | undefined;
494
+ }> | import("@openuidev/react-lang").SubComponentOf<{
495
+ name: string;
496
+ items: unknown[];
497
+ placeholder?: string | undefined;
498
+ rules?: {
499
+ required?: boolean | undefined;
500
+ email?: boolean | undefined;
501
+ url?: boolean | undefined;
502
+ numeric?: boolean | undefined;
503
+ min?: number | undefined;
504
+ max?: number | undefined;
505
+ minLength?: number | undefined;
506
+ maxLength?: number | undefined;
507
+ pattern?: string | undefined;
508
+ } | undefined;
509
+ }> | import("@openuidev/react-lang").SubComponentOf<{
510
+ name: string;
511
+ mode: "single" | "range";
512
+ rules?: {
513
+ required?: boolean | undefined;
514
+ email?: boolean | undefined;
515
+ url?: boolean | undefined;
516
+ numeric?: boolean | undefined;
517
+ min?: number | undefined;
518
+ max?: number | undefined;
519
+ minLength?: number | undefined;
520
+ maxLength?: number | undefined;
521
+ pattern?: string | undefined;
522
+ } | undefined;
523
+ }> | import("@openuidev/react-lang").SubComponentOf<{
524
+ name: string;
525
+ variant: "continuous" | "discrete";
526
+ min: number;
527
+ max: number;
528
+ step?: number | undefined;
529
+ defaultValue?: number[] | undefined;
530
+ rules?: {
531
+ required?: boolean | undefined;
532
+ email?: boolean | undefined;
533
+ url?: boolean | undefined;
534
+ numeric?: boolean | undefined;
535
+ min?: number | undefined;
536
+ max?: number | undefined;
537
+ minLength?: number | undefined;
538
+ maxLength?: number | undefined;
539
+ pattern?: string | undefined;
540
+ } | undefined;
541
+ }> | import("@openuidev/react-lang").SubComponentOf<{
542
+ name: string;
543
+ items: import("@openuidev/react-lang").SubComponentOf<{
544
+ label: string;
545
+ description: string;
546
+ name: string;
547
+ defaultChecked?: boolean | undefined;
548
+ }>[];
549
+ rules?: {
550
+ required?: boolean | undefined;
551
+ email?: boolean | undefined;
552
+ url?: boolean | undefined;
553
+ numeric?: boolean | undefined;
554
+ min?: number | undefined;
555
+ max?: number | undefined;
556
+ minLength?: number | undefined;
557
+ maxLength?: number | undefined;
558
+ pattern?: string | undefined;
559
+ } | undefined;
560
+ }> | import("@openuidev/react-lang").SubComponentOf<{
561
+ name: string;
562
+ items: import("@openuidev/react-lang").SubComponentOf<{
563
+ label: string;
564
+ description: string;
565
+ value: string;
566
+ }>[];
567
+ defaultValue?: string | undefined;
568
+ rules?: {
569
+ required?: boolean | undefined;
570
+ email?: boolean | undefined;
571
+ url?: boolean | undefined;
572
+ numeric?: boolean | undefined;
573
+ min?: number | undefined;
574
+ max?: number | undefined;
575
+ minLength?: number | undefined;
576
+ maxLength?: number | undefined;
577
+ pattern?: string | undefined;
578
+ } | undefined;
579
+ }>;
580
+ hint?: string | undefined;
581
+ }>[];
582
+ }> | import("@openuidev/react-lang").SubComponentOf<{
583
+ items: import("@openuidev/react-lang").SubComponentOf<{
584
+ title: string;
585
+ details: string;
586
+ }>[];
587
+ }> | import("@openuidev/react-lang").SubComponentOf<{
588
+ items: import("@openuidev/react-lang").SubComponentOf<{
589
+ title: string;
590
+ subtitle?: string | undefined;
591
+ image?: {
592
+ src: string;
593
+ alt: string;
594
+ } | undefined;
595
+ actionLabel?: string | undefined;
596
+ action?: {
597
+ type: import("@openuidev/react-lang").BuiltinActionType.ContinueConversation;
598
+ context?: string | undefined;
599
+ } | {
600
+ type: import("@openuidev/react-lang").BuiltinActionType.OpenUrl;
601
+ url: string;
602
+ } | {
603
+ type: string;
604
+ params?: Record<string, any> | undefined;
605
+ } | undefined;
606
+ }>[];
607
+ variant?: "number" | "image" | undefined;
608
+ }> | import("@openuidev/react-lang").SubComponentOf<{
609
+ items: import("@openuidev/react-lang").SubComponentOf<{
610
+ text: string;
611
+ }>[];
612
+ }>)[];
613
+ }>, unknown>>>;
614
+ isFoldable: z.ZodOptional<z.ZodBoolean>;
615
+ }, z.core.$strip>>;
616
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/genui-lib/SectionBlock/index.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAUxB,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAyEvB,CAAC"}
@@ -0,0 +1,58 @@
1
+ "use client";
2
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { defineComponent, useIsStreaming } from "@openuidev/react-lang";
4
+ import React from "react";
5
+ import { z } from "zod";
6
+ import { FoldableSectionContent, FoldableSectionItem, FoldableSectionRoot, FoldableSectionTrigger, } from "../../components/SectionBlock/FoldableSection";
7
+ import { SectionV2 } from "../../components/SectionBlock/SectionV2";
8
+ import { SectionItem } from "../SectionItem";
9
+ export const SectionBlock = defineComponent({
10
+ name: "SectionBlock",
11
+ props: z.object({
12
+ sections: z.array(SectionItem.ref),
13
+ isFoldable: z.boolean().optional(),
14
+ }),
15
+ description: "Collapsible accordion sections. Auto-opens sections as they stream in. Use SectionItem for each section.",
16
+ component: ({ props, renderNode }) => {
17
+ const items = (props.sections ?? []);
18
+ const isFoldable = props.isFoldable !== false;
19
+ const isStreaming = useIsStreaming();
20
+ const firstItemValue = items[0]?.props?.value;
21
+ const [openItems, setOpenItems] = React.useState([]);
22
+ const userSelected = React.useRef(false);
23
+ const prevLengthRef = React.useRef(0);
24
+ const prevIsStreaming = React.useRef(isStreaming);
25
+ // During streaming: auto-open each new section as it arrives
26
+ React.useEffect(() => {
27
+ if (items.length === 0)
28
+ return;
29
+ if (isStreaming && items.length > prevLengthRef.current && !userSelected.current) {
30
+ const last = items[items.length - 1];
31
+ const lastValue = last?.props?.value;
32
+ if (lastValue) {
33
+ setOpenItems((prev) => (prev.includes(lastValue) ? prev : [...prev, lastValue]));
34
+ }
35
+ }
36
+ else {
37
+ setOpenItems((prev) => (prev.length === 0 && firstItemValue ? [firstItemValue] : prev));
38
+ }
39
+ prevLengthRef.current = items.length;
40
+ }, [items.length, isStreaming, firstItemValue]);
41
+ // When streaming ends: collapse back to first item (unless user interacted)
42
+ React.useEffect(() => {
43
+ if (prevIsStreaming.current && !isStreaming && !userSelected.current && items.length > 0) {
44
+ setOpenItems(firstItemValue ? [firstItemValue] : []);
45
+ }
46
+ prevIsStreaming.current = isStreaming;
47
+ }, [isStreaming]);
48
+ const handleValueChange = React.useCallback((value) => {
49
+ userSelected.current = true;
50
+ setOpenItems(value ?? []);
51
+ }, []);
52
+ if (!isFoldable) {
53
+ return (_jsx(_Fragment, { children: items.map((item, index) => (_jsx(SectionV2, { trigger: String(item?.props?.trigger ?? ""), children: renderNode(item?.props?.content) }, index))) }));
54
+ }
55
+ return (_jsx(FoldableSectionRoot, { type: "multiple", value: openItems, onValueChange: handleValueChange, children: items.map((item, index) => (_jsxs(FoldableSectionItem, { value: String(item?.props?.value ?? index), children: [_jsx(FoldableSectionTrigger, { text: String(item?.props?.trigger ?? "") }), _jsx(FoldableSectionContent, { children: renderNode(item?.props?.content) })] }, index))) }));
56
+ },
57
+ });
58
+ //# sourceMappingURL=index.js.map