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
@@ -0,0 +1,32 @@
1
+ "use client";
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { useRef } from 'react';
4
+ import { assignInlineVars } from '../../../node_modules/@vanilla-extract/dynamic/dist/vanilla-extract-dynamic.esm.js';
5
+ import { canvasRecipe, ariaLiveRegionStyle, canvasContainerHeightVar, canvasContainerRecipe } from './CanvasContainer.css.js';
6
+
7
+ /**
8
+ * Styled container + canvas + a11y live region.
9
+ *
10
+ * Provides the boilerplate every canvas control needs:
11
+ * - Responsive or fixed-height container
12
+ * - Canvas element with proper styling
13
+ * - Screen reader announcements region
14
+ * - Disabled opacity
15
+ * - Focus-visible ring
16
+ *
17
+ * Does NOT manage rendering — consumers use useCanvasSetup + useCanvasRenderer.
18
+ */
19
+ const CanvasContainer = ({ canvasRef, height = 200, responsive = false, disabled = false, role = 'application', ariaLabel, ariaRoledescription, liveAnnouncement, handlers, className, style, testId, id, }) => {
20
+ const containerRef = useRef(null);
21
+ return (jsxs("div", { ref: containerRef, className: `${canvasContainerRecipe({ responsive })}${className ? ` ${className}` : ''}`, style: {
22
+ ...style,
23
+ ...assignInlineVars({
24
+ [canvasContainerHeightVar]: `${height}px`,
25
+ }),
26
+ minHeight: `${height}px`,
27
+ }, id: id, "data-testid": testId, children: [jsx("canvas", { ref: canvasRef, className: canvasRecipe({ disabled }), role: role, "aria-label": ariaLabel, "aria-roledescription": ariaRoledescription, tabIndex: disabled ? -1 : 0, onPointerDown: handlers?.onPointerDown, onPointerMove: handlers?.onPointerMove, onPointerUp: handlers?.onPointerUp, onDoubleClick: handlers?.onDoubleClick, onKeyDown: handlers?.onKeyDown }), jsx("div", { className: ariaLiveRegionStyle, "aria-live": "polite", role: "status", children: liveAnnouncement })] }));
28
+ };
29
+ CanvasContainer.displayName = 'CanvasContainer';
30
+
31
+ export { CanvasContainer };
32
+ //# sourceMappingURL=CanvasContainer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CanvasContainer.js","sources":["../../../../../../src/components/primitives/canvas/CanvasContainer.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;AAYA;;;;;;;;;;;AAWG;AACI;AAeL;AAEA;AAKM;AACA;AACE;;;AAGH;AAsBP;AAEA;;"}
@@ -0,0 +1,51 @@
1
+ /**
2
+ * Convert domain coordinates to canvas pixel coordinates.
3
+ *
4
+ * Y axis is flipped: domain Y goes up, canvas Y goes down.
5
+ */
6
+ function domainToCanvas(domainX, domainY, viewport, canvasWidth, canvasHeight) {
7
+ const [vxMin, vxMax] = viewport.viewX;
8
+ const [vyMin, vyMax] = viewport.viewY;
9
+ const vw = vxMax - vxMin || 1;
10
+ const vh = vyMax - vyMin || 1;
11
+ const px = ((domainX - vxMin) / vw) * canvasWidth;
12
+ const py = ((vyMax - domainY) / vh) * canvasHeight;
13
+ return { px, py };
14
+ }
15
+ /**
16
+ * Convert canvas pixel coordinates to domain coordinates.
17
+ *
18
+ * Inverse of domainToCanvas — Y axis is flipped.
19
+ */
20
+ function canvasToDomain(px, py, viewport, canvasWidth, canvasHeight) {
21
+ const [vxMin, vxMax] = viewport.viewX;
22
+ const [vyMin, vyMax] = viewport.viewY;
23
+ const vw = vxMax - vxMin || 1;
24
+ const vh = vyMax - vyMin || 1;
25
+ const x = vxMin + (px / canvasWidth) * vw;
26
+ const y = vyMax - (py / canvasHeight) * vh;
27
+ return { x, y };
28
+ }
29
+ /**
30
+ * Test whether a canvas pixel position is within tolerance of a domain point.
31
+ *
32
+ * @returns Distance in pixels, or Infinity if outside tolerance
33
+ */
34
+ function hitTestPoint(px, py, point, viewport, canvasWidth, canvasHeight, tolerancePx = 10) {
35
+ const target = domainToCanvas(point.x, point.y, viewport, canvasWidth, canvasHeight);
36
+ const dist = Math.sqrt((px - target.px) ** 2 + (py - target.py) ** 2);
37
+ return dist <= tolerancePx ? dist : Infinity;
38
+ }
39
+ /**
40
+ * Get the canvas-pixel position of a pointer event relative to the canvas.
41
+ */
42
+ function getCanvasPointerPosition(e, canvas) {
43
+ const rect = canvas.getBoundingClientRect();
44
+ return {
45
+ px: e.clientX - rect.left,
46
+ py: e.clientY - rect.top,
47
+ };
48
+ }
49
+
50
+ export { canvasToDomain, domainToCanvas, getCanvasPointerPosition, hitTestPoint };
51
+ //# sourceMappingURL=canvasCoords.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"canvasCoords.js","sources":["../../../../../../src/components/primitives/canvas/canvasCoords.ts"],"sourcesContent":[null],"names":[],"mappings":"AAEA;;;;AAIG;AACG,SAAU,cAAc,CAC5B,OAAe,EACf,OAAe,EACf,QAAwB,EACxB,WAAmB,EACnB,YAAoB,EAAA;IAEpB,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,QAAQ,CAAC,KAAK;IACrC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,QAAQ,CAAC,KAAK;AAErC,IAAA,MAAM,EAAE,GAAG,KAAK,GAAG,KAAK,IAAI,CAAC;AAC7B,IAAA,MAAM,EAAE,GAAG,KAAK,GAAG,KAAK,IAAI,CAAC;AAE7B,IAAA,MAAM,EAAE,GAAG,CAAC,CAAC,OAAO,GAAG,KAAK,IAAI,EAAE,IAAI,WAAW;AACjD,IAAA,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,GAAG,OAAO,IAAI,EAAE,IAAI,YAAY;AAElD,IAAA,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE;AACnB;AAEA;;;;AAIG;AACG,SAAU,cAAc,CAC5B,EAAU,EACV,EAAU,EACV,QAAwB,EACxB,WAAmB,EACnB,YAAoB,EAAA;IAEpB,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,QAAQ,CAAC,KAAK;IACrC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,QAAQ,CAAC,KAAK;AAErC,IAAA,MAAM,EAAE,GAAG,KAAK,GAAG,KAAK,IAAI,CAAC;AAC7B,IAAA,MAAM,EAAE,GAAG,KAAK,GAAG,KAAK,IAAI,CAAC;IAE7B,MAAM,CAAC,GAAG,KAAK,GAAG,CAAC,EAAE,GAAG,WAAW,IAAI,EAAE;IACzC,MAAM,CAAC,GAAG,KAAK,GAAG,CAAC,EAAE,GAAG,YAAY,IAAI,EAAE;AAE1C,IAAA,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE;AACjB;AAEA;;;;AAIG;SACa,YAAY,CAC1B,EAAU,EACV,EAAU,EACV,KAAc,EACd,QAAwB,EACxB,WAAmB,EACnB,YAAoB,EACpB,cAAsB,EAAE,EAAA;AAExB,IAAA,MAAM,MAAM,GAAG,cAAc,CAC3B,KAAK,CAAC,CAAC,EACP,KAAK,CAAC,CAAC,EACP,QAAQ,EACR,WAAW,EACX,YAAY,CACb;IACD,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,GAAG,MAAM,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,MAAM,CAAC,EAAE,KAAK,CAAC,CAAC;IACrE,OAAO,IAAI,IAAI,WAAW,GAAG,IAAI,GAAG,QAAQ;AAC9C;AAEA;;AAEG;AACG,SAAU,wBAAwB,CACtC,CAAuC,EACvC,MAAyB,EAAA;AAEzB,IAAA,MAAM,IAAI,GAAG,MAAM,CAAC,qBAAqB,EAAE;IAC3C,OAAO;AACL,QAAA,EAAE,EAAE,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI;AACzB,QAAA,EAAE,EAAE,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG;KACzB;AACH;;;;"}
@@ -0,0 +1,251 @@
1
+ import { domainToCanvas } from './canvasCoords.js';
2
+ import { clamp } from '../../../utils/mathUtils.js';
3
+
4
+ /**
5
+ * Format a number for axis labels.
6
+ * Integers show as "0", "1". Clean fractions show as "0.25", "0.5".
7
+ * Others show with minimal decimals needed.
8
+ */
9
+ function formatLabel(value, domainRange) {
10
+ const rounded = Math.round(value * 1e10) / 1e10;
11
+ if (Number.isInteger(rounded))
12
+ return rounded.toFixed(0);
13
+ if (domainRange <= 1) {
14
+ const str = rounded.toFixed(2);
15
+ if (str.endsWith('0'))
16
+ return rounded.toFixed(1);
17
+ return str;
18
+ }
19
+ if (domainRange <= 10)
20
+ return rounded.toFixed(1);
21
+ return rounded.toFixed(0);
22
+ }
23
+ /**
24
+ * Draw grid lines at clean domain values.
25
+ * Grid lines subdivide the domain range into equal parts.
26
+ *
27
+ * Extracted from CurveEditor's drawGrid — identical visual output.
28
+ */
29
+ function drawGrid(ctx, w, h, theme, options) {
30
+ const { subdivisions, domain, viewport, opacity = 1 } = options;
31
+ const { domainX, domainY } = domain;
32
+ const dxRange = domainX[1] - domainX[0] || 1;
33
+ const dyRange = domainY[1] - domainY[0] || 1;
34
+ ctx.lineWidth = 1;
35
+ // Vertical grid lines (subdivide domain X)
36
+ const xStep = dxRange / subdivisions;
37
+ for (let i = 0; i <= subdivisions; i++) {
38
+ const domX = domainX[0] + i * xStep;
39
+ const { px } = domainToCanvas(domX, 0, viewport, w, h);
40
+ const isBound = i === 0 || i === subdivisions;
41
+ ctx.globalAlpha = opacity * (isBound ? 0.25 : 0.12);
42
+ ctx.strokeStyle = theme.borderDefault;
43
+ ctx.beginPath();
44
+ ctx.moveTo(Math.round(px) + 0.5, 0);
45
+ ctx.lineTo(Math.round(px) + 0.5, h);
46
+ ctx.stroke();
47
+ }
48
+ // Horizontal grid lines (subdivide domain Y)
49
+ const yStep = dyRange / subdivisions;
50
+ for (let i = 0; i <= subdivisions; i++) {
51
+ const domY = domainY[0] + i * yStep;
52
+ const { py } = domainToCanvas(0, domY, viewport, w, h);
53
+ const isBound = i === 0 || i === subdivisions;
54
+ ctx.globalAlpha = opacity * (isBound ? 0.25 : 0.12);
55
+ ctx.strokeStyle = theme.borderDefault;
56
+ ctx.beginPath();
57
+ ctx.moveTo(0, Math.round(py) + 0.5);
58
+ ctx.lineTo(w, Math.round(py) + 0.5);
59
+ ctx.stroke();
60
+ }
61
+ }
62
+ /**
63
+ * Draw stronger lines at the domain boundaries (min/max on both axes).
64
+ */
65
+ function drawDomainBounds(ctx, w, h, theme, domain, viewport, opacity = 1) {
66
+ const { domainX, domainY } = domain;
67
+ ctx.globalAlpha = opacity * 0.35;
68
+ ctx.strokeStyle = theme.borderDefault;
69
+ ctx.lineWidth = 1.5;
70
+ const { px: pxMin } = domainToCanvas(domainX[0], 0, viewport, w, h);
71
+ ctx.beginPath();
72
+ ctx.moveTo(Math.round(pxMin) + 0.5, 0);
73
+ ctx.lineTo(Math.round(pxMin) + 0.5, h);
74
+ ctx.stroke();
75
+ const { px: pxMax } = domainToCanvas(domainX[1], 0, viewport, w, h);
76
+ ctx.beginPath();
77
+ ctx.moveTo(Math.round(pxMax) + 0.5, 0);
78
+ ctx.lineTo(Math.round(pxMax) + 0.5, h);
79
+ ctx.stroke();
80
+ const { py: pyMin } = domainToCanvas(0, domainY[0], viewport, w, h);
81
+ ctx.beginPath();
82
+ ctx.moveTo(0, Math.round(pyMin) + 0.5);
83
+ ctx.lineTo(w, Math.round(pyMin) + 0.5);
84
+ ctx.stroke();
85
+ const { py: pyMax } = domainToCanvas(0, domainY[1], viewport, w, h);
86
+ ctx.beginPath();
87
+ ctx.moveTo(0, Math.round(pyMax) + 0.5);
88
+ ctx.lineTo(w, Math.round(pyMax) + 0.5);
89
+ ctx.stroke();
90
+ }
91
+ /**
92
+ * Draw axis labels at clean domain values.
93
+ *
94
+ * Y labels on the left side, X labels at the bottom.
95
+ * Extracted from CurveEditor's drawAxisLabels — identical layout algorithm.
96
+ */
97
+ function drawAxisLabels(ctx, w, h, theme, options) {
98
+ const { subdivisions, domain, viewport, opacity = 1, labelX, labelY, } = options;
99
+ const { domainX, domainY } = domain;
100
+ const dxRange = domainX[1] - domainX[0] || 1;
101
+ const dyRange = domainY[1] - domainY[0] || 1;
102
+ const fontSize = theme.fontSizeXs;
103
+ ctx.globalAlpha = opacity * 0.7;
104
+ ctx.fillStyle = theme.textMuted;
105
+ ctx.font = `${fontSize}px sans-serif`;
106
+ const sidePadding = 4;
107
+ const axisGap = 6;
108
+ const { px: xAxisMin } = domainToCanvas(domainX[0], 0, viewport, w, h);
109
+ const { px: xAxisMax } = domainToCanvas(domainX[1], 0, viewport, w, h);
110
+ const { py: yAxisMin } = domainToCanvas(0, domainY[0], viewport, w, h);
111
+ const { py: yAxisMax } = domainToCanvas(0, domainY[1], viewport, w, h);
112
+ const xTickTop = clamp(yAxisMin + axisGap, yAxisMax + 2, h - fontSize - (labelX ? fontSize + 8 : 2));
113
+ const xAxisLabelTop = labelX
114
+ ? clamp(xTickTop + fontSize + 4, 0, h - fontSize - 1)
115
+ : 0;
116
+ const yTickAnchorX = clamp(xAxisMin - axisGap, sidePadding + 1, w - sidePadding);
117
+ const yTickMinY = fontSize / 2 + 2;
118
+ const yTickMaxY = Math.max(yTickMinY, xTickTop - 2);
119
+ const yAxisLabelTop = clamp(yAxisMax - fontSize - 4, sidePadding, Math.max(sidePadding, xTickTop - fontSize - 6));
120
+ // X axis labels (bottom, aligned to domain subdivisions)
121
+ ctx.textBaseline = 'top';
122
+ const xStep = dxRange / subdivisions;
123
+ for (let i = 0; i <= subdivisions; i++) {
124
+ const domX = domainX[0] + i * xStep;
125
+ const { px } = domainToCanvas(domX, 0, viewport, w, h);
126
+ const label = formatLabel(domX, dxRange);
127
+ if (i === 0) {
128
+ ctx.textAlign = 'left';
129
+ ctx.fillText(label, xAxisMin + 2, xTickTop);
130
+ }
131
+ else if (i === subdivisions) {
132
+ ctx.textAlign = 'right';
133
+ ctx.fillText(label, xAxisMax - 2, xTickTop);
134
+ }
135
+ else {
136
+ ctx.textAlign = 'center';
137
+ ctx.fillText(label, clamp(px, xAxisMin + 2, xAxisMax - 2), xTickTop);
138
+ }
139
+ }
140
+ // Y axis labels (left side, aligned to domain subdivisions)
141
+ ctx.textAlign = 'right';
142
+ ctx.textBaseline = 'middle';
143
+ const yStep = dyRange / subdivisions;
144
+ for (let i = 0; i <= subdivisions; i++) {
145
+ const domY = domainY[0] + i * yStep;
146
+ const { py } = domainToCanvas(0, domY, viewport, w, h);
147
+ const label = formatLabel(domY, dyRange);
148
+ const clampedPy = clamp(py, yTickMinY, yTickMaxY);
149
+ ctx.fillText(label, yTickAnchorX, clampedPy);
150
+ }
151
+ // Axis name labels
152
+ if (labelX) {
153
+ const textWidth = ctx.measureText(labelX).width;
154
+ const x = clamp(xAxisMax + axisGap, sidePadding, w - sidePadding - textWidth);
155
+ ctx.textAlign = 'left';
156
+ ctx.textBaseline = 'top';
157
+ ctx.fillText(labelX, x, xAxisLabelTop);
158
+ }
159
+ if (labelY) {
160
+ const x = clamp(xAxisMin + axisGap, sidePadding, w - sidePadding);
161
+ ctx.textAlign = 'left';
162
+ ctx.textBaseline = 'top';
163
+ ctx.fillText(labelY, x, yAxisLabelTop);
164
+ }
165
+ }
166
+ /**
167
+ * Draw crosshair lines through a point.
168
+ *
169
+ * Used by CartesianPicker to show the current selection.
170
+ * Can be solid or dashed, full-span or limited to domain bounds.
171
+ */
172
+ function drawCrosshair(ctx, w, h, theme, options) {
173
+ const { point, viewport, lineStyle = 'dashed', lineWidth = 1, fullSpan = true, opacity = 1, } = options;
174
+ const { px, py } = domainToCanvas(point.x, point.y, viewport, w, h);
175
+ ctx.globalAlpha = opacity * 0.6;
176
+ ctx.strokeStyle = theme.accentPrimary;
177
+ ctx.lineWidth = lineWidth;
178
+ if (lineStyle === 'dashed') {
179
+ ctx.setLineDash([4, 4]);
180
+ }
181
+ else {
182
+ ctx.setLineDash([]);
183
+ }
184
+ // Vertical line through point
185
+ ctx.beginPath();
186
+ ctx.moveTo(Math.round(px) + 0.5, fullSpan ? 0 : py - 20);
187
+ ctx.lineTo(Math.round(px) + 0.5, fullSpan ? h : py + 20);
188
+ ctx.stroke();
189
+ // Horizontal line through point
190
+ ctx.beginPath();
191
+ ctx.moveTo(fullSpan ? 0 : px - 20, Math.round(py) + 0.5);
192
+ ctx.lineTo(fullSpan ? w : px + 20, Math.round(py) + 0.5);
193
+ ctx.stroke();
194
+ ctx.setLineDash([]);
195
+ }
196
+ /**
197
+ * Draw a circular point marker.
198
+ *
199
+ * Used by CartesianPicker for the selected point.
200
+ * Supports hover and drag visual states.
201
+ */
202
+ function drawPointMarker(ctx, w, h, theme, options) {
203
+ const { point, viewport, radius = 6, hovered = false, dragging = false, opacity = 1, } = options;
204
+ const { px, py } = domainToCanvas(point.x, point.y, viewport, w, h);
205
+ const effectiveRadius = hovered || dragging ? radius + 2 : radius;
206
+ ctx.globalAlpha = opacity;
207
+ // Outer ring
208
+ ctx.beginPath();
209
+ ctx.arc(px, py, effectiveRadius, 0, Math.PI * 2);
210
+ ctx.fillStyle = dragging ? theme.accentPrimary : theme.backgroundSecondary;
211
+ ctx.fill();
212
+ ctx.strokeStyle = theme.accentPrimary;
213
+ ctx.lineWidth = 2;
214
+ ctx.stroke();
215
+ // Inner dot
216
+ ctx.beginPath();
217
+ ctx.arc(px, py, 2, 0, Math.PI * 2);
218
+ ctx.fillStyle = theme.accentPrimary;
219
+ ctx.fill();
220
+ }
221
+ /**
222
+ * Draw axis origin lines (X=0 and Y=0 if visible within viewport).
223
+ *
224
+ * Useful for CartesianPicker where domain is centered on origin.
225
+ */
226
+ function drawOriginAxes(ctx, w, h, theme, viewport, opacity = 1) {
227
+ const [vxMin, vxMax] = viewport.viewX;
228
+ const [vyMin, vyMax] = viewport.viewY;
229
+ ctx.globalAlpha = opacity * 0.5;
230
+ ctx.strokeStyle = theme.textMuted;
231
+ ctx.lineWidth = 1;
232
+ // Y axis (x = 0) if in viewport
233
+ if (vxMin <= 0 && vxMax >= 0) {
234
+ const { px } = domainToCanvas(0, 0, viewport, w, h);
235
+ ctx.beginPath();
236
+ ctx.moveTo(Math.round(px) + 0.5, 0);
237
+ ctx.lineTo(Math.round(px) + 0.5, h);
238
+ ctx.stroke();
239
+ }
240
+ // X axis (y = 0) if in viewport
241
+ if (vyMin <= 0 && vyMax >= 0) {
242
+ const { py } = domainToCanvas(0, 0, viewport, w, h);
243
+ ctx.beginPath();
244
+ ctx.moveTo(0, Math.round(py) + 0.5);
245
+ ctx.lineTo(w, Math.round(py) + 0.5);
246
+ ctx.stroke();
247
+ }
248
+ }
249
+
250
+ export { drawAxisLabels, drawCrosshair, drawDomainBounds, drawGrid, drawOriginAxes, drawPointMarker, formatLabel };
251
+ //# sourceMappingURL=canvasDrawing.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"canvasDrawing.js","sources":["../../../../../../src/components/primitives/canvas/canvasDrawing.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ import { vars } from '../../../theme/contract.css.js';
2
+
3
+ /**
4
+ * Resolve CSS variable references (e.g., `var(--etui-color-text-primary)`)
5
+ * to their computed values via getComputedStyle.
6
+ */
7
+ function resolveVar(element, cssVar) {
8
+ const match = cssVar.match(/var\(([^)]+)\)/);
9
+ if (!match)
10
+ return cssVar;
11
+ const varName = match[1];
12
+ if (!varName)
13
+ return cssVar;
14
+ return getComputedStyle(element).getPropertyValue(varName).trim() || cssVar;
15
+ }
16
+ /**
17
+ * Resolve Vanilla Extract CSS variables from a canvas element to
18
+ * actual color values for canvas 2D drawing.
19
+ *
20
+ * Canvas 2D contexts cannot read CSS variables — this resolves them
21
+ * via getComputedStyle.
22
+ */
23
+ function resolveCanvasTheme(canvas) {
24
+ return {
25
+ backgroundSecondary: resolveVar(canvas, vars.colors.background.secondary),
26
+ borderDefault: resolveVar(canvas, vars.colors.border.default),
27
+ textMuted: resolveVar(canvas, vars.colors.text.muted),
28
+ textPrimary: resolveVar(canvas, vars.colors.text.primary),
29
+ textSecondary: resolveVar(canvas, vars.colors.text.secondary),
30
+ accentPrimary: resolveVar(canvas, vars.colors.accent.primary),
31
+ fontSizeXs: parseFloat(resolveVar(canvas, vars.typography.fontSize.xs)) || 10,
32
+ };
33
+ }
34
+ /**
35
+ * Resolve a single CSS variable reference string (e.g. `var(--etui-color-accent-primary)`)
36
+ * to its computed value.
37
+ */
38
+ function resolveVarValue(element, cssVar) {
39
+ return resolveVar(element, cssVar);
40
+ }
41
+
42
+ export { resolveCanvasTheme, resolveVarValue };
43
+ //# sourceMappingURL=canvasTheme.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"canvasTheme.js","sources":["../../../../../../src/components/primitives/canvas/canvasTheme.ts"],"sourcesContent":[null],"names":[],"mappings":";;AAGA;;;AAGG;AACH,SAAS,UAAU,CAAC,OAAgB,EAAE,MAAc,EAAA;IAClD,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,gBAAgB,CAAC;AAC5C,IAAA,IAAI,CAAC,KAAK;AAAE,QAAA,OAAO,MAAM;AACzB,IAAA,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC;AACxB,IAAA,IAAI,CAAC,OAAO;AAAE,QAAA,OAAO,MAAM;AAC3B,IAAA,OAAO,gBAAgB,CAAC,OAAO,CAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,IAAI,MAAM;AAC7E;AAEA;;;;;;AAMG;AACG,SAAU,kBAAkB,CAChC,MAAyB,EAAA;IAEzB,OAAO;AACL,QAAA,mBAAmB,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC;AACzE,QAAA,aAAa,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC;AAC7D,QAAA,SAAS,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;AACrD,QAAA,WAAW,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC;AACzD,QAAA,aAAa,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;AAC7D,QAAA,aAAa,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC;AAC7D,QAAA,UAAU,EACR,UAAU,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE;KACpE;AACH;AAEA;;;AAGG;AACG,SAAU,eAAe,CAAC,OAAgB,EAAE,MAAc,EAAA;AAC9D,IAAA,OAAO,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC;AACpC;;;;"}
@@ -0,0 +1,26 @@
1
+ "use client";
2
+ import { useRef, useCallback, useEffect } from 'react';
3
+
4
+ /**
5
+ * Hook that manages a rAF-based render loop for canvas drawing.
6
+ *
7
+ * Calls the provided draw function whenever deps change.
8
+ * Does NOT run continuously — only re-renders when deps trigger a change.
9
+ *
10
+ * Extracted from CurveEditor's useCurveRenderer rAF pattern.
11
+ */
12
+ function useCanvasRenderer(options) {
13
+ const { draw, deps, paused = false } = options;
14
+ const rafRef = useRef(0);
15
+ const stableDraw = useCallback(draw, deps); // deps intentionally dynamic
16
+ useEffect(() => {
17
+ if (paused)
18
+ return;
19
+ cancelAnimationFrame(rafRef.current);
20
+ rafRef.current = requestAnimationFrame(stableDraw);
21
+ return () => cancelAnimationFrame(rafRef.current);
22
+ }, [stableDraw, paused]);
23
+ }
24
+
25
+ export { useCanvasRenderer };
26
+ //# sourceMappingURL=useCanvasRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCanvasRenderer.js","sources":["../../../../../../src/components/primitives/canvas/useCanvasRenderer.ts"],"sourcesContent":[null],"names":[],"mappings":";;;AAaA;;;;;;;AAOG;AACG;;AAEJ;;;AAKE;;AAEA;AACA;;AAGF;AACF;;"}
@@ -0,0 +1,13 @@
1
+ import './../../../assets/src/components/shell/AppShell/AppShell.css.ts.vanilla-BYmtU0O_.css';
2
+ import { c as createRuntimeFn } from '../../../node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js';
3
+
4
+ var dockSlot = 'AppShell_dockSlot__1m62ws2l';
5
+ var menuBarSlot = 'AppShell_menuBarSlot__1m62ws22';
6
+ var shellRoot = 'AppShell_shellRoot__1m62ws21';
7
+ var sideToolbarSlot = createRuntimeFn({defaultClassName:'AppShell_sideToolbarSlot__1m62ws28',variantClassNames:{side:{left:'AppShell_sideToolbarSlot_side_left__1m62ws29',right:'AppShell_sideToolbarSlot_side_right__1m62ws2a'},separator:{none:'AppShell_sideToolbarSlot_separator_none__1m62ws2b',border:'AppShell_sideToolbarSlot_separator_border__1m62ws2c',shadow:'AppShell_sideToolbarSlot_separator_shadow__1m62ws2d',both:'AppShell_sideToolbarSlot_separator_both__1m62ws2e'}},defaultVariants:{side:'left',separator:'border'},compoundVariants:[[{side:'left',separator:'border'},'AppShell_sideToolbarSlot_compound_0__1m62ws2f'],[{side:'left',separator:'shadow'},'AppShell_sideToolbarSlot_compound_1__1m62ws2g'],[{side:'left',separator:'both'},'AppShell_sideToolbarSlot_compound_2__1m62ws2h'],[{side:'right',separator:'border'},'AppShell_sideToolbarSlot_compound_3__1m62ws2i'],[{side:'right',separator:'shadow'},'AppShell_sideToolbarSlot_compound_4__1m62ws2j'],[{side:'right',separator:'both'},'AppShell_sideToolbarSlot_compound_5__1m62ws2k']]});
8
+ var statusBarSlot = 'AppShell_statusBarSlot__1m62ws2m';
9
+ var toolbarTopSlot = createRuntimeFn({defaultClassName:'AppShell_toolbarTopSlot__1m62ws23',variantClassNames:{separator:{none:'AppShell_toolbarTopSlot_separator_none__1m62ws24',border:'AppShell_toolbarTopSlot_separator_border__1m62ws25',shadow:'AppShell_toolbarTopSlot_separator_shadow__1m62ws26',both:'AppShell_toolbarTopSlot_separator_both__1m62ws27'}},defaultVariants:{separator:'border'},compoundVariants:[]});
10
+ var viewportLockClass = 'AppShell_viewportLockClass__1m62ws20';
11
+
12
+ export { dockSlot, menuBarSlot, shellRoot, sideToolbarSlot, statusBarSlot, toolbarTopSlot, viewportLockClass };
13
+ //# sourceMappingURL=AppShell.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppShell.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;"}
@@ -1,8 +1,8 @@
1
- import { jsx, jsxs } from 'react/jsx-runtime';
2
- import { useContext, createContext, useState, useCallback, useMemo } from 'react';
3
- import styled from '@emotion/styled';
4
- import { useTheme, Global, css } from '@emotion/react';
5
- import { processCss } from '../../../utils/styledUtils.js';
1
+ "use client";
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { useContext, useState, useCallback, useMemo, createContext } from 'react';
4
+ import { cx } from '../../../utils/cx.js';
5
+ import { viewportLockClass, shellRoot, statusBarSlot, dockSlot, toolbarTopSlot, sideToolbarSlot, menuBarSlot } from './AppShell.css.js';
6
6
 
7
7
  // --- Context ---
8
8
  const AppShellContext = /*#__PURE__*/ createContext({
@@ -12,116 +12,31 @@ const AppShellContext = /*#__PURE__*/ createContext({
12
12
  sideChromeSeparator: 'border',
13
13
  });
14
14
  const useAppShell = () => useContext(AppShellContext);
15
- const StyledAppShell = styled.div `
16
- display: grid;
17
- grid-template-rows: auto auto 1fr auto;
18
- grid-template-columns: auto 1fr auto;
19
- grid-template-areas:
20
- 'menubar menubar menubar'
21
- 'toolbar-top toolbar-top toolbar-top'
22
- 'toolbar-left dock toolbar-right'
23
- 'statusbar statusbar statusbar';
24
- width: 100%;
25
- height: 100%;
26
- overflow: hidden;
27
- background: ${({ theme }) => theme.colors.background.primary};
28
- color: ${({ theme }) => theme.colors.text.primary};
29
- font-family: ${({ theme }) => theme.typography.fontFamily.sans};
30
-
31
- ${({ $css, theme }) => processCss($css, theme)}
32
- `;
33
- const StyledMenuBarSlot = styled.header `
34
- grid-area: menubar;
35
-
36
- ${({ $css, theme }) => processCss($css, theme)}
37
- `;
38
- const StyledToolbarTopSlot = styled.div `
39
- grid-area: toolbar-top;
40
- border-bottom: ${({ $topChromeSeparator, theme }) => $topChromeSeparator === 'border' || $topChromeSeparator === 'both'
41
- ? `1px solid ${theme.colors.border.default}`
42
- : 'none'};
43
- box-shadow: ${({ $topChromeSeparator, theme }) => $topChromeSeparator === 'shadow' || $topChromeSeparator === 'both'
44
- ? theme.shadows.separatorBottom
45
- : 'none'};
46
- z-index: ${({ theme }) => theme.zIndex.base};
47
-
48
- ${({ $css, theme }) => processCss($css, theme)}
49
- `;
50
- const StyledSideToolbarSlot = styled.aside `
51
- grid-area: ${({ $side }) => `toolbar-${$side}`};
52
- min-width: 0;
53
- min-height: 0;
54
- overflow: hidden;
55
- border-right: ${({ $side, $sideChromeSeparator, theme }) => $side === 'left' &&
56
- ($sideChromeSeparator === 'border' || $sideChromeSeparator === 'both')
57
- ? `1px solid ${theme.colors.border.default}`
58
- : 'none'};
59
- border-left: ${({ $side, $sideChromeSeparator, theme }) => $side === 'right' &&
60
- ($sideChromeSeparator === 'border' || $sideChromeSeparator === 'both')
61
- ? `1px solid ${theme.colors.border.default}`
62
- : 'none'};
63
- box-shadow: ${({ $side, $sideChromeSeparator, theme }) => {
64
- if ($sideChromeSeparator !== 'shadow' && $sideChromeSeparator !== 'both')
65
- return 'none';
66
- return $side === 'left'
67
- ? theme.shadows.separatorRight
68
- : theme.shadows.separatorLeft;
69
- }};
70
- z-index: ${({ theme }) => theme.zIndex.base};
71
-
72
- ${({ $css, theme }) => processCss($css, theme)}
73
- `;
74
- const StyledDockSlot = styled.main `
75
- grid-area: dock;
76
- position: relative;
77
- overflow: hidden;
78
- min-width: 0;
79
- min-height: 0;
80
-
81
- ${({ $css, theme }) => processCss($css, theme)}
82
- `;
83
- const StyledStatusBarSlot = styled.footer `
84
- grid-area: statusbar;
85
-
86
- ${({ $css, theme }) => processCss($css, theme)}
87
- `;
88
15
  // --- Slot Components ---
89
- const MenuBarSlot = ({ children, className, style, testId, css, ref, ...rest }) => (jsx(StyledMenuBarSlot, { ref: ref, className: className, style: style, "data-testid": testId, "$css": css, ...rest, children: children }));
16
+ const MenuBarSlot = ({ children, className, style, testId, ref, ...rest }) => (jsx("header", { ref: ref, className: cx(menuBarSlot, className), style: style, "data-testid": testId, ...rest, children: children }));
90
17
  MenuBarSlot.displayName = 'AppShell.MenuBar';
91
- const ToolbarSlot = ({ children, className, style, testId, css, ref, position = 'top', ...rest }) => {
18
+ const ToolbarSlot = ({ children, className, style, testId, ref, position = 'top', ...rest }) => {
92
19
  const { isToolbarVisible, topChromeSeparator, sideChromeSeparator } = useAppShell();
93
20
  if (!isToolbarVisible(position))
94
21
  return null;
95
22
  switch (position) {
96
23
  case 'left':
97
24
  case 'right':
98
- return (jsx(StyledSideToolbarSlot, { ref: ref, className: className, style: style, "data-testid": testId, "$side": position, "$sideChromeSeparator": sideChromeSeparator, "$css": css, ...rest, children: children }));
25
+ return (jsx("aside", { ref: ref, className: cx(sideToolbarSlot({
26
+ side: position,
27
+ separator: sideChromeSeparator,
28
+ }), className), style: style, "data-testid": testId, ...rest, children: children }));
99
29
  default:
100
- return (jsx(StyledToolbarTopSlot, { ref: ref, className: className, style: style, "data-testid": testId, "$topChromeSeparator": topChromeSeparator, "$css": css, ...rest, children: children }));
30
+ return (jsx("div", { ref: ref, className: cx(toolbarTopSlot({ separator: topChromeSeparator }), className), style: style, "data-testid": testId, ...rest, children: children }));
101
31
  }
102
32
  };
103
33
  ToolbarSlot.displayName = 'AppShell.Toolbar';
104
- const DockSlot = ({ children, className, style, testId, css, ref, ...rest }) => (jsx(StyledDockSlot, { ref: ref, className: className, style: style, "data-testid": testId, "$css": css, ...rest, children: children }));
34
+ const DockSlot = ({ children, className, style, testId, ref, ...rest }) => (jsx("main", { ref: ref, className: cx(dockSlot, className), style: style, "data-testid": testId, ...rest, children: children }));
105
35
  DockSlot.displayName = 'AppShell.Dock';
106
- const StatusBarSlot = ({ children, className, style, testId, css, ref, ...rest }) => (jsx(StyledStatusBarSlot, { ref: ref, className: className, style: style, "data-testid": testId, "$css": css, ...rest, children: children }));
36
+ const StatusBarSlot = ({ children, className, style, testId, ref, ...rest }) => (jsx("footer", { ref: ref, className: cx(statusBarSlot, className), style: style, "data-testid": testId, ...rest, children: children }));
107
37
  StatusBarSlot.displayName = 'AppShell.StatusBar';
108
- // --- Viewport Lock Styles ---
109
- const ViewportLockStyles = () => {
110
- const theme = useTheme();
111
- return (jsx(Global, { styles: css `
112
- html,
113
- body {
114
- margin: 0;
115
- padding: 0;
116
- overflow: hidden;
117
- width: 100vw;
118
- height: 100vh;
119
- background: ${theme.colors.background.primary};
120
- }
121
- ` }));
122
- };
123
38
  // --- Root Component ---
124
- const AppShellRoot = ({ viewportLock = false, topChromeSeparator = 'border', sideChromeSeparator = 'border', children, className, style, testId, css, ref, ...rest }) => {
39
+ const AppShellRoot = ({ viewportLock = false, topChromeSeparator = 'border', sideChromeSeparator = 'border', children, className, style, testId, ref, ...rest }) => {
125
40
  const [toolbarVisibility, setToolbarVisibility] = useState({
126
41
  top: true,
127
42
  left: true,
@@ -142,7 +57,7 @@ const AppShellRoot = ({ viewportLock = false, topChromeSeparator = 'border', sid
142
57
  topChromeSeparator,
143
58
  sideChromeSeparator,
144
59
  ]);
145
- return (jsxs(AppShellContext.Provider, { value: contextValue, children: [viewportLock && jsx(ViewportLockStyles, {}), jsx(StyledAppShell, { ref: ref, className: className, style: style, "data-testid": testId, "$css": css, role: "application", ...rest, children: children })] }));
60
+ return (jsx(AppShellContext.Provider, { value: contextValue, children: jsx("div", { ref: ref, className: cx(shellRoot, viewportLock && viewportLockClass, className), style: style, "data-testid": testId, role: "application", ...rest, children: children }) }));
146
61
  };
147
62
  AppShellRoot.displayName = 'AppShell';
148
63
  // --- Compound Component ---
@@ -1 +1 @@
1
- {"version":3,"file":"AppShell.js","sources":["../../../../../../src/components/shell/AppShell/AppShell.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":"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"}
1
+ {"version":3,"file":"AppShell.js","sources":["../../../../../../src/components/shell/AppShell/AppShell.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;AA2BA;AAEA;AACE;AACA;AACA;AACA;AACD;AAEM;AAEP;AAEA;AAkBA;AAEA;;AAYE;AAAiC;;AAG/B;AACA;;AAMU;AACA;AACD;AAUT;AACE;;AAeN;AACA;AAEA;AAmBA;AAEA;AAmBA;AAEA;AAEA;AAYE;AAGE;AACA;AACA;AACD;;;AASG;;AAKJ;;;;;AAMG;;;;;AAMA;;AAiBL;AAEA;AAEA;AAEO;AACL;AACA;AACA;AACA;AACD;;"}