entangle-ui 0.1.0 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (347) hide show
  1. package/CHANGELOG.md +54 -0
  2. package/README.md +129 -75
  3. package/dist/esm/components/Icons/CheckIcon.js +27 -0
  4. package/dist/esm/components/Icons/CheckIcon.js.map +1 -0
  5. package/dist/esm/components/Icons/ChevronDownIcon.js +27 -0
  6. package/dist/esm/components/Icons/ChevronDownIcon.js.map +1 -0
  7. package/dist/esm/components/Icons/ChevronUpIcon.js +27 -0
  8. package/dist/esm/components/Icons/ChevronUpIcon.js.map +1 -0
  9. package/dist/esm/components/Icons/CircleIcon.js +27 -0
  10. package/dist/esm/components/Icons/CircleIcon.js.map +1 -0
  11. package/dist/esm/components/Icons/CloseIcon.js +27 -0
  12. package/dist/esm/components/Icons/CloseIcon.js.map +1 -0
  13. package/dist/esm/components/Icons/EyeDropperIcon.js +28 -0
  14. package/dist/esm/components/Icons/EyeDropperIcon.js.map +1 -0
  15. package/dist/esm/components/Icons/TangentAlignedIcon.js +9 -0
  16. package/dist/esm/components/Icons/TangentAlignedIcon.js.map +1 -0
  17. package/dist/esm/components/Icons/TangentAutoIcon.js +9 -0
  18. package/dist/esm/components/Icons/TangentAutoIcon.js.map +1 -0
  19. package/dist/esm/components/Icons/TangentFreeIcon.js +9 -0
  20. package/dist/esm/components/Icons/TangentFreeIcon.js.map +1 -0
  21. package/dist/esm/components/Icons/TangentLinearIcon.js +9 -0
  22. package/dist/esm/components/Icons/TangentLinearIcon.js.map +1 -0
  23. package/dist/esm/components/Icons/TangentMirroredIcon.js +9 -0
  24. package/dist/esm/components/Icons/TangentMirroredIcon.js.map +1 -0
  25. package/dist/esm/components/Icons/TangentStepIcon.js +9 -0
  26. package/dist/esm/components/Icons/TangentStepIcon.js.map +1 -0
  27. package/dist/esm/components/controls/ColorPicker/AlphaSlider.js +92 -0
  28. package/dist/esm/components/controls/ColorPicker/AlphaSlider.js.map +1 -0
  29. package/dist/esm/components/controls/ColorPicker/ColorArea.js +93 -0
  30. package/dist/esm/components/controls/ColorPicker/ColorArea.js.map +1 -0
  31. package/dist/esm/components/controls/ColorPicker/ColorInputs.js +129 -0
  32. package/dist/esm/components/controls/ColorPicker/ColorInputs.js.map +1 -0
  33. package/dist/esm/components/controls/ColorPicker/ColorPalette.js +89 -0
  34. package/dist/esm/components/controls/ColorPicker/ColorPalette.js.map +1 -0
  35. package/dist/esm/components/controls/ColorPicker/ColorPicker.js +75 -0
  36. package/dist/esm/components/controls/ColorPicker/ColorPicker.js.map +1 -0
  37. package/dist/esm/components/controls/ColorPicker/ColorPresets.js +57 -0
  38. package/dist/esm/components/controls/ColorPicker/ColorPresets.js.map +1 -0
  39. package/dist/esm/components/controls/ColorPicker/ColorSwatch.js +67 -0
  40. package/dist/esm/components/controls/ColorPicker/ColorSwatch.js.map +1 -0
  41. package/dist/esm/components/controls/ColorPicker/EyeDropper.js +85 -0
  42. package/dist/esm/components/controls/ColorPicker/EyeDropper.js.map +1 -0
  43. package/dist/esm/components/controls/ColorPicker/HueSlider.js +85 -0
  44. package/dist/esm/components/controls/ColorPicker/HueSlider.js.map +1 -0
  45. package/dist/esm/components/controls/ColorPicker/colorUtils.js +220 -0
  46. package/dist/esm/components/controls/ColorPicker/colorUtils.js.map +1 -0
  47. package/dist/esm/components/controls/ColorPicker/palettes/material.js +299 -0
  48. package/dist/esm/components/controls/ColorPicker/palettes/material.js.map +1 -0
  49. package/dist/esm/components/controls/ColorPicker/palettes/professional.js +479 -0
  50. package/dist/esm/components/controls/ColorPicker/palettes/professional.js.map +1 -0
  51. package/dist/esm/components/controls/ColorPicker/palettes/tailwind.js +366 -0
  52. package/dist/esm/components/controls/ColorPicker/palettes/tailwind.js.map +1 -0
  53. package/dist/esm/components/controls/ColorPicker/useColor.js +63 -0
  54. package/dist/esm/components/controls/ColorPicker/useColor.js.map +1 -0
  55. package/dist/esm/components/controls/CurveEditor/CurveCanvas.js +84 -0
  56. package/dist/esm/components/controls/CurveEditor/CurveCanvas.js.map +1 -0
  57. package/dist/esm/components/controls/CurveEditor/CurveEditor.js +134 -0
  58. package/dist/esm/components/controls/CurveEditor/CurveEditor.js.map +1 -0
  59. package/dist/esm/components/controls/CurveEditor/CurveToolbar.js +96 -0
  60. package/dist/esm/components/controls/CurveEditor/CurveToolbar.js.map +1 -0
  61. package/dist/esm/components/controls/CurveEditor/curvePresets.js +184 -0
  62. package/dist/esm/components/controls/CurveEditor/curvePresets.js.map +1 -0
  63. package/dist/esm/components/controls/CurveEditor/curveUtils.js +338 -0
  64. package/dist/esm/components/controls/CurveEditor/curveUtils.js.map +1 -0
  65. package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js +569 -0
  66. package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js.map +1 -0
  67. package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js +400 -0
  68. package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js.map +1 -0
  69. package/dist/esm/components/controls/NumberInput/NumberInput.js +377 -0
  70. package/dist/esm/components/controls/NumberInput/NumberInput.js.map +1 -0
  71. package/dist/esm/components/controls/NumberInput/useNumberInput.js +324 -0
  72. package/dist/esm/components/controls/NumberInput/useNumberInput.js.map +1 -0
  73. package/dist/esm/components/controls/Select/Select.js +533 -0
  74. package/dist/esm/components/controls/Select/Select.js.map +1 -0
  75. package/dist/esm/components/controls/Slider/Slider.js +413 -0
  76. package/dist/esm/components/controls/Slider/Slider.js.map +1 -0
  77. package/dist/esm/components/controls/TreeView/TreeNode.js +189 -0
  78. package/dist/esm/components/controls/TreeView/TreeNode.js.map +1 -0
  79. package/dist/esm/components/controls/TreeView/TreeView.js +213 -0
  80. package/dist/esm/components/controls/TreeView/TreeView.js.map +1 -0
  81. package/dist/esm/components/controls/TreeView/useTreeState.js +154 -0
  82. package/dist/esm/components/controls/TreeView/useTreeState.js.map +1 -0
  83. package/dist/esm/components/controls/VectorInput/VectorInput.js +202 -0
  84. package/dist/esm/components/controls/VectorInput/VectorInput.js.map +1 -0
  85. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js +42 -0
  86. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js.map +1 -0
  87. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js +98 -0
  88. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js.map +1 -0
  89. package/dist/esm/components/editor/PropertyInspector/PropertyRow.js +154 -0
  90. package/dist/esm/components/editor/PropertyInspector/PropertyRow.js.map +1 -0
  91. package/dist/esm/components/editor/PropertyInspector/PropertySection.js +136 -0
  92. package/dist/esm/components/editor/PropertyInspector/PropertySection.js.map +1 -0
  93. package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js +86 -0
  94. package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js.map +1 -0
  95. package/dist/esm/components/feedback/Dialog/Dialog.js +92 -0
  96. package/dist/esm/components/feedback/Dialog/Dialog.js.map +1 -0
  97. package/dist/esm/components/feedback/Dialog/Dialog.styled.js +80 -0
  98. package/dist/esm/components/feedback/Dialog/Dialog.styled.js.map +1 -0
  99. package/dist/esm/components/feedback/Dialog/DialogBody.js +33 -0
  100. package/dist/esm/components/feedback/Dialog/DialogBody.js.map +1 -0
  101. package/dist/esm/components/feedback/Dialog/DialogClose.js +26 -0
  102. package/dist/esm/components/feedback/Dialog/DialogClose.js.map +1 -0
  103. package/dist/esm/components/feedback/Dialog/DialogFooter.js +43 -0
  104. package/dist/esm/components/feedback/Dialog/DialogFooter.js.map +1 -0
  105. package/dist/esm/components/feedback/Dialog/DialogHeader.js +84 -0
  106. package/dist/esm/components/feedback/Dialog/DialogHeader.js.map +1 -0
  107. package/dist/esm/components/feedback/Dialog/useDialogAnimation.js +70 -0
  108. package/dist/esm/components/feedback/Dialog/useDialogAnimation.js.map +1 -0
  109. package/dist/esm/components/feedback/Dialog/useFocusTrap.js +55 -0
  110. package/dist/esm/components/feedback/Dialog/useFocusTrap.js.map +1 -0
  111. package/dist/esm/components/feedback/Toast/ToastContainer.js +34 -0
  112. package/dist/esm/components/feedback/Toast/ToastContainer.js.map +1 -0
  113. package/dist/esm/components/feedback/Toast/ToastItem.js +214 -0
  114. package/dist/esm/components/feedback/Toast/ToastItem.js.map +1 -0
  115. package/dist/esm/components/feedback/Toast/ToastProvider.js +47 -0
  116. package/dist/esm/components/feedback/Toast/ToastProvider.js.map +1 -0
  117. package/dist/esm/components/feedback/Toast/useToast.js +60 -0
  118. package/dist/esm/components/feedback/Toast/useToast.js.map +1 -0
  119. package/dist/esm/components/form/FormHelperText.js +38 -0
  120. package/dist/esm/components/form/FormHelperText.js.map +1 -0
  121. package/dist/esm/components/form/FormLabel.js +43 -0
  122. package/dist/esm/components/form/FormLabel.js.map +1 -0
  123. package/dist/esm/components/form/InputWrapper.js +100 -0
  124. package/dist/esm/components/form/InputWrapper.js.map +1 -0
  125. package/dist/esm/components/layout/Accordion/Accordion.js +103 -0
  126. package/dist/esm/components/layout/Accordion/Accordion.js.map +1 -0
  127. package/dist/esm/components/layout/Accordion/AccordionContent.js +37 -0
  128. package/dist/esm/components/layout/Accordion/AccordionContent.js.map +1 -0
  129. package/dist/esm/components/layout/Accordion/AccordionItem.js +24 -0
  130. package/dist/esm/components/layout/Accordion/AccordionItem.js.map +1 -0
  131. package/dist/esm/components/layout/Accordion/AccordionTrigger.js +123 -0
  132. package/dist/esm/components/layout/Accordion/AccordionTrigger.js.map +1 -0
  133. package/dist/esm/components/layout/Flex/Flex.js +149 -0
  134. package/dist/esm/components/layout/Flex/Flex.js.map +1 -0
  135. package/dist/esm/components/layout/Grid/Grid.js +118 -0
  136. package/dist/esm/components/layout/Grid/Grid.js.map +1 -0
  137. package/dist/esm/components/layout/PanelSurface/PanelSurface.js +106 -0
  138. package/dist/esm/components/layout/PanelSurface/PanelSurface.js.map +1 -0
  139. package/dist/esm/components/layout/ScrollArea/ScrollArea.js +362 -0
  140. package/dist/esm/components/layout/ScrollArea/ScrollArea.js.map +1 -0
  141. package/dist/esm/components/layout/Spacer/Spacer.js +78 -0
  142. package/dist/esm/components/layout/Spacer/Spacer.js.map +1 -0
  143. package/dist/esm/components/layout/SplitPane/SplitPane.js +581 -0
  144. package/dist/esm/components/layout/SplitPane/SplitPane.js.map +1 -0
  145. package/dist/esm/components/layout/SplitPane/SplitPanePanel.js +29 -0
  146. package/dist/esm/components/layout/SplitPane/SplitPanePanel.js.map +1 -0
  147. package/dist/esm/components/layout/Stack/Stack.js +138 -0
  148. package/dist/esm/components/layout/Stack/Stack.js.map +1 -0
  149. package/dist/esm/components/navigation/ContextMenu/ContextMenu.js +45 -0
  150. package/dist/esm/components/navigation/ContextMenu/ContextMenu.js.map +1 -0
  151. package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js +52 -0
  152. package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js.map +1 -0
  153. package/dist/esm/components/navigation/Menu/Menu.helpers.js +52 -0
  154. package/dist/esm/components/navigation/Menu/Menu.helpers.js.map +1 -0
  155. package/dist/esm/components/navigation/Menu/Menu.js +80 -0
  156. package/dist/esm/components/navigation/Menu/Menu.js.map +1 -0
  157. package/dist/esm/components/navigation/Menu/Menu.styled.js +83 -0
  158. package/dist/esm/components/navigation/Menu/Menu.styled.js.map +1 -0
  159. package/dist/esm/components/navigation/Menu/useMenu.js +87 -0
  160. package/dist/esm/components/navigation/Menu/useMenu.js.map +1 -0
  161. package/dist/esm/components/navigation/Tabs/Tab.js +222 -0
  162. package/dist/esm/components/navigation/Tabs/Tab.js.map +1 -0
  163. package/dist/esm/components/navigation/Tabs/TabList.js +115 -0
  164. package/dist/esm/components/navigation/Tabs/TabList.js.map +1 -0
  165. package/dist/esm/components/navigation/Tabs/TabPanel.js +32 -0
  166. package/dist/esm/components/navigation/Tabs/TabPanel.js.map +1 -0
  167. package/dist/esm/components/navigation/Tabs/Tabs.js +77 -0
  168. package/dist/esm/components/navigation/Tabs/Tabs.js.map +1 -0
  169. package/dist/esm/components/primitives/BaseButton/BaseButton.js +17 -0
  170. package/dist/esm/components/primitives/BaseButton/BaseButton.js.map +1 -0
  171. package/dist/esm/components/primitives/Button/Button.js +183 -0
  172. package/dist/esm/components/primitives/Button/Button.js.map +1 -0
  173. package/dist/esm/components/primitives/Checkbox/Checkbox.js +205 -0
  174. package/dist/esm/components/primitives/Checkbox/Checkbox.js.map +1 -0
  175. package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js +71 -0
  176. package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js.map +1 -0
  177. package/dist/esm/components/primitives/Collapsible/Collapsible.js +116 -0
  178. package/dist/esm/components/primitives/Collapsible/Collapsible.js.map +1 -0
  179. package/dist/esm/components/primitives/Icon/Icon.js +63 -0
  180. package/dist/esm/components/primitives/Icon/Icon.js.map +1 -0
  181. package/dist/esm/components/primitives/IconButton/IconButton.js +222 -0
  182. package/dist/esm/components/primitives/IconButton/IconButton.js.map +1 -0
  183. package/dist/esm/components/primitives/Input/Input.js +133 -0
  184. package/dist/esm/components/primitives/Input/Input.js.map +1 -0
  185. package/dist/esm/components/primitives/Paper/Paper.js +146 -0
  186. package/dist/esm/components/primitives/Paper/Paper.js.map +1 -0
  187. package/dist/esm/components/primitives/Popover/Popover.js +121 -0
  188. package/dist/esm/components/primitives/Popover/Popover.js.map +1 -0
  189. package/dist/esm/components/primitives/Popover/PopoverClose.js +50 -0
  190. package/dist/esm/components/primitives/Popover/PopoverClose.js.map +1 -0
  191. package/dist/esm/components/primitives/Popover/PopoverContent.js +102 -0
  192. package/dist/esm/components/primitives/Popover/PopoverContent.js.map +1 -0
  193. package/dist/esm/components/primitives/Popover/PopoverTrigger.js +37 -0
  194. package/dist/esm/components/primitives/Popover/PopoverTrigger.js.map +1 -0
  195. package/dist/esm/components/primitives/Switch/Switch.js +170 -0
  196. package/dist/esm/components/primitives/Switch/Switch.js.map +1 -0
  197. package/dist/esm/components/primitives/Text/Text.js +166 -0
  198. package/dist/esm/components/primitives/Text/Text.js.map +1 -0
  199. package/dist/esm/components/primitives/Tooltip/Arrow.js +52 -0
  200. package/dist/esm/components/primitives/Tooltip/Arrow.js.map +1 -0
  201. package/dist/esm/components/primitives/Tooltip/Tooltip.js +219 -0
  202. package/dist/esm/components/primitives/Tooltip/Tooltip.js.map +1 -0
  203. package/dist/esm/components/primitives/Tooltip/utils.js +66 -0
  204. package/dist/esm/components/primitives/Tooltip/utils.js.map +1 -0
  205. package/dist/esm/components/shell/AppShell/AppShell.js +157 -0
  206. package/dist/esm/components/shell/AppShell/AppShell.js.map +1 -0
  207. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js +236 -0
  208. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js.map +1 -0
  209. package/dist/esm/components/shell/MenuBar/MenuBar.js +340 -0
  210. package/dist/esm/components/shell/MenuBar/MenuBar.js.map +1 -0
  211. package/dist/esm/components/shell/StatusBar/StatusBar.js +134 -0
  212. package/dist/esm/components/shell/StatusBar/StatusBar.js.map +1 -0
  213. package/dist/esm/components/shell/Toolbar/Toolbar.js +185 -0
  214. package/dist/esm/components/shell/Toolbar/Toolbar.js.map +1 -0
  215. package/dist/esm/context/KeyboardContext.js +14 -0
  216. package/dist/esm/context/KeyboardContext.js.map +1 -0
  217. package/dist/esm/index.js +78 -0
  218. package/dist/esm/index.js.map +1 -0
  219. package/dist/esm/palettes.js +4 -0
  220. package/dist/esm/palettes.js.map +1 -0
  221. package/dist/esm/theme/ThemeProvider.js +12 -0
  222. package/dist/esm/theme/ThemeProvider.js.map +1 -0
  223. package/dist/esm/theme/createTheme.js +10 -0
  224. package/dist/esm/theme/createTheme.js.map +1 -0
  225. package/dist/esm/theme/tokens.js +144 -0
  226. package/dist/esm/theme/tokens.js.map +1 -0
  227. package/dist/esm/utils/cn.js +6 -0
  228. package/dist/esm/utils/cn.js.map +1 -0
  229. package/dist/esm/utils/mathExpression.js +275 -0
  230. package/dist/esm/utils/mathExpression.js.map +1 -0
  231. package/dist/esm/utils/mathUtils.js +18 -0
  232. package/dist/esm/utils/mathUtils.js.map +1 -0
  233. package/dist/esm/utils/objects.js +22 -0
  234. package/dist/esm/utils/objects.js.map +1 -0
  235. package/dist/esm/utils/styledUtils.js +81 -0
  236. package/dist/esm/utils/styledUtils.js.map +1 -0
  237. package/dist/types/components/controls/ColorPicker/ColorPalette.d.ts +16 -0
  238. package/dist/types/components/controls/ColorPicker/ColorPicker.d.ts +6 -0
  239. package/dist/types/components/controls/ColorPicker/ColorPicker.types.d.ts +120 -0
  240. package/dist/types/components/controls/ColorPicker/ColorSwatch.d.ts +6 -0
  241. package/dist/types/components/controls/ColorPicker/EyeDropper.d.ts +28 -0
  242. package/dist/types/components/controls/ColorPicker/colorUtils.d.ts +3 -0
  243. package/dist/types/components/controls/ColorPicker/palettes/material.d.ts +24 -0
  244. package/dist/types/components/controls/ColorPicker/palettes/professional.d.ts +19 -0
  245. package/dist/types/components/controls/ColorPicker/palettes/tailwind.d.ts +12 -0
  246. package/dist/types/components/controls/CurveEditor/CurveEditor.d.ts +6 -0
  247. package/dist/types/components/controls/CurveEditor/CurveEditor.types.d.ts +297 -0
  248. package/dist/types/components/controls/CurveEditor/curvePresets.d.ts +5 -0
  249. package/dist/types/components/controls/CurveEditor/curveUtils.d.ts +28 -0
  250. package/dist/types/components/controls/NumberInput/NumberInput.d.ts +150 -0
  251. package/dist/types/components/controls/NumberInput/useNumberInput.d.ts +65 -0
  252. package/dist/types/components/controls/Select/Select.d.ts +29 -0
  253. package/dist/types/components/controls/Select/Select.types.d.ts +131 -0
  254. package/dist/types/components/controls/Slider/Slider.d.ts +178 -0
  255. package/dist/types/components/controls/TreeView/TreeView.d.ts +27 -0
  256. package/dist/types/components/controls/TreeView/TreeView.types.d.ts +135 -0
  257. package/dist/types/components/controls/VectorInput/VectorInput.d.ts +26 -0
  258. package/dist/types/components/controls/VectorInput/VectorInput.types.d.ts +158 -0
  259. package/dist/types/components/editor/PropertyInspector/PropertyGroup.d.ts +6 -0
  260. package/dist/types/components/editor/PropertyInspector/PropertyInspector.types.d.ts +238 -0
  261. package/dist/types/components/editor/PropertyInspector/PropertyPanel.d.ts +6 -0
  262. package/dist/types/components/editor/PropertyInspector/PropertyRow.d.ts +6 -0
  263. package/dist/types/components/editor/PropertyInspector/PropertySection.d.ts +6 -0
  264. package/dist/types/components/editor/PropertyInspector/usePropertyUndo.d.ts +9 -0
  265. package/dist/types/components/feedback/Dialog/Dialog.d.ts +25 -0
  266. package/dist/types/components/feedback/Dialog/Dialog.types.d.ts +55 -0
  267. package/dist/types/components/feedback/Dialog/DialogBody.d.ts +16 -0
  268. package/dist/types/components/feedback/Dialog/DialogClose.d.ts +21 -0
  269. package/dist/types/components/feedback/Dialog/DialogFooter.d.ts +17 -0
  270. package/dist/types/components/feedback/Dialog/DialogHeader.d.ts +17 -0
  271. package/dist/types/components/feedback/Toast/Toast.types.d.ts +39 -0
  272. package/dist/types/components/feedback/Toast/ToastProvider.d.ts +19 -0
  273. package/dist/types/components/feedback/Toast/useToast.d.ts +22 -0
  274. package/dist/types/components/form/FormHelperText.d.ts +321 -0
  275. package/dist/types/components/form/FormLabel.d.ts +331 -0
  276. package/dist/types/components/form/InputWrapper.d.ts +346 -0
  277. package/dist/types/components/layout/Accordion/Accordion.d.ts +23 -0
  278. package/dist/types/components/layout/Accordion/Accordion.types.d.ts +109 -0
  279. package/dist/types/components/layout/Accordion/AccordionContent.d.ts +6 -0
  280. package/dist/types/components/layout/Accordion/AccordionItem.d.ts +6 -0
  281. package/dist/types/components/layout/Accordion/AccordionTrigger.d.ts +6 -0
  282. package/dist/types/components/layout/Flex/Flex.d.ts +215 -0
  283. package/dist/types/components/layout/Grid/Grid.d.ts +113 -0
  284. package/dist/types/components/layout/PanelSurface/PanelSurface.d.ts +1153 -0
  285. package/dist/types/components/layout/PanelSurface/PanelSurface.types.d.ts +64 -0
  286. package/dist/types/components/layout/ScrollArea/ScrollArea.d.ts +6 -0
  287. package/dist/types/components/layout/ScrollArea/ScrollArea.types.d.ts +93 -0
  288. package/dist/types/components/layout/Spacer/Spacer.d.ts +329 -0
  289. package/dist/types/components/layout/SplitPane/SplitPane.d.ts +21 -0
  290. package/dist/types/components/layout/SplitPane/SplitPane.types.d.ts +87 -0
  291. package/dist/types/components/layout/SplitPane/SplitPanePanel.d.ts +20 -0
  292. package/dist/types/components/layout/Stack/Stack.d.ts +166 -0
  293. package/dist/types/components/navigation/ContextMenu/ContextMenu.d.ts +6 -0
  294. package/dist/types/components/navigation/ContextMenu/ContextMenu.types.d.ts +74 -0
  295. package/dist/types/components/navigation/ContextMenu/useContextMenuTarget.d.ts +5 -0
  296. package/dist/types/components/navigation/Menu/Menu.d.ts +42 -0
  297. package/dist/types/components/navigation/Menu/Menu.types.d.ts +94 -0
  298. package/dist/types/components/navigation/Menu/useMenu.d.ts +16 -0
  299. package/dist/types/components/navigation/Tabs/Tab.d.ts +6 -0
  300. package/dist/types/components/navigation/Tabs/TabList.d.ts +6 -0
  301. package/dist/types/components/navigation/Tabs/TabPanel.d.ts +6 -0
  302. package/dist/types/components/navigation/Tabs/Tabs.d.ts +23 -0
  303. package/dist/types/components/navigation/Tabs/Tabs.types.d.ts +117 -0
  304. package/dist/types/components/primitives/Button/Button.d.ts +392 -0
  305. package/dist/types/components/primitives/Checkbox/Checkbox.d.ts +20 -0
  306. package/dist/types/components/primitives/Checkbox/Checkbox.types.d.ts +156 -0
  307. package/dist/types/components/primitives/Checkbox/CheckboxGroup.d.ts +25 -0
  308. package/dist/types/components/primitives/Collapsible/Collapsible.d.ts +6 -0
  309. package/dist/types/components/primitives/Collapsible/Collapsible.types.d.ts +28 -0
  310. package/dist/types/components/primitives/Icon/Icon.d.ts +40 -0
  311. package/dist/types/components/primitives/IconButton/IconButton.d.ts +354 -0
  312. package/dist/types/components/primitives/Input/Input.d.ts +134 -0
  313. package/dist/types/components/primitives/Paper/Paper.d.ts +419 -0
  314. package/dist/types/components/primitives/Popover/Popover.d.ts +25 -0
  315. package/dist/types/components/primitives/Popover/Popover.types.d.ts +99 -0
  316. package/dist/types/components/primitives/Popover/PopoverClose.d.ts +6 -0
  317. package/dist/types/components/primitives/Popover/PopoverContent.d.ts +6 -0
  318. package/dist/types/components/primitives/Popover/PopoverTrigger.d.ts +10 -0
  319. package/dist/types/components/primitives/Switch/Switch.d.ts +78 -0
  320. package/dist/types/components/primitives/Text/Text.d.ts +442 -0
  321. package/dist/types/components/primitives/Tooltip/Tooltip.d.ts +175 -0
  322. package/dist/types/components/primitives/Tooltip/types.d.ts +82 -0
  323. package/dist/types/components/shell/AppShell/AppShell.d.ts +1437 -0
  324. package/dist/types/components/shell/AppShell/AppShell.types.d.ts +48 -0
  325. package/dist/types/components/shell/FloatingPanel/FloatingPanel.d.ts +7 -0
  326. package/dist/types/components/shell/FloatingPanel/FloatingPanel.types.d.ts +61 -0
  327. package/dist/types/components/shell/MenuBar/MenuBar.d.ts +1441 -0
  328. package/dist/types/components/shell/MenuBar/MenuBar.types.d.ts +48 -0
  329. package/dist/types/components/shell/StatusBar/StatusBar.d.ts +868 -0
  330. package/dist/types/components/shell/StatusBar/StatusBar.types.d.ts +40 -0
  331. package/dist/types/components/shell/Toolbar/Toolbar.d.ts +1728 -0
  332. package/dist/types/components/shell/Toolbar/Toolbar.types.d.ts +59 -0
  333. package/dist/types/index.d.ts +101 -0
  334. package/dist/types/palettes.d.ts +3 -0
  335. package/dist/types/theme/ThemeProvider.d.ts +11 -0
  336. package/dist/types/theme/createTheme.d.ts +6 -0
  337. package/dist/types/theme/tokens.d.ts +147 -0
  338. package/dist/types/theme/types.d.ts +7 -0
  339. package/dist/types/types/common.d.ts +24 -0
  340. package/dist/types/types/utilities.d.ts +72 -0
  341. package/dist/types/utils/cn.d.ts +3 -0
  342. package/package.json +23 -7
  343. package/dist/index.d.ts +0 -11
  344. package/dist/index.esm.js +0 -12149
  345. package/dist/index.esm.js.map +0 -1
  346. package/dist/index.js +0 -12223
  347. package/dist/index.js.map +0 -1
@@ -0,0 +1,214 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useState, useRef, useCallback, useEffect } from 'react';
3
+ import styled from '@emotion/styled';
4
+ import { keyframes } from '@emotion/react';
5
+
6
+ // --- Severity color map ---
7
+ const SEVERITY_COLOR_MAP = {
8
+ info: 'primary',
9
+ success: 'success',
10
+ warning: 'warning',
11
+ error: 'error',
12
+ };
13
+ // --- Severity icons (inline SVGs) ---
14
+ const SeverityIcon = ({ severity, color, }) => {
15
+ const size = 16;
16
+ const commonProps = {
17
+ width: size,
18
+ height: size,
19
+ viewBox: '0 0 16 16',
20
+ fill: 'none',
21
+ 'aria-hidden': true,
22
+ };
23
+ switch (severity) {
24
+ case 'info':
25
+ return (jsxs("svg", { ...commonProps, children: [jsx("circle", { cx: "8", cy: "8", r: "7", stroke: color, strokeWidth: "1.5" }), jsx("line", { x1: "8", y1: "7", x2: "8", y2: "11", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" }), jsx("circle", { cx: "8", cy: "5", r: "0.75", fill: color })] }));
26
+ case 'success':
27
+ return (jsxs("svg", { ...commonProps, children: [jsx("circle", { cx: "8", cy: "8", r: "7", stroke: color, strokeWidth: "1.5" }), jsx("path", { d: "M5 8L7 10L11 6", stroke: color, strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" })] }));
28
+ case 'warning':
29
+ return (jsxs("svg", { ...commonProps, children: [jsx("path", { d: "M8 2L14.5 13H1.5L8 2Z", stroke: color, strokeWidth: "1.5", strokeLinejoin: "round" }), jsx("line", { x1: "8", y1: "6", x2: "8", y2: "9", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" }), jsx("circle", { cx: "8", cy: "11", r: "0.75", fill: color })] }));
30
+ case 'error':
31
+ return (jsxs("svg", { ...commonProps, children: [jsx("circle", { cx: "8", cy: "8", r: "7", stroke: color, strokeWidth: "1.5" }), jsx("line", { x1: "5.5", y1: "5.5", x2: "10.5", y2: "10.5", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" }), jsx("line", { x1: "10.5", y1: "5.5", x2: "5.5", y2: "10.5", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" })] }));
32
+ }
33
+ };
34
+ // --- Animations ---
35
+ const slideIn = keyframes `
36
+ from {
37
+ opacity: 0;
38
+ transform: translateX(20px);
39
+ }
40
+ to {
41
+ opacity: 1;
42
+ transform: translateX(0);
43
+ }
44
+ `;
45
+ const progressShrink = keyframes `
46
+ from {
47
+ width: 100%;
48
+ }
49
+ to {
50
+ width: 0%;
51
+ }
52
+ `;
53
+ const StyledToast = styled.div `
54
+ width: 360px;
55
+ background: ${props => props.theme.colors.background.elevated};
56
+ border: 1px solid ${props => props.theme.colors.border.default};
57
+ border-left: 3px solid
58
+ ${props => props.theme.colors.accent[SEVERITY_COLOR_MAP[props.$severity]]};
59
+ border-radius: ${props => props.theme.borderRadius.lg}px;
60
+ box-shadow: ${props => props.theme.shadows.md};
61
+ padding: ${props => props.theme.spacing.md}px;
62
+ pointer-events: auto;
63
+ position: relative;
64
+ overflow: hidden;
65
+ animation: ${slideIn} ${props => props.theme.transitions.normal} forwards;
66
+ `;
67
+ const StyledContent = styled.div `
68
+ display: flex;
69
+ align-items: flex-start;
70
+ gap: ${props => props.theme.spacing.md}px;
71
+ `;
72
+ const StyledIconWrapper = styled.div `
73
+ flex-shrink: 0;
74
+ display: flex;
75
+ align-items: center;
76
+ padding-top: 1px;
77
+ `;
78
+ const StyledTextContent = styled.div `
79
+ flex: 1;
80
+ min-width: 0;
81
+ `;
82
+ const StyledTitle = styled.div `
83
+ font-weight: ${props => props.theme.typography.fontWeight.semibold};
84
+ color: ${props => props.theme.colors.text.primary};
85
+ font-size: ${props => props.theme.typography.fontSize.sm}px;
86
+ line-height: ${props => props.theme.typography.lineHeight.normal};
87
+ `;
88
+ const StyledMessage = styled.div `
89
+ color: ${props => props.theme.colors.text.secondary};
90
+ font-size: ${props => props.theme.typography.fontSize.xs}px;
91
+ line-height: ${props => props.theme.typography.lineHeight.normal};
92
+ margin-top: ${props => props.theme.spacing.xs}px;
93
+ `;
94
+ const StyledCloseButton = styled.button `
95
+ /* Reset */
96
+ padding: 0;
97
+ margin: 0;
98
+ border: none;
99
+ background: none;
100
+ cursor: pointer;
101
+ outline: none;
102
+
103
+ /* Layout */
104
+ display: flex;
105
+ align-items: center;
106
+ justify-content: center;
107
+ flex-shrink: 0;
108
+ width: 20px;
109
+ height: 20px;
110
+ border-radius: ${props => props.theme.borderRadius.sm}px;
111
+ color: ${props => props.theme.colors.text.muted};
112
+ transition:
113
+ color ${props => props.theme.transitions.fast},
114
+ background ${props => props.theme.transitions.fast};
115
+
116
+ &:hover {
117
+ color: ${props => props.theme.colors.text.primary};
118
+ background: ${props => props.theme.colors.surface.hover};
119
+ }
120
+
121
+ &:focus-visible {
122
+ box-shadow: ${props => props.theme.shadows.focus};
123
+ }
124
+ `;
125
+ const StyledActionButton = styled.button `
126
+ /* Reset */
127
+ padding: ${props => props.theme.spacing.xs}px
128
+ ${props => props.theme.spacing.sm}px;
129
+ margin: 0;
130
+ border: none;
131
+ background: none;
132
+ cursor: pointer;
133
+ outline: none;
134
+
135
+ /* Styling */
136
+ color: ${props => props.theme.colors.accent[SEVERITY_COLOR_MAP[props.$severity]]};
137
+ font-size: ${props => props.theme.typography.fontSize.xs}px;
138
+ font-weight: ${props => props.theme.typography.fontWeight.medium};
139
+ border-radius: ${props => props.theme.borderRadius.sm}px;
140
+ transition: background ${props => props.theme.transitions.fast};
141
+ margin-top: ${props => props.theme.spacing.sm}px;
142
+
143
+ &:hover {
144
+ background: ${props => props.theme.colors.surface.hover};
145
+ }
146
+
147
+ &:focus-visible {
148
+ box-shadow: ${props => props.theme.shadows.focus};
149
+ }
150
+ `;
151
+ const StyledProgressBar = styled.div `
152
+ position: absolute;
153
+ bottom: 0;
154
+ left: 0;
155
+ height: 2px;
156
+ background: ${props => props.theme.colors.accent[SEVERITY_COLOR_MAP[props.$severity]]};
157
+ animation: ${progressShrink} ${props => props.$duration}ms linear forwards;
158
+ animation-play-state: ${props => (props.$paused ? 'paused' : 'running')};
159
+ `;
160
+ /**
161
+ * Individual toast notification with severity indicator, auto-dismiss,
162
+ * optional progress bar, and action button support.
163
+ *
164
+ * - info/success: role="status", aria-live="polite"
165
+ * - warning/error: role="alert", aria-live="assertive"
166
+ * - Auto-dismiss pauses on hover
167
+ */
168
+ const ToastItem = ({ toast, onDismiss }) => {
169
+ const { id, title, message, severity, duration, closable, showProgress, icon, action, } = toast;
170
+ const [paused, setPaused] = useState(false);
171
+ const timerRef = useRef(null);
172
+ const remainingRef = useRef(duration);
173
+ const startRef = useRef(Date.now());
174
+ const isAlert = severity === 'warning' || severity === 'error';
175
+ const role = isAlert ? 'alert' : 'status';
176
+ const ariaLive = isAlert ? 'assertive' : 'polite';
177
+ const clearTimer = useCallback(() => {
178
+ if (timerRef.current !== null) {
179
+ clearTimeout(timerRef.current);
180
+ timerRef.current = null;
181
+ }
182
+ }, []);
183
+ const startTimer = useCallback(() => {
184
+ if (duration <= 0)
185
+ return;
186
+ clearTimer();
187
+ startRef.current = Date.now();
188
+ timerRef.current = setTimeout(() => {
189
+ onDismiss(id);
190
+ }, remainingRef.current);
191
+ }, [duration, clearTimer, onDismiss, id]);
192
+ const handleMouseEnter = useCallback(() => {
193
+ if (duration <= 0)
194
+ return;
195
+ setPaused(true);
196
+ clearTimer();
197
+ remainingRef.current -= Date.now() - startRef.current;
198
+ }, [duration, clearTimer]);
199
+ const handleMouseLeave = useCallback(() => {
200
+ if (duration <= 0)
201
+ return;
202
+ setPaused(false);
203
+ startTimer();
204
+ }, [duration, startTimer]);
205
+ useEffect(() => {
206
+ startTimer();
207
+ return clearTimer;
208
+ }, [startTimer, clearTimer]);
209
+ return (jsxs(StyledToast, { "$severity": severity, role: role, "aria-live": ariaLive, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, "data-testid": `toast-${id}`, children: [jsxs(StyledContent, { children: [jsx(StyledIconWrapper, { children: icon ?? jsx(SeverityIcon, { severity: severity, color: "currentColor" }) }), jsxs(StyledTextContent, { children: [title && jsx(StyledTitle, { children: title }), jsx(StyledMessage, { children: message }), action && (jsx(StyledActionButton, { "$severity": severity, onClick: action.onClick, type: "button", children: action.label }))] }), closable && (jsx(StyledCloseButton, { onClick: () => onDismiss(id), "aria-label": "Dismiss notification", type: "button", children: jsxs("svg", { width: 12, height: 12, viewBox: "0 0 12 12", fill: "none", "aria-hidden": "true", children: [jsx("line", { x1: "2", y1: "2", x2: "10", y2: "10", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" }), jsx("line", { x1: "10", y1: "2", x2: "2", y2: "10", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" })] }) }))] }), showProgress && duration > 0 && (jsx(StyledProgressBar, { "$severity": severity, "$duration": duration, "$paused": paused, "data-testid": `toast-progress-${id}` }))] }));
210
+ };
211
+ ToastItem.displayName = 'ToastItem';
212
+
213
+ export { ToastItem };
214
+ //# sourceMappingURL=ToastItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToastItem.js","sources":["../../../../../../src/components/feedback/Toast/ToastItem.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":"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"}
@@ -0,0 +1,47 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useReducer, useMemo, createContext } from 'react';
3
+ import { createPortal } from 'react-dom';
4
+ import { ToastContainer } from './ToastContainer.js';
5
+
6
+ const ToastContext =
7
+ /*#__PURE__*/ createContext(null);
8
+ // --- Reducer ---
9
+ function toastReducer(state, action) {
10
+ switch (action.type) {
11
+ case 'ADD_TOAST':
12
+ return [...state, action.toast];
13
+ case 'DISMISS_TOAST':
14
+ return state.filter(t => t.id !== action.id);
15
+ case 'DISMISS_ALL':
16
+ return [];
17
+ default:
18
+ return state;
19
+ }
20
+ }
21
+ /**
22
+ * ToastProvider manages toast notification state and renders them via portal.
23
+ *
24
+ * Wrap your application (or a section of it) with this provider, then use
25
+ * the `useToast()` hook to trigger notifications from any child component.
26
+ *
27
+ * @example
28
+ * ```tsx
29
+ * <ToastProvider position="bottom-right" maxVisible={5}>
30
+ * <App />
31
+ * </ToastProvider>
32
+ * ```
33
+ */
34
+ const ToastProvider = ({ children, position = 'bottom-right', maxVisible = 5, defaultDuration = 5000, gap = 8, zIndex = 1200, }) => {
35
+ const [toasts, dispatch] = useReducer(toastReducer, []);
36
+ const contextValue = useMemo(() => ({ dispatch, defaultDuration }), [dispatch, defaultDuration]);
37
+ const visibleToasts = toasts.slice(-maxVisible);
38
+ const handleDismiss = (id) => {
39
+ dispatch({ type: 'DISMISS_TOAST', id });
40
+ };
41
+ return (jsxs(ToastContext.Provider, { value: contextValue, children: [children, typeof document !== 'undefined' &&
42
+ createPortal(jsx(ToastContainer, { toasts: visibleToasts, position: position, gap: gap, zIndex: zIndex, onDismiss: handleDismiss }), document.body)] }));
43
+ };
44
+ ToastProvider.displayName = 'ToastProvider';
45
+
46
+ export { ToastContext, ToastProvider };
47
+ //# sourceMappingURL=ToastProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToastProvider.js","sources":["../../../../../../src/components/feedback/Toast/ToastProvider.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;;MAmBa,YAAY;AACvB,cAAc,aAAa,CAA2B,IAAI;AAE5D;AAEA,SAAS,YAAY,CACnB,KAA0B,EAC1B,MAAmB,EAAA;AAEnB,IAAA,QAAQ,MAAM,CAAC,IAAI;AACjB,QAAA,KAAK,WAAW;YACd,OAAO,CAAC,GAAG,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC;AACjC,QAAA,KAAK,eAAe;AAClB,YAAA,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,EAAE,CAAC;AAC9C,QAAA,KAAK,aAAa;AAChB,YAAA,OAAO,EAAE;AACX,QAAA;AACE,YAAA,OAAO,KAAK;;AAElB;AAEA;;;;;;;;;;;;AAYG;AACI,MAAM,aAAa,GAAiC,CAAC,EAC1D,QAAQ,EACR,QAAQ,GAAG,cAAc,EACzB,UAAU,GAAG,CAAC,EACd,eAAe,GAAG,IAAI,EACtB,GAAG,GAAG,CAAC,EACP,MAAM,GAAG,IAAI,GACd,KAAI;AACH,IAAA,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,GAAG,UAAU,CAAC,YAAY,EAAE,EAAE,CAAC;IAEvD,MAAM,YAAY,GAAG,OAAO,CAC1B,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,CAAC,EACrC,CAAC,QAAQ,EAAE,eAAe,CAAC,CAC5B;IAED,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;AAE/C,IAAA,MAAM,aAAa,GAAG,CAAC,EAAU,KAAI;QACnC,QAAQ,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,EAAE,EAAE,CAAC;AACzC,KAAC;AAED,IAAA,QACEA,IAAA,CAAC,YAAY,CAAC,QAAQ,EAAC,EAAA,KAAK,EAAE,YAAY,aACvC,QAAQ,EACR,OAAO,QAAQ,KAAK,WAAW;AAC9B,gBAAA,YAAY,CACVC,GAAA,CAAC,cAAc,EAAA,EACb,MAAM,EAAE,aAAa,EACrB,QAAQ,EAAE,QAAQ,EAClB,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,aAAa,EAAA,CACxB,EACF,QAAQ,CAAC,IAAI,CACd,CAAA,EAAA,CACmB;AAE5B;AAEA,aAAa,CAAC,WAAW,GAAG,eAAe;;;;"}
@@ -0,0 +1,60 @@
1
+ import { useContext, useRef, useCallback } from 'react';
2
+ import { ToastContext } from './ToastProvider.js';
3
+
4
+ /**
5
+ * Hook to trigger toast notifications from any component
6
+ * inside a `<ToastProvider>`.
7
+ *
8
+ * @throws Error if used outside of a `<ToastProvider>`
9
+ *
10
+ * @example
11
+ * ```tsx
12
+ * const { toast, success, error, dismiss } = useToast();
13
+ *
14
+ * success('File saved successfully');
15
+ * error('Failed to export', { title: 'Export Error' });
16
+ *
17
+ * const id = toast({ message: 'Custom toast', severity: 'info' });
18
+ * dismiss(id);
19
+ * ```
20
+ */
21
+ function useToast() {
22
+ const context = useContext(ToastContext);
23
+ if (!context) {
24
+ throw new Error('useToast must be used within a ToastProvider');
25
+ }
26
+ const { dispatch, defaultDuration } = context;
27
+ const counterRef = useRef(0);
28
+ const generateId = useCallback(() => {
29
+ counterRef.current += 1;
30
+ return `toast-${Date.now()}-${counterRef.current}`;
31
+ }, []);
32
+ const toast = useCallback((data) => {
33
+ const id = data.id ?? generateId();
34
+ const internalData = {
35
+ ...data,
36
+ id,
37
+ severity: data.severity ?? 'info',
38
+ duration: data.duration ?? defaultDuration,
39
+ closable: data.closable ?? true,
40
+ showProgress: data.showProgress ?? false,
41
+ createdAt: Date.now(),
42
+ };
43
+ dispatch({ type: 'ADD_TOAST', toast: internalData });
44
+ return id;
45
+ }, [dispatch, defaultDuration, generateId]);
46
+ const info = useCallback((message, options) => toast({ message, severity: 'info', ...options }), [toast]);
47
+ const success = useCallback((message, options) => toast({ message, severity: 'success', ...options }), [toast]);
48
+ const warning = useCallback((message, options) => toast({ message, severity: 'warning', ...options }), [toast]);
49
+ const error = useCallback((message, options) => toast({ message, severity: 'error', ...options }), [toast]);
50
+ const dismiss = useCallback((id) => {
51
+ dispatch({ type: 'DISMISS_TOAST', id });
52
+ }, [dispatch]);
53
+ const dismissAll = useCallback(() => {
54
+ dispatch({ type: 'DISMISS_ALL' });
55
+ }, [dispatch]);
56
+ return { toast, info, success, warning, error, dismiss, dismissAll };
57
+ }
58
+
59
+ export { useToast };
60
+ //# sourceMappingURL=useToast.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useToast.js","sources":["../../../../../../src/components/feedback/Toast/useToast.ts"],"sourcesContent":[null],"names":[],"mappings":";;;AAQA;;;;;;;;;;;;;;;;AAgBG;SACa,QAAQ,GAAA;AACtB,IAAA,MAAM,OAAO,GAAG,UAAU,CAAC,YAAY,CAAC;IACxC,IAAI,CAAC,OAAO,EAAE;AACZ,QAAA,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC;;AAGjE,IAAA,MAAM,EAAE,QAAQ,EAAE,eAAe,EAAE,GAAG,OAAO;AAC7C,IAAA,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC;AAE5B,IAAA,MAAM,UAAU,GAAG,WAAW,CAAC,MAAK;AAClC,QAAA,UAAU,CAAC,OAAO,IAAI,CAAC;QACvB,OAAO,CAAA,MAAA,EAAS,IAAI,CAAC,GAAG,EAAE,IAAI,UAAU,CAAC,OAAO,CAAA,CAAE;KACnD,EAAE,EAAE,CAAC;AAEN,IAAA,MAAM,KAAK,GAAG,WAAW,CACvB,CAAC,IAAe,KAAY;QAC1B,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,UAAU,EAAE;AAClC,QAAA,MAAM,YAAY,GAAsB;AACtC,YAAA,GAAG,IAAI;YACP,EAAE;AACF,YAAA,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,MAAM;AACjC,YAAA,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,eAAe;AAC1C,YAAA,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,IAAI;AAC/B,YAAA,YAAY,EAAE,IAAI,CAAC,YAAY,IAAI,KAAK;AACxC,YAAA,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB;QACD,QAAQ,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC;AACpD,QAAA,OAAO,EAAE;KACV,EACD,CAAC,QAAQ,EAAE,eAAe,EAAE,UAAU,CAAC,CACxC;AAED,IAAA,MAAM,IAAI,GAAG,WAAW,CACtB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC,EAClD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,OAAO,GAAG,WAAW,CACzB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,OAAO,EAAE,CAAC,EACrD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,OAAO,GAAG,WAAW,CACzB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,OAAO,EAAE,CAAC,EACrD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,KAAK,GAAG,WAAW,CACvB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAAC,EACnD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,OAAO,GAAG,WAAW,CACzB,CAAC,EAAU,KAAI;QACb,QAAQ,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,EAAE,EAAE,CAAC;AACzC,KAAC,EACD,CAAC,QAAQ,CAAC,CACX;AAED,IAAA,MAAM,UAAU,GAAG,WAAW,CAAC,MAAK;AAClC,QAAA,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;AACnC,KAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;AAEd,IAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE;AACtE;;;;"}
@@ -0,0 +1,38 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import React from 'react';
3
+ import styled from '@emotion/styled';
4
+ import { processCss } from '../../utils/styledUtils.js';
5
+
6
+ const StyledHelperText = styled.div `
7
+ font-size: ${props => props.theme.typography.fontSize.xs}px;
8
+ line-height: ${props => props.theme.typography.lineHeight.tight};
9
+ color: ${props => props.$error
10
+ ? props.theme.colors.accent.error
11
+ : props.theme.colors.text.muted};
12
+ margin-top: ${props => props.theme.spacing.xs}px;
13
+
14
+ /* Custom CSS */
15
+ ${props => processCss(props.$css, props.theme)}
16
+ `;
17
+ /**
18
+ * A standardized helper text component for use with form controls.
19
+ *
20
+ * Provides consistent styling for helper text and error messages
21
+ * across different form components.
22
+ *
23
+ * @example
24
+ * ```tsx
25
+ * <Input label="Email" />
26
+ * <FormHelperText>We'll never share your email with anyone else.</FormHelperText>
27
+ *
28
+ * <Input label="Username" error={!!usernameError} />
29
+ * <FormHelperText error>{usernameError}</FormHelperText>
30
+ * ```
31
+ */
32
+ const FormHelperText = /*#__PURE__*/ React.memo(({ children, error = false, className, style, css, ref, ...rest }) => {
33
+ return (jsx(StyledHelperText, { ref: ref, "$error": error, "$css": css, className: className, style: style, ...rest, children: children }));
34
+ });
35
+ FormHelperText.displayName = 'FormHelperText';
36
+
37
+ export { FormHelperText };
38
+ //# sourceMappingURL=FormHelperText.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FormHelperText.js","sources":["../../../../../src/components/form/FormHelperText.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;;;AAqBA,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAGjC;eACa,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAA;iBACzC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAA;AACtD,SAAA,EAAA,KAAK,IACZ,KAAK,CAAC;MACF,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;MAC1B,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAA;gBACrB,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAA;;;AAG3C,EAAA,EAAA,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC;CAC/C;AAED;;;;;;;;;;;;;;AAcG;AACI,MAAM,cAAc,iBAAiB,KAAK,CAAC,IAAI,CACpD,CAAC,EAAE,QAAQ,EAAE,KAAK,GAAG,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,KAAI;IACnE,QACEA,GAAC,CAAA,gBAAgB,EACf,EAAA,GAAG,EAAE,GAAG,EAAA,QAAA,EACA,KAAK,EAAA,MAAA,EACP,GAAG,EACT,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EACR,GAAA,IAAI,EAEP,QAAA,EAAA,QAAQ,EACQ,CAAA;AAEvB,CAAC;AAGH,cAAc,CAAC,WAAW,GAAG,gBAAgB;;;;"}
@@ -0,0 +1,43 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import React from 'react';
3
+ import styled from '@emotion/styled';
4
+ import { processCss } from '../../utils/styledUtils.js';
5
+
6
+ const StyledLabel = styled.label `
7
+ font-size: ${props => props.theme.typography.fontSize.sm}px;
8
+ font-weight: ${props => props.theme.typography.fontWeight.medium};
9
+ color: ${props => props.$disabled
10
+ ? props.theme.colors.text.disabled
11
+ : props.theme.colors.text.secondary};
12
+ line-height: ${props => props.theme.typography.lineHeight.tight};
13
+ margin-bottom: ${props => props.theme.spacing.xs}px;
14
+ display: inline-block;
15
+
16
+ /* Custom CSS */
17
+ ${props => processCss(props.$css, props.theme)}
18
+ `;
19
+ const RequiredIndicator = styled.span `
20
+ color: ${props => props.theme.colors.accent.error};
21
+ margin-left: 2px;
22
+ `;
23
+ /**
24
+ * A standardized form label component for use with form controls.
25
+ *
26
+ * Provides consistent styling and behavior for labels across different
27
+ * form components, with support for required indicators and disabled states.
28
+ *
29
+ * @example
30
+ * ```tsx
31
+ * <FormLabel htmlFor="name-input" required>
32
+ * Full Name
33
+ * </FormLabel>
34
+ * <Input id="name-input" />
35
+ * ```
36
+ */
37
+ const FormLabel = /*#__PURE__*/ React.memo(({ children, htmlFor, disabled = false, required = false, className, style, css, ref, ...rest }) => {
38
+ return (jsxs(StyledLabel, { ref: ref, htmlFor: htmlFor, "$disabled": disabled, "$css": css, className: className, style: style, ...rest, children: [children, required && jsx(RequiredIndicator, { children: " *" })] }));
39
+ });
40
+ FormLabel.displayName = 'FormLabel';
41
+
42
+ export { FormLabel };
43
+ //# sourceMappingURL=FormLabel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FormLabel.js","sources":["../../../../../src/components/form/FormLabel.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;;AAgCA,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAG9B;eACa,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAA;iBACzC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,CAAA;AACvD,SAAA,EAAA,KAAK,IACZ,KAAK,CAAC;MACF,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC;MACxB,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAA;iBACxB,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAA;mBAC9C,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAA;;;;AAI9C,EAAA,EAAA,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC;CAC/C;AAED,MAAM,iBAAiB,GAAG,MAAM,CAAC,IAAI,CAAA;WAC1B,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAA;;CAElD;AAED;;;;;;;;;;;;;AAaG;AACU,MAAA,SAAS,iBAAiB,KAAK,CAAC,IAAI,CAC/C,CAAC,EACC,QAAQ,EACR,OAAO,EACP,QAAQ,GAAG,KAAK,EAChB,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,KAAK,EACL,GAAG,EACH,GAAG,EACH,GAAG,IAAI,EACR,KAAI;AACH,IAAA,QACEA,IAAA,CAAC,WAAW,EAAA,EACV,GAAG,EAAE,GAAG,EACR,OAAO,EAAE,OAAO,EAAA,WAAA,EACL,QAAQ,EAAA,MAAA,EACb,GAAG,EACT,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EAAA,GACR,IAAI,EAEP,QAAA,EAAA,CAAA,QAAQ,EACR,QAAQ,IAAIC,GAAC,CAAA,iBAAiB,EAAuB,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,CAAA,EAAA,CAC1C;AAElB,CAAC;AAGH,SAAS,CAAC,WAAW,GAAG,WAAW;;;;"}
@@ -0,0 +1,100 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import React from 'react';
3
+ import styled from '@emotion/styled';
4
+ import { processCss } from '../../utils/styledUtils.js';
5
+
6
+ const StyledInputWrapper = styled.div `
7
+ position: relative;
8
+ display: flex;
9
+ align-items: center;
10
+ border: 1px solid;
11
+ border-radius: ${props => props.theme.borderRadius.md}px;
12
+ transition: all ${props => props.theme.transitions.normal};
13
+ background: ${props => props.$disabled
14
+ ? props.theme.colors.surface.disabled
15
+ : props.theme.colors.surface.default};
16
+
17
+ /* Size variants */
18
+ ${props => {
19
+ const sizes = {
20
+ sm: {
21
+ height: '20px',
22
+ padding: `0 ${props.theme.spacing.sm}px`,
23
+ },
24
+ md: {
25
+ height: '24px',
26
+ padding: `0 ${props.theme.spacing.md}px`,
27
+ },
28
+ lg: {
29
+ height: '32px',
30
+ padding: `0 ${props.theme.spacing.lg}px`,
31
+ },
32
+ };
33
+ const size = sizes[props.$size];
34
+ return `
35
+ height: ${size.height};
36
+ padding: ${size.padding};
37
+ `;
38
+ }}
39
+
40
+ /* Border color states */
41
+ border-color: ${props => {
42
+ if (props.$error)
43
+ return props.theme.colors.border.error;
44
+ if (props.$focused)
45
+ return props.theme.colors.border.focus;
46
+ return props.theme.colors.border.default;
47
+ }};
48
+
49
+ /* Focus ring */
50
+ ${props => props.$focused &&
51
+ !props.$error &&
52
+ `
53
+ box-shadow: 0 0 0 2px ${props.theme.colors.accent.primary}20;
54
+ `}
55
+
56
+ /* Disabled state */
57
+ ${props => props.$disabled &&
58
+ `
59
+ opacity: 0.5;
60
+ cursor: not-allowed;
61
+ `}
62
+
63
+ /* Hover state */
64
+ &:hover:not(:focus-within) {
65
+ border-color: ${props => {
66
+ if (props.$disabled || props.$error)
67
+ return 'inherit';
68
+ return props.theme.colors.border.focus;
69
+ }};
70
+ }
71
+
72
+ /* Custom CSS */
73
+ ${props => processCss(props.$css, props.theme)}
74
+ `;
75
+ /**
76
+ * A standardized wrapper component for form inputs.
77
+ *
78
+ * Provides consistent styling and behavior for input containers
79
+ * across different form components, with support for different sizes,
80
+ * states (error, disabled, focused), and consistent border styling.
81
+ *
82
+ * @example
83
+ * ```tsx
84
+ * <InputWrapper
85
+ * size="md"
86
+ * error={!!inputError}
87
+ * disabled={isDisabled}
88
+ * focused={isFocused}
89
+ * >
90
+ * <input type="text" />
91
+ * </InputWrapper>
92
+ * ```
93
+ */
94
+ const InputWrapper = /*#__PURE__*/ React.memo(({ children, size = 'md', error = false, disabled = false, focused = false, className, style, css, ref, ...rest }) => {
95
+ return (jsx(StyledInputWrapper, { ref: ref, "$size": size, "$error": error, "$disabled": disabled, "$focused": focused, "$css": css, className: className, style: style, ...rest, children: children }));
96
+ });
97
+ InputWrapper.displayName = 'InputWrapper';
98
+
99
+ export { InputWrapper, StyledInputWrapper };
100
+ //# sourceMappingURL=InputWrapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputWrapper.js","sources":["../../../../../src/components/form/InputWrapper.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;;;AAkDa,MAAA,kBAAkB,GAAG,MAAM,CAAC,GAAG,CAAyB;;;;;mBAKlD,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAA;oBACnC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAA;AAC3C,cAAA,EAAA,KAAK,IACjB,KAAK,CAAC;MACF,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;MAC3B,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAA;;;AAGtC,EAAA,EAAA,KAAK,IAAG;AACR,IAAA,MAAM,KAAK,GAAG;AACZ,QAAA,EAAE,EAAE;AACF,YAAA,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAI,EAAA,CAAA;AACzC,SAAA;AACD,QAAA,EAAE,EAAE;AACF,YAAA,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAI,EAAA,CAAA;AACzC,SAAA;AACD,QAAA,EAAE,EAAE;AACF,YAAA,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAI,EAAA,CAAA;AACzC,SAAA;KACF;IACD,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;IAC/B,OAAO;AACK,cAAA,EAAA,IAAI,CAAC,MAAM,CAAA;AACV,eAAA,EAAA,IAAI,CAAC,OAAO,CAAA;KACxB;AACH,CAAC;;;AAGe,gBAAA,EAAA,KAAK,IAAG;IACtB,IAAI,KAAK,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;IACxD,IAAI,KAAK,CAAC,QAAQ;QAAE,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;IAC1D,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO;AAC1C,CAAC,CAAA;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,QAAQ;IACd,CAAC,KAAK,CAAC,MAAM;AACb,IAAA;AACwB,0BAAA,EAAA,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAA;AAC1D,EAAA,CAAA;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,SAAS;AACf,IAAA;;;AAGD,EAAA,CAAA;;;;AAIiB,kBAAA,EAAA,KAAK,IAAG;AACtB,IAAA,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,MAAM;AAAE,QAAA,OAAO,SAAS;IACrD,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;AACxC,CAAC,CAAA;;;;AAID,EAAA,EAAA,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC;;AAGhD;;;;;;;;;;;;;;;;;;AAkBG;AACU,MAAA,YAAY,iBAAiB,KAAK,CAAC,IAAI,CAClD,CAAC,EACC,QAAQ,EACR,IAAI,GAAG,IAAI,EACX,KAAK,GAAG,KAAK,EACb,QAAQ,GAAG,KAAK,EAChB,OAAO,GAAG,KAAK,EACf,SAAS,EACT,KAAK,EACL,GAAG,EACH,GAAG,EACH,GAAG,IAAI,EACR,KAAI;AACH,IAAA,QACEA,GAAA,CAAC,kBAAkB,EAAA,EACjB,GAAG,EAAE,GAAG,EAAA,OAAA,EACD,IAAI,EAAA,QAAA,EACH,KAAK,EAAA,WAAA,EACF,QAAQ,EACT,UAAA,EAAA,OAAO,EACX,MAAA,EAAA,GAAG,EACT,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EAAA,GACR,IAAI,EAAA,QAAA,EAEP,QAAQ,EAAA,CACU;AAEzB,CAAC;AAGH,YAAY,CAAC,WAAW,GAAG,cAAc;;;;"}
@@ -0,0 +1,103 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useId, useState, useCallback, createContext, useContext } from 'react';
3
+ import styled from '@emotion/styled';
4
+ import { processCss } from '../../../utils/styledUtils.js';
5
+
6
+ // --- Contexts ---
7
+ const AccordionContext =
8
+ /*#__PURE__*/ createContext(null);
9
+ const AccordionItemContext =
10
+ /*#__PURE__*/ createContext(null);
11
+ function useAccordionContext() {
12
+ const ctx = useContext(AccordionContext);
13
+ if (!ctx) {
14
+ throw new Error('Accordion compound components must be used within <Accordion>');
15
+ }
16
+ return ctx;
17
+ }
18
+ function useAccordionItemContext() {
19
+ const ctx = useContext(AccordionItemContext);
20
+ if (!ctx) {
21
+ throw new Error('AccordionTrigger/AccordionContent must be used within <AccordionItem>');
22
+ }
23
+ return ctx;
24
+ }
25
+ // --- Helpers ---
26
+ function normalizeValue(value) {
27
+ if (value === undefined)
28
+ return [];
29
+ if (Array.isArray(value))
30
+ return value;
31
+ return [value];
32
+ }
33
+ const StyledAccordionRoot = styled.div `
34
+ display: flex;
35
+ flex-direction: column;
36
+ gap: ${props => props.$gap}px;
37
+
38
+ ${props => processCss(props.$css, props.theme)}
39
+ `;
40
+ // --- Component ---
41
+ /**
42
+ * Accordion component for collapsible sections in property inspectors
43
+ * and settings panels.
44
+ *
45
+ * Compound component pattern: use with AccordionItem, AccordionTrigger,
46
+ * and AccordionContent.
47
+ *
48
+ * @example
49
+ * ```tsx
50
+ * <Accordion defaultValue="transform">
51
+ * <AccordionItem value="transform">
52
+ * <AccordionTrigger>Transform</AccordionTrigger>
53
+ * <AccordionContent>Position, rotation, scale fields...</AccordionContent>
54
+ * </AccordionItem>
55
+ * </Accordion>
56
+ * ```
57
+ */
58
+ const Accordion = ({ value: valueProp, defaultValue, multiple = false, collapsible = false, variant = 'default', size = 'md', gap = 0, children, onChange, className, style, css, testId, ref, ...rest }) => {
59
+ const autoId = useId();
60
+ const [internalValue, setInternalValue] = useState(normalizeValue(defaultValue));
61
+ const isControlled = valueProp !== undefined;
62
+ const expandedItems = isControlled
63
+ ? normalizeValue(valueProp)
64
+ : internalValue;
65
+ const toggleItem = useCallback((itemValue) => {
66
+ const isExpanded = expandedItems.includes(itemValue);
67
+ let nextExpanded;
68
+ if (multiple) {
69
+ nextExpanded = isExpanded
70
+ ? expandedItems.filter(v => v !== itemValue)
71
+ : [...expandedItems, itemValue];
72
+ }
73
+ else {
74
+ if (isExpanded) {
75
+ nextExpanded = collapsible ? [] : expandedItems;
76
+ }
77
+ else {
78
+ nextExpanded = [itemValue];
79
+ }
80
+ }
81
+ if (!isControlled) {
82
+ setInternalValue(nextExpanded);
83
+ }
84
+ if (multiple) {
85
+ onChange?.(nextExpanded);
86
+ }
87
+ else {
88
+ onChange?.(nextExpanded[0] ?? '');
89
+ }
90
+ }, [expandedItems, multiple, collapsible, isControlled, onChange]);
91
+ const contextValue = {
92
+ expandedItems,
93
+ toggleItem,
94
+ variant,
95
+ size,
96
+ accordionId: autoId,
97
+ };
98
+ return (jsx(AccordionContext.Provider, { value: contextValue, children: jsx(StyledAccordionRoot, { ref: ref, "$gap": gap, "$css": css, className: className, style: style, "data-testid": testId, ...rest, children: children }) }));
99
+ };
100
+ Accordion.displayName = 'Accordion';
101
+
102
+ export { Accordion, AccordionContext, AccordionItemContext, useAccordionContext, useAccordionItemContext };
103
+ //# sourceMappingURL=Accordion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.js","sources":["../../../../../../src/components/layout/Accordion/Accordion.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":"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"}