@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,300 @@
1
+ import { cn } from './chunk-HMN4IKTG.mjs';
2
+ import { useSyncScroll, useScrollSlave, useSyncDrag } from './chunk-SAGQV2YZ.mjs';
3
+ import { Slot } from '@radix-ui/react-slot';
4
+ import { useState, useRef, useEffect } from 'react';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ var SyncScroll = ({ children, className, asChild = false, ...props }) => {
8
+ const Comp = asChild ? Slot : "div";
9
+ return /* @__PURE__ */ jsx(Comp, { ref: useSyncScroll(), className: cn("overflow-y-auto", className), ...props, children });
10
+ };
11
+ var SyncScrollSlave = ({
12
+ children,
13
+ className,
14
+ asChild = false,
15
+ ...props
16
+ }) => {
17
+ const Comp = asChild ? Slot : "div";
18
+ return /* @__PURE__ */ jsx(Comp, { ref: useScrollSlave(), className: cn("overflow-y-auto", className), ...props, children });
19
+ };
20
+ var SyncDrag = ({
21
+ ref: extRef,
22
+ children,
23
+ className,
24
+ asChild = false,
25
+ ...props
26
+ }) => {
27
+ const ref = useSyncDrag({ ref: extRef, axis: "both" });
28
+ const [isDragging, setIsDragging] = useState(false);
29
+ const dragStartX = useRef(0);
30
+ const dragStartY = useRef(0);
31
+ const scrollStartLeft = useRef(0);
32
+ const scrollStartTop = useRef(0);
33
+ useEffect(() => {
34
+ const element = ref.current;
35
+ if (!element) return;
36
+ const handleMouseDown = (e) => {
37
+ setIsDragging(true);
38
+ dragStartX.current = e.clientX;
39
+ dragStartY.current = e.clientY;
40
+ scrollStartLeft.current = element.scrollLeft;
41
+ scrollStartTop.current = element.scrollTop;
42
+ e.preventDefault();
43
+ };
44
+ const handleMouseMove = (e) => {
45
+ if (!isDragging || !element) return;
46
+ const deltaX = e.clientX - dragStartX.current;
47
+ const deltaY = e.clientY - dragStartY.current;
48
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
49
+ element.scrollTop = scrollStartTop.current - deltaY * 2;
50
+ };
51
+ const handleMouseUp = () => {
52
+ setIsDragging(false);
53
+ };
54
+ element.addEventListener("mousedown", handleMouseDown);
55
+ if (isDragging) {
56
+ document.addEventListener("mousemove", handleMouseMove);
57
+ document.addEventListener("mouseup", handleMouseUp);
58
+ document.addEventListener("mouseleave", handleMouseUp);
59
+ }
60
+ return () => {
61
+ element.removeEventListener("mousedown", handleMouseDown);
62
+ document.removeEventListener("mousemove", handleMouseMove);
63
+ document.removeEventListener("mouseup", handleMouseUp);
64
+ document.removeEventListener("mouseleave", handleMouseUp);
65
+ };
66
+ }, [isDragging, ref]);
67
+ const Comp = asChild ? Slot : "div";
68
+ return /* @__PURE__ */ jsx(
69
+ Comp,
70
+ {
71
+ ref,
72
+ className: cn("cursor-grab overflow-auto", isDragging && "cursor-grabbing", className),
73
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
74
+ ...props,
75
+ children
76
+ }
77
+ );
78
+ };
79
+ var SyncDragX = ({ children, className, asChild = false, ...props }) => {
80
+ const ref = useSyncDrag({ axis: "horizontal" });
81
+ const [isDragging, setIsDragging] = useState(false);
82
+ const dragStartX = useRef(0);
83
+ const scrollStartLeft = useRef(0);
84
+ useEffect(() => {
85
+ const element = ref.current;
86
+ if (!element) return;
87
+ const handleMouseDown = (e) => {
88
+ setIsDragging(true);
89
+ dragStartX.current = e.clientX;
90
+ scrollStartLeft.current = element.scrollLeft;
91
+ e.preventDefault();
92
+ };
93
+ const handleMouseMove = (e) => {
94
+ if (!isDragging || !element) return;
95
+ const deltaX = e.clientX - dragStartX.current;
96
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
97
+ };
98
+ const handleMouseUp = () => {
99
+ setIsDragging(false);
100
+ };
101
+ element.addEventListener("mousedown", handleMouseDown);
102
+ if (isDragging) {
103
+ document.addEventListener("mousemove", handleMouseMove);
104
+ document.addEventListener("mouseup", handleMouseUp);
105
+ document.addEventListener("mouseleave", handleMouseUp);
106
+ }
107
+ return () => {
108
+ element.removeEventListener("mousedown", handleMouseDown);
109
+ document.removeEventListener("mousemove", handleMouseMove);
110
+ document.removeEventListener("mouseup", handleMouseUp);
111
+ document.removeEventListener("mouseleave", handleMouseUp);
112
+ };
113
+ }, [isDragging, ref]);
114
+ const Comp = asChild ? Slot : "div";
115
+ return /* @__PURE__ */ jsx(
116
+ Comp,
117
+ {
118
+ ref,
119
+ className: cn("cursor-grab overflow-x-auto", isDragging ? "cursor-grabbing" : "", className),
120
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
121
+ ...props,
122
+ children
123
+ }
124
+ );
125
+ };
126
+ var SyncDragSlave = ({
127
+ ref: extRef,
128
+ children,
129
+ className,
130
+ asChild = false,
131
+ ...props
132
+ }) => {
133
+ const ref = useScrollSlave({ ref: extRef, axis: "both" });
134
+ const [isDragging, setIsDragging] = useState(false);
135
+ const dragStartX = useRef(0);
136
+ const dragStartY = useRef(0);
137
+ const scrollStartLeft = useRef(0);
138
+ const scrollStartTop = useRef(0);
139
+ useEffect(() => {
140
+ const element = ref.current;
141
+ if (!element) return;
142
+ const handleMouseDown = (e) => {
143
+ setIsDragging(true);
144
+ dragStartX.current = e.clientX;
145
+ dragStartY.current = e.clientY;
146
+ scrollStartLeft.current = element.scrollLeft;
147
+ scrollStartTop.current = element.scrollTop;
148
+ e.preventDefault();
149
+ };
150
+ const handleMouseMove = (e) => {
151
+ if (!isDragging || !element) return;
152
+ const deltaX = e.clientX - dragStartX.current;
153
+ const deltaY = e.clientY - dragStartY.current;
154
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
155
+ element.scrollTop = scrollStartTop.current - deltaY * 2;
156
+ };
157
+ const handleMouseUp = () => {
158
+ setIsDragging(false);
159
+ };
160
+ element.addEventListener("mousedown", handleMouseDown);
161
+ if (isDragging) {
162
+ document.addEventListener("mousemove", handleMouseMove);
163
+ document.addEventListener("mouseup", handleMouseUp);
164
+ document.addEventListener("mouseleave", handleMouseUp);
165
+ }
166
+ return () => {
167
+ element.removeEventListener("mousedown", handleMouseDown);
168
+ document.removeEventListener("mousemove", handleMouseMove);
169
+ document.removeEventListener("mouseup", handleMouseUp);
170
+ document.removeEventListener("mouseleave", handleMouseUp);
171
+ };
172
+ }, [isDragging, ref]);
173
+ const Comp = asChild ? Slot : "div";
174
+ return /* @__PURE__ */ jsx(
175
+ Comp,
176
+ {
177
+ ref,
178
+ className: cn("cursor-grab overflow-auto", isDragging && "cursor-grabbing", className),
179
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
180
+ ...props,
181
+ children
182
+ }
183
+ );
184
+ };
185
+ var SyncDragSlaveX = ({
186
+ ref: extRef,
187
+ children,
188
+ className,
189
+ asChild = false,
190
+ ...props
191
+ }) => {
192
+ const ref = useScrollSlave({ ref: extRef, axis: "horizontal" });
193
+ const [isDragging, setIsDragging] = useState(false);
194
+ const dragStartX = useRef(0);
195
+ const scrollStartLeft = useRef(0);
196
+ useEffect(() => {
197
+ const element = ref.current;
198
+ if (!element) return;
199
+ const handleMouseDown = (e) => {
200
+ setIsDragging(true);
201
+ dragStartX.current = e.clientX;
202
+ scrollStartLeft.current = element.scrollLeft;
203
+ e.preventDefault();
204
+ };
205
+ const handleMouseMove = (e) => {
206
+ if (!isDragging || !element) return;
207
+ const deltaX = e.clientX - dragStartX.current;
208
+ element.scrollLeft = scrollStartLeft.current - deltaX * 2;
209
+ };
210
+ const handleMouseUp = () => {
211
+ setIsDragging(false);
212
+ };
213
+ element.addEventListener("mousedown", handleMouseDown);
214
+ if (isDragging) {
215
+ document.addEventListener("mousemove", handleMouseMove);
216
+ document.addEventListener("mouseup", handleMouseUp);
217
+ document.addEventListener("mouseleave", handleMouseUp);
218
+ }
219
+ return () => {
220
+ element.removeEventListener("mousedown", handleMouseDown);
221
+ document.removeEventListener("mousemove", handleMouseMove);
222
+ document.removeEventListener("mouseup", handleMouseUp);
223
+ document.removeEventListener("mouseleave", handleMouseUp);
224
+ };
225
+ }, [isDragging, ref]);
226
+ const Comp = asChild ? Slot : "div";
227
+ return /* @__PURE__ */ jsx(
228
+ Comp,
229
+ {
230
+ ref,
231
+ className: cn(
232
+ "cursor-grab overflow-x-auto overflow-y-hidden",
233
+ isDragging && "cursor-grabbing",
234
+ className
235
+ ),
236
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
237
+ ...props,
238
+ children
239
+ }
240
+ );
241
+ };
242
+ var SyncDragY = ({
243
+ ref: extRef,
244
+ children,
245
+ className,
246
+ asChild = false,
247
+ ...props
248
+ }) => {
249
+ const ref = useSyncDrag({ ref: extRef, axis: "vertical" });
250
+ const [isDragging, setIsDragging] = useState(false);
251
+ const dragStartY = useRef(0);
252
+ const scrollStartTop = useRef(0);
253
+ useEffect(() => {
254
+ const element = ref.current;
255
+ if (!element) return;
256
+ const handleMouseDown = (e) => {
257
+ setIsDragging(true);
258
+ dragStartY.current = e.clientY;
259
+ scrollStartTop.current = element.scrollTop;
260
+ e.preventDefault();
261
+ };
262
+ const handleMouseMove = (e) => {
263
+ if (!isDragging || !element) return;
264
+ const deltaY = e.clientY - dragStartY.current;
265
+ element.scrollTop = scrollStartTop.current - deltaY * 2;
266
+ };
267
+ const handleMouseUp = () => {
268
+ setIsDragging(false);
269
+ };
270
+ element.addEventListener("mousedown", handleMouseDown);
271
+ if (isDragging) {
272
+ document.addEventListener("mousemove", handleMouseMove);
273
+ document.addEventListener("mouseup", handleMouseUp);
274
+ document.addEventListener("mouseleave", handleMouseUp);
275
+ }
276
+ return () => {
277
+ element.removeEventListener("mousedown", handleMouseDown);
278
+ document.removeEventListener("mousemove", handleMouseMove);
279
+ document.removeEventListener("mouseup", handleMouseUp);
280
+ document.removeEventListener("mouseleave", handleMouseUp);
281
+ };
282
+ }, [isDragging, ref]);
283
+ const Comp = asChild ? Slot : "div";
284
+ return /* @__PURE__ */ jsx(
285
+ Comp,
286
+ {
287
+ ref,
288
+ className: cn(
289
+ "cursor-grab overflow-x-hidden overflow-y-auto",
290
+ isDragging && "cursor-grabbing",
291
+ className
292
+ ),
293
+ style: { userSelect: isDragging ? "none" : "auto", ...props.style },
294
+ ...props,
295
+ children
296
+ }
297
+ );
298
+ };
299
+
300
+ export { SyncDrag, SyncDragSlave, SyncDragSlaveX, SyncDragX, SyncDragY, SyncScroll, SyncScrollSlave };
@@ -1,12 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var chunkI7NPMMUG_cjs = require('./chunk-I7NPMMUG.cjs');
3
+ var chunkRBKCE3N7_cjs = require('./chunk-RBKCE3N7.cjs');
4
4
  var react = require('react');
5
5
  var jsxRuntime = require('react/jsx-runtime');
6
6
 
7
7
  var InchInput = react.forwardRef(function InchInput2({ value = 0, onChange, ...props }, ref) {
8
8
  return /* @__PURE__ */ jsxRuntime.jsx(
9
- chunkI7NPMMUG_cjs.InputNumbers,
9
+ chunkRBKCE3N7_cjs.InputNumbers,
10
10
  {
11
11
  ref,
12
12
  value: [value],
@@ -1,4 +1,4 @@
1
- import { EulerInput } from './chunk-OLCFDXGF.mjs';
1
+ import { EulerInput } from './chunk-OBYDDCUD.mjs';
2
2
  import { forwardRef } from 'react';
3
3
  import { jsx } from 'react/jsx-runtime';
4
4
 
@@ -23,7 +23,7 @@ var changeElementsHoverState = (inputs, range, changed) => {
23
23
  }
24
24
  });
25
25
  };
26
- var InputNumbers = forwardRef(function InputNumbers2({ size, side, value, onValuesChange, prefix, suffix, step = 0.1 }, ref) {
26
+ var InputNumbers = forwardRef(function InputNumbers2({ size, side, value, onValuesChange, prefix, suffix, step = 0.1, gridAutoFlow, columns, rows, layout = "column", columnMajor = false }, ref) {
27
27
  const inputs = useRef(/* @__PURE__ */ new Map());
28
28
  const selectRange = useRef([null, null]);
29
29
  const inputChange = useRef(false);
@@ -92,8 +92,9 @@ var InputNumbers = forwardRef(function InputNumbers2({ size, side, value, onValu
92
92
  if (first === null || last === null) {
93
93
  return v;
94
94
  } else if (i <= Math.max(first, last) && i >= Math.min(first, last)) {
95
+ const currentStep = Array.isArray(step) ? step[i] ?? 0.1 : step;
95
96
  return Number(
96
- ((v || 0) + Math.floor(accumulatedDelta.current) * step * multiplyStep).toPrecision(
97
+ ((v || 0) + Math.floor(accumulatedDelta.current) * currentStep * multiplyStep).toPrecision(
97
98
  6
98
99
  )
99
100
  );
@@ -170,7 +171,8 @@ var InputNumbers = forwardRef(function InputNumbers2({ size, side, value, onValu
170
171
  e.preventDefault();
171
172
  const direction = e.key === "ArrowUp" ? 1 : -1;
172
173
  const currentValue = value[index] || 0;
173
- const newValue = Number((currentValue + direction * step).toPrecision(6));
174
+ const currentStep = Array.isArray(step) ? step[index] ?? 0.1 : step;
175
+ const newValue = Number((currentValue + direction * currentStep).toPrecision(6));
174
176
  const updatedValues = value.map((v, i) => {
175
177
  if (i === index) {
176
178
  return newValue;
@@ -186,13 +188,33 @@ var InputNumbers = forwardRef(function InputNumbers2({ size, side, value, onValu
186
188
  if (value?.length === 0) {
187
189
  throw new Error("`value` cannot be an empty array");
188
190
  }
191
+ const actualGridAutoFlow = gridAutoFlow || layout || "row";
192
+ const useGrid = columns || rows || actualGridAutoFlow === "row" || layout === "row";
193
+ const gridStyles = {};
194
+ if (useGrid) {
195
+ gridStyles.display = "grid";
196
+ gridStyles.gridAutoFlow = actualGridAutoFlow;
197
+ if (columns) {
198
+ gridStyles.gridTemplateColumns = `repeat(${columns}, minmax(0, 1fr))`;
199
+ }
200
+ if (rows) {
201
+ gridStyles.gridTemplateRows = `repeat(${rows}, minmax(0, 1fr))`;
202
+ }
203
+ if (columnMajor && layout === "row") {
204
+ gridStyles.gridAutoFlow = "column";
205
+ if (!rows && columns) {
206
+ gridStyles.gridTemplateRows = `repeat(${Math.ceil(value.length / columns)}, minmax(0, 1fr))`;
207
+ }
208
+ }
209
+ }
189
210
  return /* @__PURE__ */ jsx(
190
211
  "div",
191
212
  {
192
213
  ref,
193
214
  onMouseDown: handleMouseDown,
194
215
  className: cn([
195
- "gap-xs flex touch-none flex-col select-none",
216
+ "gap-xs touch-none select-none",
217
+ !useGrid && "flex flex-col",
196
218
  cursorState === "default" && "cursor-crosshair",
197
219
  cursorState === "dragging-y" && "cursor-ns-resize",
198
220
  cursorState === "dragging-x" && "cursor-col-resize",
@@ -202,6 +224,7 @@ var InputNumbers = forwardRef(function InputNumbers2({ size, side, value, onValu
202
224
  "data-[hover=x]:cursor-col-resize",
203
225
  "data-[hover=y]:cursor-ns-resize"
204
226
  ]),
227
+ style: useGrid ? gridStyles : void 0,
205
228
  children: value.map((item, index) => /* @__PURE__ */ jsxs(
206
229
  InputRoot,
207
230
  {
@@ -214,6 +237,7 @@ var InputNumbers = forwardRef(function InputNumbers2({ size, side, value, onValu
214
237
  size,
215
238
  side,
216
239
  type: "number",
240
+ step: Array.isArray(step) ? step[index] ?? 0.1 : step,
217
241
  value: item,
218
242
  onClick: () => {
219
243
  inputs.current.get(index.toString())?.focus();
@@ -1,13 +1,13 @@
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 KVectorInput = react.forwardRef(function KVectorInput2({ value, dimensions, ...props }, ref) {
8
8
  const k = dimensions || value.length;
9
9
  const labels = Array.from({ length: k }, (_, i) => `${i}`);
10
- return /* @__PURE__ */ jsxRuntime.jsx(chunkVFSVU357_cjs.VectorInput, { ref, value, labels, ...props });
10
+ return /* @__PURE__ */ jsxRuntime.jsx(chunkKZP7AY75_cjs.VectorInput, { ref, value, labels, ...props });
11
11
  });
12
12
 
13
13
  exports.KVectorInput = KVectorInput;