@zentauri-ui/zentauri-components 1.0.0 → 1.1.1

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.
@@ -0,0 +1,521 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var chunkWZ2GOU2J_js = require('../chunk-WZ2GOU2J.js');
5
+ var react = require('react');
6
+ var classVarianceAuthority = require('class-variance-authority');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+
9
+ var sliderRootVariants = classVarianceAuthority.cva("w-full select-none touch-none", {
10
+ variants: {
11
+ size: {
12
+ sm: "py-2",
13
+ md: "py-2.5",
14
+ lg: "py-3"
15
+ }
16
+ },
17
+ defaultVariants: {
18
+ size: "md"
19
+ }
20
+ });
21
+ var sliderTrackVariants = classVarianceAuthority.cva(
22
+ "relative h-2 w-full shrink-0 overflow-hidden rounded-full bg-white/10",
23
+ {
24
+ variants: {
25
+ size: {
26
+ sm: "h-1.5",
27
+ md: "h-2",
28
+ lg: "h-2.5"
29
+ }
30
+ },
31
+ defaultVariants: {
32
+ size: "md"
33
+ }
34
+ }
35
+ );
36
+ var sliderRangeVariants = classVarianceAuthority.cva(
37
+ "absolute h-full rounded-full bg-gradient-to-r from-violet-500 to-indigo-400",
38
+ {
39
+ variants: {
40
+ appearance: {
41
+ default: "from-violet-500 to-indigo-400",
42
+ sky: "from-sky-500 to-indigo-400",
43
+ rose: "from-rose-500 to-indigo-400",
44
+ purple: "from-purple-500 to-indigo-400",
45
+ pink: "from-pink-500 to-indigo-400",
46
+ orange: "from-orange-500 to-indigo-400",
47
+ yellow: "from-yellow-500 to-indigo-400",
48
+ teal: "from-teal-500 to-indigo-400",
49
+ indigo: "from-indigo-500 to-indigo-400",
50
+ emerald: "from-emerald-500 to-teal-400",
51
+ amber: "from-amber-500 to-orange-400",
52
+ gray: "from-gray-500 to-indigo-400",
53
+ violet: "from-violet-500 to-indigo-400",
54
+ "gradient-blue": "from-blue-500 to-indigo-400",
55
+ "gradient-green": "from-green-500 to-indigo-400",
56
+ "gradient-red": "from-red-500 to-indigo-400",
57
+ "gradient-yellow": "from-yellow-500 to-indigo-400",
58
+ "gradient-purple": "from-purple-500 to-indigo-400",
59
+ "gradient-teal": "from-teal-500 to-indigo-400",
60
+ "gradient-indigo": "from-indigo-500 to-indigo-400",
61
+ "gradient-pink": "from-pink-500 to-indigo-400",
62
+ "gradient-orange": "from-orange-500 to-indigo-400"
63
+ }
64
+ },
65
+ defaultVariants: {
66
+ appearance: "default"
67
+ }
68
+ }
69
+ );
70
+ var sliderThumbVariants = classVarianceAuthority.cva(
71
+ "block size-4 rounded-full border border-white/20 bg-white shadow-md ring-offset-2 ring-offset-slate-950 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/40 disabled:pointer-events-none disabled:opacity-40",
72
+ {
73
+ variants: {
74
+ size: {
75
+ sm: "size-3.5",
76
+ md: "size-4",
77
+ lg: "size-5"
78
+ }
79
+ },
80
+ defaultVariants: {
81
+ size: "md"
82
+ }
83
+ }
84
+ );
85
+ function clamp(value, min, max) {
86
+ return Math.min(max, Math.max(min, value));
87
+ }
88
+ function snapToStep(value, min, step) {
89
+ const steps = Math.round((value - min) / step);
90
+ return min + steps * step;
91
+ }
92
+ var SliderContext = react.createContext(null);
93
+ function useSliderContext(component) {
94
+ const ctx = react.useContext(SliderContext);
95
+ if (!ctx) {
96
+ throw new Error(`${component} must be used within <Slider>`);
97
+ }
98
+ return ctx;
99
+ }
100
+ function computeValueFromPointer(clientX, track, min, max, step) {
101
+ const rect = track.getBoundingClientRect();
102
+ const ratio = rect.width === 0 ? 0 : (clientX - rect.left) / rect.width;
103
+ const raw = min + ratio * (max - min);
104
+ return snapToStep(clamp(raw, min, max), min, step);
105
+ }
106
+ function Slider({
107
+ className,
108
+ size = "md",
109
+ min = 0,
110
+ max = 100,
111
+ step = 1,
112
+ value: valueProp,
113
+ defaultValue,
114
+ onValueChange,
115
+ disabled = false,
116
+ appearance = "default",
117
+ "aria-label": ariaLabel,
118
+ "aria-labelledby": ariaLabelledBy,
119
+ children,
120
+ ref,
121
+ ...rest
122
+ }) {
123
+ const trackRef = react.useRef(null);
124
+ const isControlled = valueProp !== void 0;
125
+ const [uncontrolled, setUncontrolled] = react.useState(
126
+ defaultValue ?? min
127
+ );
128
+ const value = isControlled ? valueProp : uncontrolled;
129
+ const setValue = react.useCallback(
130
+ (next) => {
131
+ const clamped = clamp(snapToStep(next, min, step), min, max);
132
+ if (!isControlled) {
133
+ setUncontrolled(clamped);
134
+ }
135
+ onValueChange?.(clamped);
136
+ },
137
+ [isControlled, max, min, onValueChange, step]
138
+ );
139
+ const ctx = react.useMemo(
140
+ () => ({
141
+ min,
142
+ max,
143
+ step,
144
+ value: clamp(snapToStep(value, min, step), min, max),
145
+ setValue,
146
+ disabled,
147
+ size: size ?? "md",
148
+ appearance: appearance ?? "default",
149
+ trackRef
150
+ }),
151
+ [appearance, disabled, max, min, setValue, size, step, value]
152
+ );
153
+ return /* @__PURE__ */ jsxRuntime.jsx(SliderContext.Provider, { value: ctx, children: /* @__PURE__ */ jsxRuntime.jsx(
154
+ "div",
155
+ {
156
+ ref,
157
+ "data-slot": "slider",
158
+ role: "group",
159
+ "aria-label": ariaLabel,
160
+ "aria-labelledby": ariaLabelledBy,
161
+ className: chunkWZ2GOU2J_js.cn(sliderRootVariants({ size }), className),
162
+ ...rest,
163
+ children
164
+ }
165
+ ) });
166
+ }
167
+ Slider.displayName = "Slider";
168
+ function SliderTrack({
169
+ className,
170
+ ref: refProp,
171
+ ...rest
172
+ }) {
173
+ const { size, trackRef } = useSliderContext("SliderTrack");
174
+ return /* @__PURE__ */ jsxRuntime.jsx(
175
+ "div",
176
+ {
177
+ ref: (node) => {
178
+ trackRef.current = node;
179
+ if (typeof refProp === "function") {
180
+ refProp(node);
181
+ } else if (refProp) {
182
+ refProp.current = node;
183
+ }
184
+ },
185
+ "data-slot": "slider-track",
186
+ className: chunkWZ2GOU2J_js.cn(sliderTrackVariants({ size }), className),
187
+ ...rest
188
+ }
189
+ );
190
+ }
191
+ SliderTrack.displayName = "SliderTrack";
192
+ function SliderRange({
193
+ className,
194
+ ref,
195
+ ...rest
196
+ }) {
197
+ const { min, max, value, appearance } = useSliderContext("SliderRange");
198
+ const pct = max === min ? 0 : (value - min) / (max - min) * 100;
199
+ return /* @__PURE__ */ jsxRuntime.jsx(
200
+ "div",
201
+ {
202
+ ref,
203
+ "data-slot": "slider-range",
204
+ className: chunkWZ2GOU2J_js.cn(sliderRangeVariants({ appearance }), className),
205
+ style: { width: `${pct}%` },
206
+ ...rest
207
+ }
208
+ );
209
+ }
210
+ SliderRange.displayName = "SliderRange";
211
+ function SliderThumb({
212
+ className,
213
+ ref: refProp,
214
+ ...rest
215
+ }) {
216
+ const { min, max, value, step, setValue, disabled, size, trackRef } = useSliderContext("SliderThumb");
217
+ const pct = max === min ? 0 : (value - min) / (max - min) * 100;
218
+ const onPointerDown = react.useCallback(
219
+ (event) => {
220
+ if (disabled) {
221
+ return;
222
+ }
223
+ event.preventDefault();
224
+ const track = trackRef.current;
225
+ if (!track) {
226
+ return;
227
+ }
228
+ event.currentTarget.setPointerCapture(event.pointerId);
229
+ const move = (e) => {
230
+ setValue(computeValueFromPointer(e.clientX, track, min, max, step));
231
+ };
232
+ const up = () => {
233
+ window.removeEventListener("pointermove", move);
234
+ window.removeEventListener("pointerup", up);
235
+ };
236
+ window.addEventListener("pointermove", move);
237
+ window.addEventListener("pointerup", up);
238
+ },
239
+ [disabled, max, min, setValue, step, trackRef]
240
+ );
241
+ const onKeyDown = react.useCallback(
242
+ (event) => {
243
+ if (disabled) {
244
+ return;
245
+ }
246
+ const big = (max - min) / 10;
247
+ let delta = 0;
248
+ if (event.key === "ArrowRight" || event.key === "ArrowUp") {
249
+ delta = step;
250
+ } else if (event.key === "ArrowLeft" || event.key === "ArrowDown") {
251
+ delta = -step;
252
+ } else if (event.key === "PageUp") {
253
+ delta = big;
254
+ } else if (event.key === "PageDown") {
255
+ delta = -big;
256
+ } else if (event.key === "Home") {
257
+ event.preventDefault();
258
+ setValue(min);
259
+ return;
260
+ } else if (event.key === "End") {
261
+ event.preventDefault();
262
+ setValue(max);
263
+ return;
264
+ } else {
265
+ return;
266
+ }
267
+ event.preventDefault();
268
+ setValue(value + delta);
269
+ },
270
+ [disabled, max, min, setValue, step, value]
271
+ );
272
+ return /* @__PURE__ */ jsxRuntime.jsx(
273
+ "div",
274
+ {
275
+ ref: (node) => {
276
+ if (typeof refProp === "function") {
277
+ refProp(node);
278
+ } else if (refProp) {
279
+ refProp.current = node;
280
+ }
281
+ },
282
+ role: "slider",
283
+ tabIndex: disabled ? -1 : 0,
284
+ "data-slot": "slider-thumb",
285
+ "aria-valuemin": min,
286
+ "aria-valuemax": max,
287
+ "aria-valuenow": value,
288
+ "aria-disabled": disabled || void 0,
289
+ className: chunkWZ2GOU2J_js.cn(
290
+ "absolute top-1/2 z-10 -translate-x-1/2 -translate-y-1/2",
291
+ sliderThumbVariants({ size }),
292
+ className
293
+ ),
294
+ style: { left: `${pct}%` },
295
+ onPointerDown,
296
+ onKeyDown,
297
+ ...rest
298
+ }
299
+ );
300
+ }
301
+ SliderThumb.displayName = "SliderThumb";
302
+ function RangeSlider({
303
+ className,
304
+ size = "md",
305
+ min = 0,
306
+ max = 100,
307
+ step = 1,
308
+ value: valueProp,
309
+ defaultValue,
310
+ onValueChange,
311
+ disabled = false,
312
+ appearance = "default",
313
+ "aria-label": ariaLabel,
314
+ "aria-labelledby": ariaLabelledBy,
315
+ ref,
316
+ ...rest
317
+ }) {
318
+ const trackRef = react.useRef(null);
319
+ const isControlled = valueProp !== void 0;
320
+ const [uncontrolled, setUncontrolled] = react.useState(() => {
321
+ const seed = defaultValue ?? [min, max];
322
+ const lo2 = clamp(snapToStep(seed[0], min, step), min, max);
323
+ const hi2 = clamp(snapToStep(seed[1], min, step), min, max);
324
+ return lo2 <= hi2 ? [lo2, hi2] : [hi2, lo2];
325
+ });
326
+ const value = isControlled ? valueProp : uncontrolled;
327
+ const [lo, hi] = value[0] <= value[1] ? [value[0], value[1]] : [value[1], value[0]];
328
+ const setPair = react.useCallback(
329
+ (next) => {
330
+ const a = clamp(snapToStep(next[0], min, step), min, max);
331
+ const b = clamp(snapToStep(next[1], min, step), min, max);
332
+ const ordered = a <= b ? [a, b] : [b, a];
333
+ if (!isControlled) {
334
+ setUncontrolled(ordered);
335
+ }
336
+ onValueChange?.(ordered);
337
+ },
338
+ [isControlled, max, min, onValueChange, step]
339
+ );
340
+ const moveThumb = react.useCallback(
341
+ (index, clientX) => {
342
+ const track = trackRef.current;
343
+ if (!track) {
344
+ return;
345
+ }
346
+ const raw = computeValueFromPointer(clientX, track, min, max, step);
347
+ if (index === 0) {
348
+ setPair([raw, hi]);
349
+ } else {
350
+ setPair([lo, raw]);
351
+ }
352
+ },
353
+ [hi, lo, max, min, setPair, step]
354
+ );
355
+ const loPct = max === min ? 0 : (lo - min) / (max - min) * 100;
356
+ const hiPct = max === min ? 0 : (hi - min) / (max - min) * 100;
357
+ const resolvedSize = size ?? "md";
358
+ return /* @__PURE__ */ jsxRuntime.jsx(
359
+ "div",
360
+ {
361
+ ref,
362
+ "data-slot": "range-slider",
363
+ role: "group",
364
+ "aria-label": ariaLabel,
365
+ "aria-labelledby": ariaLabelledBy,
366
+ "aria-valuetext": `${lo} \u2013 ${hi}`,
367
+ className: chunkWZ2GOU2J_js.cn(sliderRootVariants({ size: resolvedSize }), className),
368
+ ...rest,
369
+ children: /* @__PURE__ */ jsxRuntime.jsxs(
370
+ "div",
371
+ {
372
+ ref: trackRef,
373
+ "data-slot": "slider-track",
374
+ className: chunkWZ2GOU2J_js.cn(sliderTrackVariants({ size: resolvedSize }), "relative"),
375
+ children: [
376
+ /* @__PURE__ */ jsxRuntime.jsx(
377
+ "div",
378
+ {
379
+ "data-slot": "slider-range",
380
+ className: chunkWZ2GOU2J_js.cn(sliderRangeVariants({ appearance }), "absolute"),
381
+ style: {
382
+ left: `${loPct}%`,
383
+ width: `${Math.max(hiPct - loPct, 0)}%`
384
+ }
385
+ }
386
+ ),
387
+ /* @__PURE__ */ jsxRuntime.jsx(
388
+ RangeThumb,
389
+ {
390
+ disabled,
391
+ size: resolvedSize,
392
+ value: lo,
393
+ min,
394
+ max,
395
+ step,
396
+ positionPct: loPct,
397
+ trackRef,
398
+ onMoveClientX: (x) => moveThumb(0, x),
399
+ onNudge: (delta) => setPair([lo + delta, hi])
400
+ }
401
+ ),
402
+ /* @__PURE__ */ jsxRuntime.jsx(
403
+ RangeThumb,
404
+ {
405
+ disabled,
406
+ size: resolvedSize,
407
+ value: hi,
408
+ min,
409
+ max,
410
+ step,
411
+ positionPct: hiPct,
412
+ trackRef,
413
+ onMoveClientX: (x) => moveThumb(1, x),
414
+ onNudge: (delta) => setPair([lo, hi + delta])
415
+ }
416
+ )
417
+ ]
418
+ }
419
+ )
420
+ }
421
+ );
422
+ }
423
+ RangeSlider.displayName = "RangeSlider";
424
+ function RangeThumb({
425
+ disabled,
426
+ size,
427
+ value,
428
+ min,
429
+ max,
430
+ step,
431
+ positionPct,
432
+ trackRef,
433
+ onMoveClientX,
434
+ onNudge
435
+ }) {
436
+ const onPointerDown = react.useCallback(
437
+ (event) => {
438
+ if (disabled) {
439
+ return;
440
+ }
441
+ event.preventDefault();
442
+ const track = trackRef.current;
443
+ if (!track) {
444
+ return;
445
+ }
446
+ event.currentTarget.setPointerCapture(event.pointerId);
447
+ const move = (e) => {
448
+ onMoveClientX(e.clientX);
449
+ };
450
+ const up = () => {
451
+ window.removeEventListener("pointermove", move);
452
+ window.removeEventListener("pointerup", up);
453
+ };
454
+ window.addEventListener("pointermove", move);
455
+ window.addEventListener("pointerup", up);
456
+ },
457
+ [disabled, onMoveClientX, trackRef]
458
+ );
459
+ const onKeyDown = react.useCallback(
460
+ (event) => {
461
+ if (disabled) {
462
+ return;
463
+ }
464
+ const big = (max - min) / 10;
465
+ let delta = 0;
466
+ if (event.key === "ArrowRight" || event.key === "ArrowUp") {
467
+ delta = step;
468
+ } else if (event.key === "ArrowLeft" || event.key === "ArrowDown") {
469
+ delta = -step;
470
+ } else if (event.key === "PageUp") {
471
+ delta = big;
472
+ } else if (event.key === "PageDown") {
473
+ delta = -big;
474
+ } else if (event.key === "Home") {
475
+ event.preventDefault();
476
+ onNudge(min - value);
477
+ return;
478
+ } else if (event.key === "End") {
479
+ event.preventDefault();
480
+ onNudge(max - value);
481
+ return;
482
+ } else {
483
+ return;
484
+ }
485
+ event.preventDefault();
486
+ onNudge(delta);
487
+ },
488
+ [disabled, max, min, onNudge, step, value]
489
+ );
490
+ return /* @__PURE__ */ jsxRuntime.jsx(
491
+ "div",
492
+ {
493
+ role: "slider",
494
+ tabIndex: disabled ? -1 : 0,
495
+ "data-slot": "range-slider-thumb",
496
+ "aria-valuemin": min,
497
+ "aria-valuemax": max,
498
+ "aria-valuenow": value,
499
+ "aria-disabled": disabled || void 0,
500
+ className: chunkWZ2GOU2J_js.cn(
501
+ "absolute top-1/2 z-10 -translate-x-1/2 -translate-y-1/2",
502
+ sliderThumbVariants({ size })
503
+ ),
504
+ style: { left: `${positionPct}%` },
505
+ onPointerDown,
506
+ onKeyDown
507
+ }
508
+ );
509
+ }
510
+
511
+ exports.RangeSlider = RangeSlider;
512
+ exports.Slider = Slider;
513
+ exports.SliderRange = SliderRange;
514
+ exports.SliderThumb = SliderThumb;
515
+ exports.SliderTrack = SliderTrack;
516
+ exports.sliderRangeVariants = sliderRangeVariants;
517
+ exports.sliderRootVariants = sliderRootVariants;
518
+ exports.sliderThumbVariants = sliderThumbVariants;
519
+ exports.sliderTrackVariants = sliderTrackVariants;
520
+ //# sourceMappingURL=slider.js.map
521
+ //# sourceMappingURL=slider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/ui/slider/variants.ts","../../src/ui/slider/slider.tsx"],"names":["cva","createContext","useContext","useRef","useState","useCallback","useMemo","jsx","cn","lo","hi","jsxs"],"mappings":"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","file":"slider.js","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nexport const sliderRootVariants = cva(\"w-full select-none touch-none\", {\n variants: {\n size: {\n sm: \"py-2\",\n md: \"py-2.5\",\n lg: \"py-3\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\nexport const sliderTrackVariants = cva(\n \"relative h-2 w-full shrink-0 overflow-hidden rounded-full bg-white/10\",\n {\n variants: {\n size: {\n sm: \"h-1.5\",\n md: \"h-2\",\n lg: \"h-2.5\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n },\n);\n\nexport const sliderRangeVariants = cva(\n \"absolute h-full rounded-full bg-gradient-to-r from-violet-500 to-indigo-400\",\n {\n variants: {\n appearance: {\n default: \"from-violet-500 to-indigo-400\",\n sky: \"from-sky-500 to-indigo-400\",\n rose: \"from-rose-500 to-indigo-400\",\n purple: \"from-purple-500 to-indigo-400\",\n pink: \"from-pink-500 to-indigo-400\",\n orange: \"from-orange-500 to-indigo-400\",\n yellow: \"from-yellow-500 to-indigo-400\",\n teal: \"from-teal-500 to-indigo-400\",\n indigo: \"from-indigo-500 to-indigo-400\",\n emerald: \"from-emerald-500 to-teal-400\",\n amber: \"from-amber-500 to-orange-400\",\n gray: \"from-gray-500 to-indigo-400\",\n violet: \"from-violet-500 to-indigo-400\",\n \"gradient-blue\": \"from-blue-500 to-indigo-400\",\n \"gradient-green\": \"from-green-500 to-indigo-400\",\n \"gradient-red\": \"from-red-500 to-indigo-400\",\n \"gradient-yellow\": \"from-yellow-500 to-indigo-400\",\n \"gradient-purple\": \"from-purple-500 to-indigo-400\",\n \"gradient-teal\": \"from-teal-500 to-indigo-400\",\n \"gradient-indigo\": \"from-indigo-500 to-indigo-400\",\n \"gradient-pink\": \"from-pink-500 to-indigo-400\",\n \"gradient-orange\": \"from-orange-500 to-indigo-400\",\n },\n },\n defaultVariants: {\n appearance: \"default\",\n },\n },\n);\n\nexport const sliderThumbVariants = cva(\n \"block size-4 rounded-full border border-white/20 bg-white shadow-md ring-offset-2 ring-offset-slate-950 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/40 disabled:pointer-events-none disabled:opacity-40\",\n {\n variants: {\n size: {\n sm: \"size-3.5\",\n md: \"size-4\",\n lg: \"size-5\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n },\n);\n","\"use client\";\n\nimport {\n createContext,\n useCallback,\n useContext,\n useMemo,\n useRef,\n useState,\n type KeyboardEvent as ReactKeyboardEvent,\n type MutableRefObject,\n type PointerEvent as ReactPointerEvent,\n type Ref,\n type RefObject,\n} from \"react\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport type {\n RangeSliderProps,\n SliderProps,\n SliderRangeProps,\n SliderThumbProps,\n SliderTrackProps,\n} from \"./types\";\nimport {\n sliderRangeVariants,\n sliderRootVariants,\n sliderThumbVariants,\n sliderTrackVariants,\n} from \"./variants\";\n\nfunction clamp(value: number, min: number, max: number) {\n return Math.min(max, Math.max(min, value));\n}\n\nfunction snapToStep(value: number, min: number, step: number) {\n const steps = Math.round((value - min) / step);\n return min + steps * step;\n}\n\ntype SliderAppearance = NonNullable<\n Parameters<typeof sliderRangeVariants>[0]\n>[\"appearance\"];\n\ntype SliderCtx = {\n min: number;\n max: number;\n step: number;\n value: number;\n setValue: (next: number) => void;\n disabled: boolean;\n size: NonNullable<SliderProps[\"size\"]>;\n appearance: SliderAppearance;\n trackRef: RefObject<HTMLDivElement | null>;\n};\n\nconst SliderContext = createContext<SliderCtx | null>(null);\n\nfunction useSliderContext(component: string): SliderCtx {\n const ctx = useContext(SliderContext);\n if (!ctx) {\n throw new Error(`${component} must be used within <Slider>`);\n }\n return ctx;\n}\n\nfunction computeValueFromPointer(\n clientX: number,\n track: HTMLDivElement,\n min: number,\n max: number,\n step: number,\n) {\n const rect = track.getBoundingClientRect();\n const ratio = rect.width === 0 ? 0 : (clientX - rect.left) / rect.width;\n const raw = min + ratio * (max - min);\n return snapToStep(clamp(raw, min, max), min, step);\n}\n\nexport function Slider({\n className,\n size = \"md\",\n min = 0,\n max = 100,\n step = 1,\n value: valueProp,\n defaultValue,\n onValueChange,\n disabled = false,\n appearance = \"default\",\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n children,\n ref,\n ...rest\n}: SliderProps & { ref?: Ref<HTMLDivElement> }) {\n const trackRef = useRef<HTMLDivElement | null>(null);\n const isControlled = valueProp !== undefined;\n const [uncontrolled, setUncontrolled] = useState(\n defaultValue ?? min,\n );\n const value = isControlled ? (valueProp as number) : uncontrolled;\n\n const setValue = useCallback(\n (next: number) => {\n const clamped = clamp(snapToStep(next, min, step), min, max);\n if (!isControlled) {\n setUncontrolled(clamped);\n }\n onValueChange?.(clamped);\n },\n [isControlled, max, min, onValueChange, step],\n );\n\n const ctx = useMemo(\n () => ({\n min,\n max,\n step,\n value: clamp(snapToStep(value, min, step), min, max),\n setValue,\n disabled,\n size: size ?? \"md\",\n appearance: appearance ?? \"default\",\n trackRef,\n }),\n [appearance, disabled, max, min, setValue, size, step, value],\n );\n\n return (\n <SliderContext.Provider value={ctx}>\n <div\n ref={ref}\n data-slot=\"slider\"\n role=\"group\"\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n className={cn(sliderRootVariants({ size }), className)}\n {...rest}\n >\n {children}\n </div>\n </SliderContext.Provider>\n );\n}\n\nSlider.displayName = \"Slider\";\n\nexport function SliderTrack({\n className,\n ref: refProp,\n ...rest\n}: SliderTrackProps & { ref?: Ref<HTMLDivElement> }) {\n const { size, trackRef } = useSliderContext(\"SliderTrack\");\n\n return (\n <div\n ref={(node) => {\n trackRef.current = node;\n if (typeof refProp === \"function\") {\n refProp(node);\n } else if (refProp) {\n (refProp as MutableRefObject<HTMLDivElement | null>).current = node;\n }\n }}\n data-slot=\"slider-track\"\n className={cn(sliderTrackVariants({ size }), className)}\n {...rest}\n />\n );\n}\n\nSliderTrack.displayName = \"SliderTrack\";\n\nexport function SliderRange({\n className,\n ref,\n ...rest\n}: SliderRangeProps & { ref?: Ref<HTMLDivElement> }) {\n const { min, max, value, appearance } = useSliderContext(\"SliderRange\");\n const pct = max === min ? 0 : ((value - min) / (max - min)) * 100;\n return (\n <div\n ref={ref}\n data-slot=\"slider-range\"\n className={cn(sliderRangeVariants({ appearance }), className)}\n style={{ width: `${pct}%` }}\n {...rest}\n />\n );\n}\n\nSliderRange.displayName = \"SliderRange\";\n\nexport function SliderThumb({\n className,\n ref: refProp,\n ...rest\n}: SliderThumbProps & { ref?: Ref<HTMLDivElement> }) {\n const { min, max, value, step, setValue, disabled, size, trackRef } =\n useSliderContext(\"SliderThumb\");\n const pct = max === min ? 0 : ((value - min) / (max - min)) * 100;\n\n const onPointerDown = useCallback(\n (event: ReactPointerEvent<HTMLDivElement>) => {\n if (disabled) {\n return;\n }\n event.preventDefault();\n const track = trackRef.current;\n if (!track) {\n return;\n }\n event.currentTarget.setPointerCapture(event.pointerId);\n const move = (e: PointerEvent) => {\n setValue(computeValueFromPointer(e.clientX, track, min, max, step));\n };\n const up = () => {\n window.removeEventListener(\"pointermove\", move);\n window.removeEventListener(\"pointerup\", up);\n };\n window.addEventListener(\"pointermove\", move);\n window.addEventListener(\"pointerup\", up);\n },\n [disabled, max, min, setValue, step, trackRef],\n );\n\n const onKeyDown = useCallback(\n (event: ReactKeyboardEvent<HTMLDivElement>) => {\n if (disabled) {\n return;\n }\n const big = (max - min) / 10;\n let delta = 0;\n if (event.key === \"ArrowRight\" || event.key === \"ArrowUp\") {\n delta = step;\n } else if (event.key === \"ArrowLeft\" || event.key === \"ArrowDown\") {\n delta = -step;\n } else if (event.key === \"PageUp\") {\n delta = big;\n } else if (event.key === \"PageDown\") {\n delta = -big;\n } else if (event.key === \"Home\") {\n event.preventDefault();\n setValue(min);\n return;\n } else if (event.key === \"End\") {\n event.preventDefault();\n setValue(max);\n return;\n } else {\n return;\n }\n event.preventDefault();\n setValue(value + delta);\n },\n [disabled, max, min, setValue, step, value],\n );\n\n return (\n <div\n ref={(node) => {\n if (typeof refProp === \"function\") {\n refProp(node);\n } else if (refProp) {\n (refProp as MutableRefObject<HTMLDivElement | null>).current = node;\n }\n }}\n role=\"slider\"\n tabIndex={disabled ? -1 : 0}\n data-slot=\"slider-thumb\"\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={value}\n aria-disabled={disabled || undefined}\n className={cn(\n \"absolute top-1/2 z-10 -translate-x-1/2 -translate-y-1/2\",\n sliderThumbVariants({ size }),\n className,\n )}\n style={{ left: `${pct}%` }}\n onPointerDown={onPointerDown}\n onKeyDown={onKeyDown}\n {...rest}\n />\n );\n}\n\nSliderThumb.displayName = \"SliderThumb\";\n\nexport function RangeSlider({\n className,\n size = \"md\",\n min = 0,\n max = 100,\n step = 1,\n value: valueProp,\n defaultValue,\n onValueChange,\n disabled = false,\n appearance = \"default\",\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n ref,\n ...rest\n}: RangeSliderProps & { ref?: Ref<HTMLDivElement> }) {\n const trackRef = useRef<HTMLDivElement | null>(null);\n const isControlled = valueProp !== undefined;\n const [uncontrolled, setUncontrolled] = useState<[number, number]>(() => {\n const seed = defaultValue ?? [min, max];\n const lo = clamp(snapToStep(seed[0], min, step), min, max);\n const hi = clamp(snapToStep(seed[1], min, step), min, max);\n return lo <= hi ? [lo, hi] : [hi, lo];\n });\n\n const value = isControlled ? (valueProp as [number, number]) : uncontrolled;\n const [lo, hi] =\n value[0] <= value[1]\n ? [value[0], value[1]]\n : [value[1], value[0]];\n\n const setPair = useCallback(\n (next: [number, number]) => {\n const a = clamp(snapToStep(next[0], min, step), min, max);\n const b = clamp(snapToStep(next[1], min, step), min, max);\n const ordered: [number, number] = a <= b ? [a, b] : [b, a];\n if (!isControlled) {\n setUncontrolled(ordered);\n }\n onValueChange?.(ordered);\n },\n [isControlled, max, min, onValueChange, step],\n );\n\n const moveThumb = useCallback(\n (index: 0 | 1, clientX: number) => {\n const track = trackRef.current;\n if (!track) {\n return;\n }\n const raw = computeValueFromPointer(clientX, track, min, max, step);\n if (index === 0) {\n setPair([raw, hi]);\n } else {\n setPair([lo, raw]);\n }\n },\n [hi, lo, max, min, setPair, step],\n );\n\n const loPct = max === min ? 0 : ((lo - min) / (max - min)) * 100;\n const hiPct = max === min ? 0 : ((hi - min) / (max - min)) * 100;\n const resolvedSize = size ?? \"md\";\n\n return (\n <div\n ref={ref}\n data-slot=\"range-slider\"\n role=\"group\"\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-valuetext={`${lo} – ${hi}`}\n className={cn(sliderRootVariants({ size: resolvedSize }), className)}\n {...rest}\n >\n <div\n ref={trackRef}\n data-slot=\"slider-track\"\n className={cn(sliderTrackVariants({ size: resolvedSize }), \"relative\")}\n >\n <div\n data-slot=\"slider-range\"\n className={cn(sliderRangeVariants({ appearance }), \"absolute\")}\n style={{\n left: `${loPct}%`,\n width: `${Math.max(hiPct - loPct, 0)}%`,\n }}\n />\n <RangeThumb\n disabled={disabled}\n size={resolvedSize}\n value={lo}\n min={min}\n max={max}\n step={step}\n positionPct={loPct}\n trackRef={trackRef}\n onMoveClientX={(x) => moveThumb(0, x)}\n onNudge={(delta) => setPair([lo + delta, hi])}\n />\n <RangeThumb\n disabled={disabled}\n size={resolvedSize}\n value={hi}\n min={min}\n max={max}\n step={step}\n positionPct={hiPct}\n trackRef={trackRef}\n onMoveClientX={(x) => moveThumb(1, x)}\n onNudge={(delta) => setPair([lo, hi + delta])}\n />\n </div>\n </div>\n );\n}\n\nRangeSlider.displayName = \"RangeSlider\";\n\ntype RangeThumbProps = {\n disabled: boolean;\n size: \"sm\" | \"md\" | \"lg\";\n value: number;\n min: number;\n max: number;\n step: number;\n positionPct: number;\n trackRef: RefObject<HTMLDivElement | null>;\n onMoveClientX: (clientX: number) => void;\n onNudge: (delta: number) => void;\n};\n\nfunction RangeThumb({\n disabled,\n size,\n value,\n min,\n max,\n step,\n positionPct,\n trackRef,\n onMoveClientX,\n onNudge,\n}: RangeThumbProps) {\n const onPointerDown = useCallback(\n (event: ReactPointerEvent<HTMLDivElement>) => {\n if (disabled) {\n return;\n }\n event.preventDefault();\n const track = trackRef.current;\n if (!track) {\n return;\n }\n event.currentTarget.setPointerCapture(event.pointerId);\n const move = (e: PointerEvent) => {\n onMoveClientX(e.clientX);\n };\n const up = () => {\n window.removeEventListener(\"pointermove\", move);\n window.removeEventListener(\"pointerup\", up);\n };\n window.addEventListener(\"pointermove\", move);\n window.addEventListener(\"pointerup\", up);\n },\n [disabled, onMoveClientX, trackRef],\n );\n\n const onKeyDown = useCallback(\n (event: ReactKeyboardEvent<HTMLDivElement>) => {\n if (disabled) {\n return;\n }\n const big = (max - min) / 10;\n let delta = 0;\n if (event.key === \"ArrowRight\" || event.key === \"ArrowUp\") {\n delta = step;\n } else if (event.key === \"ArrowLeft\" || event.key === \"ArrowDown\") {\n delta = -step;\n } else if (event.key === \"PageUp\") {\n delta = big;\n } else if (event.key === \"PageDown\") {\n delta = -big;\n } else if (event.key === \"Home\") {\n event.preventDefault();\n onNudge(min - value);\n return;\n } else if (event.key === \"End\") {\n event.preventDefault();\n onNudge(max - value);\n return;\n } else {\n return;\n }\n event.preventDefault();\n onNudge(delta);\n },\n [disabled, max, min, onNudge, step, value],\n );\n\n return (\n <div\n role=\"slider\"\n tabIndex={disabled ? -1 : 0}\n data-slot=\"range-slider-thumb\"\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={value}\n aria-disabled={disabled || undefined}\n className={cn(\n \"absolute top-1/2 z-10 -translate-x-1/2 -translate-y-1/2\",\n sliderThumbVariants({ size }),\n )}\n style={{ left: `${positionPct}%` }}\n onPointerDown={onPointerDown}\n onKeyDown={onKeyDown}\n />\n );\n}\n"]}