entangle-ui 0.2.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 (346) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/dist/esm/components/Icons/CheckIcon.js +27 -0
  3. package/dist/esm/components/Icons/CheckIcon.js.map +1 -0
  4. package/dist/esm/components/Icons/ChevronDownIcon.js +27 -0
  5. package/dist/esm/components/Icons/ChevronDownIcon.js.map +1 -0
  6. package/dist/esm/components/Icons/ChevronUpIcon.js +27 -0
  7. package/dist/esm/components/Icons/ChevronUpIcon.js.map +1 -0
  8. package/dist/esm/components/Icons/CircleIcon.js +27 -0
  9. package/dist/esm/components/Icons/CircleIcon.js.map +1 -0
  10. package/dist/esm/components/Icons/CloseIcon.js +27 -0
  11. package/dist/esm/components/Icons/CloseIcon.js.map +1 -0
  12. package/dist/esm/components/Icons/EyeDropperIcon.js +28 -0
  13. package/dist/esm/components/Icons/EyeDropperIcon.js.map +1 -0
  14. package/dist/esm/components/Icons/TangentAlignedIcon.js +9 -0
  15. package/dist/esm/components/Icons/TangentAlignedIcon.js.map +1 -0
  16. package/dist/esm/components/Icons/TangentAutoIcon.js +9 -0
  17. package/dist/esm/components/Icons/TangentAutoIcon.js.map +1 -0
  18. package/dist/esm/components/Icons/TangentFreeIcon.js +9 -0
  19. package/dist/esm/components/Icons/TangentFreeIcon.js.map +1 -0
  20. package/dist/esm/components/Icons/TangentLinearIcon.js +9 -0
  21. package/dist/esm/components/Icons/TangentLinearIcon.js.map +1 -0
  22. package/dist/esm/components/Icons/TangentMirroredIcon.js +9 -0
  23. package/dist/esm/components/Icons/TangentMirroredIcon.js.map +1 -0
  24. package/dist/esm/components/Icons/TangentStepIcon.js +9 -0
  25. package/dist/esm/components/Icons/TangentStepIcon.js.map +1 -0
  26. package/dist/esm/components/controls/ColorPicker/AlphaSlider.js +92 -0
  27. package/dist/esm/components/controls/ColorPicker/AlphaSlider.js.map +1 -0
  28. package/dist/esm/components/controls/ColorPicker/ColorArea.js +93 -0
  29. package/dist/esm/components/controls/ColorPicker/ColorArea.js.map +1 -0
  30. package/dist/esm/components/controls/ColorPicker/ColorInputs.js +129 -0
  31. package/dist/esm/components/controls/ColorPicker/ColorInputs.js.map +1 -0
  32. package/dist/esm/components/controls/ColorPicker/ColorPalette.js +89 -0
  33. package/dist/esm/components/controls/ColorPicker/ColorPalette.js.map +1 -0
  34. package/dist/esm/components/controls/ColorPicker/ColorPicker.js +75 -0
  35. package/dist/esm/components/controls/ColorPicker/ColorPicker.js.map +1 -0
  36. package/dist/esm/components/controls/ColorPicker/ColorPresets.js +57 -0
  37. package/dist/esm/components/controls/ColorPicker/ColorPresets.js.map +1 -0
  38. package/dist/esm/components/controls/ColorPicker/ColorSwatch.js +67 -0
  39. package/dist/esm/components/controls/ColorPicker/ColorSwatch.js.map +1 -0
  40. package/dist/esm/components/controls/ColorPicker/EyeDropper.js +85 -0
  41. package/dist/esm/components/controls/ColorPicker/EyeDropper.js.map +1 -0
  42. package/dist/esm/components/controls/ColorPicker/HueSlider.js +85 -0
  43. package/dist/esm/components/controls/ColorPicker/HueSlider.js.map +1 -0
  44. package/dist/esm/components/controls/ColorPicker/colorUtils.js +220 -0
  45. package/dist/esm/components/controls/ColorPicker/colorUtils.js.map +1 -0
  46. package/dist/esm/components/controls/ColorPicker/palettes/material.js +299 -0
  47. package/dist/esm/components/controls/ColorPicker/palettes/material.js.map +1 -0
  48. package/dist/esm/components/controls/ColorPicker/palettes/professional.js +479 -0
  49. package/dist/esm/components/controls/ColorPicker/palettes/professional.js.map +1 -0
  50. package/dist/esm/components/controls/ColorPicker/palettes/tailwind.js +366 -0
  51. package/dist/esm/components/controls/ColorPicker/palettes/tailwind.js.map +1 -0
  52. package/dist/esm/components/controls/ColorPicker/useColor.js +63 -0
  53. package/dist/esm/components/controls/ColorPicker/useColor.js.map +1 -0
  54. package/dist/esm/components/controls/CurveEditor/CurveCanvas.js +84 -0
  55. package/dist/esm/components/controls/CurveEditor/CurveCanvas.js.map +1 -0
  56. package/dist/esm/components/controls/CurveEditor/CurveEditor.js +134 -0
  57. package/dist/esm/components/controls/CurveEditor/CurveEditor.js.map +1 -0
  58. package/dist/esm/components/controls/CurveEditor/CurveToolbar.js +96 -0
  59. package/dist/esm/components/controls/CurveEditor/CurveToolbar.js.map +1 -0
  60. package/dist/esm/components/controls/CurveEditor/curvePresets.js +184 -0
  61. package/dist/esm/components/controls/CurveEditor/curvePresets.js.map +1 -0
  62. package/dist/esm/components/controls/CurveEditor/curveUtils.js +338 -0
  63. package/dist/esm/components/controls/CurveEditor/curveUtils.js.map +1 -0
  64. package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js +569 -0
  65. package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js.map +1 -0
  66. package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js +400 -0
  67. package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js.map +1 -0
  68. package/dist/esm/components/controls/NumberInput/NumberInput.js +377 -0
  69. package/dist/esm/components/controls/NumberInput/NumberInput.js.map +1 -0
  70. package/dist/esm/components/controls/NumberInput/useNumberInput.js +324 -0
  71. package/dist/esm/components/controls/NumberInput/useNumberInput.js.map +1 -0
  72. package/dist/esm/components/controls/Select/Select.js +533 -0
  73. package/dist/esm/components/controls/Select/Select.js.map +1 -0
  74. package/dist/esm/components/controls/Slider/Slider.js +413 -0
  75. package/dist/esm/components/controls/Slider/Slider.js.map +1 -0
  76. package/dist/esm/components/controls/TreeView/TreeNode.js +189 -0
  77. package/dist/esm/components/controls/TreeView/TreeNode.js.map +1 -0
  78. package/dist/esm/components/controls/TreeView/TreeView.js +213 -0
  79. package/dist/esm/components/controls/TreeView/TreeView.js.map +1 -0
  80. package/dist/esm/components/controls/TreeView/useTreeState.js +154 -0
  81. package/dist/esm/components/controls/TreeView/useTreeState.js.map +1 -0
  82. package/dist/esm/components/controls/VectorInput/VectorInput.js +202 -0
  83. package/dist/esm/components/controls/VectorInput/VectorInput.js.map +1 -0
  84. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js +42 -0
  85. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js.map +1 -0
  86. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js +98 -0
  87. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js.map +1 -0
  88. package/dist/esm/components/editor/PropertyInspector/PropertyRow.js +154 -0
  89. package/dist/esm/components/editor/PropertyInspector/PropertyRow.js.map +1 -0
  90. package/dist/esm/components/editor/PropertyInspector/PropertySection.js +136 -0
  91. package/dist/esm/components/editor/PropertyInspector/PropertySection.js.map +1 -0
  92. package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js +86 -0
  93. package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js.map +1 -0
  94. package/dist/esm/components/feedback/Dialog/Dialog.js +92 -0
  95. package/dist/esm/components/feedback/Dialog/Dialog.js.map +1 -0
  96. package/dist/esm/components/feedback/Dialog/Dialog.styled.js +80 -0
  97. package/dist/esm/components/feedback/Dialog/Dialog.styled.js.map +1 -0
  98. package/dist/esm/components/feedback/Dialog/DialogBody.js +33 -0
  99. package/dist/esm/components/feedback/Dialog/DialogBody.js.map +1 -0
  100. package/dist/esm/components/feedback/Dialog/DialogClose.js +26 -0
  101. package/dist/esm/components/feedback/Dialog/DialogClose.js.map +1 -0
  102. package/dist/esm/components/feedback/Dialog/DialogFooter.js +43 -0
  103. package/dist/esm/components/feedback/Dialog/DialogFooter.js.map +1 -0
  104. package/dist/esm/components/feedback/Dialog/DialogHeader.js +84 -0
  105. package/dist/esm/components/feedback/Dialog/DialogHeader.js.map +1 -0
  106. package/dist/esm/components/feedback/Dialog/useDialogAnimation.js +70 -0
  107. package/dist/esm/components/feedback/Dialog/useDialogAnimation.js.map +1 -0
  108. package/dist/esm/components/feedback/Dialog/useFocusTrap.js +55 -0
  109. package/dist/esm/components/feedback/Dialog/useFocusTrap.js.map +1 -0
  110. package/dist/esm/components/feedback/Toast/ToastContainer.js +34 -0
  111. package/dist/esm/components/feedback/Toast/ToastContainer.js.map +1 -0
  112. package/dist/esm/components/feedback/Toast/ToastItem.js +214 -0
  113. package/dist/esm/components/feedback/Toast/ToastItem.js.map +1 -0
  114. package/dist/esm/components/feedback/Toast/ToastProvider.js +47 -0
  115. package/dist/esm/components/feedback/Toast/ToastProvider.js.map +1 -0
  116. package/dist/esm/components/feedback/Toast/useToast.js +60 -0
  117. package/dist/esm/components/feedback/Toast/useToast.js.map +1 -0
  118. package/dist/esm/components/form/FormHelperText.js +38 -0
  119. package/dist/esm/components/form/FormHelperText.js.map +1 -0
  120. package/dist/esm/components/form/FormLabel.js +43 -0
  121. package/dist/esm/components/form/FormLabel.js.map +1 -0
  122. package/dist/esm/components/form/InputWrapper.js +100 -0
  123. package/dist/esm/components/form/InputWrapper.js.map +1 -0
  124. package/dist/esm/components/layout/Accordion/Accordion.js +103 -0
  125. package/dist/esm/components/layout/Accordion/Accordion.js.map +1 -0
  126. package/dist/esm/components/layout/Accordion/AccordionContent.js +37 -0
  127. package/dist/esm/components/layout/Accordion/AccordionContent.js.map +1 -0
  128. package/dist/esm/components/layout/Accordion/AccordionItem.js +24 -0
  129. package/dist/esm/components/layout/Accordion/AccordionItem.js.map +1 -0
  130. package/dist/esm/components/layout/Accordion/AccordionTrigger.js +123 -0
  131. package/dist/esm/components/layout/Accordion/AccordionTrigger.js.map +1 -0
  132. package/dist/esm/components/layout/Flex/Flex.js +149 -0
  133. package/dist/esm/components/layout/Flex/Flex.js.map +1 -0
  134. package/dist/esm/components/layout/Grid/Grid.js +118 -0
  135. package/dist/esm/components/layout/Grid/Grid.js.map +1 -0
  136. package/dist/esm/components/layout/PanelSurface/PanelSurface.js +106 -0
  137. package/dist/esm/components/layout/PanelSurface/PanelSurface.js.map +1 -0
  138. package/dist/esm/components/layout/ScrollArea/ScrollArea.js +362 -0
  139. package/dist/esm/components/layout/ScrollArea/ScrollArea.js.map +1 -0
  140. package/dist/esm/components/layout/Spacer/Spacer.js +78 -0
  141. package/dist/esm/components/layout/Spacer/Spacer.js.map +1 -0
  142. package/dist/esm/components/layout/SplitPane/SplitPane.js +581 -0
  143. package/dist/esm/components/layout/SplitPane/SplitPane.js.map +1 -0
  144. package/dist/esm/components/layout/SplitPane/SplitPanePanel.js +29 -0
  145. package/dist/esm/components/layout/SplitPane/SplitPanePanel.js.map +1 -0
  146. package/dist/esm/components/layout/Stack/Stack.js +138 -0
  147. package/dist/esm/components/layout/Stack/Stack.js.map +1 -0
  148. package/dist/esm/components/navigation/ContextMenu/ContextMenu.js +45 -0
  149. package/dist/esm/components/navigation/ContextMenu/ContextMenu.js.map +1 -0
  150. package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js +52 -0
  151. package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js.map +1 -0
  152. package/dist/esm/components/navigation/Menu/Menu.helpers.js +52 -0
  153. package/dist/esm/components/navigation/Menu/Menu.helpers.js.map +1 -0
  154. package/dist/esm/components/navigation/Menu/Menu.js +80 -0
  155. package/dist/esm/components/navigation/Menu/Menu.js.map +1 -0
  156. package/dist/esm/components/navigation/Menu/Menu.styled.js +83 -0
  157. package/dist/esm/components/navigation/Menu/Menu.styled.js.map +1 -0
  158. package/dist/esm/components/navigation/Menu/useMenu.js +87 -0
  159. package/dist/esm/components/navigation/Menu/useMenu.js.map +1 -0
  160. package/dist/esm/components/navigation/Tabs/Tab.js +222 -0
  161. package/dist/esm/components/navigation/Tabs/Tab.js.map +1 -0
  162. package/dist/esm/components/navigation/Tabs/TabList.js +115 -0
  163. package/dist/esm/components/navigation/Tabs/TabList.js.map +1 -0
  164. package/dist/esm/components/navigation/Tabs/TabPanel.js +32 -0
  165. package/dist/esm/components/navigation/Tabs/TabPanel.js.map +1 -0
  166. package/dist/esm/components/navigation/Tabs/Tabs.js +77 -0
  167. package/dist/esm/components/navigation/Tabs/Tabs.js.map +1 -0
  168. package/dist/esm/components/primitives/BaseButton/BaseButton.js +17 -0
  169. package/dist/esm/components/primitives/BaseButton/BaseButton.js.map +1 -0
  170. package/dist/esm/components/primitives/Button/Button.js +183 -0
  171. package/dist/esm/components/primitives/Button/Button.js.map +1 -0
  172. package/dist/esm/components/primitives/Checkbox/Checkbox.js +205 -0
  173. package/dist/esm/components/primitives/Checkbox/Checkbox.js.map +1 -0
  174. package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js +71 -0
  175. package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js.map +1 -0
  176. package/dist/esm/components/primitives/Collapsible/Collapsible.js +116 -0
  177. package/dist/esm/components/primitives/Collapsible/Collapsible.js.map +1 -0
  178. package/dist/esm/components/primitives/Icon/Icon.js +63 -0
  179. package/dist/esm/components/primitives/Icon/Icon.js.map +1 -0
  180. package/dist/esm/components/primitives/IconButton/IconButton.js +222 -0
  181. package/dist/esm/components/primitives/IconButton/IconButton.js.map +1 -0
  182. package/dist/esm/components/primitives/Input/Input.js +133 -0
  183. package/dist/esm/components/primitives/Input/Input.js.map +1 -0
  184. package/dist/esm/components/primitives/Paper/Paper.js +146 -0
  185. package/dist/esm/components/primitives/Paper/Paper.js.map +1 -0
  186. package/dist/esm/components/primitives/Popover/Popover.js +121 -0
  187. package/dist/esm/components/primitives/Popover/Popover.js.map +1 -0
  188. package/dist/esm/components/primitives/Popover/PopoverClose.js +50 -0
  189. package/dist/esm/components/primitives/Popover/PopoverClose.js.map +1 -0
  190. package/dist/esm/components/primitives/Popover/PopoverContent.js +102 -0
  191. package/dist/esm/components/primitives/Popover/PopoverContent.js.map +1 -0
  192. package/dist/esm/components/primitives/Popover/PopoverTrigger.js +37 -0
  193. package/dist/esm/components/primitives/Popover/PopoverTrigger.js.map +1 -0
  194. package/dist/esm/components/primitives/Switch/Switch.js +170 -0
  195. package/dist/esm/components/primitives/Switch/Switch.js.map +1 -0
  196. package/dist/esm/components/primitives/Text/Text.js +166 -0
  197. package/dist/esm/components/primitives/Text/Text.js.map +1 -0
  198. package/dist/esm/components/primitives/Tooltip/Arrow.js +52 -0
  199. package/dist/esm/components/primitives/Tooltip/Arrow.js.map +1 -0
  200. package/dist/esm/components/primitives/Tooltip/Tooltip.js +219 -0
  201. package/dist/esm/components/primitives/Tooltip/Tooltip.js.map +1 -0
  202. package/dist/esm/components/primitives/Tooltip/utils.js +66 -0
  203. package/dist/esm/components/primitives/Tooltip/utils.js.map +1 -0
  204. package/dist/esm/components/shell/AppShell/AppShell.js +157 -0
  205. package/dist/esm/components/shell/AppShell/AppShell.js.map +1 -0
  206. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js +236 -0
  207. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js.map +1 -0
  208. package/dist/esm/components/shell/MenuBar/MenuBar.js +340 -0
  209. package/dist/esm/components/shell/MenuBar/MenuBar.js.map +1 -0
  210. package/dist/esm/components/shell/StatusBar/StatusBar.js +134 -0
  211. package/dist/esm/components/shell/StatusBar/StatusBar.js.map +1 -0
  212. package/dist/esm/components/shell/Toolbar/Toolbar.js +185 -0
  213. package/dist/esm/components/shell/Toolbar/Toolbar.js.map +1 -0
  214. package/dist/esm/context/KeyboardContext.js +14 -0
  215. package/dist/esm/context/KeyboardContext.js.map +1 -0
  216. package/dist/esm/index.js +78 -0
  217. package/dist/esm/index.js.map +1 -0
  218. package/dist/esm/palettes.js +4 -0
  219. package/dist/esm/palettes.js.map +1 -0
  220. package/dist/esm/theme/ThemeProvider.js +12 -0
  221. package/dist/esm/theme/ThemeProvider.js.map +1 -0
  222. package/dist/esm/theme/createTheme.js +10 -0
  223. package/dist/esm/theme/createTheme.js.map +1 -0
  224. package/dist/esm/theme/tokens.js +144 -0
  225. package/dist/esm/theme/tokens.js.map +1 -0
  226. package/dist/esm/utils/cn.js +6 -0
  227. package/dist/esm/utils/cn.js.map +1 -0
  228. package/dist/esm/utils/mathExpression.js +275 -0
  229. package/dist/esm/utils/mathExpression.js.map +1 -0
  230. package/dist/esm/utils/mathUtils.js +18 -0
  231. package/dist/esm/utils/mathUtils.js.map +1 -0
  232. package/dist/esm/utils/objects.js +22 -0
  233. package/dist/esm/utils/objects.js.map +1 -0
  234. package/dist/esm/utils/styledUtils.js +81 -0
  235. package/dist/esm/utils/styledUtils.js.map +1 -0
  236. package/dist/types/components/controls/ColorPicker/ColorPalette.d.ts +16 -0
  237. package/dist/types/components/controls/ColorPicker/ColorPicker.d.ts +6 -0
  238. package/dist/types/components/controls/ColorPicker/ColorPicker.types.d.ts +120 -0
  239. package/dist/types/components/controls/ColorPicker/ColorSwatch.d.ts +6 -0
  240. package/dist/types/components/controls/ColorPicker/EyeDropper.d.ts +28 -0
  241. package/dist/types/components/controls/ColorPicker/colorUtils.d.ts +3 -0
  242. package/dist/types/components/controls/ColorPicker/palettes/material.d.ts +24 -0
  243. package/dist/types/components/controls/ColorPicker/palettes/professional.d.ts +19 -0
  244. package/dist/types/components/controls/ColorPicker/palettes/tailwind.d.ts +12 -0
  245. package/dist/types/components/controls/CurveEditor/CurveEditor.d.ts +6 -0
  246. package/dist/types/components/controls/CurveEditor/CurveEditor.types.d.ts +297 -0
  247. package/dist/types/components/controls/CurveEditor/curvePresets.d.ts +5 -0
  248. package/dist/types/components/controls/CurveEditor/curveUtils.d.ts +28 -0
  249. package/dist/types/components/controls/NumberInput/NumberInput.d.ts +150 -0
  250. package/dist/types/components/controls/NumberInput/useNumberInput.d.ts +65 -0
  251. package/dist/types/components/controls/Select/Select.d.ts +29 -0
  252. package/dist/types/components/controls/Select/Select.types.d.ts +131 -0
  253. package/dist/types/components/controls/Slider/Slider.d.ts +178 -0
  254. package/dist/types/components/controls/TreeView/TreeView.d.ts +27 -0
  255. package/dist/types/components/controls/TreeView/TreeView.types.d.ts +135 -0
  256. package/dist/types/components/controls/VectorInput/VectorInput.d.ts +26 -0
  257. package/dist/types/components/controls/VectorInput/VectorInput.types.d.ts +158 -0
  258. package/dist/types/components/editor/PropertyInspector/PropertyGroup.d.ts +6 -0
  259. package/dist/types/components/editor/PropertyInspector/PropertyInspector.types.d.ts +238 -0
  260. package/dist/types/components/editor/PropertyInspector/PropertyPanel.d.ts +6 -0
  261. package/dist/types/components/editor/PropertyInspector/PropertyRow.d.ts +6 -0
  262. package/dist/types/components/editor/PropertyInspector/PropertySection.d.ts +6 -0
  263. package/dist/types/components/editor/PropertyInspector/usePropertyUndo.d.ts +9 -0
  264. package/dist/types/components/feedback/Dialog/Dialog.d.ts +25 -0
  265. package/dist/types/components/feedback/Dialog/Dialog.types.d.ts +55 -0
  266. package/dist/types/components/feedback/Dialog/DialogBody.d.ts +16 -0
  267. package/dist/types/components/feedback/Dialog/DialogClose.d.ts +21 -0
  268. package/dist/types/components/feedback/Dialog/DialogFooter.d.ts +17 -0
  269. package/dist/types/components/feedback/Dialog/DialogHeader.d.ts +17 -0
  270. package/dist/types/components/feedback/Toast/Toast.types.d.ts +39 -0
  271. package/dist/types/components/feedback/Toast/ToastProvider.d.ts +19 -0
  272. package/dist/types/components/feedback/Toast/useToast.d.ts +22 -0
  273. package/dist/types/components/form/FormHelperText.d.ts +321 -0
  274. package/dist/types/components/form/FormLabel.d.ts +331 -0
  275. package/dist/types/components/form/InputWrapper.d.ts +346 -0
  276. package/dist/types/components/layout/Accordion/Accordion.d.ts +23 -0
  277. package/dist/types/components/layout/Accordion/Accordion.types.d.ts +109 -0
  278. package/dist/types/components/layout/Accordion/AccordionContent.d.ts +6 -0
  279. package/dist/types/components/layout/Accordion/AccordionItem.d.ts +6 -0
  280. package/dist/types/components/layout/Accordion/AccordionTrigger.d.ts +6 -0
  281. package/dist/types/components/layout/Flex/Flex.d.ts +215 -0
  282. package/dist/types/components/layout/Grid/Grid.d.ts +113 -0
  283. package/dist/types/components/layout/PanelSurface/PanelSurface.d.ts +1153 -0
  284. package/dist/types/components/layout/PanelSurface/PanelSurface.types.d.ts +64 -0
  285. package/dist/types/components/layout/ScrollArea/ScrollArea.d.ts +6 -0
  286. package/dist/types/components/layout/ScrollArea/ScrollArea.types.d.ts +93 -0
  287. package/dist/types/components/layout/Spacer/Spacer.d.ts +329 -0
  288. package/dist/types/components/layout/SplitPane/SplitPane.d.ts +21 -0
  289. package/dist/types/components/layout/SplitPane/SplitPane.types.d.ts +87 -0
  290. package/dist/types/components/layout/SplitPane/SplitPanePanel.d.ts +20 -0
  291. package/dist/types/components/layout/Stack/Stack.d.ts +166 -0
  292. package/dist/types/components/navigation/ContextMenu/ContextMenu.d.ts +6 -0
  293. package/dist/types/components/navigation/ContextMenu/ContextMenu.types.d.ts +74 -0
  294. package/dist/types/components/navigation/ContextMenu/useContextMenuTarget.d.ts +5 -0
  295. package/dist/types/components/navigation/Menu/Menu.d.ts +42 -0
  296. package/dist/types/components/navigation/Menu/Menu.types.d.ts +94 -0
  297. package/dist/types/components/navigation/Menu/useMenu.d.ts +16 -0
  298. package/dist/types/components/navigation/Tabs/Tab.d.ts +6 -0
  299. package/dist/types/components/navigation/Tabs/TabList.d.ts +6 -0
  300. package/dist/types/components/navigation/Tabs/TabPanel.d.ts +6 -0
  301. package/dist/types/components/navigation/Tabs/Tabs.d.ts +23 -0
  302. package/dist/types/components/navigation/Tabs/Tabs.types.d.ts +117 -0
  303. package/dist/types/components/primitives/Button/Button.d.ts +392 -0
  304. package/dist/types/components/primitives/Checkbox/Checkbox.d.ts +20 -0
  305. package/dist/types/components/primitives/Checkbox/Checkbox.types.d.ts +156 -0
  306. package/dist/types/components/primitives/Checkbox/CheckboxGroup.d.ts +25 -0
  307. package/dist/types/components/primitives/Collapsible/Collapsible.d.ts +6 -0
  308. package/dist/types/components/primitives/Collapsible/Collapsible.types.d.ts +28 -0
  309. package/dist/types/components/primitives/Icon/Icon.d.ts +40 -0
  310. package/dist/types/components/primitives/IconButton/IconButton.d.ts +354 -0
  311. package/dist/types/components/primitives/Input/Input.d.ts +134 -0
  312. package/dist/types/components/primitives/Paper/Paper.d.ts +419 -0
  313. package/dist/types/components/primitives/Popover/Popover.d.ts +25 -0
  314. package/dist/types/components/primitives/Popover/Popover.types.d.ts +99 -0
  315. package/dist/types/components/primitives/Popover/PopoverClose.d.ts +6 -0
  316. package/dist/types/components/primitives/Popover/PopoverContent.d.ts +6 -0
  317. package/dist/types/components/primitives/Popover/PopoverTrigger.d.ts +10 -0
  318. package/dist/types/components/primitives/Switch/Switch.d.ts +78 -0
  319. package/dist/types/components/primitives/Text/Text.d.ts +442 -0
  320. package/dist/types/components/primitives/Tooltip/Tooltip.d.ts +175 -0
  321. package/dist/types/components/primitives/Tooltip/types.d.ts +82 -0
  322. package/dist/types/components/shell/AppShell/AppShell.d.ts +1437 -0
  323. package/dist/types/components/shell/AppShell/AppShell.types.d.ts +48 -0
  324. package/dist/types/components/shell/FloatingPanel/FloatingPanel.d.ts +7 -0
  325. package/dist/types/components/shell/FloatingPanel/FloatingPanel.types.d.ts +61 -0
  326. package/dist/types/components/shell/MenuBar/MenuBar.d.ts +1441 -0
  327. package/dist/types/components/shell/MenuBar/MenuBar.types.d.ts +48 -0
  328. package/dist/types/components/shell/StatusBar/StatusBar.d.ts +868 -0
  329. package/dist/types/components/shell/StatusBar/StatusBar.types.d.ts +40 -0
  330. package/dist/types/components/shell/Toolbar/Toolbar.d.ts +1728 -0
  331. package/dist/types/components/shell/Toolbar/Toolbar.types.d.ts +59 -0
  332. package/dist/types/index.d.ts +101 -0
  333. package/dist/types/palettes.d.ts +3 -0
  334. package/dist/types/theme/ThemeProvider.d.ts +11 -0
  335. package/dist/types/theme/createTheme.d.ts +6 -0
  336. package/dist/types/theme/tokens.d.ts +147 -0
  337. package/dist/types/theme/types.d.ts +7 -0
  338. package/dist/types/types/common.d.ts +24 -0
  339. package/dist/types/types/utilities.d.ts +72 -0
  340. package/dist/types/utils/cn.d.ts +3 -0
  341. package/package.json +23 -7
  342. package/dist/index.d.ts +0 -12
  343. package/dist/index.esm.js +0 -13962
  344. package/dist/index.esm.js.map +0 -1
  345. package/dist/index.js +0 -14048
  346. package/dist/index.js.map +0 -1
@@ -0,0 +1,392 @@
1
+ import React from 'react';
2
+ import { Theme } from '../../../theme/types.js';
3
+ import { Prettify } from '../../../types/utilities.js';
4
+ import { Size, Variant, BaseComponent } from '../../../types/common.js';
5
+
6
+ /**
7
+ * Button sizes optimized for editor interfaces
8
+ */
9
+ type ButtonSize = Size;
10
+ /**
11
+ * Visual variants for the button
12
+ */
13
+ type ButtonVariant = Variant;
14
+ /**
15
+ * Base props for the Button component
16
+ */
17
+ interface ButtonBaseProps extends BaseComponent<HTMLButtonElement> {
18
+ /**
19
+ * Button content — text, icons, or other React elements
20
+ * @example "Save", <><SaveIcon /> Save</>
21
+ */
22
+ children?: React.ReactNode;
23
+ /**
24
+ * Size variant optimized for editor interfaces
25
+ * - `sm`: 20px height, compact for toolbars
26
+ * - `md`: 24px height, standard for panels
27
+ * - `lg`: 32px height, prominent actions
28
+ * @default "md"
29
+ */
30
+ size?: ButtonSize;
31
+ /**
32
+ * Visual variant of the button
33
+ * - `default`: Transparent with border, fills on hover
34
+ * - `ghost`: No border, subtle hover state
35
+ * - `filled`: Solid background with accent color
36
+ * @default "default"
37
+ */
38
+ variant?: ButtonVariant;
39
+ /**
40
+ * Whether the button is disabled
41
+ * When true, button becomes non-interactive with reduced opacity
42
+ * @default false
43
+ */
44
+ disabled?: boolean;
45
+ /**
46
+ * Loading state — shows spinner and disables interaction
47
+ * Use for async operations like saving, loading data
48
+ * @default false
49
+ */
50
+ loading?: boolean;
51
+ /**
52
+ * Icon element to display before text
53
+ * Should be 16x16px for optimal appearance
54
+ * @example <SaveIcon />, <PlayIcon />
55
+ */
56
+ icon?: React.ReactNode;
57
+ /**
58
+ * Whether the button should take the full width of the container
59
+ * Useful for form actions and modal buttons
60
+ * @default false
61
+ */
62
+ fullWidth?: boolean;
63
+ /**
64
+ * Click event handler
65
+ * Called when button is clicked (not when disabled/loading)
66
+ */
67
+ onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void;
68
+ }
69
+ /**
70
+ * Props for the Button component with prettified type for better IntelliSense
71
+ */
72
+ type ButtonProps = Prettify<ButtonBaseProps>;
73
+ /**
74
+ * Versatile button component for editor interfaces.
75
+ *
76
+ * Supports multiple variants, sizes, and states. Optimized for professional
77
+ * editor interfaces with compact dimensions and precise interactions.
78
+ *
79
+ * @example
80
+ * ```tsx
81
+ * // Basic usage
82
+ * <Button variant="default" size="md">Save</Button>
83
+ *
84
+ * // With icon and loading state
85
+ * <Button
86
+ * icon={<SaveIcon />}
87
+ * loading={isSaving}
88
+ * onClick={handleSave}
89
+ * >
90
+ * Save Project
91
+ * </Button>
92
+ *
93
+ * // Full width button
94
+ * <Button variant="filled" fullWidth>
95
+ * Confirm
96
+ * </Button>
97
+ * ```
98
+ */
99
+ declare const Button: React.NamedExoticComponent<{
100
+ children?: React.ReactNode;
101
+ size?: ButtonSize | undefined;
102
+ variant?: ButtonVariant | undefined;
103
+ disabled?: boolean | undefined;
104
+ loading?: boolean | undefined;
105
+ icon?: React.ReactNode;
106
+ fullWidth?: boolean | undefined;
107
+ onClick?: ((event: React.MouseEvent<HTMLButtonElement>) => void) | undefined;
108
+ id?: string | undefined | undefined;
109
+ className?: string | undefined | undefined;
110
+ testId?: string | undefined;
111
+ style?: React.CSSProperties | undefined;
112
+ css?: React.CSSProperties | ((theme: Theme) => React.CSSProperties) | undefined;
113
+ ref?: React.Ref<HTMLButtonElement> | undefined;
114
+ defaultChecked?: boolean | undefined | undefined;
115
+ defaultValue?: string | number | readonly string[] | undefined;
116
+ suppressContentEditableWarning?: boolean | undefined | undefined;
117
+ suppressHydrationWarning?: boolean | undefined | undefined;
118
+ accessKey?: string | undefined | undefined;
119
+ autoCapitalize?: "off" | "none" | "on" | "sentences" | "words" | "characters" | undefined | (string & {}) | undefined;
120
+ autoFocus?: boolean | undefined | undefined;
121
+ contentEditable?: (boolean | "true" | "false") | "inherit" | "plaintext-only" | undefined;
122
+ contextMenu?: string | undefined | undefined;
123
+ dir?: string | undefined | undefined;
124
+ draggable?: (boolean | "true" | "false") | undefined;
125
+ enterKeyHint?: "enter" | "done" | "go" | "next" | "previous" | "search" | "send" | undefined | undefined;
126
+ hidden?: boolean | undefined | undefined;
127
+ lang?: string | undefined | undefined;
128
+ nonce?: string | undefined | undefined;
129
+ slot?: string | undefined | undefined;
130
+ spellCheck?: (boolean | "true" | "false") | undefined;
131
+ tabIndex?: number | undefined | undefined;
132
+ title?: string | undefined | undefined;
133
+ translate?: "yes" | "no" | undefined | undefined;
134
+ radioGroup?: string | undefined | undefined;
135
+ role?: React.AriaRole | undefined;
136
+ about?: string | undefined | undefined;
137
+ content?: string | undefined | undefined;
138
+ datatype?: string | undefined | undefined;
139
+ inlist?: any;
140
+ prefix?: string | undefined | undefined;
141
+ property?: string | undefined | undefined;
142
+ rel?: string | undefined | undefined;
143
+ resource?: string | undefined | undefined;
144
+ rev?: string | undefined | undefined;
145
+ typeof?: string | undefined | undefined;
146
+ vocab?: string | undefined | undefined;
147
+ autoCorrect?: string | undefined | undefined;
148
+ autoSave?: string | undefined | undefined;
149
+ color?: string | undefined | undefined;
150
+ itemProp?: string | undefined | undefined;
151
+ itemScope?: boolean | undefined | undefined;
152
+ itemType?: string | undefined | undefined;
153
+ itemID?: string | undefined | undefined;
154
+ itemRef?: string | undefined | undefined;
155
+ results?: number | undefined | undefined;
156
+ security?: string | undefined | undefined;
157
+ unselectable?: "on" | "off" | undefined | undefined;
158
+ popover?: "" | "auto" | "manual" | undefined | undefined;
159
+ popoverTargetAction?: "toggle" | "show" | "hide" | undefined | undefined;
160
+ popoverTarget?: string | undefined | undefined;
161
+ inert?: boolean | undefined | undefined;
162
+ inputMode?: "none" | "text" | "tel" | "url" | "email" | "numeric" | "decimal" | "search" | undefined | undefined;
163
+ is?: string | undefined | undefined;
164
+ exportparts?: string | undefined | undefined;
165
+ part?: string | undefined | undefined;
166
+ "aria-activedescendant"?: string | undefined | undefined;
167
+ "aria-atomic"?: (boolean | "true" | "false") | undefined;
168
+ "aria-autocomplete"?: "none" | "inline" | "list" | "both" | undefined | undefined;
169
+ "aria-braillelabel"?: string | undefined | undefined;
170
+ "aria-brailleroledescription"?: string | undefined | undefined;
171
+ "aria-busy"?: (boolean | "true" | "false") | undefined;
172
+ "aria-checked"?: boolean | "false" | "mixed" | "true" | undefined | undefined;
173
+ "aria-colcount"?: number | undefined | undefined;
174
+ "aria-colindex"?: number | undefined | undefined;
175
+ "aria-colindextext"?: string | undefined | undefined;
176
+ "aria-colspan"?: number | undefined | undefined;
177
+ "aria-controls"?: string | undefined | undefined;
178
+ "aria-current"?: boolean | "false" | "true" | "page" | "step" | "location" | "date" | "time" | undefined | undefined;
179
+ "aria-describedby"?: string | undefined | undefined;
180
+ "aria-description"?: string | undefined | undefined;
181
+ "aria-details"?: string | undefined | undefined;
182
+ "aria-disabled"?: (boolean | "true" | "false") | undefined;
183
+ "aria-dropeffect"?: "none" | "copy" | "execute" | "link" | "move" | "popup" | undefined | undefined;
184
+ "aria-errormessage"?: string | undefined | undefined;
185
+ "aria-expanded"?: (boolean | "true" | "false") | undefined;
186
+ "aria-flowto"?: string | undefined | undefined;
187
+ "aria-grabbed"?: (boolean | "true" | "false") | undefined;
188
+ "aria-haspopup"?: boolean | "false" | "true" | "menu" | "listbox" | "tree" | "grid" | "dialog" | undefined | undefined;
189
+ "aria-hidden"?: (boolean | "true" | "false") | undefined;
190
+ "aria-invalid"?: boolean | "false" | "true" | "grammar" | "spelling" | undefined | undefined;
191
+ "aria-keyshortcuts"?: string | undefined | undefined;
192
+ "aria-label"?: string | undefined | undefined;
193
+ "aria-labelledby"?: string | undefined | undefined;
194
+ "aria-level"?: number | undefined | undefined;
195
+ "aria-live"?: "off" | "assertive" | "polite" | undefined | undefined;
196
+ "aria-modal"?: (boolean | "true" | "false") | undefined;
197
+ "aria-multiline"?: (boolean | "true" | "false") | undefined;
198
+ "aria-multiselectable"?: (boolean | "true" | "false") | undefined;
199
+ "aria-orientation"?: "horizontal" | "vertical" | undefined | undefined;
200
+ "aria-owns"?: string | undefined | undefined;
201
+ "aria-placeholder"?: string | undefined | undefined;
202
+ "aria-posinset"?: number | undefined | undefined;
203
+ "aria-pressed"?: boolean | "false" | "mixed" | "true" | undefined | undefined;
204
+ "aria-readonly"?: (boolean | "true" | "false") | undefined;
205
+ "aria-relevant"?: "additions" | "additions removals" | "additions text" | "all" | "removals" | "removals additions" | "removals text" | "text" | "text additions" | "text removals" | undefined | undefined;
206
+ "aria-required"?: (boolean | "true" | "false") | undefined;
207
+ "aria-roledescription"?: string | undefined | undefined;
208
+ "aria-rowcount"?: number | undefined | undefined;
209
+ "aria-rowindex"?: number | undefined | undefined;
210
+ "aria-rowindextext"?: string | undefined | undefined;
211
+ "aria-rowspan"?: number | undefined | undefined;
212
+ "aria-selected"?: (boolean | "true" | "false") | undefined;
213
+ "aria-setsize"?: number | undefined | undefined;
214
+ "aria-sort"?: "none" | "ascending" | "descending" | "other" | undefined | undefined;
215
+ "aria-valuemax"?: number | undefined | undefined;
216
+ "aria-valuemin"?: number | undefined | undefined;
217
+ "aria-valuenow"?: number | undefined | undefined;
218
+ "aria-valuetext"?: string | undefined | undefined;
219
+ dangerouslySetInnerHTML?: {
220
+ __html: string | TrustedHTML;
221
+ } | undefined | undefined;
222
+ onCopy?: React.ClipboardEventHandler<HTMLButtonElement> | undefined;
223
+ onCopyCapture?: React.ClipboardEventHandler<HTMLButtonElement> | undefined;
224
+ onCut?: React.ClipboardEventHandler<HTMLButtonElement> | undefined;
225
+ onCutCapture?: React.ClipboardEventHandler<HTMLButtonElement> | undefined;
226
+ onPaste?: React.ClipboardEventHandler<HTMLButtonElement> | undefined;
227
+ onPasteCapture?: React.ClipboardEventHandler<HTMLButtonElement> | undefined;
228
+ onCompositionEnd?: React.CompositionEventHandler<HTMLButtonElement> | undefined;
229
+ onCompositionEndCapture?: React.CompositionEventHandler<HTMLButtonElement> | undefined;
230
+ onCompositionStart?: React.CompositionEventHandler<HTMLButtonElement> | undefined;
231
+ onCompositionStartCapture?: React.CompositionEventHandler<HTMLButtonElement> | undefined;
232
+ onCompositionUpdate?: React.CompositionEventHandler<HTMLButtonElement> | undefined;
233
+ onCompositionUpdateCapture?: React.CompositionEventHandler<HTMLButtonElement> | undefined;
234
+ onFocus?: React.FocusEventHandler<HTMLButtonElement> | undefined;
235
+ onFocusCapture?: React.FocusEventHandler<HTMLButtonElement> | undefined;
236
+ onBlur?: React.FocusEventHandler<HTMLButtonElement> | undefined;
237
+ onBlurCapture?: React.FocusEventHandler<HTMLButtonElement> | undefined;
238
+ onChange?: React.FormEventHandler<HTMLButtonElement> | undefined;
239
+ onChangeCapture?: React.FormEventHandler<HTMLButtonElement> | undefined;
240
+ onBeforeInput?: React.InputEventHandler<HTMLButtonElement> | undefined;
241
+ onBeforeInputCapture?: React.FormEventHandler<HTMLButtonElement> | undefined;
242
+ onInput?: React.FormEventHandler<HTMLButtonElement> | undefined;
243
+ onInputCapture?: React.FormEventHandler<HTMLButtonElement> | undefined;
244
+ onReset?: React.FormEventHandler<HTMLButtonElement> | undefined;
245
+ onResetCapture?: React.FormEventHandler<HTMLButtonElement> | undefined;
246
+ onSubmit?: React.FormEventHandler<HTMLButtonElement> | undefined;
247
+ onSubmitCapture?: React.FormEventHandler<HTMLButtonElement> | undefined;
248
+ onInvalid?: React.FormEventHandler<HTMLButtonElement> | undefined;
249
+ onInvalidCapture?: React.FormEventHandler<HTMLButtonElement> | undefined;
250
+ onLoad?: React.ReactEventHandler<HTMLButtonElement> | undefined;
251
+ onLoadCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
252
+ onError?: React.ReactEventHandler<HTMLButtonElement> | undefined;
253
+ onErrorCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
254
+ onKeyDown?: React.KeyboardEventHandler<HTMLButtonElement> | undefined;
255
+ onKeyDownCapture?: React.KeyboardEventHandler<HTMLButtonElement> | undefined;
256
+ onKeyPress?: React.KeyboardEventHandler<HTMLButtonElement> | undefined;
257
+ onKeyPressCapture?: React.KeyboardEventHandler<HTMLButtonElement> | undefined;
258
+ onKeyUp?: React.KeyboardEventHandler<HTMLButtonElement> | undefined;
259
+ onKeyUpCapture?: React.KeyboardEventHandler<HTMLButtonElement> | undefined;
260
+ onAbort?: React.ReactEventHandler<HTMLButtonElement> | undefined;
261
+ onAbortCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
262
+ onCanPlay?: React.ReactEventHandler<HTMLButtonElement> | undefined;
263
+ onCanPlayCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
264
+ onCanPlayThrough?: React.ReactEventHandler<HTMLButtonElement> | undefined;
265
+ onCanPlayThroughCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
266
+ onDurationChange?: React.ReactEventHandler<HTMLButtonElement> | undefined;
267
+ onDurationChangeCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
268
+ onEmptied?: React.ReactEventHandler<HTMLButtonElement> | undefined;
269
+ onEmptiedCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
270
+ onEncrypted?: React.ReactEventHandler<HTMLButtonElement> | undefined;
271
+ onEncryptedCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
272
+ onEnded?: React.ReactEventHandler<HTMLButtonElement> | undefined;
273
+ onEndedCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
274
+ onLoadedData?: React.ReactEventHandler<HTMLButtonElement> | undefined;
275
+ onLoadedDataCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
276
+ onLoadedMetadata?: React.ReactEventHandler<HTMLButtonElement> | undefined;
277
+ onLoadedMetadataCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
278
+ onLoadStart?: React.ReactEventHandler<HTMLButtonElement> | undefined;
279
+ onLoadStartCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
280
+ onPause?: React.ReactEventHandler<HTMLButtonElement> | undefined;
281
+ onPauseCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
282
+ onPlay?: React.ReactEventHandler<HTMLButtonElement> | undefined;
283
+ onPlayCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
284
+ onPlaying?: React.ReactEventHandler<HTMLButtonElement> | undefined;
285
+ onPlayingCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
286
+ onProgress?: React.ReactEventHandler<HTMLButtonElement> | undefined;
287
+ onProgressCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
288
+ onRateChange?: React.ReactEventHandler<HTMLButtonElement> | undefined;
289
+ onRateChangeCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
290
+ onSeeked?: React.ReactEventHandler<HTMLButtonElement> | undefined;
291
+ onSeekedCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
292
+ onSeeking?: React.ReactEventHandler<HTMLButtonElement> | undefined;
293
+ onSeekingCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
294
+ onStalled?: React.ReactEventHandler<HTMLButtonElement> | undefined;
295
+ onStalledCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
296
+ onSuspend?: React.ReactEventHandler<HTMLButtonElement> | undefined;
297
+ onSuspendCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
298
+ onTimeUpdate?: React.ReactEventHandler<HTMLButtonElement> | undefined;
299
+ onTimeUpdateCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
300
+ onVolumeChange?: React.ReactEventHandler<HTMLButtonElement> | undefined;
301
+ onVolumeChangeCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
302
+ onWaiting?: React.ReactEventHandler<HTMLButtonElement> | undefined;
303
+ onWaitingCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
304
+ onAuxClick?: React.MouseEventHandler<HTMLButtonElement> | undefined;
305
+ onAuxClickCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
306
+ onClickCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
307
+ onContextMenu?: React.MouseEventHandler<HTMLButtonElement> | undefined;
308
+ onContextMenuCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
309
+ onDoubleClick?: React.MouseEventHandler<HTMLButtonElement> | undefined;
310
+ onDoubleClickCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
311
+ onDrag?: React.DragEventHandler<HTMLButtonElement> | undefined;
312
+ onDragCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
313
+ onDragEnd?: React.DragEventHandler<HTMLButtonElement> | undefined;
314
+ onDragEndCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
315
+ onDragEnter?: React.DragEventHandler<HTMLButtonElement> | undefined;
316
+ onDragEnterCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
317
+ onDragExit?: React.DragEventHandler<HTMLButtonElement> | undefined;
318
+ onDragExitCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
319
+ onDragLeave?: React.DragEventHandler<HTMLButtonElement> | undefined;
320
+ onDragLeaveCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
321
+ onDragOver?: React.DragEventHandler<HTMLButtonElement> | undefined;
322
+ onDragOverCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
323
+ onDragStart?: React.DragEventHandler<HTMLButtonElement> | undefined;
324
+ onDragStartCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
325
+ onDrop?: React.DragEventHandler<HTMLButtonElement> | undefined;
326
+ onDropCapture?: React.DragEventHandler<HTMLButtonElement> | undefined;
327
+ onMouseDown?: React.MouseEventHandler<HTMLButtonElement> | undefined;
328
+ onMouseDownCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
329
+ onMouseEnter?: React.MouseEventHandler<HTMLButtonElement> | undefined;
330
+ onMouseLeave?: React.MouseEventHandler<HTMLButtonElement> | undefined;
331
+ onMouseMove?: React.MouseEventHandler<HTMLButtonElement> | undefined;
332
+ onMouseMoveCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
333
+ onMouseOut?: React.MouseEventHandler<HTMLButtonElement> | undefined;
334
+ onMouseOutCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
335
+ onMouseOver?: React.MouseEventHandler<HTMLButtonElement> | undefined;
336
+ onMouseOverCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
337
+ onMouseUp?: React.MouseEventHandler<HTMLButtonElement> | undefined;
338
+ onMouseUpCapture?: React.MouseEventHandler<HTMLButtonElement> | undefined;
339
+ onSelect?: React.ReactEventHandler<HTMLButtonElement> | undefined;
340
+ onSelectCapture?: React.ReactEventHandler<HTMLButtonElement> | undefined;
341
+ onTouchCancel?: React.TouchEventHandler<HTMLButtonElement> | undefined;
342
+ onTouchCancelCapture?: React.TouchEventHandler<HTMLButtonElement> | undefined;
343
+ onTouchEnd?: React.TouchEventHandler<HTMLButtonElement> | undefined;
344
+ onTouchEndCapture?: React.TouchEventHandler<HTMLButtonElement> | undefined;
345
+ onTouchMove?: React.TouchEventHandler<HTMLButtonElement> | undefined;
346
+ onTouchMoveCapture?: React.TouchEventHandler<HTMLButtonElement> | undefined;
347
+ onTouchStart?: React.TouchEventHandler<HTMLButtonElement> | undefined;
348
+ onTouchStartCapture?: React.TouchEventHandler<HTMLButtonElement> | undefined;
349
+ onPointerDown?: React.PointerEventHandler<HTMLButtonElement> | undefined;
350
+ onPointerDownCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
351
+ onPointerMove?: React.PointerEventHandler<HTMLButtonElement> | undefined;
352
+ onPointerMoveCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
353
+ onPointerUp?: React.PointerEventHandler<HTMLButtonElement> | undefined;
354
+ onPointerUpCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
355
+ onPointerCancel?: React.PointerEventHandler<HTMLButtonElement> | undefined;
356
+ onPointerCancelCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
357
+ onPointerEnter?: React.PointerEventHandler<HTMLButtonElement> | undefined;
358
+ onPointerLeave?: React.PointerEventHandler<HTMLButtonElement> | undefined;
359
+ onPointerOver?: React.PointerEventHandler<HTMLButtonElement> | undefined;
360
+ onPointerOverCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
361
+ onPointerOut?: React.PointerEventHandler<HTMLButtonElement> | undefined;
362
+ onPointerOutCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
363
+ onGotPointerCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
364
+ onGotPointerCaptureCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
365
+ onLostPointerCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
366
+ onLostPointerCaptureCapture?: React.PointerEventHandler<HTMLButtonElement> | undefined;
367
+ onScroll?: React.UIEventHandler<HTMLButtonElement> | undefined;
368
+ onScrollCapture?: React.UIEventHandler<HTMLButtonElement> | undefined;
369
+ onScrollEnd?: React.UIEventHandler<HTMLButtonElement> | undefined;
370
+ onScrollEndCapture?: React.UIEventHandler<HTMLButtonElement> | undefined;
371
+ onWheel?: React.WheelEventHandler<HTMLButtonElement> | undefined;
372
+ onWheelCapture?: React.WheelEventHandler<HTMLButtonElement> | undefined;
373
+ onAnimationStart?: React.AnimationEventHandler<HTMLButtonElement> | undefined;
374
+ onAnimationStartCapture?: React.AnimationEventHandler<HTMLButtonElement> | undefined;
375
+ onAnimationEnd?: React.AnimationEventHandler<HTMLButtonElement> | undefined;
376
+ onAnimationEndCapture?: React.AnimationEventHandler<HTMLButtonElement> | undefined;
377
+ onAnimationIteration?: React.AnimationEventHandler<HTMLButtonElement> | undefined;
378
+ onAnimationIterationCapture?: React.AnimationEventHandler<HTMLButtonElement> | undefined;
379
+ onToggle?: React.ToggleEventHandler<HTMLButtonElement> | undefined;
380
+ onBeforeToggle?: React.ToggleEventHandler<HTMLButtonElement> | undefined;
381
+ onTransitionCancel?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
382
+ onTransitionCancelCapture?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
383
+ onTransitionEnd?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
384
+ onTransitionEndCapture?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
385
+ onTransitionRun?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
386
+ onTransitionRunCapture?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
387
+ onTransitionStart?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
388
+ onTransitionStartCapture?: React.TransitionEventHandler<HTMLButtonElement> | undefined;
389
+ }>;
390
+
391
+ export { Button };
392
+ export type { ButtonBaseProps, ButtonProps, ButtonSize, ButtonVariant };
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import { CheckboxProps } from './Checkbox.types.js';
3
+
4
+ /**
5
+ * Checkbox component for boolean selection in settings panels,
6
+ * property inspectors, and form interfaces.
7
+ *
8
+ * Supports controlled/uncontrolled modes, indeterminate state,
9
+ * label positioning, sizes, variants, and error states.
10
+ *
11
+ * @example
12
+ * ```tsx
13
+ * <Checkbox label="Enable shadows" />
14
+ * <Checkbox checked={value} onChange={setValue} label="Auto-save" />
15
+ * <Checkbox indeterminate label="Select all" />
16
+ * ```
17
+ */
18
+ declare const Checkbox: React.FC<CheckboxProps>;
19
+
20
+ export { Checkbox };
@@ -0,0 +1,156 @@
1
+ import React from 'react';
2
+ import { Prettify } from '../../../types/utilities.js';
3
+ import { BaseComponent, Size } from '../../../types/common.js';
4
+
5
+ /**
6
+ * Checkbox size using standard library sizing.
7
+ */
8
+ type CheckboxSize = Size;
9
+ /**
10
+ * Checkbox visual variant.
11
+ */
12
+ type CheckboxVariant = 'default' | 'filled';
13
+ interface CheckboxBaseProps extends Omit<BaseComponent<HTMLButtonElement>, 'onChange'> {
14
+ /**
15
+ * Whether the checkbox is checked (controlled)
16
+ */
17
+ checked?: boolean;
18
+ /**
19
+ * Default checked state (uncontrolled)
20
+ * @default false
21
+ */
22
+ defaultChecked?: boolean;
23
+ /**
24
+ * Whether the checkbox is in an indeterminate state.
25
+ * Used for "select all" patterns when some items are checked.
26
+ * Takes visual precedence over checked state.
27
+ * @default false
28
+ */
29
+ indeterminate?: boolean;
30
+ /**
31
+ * Checkbox label text displayed next to the control
32
+ */
33
+ label?: string;
34
+ /**
35
+ * Position of the label relative to the checkbox
36
+ * @default "right"
37
+ */
38
+ labelPosition?: 'left' | 'right';
39
+ /**
40
+ * Checkbox size
41
+ * - `sm`: 14px box, compact for dense UIs
42
+ * - `md`: 16px box, standard for forms
43
+ * - `lg`: 20px box, prominent settings
44
+ * @default "md"
45
+ */
46
+ size?: CheckboxSize;
47
+ /**
48
+ * Visual variant
49
+ * - `default`: Border-only when unchecked, filled when checked
50
+ * - `filled`: Subtle background when unchecked, accent when checked
51
+ * @default "default"
52
+ */
53
+ variant?: CheckboxVariant;
54
+ /**
55
+ * Whether the checkbox is disabled
56
+ * @default false
57
+ */
58
+ disabled?: boolean;
59
+ /**
60
+ * Whether the checkbox is required
61
+ * @default false
62
+ */
63
+ required?: boolean;
64
+ /**
65
+ * Whether the checkbox has an error state
66
+ * @default false
67
+ */
68
+ error?: boolean;
69
+ /**
70
+ * Helper text displayed below the checkbox
71
+ */
72
+ helperText?: string;
73
+ /**
74
+ * Error message displayed when error is true
75
+ */
76
+ errorMessage?: string;
77
+ /**
78
+ * Value attribute for use in CheckboxGroup
79
+ */
80
+ value?: string;
81
+ /**
82
+ * Name attribute for form submission
83
+ */
84
+ name?: string;
85
+ /**
86
+ * Change event handler
87
+ * @param checked - The new checked state
88
+ */
89
+ onChange?: (checked: boolean) => void;
90
+ }
91
+ type CheckboxProps = Prettify<CheckboxBaseProps>;
92
+ interface CheckboxGroupBaseProps extends Omit<BaseComponent, 'onChange'> {
93
+ /**
94
+ * Currently selected values (controlled)
95
+ */
96
+ value?: string[];
97
+ /**
98
+ * Default selected values (uncontrolled)
99
+ */
100
+ defaultValue?: string[];
101
+ /**
102
+ * Group label
103
+ */
104
+ label?: string;
105
+ /**
106
+ * Layout direction
107
+ * @default "column"
108
+ */
109
+ direction?: 'row' | 'column';
110
+ /**
111
+ * Gap between checkboxes using theme spacing multiplier
112
+ * @default 2
113
+ */
114
+ gap?: number;
115
+ /**
116
+ * Whether all checkboxes in the group are disabled
117
+ * @default false
118
+ */
119
+ disabled?: boolean;
120
+ /**
121
+ * Size applied to all checkboxes in the group.
122
+ * Individual checkbox size overrides this.
123
+ * @default "md"
124
+ */
125
+ size?: CheckboxSize;
126
+ /**
127
+ * Helper text for the group
128
+ */
129
+ helperText?: string;
130
+ /**
131
+ * Error state for the group
132
+ * @default false
133
+ */
134
+ error?: boolean;
135
+ /**
136
+ * Error message for the group
137
+ */
138
+ errorMessage?: string;
139
+ /**
140
+ * Whether the group is required
141
+ * @default false
142
+ */
143
+ required?: boolean;
144
+ /**
145
+ * Checkbox elements to render
146
+ */
147
+ children: React.ReactNode;
148
+ /**
149
+ * Change event handler
150
+ * @param value - Array of selected checkbox values
151
+ */
152
+ onChange?: (value: string[]) => void;
153
+ }
154
+ type CheckboxGroupProps = Prettify<CheckboxGroupBaseProps>;
155
+
156
+ export type { CheckboxBaseProps, CheckboxGroupBaseProps, CheckboxGroupProps, CheckboxProps, CheckboxSize, CheckboxVariant };
@@ -0,0 +1,25 @@
1
+ import React from 'react';
2
+ import { CheckboxGroupProps } from './Checkbox.types.js';
3
+
4
+ /**
5
+ * Groups multiple Checkbox components with shared state management.
6
+ *
7
+ * Manages a `string[]` value, propagates `disabled` and `size` to children
8
+ * via React Context. Supports controlled and uncontrolled modes.
9
+ *
10
+ * @example
11
+ * ```tsx
12
+ * <CheckboxGroup
13
+ * label="Render passes"
14
+ * value={selected}
15
+ * onChange={setSelected}
16
+ * >
17
+ * <Checkbox value="diffuse" label="Diffuse" />
18
+ * <Checkbox value="specular" label="Specular" />
19
+ * <Checkbox value="shadow" label="Shadow" />
20
+ * </CheckboxGroup>
21
+ * ```
22
+ */
23
+ declare const CheckboxGroup: React.FC<CheckboxGroupProps>;
24
+
25
+ export { CheckboxGroup };
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import { CollapsibleProps } from './Collapsible.types.js';
3
+
4
+ declare const Collapsible: React.FC<CollapsibleProps>;
5
+
6
+ export { Collapsible };
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import { Prettify } from '../../../types/utilities.js';
3
+ import { BaseComponent, Size } from '../../../types/common.js';
4
+
5
+ type CollapsibleSize = Size;
6
+ interface CollapsibleBaseProps extends Omit<BaseComponent, 'onChange'> {
7
+ /** Content shown in the collapsible header/trigger */
8
+ trigger: React.ReactNode;
9
+ /** Whether expanded (controlled) */
10
+ open?: boolean;
11
+ /** Default expanded state (uncontrolled) @default false */
12
+ defaultOpen?: boolean;
13
+ /** Size @default "sm" */
14
+ size?: CollapsibleSize;
15
+ /** Custom indicator icon, or null to hide the indicator @default built-in chevron */
16
+ indicator?: React.ReactNode | null;
17
+ /** Whether disabled @default false */
18
+ disabled?: boolean;
19
+ /** Keep content in DOM when collapsed @default false */
20
+ keepMounted?: boolean;
21
+ /** Callback when open state changes */
22
+ onChange?: (open: boolean) => void;
23
+ /** Content to render when expanded */
24
+ children: React.ReactNode;
25
+ }
26
+ type CollapsibleProps = Prettify<CollapsibleBaseProps>;
27
+
28
+ export type { CollapsibleBaseProps, CollapsibleProps, CollapsibleSize };
@@ -0,0 +1,40 @@
1
+ import React from 'react';
2
+ import { LiteralUnion, Prettify } from '../../../types/utilities.js';
3
+ import { Size } from '../../../types/common.js';
4
+ import { Theme } from '../../../theme/types.js';
5
+
6
+ type IconSize = Size;
7
+ type IconColor = LiteralUnion<'primary' | 'secondary' | 'muted' | 'accent' | 'success' | 'warning' | 'error'>;
8
+ interface IconBaseProps {
9
+ children: React.ReactNode;
10
+ size?: IconSize;
11
+ color?: IconColor;
12
+ className?: string;
13
+ title?: string;
14
+ decorative?: boolean;
15
+ /**
16
+ * Custom CSS styles included in styled-components
17
+ * Can be an object of CSS properties or a function that receives theme and returns CSS properties
18
+ */
19
+ css?: React.CSSProperties | ((theme: Theme) => React.CSSProperties) | undefined;
20
+ /**
21
+ * Test identifier for automated testing
22
+ */
23
+ testId?: string;
24
+ ref?: React.Ref<SVGSVGElement>;
25
+ }
26
+ type IconProps = Prettify<IconBaseProps>;
27
+ declare const Icon: React.NamedExoticComponent<{
28
+ children: React.ReactNode;
29
+ size?: IconSize | undefined;
30
+ color?: IconColor | undefined;
31
+ className?: string | undefined;
32
+ title?: string | undefined;
33
+ decorative?: boolean | undefined;
34
+ css?: React.CSSProperties | ((theme: Theme) => React.CSSProperties) | undefined;
35
+ testId?: string | undefined;
36
+ ref?: React.Ref<SVGSVGElement> | undefined;
37
+ }>;
38
+
39
+ export { Icon };
40
+ export type { IconBaseProps, IconColor, IconProps, IconSize };