@vuer-ai/vuer-uikit 0.0.96 → 0.0.98

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 (341) hide show
  1. package/README.md +106 -7
  2. package/cli/dial-cli.js +49 -7
  3. package/dist/SyncScroll/SyncScroll.cjs +10 -10
  4. package/dist/SyncScroll/SyncScroll.mjs +3 -3
  5. package/dist/SyncScroll/index.cjs +10 -10
  6. package/dist/SyncScroll/index.mjs +3 -3
  7. package/dist/chunk-3HEZVWRW.mjs +62 -0
  8. package/dist/chunk-4KWGGESI.cjs +494 -0
  9. package/dist/{chunk-CCMKL2OA.cjs → chunk-7GWDO25E.cjs} +2 -2
  10. package/dist/chunk-A5LCX2UQ.cjs +208 -0
  11. package/dist/chunk-BEJIZ56L.mjs +300 -0
  12. package/dist/chunk-C7VGRU3O.mjs +283 -0
  13. package/dist/{chunk-LONOMMFA.cjs → chunk-LJMNHTTG.cjs} +21 -21
  14. package/dist/chunk-O66RESRR.cjs +285 -0
  15. package/dist/{chunk-RINTUFYQ.cjs → chunk-RMK6W774.cjs} +24 -19
  16. package/dist/{chunk-BFQ2WL5U.mjs → chunk-TTYSYGVE.mjs} +2 -2
  17. package/dist/chunk-VA3PEYFM.mjs +489 -0
  18. package/dist/chunk-VBBJSIY7.cjs +308 -0
  19. package/dist/{chunk-AIINOWEH.mjs → chunk-W4JCKCW7.mjs} +5 -5
  20. package/dist/chunk-WWGF6TBZ.mjs +206 -0
  21. package/dist/chunk-ZGN4UEJR.cjs +679 -0
  22. package/dist/chunk-ZQLRMOUW.mjs +661 -0
  23. package/dist/dial/DialPanel.cjs +24 -24
  24. package/dist/dial/DialPanel.mjs +23 -23
  25. package/dist/dial/DialProvider.cjs +3 -3
  26. package/dist/dial/DialProvider.d.cts +1 -0
  27. package/dist/dial/DialProvider.d.ts +1 -0
  28. package/dist/dial/DialProvider.example.cjs +72 -0
  29. package/dist/dial/DialProvider.example.d.cts +7 -0
  30. package/dist/dial/DialProvider.example.d.ts +7 -0
  31. package/dist/dial/DialProvider.example.mjs +68 -0
  32. package/dist/dial/DialProvider.mjs +1 -1
  33. package/dist/dial/index.cjs +42 -42
  34. package/dist/dial/index.mjs +23 -23
  35. package/dist/dial/wrapped-inputs/ControlledInputs.cjs +27 -27
  36. package/dist/dial/wrapped-inputs/ControlledInputs.mjs +23 -23
  37. package/dist/dial/wrapped-inputs/DialInputs.cjs +34 -34
  38. package/dist/dial/wrapped-inputs/DialInputs.mjs +23 -23
  39. package/dist/dial/wrapped-inputs/DialVectorInput.cjs +24 -24
  40. package/dist/dial/wrapped-inputs/DialVectorInput.mjs +23 -23
  41. package/dist/dial/wrapped-inputs/index.cjs +39 -39
  42. package/dist/dial/wrapped-inputs/index.mjs +23 -23
  43. package/dist/highlight-cursor/cursor-provider.cjs +3 -3
  44. package/dist/highlight-cursor/cursor-provider.mjs +2 -2
  45. package/dist/highlight-cursor/enhanced-components.cjs +10 -10
  46. package/dist/highlight-cursor/enhanced-components.mjs +5 -5
  47. package/dist/highlight-cursor/index.cjs +16 -16
  48. package/dist/highlight-cursor/index.mjs +6 -6
  49. package/dist/hooks/index.cjs +5 -5
  50. package/dist/hooks/index.mjs +1 -1
  51. package/dist/index.cjs +190 -190
  52. package/dist/index.mjs +23 -23
  53. package/dist/ui/UIKitBadge.cjs +6 -6
  54. package/dist/ui/UIKitBadge.mjs +2 -2
  55. package/dist/ui/avatar.cjs +1 -1
  56. package/dist/ui/avatar.mjs +1 -1
  57. package/dist/ui/badge.cjs +1 -1
  58. package/dist/ui/badge.d.cts +1 -1
  59. package/dist/ui/badge.d.ts +1 -1
  60. package/dist/ui/badge.mjs +1 -1
  61. package/dist/ui/button.cjs +1 -1
  62. package/dist/ui/button.mjs +1 -1
  63. package/dist/ui/card.cjs +1 -1
  64. package/dist/ui/card.mjs +1 -1
  65. package/dist/ui/checkbox.cjs +1 -1
  66. package/dist/ui/checkbox.mjs +1 -1
  67. package/dist/ui/collapsible.cjs +1 -1
  68. package/dist/ui/collapsible.mjs +1 -1
  69. package/dist/ui/drawer.cjs +1 -1
  70. package/dist/ui/drawer.mjs +1 -1
  71. package/dist/ui/dropdown.cjs +1 -1
  72. package/dist/ui/dropdown.mjs +1 -1
  73. package/dist/ui/index.cjs +107 -107
  74. package/dist/ui/index.mjs +17 -17
  75. package/dist/ui/inputs/color-input.cjs +1 -1
  76. package/dist/ui/inputs/color-input.mjs +1 -1
  77. package/dist/ui/inputs/index.cjs +11 -11
  78. package/dist/ui/inputs/index.mjs +3 -3
  79. package/dist/ui/inputs/input-numbers.cjs +1 -1
  80. package/dist/ui/inputs/input-numbers.mjs +1 -1
  81. package/dist/ui/inputs/input.cjs +1 -1
  82. package/dist/ui/inputs/input.d.cts +1 -1
  83. package/dist/ui/inputs/input.d.ts +1 -1
  84. package/dist/ui/inputs/input.mjs +1 -1
  85. package/dist/ui/inputs/number-inputs/CmInput.cjs +1 -1
  86. package/dist/ui/inputs/number-inputs/CmInput.mjs +1 -1
  87. package/dist/ui/inputs/number-inputs/DegInput.cjs +1 -1
  88. package/dist/ui/inputs/number-inputs/DegInput.mjs +1 -1
  89. package/dist/ui/inputs/number-inputs/EulerDegInput.cjs +1 -1
  90. package/dist/ui/inputs/number-inputs/EulerDegInput.mjs +1 -1
  91. package/dist/ui/inputs/number-inputs/EulerInput.cjs +1 -1
  92. package/dist/ui/inputs/number-inputs/EulerInput.mjs +1 -1
  93. package/dist/ui/inputs/number-inputs/EulerRadInput.cjs +1 -1
  94. package/dist/ui/inputs/number-inputs/EulerRadInput.mjs +1 -1
  95. package/dist/ui/inputs/number-inputs/InchInput.cjs +1 -1
  96. package/dist/ui/inputs/number-inputs/InchInput.mjs +1 -1
  97. package/dist/ui/inputs/number-inputs/IntInput.cjs +1 -1
  98. package/dist/ui/inputs/number-inputs/IntInput.mjs +1 -1
  99. package/dist/ui/inputs/number-inputs/KVectorInput.cjs +1 -1
  100. package/dist/ui/inputs/number-inputs/KVectorInput.mjs +1 -1
  101. package/dist/ui/inputs/number-inputs/QuaternionInput.cjs +1 -1
  102. package/dist/ui/inputs/number-inputs/QuaternionInput.mjs +1 -1
  103. package/dist/ui/inputs/number-inputs/RadInput.cjs +1 -1
  104. package/dist/ui/inputs/number-inputs/RadInput.mjs +1 -1
  105. package/dist/ui/inputs/number-inputs/TimeInput.cjs +1 -1
  106. package/dist/ui/inputs/number-inputs/TimeInput.mjs +1 -1
  107. package/dist/ui/inputs/number-inputs/Vec3Input.cjs +1 -1
  108. package/dist/ui/inputs/number-inputs/Vec3Input.mjs +1 -1
  109. package/dist/ui/inputs/number-inputs/VectorInput.cjs +1 -1
  110. package/dist/ui/inputs/number-inputs/VectorInput.mjs +1 -1
  111. package/dist/ui/inputs/number-inputs/index.cjs +11 -11
  112. package/dist/ui/inputs/number-inputs/index.mjs +3 -3
  113. package/dist/ui/inputs/presets-input.cjs +1 -1
  114. package/dist/ui/inputs/presets-input.mjs +1 -1
  115. package/dist/ui/label.cjs +1 -1
  116. package/dist/ui/label.mjs +1 -1
  117. package/dist/ui/layout.cjs +1 -1
  118. package/dist/ui/layout.mjs +1 -1
  119. package/dist/ui/layouts/dock-layout/DockLayoutView.cjs +1 -1
  120. package/dist/ui/layouts/dock-layout/DockLayoutView.mjs +1 -1
  121. package/dist/ui/layouts/dock-layout/LayoutSlots.cjs +1 -1
  122. package/dist/ui/layouts/dock-layout/LayoutSlots.mjs +1 -1
  123. package/dist/ui/layouts/dock-layout/index.cjs +1 -1
  124. package/dist/ui/layouts/dock-layout/index.mjs +1 -1
  125. package/dist/ui/layouts/index.cjs +2 -2
  126. package/dist/ui/layouts/index.mjs +2 -2
  127. package/dist/ui/layouts/liquid-layout/LayoutSlots.cjs +1 -1
  128. package/dist/ui/layouts/liquid-layout/LayoutSlots.mjs +1 -1
  129. package/dist/ui/layouts/liquid-layout/LiquidLayoutView.cjs +1 -1
  130. package/dist/ui/layouts/liquid-layout/LiquidLayoutView.mjs +1 -1
  131. package/dist/ui/layouts/liquid-layout/index.cjs +1 -1
  132. package/dist/ui/layouts/liquid-layout/index.mjs +1 -1
  133. package/dist/ui/modal.cjs +1 -1
  134. package/dist/ui/modal.mjs +1 -1
  135. package/dist/ui/navigation.cjs +1 -1
  136. package/dist/ui/navigation.mjs +1 -1
  137. package/dist/ui/pagination.cjs +1 -1
  138. package/dist/ui/pagination.mjs +1 -1
  139. package/dist/ui/panel.cjs +1 -1
  140. package/dist/ui/panel.mjs +1 -1
  141. package/dist/ui/popover.cjs +1 -1
  142. package/dist/ui/popover.mjs +1 -1
  143. package/dist/ui/radio-group.cjs +1 -1
  144. package/dist/ui/radio-group.mjs +1 -1
  145. package/dist/ui/resizable.cjs +1 -1
  146. package/dist/ui/resizable.mjs +1 -1
  147. package/dist/ui/select.cjs +1 -1
  148. package/dist/ui/select.d.cts +1 -1
  149. package/dist/ui/select.d.ts +1 -1
  150. package/dist/ui/select.mjs +1 -1
  151. package/dist/ui/separator.cjs +1 -1
  152. package/dist/ui/separator.mjs +1 -1
  153. package/dist/ui/sheet.cjs +1 -1
  154. package/dist/ui/sheet.mjs +1 -1
  155. package/dist/ui/sidebar.cjs +26 -26
  156. package/dist/ui/sidebar.mjs +2 -2
  157. package/dist/ui/simple-tree-view.cjs +1 -1
  158. package/dist/ui/simple-tree-view.mjs +1 -1
  159. package/dist/ui/skeleton.cjs +1 -1
  160. package/dist/ui/skeleton.mjs +1 -1
  161. package/dist/ui/slider.cjs +1 -1
  162. package/dist/ui/slider.mjs +1 -1
  163. package/dist/ui/switch.cjs +1 -1
  164. package/dist/ui/switch.mjs +1 -1
  165. package/dist/ui/table.cjs +1 -1
  166. package/dist/ui/table.mjs +1 -1
  167. package/dist/ui/tabs.cjs +1 -1
  168. package/dist/ui/tabs.mjs +1 -1
  169. package/dist/ui/textarea.cjs +1 -1
  170. package/dist/ui/textarea.d.cts +1 -1
  171. package/dist/ui/textarea.d.ts +1 -1
  172. package/dist/ui/textarea.mjs +1 -1
  173. package/dist/ui/theme/ThemeToggles.cjs +1 -1
  174. package/dist/ui/theme/ThemeToggles.mjs +1 -1
  175. package/dist/ui/theme/index.cjs +1 -1
  176. package/dist/ui/theme/index.mjs +1 -1
  177. package/dist/ui/toggle-buttons.cjs +1 -1
  178. package/dist/ui/toggle-buttons.mjs +1 -1
  179. package/dist/ui/toggle-group.cjs +1 -1
  180. package/dist/ui/toggle-group.mjs +1 -1
  181. package/dist/ui/toggle.cjs +1 -1
  182. package/dist/ui/toggle.mjs +1 -1
  183. package/dist/ui/toolbar.cjs +1 -1
  184. package/dist/ui/toolbar.mjs +1 -1
  185. package/dist/ui/tooltip.cjs +1 -1
  186. package/dist/ui/tooltip.mjs +1 -1
  187. package/dist/ui/tree-view/TreeSearchBar.cjs +1 -1
  188. package/dist/ui/tree-view/TreeSearchBar.mjs +1 -1
  189. package/dist/ui/tree-view/TreeView.cjs +1 -1
  190. package/dist/ui/tree-view/TreeView.mjs +1 -1
  191. package/dist/ui/tree-view/index.cjs +6 -6
  192. package/dist/ui/tree-view/index.mjs +2 -2
  193. package/dist/ui/tree-view-legacy.cjs +9 -9
  194. package/dist/ui/tree-view-legacy.mjs +5 -5
  195. package/dist/ui/waterfall/CursorOverlay.cjs +1 -1
  196. package/dist/ui/waterfall/CursorOverlay.mjs +1 -1
  197. package/dist/ui/waterfall/TimelineEvent.cjs +1 -1
  198. package/dist/ui/waterfall/TimelineEvent.mjs +1 -1
  199. package/dist/ui/waterfall/TimelineProcessBar.cjs +1 -1
  200. package/dist/ui/waterfall/TimelineProcessBar.mjs +1 -1
  201. package/dist/ui/waterfall/Wedges.cjs +1 -1
  202. package/dist/ui/waterfall/Wedges.mjs +1 -1
  203. package/dist/ui/waterfall/index.cjs +8 -8
  204. package/dist/ui/waterfall/index.mjs +7 -7
  205. package/package.json +28 -2
  206. package/src/SyncScroll/README.md +283 -0
  207. package/src/SyncScroll/SyncScroll.tsx +361 -0
  208. package/src/SyncScroll/index.ts +22 -0
  209. package/src/SyncScroll/useSyncScroll.tsx +226 -0
  210. package/src/cli/dial-cli.ts +1133 -0
  211. package/src/dial/DialPanel.tsx +208 -0
  212. package/src/dial/DialProvider.example.tsx +80 -0
  213. package/src/dial/DialProvider.tsx +138 -0
  214. package/src/dial/index.ts +26 -0
  215. package/src/dial/wrapped-inputs/ControlledInputs.tsx +176 -0
  216. package/src/dial/wrapped-inputs/DialInputs.tsx +401 -0
  217. package/src/dial/wrapped-inputs/DialVectorInput.tsx +125 -0
  218. package/src/dial/wrapped-inputs/index.ts +25 -0
  219. package/src/highlight-cursor/cursor-context.tsx +23 -0
  220. package/src/highlight-cursor/cursor-provider.tsx +264 -0
  221. package/src/highlight-cursor/enhanced-components.tsx +16 -0
  222. package/src/highlight-cursor/index.ts +21 -0
  223. package/src/highlight-cursor/tabs-cursor-context.tsx +121 -0
  224. package/src/highlight-cursor/types.ts +40 -0
  225. package/src/highlight-cursor/with-cursor.tsx +144 -0
  226. package/src/hooks/clientOnly.tsx +54 -0
  227. package/src/hooks/cn.ts +33 -0
  228. package/src/hooks/index.ts +9 -0
  229. package/src/hooks/useDocument.tsx +18 -0
  230. package/src/hooks/useDragSelect.ts +116 -0
  231. package/src/hooks/useIsMobile.ts +35 -0
  232. package/src/hooks/useLocalStorage.ts +122 -0
  233. package/src/hooks/useLocation.tsx +95 -0
  234. package/src/hooks/useQueryParams.tsx +31 -0
  235. package/src/hooks/useWindow.tsx +18 -0
  236. package/src/index.css +5 -0
  237. package/src/index.ts +5 -0
  238. package/src/styles/.editorconfig +0 -0
  239. package/src/styles/theme.css +152 -0
  240. package/src/styles/toast.css +67 -0
  241. package/src/styles/variables.css +229 -0
  242. package/src/ui/UIKitBadge.tsx +171 -0
  243. package/src/ui/avatar.tsx +221 -0
  244. package/src/ui/badge.tsx +74 -0
  245. package/src/ui/button.tsx +143 -0
  246. package/src/ui/card.tsx +146 -0
  247. package/src/ui/checkbox.tsx +78 -0
  248. package/src/ui/collapsible.tsx +43 -0
  249. package/src/ui/drag-selectable/DragSelectProvider.tsx +178 -0
  250. package/src/ui/drag-selectable/createSelectable.tsx +43 -0
  251. package/src/ui/drag-selectable/index.ts +2 -0
  252. package/src/ui/drawer.tsx +137 -0
  253. package/src/ui/dropdown.tsx +707 -0
  254. package/src/ui/icons/MouseCursorIcons.tsx +39 -0
  255. package/src/ui/icons/cursor.tsx +38 -0
  256. package/src/ui/icons/index.ts +2 -0
  257. package/src/ui/index.ts +45 -0
  258. package/src/ui/inputs/color-input.tsx +61 -0
  259. package/src/ui/inputs/index.tsx +5 -0
  260. package/src/ui/inputs/input-numbers.tsx +394 -0
  261. package/src/ui/inputs/input.tsx +155 -0
  262. package/src/ui/inputs/number-inputs/CmInput.tsx +26 -0
  263. package/src/ui/inputs/number-inputs/DegInput.tsx +26 -0
  264. package/src/ui/inputs/number-inputs/EulerDegInput.tsx +14 -0
  265. package/src/ui/inputs/number-inputs/EulerInput.tsx +30 -0
  266. package/src/ui/inputs/number-inputs/EulerRadInput.tsx +14 -0
  267. package/src/ui/inputs/number-inputs/InchInput.tsx +26 -0
  268. package/src/ui/inputs/number-inputs/IntInput.tsx +46 -0
  269. package/src/ui/inputs/number-inputs/KVectorInput.tsx +20 -0
  270. package/src/ui/inputs/number-inputs/QuaternionInput.tsx +27 -0
  271. package/src/ui/inputs/number-inputs/RadInput.tsx +26 -0
  272. package/src/ui/inputs/number-inputs/TimeInput.tsx +26 -0
  273. package/src/ui/inputs/number-inputs/Vec3Input.tsx +26 -0
  274. package/src/ui/inputs/number-inputs/VectorInput.tsx +38 -0
  275. package/src/ui/inputs/number-inputs/index.ts +38 -0
  276. package/src/ui/inputs/presets-input.tsx +59 -0
  277. package/src/ui/label.tsx +35 -0
  278. package/src/ui/layout.tsx +43 -0
  279. package/src/ui/layouts/dock-layout/DockLayoutView.tsx +128 -0
  280. package/src/ui/layouts/dock-layout/LayoutSlots.tsx +85 -0
  281. package/src/ui/layouts/dock-layout/index.tsx +2 -0
  282. package/src/ui/layouts/index.ts +2 -0
  283. package/src/ui/layouts/liquid-layout/LayoutSlots.tsx +82 -0
  284. package/src/ui/layouts/liquid-layout/LiquidLayoutView.tsx +76 -0
  285. package/src/ui/layouts/liquid-layout/index.ts +1 -0
  286. package/src/ui/modal.tsx +211 -0
  287. package/src/ui/navigation.tsx +86 -0
  288. package/src/ui/pagination.tsx +129 -0
  289. package/src/ui/panel.tsx +146 -0
  290. package/src/ui/popover.tsx +112 -0
  291. package/src/ui/radio-group.tsx +63 -0
  292. package/src/ui/resizable.tsx +52 -0
  293. package/src/ui/select.tsx +365 -0
  294. package/src/ui/separator.tsx +26 -0
  295. package/src/ui/sheet.tsx +257 -0
  296. package/src/ui/sidebar.tsx +695 -0
  297. package/src/ui/simple-tree-view.tsx +604 -0
  298. package/src/ui/skeleton.tsx +15 -0
  299. package/src/ui/slider.tsx +204 -0
  300. package/src/ui/switch.tsx +45 -0
  301. package/src/ui/table.tsx +99 -0
  302. package/src/ui/tabs.tsx +192 -0
  303. package/src/ui/textarea.tsx +55 -0
  304. package/src/ui/theme/ThemeProvider.tsx +319 -0
  305. package/src/ui/theme/ThemeToggles.tsx +84 -0
  306. package/src/ui/theme/index.ts +21 -0
  307. package/src/ui/theme/themeScript.tsx +179 -0
  308. package/src/ui/theme/types.ts +61 -0
  309. package/src/ui/toast.tsx +30 -0
  310. package/src/ui/toggle-buttons.tsx +290 -0
  311. package/src/ui/toggle-group.tsx +236 -0
  312. package/src/ui/toggle.tsx +94 -0
  313. package/src/ui/toolbar.tsx +54 -0
  314. package/src/ui/tooltip.tsx +171 -0
  315. package/src/ui/tree-view/TreeSearchBar.tsx +88 -0
  316. package/src/ui/tree-view/TreeView.tsx +232 -0
  317. package/src/ui/tree-view/hooks.tsx +289 -0
  318. package/src/ui/tree-view/index.ts +4 -0
  319. package/src/ui/tree-view/types.ts +23 -0
  320. package/src/ui/tree-view-legacy.tsx +644 -0
  321. package/src/ui/version-badge.tsx +0 -0
  322. package/src/ui/waterfall/CursorOverlay.tsx +96 -0
  323. package/src/ui/waterfall/NavigationControls.tsx +42 -0
  324. package/src/ui/waterfall/Tick.tsx +51 -0
  325. package/src/ui/waterfall/TimeRuleEventDot.tsx +19 -0
  326. package/src/ui/waterfall/TimelineEvent.tsx +60 -0
  327. package/src/ui/waterfall/TimelineProcessBar.tsx +207 -0
  328. package/src/ui/waterfall/Wedges.tsx +67 -0
  329. package/src/ui/waterfall/WheelZoomContext.tsx +128 -0
  330. package/src/ui/waterfall/hooks/useTimelineState.tsx +134 -0
  331. package/src/ui/waterfall/hooks/useViewport.tsx +293 -0
  332. package/src/ui/waterfall/index.tsx +326 -0
  333. package/src/ui/waterfall/types.ts +20 -0
  334. package/src/ui/waterfall/utils.ts +91 -0
  335. package/dist/chunk-W2YAQV5N.mjs +0 -57
  336. package/dist/{chunk-QLCEHV4Q.mjs → chunk-2OZK5DY5.mjs} +2 -2
  337. package/dist/{chunk-Z35DNFRZ.cjs → chunk-7IS37C3P.cjs} +2 -2
  338. package/dist/{chunk-4AOAH77D.mjs → chunk-A2PCEL5S.mjs} +2 -2
  339. package/dist/{chunk-K4VD5PPY.mjs → chunk-BIUDC66P.mjs} +1 -1
  340. package/dist/{chunk-RKJR6RZU.cjs → chunk-OYNLQTHW.cjs} +1 -1
  341. package/dist/{chunk-VE3XLQLO.cjs → chunk-QUFZWF4E.cjs} +2 -2
@@ -0,0 +1,308 @@
1
+ 'use strict';
2
+
3
+ var chunkG4FJGNY5_cjs = require('./chunk-G4FJGNY5.cjs');
4
+ var chunkOHIB3TEN_cjs = require('./chunk-OHIB3TEN.cjs');
5
+ var reactSlot = require('@radix-ui/react-slot');
6
+ var react = require('react');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+
9
+ var SyncScroll = ({ children, className, asChild = false, ...props }) => {
10
+ const Comp = asChild ? reactSlot.Slot : "div";
11
+ return /* @__PURE__ */ jsxRuntime.jsx(Comp, { ref: chunkG4FJGNY5_cjs.useSyncScroll(), className: chunkOHIB3TEN_cjs.cn("overflow-y-auto", className), ...props, children });
12
+ };
13
+ var SyncScrollSlave = ({
14
+ children,
15
+ className,
16
+ asChild = false,
17
+ ...props
18
+ }) => {
19
+ const Comp = asChild ? reactSlot.Slot : "div";
20
+ return /* @__PURE__ */ jsxRuntime.jsx(Comp, { ref: chunkG4FJGNY5_cjs.useScrollSlave(), className: chunkOHIB3TEN_cjs.cn("overflow-y-auto", className), ...props, children });
21
+ };
22
+ var SyncDrag = ({
23
+ ref: extRef,
24
+ children,
25
+ className,
26
+ asChild = false,
27
+ ...props
28
+ }) => {
29
+ const ref = chunkG4FJGNY5_cjs.useSyncDrag({ ref: extRef, axis: "both" });
30
+ const [isDragging, setIsDragging] = react.useState(false);
31
+ const dragStartX = react.useRef(0);
32
+ const dragStartY = react.useRef(0);
33
+ const scrollStartLeft = react.useRef(0);
34
+ const scrollStartTop = react.useRef(0);
35
+ react.useEffect(() => {
36
+ const element = ref.current;
37
+ if (!element) return;
38
+ const handleMouseDown = (e) => {
39
+ setIsDragging(true);
40
+ dragStartX.current = e.clientX;
41
+ dragStartY.current = e.clientY;
42
+ scrollStartLeft.current = element.scrollLeft;
43
+ scrollStartTop.current = element.scrollTop;
44
+ e.preventDefault();
45
+ };
46
+ const handleMouseMove = (e) => {
47
+ if (!isDragging || !element) return;
48
+ const deltaX = e.clientX - dragStartX.current;
49
+ const deltaY = e.clientY - dragStartY.current;
50
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
51
+ element.scrollTop = scrollStartTop.current - deltaY * 2;
52
+ };
53
+ const handleMouseUp = () => {
54
+ setIsDragging(false);
55
+ };
56
+ element.addEventListener("mousedown", handleMouseDown);
57
+ if (isDragging) {
58
+ document.addEventListener("mousemove", handleMouseMove);
59
+ document.addEventListener("mouseup", handleMouseUp);
60
+ document.addEventListener("mouseleave", handleMouseUp);
61
+ }
62
+ return () => {
63
+ element.removeEventListener("mousedown", handleMouseDown);
64
+ document.removeEventListener("mousemove", handleMouseMove);
65
+ document.removeEventListener("mouseup", handleMouseUp);
66
+ document.removeEventListener("mouseleave", handleMouseUp);
67
+ };
68
+ }, [isDragging, ref]);
69
+ const Comp = asChild ? reactSlot.Slot : "div";
70
+ return /* @__PURE__ */ jsxRuntime.jsx(
71
+ Comp,
72
+ {
73
+ ref,
74
+ className: chunkOHIB3TEN_cjs.cn("cursor-grab overflow-auto", isDragging && "cursor-grabbing", className),
75
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
76
+ ...props,
77
+ children
78
+ }
79
+ );
80
+ };
81
+ var SyncDragX = ({ children, className, asChild = false, ...props }) => {
82
+ const ref = chunkG4FJGNY5_cjs.useSyncDrag({ axis: "horizontal" });
83
+ const [isDragging, setIsDragging] = react.useState(false);
84
+ const dragStartX = react.useRef(0);
85
+ const scrollStartLeft = react.useRef(0);
86
+ react.useEffect(() => {
87
+ const element = ref.current;
88
+ if (!element) return;
89
+ const handleMouseDown = (e) => {
90
+ setIsDragging(true);
91
+ dragStartX.current = e.clientX;
92
+ scrollStartLeft.current = element.scrollLeft;
93
+ e.preventDefault();
94
+ };
95
+ const handleMouseMove = (e) => {
96
+ if (!isDragging || !element) return;
97
+ const deltaX = e.clientX - dragStartX.current;
98
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
99
+ };
100
+ const handleMouseUp = () => {
101
+ setIsDragging(false);
102
+ };
103
+ element.addEventListener("mousedown", handleMouseDown);
104
+ if (isDragging) {
105
+ document.addEventListener("mousemove", handleMouseMove);
106
+ document.addEventListener("mouseup", handleMouseUp);
107
+ document.addEventListener("mouseleave", handleMouseUp);
108
+ }
109
+ return () => {
110
+ element.removeEventListener("mousedown", handleMouseDown);
111
+ document.removeEventListener("mousemove", handleMouseMove);
112
+ document.removeEventListener("mouseup", handleMouseUp);
113
+ document.removeEventListener("mouseleave", handleMouseUp);
114
+ };
115
+ }, [isDragging, ref]);
116
+ const Comp = asChild ? reactSlot.Slot : "div";
117
+ return /* @__PURE__ */ jsxRuntime.jsx(
118
+ Comp,
119
+ {
120
+ ref,
121
+ className: chunkOHIB3TEN_cjs.cn("cursor-grab overflow-x-auto", isDragging ? "cursor-grabbing" : "", className),
122
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
123
+ ...props,
124
+ children
125
+ }
126
+ );
127
+ };
128
+ var SyncDragSlave = ({
129
+ ref: extRef,
130
+ children,
131
+ className,
132
+ asChild = false,
133
+ ...props
134
+ }) => {
135
+ const ref = chunkG4FJGNY5_cjs.useScrollSlave({ ref: extRef, axis: "both" });
136
+ const [isDragging, setIsDragging] = react.useState(false);
137
+ const dragStartX = react.useRef(0);
138
+ const dragStartY = react.useRef(0);
139
+ const scrollStartLeft = react.useRef(0);
140
+ const scrollStartTop = react.useRef(0);
141
+ react.useEffect(() => {
142
+ const element = ref.current;
143
+ if (!element) return;
144
+ const handleMouseDown = (e) => {
145
+ setIsDragging(true);
146
+ dragStartX.current = e.clientX;
147
+ dragStartY.current = e.clientY;
148
+ scrollStartLeft.current = element.scrollLeft;
149
+ scrollStartTop.current = element.scrollTop;
150
+ e.preventDefault();
151
+ };
152
+ const handleMouseMove = (e) => {
153
+ if (!isDragging || !element) return;
154
+ const deltaX = e.clientX - dragStartX.current;
155
+ const deltaY = e.clientY - dragStartY.current;
156
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
157
+ element.scrollTop = scrollStartTop.current - deltaY * 2;
158
+ };
159
+ const handleMouseUp = () => {
160
+ setIsDragging(false);
161
+ };
162
+ element.addEventListener("mousedown", handleMouseDown);
163
+ if (isDragging) {
164
+ document.addEventListener("mousemove", handleMouseMove);
165
+ document.addEventListener("mouseup", handleMouseUp);
166
+ document.addEventListener("mouseleave", handleMouseUp);
167
+ }
168
+ return () => {
169
+ element.removeEventListener("mousedown", handleMouseDown);
170
+ document.removeEventListener("mousemove", handleMouseMove);
171
+ document.removeEventListener("mouseup", handleMouseUp);
172
+ document.removeEventListener("mouseleave", handleMouseUp);
173
+ };
174
+ }, [isDragging, ref]);
175
+ const Comp = asChild ? reactSlot.Slot : "div";
176
+ return /* @__PURE__ */ jsxRuntime.jsx(
177
+ Comp,
178
+ {
179
+ ref,
180
+ className: chunkOHIB3TEN_cjs.cn("cursor-grab overflow-auto", isDragging && "cursor-grabbing", className),
181
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
182
+ ...props,
183
+ children
184
+ }
185
+ );
186
+ };
187
+ var SyncDragSlaveX = ({
188
+ ref: extRef,
189
+ children,
190
+ className,
191
+ asChild = false,
192
+ ...props
193
+ }) => {
194
+ const ref = chunkG4FJGNY5_cjs.useScrollSlave({ ref: extRef, axis: "horizontal" });
195
+ const [isDragging, setIsDragging] = react.useState(false);
196
+ const dragStartX = react.useRef(0);
197
+ const scrollStartLeft = react.useRef(0);
198
+ react.useEffect(() => {
199
+ const element = ref.current;
200
+ if (!element) return;
201
+ const handleMouseDown = (e) => {
202
+ setIsDragging(true);
203
+ dragStartX.current = e.clientX;
204
+ scrollStartLeft.current = element.scrollLeft;
205
+ e.preventDefault();
206
+ };
207
+ const handleMouseMove = (e) => {
208
+ if (!isDragging || !element) return;
209
+ const deltaX = e.clientX - dragStartX.current;
210
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
211
+ };
212
+ const handleMouseUp = () => {
213
+ setIsDragging(false);
214
+ };
215
+ element.addEventListener("mousedown", handleMouseDown);
216
+ if (isDragging) {
217
+ document.addEventListener("mousemove", handleMouseMove);
218
+ document.addEventListener("mouseup", handleMouseUp);
219
+ document.addEventListener("mouseleave", handleMouseUp);
220
+ }
221
+ return () => {
222
+ element.removeEventListener("mousedown", handleMouseDown);
223
+ document.removeEventListener("mousemove", handleMouseMove);
224
+ document.removeEventListener("mouseup", handleMouseUp);
225
+ document.removeEventListener("mouseleave", handleMouseUp);
226
+ };
227
+ }, [isDragging, ref]);
228
+ const Comp = asChild ? reactSlot.Slot : "div";
229
+ return /* @__PURE__ */ jsxRuntime.jsx(
230
+ Comp,
231
+ {
232
+ ref,
233
+ className: chunkOHIB3TEN_cjs.cn(
234
+ "cursor-grab overflow-x-auto overflow-y-hidden",
235
+ isDragging && "cursor-grabbing",
236
+ className
237
+ ),
238
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
239
+ ...props,
240
+ children
241
+ }
242
+ );
243
+ };
244
+ var SyncDragY = ({
245
+ ref: extRef,
246
+ children,
247
+ className,
248
+ asChild = false,
249
+ ...props
250
+ }) => {
251
+ const ref = chunkG4FJGNY5_cjs.useSyncDrag({ ref: extRef, axis: "vertical" });
252
+ const [isDragging, setIsDragging] = react.useState(false);
253
+ const dragStartY = react.useRef(0);
254
+ const scrollStartTop = react.useRef(0);
255
+ react.useEffect(() => {
256
+ const element = ref.current;
257
+ if (!element) return;
258
+ const handleMouseDown = (e) => {
259
+ setIsDragging(true);
260
+ dragStartY.current = e.clientY;
261
+ scrollStartTop.current = element.scrollTop;
262
+ e.preventDefault();
263
+ };
264
+ const handleMouseMove = (e) => {
265
+ if (!isDragging || !element) return;
266
+ const deltaY = e.clientY - dragStartY.current;
267
+ element.scrollTop = scrollStartTop.current - deltaY * 2;
268
+ };
269
+ const handleMouseUp = () => {
270
+ setIsDragging(false);
271
+ };
272
+ element.addEventListener("mousedown", handleMouseDown);
273
+ if (isDragging) {
274
+ document.addEventListener("mousemove", handleMouseMove);
275
+ document.addEventListener("mouseup", handleMouseUp);
276
+ document.addEventListener("mouseleave", handleMouseUp);
277
+ }
278
+ return () => {
279
+ element.removeEventListener("mousedown", handleMouseDown);
280
+ document.removeEventListener("mousemove", handleMouseMove);
281
+ document.removeEventListener("mouseup", handleMouseUp);
282
+ document.removeEventListener("mouseleave", handleMouseUp);
283
+ };
284
+ }, [isDragging, ref]);
285
+ const Comp = asChild ? reactSlot.Slot : "div";
286
+ return /* @__PURE__ */ jsxRuntime.jsx(
287
+ Comp,
288
+ {
289
+ ref,
290
+ className: chunkOHIB3TEN_cjs.cn(
291
+ "cursor-grab overflow-x-hidden overflow-y-auto",
292
+ isDragging && "cursor-grabbing",
293
+ className
294
+ ),
295
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
296
+ ...props,
297
+ children
298
+ }
299
+ );
300
+ };
301
+
302
+ exports.SyncDrag = SyncDrag;
303
+ exports.SyncDragSlave = SyncDragSlave;
304
+ exports.SyncDragSlaveX = SyncDragSlaveX;
305
+ exports.SyncDragX = SyncDragX;
306
+ exports.SyncDragY = SyncDragY;
307
+ exports.SyncScroll = SyncScroll;
308
+ exports.SyncScrollSlave = SyncScrollSlave;
@@ -1,21 +1,21 @@
1
+ import { QuaternionInput } from './chunk-6J7ZVRSY.mjs';
1
2
  import { RadInput } from './chunk-GPV4XELL.mjs';
2
3
  import { TimeInput } from './chunk-7R2ZBAE6.mjs';
3
4
  import { Vec3Input } from './chunk-PIXIN3IG.mjs';
5
+ import { CmInput } from './chunk-SQQXY4AY.mjs';
4
6
  import { DegInput } from './chunk-CZ2YNM7Y.mjs';
5
7
  import { EulerDegInput } from './chunk-OJUK6WJ5.mjs';
6
8
  import { EulerInput } from './chunk-5TXABUNC.mjs';
7
9
  import { InchInput } from './chunk-ZZLF2YWP.mjs';
8
10
  import { IntInput } from './chunk-NT5ZTF56.mjs';
9
- import { QuaternionInput } from './chunk-6J7ZVRSY.mjs';
10
11
  import { VectorInput } from './chunk-6CM4GYJU.mjs';
11
- import { CmInput } from './chunk-SQQXY4AY.mjs';
12
12
  import { Slider } from './chunk-Y6WGGVT2.mjs';
13
13
  import { Switch } from './chunk-AZBJB6KC.mjs';
14
- import { Label } from './chunk-42UBHC2D.mjs';
15
14
  import { FormLayout } from './chunk-NRQJX772.mjs';
16
- import { InputRoot, InputSlot } from './chunk-4XUJBMDE.mjs';
15
+ import { Label } from './chunk-42UBHC2D.mjs';
16
+ import { useDialSchema } from './chunk-3HEZVWRW.mjs';
17
17
  import { Select, SelectTrigger, SelectValue, SelectContent, SelectItem } from './chunk-CX6OFX5Z.mjs';
18
- import { useDialSchema } from './chunk-W2YAQV5N.mjs';
18
+ import { InputRoot, InputSlot } from './chunk-4XUJBMDE.mjs';
19
19
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
20
20
 
21
21
  var DialInputWrapper = ({ label, children }) => {
@@ -0,0 +1,206 @@
1
+ import { cn } from './chunk-HMN4IKTG.mjs';
2
+ import { CursorContext } from './chunk-3FR3WKI4.mjs';
3
+ import { useState, useRef, useEffect, useCallback, useMemo } from 'react';
4
+ import { createPortal } from 'react-dom';
5
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
6
+
7
+ var CursorProvider = ({
8
+ children,
9
+ maxOffsetX = 5,
10
+ maxOffsetY = 20,
11
+ cursorSize = 20,
12
+ transitionDuration = 100,
13
+ cursorClassName,
14
+ className,
15
+ as: Component = "div",
16
+ ...props
17
+ }) => {
18
+ const [isClient, setIsClient] = useState(false);
19
+ const [isMouseInside, setIsMouseInside] = useState(false);
20
+ const [mousePosition, setMousePosition] = useState({ x: 0, y: 0 });
21
+ const [hoveredElementId, setHoveredElementId] = useState(null);
22
+ const [elementDimensions, setElementDimensions] = useState({
23
+ width: 0,
24
+ height: 0,
25
+ x: 0,
26
+ y: 0,
27
+ right: 0,
28
+ bottom: 0
29
+ });
30
+ const hoveredElementRef = useRef(null);
31
+ useEffect(() => {
32
+ setIsClient(true);
33
+ }, []);
34
+ useEffect(() => {
35
+ if (!isClient) return;
36
+ const handleMouseMove = (e) => {
37
+ setMousePosition({ x: e.clientX, y: e.clientY });
38
+ };
39
+ document.addEventListener("mousemove", handleMouseMove);
40
+ return () => document.removeEventListener("mousemove", handleMouseMove);
41
+ }, [isClient]);
42
+ const handleMouseEnter = useCallback(() => {
43
+ setIsMouseInside(true);
44
+ }, []);
45
+ const handleMouseLeave = useCallback(() => {
46
+ setIsMouseInside(false);
47
+ setHoveredElementId(null);
48
+ hoveredElementRef.current = null;
49
+ }, []);
50
+ const checkMouseInElement = useCallback(() => {
51
+ if (!hoveredElementRef.current || !hoveredElementId) {
52
+ return;
53
+ }
54
+ const rect = hoveredElementRef.current.getBoundingClientRect();
55
+ setElementDimensions({
56
+ width: rect.width,
57
+ height: rect.height,
58
+ x: rect.left,
59
+ y: rect.top,
60
+ right: rect.right,
61
+ bottom: rect.bottom
62
+ });
63
+ const isInside = mousePosition.x >= rect.left && mousePosition.x <= rect.right && mousePosition.y >= rect.top && mousePosition.y <= rect.bottom;
64
+ if (!isInside) {
65
+ setHoveredElementId(null);
66
+ hoveredElementRef.current = null;
67
+ }
68
+ }, [mousePosition, hoveredElementId]);
69
+ useEffect(() => {
70
+ if (!isClient) return;
71
+ const handleScroll = () => {
72
+ checkMouseInElement();
73
+ };
74
+ document.addEventListener("scroll", handleScroll, { passive: true, capture: true });
75
+ return () => {
76
+ document.removeEventListener("scroll", handleScroll, { capture: true });
77
+ };
78
+ }, [checkMouseInElement, isClient]);
79
+ const registerHoveredElement = useCallback(
80
+ (id, dimensions, element) => {
81
+ setHoveredElementId(id);
82
+ setElementDimensions({
83
+ width: dimensions.width,
84
+ height: dimensions.height,
85
+ x: dimensions.left,
86
+ y: dimensions.top,
87
+ right: dimensions.right,
88
+ bottom: dimensions.bottom
89
+ });
90
+ if (element) {
91
+ hoveredElementRef.current = element;
92
+ }
93
+ },
94
+ []
95
+ );
96
+ const unregisterHoveredElement = useCallback(() => {
97
+ setHoveredElementId(null);
98
+ hoveredElementRef.current = null;
99
+ }, []);
100
+ const updateElementDimensions = useCallback(
101
+ (dimensions) => {
102
+ if (hoveredElementId) {
103
+ setElementDimensions({
104
+ width: dimensions.width,
105
+ height: dimensions.height,
106
+ x: dimensions.left,
107
+ y: dimensions.top,
108
+ right: dimensions.right,
109
+ bottom: dimensions.bottom
110
+ });
111
+ }
112
+ },
113
+ [hoveredElementId]
114
+ );
115
+ const getCursorPosition = () => {
116
+ if (!hoveredElementId) {
117
+ return {
118
+ x: mousePosition.x - cursorSize / 2,
119
+ y: mousePosition.y - cursorSize / 2
120
+ };
121
+ }
122
+ const elementCenterX = elementDimensions.x + elementDimensions.width / 2;
123
+ const elementCenterY = elementDimensions.y + elementDimensions.height / 2;
124
+ const offsetX = (mousePosition.x - elementCenterX) * 0.1;
125
+ const offsetY = (mousePosition.y - elementCenterY) * 0.1;
126
+ const boundedOffsetX = Math.max(-maxOffsetX, Math.min(maxOffsetX, offsetX));
127
+ const boundedOffsetY = Math.max(-maxOffsetY, Math.min(maxOffsetY, offsetY));
128
+ return {
129
+ x: elementDimensions.x + boundedOffsetX,
130
+ y: elementDimensions.y + boundedOffsetY
131
+ };
132
+ };
133
+ const contextValue = useMemo(
134
+ () => ({
135
+ // State values that change during component lifecycle
136
+ mousePosition,
137
+ hoveredElementId,
138
+ elementDimensions,
139
+ // Callbacks that should be stable references
140
+ registerHoveredElement,
141
+ unregisterHoveredElement,
142
+ updateElementDimensions
143
+ }),
144
+ [
145
+ mousePosition,
146
+ hoveredElementId,
147
+ elementDimensions,
148
+ registerHoveredElement,
149
+ unregisterHoveredElement,
150
+ updateElementDimensions
151
+ ]
152
+ );
153
+ const cursorPosition = getCursorPosition();
154
+ const cursorStyleObject = useMemo(
155
+ () => ({
156
+ left: cursorPosition.x,
157
+ top: cursorPosition.y,
158
+ width: hoveredElementId ? elementDimensions.width > 0 ? elementDimensions.width : cursorSize : cursorSize,
159
+ height: hoveredElementId ? elementDimensions.height > 0 ? elementDimensions.height : cursorSize : cursorSize,
160
+ willChange: "transform, width, height"
161
+ }),
162
+ [
163
+ cursorPosition.x,
164
+ cursorPosition.y,
165
+ hoveredElementId,
166
+ elementDimensions.width,
167
+ elementDimensions.height,
168
+ cursorSize
169
+ ]
170
+ );
171
+ let styleClass;
172
+ if (hoveredElementId) {
173
+ styleClass = `opacity-[0.05] rounded-uk-md transition-[width,height,left,top] duration-${transitionDuration} ease-out`;
174
+ } else {
175
+ styleClass = `opacity-90 rounded-full z-10 transition-[width,height,left,top] duration-${transitionDuration} ease-out transition-opacity duration-${transitionDuration}`;
176
+ }
177
+ const cursorElement = isClient && isMouseInside && /* @__PURE__ */ jsx(
178
+ "div",
179
+ {
180
+ className: `pointer-events-none fixed ${styleClass} ${hoveredElementId ? "" : cursorClassName || ""}`,
181
+ style: {
182
+ ...cursorStyleObject,
183
+ backgroundColor: "var(--shadow-tertiary)"
184
+ }
185
+ }
186
+ );
187
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
188
+ isClient && typeof document !== "undefined" && document.body && cursorElement && createPortal(cursorElement, document.body),
189
+ /* @__PURE__ */ jsx(CursorContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx(
190
+ Component,
191
+ {
192
+ ...props,
193
+ className: cn(className),
194
+ style: {
195
+ cursor: isMouseInside && !hoveredElementId ? "none" : "auto",
196
+ ...props.style
197
+ },
198
+ onMouseEnter: handleMouseEnter,
199
+ onMouseLeave: handleMouseLeave,
200
+ children
201
+ }
202
+ ) })
203
+ ] });
204
+ };
205
+
206
+ export { CursorProvider };