@vuer-ai/vuer-uikit 0.0.88 → 0.0.89

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 (263) hide show
  1. package/dist/SyncScroll/SyncScroll.cjs +3 -3
  2. package/dist/SyncScroll/SyncScroll.mjs +3 -3
  3. package/dist/SyncScroll/index.cjs +3 -3
  4. package/dist/SyncScroll/index.mjs +3 -3
  5. package/dist/{chunk-DKDXGIOU.cjs → chunk-2LIAVSDV.cjs} +2 -2
  6. package/dist/{chunk-VI67LD6E.mjs → chunk-3HUKXFD4.mjs} +1 -1
  7. package/dist/chunk-43ZAEQYD.cjs +564 -0
  8. package/dist/chunk-5PDZWPUI.cjs +208 -0
  9. package/dist/chunk-6FY4AL6N.mjs +15 -0
  10. package/dist/{chunk-XIAVCKC3.mjs → chunk-7YRIF5K4.mjs} +1 -1
  11. package/dist/chunk-AFJ6DMZW.cjs +54 -0
  12. package/dist/{chunk-UKSD5GPI.cjs → chunk-AI2OGSMP.cjs} +2 -2
  13. package/dist/{chunk-URUEOOWI.cjs → chunk-AUCWPDXH.cjs} +2 -2
  14. package/dist/chunk-AUENXQXS.mjs +206 -0
  15. package/dist/{chunk-I2UIJ23T.mjs → chunk-AXTZ2RY6.mjs} +1 -1
  16. package/dist/chunk-C4VVMAPU.cjs +285 -0
  17. package/dist/chunk-CGNTK3WP.cjs +494 -0
  18. package/dist/{chunk-IWS7VNJQ.mjs → chunk-D3U5PLHK.mjs} +1 -1
  19. package/dist/chunk-DG3DDLXZ.mjs +599 -0
  20. package/dist/chunk-E4AGCYEF.mjs +545 -0
  21. package/dist/chunk-EAQAIANE.mjs +20 -0
  22. package/dist/{chunk-BGYHKHMQ.mjs → chunk-FBPAIVBH.mjs} +1 -1
  23. package/dist/{chunk-TKV4YQPL.cjs → chunk-FR6JWEU4.cjs} +1 -1
  24. package/dist/chunk-G5JZGNKY.cjs +308 -0
  25. package/dist/{chunk-YSUCUNBJ.mjs → chunk-GMGAUN57.mjs} +1 -1
  26. package/dist/{chunk-LY5RLGFY.cjs → chunk-GPSSQ7XQ.cjs} +2 -2
  27. package/dist/chunk-H5LP5KMB.cjs +624 -0
  28. package/dist/{chunk-ALQIRJAV.mjs → chunk-HOF7YOYS.mjs} +1 -1
  29. package/dist/{chunk-NQVD3ZW4.cjs → chunk-I22QSUB7.cjs} +1 -1
  30. package/dist/{chunk-ZQNV64BB.cjs → chunk-IBSCKXGA.cjs} +2 -2
  31. package/dist/{chunk-6K3HTR4W.cjs → chunk-IPBOH3RD.cjs} +2 -2
  32. package/dist/chunk-ISLTDEPI.cjs +99 -0
  33. package/dist/{chunk-X3RZDN2C.cjs → chunk-IZNQXFZ6.cjs} +2 -2
  34. package/dist/{chunk-JWS7MZGX.mjs → chunk-J2RFARFN.mjs} +1 -1
  35. package/dist/{chunk-6NUAFTM5.cjs → chunk-JO5TYMHM.cjs} +2 -2
  36. package/dist/{chunk-7WS53WEO.cjs → chunk-JSUB7URV.cjs} +2 -2
  37. package/dist/chunk-KVRUJWH2.mjs +283 -0
  38. package/dist/chunk-KZP7AY75.cjs +22 -0
  39. package/dist/{chunk-4V5DMSTZ.mjs → chunk-LQWJ34PD.mjs} +1 -1
  40. package/dist/{chunk-7CP6EUTM.mjs → chunk-M7CWV3WR.mjs} +1 -1
  41. package/dist/{chunk-OLCFDXGF.mjs → chunk-OBYDDCUD.mjs} +1 -1
  42. package/dist/chunk-PDOFOJ4P.mjs +300 -0
  43. package/dist/{chunk-IV3CZ27Q.cjs → chunk-PHRBUOTG.cjs} +2 -2
  44. package/dist/{chunk-ZE7BMGJN.mjs → chunk-PXVFCVUE.mjs} +1 -1
  45. package/dist/{chunk-QN5Q5OCZ.mjs → chunk-QAERXYKR.mjs} +28 -4
  46. package/dist/{chunk-HMGDXKPW.cjs → chunk-QGGJXDBC.cjs} +2 -2
  47. package/dist/chunk-QKQFSQ6A.mjs +489 -0
  48. package/dist/{chunk-I7NPMMUG.cjs → chunk-RBKCE3N7.cjs} +28 -4
  49. package/dist/{chunk-VWPT77VT.mjs → chunk-SGYNKN5X.mjs} +1 -1
  50. package/dist/chunk-SH4FDQTB.mjs +94 -0
  51. package/dist/{chunk-U2CXSVXD.cjs → chunk-SJPXQV2G.cjs} +2 -2
  52. package/dist/{chunk-SCQQZUQV.mjs → chunk-SQBCVWEA.mjs} +1 -1
  53. package/dist/{chunk-72Q6YVID.cjs → chunk-TG4B5Y3I.cjs} +2 -2
  54. package/dist/chunk-VE3XLQLO.cjs +21 -0
  55. package/dist/chunk-WHRN67N6.mjs +51 -0
  56. package/dist/{chunk-4JAPZTNY.mjs → chunk-XTE66VZ3.mjs} +1 -1
  57. package/dist/dial/DialPanel.cjs +121 -0
  58. package/dist/dial/DialPanel.d.cts +9 -0
  59. package/dist/dial/DialPanel.d.ts +9 -0
  60. package/dist/dial/DialPanel.mjs +112 -0
  61. package/dist/dial/DialProvider.cjs +14 -0
  62. package/dist/dial/DialProvider.d.cts +48 -0
  63. package/dist/dial/DialProvider.d.ts +48 -0
  64. package/dist/dial/DialProvider.mjs +1 -0
  65. package/dist/dial/index.cjs +193 -0
  66. package/dist/dial/index.d.cts +5 -0
  67. package/dist/dial/index.d.ts +5 -0
  68. package/dist/dial/index.mjs +112 -0
  69. package/dist/dial/wrapped-inputs/ControlledInputs.cjs +137 -0
  70. package/dist/dial/wrapped-inputs/ControlledInputs.d.cts +21 -0
  71. package/dist/dial/wrapped-inputs/ControlledInputs.d.ts +21 -0
  72. package/dist/dial/wrapped-inputs/ControlledInputs.mjs +112 -0
  73. package/dist/dial/wrapped-inputs/DialVectorNInput.cjs +121 -0
  74. package/dist/dial/wrapped-inputs/DialVectorNInput.d.cts +15 -0
  75. package/dist/dial/wrapped-inputs/DialVectorNInput.d.ts +15 -0
  76. package/dist/dial/wrapped-inputs/DialVectorNInput.mjs +112 -0
  77. package/dist/dial/wrapped-inputs/DialWrappedInputs.cjs +161 -0
  78. package/dist/dial/wrapped-inputs/DialWrappedInputs.d.cts +24 -0
  79. package/dist/dial/wrapped-inputs/DialWrappedInputs.d.ts +24 -0
  80. package/dist/dial/wrapped-inputs/DialWrappedInputs.mjs +112 -0
  81. package/dist/dial/wrapped-inputs/index.cjs +185 -0
  82. package/dist/dial/wrapped-inputs/index.d.cts +4 -0
  83. package/dist/dial/wrapped-inputs/index.d.ts +4 -0
  84. package/dist/dial/wrapped-inputs/index.mjs +112 -0
  85. package/dist/highlight-cursor/enhanced-components.cjs +10 -10
  86. package/dist/highlight-cursor/enhanced-components.mjs +5 -5
  87. package/dist/highlight-cursor/index.cjs +10 -10
  88. package/dist/highlight-cursor/index.mjs +5 -5
  89. package/dist/hooks/index.cjs +12 -12
  90. package/dist/hooks/index.mjs +3 -3
  91. package/dist/hooks/useQueryParams.cjs +3 -3
  92. package/dist/hooks/useQueryParams.mjs +2 -2
  93. package/dist/index.cjs +475 -397
  94. package/dist/index.d.cts +4 -0
  95. package/dist/index.d.ts +4 -0
  96. package/dist/index.mjs +55 -53
  97. package/dist/ui/UIKitBadge.cjs +8 -8
  98. package/dist/ui/UIKitBadge.mjs +4 -4
  99. package/dist/ui/avatar.cjs +3 -3
  100. package/dist/ui/avatar.mjs +3 -3
  101. package/dist/ui/badge.cjs +3 -3
  102. package/dist/ui/badge.d.cts +1 -1
  103. package/dist/ui/badge.d.ts +1 -1
  104. package/dist/ui/badge.mjs +3 -3
  105. package/dist/ui/button.cjs +3 -3
  106. package/dist/ui/button.mjs +3 -3
  107. package/dist/ui/card.cjs +3 -3
  108. package/dist/ui/card.mjs +3 -3
  109. package/dist/ui/checkbox.cjs +3 -3
  110. package/dist/ui/checkbox.mjs +3 -3
  111. package/dist/ui/collapsible.cjs +3 -3
  112. package/dist/ui/collapsible.mjs +3 -3
  113. package/dist/ui/drawer.cjs +3 -3
  114. package/dist/ui/drawer.mjs +3 -3
  115. package/dist/ui/dropdown.cjs +3 -3
  116. package/dist/ui/dropdown.mjs +3 -3
  117. package/dist/ui/index.cjs +390 -390
  118. package/dist/ui/index.mjs +52 -52
  119. package/dist/ui/inputs/color-input.cjs +3 -3
  120. package/dist/ui/inputs/color-input.mjs +3 -3
  121. package/dist/ui/inputs/index.cjs +39 -39
  122. package/dist/ui/inputs/index.mjs +18 -18
  123. package/dist/ui/inputs/input-numbers.cjs +5 -5
  124. package/dist/ui/inputs/input-numbers.d.cts +7 -2
  125. package/dist/ui/inputs/input-numbers.d.ts +7 -2
  126. package/dist/ui/inputs/input-numbers.mjs +4 -4
  127. package/dist/ui/inputs/input.cjs +3 -3
  128. package/dist/ui/inputs/input.d.cts +1 -1
  129. package/dist/ui/inputs/input.d.ts +1 -1
  130. package/dist/ui/inputs/input.mjs +3 -3
  131. package/dist/ui/inputs/number-inputs/CmInput.cjs +6 -6
  132. package/dist/ui/inputs/number-inputs/CmInput.mjs +5 -5
  133. package/dist/ui/inputs/number-inputs/DegInput.cjs +6 -6
  134. package/dist/ui/inputs/number-inputs/DegInput.mjs +5 -5
  135. package/dist/ui/inputs/number-inputs/EulerDegInput.cjs +8 -8
  136. package/dist/ui/inputs/number-inputs/EulerDegInput.mjs +7 -7
  137. package/dist/ui/inputs/number-inputs/EulerInput.cjs +7 -7
  138. package/dist/ui/inputs/number-inputs/EulerInput.mjs +6 -6
  139. package/dist/ui/inputs/number-inputs/EulerRadInput.cjs +8 -8
  140. package/dist/ui/inputs/number-inputs/EulerRadInput.mjs +7 -7
  141. package/dist/ui/inputs/number-inputs/InchInput.cjs +6 -6
  142. package/dist/ui/inputs/number-inputs/InchInput.mjs +5 -5
  143. package/dist/ui/inputs/number-inputs/IntInput.cjs +6 -6
  144. package/dist/ui/inputs/number-inputs/IntInput.mjs +5 -5
  145. package/dist/ui/inputs/number-inputs/KVectorInput.cjs +7 -7
  146. package/dist/ui/inputs/number-inputs/KVectorInput.mjs +6 -6
  147. package/dist/ui/inputs/number-inputs/QuaternionInput.cjs +7 -7
  148. package/dist/ui/inputs/number-inputs/QuaternionInput.mjs +6 -6
  149. package/dist/ui/inputs/number-inputs/RadInput.cjs +6 -6
  150. package/dist/ui/inputs/number-inputs/RadInput.mjs +5 -5
  151. package/dist/ui/inputs/number-inputs/TimeInput.cjs +6 -6
  152. package/dist/ui/inputs/number-inputs/TimeInput.mjs +5 -5
  153. package/dist/ui/inputs/number-inputs/Vec3Input.cjs +7 -7
  154. package/dist/ui/inputs/number-inputs/Vec3Input.mjs +6 -6
  155. package/dist/ui/inputs/number-inputs/VectorInput.cjs +6 -6
  156. package/dist/ui/inputs/number-inputs/VectorInput.d.cts +6 -0
  157. package/dist/ui/inputs/number-inputs/VectorInput.d.ts +6 -0
  158. package/dist/ui/inputs/number-inputs/VectorInput.mjs +5 -5
  159. package/dist/ui/inputs/number-inputs/index.cjs +36 -36
  160. package/dist/ui/inputs/number-inputs/index.mjs +17 -17
  161. package/dist/ui/inputs/presets-input.cjs +6 -6
  162. package/dist/ui/inputs/presets-input.mjs +5 -5
  163. package/dist/ui/label.cjs +3 -3
  164. package/dist/ui/label.mjs +3 -3
  165. package/dist/ui/layout.cjs +5 -5
  166. package/dist/ui/layout.mjs +4 -4
  167. package/dist/ui/layouts/dock-layout/DockLayoutView.cjs +3 -3
  168. package/dist/ui/layouts/dock-layout/DockLayoutView.mjs +3 -3
  169. package/dist/ui/layouts/dock-layout/LayoutSlots.cjs +3 -3
  170. package/dist/ui/layouts/dock-layout/LayoutSlots.mjs +3 -3
  171. package/dist/ui/layouts/dock-layout/index.cjs +3 -3
  172. package/dist/ui/layouts/dock-layout/index.mjs +3 -3
  173. package/dist/ui/layouts/index.cjs +9 -9
  174. package/dist/ui/layouts/index.mjs +5 -5
  175. package/dist/ui/layouts/liquid-layout/LayoutSlots.cjs +3 -3
  176. package/dist/ui/layouts/liquid-layout/LayoutSlots.mjs +3 -3
  177. package/dist/ui/layouts/liquid-layout/LiquidLayoutView.cjs +3 -3
  178. package/dist/ui/layouts/liquid-layout/LiquidLayoutView.mjs +3 -3
  179. package/dist/ui/layouts/liquid-layout/index.cjs +3 -3
  180. package/dist/ui/layouts/liquid-layout/index.mjs +3 -3
  181. package/dist/ui/modal.cjs +3 -3
  182. package/dist/ui/modal.mjs +3 -3
  183. package/dist/ui/navigation.cjs +3 -3
  184. package/dist/ui/navigation.mjs +3 -3
  185. package/dist/ui/pagination.cjs +3 -3
  186. package/dist/ui/pagination.mjs +3 -3
  187. package/dist/ui/panel.cjs +3 -3
  188. package/dist/ui/panel.mjs +3 -3
  189. package/dist/ui/popover.cjs +3 -3
  190. package/dist/ui/popover.mjs +3 -3
  191. package/dist/ui/radio-group.cjs +3 -3
  192. package/dist/ui/radio-group.mjs +3 -3
  193. package/dist/ui/resizable.cjs +3 -3
  194. package/dist/ui/resizable.mjs +3 -3
  195. package/dist/ui/select.cjs +3 -3
  196. package/dist/ui/select.d.cts +1 -1
  197. package/dist/ui/select.d.ts +1 -1
  198. package/dist/ui/select.mjs +3 -3
  199. package/dist/ui/separator.cjs +3 -3
  200. package/dist/ui/separator.mjs +3 -3
  201. package/dist/ui/sheet.cjs +3 -3
  202. package/dist/ui/sheet.mjs +3 -3
  203. package/dist/ui/sidebar.cjs +29 -29
  204. package/dist/ui/sidebar.mjs +5 -5
  205. package/dist/ui/simple-tree-view.cjs +3 -3
  206. package/dist/ui/simple-tree-view.mjs +3 -3
  207. package/dist/ui/skeleton.cjs +3 -3
  208. package/dist/ui/skeleton.mjs +3 -3
  209. package/dist/ui/slider.cjs +3 -3
  210. package/dist/ui/slider.mjs +3 -3
  211. package/dist/ui/switch.cjs +3 -3
  212. package/dist/ui/switch.mjs +3 -3
  213. package/dist/ui/table.cjs +3 -3
  214. package/dist/ui/table.mjs +3 -3
  215. package/dist/ui/tabs.cjs +3 -3
  216. package/dist/ui/tabs.mjs +3 -3
  217. package/dist/ui/textarea.cjs +3 -3
  218. package/dist/ui/textarea.d.cts +1 -1
  219. package/dist/ui/textarea.d.ts +1 -1
  220. package/dist/ui/textarea.mjs +3 -3
  221. package/dist/ui/theme/ThemeToggles.cjs +3 -3
  222. package/dist/ui/theme/ThemeToggles.mjs +3 -3
  223. package/dist/ui/theme/index.cjs +3 -3
  224. package/dist/ui/theme/index.mjs +3 -3
  225. package/dist/ui/toggle-buttons.cjs +3 -3
  226. package/dist/ui/toggle-buttons.mjs +3 -3
  227. package/dist/ui/toggle-group.cjs +3 -3
  228. package/dist/ui/toggle-group.mjs +3 -3
  229. package/dist/ui/toggle.cjs +3 -3
  230. package/dist/ui/toggle.mjs +3 -3
  231. package/dist/ui/toolbar.cjs +3 -3
  232. package/dist/ui/toolbar.mjs +3 -3
  233. package/dist/ui/tooltip.cjs +3 -3
  234. package/dist/ui/tooltip.mjs +3 -3
  235. package/dist/ui/tree-view/TreeSearchBar.cjs +3 -3
  236. package/dist/ui/tree-view/TreeSearchBar.mjs +3 -3
  237. package/dist/ui/tree-view/TreeView.cjs +3 -3
  238. package/dist/ui/tree-view/TreeView.mjs +3 -3
  239. package/dist/ui/tree-view/index.cjs +4 -4
  240. package/dist/ui/tree-view/index.mjs +4 -4
  241. package/dist/ui/tree-view-legacy.cjs +3 -3
  242. package/dist/ui/tree-view-legacy.mjs +3 -3
  243. package/dist/ui/waterfall/CursorOverlay.cjs +3 -3
  244. package/dist/ui/waterfall/CursorOverlay.mjs +3 -3
  245. package/dist/ui/waterfall/TimelineEvent.cjs +3 -3
  246. package/dist/ui/waterfall/TimelineEvent.mjs +3 -3
  247. package/dist/ui/waterfall/TimelineProcessBar.cjs +3 -3
  248. package/dist/ui/waterfall/TimelineProcessBar.mjs +3 -3
  249. package/dist/ui/waterfall/Wedges.cjs +3 -3
  250. package/dist/ui/waterfall/Wedges.mjs +3 -3
  251. package/dist/ui/waterfall/index.cjs +11 -11
  252. package/dist/ui/waterfall/index.mjs +10 -10
  253. package/package.json +1 -1
  254. package/dist/chunk-VFSVU357.cjs +0 -11
  255. package/dist/chunk-XOZ6S53T.mjs +0 -9
  256. package/dist/{chunk-6U6BHFK4.cjs → chunk-245M2MZD.cjs} +4 -4
  257. package/dist/{chunk-A2PCEL5S.mjs → chunk-4AOAH77D.mjs} +2 -2
  258. package/dist/{chunk-K6FXUV3A.mjs → chunk-4EGKBNF2.mjs} +1 -1
  259. package/dist/{chunk-7QRSUUA2.cjs → chunk-74ETKEMH.cjs} +2 -2
  260. package/dist/{chunk-N22BVDJM.mjs → chunk-K4DBU34E.mjs} +4 -4
  261. package/dist/{chunk-Q4XH2Z5M.cjs → chunk-LYZJNEOR.cjs} +1 -1
  262. package/dist/{chunk-U3LN5NB6.mjs → chunk-OEIF3JCH.mjs} +1 -1
  263. package/dist/{chunk-QUFZWF4E.cjs → chunk-POGM4FXC.cjs} +1 -1
@@ -0,0 +1,208 @@
1
+ 'use strict';
2
+
3
+ var chunkP6DICGAV_cjs = require('./chunk-P6DICGAV.cjs');
4
+ var chunkOHIB3TEN_cjs = require('./chunk-OHIB3TEN.cjs');
5
+ var react = require('react');
6
+ var reactDom = require('react-dom');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+
9
+ var CursorProvider = ({
10
+ children,
11
+ maxOffsetX = 5,
12
+ maxOffsetY = 20,
13
+ cursorSize = 20,
14
+ transitionDuration = 100,
15
+ cursorClassName,
16
+ className,
17
+ as: Component = "div",
18
+ ...props
19
+ }) => {
20
+ const [isClient, setIsClient] = react.useState(false);
21
+ const [isMouseInside, setIsMouseInside] = react.useState(false);
22
+ const [mousePosition, setMousePosition] = react.useState({ x: 0, y: 0 });
23
+ const [hoveredElementId, setHoveredElementId] = react.useState(null);
24
+ const [elementDimensions, setElementDimensions] = react.useState({
25
+ width: 0,
26
+ height: 0,
27
+ x: 0,
28
+ y: 0,
29
+ right: 0,
30
+ bottom: 0
31
+ });
32
+ const hoveredElementRef = react.useRef(null);
33
+ react.useEffect(() => {
34
+ setIsClient(true);
35
+ }, []);
36
+ react.useEffect(() => {
37
+ if (!isClient) return;
38
+ const handleMouseMove = (e) => {
39
+ setMousePosition({ x: e.clientX, y: e.clientY });
40
+ };
41
+ document.addEventListener("mousemove", handleMouseMove);
42
+ return () => document.removeEventListener("mousemove", handleMouseMove);
43
+ }, [isClient]);
44
+ const handleMouseEnter = react.useCallback(() => {
45
+ setIsMouseInside(true);
46
+ }, []);
47
+ const handleMouseLeave = react.useCallback(() => {
48
+ setIsMouseInside(false);
49
+ setHoveredElementId(null);
50
+ hoveredElementRef.current = null;
51
+ }, []);
52
+ const checkMouseInElement = react.useCallback(() => {
53
+ if (!hoveredElementRef.current || !hoveredElementId) {
54
+ return;
55
+ }
56
+ const rect = hoveredElementRef.current.getBoundingClientRect();
57
+ setElementDimensions({
58
+ width: rect.width,
59
+ height: rect.height,
60
+ x: rect.left,
61
+ y: rect.top,
62
+ right: rect.right,
63
+ bottom: rect.bottom
64
+ });
65
+ const isInside = mousePosition.x >= rect.left && mousePosition.x <= rect.right && mousePosition.y >= rect.top && mousePosition.y <= rect.bottom;
66
+ if (!isInside) {
67
+ setHoveredElementId(null);
68
+ hoveredElementRef.current = null;
69
+ }
70
+ }, [mousePosition, hoveredElementId]);
71
+ react.useEffect(() => {
72
+ if (!isClient) return;
73
+ const handleScroll = () => {
74
+ checkMouseInElement();
75
+ };
76
+ document.addEventListener("scroll", handleScroll, { passive: true, capture: true });
77
+ return () => {
78
+ document.removeEventListener("scroll", handleScroll, { capture: true });
79
+ };
80
+ }, [checkMouseInElement, isClient]);
81
+ const registerHoveredElement = react.useCallback(
82
+ (id, dimensions, element) => {
83
+ setHoveredElementId(id);
84
+ setElementDimensions({
85
+ width: dimensions.width,
86
+ height: dimensions.height,
87
+ x: dimensions.left,
88
+ y: dimensions.top,
89
+ right: dimensions.right,
90
+ bottom: dimensions.bottom
91
+ });
92
+ if (element) {
93
+ hoveredElementRef.current = element;
94
+ }
95
+ },
96
+ []
97
+ );
98
+ const unregisterHoveredElement = react.useCallback(() => {
99
+ setHoveredElementId(null);
100
+ hoveredElementRef.current = null;
101
+ }, []);
102
+ const updateElementDimensions = react.useCallback(
103
+ (dimensions) => {
104
+ if (hoveredElementId) {
105
+ setElementDimensions({
106
+ width: dimensions.width,
107
+ height: dimensions.height,
108
+ x: dimensions.left,
109
+ y: dimensions.top,
110
+ right: dimensions.right,
111
+ bottom: dimensions.bottom
112
+ });
113
+ }
114
+ },
115
+ [hoveredElementId]
116
+ );
117
+ const getCursorPosition = () => {
118
+ if (!hoveredElementId) {
119
+ return {
120
+ x: mousePosition.x - cursorSize / 2,
121
+ y: mousePosition.y - cursorSize / 2
122
+ };
123
+ }
124
+ const elementCenterX = elementDimensions.x + elementDimensions.width / 2;
125
+ const elementCenterY = elementDimensions.y + elementDimensions.height / 2;
126
+ const offsetX = (mousePosition.x - elementCenterX) * 0.1;
127
+ const offsetY = (mousePosition.y - elementCenterY) * 0.1;
128
+ const boundedOffsetX = Math.max(-maxOffsetX, Math.min(maxOffsetX, offsetX));
129
+ const boundedOffsetY = Math.max(-maxOffsetY, Math.min(maxOffsetY, offsetY));
130
+ return {
131
+ x: elementDimensions.x + boundedOffsetX,
132
+ y: elementDimensions.y + boundedOffsetY
133
+ };
134
+ };
135
+ const contextValue = react.useMemo(
136
+ () => ({
137
+ // State values that change during component lifecycle
138
+ mousePosition,
139
+ hoveredElementId,
140
+ elementDimensions,
141
+ // Callbacks that should be stable references
142
+ registerHoveredElement,
143
+ unregisterHoveredElement,
144
+ updateElementDimensions
145
+ }),
146
+ [
147
+ mousePosition,
148
+ hoveredElementId,
149
+ elementDimensions,
150
+ registerHoveredElement,
151
+ unregisterHoveredElement,
152
+ updateElementDimensions
153
+ ]
154
+ );
155
+ const cursorPosition = getCursorPosition();
156
+ const cursorStyleObject = react.useMemo(
157
+ () => ({
158
+ left: cursorPosition.x,
159
+ top: cursorPosition.y,
160
+ width: hoveredElementId ? elementDimensions.width > 0 ? elementDimensions.width : cursorSize : cursorSize,
161
+ height: hoveredElementId ? elementDimensions.height > 0 ? elementDimensions.height : cursorSize : cursorSize,
162
+ willChange: "transform, width, height"
163
+ }),
164
+ [
165
+ cursorPosition.x,
166
+ cursorPosition.y,
167
+ hoveredElementId,
168
+ elementDimensions.width,
169
+ elementDimensions.height,
170
+ cursorSize
171
+ ]
172
+ );
173
+ let styleClass;
174
+ if (hoveredElementId) {
175
+ styleClass = `opacity-[0.05] rounded-uk-md transition-[width,height,left,top] duration-${transitionDuration} ease-out`;
176
+ } else {
177
+ styleClass = `opacity-90 rounded-full z-10 transition-[width,height,left,top] duration-${transitionDuration} ease-out transition-opacity duration-${transitionDuration}`;
178
+ }
179
+ const cursorElement = isClient && isMouseInside && /* @__PURE__ */ jsxRuntime.jsx(
180
+ "div",
181
+ {
182
+ className: `pointer-events-none fixed ${styleClass} ${hoveredElementId ? "" : cursorClassName || ""}`,
183
+ style: {
184
+ ...cursorStyleObject,
185
+ backgroundColor: "var(--shadow-tertiary)"
186
+ }
187
+ }
188
+ );
189
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
190
+ isClient && typeof document !== "undefined" && document.body && cursorElement && reactDom.createPortal(cursorElement, document.body),
191
+ /* @__PURE__ */ jsxRuntime.jsx(chunkP6DICGAV_cjs.CursorContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxRuntime.jsx(
192
+ Component,
193
+ {
194
+ ...props,
195
+ className: chunkOHIB3TEN_cjs.cn(className),
196
+ style: {
197
+ cursor: isMouseInside && !hoveredElementId ? "none" : "auto",
198
+ ...props.style
199
+ },
200
+ onMouseEnter: handleMouseEnter,
201
+ onMouseLeave: handleMouseLeave,
202
+ children
203
+ }
204
+ ) })
205
+ ] });
206
+ };
207
+
208
+ exports.CursorProvider = CursorProvider;
@@ -0,0 +1,15 @@
1
+ import { Tabs } from './chunk-B53A4WNW.mjs';
2
+ import { Textarea } from './chunk-25RDJXX7.mjs';
3
+ import { InputRoot } from './chunk-4XUJBMDE.mjs';
4
+ import { SelectTrigger } from './chunk-CX6OFX5Z.mjs';
5
+ import { Button } from './chunk-INHZ5D7P.mjs';
6
+ import { withCursor } from './chunk-RAHKRYQJ.mjs';
7
+
8
+ // src/highlight-cursor/enhanced-components.tsx
9
+ var CursorButton = withCursor(Button);
10
+ var CursorTabs = withCursor(Tabs);
11
+ var CursorInputRoot = withCursor(InputRoot);
12
+ var CursorSelectTrigger = withCursor(SelectTrigger);
13
+ var CursorTextarea = withCursor(Textarea);
14
+
15
+ export { CursorButton, CursorInputRoot, CursorSelectTrigger, CursorTabs, CursorTextarea };
@@ -1,4 +1,4 @@
1
- import { InputNumbers } from './chunk-QN5Q5OCZ.mjs';
1
+ import { InputNumbers } from './chunk-QAERXYKR.mjs';
2
2
  import { forwardRef } from 'react';
3
3
  import { jsx } from 'react/jsx-runtime';
4
4
 
@@ -0,0 +1,54 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+
6
+ // src/dial/DialProvider.tsx
7
+ var DialSchemaContext = react.createContext(void 0);
8
+ var useDialSchema = () => {
9
+ const context = react.useContext(DialSchemaContext);
10
+ if (!context) {
11
+ throw new Error("useDialSchema must be used within a DialSchemaProvider");
12
+ }
13
+ return context;
14
+ };
15
+ var DialProvider = ({
16
+ children,
17
+ schemas,
18
+ initialValues = {},
19
+ onValueChange
20
+ }) => {
21
+ const [values, setValues] = react.useState(() => {
22
+ const defaultValues = {};
23
+ schemas.forEach((schema) => {
24
+ defaultValues[schema.name] = initialValues[schema.name] ?? schema.value;
25
+ });
26
+ return defaultValues;
27
+ });
28
+ const getValue = react.useCallback((name) => {
29
+ return values[name];
30
+ }, [values]);
31
+ const setValue = react.useCallback((name, value) => {
32
+ setValues((prev) => ({
33
+ ...prev,
34
+ [name]: value
35
+ }));
36
+ onValueChange?.(name, value);
37
+ }, [onValueChange]);
38
+ return /* @__PURE__ */ jsxRuntime.jsx(
39
+ DialSchemaContext.Provider,
40
+ {
41
+ value: {
42
+ values,
43
+ schemas,
44
+ getValue,
45
+ setValue,
46
+ onValueChange
47
+ },
48
+ children
49
+ }
50
+ );
51
+ };
52
+
53
+ exports.DialProvider = DialProvider;
54
+ exports.useDialSchema = useDialSchema;
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var chunkZQNV64BB_cjs = require('./chunk-ZQNV64BB.cjs');
3
+ var chunkIBSCKXGA_cjs = require('./chunk-IBSCKXGA.cjs');
4
4
  var react = require('react');
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
6
 
7
7
  var EulerDegInput = react.forwardRef(
8
8
  function EulerDegInput2(props, ref) {
9
- return /* @__PURE__ */ jsxRuntime.jsx(chunkZQNV64BB_cjs.EulerInput, { ref, unit: "deg", ...props });
9
+ return /* @__PURE__ */ jsxRuntime.jsx(chunkIBSCKXGA_cjs.EulerInput, { ref, unit: "deg", ...props });
10
10
  }
11
11
  );
12
12
 
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var chunkVFSVU357_cjs = require('./chunk-VFSVU357.cjs');
3
+ var chunkKZP7AY75_cjs = require('./chunk-KZP7AY75.cjs');
4
4
  var react = require('react');
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
6
 
7
7
  var QuaternionInput = react.forwardRef(function QuaternionInput2({ value, onValuesChange, ...props }, ref) {
8
8
  return /* @__PURE__ */ jsxRuntime.jsx(
9
- chunkVFSVU357_cjs.VectorInput,
9
+ chunkKZP7AY75_cjs.VectorInput,
10
10
  {
11
11
  ref,
12
12
  value,
@@ -0,0 +1,206 @@
1
+ import { CursorContext } from './chunk-3FR3WKI4.mjs';
2
+ import { cn } from './chunk-HMN4IKTG.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 };
@@ -1,4 +1,4 @@
1
- import { VectorInput } from './chunk-XOZ6S53T.mjs';
1
+ import { VectorInput } from './chunk-EAQAIANE.mjs';
2
2
  import { forwardRef } from 'react';
3
3
  import { jsx } from 'react/jsx-runtime';
4
4