@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.
- package/dist/SyncScroll/SyncScroll.cjs +3 -3
- package/dist/SyncScroll/SyncScroll.mjs +3 -3
- package/dist/SyncScroll/index.cjs +3 -3
- package/dist/SyncScroll/index.mjs +3 -3
- package/dist/{chunk-DKDXGIOU.cjs → chunk-2LIAVSDV.cjs} +2 -2
- package/dist/{chunk-VI67LD6E.mjs → chunk-3HUKXFD4.mjs} +1 -1
- package/dist/chunk-43ZAEQYD.cjs +564 -0
- package/dist/chunk-5PDZWPUI.cjs +208 -0
- package/dist/chunk-6FY4AL6N.mjs +15 -0
- package/dist/{chunk-XIAVCKC3.mjs → chunk-7YRIF5K4.mjs} +1 -1
- package/dist/chunk-AFJ6DMZW.cjs +54 -0
- package/dist/{chunk-UKSD5GPI.cjs → chunk-AI2OGSMP.cjs} +2 -2
- package/dist/{chunk-URUEOOWI.cjs → chunk-AUCWPDXH.cjs} +2 -2
- package/dist/chunk-AUENXQXS.mjs +206 -0
- package/dist/{chunk-I2UIJ23T.mjs → chunk-AXTZ2RY6.mjs} +1 -1
- package/dist/chunk-C4VVMAPU.cjs +285 -0
- package/dist/chunk-CGNTK3WP.cjs +494 -0
- package/dist/{chunk-IWS7VNJQ.mjs → chunk-D3U5PLHK.mjs} +1 -1
- package/dist/chunk-DG3DDLXZ.mjs +599 -0
- package/dist/chunk-E4AGCYEF.mjs +545 -0
- package/dist/chunk-EAQAIANE.mjs +20 -0
- package/dist/{chunk-BGYHKHMQ.mjs → chunk-FBPAIVBH.mjs} +1 -1
- package/dist/{chunk-TKV4YQPL.cjs → chunk-FR6JWEU4.cjs} +1 -1
- package/dist/chunk-G5JZGNKY.cjs +308 -0
- package/dist/{chunk-YSUCUNBJ.mjs → chunk-GMGAUN57.mjs} +1 -1
- package/dist/{chunk-LY5RLGFY.cjs → chunk-GPSSQ7XQ.cjs} +2 -2
- package/dist/chunk-H5LP5KMB.cjs +624 -0
- package/dist/{chunk-ALQIRJAV.mjs → chunk-HOF7YOYS.mjs} +1 -1
- package/dist/{chunk-NQVD3ZW4.cjs → chunk-I22QSUB7.cjs} +1 -1
- package/dist/{chunk-ZQNV64BB.cjs → chunk-IBSCKXGA.cjs} +2 -2
- package/dist/{chunk-6K3HTR4W.cjs → chunk-IPBOH3RD.cjs} +2 -2
- package/dist/chunk-ISLTDEPI.cjs +99 -0
- package/dist/{chunk-X3RZDN2C.cjs → chunk-IZNQXFZ6.cjs} +2 -2
- package/dist/{chunk-JWS7MZGX.mjs → chunk-J2RFARFN.mjs} +1 -1
- package/dist/{chunk-6NUAFTM5.cjs → chunk-JO5TYMHM.cjs} +2 -2
- package/dist/{chunk-7WS53WEO.cjs → chunk-JSUB7URV.cjs} +2 -2
- package/dist/chunk-KVRUJWH2.mjs +283 -0
- package/dist/chunk-KZP7AY75.cjs +22 -0
- package/dist/{chunk-4V5DMSTZ.mjs → chunk-LQWJ34PD.mjs} +1 -1
- package/dist/{chunk-7CP6EUTM.mjs → chunk-M7CWV3WR.mjs} +1 -1
- package/dist/{chunk-OLCFDXGF.mjs → chunk-OBYDDCUD.mjs} +1 -1
- package/dist/chunk-PDOFOJ4P.mjs +300 -0
- package/dist/{chunk-IV3CZ27Q.cjs → chunk-PHRBUOTG.cjs} +2 -2
- package/dist/{chunk-ZE7BMGJN.mjs → chunk-PXVFCVUE.mjs} +1 -1
- package/dist/{chunk-QN5Q5OCZ.mjs → chunk-QAERXYKR.mjs} +28 -4
- package/dist/{chunk-HMGDXKPW.cjs → chunk-QGGJXDBC.cjs} +2 -2
- package/dist/chunk-QKQFSQ6A.mjs +489 -0
- package/dist/{chunk-I7NPMMUG.cjs → chunk-RBKCE3N7.cjs} +28 -4
- package/dist/{chunk-VWPT77VT.mjs → chunk-SGYNKN5X.mjs} +1 -1
- package/dist/chunk-SH4FDQTB.mjs +94 -0
- package/dist/{chunk-U2CXSVXD.cjs → chunk-SJPXQV2G.cjs} +2 -2
- package/dist/{chunk-SCQQZUQV.mjs → chunk-SQBCVWEA.mjs} +1 -1
- package/dist/{chunk-72Q6YVID.cjs → chunk-TG4B5Y3I.cjs} +2 -2
- package/dist/chunk-VE3XLQLO.cjs +21 -0
- package/dist/chunk-WHRN67N6.mjs +51 -0
- package/dist/{chunk-4JAPZTNY.mjs → chunk-XTE66VZ3.mjs} +1 -1
- package/dist/dial/DialPanel.cjs +121 -0
- package/dist/dial/DialPanel.d.cts +9 -0
- package/dist/dial/DialPanel.d.ts +9 -0
- package/dist/dial/DialPanel.mjs +112 -0
- package/dist/dial/DialProvider.cjs +14 -0
- package/dist/dial/DialProvider.d.cts +48 -0
- package/dist/dial/DialProvider.d.ts +48 -0
- package/dist/dial/DialProvider.mjs +1 -0
- package/dist/dial/index.cjs +193 -0
- package/dist/dial/index.d.cts +5 -0
- package/dist/dial/index.d.ts +5 -0
- package/dist/dial/index.mjs +112 -0
- package/dist/dial/wrapped-inputs/ControlledInputs.cjs +137 -0
- package/dist/dial/wrapped-inputs/ControlledInputs.d.cts +21 -0
- package/dist/dial/wrapped-inputs/ControlledInputs.d.ts +21 -0
- package/dist/dial/wrapped-inputs/ControlledInputs.mjs +112 -0
- package/dist/dial/wrapped-inputs/DialVectorNInput.cjs +121 -0
- package/dist/dial/wrapped-inputs/DialVectorNInput.d.cts +15 -0
- package/dist/dial/wrapped-inputs/DialVectorNInput.d.ts +15 -0
- package/dist/dial/wrapped-inputs/DialVectorNInput.mjs +112 -0
- package/dist/dial/wrapped-inputs/DialWrappedInputs.cjs +161 -0
- package/dist/dial/wrapped-inputs/DialWrappedInputs.d.cts +24 -0
- package/dist/dial/wrapped-inputs/DialWrappedInputs.d.ts +24 -0
- package/dist/dial/wrapped-inputs/DialWrappedInputs.mjs +112 -0
- package/dist/dial/wrapped-inputs/index.cjs +185 -0
- package/dist/dial/wrapped-inputs/index.d.cts +4 -0
- package/dist/dial/wrapped-inputs/index.d.ts +4 -0
- package/dist/dial/wrapped-inputs/index.mjs +112 -0
- package/dist/highlight-cursor/enhanced-components.cjs +10 -10
- package/dist/highlight-cursor/enhanced-components.mjs +5 -5
- package/dist/highlight-cursor/index.cjs +10 -10
- package/dist/highlight-cursor/index.mjs +5 -5
- package/dist/hooks/index.cjs +12 -12
- package/dist/hooks/index.mjs +3 -3
- package/dist/hooks/useQueryParams.cjs +3 -3
- package/dist/hooks/useQueryParams.mjs +2 -2
- package/dist/index.cjs +475 -397
- package/dist/index.d.cts +4 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.mjs +55 -53
- package/dist/ui/UIKitBadge.cjs +8 -8
- package/dist/ui/UIKitBadge.mjs +4 -4
- package/dist/ui/avatar.cjs +3 -3
- package/dist/ui/avatar.mjs +3 -3
- package/dist/ui/badge.cjs +3 -3
- package/dist/ui/badge.d.cts +1 -1
- package/dist/ui/badge.d.ts +1 -1
- package/dist/ui/badge.mjs +3 -3
- package/dist/ui/button.cjs +3 -3
- package/dist/ui/button.mjs +3 -3
- package/dist/ui/card.cjs +3 -3
- package/dist/ui/card.mjs +3 -3
- package/dist/ui/checkbox.cjs +3 -3
- package/dist/ui/checkbox.mjs +3 -3
- package/dist/ui/collapsible.cjs +3 -3
- package/dist/ui/collapsible.mjs +3 -3
- package/dist/ui/drawer.cjs +3 -3
- package/dist/ui/drawer.mjs +3 -3
- package/dist/ui/dropdown.cjs +3 -3
- package/dist/ui/dropdown.mjs +3 -3
- package/dist/ui/index.cjs +390 -390
- package/dist/ui/index.mjs +52 -52
- package/dist/ui/inputs/color-input.cjs +3 -3
- package/dist/ui/inputs/color-input.mjs +3 -3
- package/dist/ui/inputs/index.cjs +39 -39
- package/dist/ui/inputs/index.mjs +18 -18
- package/dist/ui/inputs/input-numbers.cjs +5 -5
- package/dist/ui/inputs/input-numbers.d.cts +7 -2
- package/dist/ui/inputs/input-numbers.d.ts +7 -2
- package/dist/ui/inputs/input-numbers.mjs +4 -4
- package/dist/ui/inputs/input.cjs +3 -3
- package/dist/ui/inputs/input.d.cts +1 -1
- package/dist/ui/inputs/input.d.ts +1 -1
- package/dist/ui/inputs/input.mjs +3 -3
- package/dist/ui/inputs/number-inputs/CmInput.cjs +6 -6
- package/dist/ui/inputs/number-inputs/CmInput.mjs +5 -5
- package/dist/ui/inputs/number-inputs/DegInput.cjs +6 -6
- package/dist/ui/inputs/number-inputs/DegInput.mjs +5 -5
- package/dist/ui/inputs/number-inputs/EulerDegInput.cjs +8 -8
- package/dist/ui/inputs/number-inputs/EulerDegInput.mjs +7 -7
- package/dist/ui/inputs/number-inputs/EulerInput.cjs +7 -7
- package/dist/ui/inputs/number-inputs/EulerInput.mjs +6 -6
- package/dist/ui/inputs/number-inputs/EulerRadInput.cjs +8 -8
- package/dist/ui/inputs/number-inputs/EulerRadInput.mjs +7 -7
- package/dist/ui/inputs/number-inputs/InchInput.cjs +6 -6
- package/dist/ui/inputs/number-inputs/InchInput.mjs +5 -5
- package/dist/ui/inputs/number-inputs/IntInput.cjs +6 -6
- package/dist/ui/inputs/number-inputs/IntInput.mjs +5 -5
- package/dist/ui/inputs/number-inputs/KVectorInput.cjs +7 -7
- package/dist/ui/inputs/number-inputs/KVectorInput.mjs +6 -6
- package/dist/ui/inputs/number-inputs/QuaternionInput.cjs +7 -7
- package/dist/ui/inputs/number-inputs/QuaternionInput.mjs +6 -6
- package/dist/ui/inputs/number-inputs/RadInput.cjs +6 -6
- package/dist/ui/inputs/number-inputs/RadInput.mjs +5 -5
- package/dist/ui/inputs/number-inputs/TimeInput.cjs +6 -6
- package/dist/ui/inputs/number-inputs/TimeInput.mjs +5 -5
- package/dist/ui/inputs/number-inputs/Vec3Input.cjs +7 -7
- package/dist/ui/inputs/number-inputs/Vec3Input.mjs +6 -6
- package/dist/ui/inputs/number-inputs/VectorInput.cjs +6 -6
- package/dist/ui/inputs/number-inputs/VectorInput.d.cts +6 -0
- package/dist/ui/inputs/number-inputs/VectorInput.d.ts +6 -0
- package/dist/ui/inputs/number-inputs/VectorInput.mjs +5 -5
- package/dist/ui/inputs/number-inputs/index.cjs +36 -36
- package/dist/ui/inputs/number-inputs/index.mjs +17 -17
- package/dist/ui/inputs/presets-input.cjs +6 -6
- package/dist/ui/inputs/presets-input.mjs +5 -5
- package/dist/ui/label.cjs +3 -3
- package/dist/ui/label.mjs +3 -3
- package/dist/ui/layout.cjs +5 -5
- package/dist/ui/layout.mjs +4 -4
- package/dist/ui/layouts/dock-layout/DockLayoutView.cjs +3 -3
- package/dist/ui/layouts/dock-layout/DockLayoutView.mjs +3 -3
- package/dist/ui/layouts/dock-layout/LayoutSlots.cjs +3 -3
- package/dist/ui/layouts/dock-layout/LayoutSlots.mjs +3 -3
- package/dist/ui/layouts/dock-layout/index.cjs +3 -3
- package/dist/ui/layouts/dock-layout/index.mjs +3 -3
- package/dist/ui/layouts/index.cjs +9 -9
- package/dist/ui/layouts/index.mjs +5 -5
- package/dist/ui/layouts/liquid-layout/LayoutSlots.cjs +3 -3
- package/dist/ui/layouts/liquid-layout/LayoutSlots.mjs +3 -3
- package/dist/ui/layouts/liquid-layout/LiquidLayoutView.cjs +3 -3
- package/dist/ui/layouts/liquid-layout/LiquidLayoutView.mjs +3 -3
- package/dist/ui/layouts/liquid-layout/index.cjs +3 -3
- package/dist/ui/layouts/liquid-layout/index.mjs +3 -3
- package/dist/ui/modal.cjs +3 -3
- package/dist/ui/modal.mjs +3 -3
- package/dist/ui/navigation.cjs +3 -3
- package/dist/ui/navigation.mjs +3 -3
- package/dist/ui/pagination.cjs +3 -3
- package/dist/ui/pagination.mjs +3 -3
- package/dist/ui/panel.cjs +3 -3
- package/dist/ui/panel.mjs +3 -3
- package/dist/ui/popover.cjs +3 -3
- package/dist/ui/popover.mjs +3 -3
- package/dist/ui/radio-group.cjs +3 -3
- package/dist/ui/radio-group.mjs +3 -3
- package/dist/ui/resizable.cjs +3 -3
- package/dist/ui/resizable.mjs +3 -3
- package/dist/ui/select.cjs +3 -3
- package/dist/ui/select.d.cts +1 -1
- package/dist/ui/select.d.ts +1 -1
- package/dist/ui/select.mjs +3 -3
- package/dist/ui/separator.cjs +3 -3
- package/dist/ui/separator.mjs +3 -3
- package/dist/ui/sheet.cjs +3 -3
- package/dist/ui/sheet.mjs +3 -3
- package/dist/ui/sidebar.cjs +29 -29
- package/dist/ui/sidebar.mjs +5 -5
- package/dist/ui/simple-tree-view.cjs +3 -3
- package/dist/ui/simple-tree-view.mjs +3 -3
- package/dist/ui/skeleton.cjs +3 -3
- package/dist/ui/skeleton.mjs +3 -3
- package/dist/ui/slider.cjs +3 -3
- package/dist/ui/slider.mjs +3 -3
- package/dist/ui/switch.cjs +3 -3
- package/dist/ui/switch.mjs +3 -3
- package/dist/ui/table.cjs +3 -3
- package/dist/ui/table.mjs +3 -3
- package/dist/ui/tabs.cjs +3 -3
- package/dist/ui/tabs.mjs +3 -3
- package/dist/ui/textarea.cjs +3 -3
- package/dist/ui/textarea.d.cts +1 -1
- package/dist/ui/textarea.d.ts +1 -1
- package/dist/ui/textarea.mjs +3 -3
- package/dist/ui/theme/ThemeToggles.cjs +3 -3
- package/dist/ui/theme/ThemeToggles.mjs +3 -3
- package/dist/ui/theme/index.cjs +3 -3
- package/dist/ui/theme/index.mjs +3 -3
- package/dist/ui/toggle-buttons.cjs +3 -3
- package/dist/ui/toggle-buttons.mjs +3 -3
- package/dist/ui/toggle-group.cjs +3 -3
- package/dist/ui/toggle-group.mjs +3 -3
- package/dist/ui/toggle.cjs +3 -3
- package/dist/ui/toggle.mjs +3 -3
- package/dist/ui/toolbar.cjs +3 -3
- package/dist/ui/toolbar.mjs +3 -3
- package/dist/ui/tooltip.cjs +3 -3
- package/dist/ui/tooltip.mjs +3 -3
- package/dist/ui/tree-view/TreeSearchBar.cjs +3 -3
- package/dist/ui/tree-view/TreeSearchBar.mjs +3 -3
- package/dist/ui/tree-view/TreeView.cjs +3 -3
- package/dist/ui/tree-view/TreeView.mjs +3 -3
- package/dist/ui/tree-view/index.cjs +4 -4
- package/dist/ui/tree-view/index.mjs +4 -4
- package/dist/ui/tree-view-legacy.cjs +3 -3
- package/dist/ui/tree-view-legacy.mjs +3 -3
- package/dist/ui/waterfall/CursorOverlay.cjs +3 -3
- package/dist/ui/waterfall/CursorOverlay.mjs +3 -3
- package/dist/ui/waterfall/TimelineEvent.cjs +3 -3
- package/dist/ui/waterfall/TimelineEvent.mjs +3 -3
- package/dist/ui/waterfall/TimelineProcessBar.cjs +3 -3
- package/dist/ui/waterfall/TimelineProcessBar.mjs +3 -3
- package/dist/ui/waterfall/Wedges.cjs +3 -3
- package/dist/ui/waterfall/Wedges.mjs +3 -3
- package/dist/ui/waterfall/index.cjs +11 -11
- package/dist/ui/waterfall/index.mjs +10 -10
- package/package.json +1 -1
- package/dist/chunk-VFSVU357.cjs +0 -11
- package/dist/chunk-XOZ6S53T.mjs +0 -9
- package/dist/{chunk-6U6BHFK4.cjs → chunk-245M2MZD.cjs} +4 -4
- package/dist/{chunk-A2PCEL5S.mjs → chunk-4AOAH77D.mjs} +2 -2
- package/dist/{chunk-K6FXUV3A.mjs → chunk-4EGKBNF2.mjs} +1 -1
- package/dist/{chunk-7QRSUUA2.cjs → chunk-74ETKEMH.cjs} +2 -2
- package/dist/{chunk-N22BVDJM.mjs → chunk-K4DBU34E.mjs} +4 -4
- package/dist/{chunk-Q4XH2Z5M.cjs → chunk-LYZJNEOR.cjs} +1 -1
- package/dist/{chunk-U3LN5NB6.mjs → chunk-OEIF3JCH.mjs} +1 -1
- 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
|
|
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
|
-
|
|
9
|
+
chunkRBKCE3N7_cjs.InputNumbers,
|
|
10
10
|
{
|
|
11
11
|
ref,
|
|
12
12
|
value: [value],
|
|
@@ -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) *
|
|
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
|
|
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
|
|
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
|
|
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(
|
|
10
|
+
return /* @__PURE__ */ jsxRuntime.jsx(chunkKZP7AY75_cjs.VectorInput, { ref, value, labels, ...props });
|
|
11
11
|
});
|
|
12
12
|
|
|
13
13
|
exports.KVectorInput = KVectorInput;
|