entangle-ui 0.3.0 → 0.4.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 (500) hide show
  1. package/CHANGELOG.md +117 -8
  2. package/README.md +98 -52
  3. package/dist/esm/_virtual/cjs.js +4 -0
  4. package/dist/esm/_virtual/cjs.js.map +1 -0
  5. package/dist/esm/_virtual/cssesc.js +4 -0
  6. package/dist/esm/_virtual/cssesc.js.map +1 -0
  7. package/dist/esm/assets/src/components/controls/CartesianPicker/CartesianPicker.css.ts.vanilla-Ccao9ycw.css +23 -0
  8. package/dist/esm/assets/src/components/controls/ColorPicker/ColorPicker.css.ts.vanilla-Do5nbdgO.css +341 -0
  9. package/dist/esm/assets/src/components/controls/CurveEditor/CurveEditor.css.ts.vanilla-Vn9SOx70.css +76 -0
  10. package/dist/esm/assets/src/components/controls/NumberInput/NumberInput.css.ts.vanilla-uGNr81xQ.css +158 -0
  11. package/dist/esm/assets/src/components/controls/Select/Select.css.ts.vanilla-D4C059Ua.css +225 -0
  12. package/dist/esm/assets/src/components/controls/Slider/Slider.css.ts.vanilla-C5SJ_7A1.css +173 -0
  13. package/dist/esm/assets/src/components/controls/TreeView/TreeNode.css.ts.vanilla-D3ylUhuW.css +150 -0
  14. package/dist/esm/assets/src/components/controls/TreeView/TreeView.css.ts.vanilla-CsG5-rWt.css +14 -0
  15. package/dist/esm/assets/src/components/controls/VectorInput/VectorInput.css.ts.vanilla-BJma3iQ4.css +102 -0
  16. package/dist/esm/assets/src/components/editor/ChatPanel/ChatPanel.css.ts.vanilla-DPIGnZ4A.css +701 -0
  17. package/dist/esm/assets/src/components/editor/PropertyInspector/PropertyGroup.css.ts.vanilla-Co4n5a98.css +25 -0
  18. package/dist/esm/assets/src/components/editor/PropertyInspector/PropertyPanel.css.ts.vanilla-RYv_XgOu.css +46 -0
  19. package/dist/esm/assets/src/components/editor/PropertyInspector/PropertyRow.css.ts.vanilla-C3YZnnHb.css +75 -0
  20. package/dist/esm/assets/src/components/editor/PropertyInspector/PropertySection.css.ts.vanilla-DJBtY_xk.css +105 -0
  21. package/dist/esm/assets/src/components/editor/ViewportGizmo/ViewportGizmo.css.ts.vanilla-CEs2H-Iv.css +43 -0
  22. package/dist/esm/assets/src/components/feedback/Dialog/Dialog.css.ts.vanilla-BrXTOHwS.css +169 -0
  23. package/dist/esm/assets/src/components/feedback/Toast/ToastContainer.css.ts.vanilla-tBLsZ_70.css +13 -0
  24. package/dist/esm/assets/src/components/feedback/Toast/ToastItem.css.ts.vanilla-D6UuPKAj.css +152 -0
  25. package/dist/esm/assets/src/components/form/FormHelperText.css.ts.vanilla-CXKd9jtx.css +11 -0
  26. package/dist/esm/assets/src/components/form/FormLabel.css.ts.vanilla-DHn6CB2v.css +17 -0
  27. package/dist/esm/assets/src/components/form/InputWrapper.css.ts.vanilla-Bl7u62PI.css +44 -0
  28. package/dist/esm/assets/src/components/layout/Accordion/Accordion.css.ts.vanilla-Ck5Yew0e.css +118 -0
  29. package/dist/esm/assets/src/components/layout/Flex/Flex.css.ts.vanilla-D7wY2gY6.css +142 -0
  30. package/dist/esm/assets/src/components/layout/Grid/Grid.css.ts.vanilla-gqfqUi29.css +213 -0
  31. package/dist/esm/assets/src/components/layout/PanelSurface/PanelSurface.css.ts.vanilla-HZvObe0l.css +86 -0
  32. package/dist/esm/assets/src/components/layout/ScrollArea/ScrollArea.css.ts.vanilla-UsyrfXTC.css +126 -0
  33. package/dist/esm/assets/src/components/layout/Spacer/Spacer.css.ts.vanilla-A-7aOV46.css +14 -0
  34. package/dist/esm/assets/src/components/layout/SplitPane/SplitPane.css.ts.vanilla-BFxdvwyI.css +44 -0
  35. package/dist/esm/assets/src/components/layout/Stack/Stack.css.ts.vanilla-DNZOFYiD.css +123 -0
  36. package/dist/esm/assets/src/components/navigation/Menu/Menu.css.ts.vanilla-DD0c5D10.css +67 -0
  37. package/dist/esm/assets/src/components/navigation/Tabs/Tabs.css.ts.vanilla-D7RGpDPC.css +247 -0
  38. package/dist/esm/assets/src/components/primitives/Button/Button.css.ts.vanilla-CT592JL7.css +98 -0
  39. package/dist/esm/assets/src/components/primitives/Checkbox/Checkbox.css.ts.vanilla-dvrGPiPs.css +124 -0
  40. package/dist/esm/assets/src/components/primitives/Collapsible/Collapsible.css.ts.vanilla-C1rYV-JT.css +73 -0
  41. package/dist/esm/assets/src/components/primitives/Icon/Icon.css.ts.vanilla-DIZ6dped.css +45 -0
  42. package/dist/esm/assets/src/components/primitives/IconButton/IconButton.css.ts.vanilla-C-xAQoR3.css +123 -0
  43. package/dist/esm/assets/src/components/primitives/Input/Input.css.ts.vanilla-De5ditYa.css +74 -0
  44. package/dist/esm/assets/src/components/primitives/Paper/Paper.css.ts.vanilla-B_tPWU80.css +67 -0
  45. package/dist/esm/assets/src/components/primitives/Popover/Popover.css.ts.vanilla-DW6aAr57.css +60 -0
  46. package/dist/esm/assets/src/components/primitives/Switch/Switch.css.ts.vanilla-CxqwUToB.css +100 -0
  47. package/dist/esm/assets/src/components/primitives/Text/Text.css.ts.vanilla-qTMvgKKC.css +126 -0
  48. package/dist/esm/assets/src/components/primitives/Tooltip/Tooltip.css.ts.vanilla-CrEFoLBX.css +71 -0
  49. package/dist/esm/assets/src/components/primitives/canvas/CanvasContainer.css.ts.vanilla-DR3zkEYQ.css +32 -0
  50. package/dist/esm/assets/src/components/shell/AppShell/AppShell.css.ts.vanilla-BYmtU0O_.css +97 -0
  51. package/dist/esm/assets/src/components/shell/FloatingPanel/FloatingPanel.css.ts.vanilla-1rIAXEFp.css +88 -0
  52. package/dist/esm/assets/src/components/shell/MenuBar/MenuBar.css.ts.vanilla-TgPcl4yA.css +120 -0
  53. package/dist/esm/assets/src/components/shell/StatusBar/StatusBar.css.ts.vanilla-BwO7oAZi.css +113 -0
  54. package/dist/esm/assets/src/components/shell/Toolbar/Toolbar.css.ts.vanilla-DPqftT18.css +97 -0
  55. package/dist/esm/assets/src/theme/darkTheme.css.ts.vanilla-V8lWHaQH.css +95 -0
  56. package/dist/esm/components/Icons/CheckIcon.js.map +1 -1
  57. package/dist/esm/components/Icons/ChevronDownIcon.js.map +1 -1
  58. package/dist/esm/components/Icons/ChevronUpIcon.js.map +1 -1
  59. package/dist/esm/components/Icons/CircleIcon.js.map +1 -1
  60. package/dist/esm/components/Icons/CloseIcon.js.map +1 -1
  61. package/dist/esm/components/Icons/EyeDropperIcon.js.map +1 -1
  62. package/dist/esm/components/Icons/TangentAlignedIcon.js.map +1 -1
  63. package/dist/esm/components/Icons/TangentAutoIcon.js.map +1 -1
  64. package/dist/esm/components/Icons/TangentFreeIcon.js.map +1 -1
  65. package/dist/esm/components/Icons/TangentLinearIcon.js.map +1 -1
  66. package/dist/esm/components/Icons/TangentMirroredIcon.js.map +1 -1
  67. package/dist/esm/components/Icons/TangentStepIcon.js.map +1 -1
  68. package/dist/esm/components/controls/CartesianPicker/CartesianPicker.css.js +9 -0
  69. package/dist/esm/components/controls/CartesianPicker/CartesianPicker.css.js.map +1 -0
  70. package/dist/esm/components/controls/CartesianPicker/CartesianPicker.js +99 -0
  71. package/dist/esm/components/controls/CartesianPicker/CartesianPicker.js.map +1 -0
  72. package/dist/esm/components/controls/CartesianPicker/useCartesianInteraction.js +230 -0
  73. package/dist/esm/components/controls/CartesianPicker/useCartesianInteraction.js.map +1 -0
  74. package/dist/esm/components/controls/CartesianPicker/useCartesianRenderer.js +122 -0
  75. package/dist/esm/components/controls/CartesianPicker/useCartesianRenderer.js.map +1 -0
  76. package/dist/esm/components/controls/ColorPicker/AlphaSlider.js +4 -41
  77. package/dist/esm/components/controls/ColorPicker/AlphaSlider.js.map +1 -1
  78. package/dist/esm/components/controls/ColorPicker/ColorArea.js +3 -32
  79. package/dist/esm/components/controls/ColorPicker/ColorArea.js.map +1 -1
  80. package/dist/esm/components/controls/ColorPicker/ColorInputs.js +3 -68
  81. package/dist/esm/components/controls/ColorPicker/ColorInputs.js.map +1 -1
  82. package/dist/esm/components/controls/ColorPicker/ColorPalette.js +5 -75
  83. package/dist/esm/components/controls/ColorPicker/ColorPalette.js.map +1 -1
  84. package/dist/esm/components/controls/ColorPicker/ColorPicker.css.js +34 -0
  85. package/dist/esm/components/controls/ColorPicker/ColorPicker.css.js.map +1 -0
  86. package/dist/esm/components/controls/ColorPicker/ColorPicker.js +4 -18
  87. package/dist/esm/components/controls/ColorPicker/ColorPicker.js.map +1 -1
  88. package/dist/esm/components/controls/ColorPicker/ColorPresets.js +5 -44
  89. package/dist/esm/components/controls/ColorPicker/ColorPresets.js.map +1 -1
  90. package/dist/esm/components/controls/ColorPicker/ColorSwatch.js +4 -58
  91. package/dist/esm/components/controls/ColorPicker/ColorSwatch.js.map +1 -1
  92. package/dist/esm/components/controls/ColorPicker/EyeDropper.js +4 -50
  93. package/dist/esm/components/controls/ColorPicker/EyeDropper.js.map +1 -1
  94. package/dist/esm/components/controls/ColorPicker/HueSlider.js +3 -32
  95. package/dist/esm/components/controls/ColorPicker/HueSlider.js.map +1 -1
  96. package/dist/esm/components/controls/ColorPicker/colorUtils.js.map +1 -1
  97. package/dist/esm/components/controls/ColorPicker/palettes/material.js.map +1 -1
  98. package/dist/esm/components/controls/ColorPicker/palettes/professional.js.map +1 -1
  99. package/dist/esm/components/controls/ColorPicker/palettes/tailwind.js.map +1 -1
  100. package/dist/esm/components/controls/ColorPicker/useColor.js +1 -0
  101. package/dist/esm/components/controls/ColorPicker/useColor.js.map +1 -1
  102. package/dist/esm/components/controls/CurveEditor/CurveCanvas.js +8 -30
  103. package/dist/esm/components/controls/CurveEditor/CurveCanvas.js.map +1 -1
  104. package/dist/esm/components/controls/CurveEditor/CurveEditor.css.js +17 -0
  105. package/dist/esm/components/controls/CurveEditor/CurveEditor.css.js.map +1 -0
  106. package/dist/esm/components/controls/CurveEditor/CurveEditor.js +17 -23
  107. package/dist/esm/components/controls/CurveEditor/CurveEditor.js.map +1 -1
  108. package/dist/esm/components/controls/CurveEditor/CurveToolbar.js +6 -23
  109. package/dist/esm/components/controls/CurveEditor/CurveToolbar.js.map +1 -1
  110. package/dist/esm/components/controls/CurveEditor/curvePresets.js.map +1 -1
  111. package/dist/esm/components/controls/CurveEditor/curveUtils.js +7 -16
  112. package/dist/esm/components/controls/CurveEditor/curveUtils.js.map +1 -1
  113. package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js +1 -0
  114. package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js.map +1 -1
  115. package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js +39 -193
  116. package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js.map +1 -1
  117. package/dist/esm/components/controls/NumberInput/NumberInput.css.js +17 -0
  118. package/dist/esm/components/controls/NumberInput/NumberInput.css.js.map +1 -0
  119. package/dist/esm/components/controls/NumberInput/NumberInput.js +22 -166
  120. package/dist/esm/components/controls/NumberInput/NumberInput.js.map +1 -1
  121. package/dist/esm/components/controls/NumberInput/useNumberInput.js +1 -1
  122. package/dist/esm/components/controls/NumberInput/useNumberInput.js.map +1 -1
  123. package/dist/esm/components/controls/Select/Select.css.js +18 -0
  124. package/dist/esm/components/controls/Select/Select.css.js.map +1 -0
  125. package/dist/esm/components/controls/Select/Select.js +29 -235
  126. package/dist/esm/components/controls/Select/Select.js.map +1 -1
  127. package/dist/esm/components/controls/Slider/Slider.css.js +17 -0
  128. package/dist/esm/components/controls/Slider/Slider.css.js.map +1 -0
  129. package/dist/esm/components/controls/Slider/Slider.js +12 -159
  130. package/dist/esm/components/controls/Slider/Slider.js.map +1 -1
  131. package/dist/esm/components/controls/TreeView/TreeNode.css.js +15 -0
  132. package/dist/esm/components/controls/TreeView/TreeNode.css.js.map +1 -0
  133. package/dist/esm/components/controls/TreeView/TreeNode.js +18 -90
  134. package/dist/esm/components/controls/TreeView/TreeNode.js.map +1 -1
  135. package/dist/esm/components/controls/TreeView/TreeView.css.js +8 -0
  136. package/dist/esm/components/controls/TreeView/TreeView.css.js.map +1 -0
  137. package/dist/esm/components/controls/TreeView/TreeView.js +11 -18
  138. package/dist/esm/components/controls/TreeView/TreeView.js.map +1 -1
  139. package/dist/esm/components/controls/TreeView/useTreeState.js +1 -0
  140. package/dist/esm/components/controls/TreeView/useTreeState.js.map +1 -1
  141. package/dist/esm/components/controls/VectorInput/VectorInput.css.js +13 -0
  142. package/dist/esm/components/controls/VectorInput/VectorInput.css.js.map +1 -0
  143. package/dist/esm/components/controls/VectorInput/VectorInput.js +11 -83
  144. package/dist/esm/components/controls/VectorInput/VectorInput.js.map +1 -1
  145. package/dist/esm/components/editor/ChatPanel/ChatActionBar.js +13 -0
  146. package/dist/esm/components/editor/ChatPanel/ChatActionBar.js.map +1 -0
  147. package/dist/esm/components/editor/ChatPanel/ChatAttachment.js +36 -0
  148. package/dist/esm/components/editor/ChatPanel/ChatAttachment.js.map +1 -0
  149. package/dist/esm/components/editor/ChatPanel/ChatBubble.js +13 -0
  150. package/dist/esm/components/editor/ChatPanel/ChatBubble.js.map +1 -0
  151. package/dist/esm/components/editor/ChatPanel/ChatCodeBlock.js +34 -0
  152. package/dist/esm/components/editor/ChatPanel/ChatCodeBlock.js.map +1 -0
  153. package/dist/esm/components/editor/ChatPanel/ChatContextChip.js +17 -0
  154. package/dist/esm/components/editor/ChatPanel/ChatContextChip.js.map +1 -0
  155. package/dist/esm/components/editor/ChatPanel/ChatEmptyState.js +16 -0
  156. package/dist/esm/components/editor/ChatPanel/ChatEmptyState.js.map +1 -0
  157. package/dist/esm/components/editor/ChatPanel/ChatInput.js +67 -0
  158. package/dist/esm/components/editor/ChatPanel/ChatInput.js.map +1 -0
  159. package/dist/esm/components/editor/ChatPanel/ChatInputToolbar.js +13 -0
  160. package/dist/esm/components/editor/ChatPanel/ChatInputToolbar.js.map +1 -0
  161. package/dist/esm/components/editor/ChatPanel/ChatMessage.js +37 -0
  162. package/dist/esm/components/editor/ChatPanel/ChatMessage.js.map +1 -0
  163. package/dist/esm/components/editor/ChatPanel/ChatMessageList.js +32 -0
  164. package/dist/esm/components/editor/ChatPanel/ChatMessageList.js.map +1 -0
  165. package/dist/esm/components/editor/ChatPanel/ChatPanel.css.js +72 -0
  166. package/dist/esm/components/editor/ChatPanel/ChatPanel.css.js.map +1 -0
  167. package/dist/esm/components/editor/ChatPanel/ChatPanel.js +13 -0
  168. package/dist/esm/components/editor/ChatPanel/ChatPanel.js.map +1 -0
  169. package/dist/esm/components/editor/ChatPanel/ChatToolCall.js +35 -0
  170. package/dist/esm/components/editor/ChatPanel/ChatToolCall.js.map +1 -0
  171. package/dist/esm/components/editor/ChatPanel/ChatTypingIndicator.js +16 -0
  172. package/dist/esm/components/editor/ChatPanel/ChatTypingIndicator.js.map +1 -0
  173. package/dist/esm/components/editor/ChatPanel/useChatInput.js +60 -0
  174. package/dist/esm/components/editor/ChatPanel/useChatInput.js.map +1 -0
  175. package/dist/esm/components/editor/ChatPanel/useChatMessages.js +47 -0
  176. package/dist/esm/components/editor/ChatPanel/useChatMessages.js.map +1 -0
  177. package/dist/esm/components/editor/ChatPanel/useChatScroll.js +71 -0
  178. package/dist/esm/components/editor/ChatPanel/useChatScroll.js.map +1 -0
  179. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.css.js +10 -0
  180. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.css.js.map +1 -0
  181. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js +14 -34
  182. package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js.map +1 -1
  183. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.css.js +13 -0
  184. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.css.js.map +1 -0
  185. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js +35 -64
  186. package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js.map +1 -1
  187. package/dist/esm/components/editor/PropertyInspector/PropertyRow.css.js +15 -0
  188. package/dist/esm/components/editor/PropertyInspector/PropertyRow.css.js.map +1 -0
  189. package/dist/esm/components/editor/PropertyInspector/PropertyRow.js +34 -114
  190. package/dist/esm/components/editor/PropertyInspector/PropertyRow.js.map +1 -1
  191. package/dist/esm/components/editor/PropertyInspector/PropertySection.css.js +15 -0
  192. package/dist/esm/components/editor/PropertyInspector/PropertySection.css.js.map +1 -0
  193. package/dist/esm/components/editor/PropertyInspector/PropertySection.js +15 -100
  194. package/dist/esm/components/editor/PropertyInspector/PropertySection.js.map +1 -1
  195. package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js +1 -0
  196. package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js.map +1 -1
  197. package/dist/esm/components/editor/ViewportGizmo/ViewportGizmo.css.js +10 -0
  198. package/dist/esm/components/editor/ViewportGizmo/ViewportGizmo.css.js.map +1 -0
  199. package/dist/esm/components/editor/ViewportGizmo/ViewportGizmo.js +90 -0
  200. package/dist/esm/components/editor/ViewportGizmo/ViewportGizmo.js.map +1 -0
  201. package/dist/esm/components/editor/ViewportGizmo/gizmoMath.js +259 -0
  202. package/dist/esm/components/editor/ViewportGizmo/gizmoMath.js.map +1 -0
  203. package/dist/esm/components/editor/ViewportGizmo/useGizmoInteraction.js +250 -0
  204. package/dist/esm/components/editor/ViewportGizmo/useGizmoInteraction.js.map +1 -0
  205. package/dist/esm/components/editor/ViewportGizmo/useGizmoRenderer.js +191 -0
  206. package/dist/esm/components/editor/ViewportGizmo/useGizmoRenderer.js.map +1 -0
  207. package/dist/esm/components/feedback/Dialog/Dialog.css.js +16 -0
  208. package/dist/esm/components/feedback/Dialog/Dialog.css.js.map +1 -0
  209. package/dist/esm/components/feedback/Dialog/Dialog.js +6 -4
  210. package/dist/esm/components/feedback/Dialog/Dialog.js.map +1 -1
  211. package/dist/esm/components/feedback/Dialog/DialogBody.js +5 -15
  212. package/dist/esm/components/feedback/Dialog/DialogBody.js.map +1 -1
  213. package/dist/esm/components/feedback/Dialog/DialogClose.js +1 -0
  214. package/dist/esm/components/feedback/Dialog/DialogClose.js.map +1 -1
  215. package/dist/esm/components/feedback/Dialog/DialogFooter.js +5 -24
  216. package/dist/esm/components/feedback/Dialog/DialogFooter.js.map +1 -1
  217. package/dist/esm/components/feedback/Dialog/DialogHeader.js +5 -63
  218. package/dist/esm/components/feedback/Dialog/DialogHeader.js.map +1 -1
  219. package/dist/esm/components/feedback/Dialog/useDialogAnimation.js +2 -1
  220. package/dist/esm/components/feedback/Dialog/useDialogAnimation.js.map +1 -1
  221. package/dist/esm/components/feedback/Dialog/useFocusTrap.js +1 -0
  222. package/dist/esm/components/feedback/Dialog/useFocusTrap.js.map +1 -1
  223. package/dist/esm/components/feedback/Toast/ToastContainer.css.js +10 -0
  224. package/dist/esm/components/feedback/Toast/ToastContainer.css.js.map +1 -0
  225. package/dist/esm/components/feedback/Toast/ToastContainer.js +12 -10
  226. package/dist/esm/components/feedback/Toast/ToastContainer.js.map +1 -1
  227. package/dist/esm/components/feedback/Toast/ToastItem.css.js +16 -0
  228. package/dist/esm/components/feedback/Toast/ToastItem.css.js.map +1 -0
  229. package/dist/esm/components/feedback/Toast/ToastItem.js +8 -138
  230. package/dist/esm/components/feedback/Toast/ToastItem.js.map +1 -1
  231. package/dist/esm/components/feedback/Toast/ToastProvider.js +1 -0
  232. package/dist/esm/components/feedback/Toast/ToastProvider.js.map +1 -1
  233. package/dist/esm/components/feedback/Toast/useToast.js +1 -0
  234. package/dist/esm/components/feedback/Toast/useToast.js.map +1 -1
  235. package/dist/esm/components/form/FormHelperText.css.js +7 -0
  236. package/dist/esm/components/form/FormHelperText.css.js.map +1 -0
  237. package/dist/esm/components/form/FormHelperText.js +5 -15
  238. package/dist/esm/components/form/FormHelperText.js.map +1 -1
  239. package/dist/esm/components/form/FormLabel.css.js +8 -0
  240. package/dist/esm/components/form/FormLabel.css.js.map +1 -0
  241. package/dist/esm/components/form/FormLabel.js +5 -21
  242. package/dist/esm/components/form/FormLabel.js.map +1 -1
  243. package/dist/esm/components/form/InputWrapper.css.js +7 -0
  244. package/dist/esm/components/form/InputWrapper.css.js.map +1 -0
  245. package/dist/esm/components/form/InputWrapper.js +6 -74
  246. package/dist/esm/components/form/InputWrapper.js.map +1 -1
  247. package/dist/esm/components/layout/Accordion/Accordion.css.js +20 -0
  248. package/dist/esm/components/layout/Accordion/Accordion.css.js.map +1 -0
  249. package/dist/esm/components/layout/Accordion/Accordion.js +12 -11
  250. package/dist/esm/components/layout/Accordion/Accordion.js.map +1 -1
  251. package/dist/esm/components/layout/Accordion/AccordionContent.js +4 -20
  252. package/dist/esm/components/layout/Accordion/AccordionContent.js.map +1 -1
  253. package/dist/esm/components/layout/Accordion/AccordionItem.js +4 -7
  254. package/dist/esm/components/layout/Accordion/AccordionItem.js.map +1 -1
  255. package/dist/esm/components/layout/Accordion/AccordionTrigger.js +12 -96
  256. package/dist/esm/components/layout/Accordion/AccordionTrigger.js.map +1 -1
  257. package/dist/esm/components/layout/Flex/Flex.css.js +11 -0
  258. package/dist/esm/components/layout/Flex/Flex.css.js.map +1 -0
  259. package/dist/esm/components/layout/Flex/Flex.js +47 -73
  260. package/dist/esm/components/layout/Flex/Flex.js.map +1 -1
  261. package/dist/esm/components/layout/Grid/Grid.css.js +9 -0
  262. package/dist/esm/components/layout/Grid/Grid.css.js.map +1 -0
  263. package/dist/esm/components/layout/Grid/Grid.js +39 -64
  264. package/dist/esm/components/layout/Grid/Grid.js.map +1 -1
  265. package/dist/esm/components/layout/PanelSurface/PanelSurface.css.js +16 -0
  266. package/dist/esm/components/layout/PanelSurface/PanelSurface.css.js.map +1 -0
  267. package/dist/esm/components/layout/PanelSurface/PanelSurface.js +23 -78
  268. package/dist/esm/components/layout/PanelSurface/PanelSurface.js.map +1 -1
  269. package/dist/esm/components/layout/ScrollArea/ScrollArea.css.js +27 -0
  270. package/dist/esm/components/layout/ScrollArea/ScrollArea.css.js.map +1 -0
  271. package/dist/esm/components/layout/ScrollArea/ScrollArea.js +35 -134
  272. package/dist/esm/components/layout/ScrollArea/ScrollArea.js.map +1 -1
  273. package/dist/esm/components/layout/Spacer/Spacer.css.js +8 -0
  274. package/dist/esm/components/layout/Spacer/Spacer.css.js.map +1 -0
  275. package/dist/esm/components/layout/Spacer/Spacer.js +13 -31
  276. package/dist/esm/components/layout/Spacer/Spacer.js.map +1 -1
  277. package/dist/esm/components/layout/SplitPane/SplitPane.css.js +10 -0
  278. package/dist/esm/components/layout/SplitPane/SplitPane.css.js.map +1 -0
  279. package/dist/esm/components/layout/SplitPane/SplitPane.js +12 -36
  280. package/dist/esm/components/layout/SplitPane/SplitPane.js.map +1 -1
  281. package/dist/esm/components/layout/SplitPane/SplitPanePanel.js +5 -8
  282. package/dist/esm/components/layout/SplitPane/SplitPanePanel.js.map +1 -1
  283. package/dist/esm/components/layout/Stack/Stack.css.js +8 -0
  284. package/dist/esm/components/layout/Stack/Stack.css.js.map +1 -0
  285. package/dist/esm/components/layout/Stack/Stack.js +36 -65
  286. package/dist/esm/components/layout/Stack/Stack.js.map +1 -1
  287. package/dist/esm/components/navigation/ContextMenu/ContextMenu.js +6 -4
  288. package/dist/esm/components/navigation/ContextMenu/ContextMenu.js.map +1 -1
  289. package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js +1 -0
  290. package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js.map +1 -1
  291. package/dist/esm/components/navigation/Menu/Menu.css.js +16 -0
  292. package/dist/esm/components/navigation/Menu/Menu.css.js.map +1 -0
  293. package/dist/esm/components/navigation/Menu/Menu.helpers.js +9 -7
  294. package/dist/esm/components/navigation/Menu/Menu.helpers.js.map +1 -1
  295. package/dist/esm/components/navigation/Menu/Menu.js +6 -4
  296. package/dist/esm/components/navigation/Menu/Menu.js.map +1 -1
  297. package/dist/esm/components/navigation/Menu/useMenu.js +1 -0
  298. package/dist/esm/components/navigation/Menu/useMenu.js.map +1 -1
  299. package/dist/esm/components/navigation/Tabs/Tab.js +31 -174
  300. package/dist/esm/components/navigation/Tabs/Tab.js.map +1 -1
  301. package/dist/esm/components/navigation/Tabs/TabList.js +5 -56
  302. package/dist/esm/components/navigation/Tabs/TabList.js.map +1 -1
  303. package/dist/esm/components/navigation/Tabs/TabPanel.js +4 -12
  304. package/dist/esm/components/navigation/Tabs/TabPanel.js.map +1 -1
  305. package/dist/esm/components/navigation/Tabs/Tabs.css.js +26 -0
  306. package/dist/esm/components/navigation/Tabs/Tabs.css.js.map +1 -0
  307. package/dist/esm/components/navigation/Tabs/Tabs.js +6 -13
  308. package/dist/esm/components/navigation/Tabs/Tabs.js.map +1 -1
  309. package/dist/esm/components/primitives/BaseButton/BaseButton.js +1 -0
  310. package/dist/esm/components/primitives/BaseButton/BaseButton.js.map +1 -1
  311. package/dist/esm/components/primitives/Button/Button.css.js +9 -0
  312. package/dist/esm/components/primitives/Button/Button.css.js.map +1 -0
  313. package/dist/esm/components/primitives/Button/Button.js +5 -149
  314. package/dist/esm/components/primitives/Button/Button.js.map +1 -1
  315. package/dist/esm/components/primitives/Checkbox/Checkbox.css.js +14 -0
  316. package/dist/esm/components/primitives/Checkbox/Checkbox.css.js.map +1 -0
  317. package/dist/esm/components/primitives/Checkbox/Checkbox.js +20 -112
  318. package/dist/esm/components/primitives/Checkbox/Checkbox.js.map +1 -1
  319. package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js +10 -17
  320. package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js.map +1 -1
  321. package/dist/esm/components/primitives/Collapsible/Collapsible.css.js +18 -0
  322. package/dist/esm/components/primitives/Collapsible/Collapsible.css.js.map +1 -0
  323. package/dist/esm/components/primitives/Collapsible/Collapsible.js +45 -83
  324. package/dist/esm/components/primitives/Collapsible/Collapsible.js.map +1 -1
  325. package/dist/esm/components/primitives/Icon/Icon.css.js +7 -0
  326. package/dist/esm/components/primitives/Icon/Icon.css.js.map +1 -0
  327. package/dist/esm/components/primitives/Icon/Icon.js +23 -55
  328. package/dist/esm/components/primitives/Icon/Icon.js.map +1 -1
  329. package/dist/esm/components/primitives/IconButton/IconButton.css.js +8 -0
  330. package/dist/esm/components/primitives/IconButton/IconButton.css.js.map +1 -0
  331. package/dist/esm/components/primitives/IconButton/IconButton.js +10 -170
  332. package/dist/esm/components/primitives/IconButton/IconButton.js.map +1 -1
  333. package/dist/esm/components/primitives/Input/Input.css.js +12 -0
  334. package/dist/esm/components/primitives/Input/Input.css.js.map +1 -0
  335. package/dist/esm/components/primitives/Input/Input.js +11 -79
  336. package/dist/esm/components/primitives/Input/Input.js.map +1 -1
  337. package/dist/esm/components/primitives/Paper/Paper.css.js +7 -0
  338. package/dist/esm/components/primitives/Paper/Paper.css.js.map +1 -0
  339. package/dist/esm/components/primitives/Paper/Paper.js +18 -90
  340. package/dist/esm/components/primitives/Paper/Paper.js.map +1 -1
  341. package/dist/esm/components/primitives/Popover/Popover.css.js +8 -0
  342. package/dist/esm/components/primitives/Popover/Popover.css.js.map +1 -0
  343. package/dist/esm/components/primitives/Popover/Popover.js +1 -0
  344. package/dist/esm/components/primitives/Popover/Popover.js.map +1 -1
  345. package/dist/esm/components/primitives/Popover/PopoverClose.js +4 -32
  346. package/dist/esm/components/primitives/Popover/PopoverClose.js.map +1 -1
  347. package/dist/esm/components/primitives/Popover/PopoverContent.js +19 -45
  348. package/dist/esm/components/primitives/Popover/PopoverContent.js.map +1 -1
  349. package/dist/esm/components/primitives/Popover/PopoverTrigger.js +1 -0
  350. package/dist/esm/components/primitives/Popover/PopoverTrigger.js.map +1 -1
  351. package/dist/esm/components/primitives/Switch/Switch.css.js +15 -0
  352. package/dist/esm/components/primitives/Switch/Switch.css.js.map +1 -0
  353. package/dist/esm/components/primitives/Switch/Switch.js +29 -122
  354. package/dist/esm/components/primitives/Switch/Switch.js.map +1 -1
  355. package/dist/esm/components/primitives/Text/Text.css.js +9 -0
  356. package/dist/esm/components/primitives/Text/Text.css.js.map +1 -0
  357. package/dist/esm/components/primitives/Text/Text.js +20 -126
  358. package/dist/esm/components/primitives/Text/Text.js.map +1 -1
  359. package/dist/esm/components/primitives/Tooltip/Arrow.js +8 -41
  360. package/dist/esm/components/primitives/Tooltip/Arrow.js.map +1 -1
  361. package/dist/esm/components/primitives/Tooltip/Tooltip.css.js +9 -0
  362. package/dist/esm/components/primitives/Tooltip/Tooltip.css.js.map +1 -0
  363. package/dist/esm/components/primitives/Tooltip/Tooltip.js +20 -79
  364. package/dist/esm/components/primitives/Tooltip/Tooltip.js.map +1 -1
  365. package/dist/esm/components/primitives/Tooltip/utils.js.map +1 -1
  366. package/dist/esm/components/primitives/canvas/CanvasContainer.css.js +10 -0
  367. package/dist/esm/components/primitives/canvas/CanvasContainer.css.js.map +1 -0
  368. package/dist/esm/components/primitives/canvas/CanvasContainer.js +32 -0
  369. package/dist/esm/components/primitives/canvas/CanvasContainer.js.map +1 -0
  370. package/dist/esm/components/primitives/canvas/canvasCoords.js +51 -0
  371. package/dist/esm/components/primitives/canvas/canvasCoords.js.map +1 -0
  372. package/dist/esm/components/primitives/canvas/canvasDrawing.js +251 -0
  373. package/dist/esm/components/primitives/canvas/canvasDrawing.js.map +1 -0
  374. package/dist/esm/components/primitives/canvas/canvasTheme.js +43 -0
  375. package/dist/esm/components/primitives/canvas/canvasTheme.js.map +1 -0
  376. package/dist/esm/components/primitives/canvas/useCanvasRenderer.js +26 -0
  377. package/dist/esm/components/primitives/canvas/useCanvasRenderer.js.map +1 -0
  378. package/dist/esm/components/shell/AppShell/AppShell.css.js +13 -0
  379. package/dist/esm/components/shell/AppShell/AppShell.css.js.map +1 -0
  380. package/dist/esm/components/shell/AppShell/AppShell.js +16 -101
  381. package/dist/esm/components/shell/AppShell/AppShell.js.map +1 -1
  382. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.css.js +18 -0
  383. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.css.js.map +1 -0
  384. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js +20 -97
  385. package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js.map +1 -1
  386. package/dist/esm/components/shell/MenuBar/MenuBar.css.js +16 -0
  387. package/dist/esm/components/shell/MenuBar/MenuBar.css.js.map +1 -0
  388. package/dist/esm/components/shell/MenuBar/MenuBar.js +14 -139
  389. package/dist/esm/components/shell/MenuBar/MenuBar.js.map +1 -1
  390. package/dist/esm/components/shell/StatusBar/StatusBar.css.js +11 -0
  391. package/dist/esm/components/shell/StatusBar/StatusBar.css.js.map +1 -0
  392. package/dist/esm/components/shell/StatusBar/StatusBar.js +11 -107
  393. package/dist/esm/components/shell/StatusBar/StatusBar.js.map +1 -1
  394. package/dist/esm/components/shell/Toolbar/Toolbar.css.js +11 -0
  395. package/dist/esm/components/shell/Toolbar/Toolbar.css.js.map +1 -0
  396. package/dist/esm/components/shell/Toolbar/Toolbar.js +21 -97
  397. package/dist/esm/components/shell/Toolbar/Toolbar.js.map +1 -1
  398. package/dist/esm/context/KeyboardContext.js +1 -0
  399. package/dist/esm/context/KeyboardContext.js.map +1 -1
  400. package/dist/esm/index.js +26 -3
  401. package/dist/esm/index.js.map +1 -1
  402. package/dist/esm/node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js +15 -0
  403. package/dist/esm/node_modules/@vanilla-extract/css/adapter/dist/vanilla-extract-css-adapter.esm.js.map +1 -0
  404. package/dist/esm/node_modules/@vanilla-extract/css/dist/transformCss-fd0786e1.esm.js +128 -0
  405. package/dist/esm/node_modules/@vanilla-extract/css/dist/transformCss-fd0786e1.esm.js.map +1 -0
  406. package/dist/esm/node_modules/@vanilla-extract/css/dist/vanilla-extract-css.esm.js +70 -0
  407. package/dist/esm/node_modules/@vanilla-extract/css/dist/vanilla-extract-css.esm.js.map +1 -0
  408. package/dist/esm/node_modules/@vanilla-extract/css/node_modules/lru-cache/dist/esm/index.js +1543 -0
  409. package/dist/esm/node_modules/@vanilla-extract/css/node_modules/lru-cache/dist/esm/index.js.map +1 -0
  410. package/dist/esm/node_modules/@vanilla-extract/dynamic/dist/vanilla-extract-dynamic.esm.js +25 -0
  411. package/dist/esm/node_modules/@vanilla-extract/dynamic/dist/vanilla-extract-dynamic.esm.js.map +1 -0
  412. package/dist/esm/node_modules/@vanilla-extract/private/dist/vanilla-extract-private.esm.js +10 -0
  413. package/dist/esm/node_modules/@vanilla-extract/private/dist/vanilla-extract-private.esm.js.map +1 -0
  414. package/dist/esm/node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js +112 -0
  415. package/dist/esm/node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js.map +1 -0
  416. package/dist/esm/node_modules/cssesc/cssesc.js +120 -0
  417. package/dist/esm/node_modules/cssesc/cssesc.js.map +1 -0
  418. package/dist/esm/node_modules/dedent/dist/dedent.js +98 -0
  419. package/dist/esm/node_modules/dedent/dist/dedent.js.map +1 -0
  420. package/dist/esm/node_modules/deepmerge/dist/cjs.js +143 -0
  421. package/dist/esm/node_modules/deepmerge/dist/cjs.js.map +1 -0
  422. package/dist/esm/theme/ThemeProvider.js +13 -7
  423. package/dist/esm/theme/ThemeProvider.js.map +1 -1
  424. package/dist/esm/theme/VanillaThemeProvider.js +26 -0
  425. package/dist/esm/theme/VanillaThemeProvider.js.map +1 -0
  426. package/dist/esm/theme/contract.css.js +4 -0
  427. package/dist/esm/theme/contract.css.js.map +1 -0
  428. package/dist/esm/theme/darkTheme.css.js +6 -0
  429. package/dist/esm/theme/darkTheme.css.js.map +1 -0
  430. package/dist/esm/utils/cx.js +14 -0
  431. package/dist/esm/utils/cx.js.map +1 -0
  432. package/dist/esm/utils/mathExpression.js.map +1 -1
  433. package/dist/esm/utils/mathUtils.js.map +1 -1
  434. package/dist/types/components/controls/CartesianPicker/CartesianPicker.d.ts +6 -0
  435. package/dist/types/components/controls/CartesianPicker/CartesianPicker.types.d.ts +163 -0
  436. package/dist/types/components/controls/CurveEditor/CurveEditor.types.d.ts +5 -13
  437. package/dist/types/components/controls/CurveEditor/curveUtils.d.ts +3 -1
  438. package/dist/types/components/controls/Select/Select.d.ts +1 -1
  439. package/dist/types/components/editor/ChatPanel/ChatActionBar.d.ts +288 -0
  440. package/dist/types/components/editor/ChatPanel/ChatAttachment.d.ts +292 -0
  441. package/dist/types/components/editor/ChatPanel/ChatBubble.d.ts +289 -0
  442. package/dist/types/components/editor/ChatPanel/ChatCodeBlock.d.ts +294 -0
  443. package/dist/types/components/editor/ChatPanel/ChatContextChip.d.ts +292 -0
  444. package/dist/types/components/editor/ChatPanel/ChatEmptyState.d.ts +292 -0
  445. package/dist/types/components/editor/ChatPanel/ChatInput.d.ts +300 -0
  446. package/dist/types/components/editor/ChatPanel/ChatInputToolbar.d.ts +288 -0
  447. package/dist/types/components/editor/ChatPanel/ChatMessage.d.ts +294 -0
  448. package/dist/types/components/editor/ChatPanel/ChatMessageList.d.ts +293 -0
  449. package/dist/types/components/editor/ChatPanel/ChatPanel.d.ts +290 -0
  450. package/dist/types/components/editor/ChatPanel/ChatPanel.types.d.ts +409 -0
  451. package/dist/types/components/editor/ChatPanel/ChatToolCall.d.ts +294 -0
  452. package/dist/types/components/editor/ChatPanel/ChatTypingIndicator.d.ts +291 -0
  453. package/dist/types/components/editor/ChatPanel/useChatInput.d.ts +5 -0
  454. package/dist/types/components/editor/ChatPanel/useChatMessages.d.ts +5 -0
  455. package/dist/types/components/editor/ChatPanel/useChatScroll.d.ts +5 -0
  456. package/dist/types/components/editor/ViewportGizmo/ViewportGizmo.d.ts +6 -0
  457. package/dist/types/components/editor/ViewportGizmo/ViewportGizmo.types.d.ts +146 -0
  458. package/dist/types/components/editor/ViewportGizmo/gizmoMath.d.ts +73 -0
  459. package/dist/types/components/form/FormHelperText.d.ts +13 -15
  460. package/dist/types/components/form/FormLabel.d.ts +13 -15
  461. package/dist/types/components/form/InputWrapper.d.ts +13 -15
  462. package/dist/types/components/layout/PanelSurface/PanelSurface.d.ts +54 -59
  463. package/dist/types/components/layout/Spacer/Spacer.d.ts +17 -19
  464. package/dist/types/components/navigation/Menu/Menu.types.d.ts +1 -1
  465. package/dist/types/components/primitives/Button/Button.d.ts +30 -18
  466. package/dist/types/components/primitives/Icon/Icon.d.ts +0 -7
  467. package/dist/types/components/primitives/IconButton/IconButton.d.ts +26 -19
  468. package/dist/types/components/primitives/Input/Input.d.ts +7 -2
  469. package/dist/types/components/primitives/Paper/Paper.d.ts +23 -21
  470. package/dist/types/components/primitives/Switch/Switch.d.ts +7 -2
  471. package/dist/types/components/primitives/Text/Text.d.ts +20 -18
  472. package/dist/types/components/primitives/Tooltip/Tooltip.d.ts +7 -3
  473. package/dist/types/components/primitives/Tooltip/types.d.ts +1 -1
  474. package/dist/types/components/primitives/canvas/canvas.types.d.ts +27 -0
  475. package/dist/types/components/shell/AppShell/AppShell.d.ts +86 -92
  476. package/dist/types/components/shell/MenuBar/MenuBar.d.ts +66 -72
  477. package/dist/types/components/shell/StatusBar/StatusBar.d.ts +42 -46
  478. package/dist/types/components/shell/Toolbar/Toolbar.d.ts +77 -84
  479. package/dist/types/index.d.ts +29 -6
  480. package/dist/types/theme/ThemeProvider.d.ts +9 -2
  481. package/dist/types/theme/VanillaThemeProvider.d.ts +34 -0
  482. package/dist/types/theme/contract.css.d.ts +164 -0
  483. package/dist/types/theme/{tokens.d.ts → darkTheme.css.d.ts} +43 -39
  484. package/dist/types/types/common.d.ts +1 -8
  485. package/dist/types/utils/cx.d.ts +11 -0
  486. package/package.json +34 -30
  487. package/dist/esm/components/feedback/Dialog/Dialog.styled.js +0 -80
  488. package/dist/esm/components/feedback/Dialog/Dialog.styled.js.map +0 -1
  489. package/dist/esm/components/navigation/Menu/Menu.styled.js +0 -83
  490. package/dist/esm/components/navigation/Menu/Menu.styled.js.map +0 -1
  491. package/dist/esm/theme/createTheme.js +0 -10
  492. package/dist/esm/theme/createTheme.js.map +0 -1
  493. package/dist/esm/theme/tokens.js +0 -144
  494. package/dist/esm/theme/tokens.js.map +0 -1
  495. package/dist/esm/utils/objects.js +0 -22
  496. package/dist/esm/utils/objects.js.map +0 -1
  497. package/dist/esm/utils/styledUtils.js +0 -81
  498. package/dist/esm/utils/styledUtils.js.map +0 -1
  499. package/dist/types/theme/createTheme.d.ts +0 -6
  500. package/dist/types/theme/types.d.ts +0 -7
@@ -1,133 +1,18 @@
1
+ "use client";
1
2
  import { jsxs, jsx } from 'react/jsx-runtime';
2
3
  import { useId, useState, useCallback } from 'react';
3
- import styled from '@emotion/styled';
4
- import { processCss } from '../../../utils/styledUtils.js';
4
+ import { assignInlineVars } from '../../../node_modules/@vanilla-extract/dynamic/dist/vanilla-extract-dynamic.esm.js';
5
5
  import '../../form/FormLabel.js';
6
6
  import { FormHelperText } from '../../form/FormHelperText.js';
7
7
  import '../../form/InputWrapper.js';
8
+ import { cx } from '../../../utils/cx.js';
9
+ import { trackHeightVar, trackWidthVar, thumbTranslateVar, thumbDiameterVar, thumbRecipe, trackRecipe, labelTextStyle, switchRowRecipe, switchContainerStyle } from './Switch.css.js';
8
10
 
9
11
  const SIZE_MAP = {
10
12
  sm: { trackW: 28, trackH: 14, thumbDiameter: 10, offset: 2 },
11
13
  md: { trackW: 34, trackH: 18, thumbDiameter: 14, offset: 2 },
12
14
  lg: { trackW: 42, trackH: 22, thumbDiameter: 18, offset: 2 },
13
15
  };
14
- const FONT_SIZE_MAP = {
15
- sm: 'xs',
16
- md: 'sm',
17
- lg: 'md',
18
- };
19
- // --- Styled components ---
20
- const StyledSwitchContainer = styled.div `
21
- display: flex;
22
- flex-direction: column;
23
- `;
24
- const StyledSwitchRow = styled.label `
25
- display: inline-flex;
26
- align-items: center;
27
- gap: ${props => props.theme.spacing.sm}px;
28
- cursor: ${props => (props.$disabled ? 'not-allowed' : 'pointer')};
29
- flex-direction: ${props => (props.$labelPosition === 'left' ? 'row' : 'row')};
30
- font-size: ${props => props.theme.typography.fontSize[FONT_SIZE_MAP[props.$size]]}px;
31
- color: ${props => props.$disabled
32
- ? props.theme.colors.text.disabled
33
- : props.theme.colors.text.secondary};
34
- line-height: ${props => props.theme.typography.lineHeight.normal};
35
- user-select: none;
36
- `;
37
- const StyledLabelText = styled.span `
38
- order: ${props => props.$order};
39
- `;
40
- const StyledTrack = styled.button `
41
- /* Reset */
42
- padding: 0;
43
- margin: 0;
44
- font: inherit;
45
- outline: none;
46
- cursor: ${props => (props.$disabled ? 'not-allowed' : 'pointer')};
47
-
48
- /* Layout */
49
- display: inline-flex;
50
- align-items: center;
51
- position: relative;
52
- flex-shrink: 0;
53
-
54
- /* Sizing */
55
- width: ${props => SIZE_MAP[props.$size].trackW}px;
56
- height: ${props => SIZE_MAP[props.$size].trackH}px;
57
- border-radius: ${props => SIZE_MAP[props.$size].trackH}px;
58
- transition:
59
- background-color ${props => props.theme.transitions.fast},
60
- border-color ${props => props.theme.transitions.fast};
61
-
62
- /* State styles */
63
- ${props => {
64
- const { colors } = props.theme;
65
- if (props.$disabled) {
66
- return `
67
- opacity: 0.5;
68
- background: ${props.$checked ? colors.accent.primary : colors.surface.active};
69
- border: 1px solid ${props.$checked ? 'transparent' : colors.border.default};
70
- `;
71
- }
72
- if (props.$error && !props.$checked) {
73
- return `
74
- background: ${colors.surface.active};
75
- border: 1px solid ${colors.accent.error};
76
- &:hover {
77
- background: ${colors.surface.hover};
78
- }
79
- `;
80
- }
81
- if (props.$checked) {
82
- return `
83
- background: ${colors.accent.primary};
84
- border: 1px solid transparent;
85
- &:hover {
86
- background: ${colors.accent.secondary};
87
- }
88
- `;
89
- }
90
- return `
91
- background: ${colors.surface.active};
92
- border: 1px solid ${colors.border.default};
93
- &:hover {
94
- background: ${colors.surface.hover};
95
- }
96
- `;
97
- }}
98
-
99
- /* Focus visible */
100
- &:focus-visible {
101
- box-shadow: ${props => props.theme.shadows.focus};
102
- }
103
-
104
- /* Disabled */
105
- &:disabled {
106
- opacity: 0.5;
107
- cursor: not-allowed;
108
- }
109
-
110
- /* Custom CSS */
111
- ${props => processCss(props.$css, props.theme)}
112
- `;
113
- const StyledThumb = styled.span `
114
- position: absolute;
115
- border-radius: 50%;
116
- transition: transform ${props => props.theme.transitions.fast};
117
-
118
- width: ${props => SIZE_MAP[props.$size].thumbDiameter}px;
119
- height: ${props => SIZE_MAP[props.$size].thumbDiameter}px;
120
-
121
- background: ${props => props.$checked ? 'white' : props.theme.colors.text.muted};
122
-
123
- ${props => {
124
- const config = SIZE_MAP[props.$size];
125
- const translateX = config.trackW - config.thumbDiameter - config.offset * 2;
126
- return `
127
- transform: translateX(${props.$checked ? translateX : config.offset}px);
128
- `;
129
- }}
130
- `;
131
16
  /**
132
17
  * Switch component for boolean on/off states in editor toolbars,
133
18
  * settings panels, and property inspectors.
@@ -141,7 +26,7 @@ const StyledThumb = styled.span `
141
26
  * <Switch checked={value} onChange={setValue} label="Auto-save" />
142
27
  * ```
143
28
  */
144
- const Switch = ({ checked: checkedProp, defaultChecked = false, label, labelPosition = 'right', size = 'md', disabled = false, helperText, error = false, errorMessage, name, onChange, className, style, css, testId, ref, id: idProp, ...rest }) => {
29
+ const Switch = ({ checked: checkedProp, defaultChecked = false, label, labelPosition = 'right', size = 'md', disabled = false, helperText, error = false, errorMessage, name, onChange, className, style, testId, ref, id: idProp, ...rest }) => {
145
30
  const autoId = useId();
146
31
  const switchId = idProp ?? autoId;
147
32
  const helperId = `${switchId}-helper`;
@@ -158,11 +43,33 @@ const Switch = ({ checked: checkedProp, defaultChecked = false, label, labelPosi
158
43
  onChange?.(newChecked);
159
44
  }, [disabled, resolvedChecked, isControlled, onChange]);
160
45
  const showHelperText = error && errorMessage ? errorMessage : helperText;
161
- const track = (jsxs(StyledTrack, { ref: ref, type: "button", role: "switch", "aria-checked": resolvedChecked, "aria-disabled": disabled || undefined, "aria-describedby": showHelperText ? helperId : undefined, disabled: disabled, onClick: handleClick, "$size": size, "$checked": resolvedChecked, "$disabled": disabled, "$error": error, "$css": css, "data-testid": testId, ...rest, children: [jsx(StyledThumb, { "$size": size, "$checked": resolvedChecked }), name && (jsx("input", { type: "hidden", name: name, value: resolvedChecked ? 'on' : '' }))] }));
46
+ const config = SIZE_MAP[size];
47
+ const translateX = config.trackW - config.thumbDiameter - config.offset * 2;
48
+ const trackInlineVars = assignInlineVars({
49
+ [trackWidthVar]: `${config.trackW}px`,
50
+ [trackHeightVar]: `${config.trackH}px`,
51
+ });
52
+ const thumbInlineVars = assignInlineVars({
53
+ [thumbDiameterVar]: `${config.thumbDiameter}px`,
54
+ [thumbTranslateVar]: `${translateX}px`,
55
+ });
56
+ const thumbStyle = !resolvedChecked
57
+ ? { transform: `translateX(${config.offset}px)` }
58
+ : {};
59
+ const track = (jsxs("button", { ref: ref, type: "button", role: "switch", "aria-checked": resolvedChecked, "aria-disabled": disabled || undefined, "aria-describedby": showHelperText ? helperId : undefined, disabled: disabled, onClick: handleClick, className: trackRecipe({
60
+ checked: resolvedChecked || undefined,
61
+ disabled: disabled || undefined,
62
+ error: error || undefined,
63
+ }), style: trackInlineVars, "data-testid": testId, ...rest, children: [jsx("span", { className: thumbRecipe({
64
+ checked: resolvedChecked || undefined,
65
+ }), style: { ...thumbInlineVars, ...thumbStyle } }), name && (jsx("input", { type: "hidden", name: name, value: resolvedChecked ? 'on' : '' }))] }));
162
66
  if (!label && !showHelperText) {
163
67
  return track;
164
68
  }
165
- return (jsxs(StyledSwitchContainer, { className: className, style: style, children: [jsxs(StyledSwitchRow, { "$labelPosition": labelPosition, "$disabled": disabled, "$size": size, children: [labelPosition === 'left' && label && (jsx(StyledLabelText, { "$order": 0, children: label })), track, labelPosition === 'right' && label && (jsx(StyledLabelText, { "$order": 1, children: label }))] }), showHelperText && (jsx(FormHelperText, { id: helperId, error: error, children: showHelperText }))] }));
69
+ return (jsxs("div", { className: cx(switchContainerStyle, className), style: style, children: [jsxs("label", { className: switchRowRecipe({
70
+ size,
71
+ disabled: disabled || undefined,
72
+ }), children: [labelPosition === 'left' && label && (jsx("span", { className: labelTextStyle, children: label })), track, labelPosition === 'right' && label && (jsx("span", { className: labelTextStyle, children: label }))] }), showHelperText && (jsx(FormHelperText, { id: helperId, error: error, children: showHelperText }))] }));
166
73
  };
167
74
  Switch.displayName = 'Switch';
168
75
 
@@ -1 +1 @@
1
- {"version":3,"file":"Switch.js","sources":["../../../../../../src/components/primitives/Switch/Switch.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"Switch.js","sources":["../../../../../../src/components/primitives/Switch/Switch.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;;;AA+GA;AACE;AACA;AACA;;AAGF;;;;;;;;;;;;AAYG;AACI;AAmBL;AACA;AACA;;AAGA;;AAGA;AACE;;AAEA;;;;AAMA;;AAGF;AAEA;AACA;;AAGE;AACA;AACD;;AAGC;AACA;AACD;;;;AAMD;;;;AAcK;;AAQE;AASP;AACE;;AAGF;;;;AAuBF;AAEA;;"}
@@ -0,0 +1,9 @@
1
+ import './../../../assets/src/components/primitives/Text/Text.css.ts.vanilla-qTMvgKKC.css';
2
+ import { c as createRuntimeFn } from '../../../node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js';
3
+
4
+ var textRecipe = createRuntimeFn({defaultClassName:'Text_textRecipe__1buvrbk0',variantClassNames:{variant:{display:'Text_textRecipe_variant_display__1buvrbk1',heading:'Text_textRecipe_variant_heading__1buvrbk2',subheading:'Text_textRecipe_variant_subheading__1buvrbk3',body:'Text_textRecipe_variant_body__1buvrbk4',caption:'Text_textRecipe_variant_caption__1buvrbk5',code:'Text_textRecipe_variant_code__1buvrbk6',inherit:'Text_textRecipe_variant_inherit__1buvrbk7'},color:{primary:'Text_textRecipe_color_primary__1buvrbk8',secondary:'Text_textRecipe_color_secondary__1buvrbk9',muted:'Text_textRecipe_color_muted__1buvrbka',disabled:'Text_textRecipe_color_disabled__1buvrbkb',accent:'Text_textRecipe_color_accent__1buvrbkc',success:'Text_textRecipe_color_success__1buvrbkd',warning:'Text_textRecipe_color_warning__1buvrbke',error:'Text_textRecipe_color_error__1buvrbkf'},size:{xs:'Text_textRecipe_size_xs__1buvrbkg',sm:'Text_textRecipe_size_sm__1buvrbkh',md:'Text_textRecipe_size_md__1buvrbki',lg:'Text_textRecipe_size_lg__1buvrbkj',xl:'Text_textRecipe_size_xl__1buvrbkk'},weight:{normal:'Text_textRecipe_weight_normal__1buvrbkl',medium:'Text_textRecipe_weight_medium__1buvrbkm',semibold:'Text_textRecipe_weight_semibold__1buvrbkn'},lineHeight:{tight:'Text_textRecipe_lineHeight_tight__1buvrbko',normal:'Text_textRecipe_lineHeight_normal__1buvrbkp',relaxed:'Text_textRecipe_lineHeight_relaxed__1buvrbkq'},align:{left:'Text_textRecipe_align_left__1buvrbkr',center:'Text_textRecipe_align_center__1buvrbks',right:'Text_textRecipe_align_right__1buvrbkt',justify:'Text_textRecipe_align_justify__1buvrbku'},nowrap:{true:'Text_textRecipe_nowrap_true__1buvrbkv',false:'Text_textRecipe_nowrap_false__1buvrbkw'},mono:{true:'Text_textRecipe_mono_true__1buvrbkx',false:'Text_textRecipe_mono_false__1buvrbky'},truncate:{true:'Text_textRecipe_truncate_true__1buvrbkz',false:'Text_textRecipe_truncate_false__1buvrbk10'}},defaultVariants:{variant:'body',color:'primary',nowrap:false,mono:false,truncate:false},compoundVariants:[]});
5
+ var truncateMultiLineStyle = 'Text_truncateMultiLineStyle__1buvrbk12';
6
+ var truncateSingleLineStyle = 'Text_truncateSingleLineStyle__1buvrbk11';
7
+
8
+ export { textRecipe, truncateMultiLineStyle, truncateSingleLineStyle };
9
+ //# sourceMappingURL=Text.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Text.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;"}
@@ -1,130 +1,9 @@
1
+ "use client";
1
2
  import { jsx } from 'react/jsx-runtime';
2
3
  import React from 'react';
3
- import styled from '@emotion/styled';
4
- import { processCss } from '../../../utils/styledUtils.js';
4
+ import { cx } from '../../../utils/cx.js';
5
+ import { truncateMultiLineStyle, truncateSingleLineStyle, textRecipe } from './Text.css.js';
5
6
 
6
- const StyledText = styled.span `
7
- /* Reset */
8
- margin: 0;
9
- padding: 0;
10
-
11
- /* Font family */
12
- font-family: ${props => props.$mono || props.$variant === 'code'
13
- ? props.theme.typography.fontFamily.mono
14
- : props.theme.typography.fontFamily.sans};
15
-
16
- /* Variant-based styling */
17
- ${props => {
18
- if (props.$variant === 'inherit') {
19
- return '';
20
- }
21
- const variants = {
22
- display: {
23
- fontSize: props.theme.typography.fontSize.xl,
24
- fontWeight: props.theme.typography.fontWeight.semibold,
25
- lineHeight: props.theme.typography.lineHeight.tight,
26
- },
27
- heading: {
28
- fontSize: props.theme.typography.fontSize.lg,
29
- fontWeight: props.theme.typography.fontWeight.medium,
30
- lineHeight: props.theme.typography.lineHeight.tight,
31
- },
32
- subheading: {
33
- fontSize: props.theme.typography.fontSize.md,
34
- fontWeight: props.theme.typography.fontWeight.medium,
35
- lineHeight: props.theme.typography.lineHeight.normal,
36
- },
37
- body: {
38
- fontSize: props.theme.typography.fontSize.sm,
39
- fontWeight: props.theme.typography.fontWeight.normal,
40
- lineHeight: props.theme.typography.lineHeight.normal,
41
- },
42
- caption: {
43
- fontSize: props.theme.typography.fontSize.xs,
44
- fontWeight: props.theme.typography.fontWeight.normal,
45
- lineHeight: props.theme.typography.lineHeight.tight,
46
- },
47
- code: {
48
- fontSize: props.theme.typography.fontSize.sm,
49
- fontWeight: props.theme.typography.fontWeight.normal,
50
- lineHeight: props.theme.typography.lineHeight.normal,
51
- },
52
- };
53
- const variant = variants[props.$variant];
54
- if (!variant)
55
- return '';
56
- return `
57
- font-size: ${variant.fontSize}px;
58
- font-weight: ${variant.fontWeight};
59
- line-height: ${variant.lineHeight};
60
- `;
61
- }}
62
-
63
- /* Size override */
64
- ${props => props.$size &&
65
- props.$variant !== 'inherit' &&
66
- `
67
- font-size: ${props.theme.typography.fontSize[props.$size]}px;
68
- `}
69
-
70
- /* Weight override */
71
- ${props => props.$weight &&
72
- props.$variant !== 'inherit' &&
73
- `
74
- font-weight: ${props.theme.typography.fontWeight[props.$weight]};
75
- `}
76
-
77
- /* Line height override */
78
- ${props => props.$lineHeight &&
79
- props.$variant !== 'inherit' &&
80
- `
81
- line-height: ${props.theme.typography.lineHeight[props.$lineHeight]};
82
- `}
83
-
84
- /* Color */
85
- color: ${props => {
86
- const colorMap = {
87
- primary: props.theme.colors.text.primary,
88
- secondary: props.theme.colors.text.secondary,
89
- muted: props.theme.colors.text.muted,
90
- disabled: props.theme.colors.text.disabled,
91
- accent: props.theme.colors.accent.primary,
92
- success: props.theme.colors.accent.success,
93
- warning: props.theme.colors.accent.warning,
94
- error: props.theme.colors.accent.error,
95
- };
96
- return colorMap[props.$color];
97
- }};
98
-
99
- /* Text alignment */
100
- ${props => props.$align && `text-align: ${props.$align};`}
101
-
102
- /* No wrap */
103
- ${props => props.$nowrap && 'white-space: nowrap;'}
104
-
105
- /* Truncation */
106
- ${props => props.$truncate &&
107
- !props.$maxLines &&
108
- `
109
- overflow: hidden;
110
- text-overflow: ellipsis;
111
- white-space: nowrap;
112
- `}
113
-
114
- /* Multi-line truncation */
115
- ${props => props.$truncate &&
116
- props.$maxLines &&
117
- `
118
- display: -webkit-box;
119
- -webkit-line-clamp: ${props.$maxLines};
120
- -webkit-box-orient: vertical;
121
- overflow: hidden;
122
- text-overflow: ellipsis;
123
- `}
124
-
125
- /* Custom CSS */
126
- ${props => processCss(props.$css, props.theme)}
127
- `;
128
7
  /**
129
8
  * A versatile text component for consistent typography in editor interfaces.
130
9
  *
@@ -157,8 +36,23 @@ const StyledText = styled.span `
157
36
  * <Text as="label" variant="caption">Form label</Text>
158
37
  * ```
159
38
  */
160
- const Text = /*#__PURE__*/ React.memo(({ children, as = 'span', variant = 'body', size, weight, color = 'primary', lineHeight, align, truncate = false, maxLines, nowrap = false, mono = false, className, style, css, ref, ...rest }) => {
161
- return (jsx(StyledText, { ref: ref, as: as, "$variant": variant, "$size": size, "$weight": weight, "$color": color, "$lineHeight": lineHeight, "$align": align, "$truncate": truncate, "$maxLines": maxLines, "$nowrap": nowrap, "$mono": mono, "$css": css, className: className, style: style, ...rest, children: children }));
39
+ const Text = /*#__PURE__*/ React.memo(({ children, as: Component = 'span', variant = 'body', size, weight, color = 'primary', lineHeight, align, truncate = false, maxLines, nowrap = false, mono = false, className, style, testId, ref, ...rest }) => {
40
+ // Only pass size/weight/lineHeight overrides when variant is not 'inherit'
41
+ const sizeVariant = size && variant !== 'inherit' ? size : undefined;
42
+ const weightVariant = weight && variant !== 'inherit' ? weight : undefined;
43
+ const lineHeightVariant = lineHeight && variant !== 'inherit' ? lineHeight : undefined;
44
+ const truncateStyle = truncate && maxLines ? { WebkitLineClamp: maxLines } : undefined;
45
+ return (jsx(Component, { ref: ref, className: cx(textRecipe({
46
+ variant,
47
+ color,
48
+ size: sizeVariant,
49
+ weight: weightVariant,
50
+ lineHeight: lineHeightVariant,
51
+ align,
52
+ nowrap: nowrap || undefined,
53
+ mono: mono || variant === 'code' ? true : undefined,
54
+ truncate: truncate || undefined,
55
+ }), truncate && !maxLines && truncateSingleLineStyle, truncate && maxLines ? truncateMultiLineStyle : undefined, className), style: { ...truncateStyle, ...style }, "data-testid": testId, ...rest, children: children }));
162
56
  });
163
57
  Text.displayName = 'Text';
164
58
 
@@ -1 +1 @@
1
- {"version":3,"file":"Text.js","sources":["../../../../../../src/components/primitives/Text/Text.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;;;AAgLA,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAiB;;;;;;iBAM9B,KAAK,IAClB,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,QAAQ,KAAK;MAC9B,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC;MAClC,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAA;;;AAG1C,EAAA,EAAA,KAAK,IAAG;AACR,IAAA,IAAI,KAAK,CAAC,QAAQ,KAAK,SAAS,EAAE;AAChC,QAAA,OAAO,EAAE;;AAGX,IAAA,MAAM,QAAQ,GAAG;AACf,QAAA,OAAO,EAAE;YACP,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YAC5C,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,QAAQ;YACtD,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK;AACpD,SAAA;AACD,QAAA,OAAO,EAAE;YACP,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YAC5C,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;YACpD,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK;AACpD,SAAA;AACD,QAAA,UAAU,EAAE;YACV,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YAC5C,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;YACpD,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;AACrD,SAAA;AACD,QAAA,IAAI,EAAE;YACJ,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YAC5C,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;YACpD,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;AACrD,SAAA;AACD,QAAA,OAAO,EAAE;YACP,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YAC5C,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;YACpD,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK;AACpD,SAAA;AACD,QAAA,IAAI,EAAE;YACJ,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YAC5C,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;YACpD,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM;AACrD,SAAA;KACF;IAED,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC;AACxC,IAAA,IAAI,CAAC,OAAO;AAAE,QAAA,OAAO,EAAE;IAEvB,OAAO;AACQ,iBAAA,EAAA,OAAO,CAAC,QAAQ,CAAA;AACd,mBAAA,EAAA,OAAO,CAAC,UAAU,CAAA;AAClB,mBAAA,EAAA,OAAO,CAAC,UAAU,CAAA;KAClC;AACH,CAAC;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,KAAK;IACX,KAAK,CAAC,QAAQ,KAAK,SAAS;AAC5B,IAAA;iBACa,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;AAC1D,EAAA,CAAA;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,OAAO;IACb,KAAK,CAAC,QAAQ,KAAK,SAAS;AAC5B,IAAA;mBACe,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;AAChE,EAAA,CAAA;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,WAAW;IACjB,KAAK,CAAC,QAAQ,KAAK,SAAS;AAC5B,IAAA;mBACe,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;AACpE,EAAA,CAAA;;;AAGQ,SAAA,EAAA,KAAK,IAAG;AACf,IAAA,MAAM,QAAQ,GAAG;QACf,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO;QACxC,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS;QAC5C,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK;QACpC,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ;QAC1C,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO;QACzC,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO;QAC1C,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO;QAC1C,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;KACvC;AACD,IAAA,OAAO,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC;AAC/B,CAAC,CAAA;;;IAGC,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,CAAe,YAAA,EAAA,KAAK,CAAC,MAAM,CAAG,CAAA,CAAA;;;AAGvD,EAAA,EAAA,KAAK,IAAI,KAAK,CAAC,OAAO,IAAI,sBAAsB;;;AAGhD,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,SAAS;IACf,CAAC,KAAK,CAAC,SAAS;AAChB,IAAA;;;;AAID,EAAA,CAAA;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,SAAS;AACf,IAAA,KAAK,CAAC,SAAS;AACf,IAAA;;AAEsB,wBAAA,EAAA,KAAK,CAAC,SAAS,CAAA;;;;AAItC,EAAA,CAAA;;;AAGC,EAAA,EAAA,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC;CAC/C;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+BG;AACI,MAAM,IAAI,iBAAiB,KAAK,CAAC,IAAI,CAC1C,CAAC,EACC,QAAQ,EACR,EAAE,GAAG,MAAM,EACX,OAAO,GAAG,MAAM,EAChB,IAAI,EACJ,MAAM,EACN,KAAK,GAAG,SAAS,EACjB,UAAU,EACV,KAAK,EACL,QAAQ,GAAG,KAAK,EAChB,QAAQ,EACR,MAAM,GAAG,KAAK,EACd,IAAI,GAAG,KAAK,EACZ,SAAS,EACT,KAAK,EACL,GAAG,EACH,GAAG,EACH,GAAG,IAAI,EACR,KAAI;IACH,QACEA,IAAC,UAAU,EAAA,EACT,GAAG,EAAE,GAAG,EACR,EAAE,EAAE,EAAE,EACI,UAAA,EAAA,OAAO,WACV,IAAI,EAAA,SAAA,EACF,MAAM,EACP,QAAA,EAAA,KAAK,EACA,aAAA,EAAA,UAAU,EACf,QAAA,EAAA,KAAK,eACF,QAAQ,EAAA,WAAA,EACR,QAAQ,EACV,SAAA,EAAA,MAAM,WACR,IAAI,EAAA,MAAA,EACL,GAAG,EACT,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EAAA,GACR,IAAI,EAEP,QAAA,EAAA,QAAQ,EACE,CAAA;AAEjB,CAAC;AAGH,IAAI,CAAC,WAAW,GAAG,MAAM;;;;"}
1
+ {"version":3,"file":"Text.js","sources":["../../../../../../src/components/primitives/Text/Text.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;AAiLA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+BG;AACI;;AAqBH;AACA;AACA;AAGA;AAGA;;;AAOQ;AACA;AACA;;;AAGA;;AAED;AAYT;AAGF;;"}
@@ -1,52 +1,19 @@
1
+ "use client";
1
2
  import { jsx } from 'react/jsx-runtime';
2
- import styled from '@emotion/styled';
3
- import { Tooltip } from '@base-ui-components/react/tooltip';
3
+ import React from 'react';
4
+ import { Tooltip } from '@base-ui/react/tooltip';
5
+ import { cx } from '../../../utils/cx.js';
6
+ import { tooltipArrowStyle, arrowFillStyle } from './Tooltip.css.js';
4
7
 
5
8
  const ArrowSvg = (props) => {
6
9
  return (jsx("svg", { width: "20", height: "10", viewBox: "0 0 20 10", fill: "none", style: {
7
10
  // Improve SVG rendering quality
8
11
  shapeRendering: 'geometricPrecision',
9
12
  imageRendering: 'crisp-edges',
10
- }, ...props, children: jsx(ArrowFill, { d: "M9.66437 2.60207L4.80758 6.97318C4.07308 7.63423 3.11989 8 2.13172 8H0V10H20V8H18.5349C17.5468 8 16.5936 7.63423 15.8591 6.97318L11.0023 2.60207C10.622 2.2598 10.0447 2.25979 9.66437 2.60207Z" }) }));
13
+ }, ...props, children: jsx("path", { className: arrowFillStyle, d: "M9.66437 2.60207L4.80758 6.97318C4.07308 7.63423 3.11989 8 2.13172 8H0V10H20V8H18.5349C17.5468 8 16.5936 7.63423 15.8591 6.97318L11.0023 2.60207C10.622 2.2598 10.0447 2.25979 9.66437 2.60207Z" }) }));
11
14
  };
12
- const ArrowFill = styled.path `
13
- fill: ${props => props.theme.colors.background.elevated};
14
- `;
15
- const StyledTooltipArrow = styled(Tooltip.Arrow) `
16
- display: flex;
17
- transform-style: preserve-3d;
18
- backface-visibility: hidden;
19
- perspective: 1000px;
20
- /* Ensure crisp rendering */
21
- image-rendering: crisp-edges;
22
- image-rendering: -webkit-optimize-contrast;
23
- image-rendering: pixelated;
24
-
25
- /* Antialiasing for smooth edges */
26
- -webkit-font-smoothing: antialiased;
27
- -moz-osx-font-smoothing: grayscale;
28
-
29
- &[data-side='top'] {
30
- bottom: -8px;
31
- rotate: 180deg;
32
- }
33
-
34
- &[data-side='bottom'] {
35
- top: -8px;
36
- rotate: 0deg;
37
- }
38
-
39
- &[data-side='left'] {
40
- right: -13px;
41
- rotate: 90deg;
42
- }
43
-
44
- &[data-side='right'] {
45
- left: -13px;
46
- rotate: -90deg;
47
- }
48
- will-change: transform;
49
- `;
15
+ const StyledTooltipArrow = React.forwardRef(({ className, ...props }, ref) => (jsx(Tooltip.Arrow, { ref: ref, className: cx(tooltipArrowStyle, typeof className === 'string' ? className : undefined), ...props })));
16
+ StyledTooltipArrow.displayName = 'StyledTooltipArrow';
50
17
 
51
18
  export { ArrowSvg, StyledTooltipArrow };
52
19
  //# sourceMappingURL=Arrow.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Arrow.js","sources":["../../../../../../src/components/primitives/Tooltip/Arrow.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;;AAKa,MAAA,QAAQ,GAAG,CAAC,KAAkC,KAAI;AAC7D,IAAA,QACEA,GACE,CAAA,KAAA,EAAA,EAAA,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,KAAK,EAAE;;AAEL,YAAA,cAAc,EAAE,oBAAoB;AACpC,YAAA,cAAc,EAAE,aAAa;SAC9B,EACG,GAAA,KAAK,EAET,QAAA,EAAAA,GAAA,CAAC,SAAS,EAAA,EAAC,CAAC,EAAC,iMAAiM,EAAA,CAAG,EAC7M,CAAA;AAEV;AAEA,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAA;UACnB,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAA;CACxD;AAEY,MAAA,kBAAkB,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"Arrow.js","sources":["../../../../../../src/components/primitives/Tooltip/Arrow.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;AAQO;AACL;;AAQM;AACA;AACD;AASP;AAEO;AAcP;;"}
@@ -0,0 +1,9 @@
1
+ import './../../../assets/src/components/primitives/Tooltip/Tooltip.css.ts.vanilla-CrEFoLBX.css';
2
+
3
+ var arrowFillStyle = 'Tooltip_arrowFillStyle__u81kis2';
4
+ var tooltipArrowStyle = 'Tooltip_tooltipArrowStyle__u81kis3';
5
+ var tooltipContentStyle = 'Tooltip_tooltipContentStyle__u81kis0';
6
+ var tooltipTriggerStyle = 'Tooltip_tooltipTriggerStyle__u81kis1';
7
+
8
+ export { arrowFillStyle, tooltipArrowStyle, tooltipContentStyle, tooltipTriggerStyle };
9
+ //# sourceMappingURL=Tooltip.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Tooltip.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;"}
@@ -1,87 +1,15 @@
1
+ "use client";
1
2
  import { jsx, jsxs } from 'react/jsx-runtime';
2
- import { Tooltip as Tooltip$1 } from '@base-ui-components/react/tooltip';
3
- import styled from '@emotion/styled';
4
- import { processCss } from '../../../utils/styledUtils.js';
3
+ import { Tooltip as Tooltip$1 } from '@base-ui/react/tooltip';
4
+ import { cx } from '../../../utils/cx.js';
5
5
  import { StyledTooltipArrow, ArrowSvg } from './Arrow.js';
6
6
  import { parsePlacement, parseCollisionStrategy } from './utils.js';
7
+ import { tooltipTriggerStyle, tooltipContentStyle } from './Tooltip.css.js';
7
8
 
8
- const StyledTooltipPositioner = styled(Tooltip$1.Positioner) `
9
- /* Positioner handles positioning, no visual styles needed here */
10
- `;
11
- const StyledTooltipContent = styled.div `
12
- /* Base styles */
13
- background: ${props => props.theme.colors.background.elevated};
14
- color: ${props => props.theme.colors.text.primary};
15
- border-radius: ${props => props.theme.borderRadius.md}px;
16
- padding: ${props => props.theme.spacing.sm}px
17
- ${props => props.theme.spacing.md}px;
18
- font-size: ${props => props.theme.typography.fontSize.xs}px;
19
- line-height: ${props => props.theme.typography.lineHeight.tight};
20
- font-family: ${props => props.theme.typography.fontFamily.sans};
21
- box-shadow: ${props => props.theme.shadows.lg};
22
- max-width: 320px;
23
- word-wrap: break-word;
24
- z-index: ${props => props.theme.zIndex.tooltip};
25
- min-height: 25px; // Ensure minimum height for better UX
26
- display: flex;
27
- align-items: center; // Center content vertically
28
- justify-content: center; // Center content horizontally
29
-
30
- /* Animation */
31
- ${props => {
32
- const { $animation } = props;
33
- const duration = $animation?.duration ?? 200;
34
- const easing = $animation?.easing ?? 'ease-out';
35
- const animated = $animation?.animated !== false;
36
- if (!animated) {
37
- return 'transition: none;';
38
- }
39
- return `
40
- transition: opacity ${duration}ms ${easing}, transform ${duration}ms ${easing};
41
- transform-origin: var(--transform-origin);
42
- `;
43
- }}
44
-
45
- /* Entry/exit animations */
46
- &[data-open] {
47
- opacity: 1;
48
- transform: scale(1);
49
- }
50
-
51
- &[data-closed] {
52
- opacity: 0;
53
- transform: scale(0.96);
54
- }
55
-
56
- /* Custom CSS */
57
- ${props => processCss(props.$css, props.theme)}
58
- `;
59
- const StyledTooltipTrigger = styled.div `
60
- /* Trigger styles */
61
- display: inline-block;
62
- cursor: pointer;
63
- width: fit-content; // Allow trigger to size to content
64
- height: fit-content; // Allow trigger to size to content
65
- position: relative; // Required for tooltip positioning
66
- z-index: 1; // Ensure trigger is above tooltip
67
- /* Prevents pointer events on the tooltip trigger */
68
- pointer-events: none;
69
- /* Allows pointer events on the children */
70
- & > * {
71
- pointer-events: auto;
72
- }
73
- /* Ensures the trigger is focusable */
74
- &:focus {
75
- outline: none; // Remove default focus outline
76
- box-shadow: ${props => props.theme.shadows.focus}; // Custom focus style
77
- }
78
- /* Custom CSS */
79
- ${props => processCss(props.$css, props.theme)}
80
- `;
81
9
  /**
82
10
  * A tooltip component that displays contextual information on hover.
83
11
  *
84
- * Built on @base-ui-components/react for robust accessibility and positioning.
12
+ * Built on @base-ui/react for robust accessibility and positioning.
85
13
  * Provides an intuitive API similar to MUI with advanced positioning and collision handling.
86
14
  * Supports both simple text and complex React nodes for advanced tooltip content.
87
15
  *
@@ -166,7 +94,7 @@ const StyledTooltipTrigger = styled.div `
166
94
  * </Tooltip>
167
95
  * ```
168
96
  */
169
- const Tooltip = ({ children, title, placement = 'top', collision = 'smart', collisionConfig, positioner = {}, animation = {}, delay = 600, closeDelay = 0, arrow = true, disabled = false, rootProps = {}, positionerProps = {}, className, testId, id, style, css, ref, ...htmlProps }) => {
97
+ const Tooltip = ({ children, title, placement = 'top', collision = 'smart', collisionConfig, positioner = {}, animation = {}, delay = 600, closeDelay = 0, arrow = true, disabled = false, rootProps = {}, positionerProps = {}, className, testId, id, style, ref, ...htmlProps }) => {
170
98
  // If disabled, return just the children without tooltip
171
99
  if (disabled) {
172
100
  return children;
@@ -211,7 +139,20 @@ const Tooltip = ({ children, title, placement = 'top', collision = 'smart', coll
211
139
  if (trackCursor) {
212
140
  rootProps.trackCursorAxis = trackCursor;
213
141
  }
214
- return (jsx(Tooltip$1.Provider, { delay: delay, closeDelay: closeDelay, ...rootProps, children: jsxs(Tooltip$1.Root, { children: [jsx(Tooltip$1.Trigger, { render: props => jsx(StyledTooltipTrigger, { ...props }), children: children }), jsx(Tooltip$1.Portal, { children: jsx(StyledTooltipPositioner, { ...finalPositionerProps, children: jsx(Tooltip$1.Popup, { render: props => (jsxs(StyledTooltipContent, { ...props, className: className, "data-testid": testId, id: id, style: style, "$css": css, "$animation": animation, ref: ref, ...htmlProps, children: [title, arrow && (jsx(StyledTooltipArrow, { children: jsx(ArrowSvg, {}) }))] })) }) }) })] }) }));
142
+ // Build animation transition style
143
+ const animated = animation?.animated !== false;
144
+ const duration = animation?.duration ?? 200;
145
+ const easing = animation?.easing ?? 'ease-out';
146
+ const animationStyle = animated
147
+ ? {
148
+ transition: `opacity ${duration}ms ${easing}, transform ${duration}ms ${easing}`,
149
+ }
150
+ : { transition: 'none' };
151
+ return (jsx(Tooltip$1.Provider, { delay: delay, closeDelay: closeDelay, ...rootProps, children: jsxs(Tooltip$1.Root, { children: [jsx(Tooltip$1.Trigger, { render: props => (jsx("div", { ...props, className: cx(tooltipTriggerStyle, props.className) })), children: children }), jsx(Tooltip$1.Portal, { children: jsx(Tooltip$1.Positioner, { ...finalPositionerProps, children: jsx(Tooltip$1.Popup, { render: props => (jsxs("div", { ...props, className: cx(tooltipContentStyle, className, props.className), "data-testid": testId, id: id, style: {
152
+ ...animationStyle,
153
+ ...style,
154
+ ...props.style,
155
+ }, ref: ref, ...htmlProps, children: [title, arrow && (jsx(StyledTooltipArrow, { children: jsx(ArrowSvg, {}) }))] })) }) }) })] }) }));
215
156
  };
216
157
  Tooltip.displayName = 'Tooltip';
217
158
 
@@ -1 +1 @@
1
- {"version":3,"file":"Tooltip.js","sources":["../../../../../../src/components/primitives/Tooltip/Tooltip.tsx"],"sourcesContent":[null],"names":["BaseTooltip","_jsx","_jsxs"],"mappings":"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"}
1
+ {"version":3,"file":"Tooltip.js","sources":["../../../../../../src/components/primitives/Tooltip/Tooltip.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;AA8HA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuFG;AACI;;;AAuBH;;;;;;AAQA;AACI;AACE;AACA;AACA;AACqB;AACxB;AACH;;AAGF;;AASA;;;AAGE;AACA;;;AAGA;;;;AAKA;;;AAGI;;;;AAGF;;;;;AAMF;;;AAIF;AACA;AACA;;AAGE;;AAEG;AACH;;AA8BgB;AACA;;;AAoBpB;AAEA;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sources":["../../../../../../src/components/primitives/Tooltip/utils.ts"],"sourcesContent":[null],"names":[],"mappings":"AAOA;;AAEG;AACU,MAAA,cAAc,GAAG,CAAC,SAA2B,KAAI;AAC5D,IAAA,MAAM,CAAC,IAAI,EAAE,KAAK,GAAG,QAAQ,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAGnD;IACD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,IAAI,QAAQ,EAAE;AAC3C;AAEA;;AAEG;AACU,MAAA,sBAAsB,GAAG,CACpC,QAAkC,KAIhC;IACF,QAAQ,QAAQ;AACd,QAAA,KAAK,MAAM;YACT,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,MAAM;AACb,oBAAA,gBAAgB,EAAE,MAAM;AACzB,iBAAA;aACF;AAEH,QAAA,KAAK,OAAO;YACV,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,OAAO;AACb,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,MAAM;AACzB,iBAAA;aACF;AAEH,QAAA,KAAK,MAAM;YACT,OAAO;AACL,gBAAA,kBAAkB,EAAE,SAAS;AAC7B,gBAAA,gBAAgB,EAAE,IAAI;aACvB;AAEH,QAAA,KAAK,YAAY;YACf,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,MAAM;AACzB,iBAAA;aACF;AAEH,QAAA,KAAK,OAAO;YACV,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,OAAO;AAC1B,iBAAA;aACF;AAEH,QAAA,KAAK,MAAM;YACT,OAAO;AACL,gBAAA,kBAAkB,EAAE,SAAS;aAC9B;AAEH,QAAA;YACE,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,OAAO;AAC1B,iBAAA;aACF;;AAEP;;;;"}
1
+ {"version":3,"file":"utils.js","sources":["../../../../../../src/components/primitives/Tooltip/utils.ts"],"sourcesContent":[null],"names":[],"mappings":"AAOA;;AAEG;AACI,MAAM,cAAc,GAAG,CAAC,SAA2B,KAAI;AAC5D,IAAA,MAAM,CAAC,IAAI,EAAE,KAAK,GAAG,QAAQ,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAGnD;IACD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,IAAI,QAAQ,EAAE;AAC3C;AAEA;;AAEG;AACI,MAAM,sBAAsB,GAAG,CACpC,QAAkC,KAIhC;IACF,QAAQ,QAAQ;AACd,QAAA,KAAK,MAAM;YACT,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,MAAM;AACb,oBAAA,gBAAgB,EAAE,MAAM;AACzB,iBAAA;aACF;AAEH,QAAA,KAAK,OAAO;YACV,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,OAAO;AACb,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,MAAM;AACzB,iBAAA;aACF;AAEH,QAAA,KAAK,MAAM;YACT,OAAO;AACL,gBAAA,kBAAkB,EAAE,SAAS;AAC7B,gBAAA,gBAAgB,EAAE,IAAI;aACvB;AAEH,QAAA,KAAK,YAAY;YACf,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,MAAM;AACzB,iBAAA;aACF;AAEH,QAAA,KAAK,OAAO;YACV,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,OAAO;AAC1B,iBAAA;aACF;AAEH,QAAA,KAAK,MAAM;YACT,OAAO;AACL,gBAAA,kBAAkB,EAAE,SAAS;aAC9B;AAEH,QAAA;YACE,OAAO;AACL,gBAAA,kBAAkB,EAAE;AAClB,oBAAA,IAAI,EAAE,MAAM;AACZ,oBAAA,KAAK,EAAE,OAAO;AACd,oBAAA,gBAAgB,EAAE,OAAO;AAC1B,iBAAA;aACF;;AAEP;;;;"}
@@ -0,0 +1,10 @@
1
+ import './../../../assets/src/components/primitives/canvas/CanvasContainer.css.ts.vanilla-DR3zkEYQ.css';
2
+ import { c as createRuntimeFn } from '../../../node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js';
3
+
4
+ var ariaLiveRegionStyle = 'CanvasContainer_ariaLiveRegionStyle__ktqdsj7';
5
+ var canvasContainerHeightVar = 'var(--canvasContainerHeightVar__ktqdsj0)';
6
+ var canvasContainerRecipe = createRuntimeFn({defaultClassName:'CanvasContainer_canvasContainerRecipe__ktqdsj1',variantClassNames:{responsive:{true:'CanvasContainer_canvasContainerRecipe_responsive_true__ktqdsj2',false:'CanvasContainer_canvasContainerRecipe_responsive_false__ktqdsj3'}},defaultVariants:{responsive:false},compoundVariants:[]});
7
+ var canvasRecipe = createRuntimeFn({defaultClassName:'CanvasContainer_canvasRecipe__ktqdsj4',variantClassNames:{disabled:{true:'CanvasContainer_canvasRecipe_disabled_true__ktqdsj5',false:'CanvasContainer_canvasRecipe_disabled_false__ktqdsj6'}},defaultVariants:{disabled:false},compoundVariants:[]});
8
+
9
+ export { ariaLiveRegionStyle, canvasContainerHeightVar, canvasContainerRecipe, canvasRecipe };
10
+ //# sourceMappingURL=CanvasContainer.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CanvasContainer.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;"}