tuiuiu.js 0.1.1

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 (803) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +324 -0
  3. package/dist/app/index.d.ts +9 -0
  4. package/dist/app/index.d.ts.map +1 -0
  5. package/dist/app/index.js +12 -0
  6. package/dist/app/index.js.map +1 -0
  7. package/dist/app/render-loop.d.ts +51 -0
  8. package/dist/app/render-loop.d.ts.map +1 -0
  9. package/dist/app/render-loop.js +263 -0
  10. package/dist/app/render-loop.js.map +1 -0
  11. package/dist/atoms/button.d.ts +109 -0
  12. package/dist/atoms/button.d.ts.map +1 -0
  13. package/dist/atoms/button.js +173 -0
  14. package/dist/atoms/button.js.map +1 -0
  15. package/dist/atoms/index.d.ts +29 -0
  16. package/dist/atoms/index.d.ts.map +1 -0
  17. package/dist/atoms/index.js +53 -0
  18. package/dist/atoms/index.js.map +1 -0
  19. package/dist/atoms/progress-bar.d.ts +96 -0
  20. package/dist/atoms/progress-bar.d.ts.map +1 -0
  21. package/dist/atoms/progress-bar.js +443 -0
  22. package/dist/atoms/progress-bar.js.map +1 -0
  23. package/dist/atoms/slider.d.ts +137 -0
  24. package/dist/atoms/slider.d.ts.map +1 -0
  25. package/dist/atoms/slider.js +317 -0
  26. package/dist/atoms/slider.js.map +1 -0
  27. package/dist/atoms/spinner.d.ts +91 -0
  28. package/dist/atoms/spinner.d.ts.map +1 -0
  29. package/dist/atoms/spinner.js +650 -0
  30. package/dist/atoms/spinner.js.map +1 -0
  31. package/dist/atoms/switch.d.ts +102 -0
  32. package/dist/atoms/switch.d.ts.map +1 -0
  33. package/dist/atoms/switch.js +176 -0
  34. package/dist/atoms/switch.js.map +1 -0
  35. package/dist/atoms/text-input.d.ts +82 -0
  36. package/dist/atoms/text-input.d.ts.map +1 -0
  37. package/dist/atoms/text-input.js +347 -0
  38. package/dist/atoms/text-input.js.map +1 -0
  39. package/dist/atoms/timer.d.ts +178 -0
  40. package/dist/atoms/timer.d.ts.map +1 -0
  41. package/dist/atoms/timer.js +355 -0
  42. package/dist/atoms/timer.js.map +1 -0
  43. package/dist/atoms/tooltip.d.ts +191 -0
  44. package/dist/atoms/tooltip.d.ts.map +1 -0
  45. package/dist/atoms/tooltip.js +279 -0
  46. package/dist/atoms/tooltip.js.map +1 -0
  47. package/dist/components/canvas.d.ts +322 -0
  48. package/dist/components/canvas.d.ts.map +1 -0
  49. package/dist/components/canvas.js +833 -0
  50. package/dist/components/canvas.js.map +1 -0
  51. package/dist/components/code-block.d.ts +75 -0
  52. package/dist/components/code-block.d.ts.map +1 -0
  53. package/dist/components/code-block.js +322 -0
  54. package/dist/components/code-block.js.map +1 -0
  55. package/dist/components/components.d.ts +122 -0
  56. package/dist/components/components.d.ts.map +1 -0
  57. package/dist/components/components.js +151 -0
  58. package/dist/components/components.js.map +1 -0
  59. package/dist/components/data-viz/bar-chart.d.ts +167 -0
  60. package/dist/components/data-viz/bar-chart.d.ts.map +1 -0
  61. package/dist/components/data-viz/bar-chart.js +375 -0
  62. package/dist/components/data-viz/bar-chart.js.map +1 -0
  63. package/dist/components/data-viz/gauge.d.ts +163 -0
  64. package/dist/components/data-viz/gauge.d.ts.map +1 -0
  65. package/dist/components/data-viz/gauge.js +451 -0
  66. package/dist/components/data-viz/gauge.js.map +1 -0
  67. package/dist/components/data-viz/heatmap.d.ts +154 -0
  68. package/dist/components/data-viz/heatmap.d.ts.map +1 -0
  69. package/dist/components/data-viz/heatmap.js +458 -0
  70. package/dist/components/data-viz/heatmap.js.map +1 -0
  71. package/dist/components/data-viz/index.d.ts +16 -0
  72. package/dist/components/data-viz/index.d.ts.map +1 -0
  73. package/dist/components/data-viz/index.js +16 -0
  74. package/dist/components/data-viz/index.js.map +1 -0
  75. package/dist/components/data-viz/line-chart.d.ts +157 -0
  76. package/dist/components/data-viz/line-chart.d.ts.map +1 -0
  77. package/dist/components/data-viz/line-chart.js +578 -0
  78. package/dist/components/data-viz/line-chart.js.map +1 -0
  79. package/dist/components/data-viz/sparkline.d.ts +156 -0
  80. package/dist/components/data-viz/sparkline.d.ts.map +1 -0
  81. package/dist/components/data-viz/sparkline.js +325 -0
  82. package/dist/components/data-viz/sparkline.js.map +1 -0
  83. package/dist/components/grid.d.ts +234 -0
  84. package/dist/components/grid.d.ts.map +1 -0
  85. package/dist/components/grid.js +719 -0
  86. package/dist/components/grid.js.map +1 -0
  87. package/dist/components/index.d.ts +33 -0
  88. package/dist/components/index.d.ts.map +1 -0
  89. package/dist/components/index.js +69 -0
  90. package/dist/components/index.js.map +1 -0
  91. package/dist/components/markdown.d.ts +52 -0
  92. package/dist/components/markdown.d.ts.map +1 -0
  93. package/dist/components/markdown.js +341 -0
  94. package/dist/components/markdown.js.map +1 -0
  95. package/dist/components/modal.d.ts +237 -0
  96. package/dist/components/modal.d.ts.map +1 -0
  97. package/dist/components/modal.js +396 -0
  98. package/dist/components/modal.js.map +1 -0
  99. package/dist/components/progress-bar.d.ts +89 -0
  100. package/dist/components/progress-bar.d.ts.map +1 -0
  101. package/dist/components/progress-bar.js +288 -0
  102. package/dist/components/progress-bar.js.map +1 -0
  103. package/dist/components/select.d.ts +114 -0
  104. package/dist/components/select.d.ts.map +1 -0
  105. package/dist/components/select.js +415 -0
  106. package/dist/components/select.js.map +1 -0
  107. package/dist/components/spinner.d.ts +71 -0
  108. package/dist/components/spinner.d.ts.map +1 -0
  109. package/dist/components/spinner.js +300 -0
  110. package/dist/components/spinner.js.map +1 -0
  111. package/dist/components/split-panel.d.ts +175 -0
  112. package/dist/components/split-panel.d.ts.map +1 -0
  113. package/dist/components/split-panel.js +322 -0
  114. package/dist/components/split-panel.js.map +1 -0
  115. package/dist/components/table.d.ts +103 -0
  116. package/dist/components/table.d.ts.map +1 -0
  117. package/dist/components/table.js +359 -0
  118. package/dist/components/table.js.map +1 -0
  119. package/dist/components/text-input.d.ts +79 -0
  120. package/dist/components/text-input.d.ts.map +1 -0
  121. package/dist/components/text-input.js +332 -0
  122. package/dist/components/text-input.js.map +1 -0
  123. package/dist/core/animation.d.ts +262 -0
  124. package/dist/core/animation.d.ts.map +1 -0
  125. package/dist/core/animation.js +626 -0
  126. package/dist/core/animation.js.map +1 -0
  127. package/dist/core/buffer.d.ts +179 -0
  128. package/dist/core/buffer.d.ts.map +1 -0
  129. package/dist/core/buffer.js +549 -0
  130. package/dist/core/buffer.js.map +1 -0
  131. package/dist/core/capabilities.d.ts +184 -0
  132. package/dist/core/capabilities.d.ts.map +1 -0
  133. package/dist/core/capabilities.js +393 -0
  134. package/dist/core/capabilities.js.map +1 -0
  135. package/dist/core/colors.d.ts +111 -0
  136. package/dist/core/colors.d.ts.map +1 -0
  137. package/dist/core/colors.js +417 -0
  138. package/dist/core/colors.js.map +1 -0
  139. package/dist/core/command-palette.d.ts +220 -0
  140. package/dist/core/command-palette.d.ts.map +1 -0
  141. package/dist/core/command-palette.js +564 -0
  142. package/dist/core/command-palette.js.map +1 -0
  143. package/dist/core/constraint.d.ts +315 -0
  144. package/dist/core/constraint.d.ts.map +1 -0
  145. package/dist/core/constraint.js +651 -0
  146. package/dist/core/constraint.js.map +1 -0
  147. package/dist/core/delta-render.d.ts +64 -0
  148. package/dist/core/delta-render.d.ts.map +1 -0
  149. package/dist/core/delta-render.js +367 -0
  150. package/dist/core/delta-render.js.map +1 -0
  151. package/dist/core/dirty.d.ts +181 -0
  152. package/dist/core/dirty.d.ts.map +1 -0
  153. package/dist/core/dirty.js +335 -0
  154. package/dist/core/dirty.js.map +1 -0
  155. package/dist/core/error-boundary.d.ts +79 -0
  156. package/dist/core/error-boundary.d.ts.map +1 -0
  157. package/dist/core/error-boundary.js +258 -0
  158. package/dist/core/error-boundary.js.map +1 -0
  159. package/dist/core/events.d.ts +206 -0
  160. package/dist/core/events.d.ts.map +1 -0
  161. package/dist/core/events.js +411 -0
  162. package/dist/core/events.js.map +1 -0
  163. package/dist/core/focus.d.ts +294 -0
  164. package/dist/core/focus.d.ts.map +1 -0
  165. package/dist/core/focus.js +589 -0
  166. package/dist/core/focus.js.map +1 -0
  167. package/dist/core/graphics.d.ts +146 -0
  168. package/dist/core/graphics.d.ts.map +1 -0
  169. package/dist/core/graphics.js +561 -0
  170. package/dist/core/graphics.js.map +1 -0
  171. package/dist/core/highlighter.d.ts +148 -0
  172. package/dist/core/highlighter.d.ts.map +1 -0
  173. package/dist/core/highlighter.js +2726 -0
  174. package/dist/core/highlighter.js.map +1 -0
  175. package/dist/core/hit-test.d.ts +126 -0
  176. package/dist/core/hit-test.d.ts.map +1 -0
  177. package/dist/core/hit-test.js +336 -0
  178. package/dist/core/hit-test.js.map +1 -0
  179. package/dist/core/index.d.ts +58 -0
  180. package/dist/core/index.d.ts.map +1 -0
  181. package/dist/core/index.js +254 -0
  182. package/dist/core/index.js.map +1 -0
  183. package/dist/core/input.d.ts +241 -0
  184. package/dist/core/input.d.ts.map +1 -0
  185. package/dist/core/input.js +768 -0
  186. package/dist/core/input.js.map +1 -0
  187. package/dist/core/keybindings.d.ts +256 -0
  188. package/dist/core/keybindings.d.ts.map +1 -0
  189. package/dist/core/keybindings.js +532 -0
  190. package/dist/core/keybindings.js.map +1 -0
  191. package/dist/core/layout.d.ts +30 -0
  192. package/dist/core/layout.d.ts.map +1 -0
  193. package/dist/core/layout.js +347 -0
  194. package/dist/core/layout.js.map +1 -0
  195. package/dist/core/overlay.d.ts +318 -0
  196. package/dist/core/overlay.d.ts.map +1 -0
  197. package/dist/core/overlay.js +794 -0
  198. package/dist/core/overlay.js.map +1 -0
  199. package/dist/core/query.d.ts +155 -0
  200. package/dist/core/query.d.ts.map +1 -0
  201. package/dist/core/query.js +616 -0
  202. package/dist/core/query.js.map +1 -0
  203. package/dist/core/renderer.d.ts +28 -0
  204. package/dist/core/renderer.d.ts.map +1 -0
  205. package/dist/core/renderer.js +403 -0
  206. package/dist/core/renderer.js.map +1 -0
  207. package/dist/core/router.d.ts +401 -0
  208. package/dist/core/router.d.ts.map +1 -0
  209. package/dist/core/router.js +766 -0
  210. package/dist/core/router.js.map +1 -0
  211. package/dist/core/screen.d.ts +302 -0
  212. package/dist/core/screen.d.ts.map +1 -0
  213. package/dist/core/screen.js +537 -0
  214. package/dist/core/screen.js.map +1 -0
  215. package/dist/core/signal.d.ts +136 -0
  216. package/dist/core/signal.d.ts.map +1 -0
  217. package/dist/core/signal.js +336 -0
  218. package/dist/core/signal.js.map +1 -0
  219. package/dist/core/theme.d.ts +220 -0
  220. package/dist/core/theme.d.ts.map +1 -0
  221. package/dist/core/theme.js +499 -0
  222. package/dist/core/theme.js.map +1 -0
  223. package/dist/core/tick.d.ts +107 -0
  224. package/dist/core/tick.d.ts.map +1 -0
  225. package/dist/core/tick.js +174 -0
  226. package/dist/core/tick.js.map +1 -0
  227. package/dist/core/transitions.d.ts +335 -0
  228. package/dist/core/transitions.d.ts.map +1 -0
  229. package/dist/core/transitions.js +650 -0
  230. package/dist/core/transitions.js.map +1 -0
  231. package/dist/core/virtual-scroll.d.ts +241 -0
  232. package/dist/core/virtual-scroll.d.ts.map +1 -0
  233. package/dist/core/virtual-scroll.js +476 -0
  234. package/dist/core/virtual-scroll.js.map +1 -0
  235. package/dist/core/visualization.d.ts +248 -0
  236. package/dist/core/visualization.d.ts.map +1 -0
  237. package/dist/core/visualization.js +709 -0
  238. package/dist/core/visualization.js.map +1 -0
  239. package/dist/design-system/core/index.d.ts +6 -0
  240. package/dist/design-system/core/index.d.ts.map +1 -0
  241. package/dist/design-system/core/index.js +6 -0
  242. package/dist/design-system/core/index.js.map +1 -0
  243. package/dist/design-system/core/layout.d.ts +30 -0
  244. package/dist/design-system/core/layout.d.ts.map +1 -0
  245. package/dist/design-system/core/layout.js +344 -0
  246. package/dist/design-system/core/layout.js.map +1 -0
  247. package/dist/design-system/core/renderer.d.ts +28 -0
  248. package/dist/design-system/core/renderer.d.ts.map +1 -0
  249. package/dist/design-system/core/renderer.js +418 -0
  250. package/dist/design-system/core/renderer.js.map +1 -0
  251. package/dist/design-system/data-display/calendar.d.ts +141 -0
  252. package/dist/design-system/data-display/calendar.d.ts.map +1 -0
  253. package/dist/design-system/data-display/calendar.js +524 -0
  254. package/dist/design-system/data-display/calendar.js.map +1 -0
  255. package/dist/design-system/data-display/code-block.d.ts +75 -0
  256. package/dist/design-system/data-display/code-block.d.ts.map +1 -0
  257. package/dist/design-system/data-display/code-block.js +311 -0
  258. package/dist/design-system/data-display/code-block.js.map +1 -0
  259. package/dist/design-system/data-display/data-table.d.ts +173 -0
  260. package/dist/design-system/data-display/data-table.d.ts.map +1 -0
  261. package/dist/design-system/data-display/data-table.js +428 -0
  262. package/dist/design-system/data-display/data-table.js.map +1 -0
  263. package/dist/design-system/data-display/index.d.ts +10 -0
  264. package/dist/design-system/data-display/index.d.ts.map +1 -0
  265. package/dist/design-system/data-display/index.js +16 -0
  266. package/dist/design-system/data-display/index.js.map +1 -0
  267. package/dist/design-system/data-display/markdown.d.ts +52 -0
  268. package/dist/design-system/data-display/markdown.d.ts.map +1 -0
  269. package/dist/design-system/data-display/markdown.js +341 -0
  270. package/dist/design-system/data-display/markdown.js.map +1 -0
  271. package/dist/design-system/data-display/table.d.ts +103 -0
  272. package/dist/design-system/data-display/table.d.ts.map +1 -0
  273. package/dist/design-system/data-display/table.js +342 -0
  274. package/dist/design-system/data-display/table.js.map +1 -0
  275. package/dist/design-system/data-display/tree.d.ts +166 -0
  276. package/dist/design-system/data-display/tree.d.ts.map +1 -0
  277. package/dist/design-system/data-display/tree.js +428 -0
  278. package/dist/design-system/data-display/tree.js.map +1 -0
  279. package/dist/design-system/feedback/badge.d.ts +21 -0
  280. package/dist/design-system/feedback/badge.d.ts.map +1 -0
  281. package/dist/design-system/feedback/badge.js +9 -0
  282. package/dist/design-system/feedback/badge.js.map +1 -0
  283. package/dist/design-system/feedback/index.d.ts +8 -0
  284. package/dist/design-system/feedback/index.d.ts.map +1 -0
  285. package/dist/design-system/feedback/index.js +12 -0
  286. package/dist/design-system/feedback/index.js.map +1 -0
  287. package/dist/design-system/feedback/progress-bar.d.ts +93 -0
  288. package/dist/design-system/feedback/progress-bar.d.ts.map +1 -0
  289. package/dist/design-system/feedback/progress-bar.js +440 -0
  290. package/dist/design-system/feedback/progress-bar.js.map +1 -0
  291. package/dist/design-system/feedback/spinner.d.ts +88 -0
  292. package/dist/design-system/feedback/spinner.d.ts.map +1 -0
  293. package/dist/design-system/feedback/spinner.js +679 -0
  294. package/dist/design-system/feedback/spinner.js.map +1 -0
  295. package/dist/design-system/feedback/timer.d.ts +175 -0
  296. package/dist/design-system/feedback/timer.d.ts.map +1 -0
  297. package/dist/design-system/feedback/timer.js +352 -0
  298. package/dist/design-system/feedback/timer.js.map +1 -0
  299. package/dist/design-system/forms/autocomplete.d.ts +163 -0
  300. package/dist/design-system/forms/autocomplete.d.ts.map +1 -0
  301. package/dist/design-system/forms/autocomplete.js +455 -0
  302. package/dist/design-system/forms/autocomplete.js.map +1 -0
  303. package/dist/design-system/forms/button.d.ts +106 -0
  304. package/dist/design-system/forms/button.d.ts.map +1 -0
  305. package/dist/design-system/forms/button.js +170 -0
  306. package/dist/design-system/forms/button.js.map +1 -0
  307. package/dist/design-system/forms/index.d.ts +12 -0
  308. package/dist/design-system/forms/index.d.ts.map +1 -0
  309. package/dist/design-system/forms/index.js +20 -0
  310. package/dist/design-system/forms/index.js.map +1 -0
  311. package/dist/design-system/forms/multi-select.d.ts +102 -0
  312. package/dist/design-system/forms/multi-select.d.ts.map +1 -0
  313. package/dist/design-system/forms/multi-select.js +309 -0
  314. package/dist/design-system/forms/multi-select.js.map +1 -0
  315. package/dist/design-system/forms/radio-group.d.ts +88 -0
  316. package/dist/design-system/forms/radio-group.d.ts.map +1 -0
  317. package/dist/design-system/forms/radio-group.js +145 -0
  318. package/dist/design-system/forms/radio-group.js.map +1 -0
  319. package/dist/design-system/forms/select.d.ts +116 -0
  320. package/dist/design-system/forms/select.d.ts.map +1 -0
  321. package/dist/design-system/forms/select.js +441 -0
  322. package/dist/design-system/forms/select.js.map +1 -0
  323. package/dist/design-system/forms/slider.d.ts +134 -0
  324. package/dist/design-system/forms/slider.d.ts.map +1 -0
  325. package/dist/design-system/forms/slider.js +314 -0
  326. package/dist/design-system/forms/slider.js.map +1 -0
  327. package/dist/design-system/forms/switch.d.ts +99 -0
  328. package/dist/design-system/forms/switch.d.ts.map +1 -0
  329. package/dist/design-system/forms/switch.js +173 -0
  330. package/dist/design-system/forms/switch.js.map +1 -0
  331. package/dist/design-system/forms/text-input.d.ts +79 -0
  332. package/dist/design-system/forms/text-input.d.ts.map +1 -0
  333. package/dist/design-system/forms/text-input.js +344 -0
  334. package/dist/design-system/forms/text-input.js.map +1 -0
  335. package/dist/design-system/index.d.ts +23 -0
  336. package/dist/design-system/index.d.ts.map +1 -0
  337. package/dist/design-system/index.js +74 -0
  338. package/dist/design-system/index.js.map +1 -0
  339. package/dist/design-system/layout/app.d.ts +205 -0
  340. package/dist/design-system/layout/app.d.ts.map +1 -0
  341. package/dist/design-system/layout/app.js +286 -0
  342. package/dist/design-system/layout/app.js.map +1 -0
  343. package/dist/design-system/layout/collapsible.d.ts +166 -0
  344. package/dist/design-system/layout/collapsible.d.ts.map +1 -0
  345. package/dist/design-system/layout/collapsible.js +286 -0
  346. package/dist/design-system/layout/collapsible.js.map +1 -0
  347. package/dist/design-system/layout/grid.d.ts +232 -0
  348. package/dist/design-system/layout/grid.d.ts.map +1 -0
  349. package/dist/design-system/layout/grid.js +333 -0
  350. package/dist/design-system/layout/grid.js.map +1 -0
  351. package/dist/design-system/layout/index.d.ts +27 -0
  352. package/dist/design-system/layout/index.d.ts.map +1 -0
  353. package/dist/design-system/layout/index.js +34 -0
  354. package/dist/design-system/layout/index.js.map +1 -0
  355. package/dist/design-system/layout/scroll-area.d.ts +188 -0
  356. package/dist/design-system/layout/scroll-area.d.ts.map +1 -0
  357. package/dist/design-system/layout/scroll-area.js +348 -0
  358. package/dist/design-system/layout/scroll-area.js.map +1 -0
  359. package/dist/design-system/layout/split-panel.d.ts +183 -0
  360. package/dist/design-system/layout/split-panel.d.ts.map +1 -0
  361. package/dist/design-system/layout/split-panel.js +323 -0
  362. package/dist/design-system/layout/split-panel.js.map +1 -0
  363. package/dist/design-system/layout/stack.d.ts +189 -0
  364. package/dist/design-system/layout/stack.d.ts.map +1 -0
  365. package/dist/design-system/layout/stack.js +170 -0
  366. package/dist/design-system/layout/stack.js.map +1 -0
  367. package/dist/design-system/layout/tabs.d.ts +129 -0
  368. package/dist/design-system/layout/tabs.d.ts.map +1 -0
  369. package/dist/design-system/layout/tabs.js +373 -0
  370. package/dist/design-system/layout/tabs.js.map +1 -0
  371. package/dist/design-system/media/index.d.ts +13 -0
  372. package/dist/design-system/media/index.d.ts.map +1 -0
  373. package/dist/design-system/media/index.js +23 -0
  374. package/dist/design-system/media/index.js.map +1 -0
  375. package/dist/design-system/media/picture.d.ts +304 -0
  376. package/dist/design-system/media/picture.d.ts.map +1 -0
  377. package/dist/design-system/media/picture.js +681 -0
  378. package/dist/design-system/media/picture.js.map +1 -0
  379. package/dist/design-system/navigation/file-manager.d.ts +492 -0
  380. package/dist/design-system/navigation/file-manager.d.ts.map +1 -0
  381. package/dist/design-system/navigation/file-manager.js +807 -0
  382. package/dist/design-system/navigation/file-manager.js.map +1 -0
  383. package/dist/design-system/navigation/index.d.ts +13 -0
  384. package/dist/design-system/navigation/index.d.ts.map +1 -0
  385. package/dist/design-system/navigation/index.js +19 -0
  386. package/dist/design-system/navigation/index.js.map +1 -0
  387. package/dist/design-system/overlays/command-palette.d.ts +217 -0
  388. package/dist/design-system/overlays/command-palette.d.ts.map +1 -0
  389. package/dist/design-system/overlays/command-palette.js +443 -0
  390. package/dist/design-system/overlays/command-palette.js.map +1 -0
  391. package/dist/design-system/overlays/index.d.ts +7 -0
  392. package/dist/design-system/overlays/index.d.ts.map +1 -0
  393. package/dist/design-system/overlays/index.js +10 -0
  394. package/dist/design-system/overlays/index.js.map +1 -0
  395. package/dist/design-system/overlays/modal.d.ts +251 -0
  396. package/dist/design-system/overlays/modal.d.ts.map +1 -0
  397. package/dist/design-system/overlays/modal.js +461 -0
  398. package/dist/design-system/overlays/modal.js.map +1 -0
  399. package/dist/design-system/overlays/overlay-stack.d.ts +200 -0
  400. package/dist/design-system/overlays/overlay-stack.d.ts.map +1 -0
  401. package/dist/design-system/overlays/overlay-stack.js +341 -0
  402. package/dist/design-system/overlays/overlay-stack.js.map +1 -0
  403. package/dist/design-system/primitives/box.d.ts +16 -0
  404. package/dist/design-system/primitives/box.d.ts.map +1 -0
  405. package/dist/design-system/primitives/box.js +23 -0
  406. package/dist/design-system/primitives/box.js.map +1 -0
  407. package/dist/design-system/primitives/divider.d.ts +52 -0
  408. package/dist/design-system/primitives/divider.d.ts.map +1 -0
  409. package/dist/design-system/primitives/divider.js +72 -0
  410. package/dist/design-system/primitives/divider.js.map +1 -0
  411. package/dist/design-system/primitives/helpers.d.ts +10 -0
  412. package/dist/design-system/primitives/helpers.d.ts.map +1 -0
  413. package/dist/design-system/primitives/helpers.js +27 -0
  414. package/dist/design-system/primitives/helpers.js.map +1 -0
  415. package/dist/design-system/primitives/index.d.ts +11 -0
  416. package/dist/design-system/primitives/index.d.ts.map +1 -0
  417. package/dist/design-system/primitives/index.js +14 -0
  418. package/dist/design-system/primitives/index.js.map +1 -0
  419. package/dist/design-system/primitives/slot.d.ts +35 -0
  420. package/dist/design-system/primitives/slot.d.ts.map +1 -0
  421. package/dist/design-system/primitives/slot.js +17 -0
  422. package/dist/design-system/primitives/slot.js.map +1 -0
  423. package/dist/design-system/primitives/spacer.d.ts +34 -0
  424. package/dist/design-system/primitives/spacer.d.ts.map +1 -0
  425. package/dist/design-system/primitives/spacer.js +53 -0
  426. package/dist/design-system/primitives/spacer.js.map +1 -0
  427. package/dist/design-system/primitives/text.d.ts +12 -0
  428. package/dist/design-system/primitives/text.d.ts.map +1 -0
  429. package/dist/design-system/primitives/text.js +25 -0
  430. package/dist/design-system/primitives/text.js.map +1 -0
  431. package/dist/design-system/primitives/utilities.d.ts +70 -0
  432. package/dist/design-system/primitives/utilities.d.ts.map +1 -0
  433. package/dist/design-system/primitives/utilities.js +56 -0
  434. package/dist/design-system/primitives/utilities.js.map +1 -0
  435. package/dist/design-system/visual/big-text.d.ts +151 -0
  436. package/dist/design-system/visual/big-text.d.ts.map +1 -0
  437. package/dist/design-system/visual/big-text.js +578 -0
  438. package/dist/design-system/visual/big-text.js.map +1 -0
  439. package/dist/design-system/visual/digits.d.ts +159 -0
  440. package/dist/design-system/visual/digits.d.ts.map +1 -0
  441. package/dist/design-system/visual/digits.js +287 -0
  442. package/dist/design-system/visual/digits.js.map +1 -0
  443. package/dist/design-system/visual/index.d.ts +20 -0
  444. package/dist/design-system/visual/index.d.ts.map +1 -0
  445. package/dist/design-system/visual/index.js +23 -0
  446. package/dist/design-system/visual/index.js.map +1 -0
  447. package/dist/design-system/visual/splash-screen.d.ts +93 -0
  448. package/dist/design-system/visual/splash-screen.d.ts.map +1 -0
  449. package/dist/design-system/visual/splash-screen.js +219 -0
  450. package/dist/design-system/visual/splash-screen.js.map +1 -0
  451. package/dist/design-system/visual/tooltip.d.ts +188 -0
  452. package/dist/design-system/visual/tooltip.d.ts.map +1 -0
  453. package/dist/design-system/visual/tooltip.js +276 -0
  454. package/dist/design-system/visual/tooltip.js.map +1 -0
  455. package/dist/dev-tools/debugger.d.ts +223 -0
  456. package/dist/dev-tools/debugger.d.ts.map +1 -0
  457. package/dist/dev-tools/debugger.js +489 -0
  458. package/dist/dev-tools/debugger.js.map +1 -0
  459. package/dist/dev-tools/index.d.ts +22 -0
  460. package/dist/dev-tools/index.d.ts.map +1 -0
  461. package/dist/dev-tools/index.js +63 -0
  462. package/dist/dev-tools/index.js.map +1 -0
  463. package/dist/dev-tools/mouse-simulator.d.ts +155 -0
  464. package/dist/dev-tools/mouse-simulator.d.ts.map +1 -0
  465. package/dist/dev-tools/mouse-simulator.js +314 -0
  466. package/dist/dev-tools/mouse-simulator.js.map +1 -0
  467. package/dist/dev-tools/testing.d.ts +262 -0
  468. package/dist/dev-tools/testing.d.ts.map +1 -0
  469. package/dist/dev-tools/testing.js +858 -0
  470. package/dist/dev-tools/testing.js.map +1 -0
  471. package/dist/hooks/context.d.ts +47 -0
  472. package/dist/hooks/context.d.ts.map +1 -0
  473. package/dist/hooks/context.js +108 -0
  474. package/dist/hooks/context.js.map +1 -0
  475. package/dist/hooks/focus-context.d.ts +65 -0
  476. package/dist/hooks/focus-context.d.ts.map +1 -0
  477. package/dist/hooks/focus-context.js +79 -0
  478. package/dist/hooks/focus-context.js.map +1 -0
  479. package/dist/hooks/index.d.ts +16 -0
  480. package/dist/hooks/index.d.ts.map +1 -0
  481. package/dist/hooks/index.js +22 -0
  482. package/dist/hooks/index.js.map +1 -0
  483. package/dist/hooks/types.d.ts +76 -0
  484. package/dist/hooks/types.d.ts.map +1 -0
  485. package/dist/hooks/types.js +5 -0
  486. package/dist/hooks/types.js.map +1 -0
  487. package/dist/hooks/use-app.d.ts +27 -0
  488. package/dist/hooks/use-app.d.ts.map +1 -0
  489. package/dist/hooks/use-app.js +179 -0
  490. package/dist/hooks/use-app.js.map +1 -0
  491. package/dist/hooks/use-effect.d.ts +20 -0
  492. package/dist/hooks/use-effect.d.ts.map +1 -0
  493. package/dist/hooks/use-effect.js +55 -0
  494. package/dist/hooks/use-effect.js.map +1 -0
  495. package/dist/hooks/use-focus.d.ts +48 -0
  496. package/dist/hooks/use-focus.d.ts.map +1 -0
  497. package/dist/hooks/use-focus.js +152 -0
  498. package/dist/hooks/use-focus.js.map +1 -0
  499. package/dist/hooks/use-input.d.ts +35 -0
  500. package/dist/hooks/use-input.d.ts.map +1 -0
  501. package/dist/hooks/use-input.js +352 -0
  502. package/dist/hooks/use-input.js.map +1 -0
  503. package/dist/hooks/use-mouse.d.ts +82 -0
  504. package/dist/hooks/use-mouse.d.ts.map +1 -0
  505. package/dist/hooks/use-mouse.js +328 -0
  506. package/dist/hooks/use-mouse.js.map +1 -0
  507. package/dist/hooks/use-navigation.d.ts +206 -0
  508. package/dist/hooks/use-navigation.d.ts.map +1 -0
  509. package/dist/hooks/use-navigation.js +319 -0
  510. package/dist/hooks/use-navigation.js.map +1 -0
  511. package/dist/hooks/use-state.d.ts +15 -0
  512. package/dist/hooks/use-state.d.ts.map +1 -0
  513. package/dist/hooks/use-state.js +29 -0
  514. package/dist/hooks/use-state.js.map +1 -0
  515. package/dist/hooks/use-terminal-size.d.ts +12 -0
  516. package/dist/hooks/use-terminal-size.d.ts.map +1 -0
  517. package/dist/hooks/use-terminal-size.js +20 -0
  518. package/dist/hooks/use-terminal-size.js.map +1 -0
  519. package/dist/index.d.ts +85 -0
  520. package/dist/index.d.ts.map +1 -0
  521. package/dist/index.js +334 -0
  522. package/dist/index.js.map +1 -0
  523. package/dist/molecules/autocomplete.d.ts +166 -0
  524. package/dist/molecules/autocomplete.d.ts.map +1 -0
  525. package/dist/molecules/autocomplete.js +458 -0
  526. package/dist/molecules/autocomplete.js.map +1 -0
  527. package/dist/molecules/calendar.d.ts +144 -0
  528. package/dist/molecules/calendar.d.ts.map +1 -0
  529. package/dist/molecules/calendar.js +527 -0
  530. package/dist/molecules/calendar.js.map +1 -0
  531. package/dist/molecules/code-block.d.ts +88 -0
  532. package/dist/molecules/code-block.d.ts.map +1 -0
  533. package/dist/molecules/code-block.js +324 -0
  534. package/dist/molecules/code-block.js.map +1 -0
  535. package/dist/molecules/collapsible.d.ts +169 -0
  536. package/dist/molecules/collapsible.d.ts.map +1 -0
  537. package/dist/molecules/collapsible.js +289 -0
  538. package/dist/molecules/collapsible.js.map +1 -0
  539. package/dist/molecules/data-viz/bar-chart.d.ts +167 -0
  540. package/dist/molecules/data-viz/bar-chart.d.ts.map +1 -0
  541. package/dist/molecules/data-viz/bar-chart.js +375 -0
  542. package/dist/molecules/data-viz/bar-chart.js.map +1 -0
  543. package/dist/molecules/data-viz/gauge.d.ts +163 -0
  544. package/dist/molecules/data-viz/gauge.d.ts.map +1 -0
  545. package/dist/molecules/data-viz/gauge.js +451 -0
  546. package/dist/molecules/data-viz/gauge.js.map +1 -0
  547. package/dist/molecules/data-viz/heatmap.d.ts +154 -0
  548. package/dist/molecules/data-viz/heatmap.d.ts.map +1 -0
  549. package/dist/molecules/data-viz/heatmap.js +458 -0
  550. package/dist/molecules/data-viz/heatmap.js.map +1 -0
  551. package/dist/molecules/data-viz/index.d.ts +16 -0
  552. package/dist/molecules/data-viz/index.d.ts.map +1 -0
  553. package/dist/molecules/data-viz/index.js +16 -0
  554. package/dist/molecules/data-viz/index.js.map +1 -0
  555. package/dist/molecules/data-viz/line-chart.d.ts +157 -0
  556. package/dist/molecules/data-viz/line-chart.d.ts.map +1 -0
  557. package/dist/molecules/data-viz/line-chart.js +578 -0
  558. package/dist/molecules/data-viz/line-chart.js.map +1 -0
  559. package/dist/molecules/data-viz/sparkline.d.ts +156 -0
  560. package/dist/molecules/data-viz/sparkline.d.ts.map +1 -0
  561. package/dist/molecules/data-viz/sparkline.js +325 -0
  562. package/dist/molecules/data-viz/sparkline.js.map +1 -0
  563. package/dist/molecules/index.d.ts +22 -0
  564. package/dist/molecules/index.d.ts.map +1 -0
  565. package/dist/molecules/index.js +26 -0
  566. package/dist/molecules/index.js.map +1 -0
  567. package/dist/molecules/markdown.d.ts +61 -0
  568. package/dist/molecules/markdown.d.ts.map +1 -0
  569. package/dist/molecules/markdown.js +350 -0
  570. package/dist/molecules/markdown.js.map +1 -0
  571. package/dist/molecules/multi-select.d.ts +105 -0
  572. package/dist/molecules/multi-select.d.ts.map +1 -0
  573. package/dist/molecules/multi-select.js +312 -0
  574. package/dist/molecules/multi-select.js.map +1 -0
  575. package/dist/molecules/radio-group.d.ts +91 -0
  576. package/dist/molecules/radio-group.d.ts.map +1 -0
  577. package/dist/molecules/radio-group.js +148 -0
  578. package/dist/molecules/radio-group.js.map +1 -0
  579. package/dist/molecules/select.d.ts +119 -0
  580. package/dist/molecules/select.d.ts.map +1 -0
  581. package/dist/molecules/select.js +444 -0
  582. package/dist/molecules/select.js.map +1 -0
  583. package/dist/molecules/table.d.ts +106 -0
  584. package/dist/molecules/table.d.ts.map +1 -0
  585. package/dist/molecules/table.js +345 -0
  586. package/dist/molecules/table.js.map +1 -0
  587. package/dist/molecules/tabs.d.ts +132 -0
  588. package/dist/molecules/tabs.d.ts.map +1 -0
  589. package/dist/molecules/tabs.js +376 -0
  590. package/dist/molecules/tabs.js.map +1 -0
  591. package/dist/molecules/tree.d.ts +169 -0
  592. package/dist/molecules/tree.d.ts.map +1 -0
  593. package/dist/molecules/tree.js +431 -0
  594. package/dist/molecules/tree.js.map +1 -0
  595. package/dist/organisms/command-palette.d.ts +217 -0
  596. package/dist/organisms/command-palette.d.ts.map +1 -0
  597. package/dist/organisms/command-palette.js +443 -0
  598. package/dist/organisms/command-palette.js.map +1 -0
  599. package/dist/organisms/data-table.d.ts +173 -0
  600. package/dist/organisms/data-table.d.ts.map +1 -0
  601. package/dist/organisms/data-table.js +428 -0
  602. package/dist/organisms/data-table.js.map +1 -0
  603. package/dist/organisms/file-browser.d.ts +492 -0
  604. package/dist/organisms/file-browser.d.ts.map +1 -0
  605. package/dist/organisms/file-browser.js +807 -0
  606. package/dist/organisms/file-browser.js.map +1 -0
  607. package/dist/organisms/grid.d.ts +234 -0
  608. package/dist/organisms/grid.d.ts.map +1 -0
  609. package/dist/organisms/grid.js +719 -0
  610. package/dist/organisms/grid.js.map +1 -0
  611. package/dist/organisms/index.d.ts +30 -0
  612. package/dist/organisms/index.d.ts.map +1 -0
  613. package/dist/organisms/index.js +92 -0
  614. package/dist/organisms/index.js.map +1 -0
  615. package/dist/organisms/modal.d.ts +251 -0
  616. package/dist/organisms/modal.d.ts.map +1 -0
  617. package/dist/organisms/modal.js +461 -0
  618. package/dist/organisms/modal.js.map +1 -0
  619. package/dist/organisms/overlay-stack.d.ts +200 -0
  620. package/dist/organisms/overlay-stack.d.ts.map +1 -0
  621. package/dist/organisms/overlay-stack.js +341 -0
  622. package/dist/organisms/overlay-stack.js.map +1 -0
  623. package/dist/organisms/scroll-area.d.ts +188 -0
  624. package/dist/organisms/scroll-area.d.ts.map +1 -0
  625. package/dist/organisms/scroll-area.js +348 -0
  626. package/dist/organisms/scroll-area.js.map +1 -0
  627. package/dist/organisms/split-panel.d.ts +183 -0
  628. package/dist/organisms/split-panel.d.ts.map +1 -0
  629. package/dist/organisms/split-panel.js +323 -0
  630. package/dist/organisms/split-panel.js.map +1 -0
  631. package/dist/primitives/canvas.d.ts +322 -0
  632. package/dist/primitives/canvas.d.ts.map +1 -0
  633. package/dist/primitives/canvas.js +833 -0
  634. package/dist/primitives/canvas.js.map +1 -0
  635. package/dist/primitives/context.d.ts +83 -0
  636. package/dist/primitives/context.d.ts.map +1 -0
  637. package/dist/primitives/context.js +101 -0
  638. package/dist/primitives/context.js.map +1 -0
  639. package/dist/primitives/divider.d.ts +52 -0
  640. package/dist/primitives/divider.d.ts.map +1 -0
  641. package/dist/primitives/divider.js +71 -0
  642. package/dist/primitives/divider.js.map +1 -0
  643. package/dist/primitives/index.d.ts +10 -0
  644. package/dist/primitives/index.d.ts.map +1 -0
  645. package/dist/primitives/index.js +10 -0
  646. package/dist/primitives/index.js.map +1 -0
  647. package/dist/primitives/nodes.d.ts +152 -0
  648. package/dist/primitives/nodes.d.ts.map +1 -0
  649. package/dist/primitives/nodes.js +164 -0
  650. package/dist/primitives/nodes.js.map +1 -0
  651. package/dist/primitives/signal.d.ts +136 -0
  652. package/dist/primitives/signal.d.ts.map +1 -0
  653. package/dist/primitives/signal.js +338 -0
  654. package/dist/primitives/signal.js.map +1 -0
  655. package/dist/primitives/store.d.ts +86 -0
  656. package/dist/primitives/store.d.ts.map +1 -0
  657. package/dist/primitives/store.js +147 -0
  658. package/dist/primitives/store.js.map +1 -0
  659. package/dist/storybook/app.d.ts +16 -0
  660. package/dist/storybook/app.d.ts.map +1 -0
  661. package/dist/storybook/app.js +697 -0
  662. package/dist/storybook/app.js.map +1 -0
  663. package/dist/storybook/cli.d.ts +10 -0
  664. package/dist/storybook/cli.d.ts.map +1 -0
  665. package/dist/storybook/cli.js +14 -0
  666. package/dist/storybook/cli.js.map +1 -0
  667. package/dist/storybook/components/compare-view.d.ts +46 -0
  668. package/dist/storybook/components/compare-view.d.ts.map +1 -0
  669. package/dist/storybook/components/compare-view.js +235 -0
  670. package/dist/storybook/components/compare-view.js.map +1 -0
  671. package/dist/storybook/components/index.d.ts +7 -0
  672. package/dist/storybook/components/index.d.ts.map +1 -0
  673. package/dist/storybook/components/index.js +7 -0
  674. package/dist/storybook/components/index.js.map +1 -0
  675. package/dist/storybook/components/log-viewer.d.ts +9 -0
  676. package/dist/storybook/components/log-viewer.d.ts.map +1 -0
  677. package/dist/storybook/components/log-viewer.js +46 -0
  678. package/dist/storybook/components/log-viewer.js.map +1 -0
  679. package/dist/storybook/components/preview.d.ts +28 -0
  680. package/dist/storybook/components/preview.d.ts.map +1 -0
  681. package/dist/storybook/components/preview.js +248 -0
  682. package/dist/storybook/components/preview.js.map +1 -0
  683. package/dist/storybook/components/sidebar.d.ts +29 -0
  684. package/dist/storybook/components/sidebar.d.ts.map +1 -0
  685. package/dist/storybook/components/sidebar.js +176 -0
  686. package/dist/storybook/components/sidebar.js.map +1 -0
  687. package/dist/storybook/core/comparatives.d.ts +94 -0
  688. package/dist/storybook/core/comparatives.d.ts.map +1 -0
  689. package/dist/storybook/core/comparatives.js +301 -0
  690. package/dist/storybook/core/comparatives.js.map +1 -0
  691. package/dist/storybook/core/index.d.ts +8 -0
  692. package/dist/storybook/core/index.d.ts.map +1 -0
  693. package/dist/storybook/core/index.js +8 -0
  694. package/dist/storybook/core/index.js.map +1 -0
  695. package/dist/storybook/core/navigator.d.ts +64 -0
  696. package/dist/storybook/core/navigator.d.ts.map +1 -0
  697. package/dist/storybook/core/navigator.js +279 -0
  698. package/dist/storybook/core/navigator.js.map +1 -0
  699. package/dist/storybook/core/playground.d.ts +73 -0
  700. package/dist/storybook/core/playground.d.ts.map +1 -0
  701. package/dist/storybook/core/playground.js +338 -0
  702. package/dist/storybook/core/playground.js.map +1 -0
  703. package/dist/storybook/core/registry.d.ts +87 -0
  704. package/dist/storybook/core/registry.d.ts.map +1 -0
  705. package/dist/storybook/core/registry.js +222 -0
  706. package/dist/storybook/core/registry.js.map +1 -0
  707. package/dist/storybook/data/ascii-art.d.ts +18 -0
  708. package/dist/storybook/data/ascii-art.d.ts.map +1 -0
  709. package/dist/storybook/data/ascii-art.js +62 -0
  710. package/dist/storybook/data/ascii-art.js.map +1 -0
  711. package/dist/storybook/data/tuiuiu-bird-colored.d.ts +13 -0
  712. package/dist/storybook/data/tuiuiu-bird-colored.d.ts.map +1 -0
  713. package/dist/storybook/data/tuiuiu-bird-colored.js +12 -0
  714. package/dist/storybook/data/tuiuiu-bird-colored.js.map +1 -0
  715. package/dist/storybook/index.d.ts +33 -0
  716. package/dist/storybook/index.d.ts.map +1 -0
  717. package/dist/storybook/index.js +44 -0
  718. package/dist/storybook/index.js.map +1 -0
  719. package/dist/storybook/store.d.ts +39 -0
  720. package/dist/storybook/store.d.ts.map +1 -0
  721. package/dist/storybook/store.js +91 -0
  722. package/dist/storybook/store.js.map +1 -0
  723. package/dist/storybook/stories/apps/index.d.ts +24 -0
  724. package/dist/storybook/stories/apps/index.d.ts.map +1 -0
  725. package/dist/storybook/stories/apps/index.js +434 -0
  726. package/dist/storybook/stories/apps/index.js.map +1 -0
  727. package/dist/storybook/stories/atoms/index.d.ts +40 -0
  728. package/dist/storybook/stories/atoms/index.d.ts.map +1 -0
  729. package/dist/storybook/stories/atoms/index.js +462 -0
  730. package/dist/storybook/stories/atoms/index.js.map +1 -0
  731. package/dist/storybook/stories/index.d.ts +37 -0
  732. package/dist/storybook/stories/index.d.ts.map +1 -0
  733. package/dist/storybook/stories/index.js +56 -0
  734. package/dist/storybook/stories/index.js.map +1 -0
  735. package/dist/storybook/stories/molecules/index.d.ts +68 -0
  736. package/dist/storybook/stories/molecules/index.d.ts.map +1 -0
  737. package/dist/storybook/stories/molecules/index.js +587 -0
  738. package/dist/storybook/stories/molecules/index.js.map +1 -0
  739. package/dist/storybook/stories/organisms/index.d.ts +29 -0
  740. package/dist/storybook/stories/organisms/index.d.ts.map +1 -0
  741. package/dist/storybook/stories/organisms/index.js +677 -0
  742. package/dist/storybook/stories/organisms/index.js.map +1 -0
  743. package/dist/storybook/types.d.ts +40 -0
  744. package/dist/storybook/types.d.ts.map +1 -0
  745. package/dist/storybook/types.js +5 -0
  746. package/dist/storybook/types.js.map +1 -0
  747. package/dist/styling/index.d.ts +12 -0
  748. package/dist/styling/index.d.ts.map +1 -0
  749. package/dist/styling/index.js +24 -0
  750. package/dist/styling/index.js.map +1 -0
  751. package/dist/styling/parser.d.ts +217 -0
  752. package/dist/styling/parser.d.ts.map +1 -0
  753. package/dist/styling/parser.js +901 -0
  754. package/dist/styling/parser.js.map +1 -0
  755. package/dist/styling/resolver.d.ts +217 -0
  756. package/dist/styling/resolver.d.ts.map +1 -0
  757. package/dist/styling/resolver.js +628 -0
  758. package/dist/styling/resolver.js.map +1 -0
  759. package/dist/styling/tokenizer.d.ts +121 -0
  760. package/dist/styling/tokenizer.d.ts.map +1 -0
  761. package/dist/styling/tokenizer.js +553 -0
  762. package/dist/styling/tokenizer.js.map +1 -0
  763. package/dist/templates/app.d.ts +205 -0
  764. package/dist/templates/app.d.ts.map +1 -0
  765. package/dist/templates/app.js +286 -0
  766. package/dist/templates/app.js.map +1 -0
  767. package/dist/templates/index.d.ts +30 -0
  768. package/dist/templates/index.d.ts.map +1 -0
  769. package/dist/templates/index.js +40 -0
  770. package/dist/templates/index.js.map +1 -0
  771. package/dist/templates/stack.d.ts +189 -0
  772. package/dist/templates/stack.d.ts.map +1 -0
  773. package/dist/templates/stack.js +170 -0
  774. package/dist/templates/stack.js.map +1 -0
  775. package/dist/utils/batcher.d.ts +88 -0
  776. package/dist/utils/batcher.d.ts.map +1 -0
  777. package/dist/utils/batcher.js +172 -0
  778. package/dist/utils/batcher.js.map +1 -0
  779. package/dist/utils/cursor.d.ts +28 -0
  780. package/dist/utils/cursor.d.ts.map +1 -0
  781. package/dist/utils/cursor.js +86 -0
  782. package/dist/utils/cursor.js.map +1 -0
  783. package/dist/utils/fs-storage.d.ts +23 -0
  784. package/dist/utils/fs-storage.d.ts.map +1 -0
  785. package/dist/utils/fs-storage.js +34 -0
  786. package/dist/utils/fs-storage.js.map +1 -0
  787. package/dist/utils/index.d.ts +14 -0
  788. package/dist/utils/index.d.ts.map +1 -0
  789. package/dist/utils/index.js +15 -0
  790. package/dist/utils/index.js.map +1 -0
  791. package/dist/utils/log-update.d.ts +31 -0
  792. package/dist/utils/log-update.d.ts.map +1 -0
  793. package/dist/utils/log-update.js +147 -0
  794. package/dist/utils/log-update.js.map +1 -0
  795. package/dist/utils/text-utils.d.ts +151 -0
  796. package/dist/utils/text-utils.d.ts.map +1 -0
  797. package/dist/utils/text-utils.js +699 -0
  798. package/dist/utils/text-utils.js.map +1 -0
  799. package/dist/utils/types.d.ts +205 -0
  800. package/dist/utils/types.d.ts.map +1 -0
  801. package/dist/utils/types.js +430 -0
  802. package/dist/utils/types.js.map +1 -0
  803. package/package.json +142 -0
@@ -0,0 +1,587 @@
1
+ /**
2
+ * Molecules Stories
3
+ *
4
+ * Molecules are simple combinations of atoms that form functional units:
5
+ * - Utility components (When, Each, Fragment)
6
+ * - Form controls (TextInput, Checkbox, RadioGroup, Select)
7
+ * - ProgressBar: Task progress indicator
8
+ * - Alert: Status messages
9
+ * - Toast: Notification popups
10
+ * - Tabs: Tab navigation
11
+ * - Sparkline & Gauge: Simple data visualizations
12
+ */
13
+ import { Box, Text, When, Each, Fragment, Spacer } from '../../../primitives/nodes.js';
14
+ import { Divider } from '../../../primitives/divider.js';
15
+ import { TextInput, Checkbox, Select, RadioGroup } from '../../../design-system/forms/index.js';
16
+ import { story, defaultControls } from '../../core/registry.js';
17
+ // Chart helpers
18
+ const sparklineChars = ['โ–', 'โ–‚', 'โ–ƒ', 'โ–„', 'โ–…', 'โ–†', 'โ–‡', 'โ–ˆ'];
19
+ function textSparkline(data) {
20
+ if (data.length === 0)
21
+ return '';
22
+ const min = Math.min(...data);
23
+ const max = Math.max(...data);
24
+ const range = max - min || 1;
25
+ return data.map((v) => {
26
+ const idx = Math.floor(((v - min) / range) * 7);
27
+ return sparklineChars[idx];
28
+ }).join('');
29
+ }
30
+ function textProgressBar(value, max, width, filled = 'โ–ˆ', empty = 'โ–‘') {
31
+ const filledWidth = Math.round((value / max) * width);
32
+ return filled.repeat(filledWidth) + empty.repeat(width - filledWidth);
33
+ }
34
+ /**
35
+ * Utility components stories (When, Each, Fragment)
36
+ */
37
+ export const utilityStories = [
38
+ story('When - Conditional')
39
+ .category('Molecules')
40
+ .description('Conditional rendering with When')
41
+ .controls({
42
+ show: defaultControls.boolean('Show Content', true),
43
+ })
44
+ .render((props) => Box({ flexDirection: 'column' }, Text({}, 'Always visible'), When(props.show, Text({ color: 'green' }, 'Conditionally visible')), Text({}, 'Also always visible'))),
45
+ story('Each - List Rendering')
46
+ .category('Molecules')
47
+ .description('Render lists with Each')
48
+ .controls({
49
+ count: defaultControls.range('Item Count', 5, 1, 10),
50
+ })
51
+ .render((props) => Box({ flexDirection: 'column' }, Each(Array.from({ length: props.count }, (_, i) => `Item ${i + 1}`), (item, index) => Box({}, Text({ color: index % 2 === 0 ? 'cyan' : 'gray' }, `${index + 1}. ${item}`))))),
52
+ story('Fragment - Grouping')
53
+ .category('Molecules')
54
+ .description('Group elements without wrapper')
55
+ .render(() => Box({ flexDirection: 'column' }, Text({}, 'Before fragment'), Fragment(Text({ color: 'cyan' }, 'Inside fragment 1'), Text({ color: 'green' }, 'Inside fragment 2'), Text({ color: 'yellow' }, 'Inside fragment 3')), Text({}, 'After fragment'))),
56
+ ];
57
+ /**
58
+ * TextInput component stories
59
+ */
60
+ export const textInputStories = [
61
+ story('TextInput - Basic')
62
+ .category('Molecules')
63
+ .description('Basic text input field')
64
+ .controls({
65
+ initialValue: defaultControls.text('Initial Value', 'Hello, World!'),
66
+ placeholder: defaultControls.text('Placeholder', 'Enter text...'),
67
+ })
68
+ .render((props) => TextInput({
69
+ initialValue: props.initialValue,
70
+ placeholder: props.placeholder,
71
+ onChange: (val) => console.log('Input changed:', val),
72
+ onSubmit: (val) => console.log('Input submitted:', val),
73
+ })),
74
+ story('TextInput - Password')
75
+ .category('Molecules')
76
+ .description('Password input with masked characters')
77
+ .controls({
78
+ initialValue: defaultControls.text('Initial Value', 'secret'),
79
+ maskChar: defaultControls.text('Mask Char', '*'),
80
+ })
81
+ .render((props) => TextInput({
82
+ initialValue: props.initialValue,
83
+ password: true,
84
+ maskChar: props.maskChar,
85
+ onChange: (val) => console.log('Password changed:', val),
86
+ })),
87
+ story('TextInput - Multi-line')
88
+ .category('Molecules')
89
+ .description('Multi-line text input (Shift+Enter for newline)')
90
+ .controls({
91
+ initialValue: defaultControls.text('Initial Value', 'Line 1\nLine 2'),
92
+ })
93
+ .render((props) => TextInput({
94
+ initialValue: props.initialValue,
95
+ multiline: true,
96
+ onChange: (val) => console.log('Multi-line changed:', val),
97
+ })),
98
+ story('TextInput - With Label')
99
+ .category('Molecules')
100
+ .description('TextInput with label and full-width')
101
+ .controls({
102
+ label: defaultControls.text('Label', 'Username:'),
103
+ initialValue: defaultControls.text('Initial Value', 'john_doe'),
104
+ })
105
+ .render((props) => Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'cyan' }, props.label), TextInput({
106
+ initialValue: props.initialValue,
107
+ fullWidth: true,
108
+ onChange: (val) => console.log('Input changed:', val),
109
+ }))),
110
+ ];
111
+ /**
112
+ * Checkbox stories
113
+ */
114
+ export const checkboxStories = [
115
+ story('Checkbox - Basic')
116
+ .category('Molecules')
117
+ .description('Basic interactive checkbox')
118
+ .controls({
119
+ label: defaultControls.text('Label', 'Accept terms'),
120
+ })
121
+ .render((props) => Checkbox({
122
+ items: [{ label: props.label, value: 'accept', description: 'Click me!' }],
123
+ onChange: (val) => console.log('Checkbox changed:', val),
124
+ showCount: false,
125
+ searchable: false,
126
+ cursorIndicator: ' ', // Hide cursor for simple checkbox feel
127
+ })),
128
+ story('Checkbox - List')
129
+ .category('Molecules')
130
+ .description('Multiple checkboxes in a list')
131
+ .render(() => Checkbox({
132
+ items: [
133
+ { label: 'Option 1', value: '1' },
134
+ { label: 'Option 2', value: '2' },
135
+ { label: 'Option 3', value: '3', disabled: true },
136
+ { label: 'Option 4', value: '4' },
137
+ ],
138
+ initialValue: ['1', '3'],
139
+ onChange: (vals) => console.log('Selected:', vals),
140
+ showCount: true,
141
+ searchable: false,
142
+ })),
143
+ ];
144
+ /**
145
+ * RadioGroup stories
146
+ */
147
+ export const radioStories = [
148
+ story('RadioGroup - Basic')
149
+ .category('Molecules')
150
+ .description('Basic radio button group')
151
+ .render(() => RadioGroup({
152
+ options: [
153
+ { value: '1', label: 'Option 1' },
154
+ { value: '2', label: 'Option 2' },
155
+ { value: '3', label: 'Option 3' },
156
+ ],
157
+ initialValue: '1',
158
+ onChange: (val) => console.log('Radio changed:', val),
159
+ })),
160
+ story('RadioGroup - Horizontal')
161
+ .category('Molecules')
162
+ .description('Radio buttons in horizontal layout')
163
+ .render(() => RadioGroup({
164
+ direction: 'horizontal',
165
+ gap: 2,
166
+ options: [
167
+ { value: 'xs', label: 'XS' },
168
+ { value: 'sm', label: 'SM' },
169
+ { value: 'md', label: 'MD' },
170
+ { value: 'lg', label: 'LG' },
171
+ { value: 'xl', label: 'XL' },
172
+ ],
173
+ initialValue: 'md',
174
+ })),
175
+ ];
176
+ /**
177
+ * Select component stories
178
+ */
179
+ export const selectStories = [
180
+ story('Select - Basic')
181
+ .category('Molecules')
182
+ .description('Basic dropdown selection')
183
+ .render(() => Select({
184
+ items: [
185
+ { label: 'Option 1', value: '1' },
186
+ { label: 'Option 2', value: '2' },
187
+ { label: 'Option 3', value: '3' },
188
+ { label: 'Option 4', value: '4' },
189
+ ],
190
+ searchable: true,
191
+ })),
192
+ story('Select - With Categories')
193
+ .category('Molecules')
194
+ .description('Select with grouped options')
195
+ .render(() => Select({
196
+ items: [
197
+ { label: 'Apple', value: 'apple', group: 'Fruits' },
198
+ { label: 'Banana', value: 'banana', group: 'Fruits' },
199
+ { label: 'Carrot', value: 'carrot', group: 'Vegetables' },
200
+ { label: 'Broccoli', value: 'broccoli', group: 'Vegetables' },
201
+ ],
202
+ initialValue: 'apple',
203
+ })),
204
+ story('Select - Multi-Select')
205
+ .category('Molecules')
206
+ .description('Select multiple items')
207
+ .render(() => Select({
208
+ multiple: true,
209
+ items: [
210
+ { label: 'JavaScript', value: 'js' },
211
+ { label: 'TypeScript', value: 'ts' },
212
+ { label: 'Python', value: 'py' },
213
+ { label: 'Rust', value: 'rs' },
214
+ { label: 'Go', value: 'go' },
215
+ ],
216
+ initialValue: ['js', 'ts', 'go'],
217
+ })),
218
+ ];
219
+ /**
220
+ * ProgressBar stories
221
+ */
222
+ export const progressBarStories = [
223
+ story('ProgressBar - Basic')
224
+ .category('Molecules')
225
+ .description('Basic progress bar')
226
+ .controls({
227
+ value: defaultControls.range('Progress', 65, 0, 100),
228
+ width: defaultControls.range('Width', 30, 15, 50),
229
+ })
230
+ .render((props) => Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'cyan' }, textProgressBar(props.value, 100, props.width)), Text({ color: 'cyan' }, `${props.value}%`))),
231
+ story('ProgressBar - Colors')
232
+ .category('Molecules')
233
+ .description('Progress bar with custom colors')
234
+ .controls({
235
+ value: defaultControls.range('Progress', 75, 0, 100),
236
+ color: defaultControls.color('Color', 'green'),
237
+ })
238
+ .render((props) => Box({ flexDirection: 'row', gap: 1 }, Text({ color: props.color }, textProgressBar(props.value, 100, 30)), Text({ color: props.color }, `${props.value}%`))),
239
+ story('ProgressBar - With Label')
240
+ .category('Molecules')
241
+ .description('Progress bar with label')
242
+ .controls({
243
+ value: defaultControls.range('Progress', 42, 0, 100),
244
+ showLabel: defaultControls.boolean('Show Label', true),
245
+ })
246
+ .render((props) => Box({ flexDirection: 'column', gap: 1 }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'Progress:'), Text({ color: 'cyan' }, textProgressBar(props.value, 100, 25)), props.showLabel ? Text({ color: 'cyan' }, `${props.value}%`) : null))),
247
+ story('ProgressBar - Multiple')
248
+ .category('Molecules')
249
+ .description('Multiple progress bars')
250
+ .render(() => Box({ flexDirection: 'column', gap: 1 }, Box({ flexDirection: 'row', gap: 1 }, Box({ width: 12 }, Text({ color: 'gray' }, 'Downloading:')), Text({ color: 'blue' }, textProgressBar(75, 100, 20)), Text({ color: 'blue' }, '75%')), Box({ flexDirection: 'row', gap: 1 }, Box({ width: 12 }, Text({ color: 'gray' }, 'Installing:')), Text({ color: 'green' }, textProgressBar(45, 100, 20)), Text({ color: 'green' }, '45%')), Box({ flexDirection: 'row', gap: 1 }, Box({ width: 12 }, Text({ color: 'gray' }, 'Configuring:')), Text({ color: 'yellow' }, textProgressBar(10, 100, 20)), Text({ color: 'yellow' }, '10%')))),
251
+ story('ProgressBar - Indeterminate Styles')
252
+ .category('Molecules')
253
+ .description('Different indeterminate loading styles')
254
+ .controls({
255
+ style: defaultControls.select('Style', ['classic', 'marquee', 'fill-and-clear'], 'marquee'),
256
+ fillStep: defaultControls.range('Fill Step', 1, 1, 5),
257
+ width: defaultControls.range('Width', 30, 10, 50),
258
+ })
259
+ .animated(50)
260
+ .render((props, frame = 0) => {
261
+ // Simulate indeterminate animation logic for story preview
262
+ const { style, fillStep, width } = props;
263
+ let barContent = '';
264
+ const t = Math.floor(Date.now() / 50); // Use real time or frame for consistency
265
+ if (style === 'marquee') {
266
+ const blockWidth = Math.max(3, Math.floor(width * 0.25));
267
+ const totalWidth = width + blockWidth;
268
+ const pos = Math.floor(frame / 1.5) % totalWidth; // Slow down a bit
269
+ const start = Math.max(0, pos - blockWidth);
270
+ const end = Math.min(width, pos);
271
+ const length = Math.max(0, end - start);
272
+ const emptyLeft = Math.max(0, start);
273
+ const emptyRight = Math.max(0, width - end);
274
+ barContent = 'โ–‘'.repeat(emptyLeft) + 'โ–ˆ'.repeat(length) + 'โ–‘'.repeat(emptyRight);
275
+ }
276
+ else if (style === 'fill-and-clear') {
277
+ const totalSteps = Math.ceil(width / fillStep);
278
+ const rawCycle = Math.floor(frame) % ((totalSteps * 2) + 4);
279
+ const effectiveCycle = rawCycle * fillStep;
280
+ if (rawCycle < totalSteps) {
281
+ const filledLen = Math.min(width, effectiveCycle);
282
+ barContent = 'โ–ˆ'.repeat(filledLen) + 'โ–‘'.repeat(width - filledLen);
283
+ }
284
+ else {
285
+ const emptyLeftLen = Math.min(width, effectiveCycle - width);
286
+ const filledLen = Math.max(0, width - emptyLeftLen);
287
+ barContent = 'โ–‘'.repeat(emptyLeftLen) + 'โ–ˆ'.repeat(filledLen);
288
+ }
289
+ }
290
+ else {
291
+ // Classic
292
+ const frames = ['[ ]', '[= ]', '[== ]', '[=== ]', '[ ===]', '[ ==]', '[ =]', '[ ]'];
293
+ barContent = frames[frame % frames.length].padEnd(width, ' ');
294
+ }
295
+ return Box({ flexDirection: 'column', gap: 1 }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'cyan' }, barContent), Text({ color: 'gray' }, style)), style === 'fill-and-clear' ? Text({ color: 'gray', dim: true }, `Step: ${fillStep}`) : null);
296
+ }),
297
+ story('ProgressBar - Thresholds')
298
+ .category('Molecules')
299
+ .description('Progress bar with color thresholds')
300
+ .controls({
301
+ value: defaultControls.range('Value', 80, 0, 100),
302
+ })
303
+ .render((props) => {
304
+ const color = props.value > 80 ? 'red' : props.value > 60 ? 'yellow' : 'green';
305
+ const status = props.value > 80 ? 'Critical!' : props.value > 60 ? 'Warning' : 'Normal';
306
+ return Box({ flexDirection: 'column', gap: 1 }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'Memory:'), Text({ color }, textProgressBar(props.value, 100, 25)), Text({ color }, `${props.value}%`)), Text({ color, dim: true }, status));
307
+ }),
308
+ ];
309
+ /**
310
+ * Alert stories
311
+ */
312
+ export const alertStories = [
313
+ story('Alert - Info')
314
+ .category('Molecules')
315
+ .description('Information alert')
316
+ .controls({
317
+ message: defaultControls.text('Message', 'This is an informational message.'),
318
+ })
319
+ .render((props) => Box({
320
+ borderStyle: 'single',
321
+ borderColor: 'blue',
322
+ padding: 1,
323
+ width: 50,
324
+ }, Text({ color: 'blue' }, 'โ„น '), Text({ color: 'white' }, props.message))),
325
+ story('Alert - Success')
326
+ .category('Molecules')
327
+ .description('Success alert')
328
+ .render(() => Box({
329
+ borderStyle: 'round',
330
+ borderColor: 'green',
331
+ backgroundColor: 'green',
332
+ padding: 1,
333
+ width: 50,
334
+ }, Text({ color: 'white', bold: true }, 'โœ“ Operation completed successfully!'))),
335
+ story('Alert - Warning')
336
+ .category('Molecules')
337
+ .description('Warning alert')
338
+ .render(() => Box({
339
+ borderStyle: 'single',
340
+ borderColor: 'yellow',
341
+ padding: 1,
342
+ width: 50,
343
+ }, Box({ flexDirection: 'column' }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'yellow', bold: true }, 'โš  Warning')), Text({ color: 'yellow' }, 'This action may have unintended consequences.')))),
344
+ story('Alert - Error')
345
+ .category('Molecules')
346
+ .description('Error alert')
347
+ .render(() => Box({
348
+ borderStyle: 'bold',
349
+ borderColor: 'red',
350
+ padding: 1,
351
+ width: 50,
352
+ }, Box({ flexDirection: 'column' }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'red', bold: true }, 'โœ— Error')), Text({ color: 'red' }, 'Failed to complete the operation.'), Text({ color: 'gray', dim: true }, 'Error code: E_CONNECTION_TIMEOUT')))),
353
+ story('Alert - Dismissible')
354
+ .category('Molecules')
355
+ .description('Alert with dismiss action')
356
+ .render(() => Box({
357
+ borderStyle: 'single',
358
+ borderColor: 'cyan',
359
+ padding: 1,
360
+ width: 50,
361
+ }, Box({ flexDirection: 'row', justifyContent: 'space-between' }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'cyan' }, 'โ„น'), Text({ color: 'white' }, 'New updates available.')), Text({ color: 'gray' }, '[x]')))),
362
+ ];
363
+ /**
364
+ * Toast notification stories
365
+ */
366
+ export const toastStories = [
367
+ story('Toast - Stack')
368
+ .category('Molecules')
369
+ .description('Stack of toast notifications')
370
+ .render(() => Box({ flexDirection: 'column', gap: 1, alignItems: 'flex-end', width: 50 }, Box({
371
+ borderStyle: 'round',
372
+ borderColor: 'green',
373
+ paddingX: 2,
374
+ paddingY: 0,
375
+ }, Text({ color: 'green' }, 'โœ“ File saved successfully')), Box({
376
+ borderStyle: 'round',
377
+ borderColor: 'blue',
378
+ paddingX: 2,
379
+ paddingY: 0,
380
+ }, Text({ color: 'blue' }, 'โ„น 3 new messages')), Box({
381
+ borderStyle: 'round',
382
+ borderColor: 'yellow',
383
+ paddingX: 2,
384
+ paddingY: 0,
385
+ }, Text({ color: 'yellow' }, 'โš  Low disk space')))),
386
+ story('Toast - With Actions')
387
+ .category('Molecules')
388
+ .description('Toast with action buttons')
389
+ .render(() => Box({
390
+ borderStyle: 'single',
391
+ borderColor: 'cyan',
392
+ padding: 1,
393
+ width: 45,
394
+ }, Box({ flexDirection: 'column', gap: 1 }, Text({ color: 'white' }, 'New version available (v2.0.0)'), Box({ flexDirection: 'row', gap: 2 }, Text({ color: 'cyan', inverse: true }, ' Update '), Text({ color: 'gray' }, 'Dismiss'))))),
395
+ ];
396
+ /**
397
+ * Tabs stories
398
+ */
399
+ export const tabsStories = [
400
+ story('Tabs - Basic')
401
+ .category('Molecules')
402
+ .description('Basic tabbed interface')
403
+ .controls({
404
+ activeTab: defaultControls.range('Active Tab', 0, 0, 2),
405
+ })
406
+ .render((props) => {
407
+ const tabs = ['Overview', 'Details', 'Settings'];
408
+ return Box({ width: 50, flexDirection: 'column' }, Box({ flexDirection: 'row', borderStyle: 'single', borderColor: 'gray' }, ...tabs.map((tab, idx) => Box({
409
+ paddingX: 2,
410
+ backgroundColor: idx === props.activeTab ? 'blue' : undefined,
411
+ }, Text({
412
+ color: idx === props.activeTab ? 'white' : 'gray',
413
+ bold: idx === props.activeTab,
414
+ }, tab)))), Box({ borderStyle: 'single', borderColor: 'blue', padding: 1, height: 5 }, Text({}, `${tabs[props.activeTab]} content here...`)));
415
+ }),
416
+ story('Tabs - With Icons')
417
+ .category('Molecules')
418
+ .description('Tabs with icons')
419
+ .render(() => Box({ width: 50, flexDirection: 'column' }, Box({ flexDirection: 'row', borderStyle: 'single', borderColor: 'gray' }, Box({ paddingX: 2, backgroundColor: 'blue' }, Text({ color: 'white', bold: true }, '๐Ÿ  Home')), Box({ paddingX: 2 }, Text({ color: 'gray' }, '๐Ÿ“ Files')), Box({ paddingX: 2 }, Text({ color: 'gray' }, 'โš™๏ธ Settings'))), Box({ borderStyle: 'single', borderColor: 'blue', padding: 1, height: 5 }, Text({}, 'Home content')))),
420
+ story('Tabs - Styled')
421
+ .category('Molecules')
422
+ .description('Tabs with custom styling')
423
+ .controls({
424
+ activeColor: defaultControls.color('Active Color', 'cyan'),
425
+ })
426
+ .render((props) => Box({ width: 50, flexDirection: 'column' }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: props.activeColor, inverse: true }, ' Tab 1 '), Text({ color: 'gray' }, 'Tab 2'), Text({ color: 'gray' }, 'Tab 3')), Box({ borderStyle: 'single', borderColor: props.activeColor, padding: 1, marginTop: 1 }, Text({}, 'Content 1')))),
427
+ ];
428
+ /**
429
+ * Sparkline stories
430
+ */
431
+ export const sparklineStories = [
432
+ story('Sparkline - Basic')
433
+ .category('Molecules')
434
+ .description('Inline sparkline chart using block characters')
435
+ .render(() => {
436
+ const data = [5, 10, 8, 15, 12, 18, 14, 22, 19, 25];
437
+ return Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'Trend:'), Text({ color: 'cyan' }, textSparkline(data)));
438
+ }),
439
+ story('Sparkline - Colors')
440
+ .category('Molecules')
441
+ .description('Sparklines with different colors')
442
+ .controls({
443
+ color: defaultControls.color('Color', 'green'),
444
+ })
445
+ .render((props) => {
446
+ const data = [3, 7, 4, 9, 6, 8, 5, 10, 7, 12];
447
+ return Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'Data:'), Text({ color: props.color }, textSparkline(data)));
448
+ }),
449
+ story('Sparkline - Multiple')
450
+ .category('Molecules')
451
+ .description('Multiple sparklines for comparison')
452
+ .render(() => {
453
+ const revenue = [30, 45, 38, 52, 48, 55, 60, 58, 65, 70];
454
+ const costs = [25, 28, 32, 30, 35, 38, 40, 42, 45, 48];
455
+ const profit = [5, 17, 6, 22, 13, 17, 20, 16, 20, 22];
456
+ return Box({ flexDirection: 'column', gap: 1 }, Box({ flexDirection: 'row', gap: 1 }, Box({ width: 10 }, Text({ color: 'gray' }, 'Revenue:')), Text({ color: 'green' }, textSparkline(revenue))), Box({ flexDirection: 'row', gap: 1 }, Box({ width: 10 }, Text({ color: 'gray' }, 'Costs:')), Text({ color: 'red' }, textSparkline(costs))), Box({ flexDirection: 'row', gap: 1 }, Box({ width: 10 }, Text({ color: 'gray' }, 'Profit:')), Text({ color: 'cyan' }, textSparkline(profit))));
457
+ }),
458
+ ];
459
+ /**
460
+ * Gauge stories
461
+ */
462
+ export const gaugeStories = [
463
+ story('Gauge - Linear')
464
+ .category('Molecules')
465
+ .description('Linear gauge indicator')
466
+ .controls({
467
+ value: defaultControls.range('Value', 65, 0, 100),
468
+ })
469
+ .render((props) => Box({ flexDirection: 'column', gap: 1 }, Text({ color: 'gray' }, 'Progress'), Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'cyan' }, textProgressBar(props.value, 100, 30)), Text({ color: 'cyan' }, `${props.value}%`)))),
470
+ story('Gauge - Thresholds')
471
+ .category('Molecules')
472
+ .description('Gauge with color thresholds')
473
+ .controls({
474
+ value: defaultControls.range('Value', 80, 0, 100),
475
+ })
476
+ .render((props) => {
477
+ const color = props.value > 80 ? 'red' :
478
+ props.value > 60 ? 'yellow' :
479
+ 'green';
480
+ const status = props.value > 80 ? 'Critical!' :
481
+ props.value > 60 ? 'Warning' :
482
+ 'Normal';
483
+ return Box({ flexDirection: 'column', gap: 1 }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'Memory:'), Text({ color }, textProgressBar(props.value, 100, 25)), Text({ color }, `${props.value}%`)), Text({ color, dim: true }, status));
484
+ }),
485
+ story('Gauge - Dashboard')
486
+ .category('Molecules')
487
+ .description('Multiple gauges dashboard style')
488
+ .render(() => Box({ flexDirection: 'column', gap: 1 }, Box({ flexDirection: 'row', gap: 1 }, Box({ width: 8 }, Text({ color: 'gray' }, 'CPU:')), Text({ color: 'green' }, textProgressBar(45, 100, 20)), Text({ color: 'green' }, ' 45%')), Box({ flexDirection: 'row', gap: 1 }, Box({ width: 8 }, Text({ color: 'gray' }, 'Memory:')), Text({ color: 'yellow' }, textProgressBar(72, 100, 20)), Text({ color: 'yellow' }, ' 72%')), Box({ flexDirection: 'row', gap: 1 }, Box({ width: 8 }, Text({ color: 'gray' }, 'Disk:')), Text({ color: 'cyan' }, textProgressBar(28, 100, 20)), Text({ color: 'cyan' }, ' 28%')))),
489
+ ];
490
+ /**
491
+ * Mouse interaction stories
492
+ * Demonstrates useMouse hook capabilities for terminal mouse input
493
+ */
494
+ export const mouseStories = [
495
+ story('Mouse - Basic Click')
496
+ .category('Molecules')
497
+ .description('Detect mouse clicks with position')
498
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'round', borderColor: 'cyan' }, Text({ bold: true, color: 'cyan' }, '๐Ÿ–ฑ๏ธ Mouse Click Detection'), Divider({}), Text({ color: 'gray' }, 'Click anywhere in the terminal to see:'), Spacer({ size: 1 }), Box({ flexDirection: 'column', gap: 0 }, Text({}, ' Position: x=12, y=5'), Text({}, ' Button: left'), Text({}, ' Action: click')), Spacer({ size: 1 }), Text({ color: 'gray', dim: true }, 'useMouse((event) => { ... })'))),
499
+ story('Mouse - All Buttons')
500
+ .category('Molecules')
501
+ .description('Detect left, right, and middle clicks')
502
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'single' }, Text({ bold: true }, 'Mouse Button Detection'), Divider({}), Box({ flexDirection: 'row', gap: 2 }, Box({ flexDirection: 'column', padding: 1, borderStyle: 'round', borderColor: 'green' }, Text({ color: 'green', bold: true }, ' LEFT '), Text({ color: 'gray', dim: true }, 'Clicks: 3')), Box({ flexDirection: 'column', padding: 1, borderStyle: 'round', borderColor: 'yellow' }, Text({ color: 'yellow', bold: true }, ' MIDDLE '), Text({ color: 'gray', dim: true }, 'Clicks: 1')), Box({ flexDirection: 'column', padding: 1, borderStyle: 'round', borderColor: 'red' }, Text({ color: 'red', bold: true }, ' RIGHT '), Text({ color: 'gray', dim: true }, 'Clicks: 0'))), Text({ color: 'gray', dim: true }, "event.button === 'left' | 'middle' | 'right'"))),
503
+ story('Mouse - Position Tracker')
504
+ .category('Molecules')
505
+ .description('Real-time mouse position tracking')
506
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'double', borderColor: 'magenta' }, Text({ bold: true, color: 'magenta' }, '๐Ÿ“ Mouse Position Tracker'), Divider({}), Box({ flexDirection: 'row', gap: 4 }, Box({ flexDirection: 'column' }, Text({ color: 'gray' }, 'X Position'), Text({ color: 'cyan', bold: true }, ' 24 ')), Box({ flexDirection: 'column' }, Text({ color: 'gray' }, 'Y Position'), Text({ color: 'cyan', bold: true }, ' 12 '))), Spacer({ size: 1 }), Box({ flexDirection: 'column', backgroundColor: 'gray' }, Text({ color: 'white' }, ' '), Text({ color: 'white' }, ' Move mouse here... '), Text({ color: 'white' }, ' โ— '), Text({ color: 'white' }, ' ')), Text({ color: 'gray', dim: true }, "action === 'move' for tracking"))),
507
+ story('Mouse - Double Click')
508
+ .category('Molecules')
509
+ .description('Detect double-click events')
510
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'round', borderColor: 'yellow' }, Text({ bold: true, color: 'yellow' }, 'โšก Double Click Detection'), Divider({}), Box({ padding: 2, borderStyle: 'single', borderColor: 'cyan' }, Text({ color: 'cyan' }, ' Double-click this area ')), Spacer({ size: 1 }), Text({}, 'Last action: double-click'), Text({ color: 'green' }, 'โœ“ Double-click detected!'), Spacer({ size: 1 }), Text({ color: 'gray', dim: true }, "event.action === 'double-click'"))),
511
+ story('Mouse - Drag Events')
512
+ .category('Molecules')
513
+ .description('Handle mouse drag operations')
514
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'round', borderColor: 'blue' }, Text({ bold: true, color: 'blue' }, 'โ†”๏ธ Drag Detection'), Divider({}), Text({ color: 'gray' }, 'Drag state: dragging'), Box({ flexDirection: 'row', gap: 1 }, Text({}, 'Start: (5, 10)'), Text({ color: 'gray' }, 'โ†’'), Text({}, 'Current: (25, 10)')), Spacer({ size: 1 }), Box({ flexDirection: 'column' }, Text({ color: 'gray' }, 'โ•”โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•—'), Text({ color: 'gray' }, 'โ•‘ โ•‘'), Text({ color: 'gray' }, 'โ•‘ โ—โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ—‹ โ•‘'), Text({ color: 'gray' }, 'โ•‘ โ•‘'), Text({ color: 'gray' }, 'โ•šโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•')), Text({ color: 'gray', dim: true }, "action === 'drag' | 'release'"))),
515
+ story('Mouse - Scroll Wheel')
516
+ .category('Molecules')
517
+ .description('Detect scroll up/down events')
518
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'single' }, Text({ bold: true }, '๐Ÿ”„ Scroll Wheel Events'), Divider({}), Box({ flexDirection: 'row', gap: 2 }, Box({ flexDirection: 'column', alignItems: 'center' }, Text({ color: 'green' }, 'โ–ฒ'), Text({ color: 'gray', dim: true }, 'scroll-up'), Text({ color: 'cyan' }, 'ร—5')), Box({ width: 1 }, Text({ color: 'gray' }, 'โ”‚')), Box({ flexDirection: 'column', alignItems: 'center' }, Text({ color: 'red' }, 'โ–ผ'), Text({ color: 'gray', dim: true }, 'scroll-down'), Text({ color: 'cyan' }, 'ร—12'))), Spacer({ size: 1 }), Text({}, 'Scroll position: 72'), Text({ color: 'gray', dim: true }, "button === 'scroll-up' | 'scroll-down'"))),
519
+ story('Mouse - With Modifiers')
520
+ .category('Molecules')
521
+ .description('Detect Ctrl, Shift, Alt + click')
522
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'round', borderColor: 'cyan' }, Text({ bold: true, color: 'cyan' }, 'โŒจ๏ธ Mouse + Modifiers'), Divider({}), Box({ flexDirection: 'column', gap: 0 }, Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'green' }, 'โœ“'), Text({}, 'Ctrl + Click'), Text({ color: 'gray', dim: true }, '- Open in new tab')), Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'โ—‹'), Text({}, 'Shift + Click'), Text({ color: 'gray', dim: true }, '- Select range')), Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'โ—‹'), Text({}, 'Alt + Click'), Text({ color: 'gray', dim: true }, '- Quick action')), Box({ flexDirection: 'row', gap: 1 }, Text({ color: 'gray' }, 'โ—‹'), Text({}, 'Ctrl + Shift + Click'), Text({ color: 'gray', dim: true }, '- Advanced mode'))), Spacer({ size: 1 }), Text({ color: 'gray', dim: true }, 'event.modifiers.ctrl | shift | alt'))),
523
+ story('Mouse - Click Hitbox')
524
+ .category('Molecules')
525
+ .description('Detect clicks on specific regions')
526
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'single' }, Text({ bold: true }, '๐ŸŽฏ Hitbox Detection'), Divider({}), Box({ flexDirection: 'row', gap: 1 }, Box({ padding: 1, borderStyle: 'round', borderColor: 'green', backgroundColor: 'green' }, Text({ color: 'white', bold: true }, ' Button 1 ')), Box({ padding: 1, borderStyle: 'round', borderColor: 'blue' }, Text({ color: 'blue' }, ' Button 2 ')), Box({ padding: 1, borderStyle: 'round', borderColor: 'red' }, Text({ color: 'red' }, ' Button 3 '))), Spacer({ size: 1 }), Text({}, 'Clicked: Button 1'), Text({ color: 'gray', dim: true }, 'Check x,y against element bounds'))),
527
+ story('Mouse - Interactive Canvas')
528
+ .category('Molecules')
529
+ .description('Draw with mouse clicks')
530
+ .render(() => {
531
+ // Simulated canvas with some "drawn" points
532
+ const canvasLines = [
533
+ 'โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”',
534
+ 'โ”‚ โ”‚',
535
+ 'โ”‚ โ— โ—โ—โ— โ”‚',
536
+ 'โ”‚ โ—โ—โ—โ—โ—โ—โ—โ— โ”‚',
537
+ 'โ”‚ โ—โ—โ—โ—โ—โ— โ—โ—โ— โ”‚',
538
+ 'โ”‚ โ—โ—โ— โ—โ—โ—โ—โ— โ”‚',
539
+ 'โ”‚ โ—โ—โ— โ”‚',
540
+ 'โ”‚ โ”‚',
541
+ 'โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜',
542
+ ];
543
+ return Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'round', borderColor: 'magenta' }, Text({ bold: true, color: 'magenta' }, '๐ŸŽจ Interactive Canvas'), Divider({}), Box({ flexDirection: 'row', gap: 2 }, Text({ color: isActive('pen') ? 'cyan' : 'gray' }, '[โœ๏ธ Pen]'), Text({ color: 'gray' }, '[๐Ÿงน Eraser]'), Text({ color: 'gray' }, '[โฌœ Clear]')), Spacer({ size: 1 }), Box({ flexDirection: 'column' }, ...canvasLines.map((line) => Text({ color: 'cyan' }, line))), Text({ color: 'gray', dim: true }, 'Click to draw, drag for lines'));
544
+ function isActive(tool) {
545
+ return tool === 'pen';
546
+ }
547
+ }),
548
+ story('Mouse - Event Log')
549
+ .category('Molecules')
550
+ .description('Log all mouse events')
551
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'single' }, Text({ bold: true }, '๐Ÿ“‹ Mouse Event Log'), Divider({}), Box({ flexDirection: 'column', height: 8, borderStyle: 'round', borderColor: 'gray', padding: 1 }, Text({ color: 'cyan' }, '[12:34:56] click left @ (24, 8)'), Text({ color: 'cyan' }, '[12:34:57] release @ (24, 8)'), Text({ color: 'yellow' }, '[12:34:58] scroll-down @ (24, 8)'), Text({ color: 'green' }, '[12:34:59] double-click left @ (24, 8)'), Text({ color: 'magenta' }, '[12:35:00] drag @ (25, 8)'), Text({ color: 'magenta' }, '[12:35:00] drag @ (26, 8)'), Text({ color: 'cyan' }, '[12:35:01] release @ (28, 8)')), Box({ flexDirection: 'row', gap: 2 }, Text({ color: 'gray' }, 'Events: 7'), Text({ color: 'gray' }, '|'), Text({ color: 'gray' }, '[Clear Log]')))),
552
+ story('Mouse - Hover State')
553
+ .category('Molecules')
554
+ .description('Track hover state over elements')
555
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'single' }, Text({ bold: true }, '๐Ÿ‘† Hover Detection'), Divider({}), Box({ flexDirection: 'row', gap: 2 }, Box({ padding: 1, borderStyle: 'round', borderColor: 'cyan', backgroundColor: 'blue' }, Text({ color: 'white', bold: true }, ' Hovered! ')), Box({ padding: 1, borderStyle: 'round', borderColor: 'gray' }, Text({ color: 'gray' }, ' Normal ')), Box({ padding: 1, borderStyle: 'round', borderColor: 'gray' }, Text({ color: 'gray' }, ' Normal '))), Spacer({ size: 1 }), Text({ color: 'gray' }, 'Hovering: Item 1'), Text({ color: 'gray', dim: true }, "Track mouse position for hover effects"))),
556
+ story('Mouse - Context Menu')
557
+ .category('Molecules')
558
+ .description('Right-click context menu trigger')
559
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'single' }, Text({ bold: true }, '๐Ÿ“œ Context Menu'), Divider({}), Box({ flexDirection: 'row', gap: 0 }, Box({ flexDirection: 'column', width: 20 }, Text({}, ' ๐Ÿ“„ Document.txt'), Text({}, ' ๐Ÿ“ Folder'), Text({ backgroundColor: 'blue', color: 'white' }, ' ๐Ÿ“„ Selected.md ')), Box({ flexDirection: 'column', borderStyle: 'single', borderColor: 'cyan', padding: 1 }, Text({ color: 'cyan' }, ' Open '), Text({}, ' Edit '), Text({}, ' Copy '), Text({ color: 'gray' }, ' โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€ '), Text({ color: 'red' }, ' Delete '))), Text({ color: 'gray', dim: true }, "if (event.button === 'right') showMenu()"))),
560
+ story('Mouse - Drag & Drop')
561
+ .category('Molecules')
562
+ .description('Visual drag and drop interface')
563
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'round', borderColor: 'green' }, Text({ bold: true, color: 'green' }, '๐Ÿ“ฆ Drag & Drop'), Divider({}), Box({ flexDirection: 'row', gap: 2 }, Box({ flexDirection: 'column', borderStyle: 'single', borderColor: 'gray', padding: 1 }, Text({ color: 'gray', dim: true }, 'Source'), Text({}, ' ๐Ÿ“„ File 1'), Text({ color: 'yellow' }, ' ๐Ÿ“„ Dragging...'), Text({}, ' ๐Ÿ“„ File 3')), Box({ flexDirection: 'column', alignItems: 'center', justifyContent: 'center' }, Text({ color: 'yellow' }, 'โ†’โ†’โ†’'), Text({ color: 'yellow', dim: true }, '๐Ÿ“„')), Box({ flexDirection: 'column', borderStyle: 'double', borderColor: 'green', padding: 1 }, Text({ color: 'green' }, 'Drop Zone'), Text({}, ' ๐Ÿ“„ Existing'), Text({ color: 'green', dim: true }, ' โ”„โ”„โ”„โ”„โ”„โ”„โ”„โ”„'))), Text({ color: 'gray', dim: true }, 'Combine drag events with position tracking'))),
564
+ story('Mouse - Selection Box')
565
+ .category('Molecules')
566
+ .description('Drag to create selection rectangle')
567
+ .render(() => Box({ flexDirection: 'column', gap: 1, padding: 1, borderStyle: 'single' }, Text({ bold: true }, 'โฌœ Selection Box'), Divider({}), Box({ flexDirection: 'column' }, Text({ color: 'gray' }, 'โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”'), Text({ color: 'gray' }, 'โ”‚ โ—‹ โ— โ—‹ โ—‹ โ”‚'), Text({ color: 'gray' }, 'โ”‚ โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”“ โ”‚'), Text({ color: 'gray' }, 'โ”‚ โ—‹ โ”ƒ โ— โ— โ”ƒ โ—‹ โ”‚'), Text({ color: 'gray' }, 'โ”‚ โ”ƒ โ— โ”ƒ โ”‚'), Text({ color: 'gray' }, 'โ”‚ โ”—โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”› โ—‹ โ”‚'), Text({ color: 'gray' }, 'โ”‚ โ—‹ โ—‹ โ”‚'), Text({ color: 'gray' }, 'โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜')), Text({ color: 'cyan' }, 'Selected: 4 items'), Text({ color: 'gray', dim: true }, 'Track start & end drag positions'))),
568
+ ];
569
+ /**
570
+ * All molecule stories
571
+ */
572
+ export const allMoleculeStories = [
573
+ ...utilityStories,
574
+ ...textInputStories,
575
+ ...checkboxStories,
576
+ ...radioStories,
577
+ ...selectStories,
578
+ ...progressBarStories,
579
+ ...alertStories,
580
+ ...toastStories,
581
+ ...tabsStories,
582
+ ...sparklineStories,
583
+ ...gaugeStories,
584
+ ...mouseStories,
585
+ ];
586
+ export default allMoleculeStories;
587
+ //# sourceMappingURL=index.js.map