@tamagui/slider 1.46.1 → 1.47.0

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tamagui/slider",
3
- "version": "1.46.1",
3
+ "version": "1.47.0",
4
4
  "sideEffects": [
5
5
  "*.css"
6
6
  ],
@@ -31,21 +31,21 @@
31
31
  }
32
32
  },
33
33
  "dependencies": {
34
- "@tamagui/compose-refs": "1.46.1",
35
- "@tamagui/core": "1.46.1",
36
- "@tamagui/create-context": "1.46.1",
37
- "@tamagui/get-token": "1.46.1",
38
- "@tamagui/helpers": "1.46.1",
39
- "@tamagui/stacks": "1.46.1",
40
- "@tamagui/use-controllable-state": "1.46.1",
41
- "@tamagui/use-direction": "1.46.1"
34
+ "@tamagui/compose-refs": "1.47.0",
35
+ "@tamagui/core": "1.47.0",
36
+ "@tamagui/create-context": "1.47.0",
37
+ "@tamagui/get-token": "1.47.0",
38
+ "@tamagui/helpers": "1.47.0",
39
+ "@tamagui/stacks": "1.47.0",
40
+ "@tamagui/use-controllable-state": "1.47.0",
41
+ "@tamagui/use-direction": "1.47.0"
42
42
  },
43
43
  "peerDependencies": {
44
44
  "react": "*",
45
45
  "react-native": "*"
46
46
  },
47
47
  "devDependencies": {
48
- "@tamagui/build": "1.46.1",
48
+ "@tamagui/build": "1.47.0",
49
49
  "react": "^18.2.0",
50
50
  "react-native": "^0.72.1"
51
51
  },
package/types/Slider.d.ts CHANGED
@@ -385,7 +385,7 @@ declare const SliderThumb: import("@tamagui/core").ReactComponentWithRef<SliderT
385
385
  readonly size?: SizeTokens | undefined;
386
386
  readonly unstyled?: boolean | undefined;
387
387
  }>>, keyof SliderThumbProps>, TamaguiElement> & {
388
- staticConfig: import("@tamagui/core").StaticConfigParsed;
388
+ staticConfig: import("@tamagui/core").StaticConfig;
389
389
  styleable: import("@tamagui/core").Styleable<Omit<import("react-native").ViewProps, "children" | "onLayout" | "style" | "display" | keyof import("react-native").GestureResponderHandlers> & import("@tamagui/core").ExtendBaseStackProps & import("@tamagui/core").TamaguiComponentPropsBase & {
390
390
  style?: import("@tamagui/core").StyleProp<import("react-native").ViewStyle | React.CSSProperties | (React.CSSProperties & import("react-native").ViewStyle)>;
391
391
  } & import("@tamagui/core").WithThemeValues<import("@tamagui/core").StackStylePropsBase> & import("@tamagui/core").WithShorthands<import("@tamagui/core").WithThemeValues<import("@tamagui/core").StackStylePropsBase>> & import("@tamagui/core/types/reactNativeTypes").RNViewProps & Omit<{
@@ -572,7 +572,7 @@ declare const Slider: React.ForwardRefExoticComponent<SliderProps & React.RefAtt
572
572
  readonly size?: SizeTokens | undefined;
573
573
  readonly unstyled?: boolean | undefined;
574
574
  }>>, keyof SliderThumbProps>, TamaguiElement> & {
575
- staticConfig: import("@tamagui/core").StaticConfigParsed;
575
+ staticConfig: import("@tamagui/core").StaticConfig;
576
576
  styleable: import("@tamagui/core").Styleable<Omit<import("react-native").ViewProps, "children" | "onLayout" | "style" | "display" | keyof import("react-native").GestureResponderHandlers> & import("@tamagui/core").ExtendBaseStackProps & import("@tamagui/core").TamaguiComponentPropsBase & {
577
577
  style?: import("@tamagui/core").StyleProp<import("react-native").ViewStyle | React.CSSProperties | (React.CSSProperties & import("react-native").ViewStyle)>;
578
578
  } & import("@tamagui/core").WithThemeValues<import("@tamagui/core").StackStylePropsBase> & import("@tamagui/core").WithShorthands<import("@tamagui/core").WithThemeValues<import("@tamagui/core").StackStylePropsBase>> & import("@tamagui/core/types/reactNativeTypes").RNViewProps & Omit<{
@@ -759,7 +759,7 @@ declare const Thumb: import("@tamagui/core").ReactComponentWithRef<SliderThumbPr
759
759
  readonly size?: SizeTokens | undefined;
760
760
  readonly unstyled?: boolean | undefined;
761
761
  }>>, keyof SliderThumbProps>, TamaguiElement> & {
762
- staticConfig: import("@tamagui/core").StaticConfigParsed;
762
+ staticConfig: import("@tamagui/core").StaticConfig;
763
763
  styleable: import("@tamagui/core").Styleable<Omit<import("react-native").ViewProps, "children" | "onLayout" | "style" | "display" | keyof import("react-native").GestureResponderHandlers> & import("@tamagui/core").ExtendBaseStackProps & import("@tamagui/core").TamaguiComponentPropsBase & {
764
764
  style?: import("@tamagui/core").StyleProp<import("react-native").ViewStyle | React.CSSProperties | (React.CSSProperties & import("react-native").ViewStyle)>;
765
765
  } & import("@tamagui/core").WithThemeValues<import("@tamagui/core").StackStylePropsBase> & import("@tamagui/core").WithShorthands<import("@tamagui/core").WithThemeValues<import("@tamagui/core").StackStylePropsBase>> & import("@tamagui/core/types/reactNativeTypes").RNViewProps & Omit<{
@@ -1,514 +0,0 @@
1
- import { composeRefs, useComposedRefs } from "@tamagui/compose-refs";
2
- import {
3
- getTokens,
4
- getVariableValue,
5
- isClient,
6
- isWeb,
7
- styled,
8
- withStaticProperties
9
- } from "@tamagui/core";
10
- import { getSize } from "@tamagui/get-token";
11
- import { clamp, composeEventHandlers } from "@tamagui/helpers";
12
- import { ThemeableStack } from "@tamagui/stacks";
13
- import { useControllableState } from "@tamagui/use-controllable-state";
14
- import { useDirection } from "@tamagui/use-direction";
15
- import * as React from "react";
16
- import {
17
- ARROW_KEYS,
18
- BACK_KEYS,
19
- PAGE_KEYS,
20
- SLIDER_NAME,
21
- SliderOrientationProvider,
22
- SliderProvider,
23
- useSliderContext,
24
- useSliderOrientationContext
25
- } from "./constants";
26
- import {
27
- convertValueToPercentage,
28
- getClosestValueIndex,
29
- getDecimalCount,
30
- getLabel,
31
- getNextSortedValues,
32
- getThumbInBoundsOffset,
33
- hasMinStepsBetweenValues,
34
- linearScale,
35
- roundValue
36
- } from "./helpers";
37
- import { SliderFrame, SliderImpl } from "./SliderImpl";
38
- const SliderHorizontal = React.forwardRef(
39
- (props, forwardedRef) => {
40
- const {
41
- min,
42
- max,
43
- dir,
44
- onSlideStart,
45
- onSlideMove,
46
- onStepKeyDown,
47
- onSlideEnd,
48
- ...sliderProps
49
- } = props;
50
- const direction = useDirection(dir);
51
- const isDirectionLTR = direction === "ltr";
52
- const sliderRef = React.useRef(null);
53
- const [state, setState] = React.useState(() => ({ size: 0, offset: 0 }));
54
- function getValueFromPointer(pointerPosition) {
55
- const input = [0, state.size];
56
- const output = isDirectionLTR ? [min, max] : [max, min];
57
- const value = linearScale(input, output);
58
- return value(pointerPosition);
59
- }
60
- const measure = () => {
61
- sliderRef.current?.measure((_x, _y, width, _height, pageX, _pageY) => {
62
- setState({
63
- size: width,
64
- offset: pageX
65
- });
66
- });
67
- };
68
- if (isClient) {
69
- useOnDebouncedWindowResize(measure);
70
- }
71
- return <SliderOrientationProvider
72
- scope={props.__scopeSlider}
73
- startEdge={isDirectionLTR ? "left" : "right"}
74
- endEdge={isDirectionLTR ? "right" : "left"}
75
- direction={isDirectionLTR ? 1 : -1}
76
- sizeProp="width"
77
- size={state.size}
78
- ><SliderImpl
79
- ref={composeRefs(forwardedRef, sliderRef)}
80
- dir={direction}
81
- {...sliderProps}
82
- orientation="horizontal"
83
- onLayout={measure}
84
- onSlideStart={(event, target) => {
85
- const value = getValueFromPointer(event.nativeEvent.locationX);
86
- if (value) {
87
- onSlideStart?.(value, target, event);
88
- }
89
- }}
90
- onSlideMove={(event) => {
91
- const value = getValueFromPointer(event.nativeEvent.pageX - state.offset);
92
- if (value) {
93
- onSlideMove?.(value, event);
94
- }
95
- }}
96
- onSlideEnd={(event) => {
97
- const value = getValueFromPointer(event.nativeEvent.pageX - state.offset);
98
- if (value) {
99
- onSlideEnd?.(event, value);
100
- }
101
- }}
102
- onStepKeyDown={(event) => {
103
- const isBackKey = BACK_KEYS[direction].includes(event.key);
104
- onStepKeyDown?.({ event, direction: isBackKey ? -1 : 1 });
105
- }}
106
- /></SliderOrientationProvider>;
107
- }
108
- );
109
- function useOnDebouncedWindowResize(callback, amt = 200) {
110
- React.useEffect(() => {
111
- let last;
112
- const onResize = () => {
113
- clearTimeout(last);
114
- last = setTimeout(callback, amt);
115
- };
116
- window.addEventListener("resize", onResize);
117
- return () => {
118
- clearTimeout(last);
119
- window.removeEventListener("resize", onResize);
120
- };
121
- }, []);
122
- }
123
- const SliderVertical = React.forwardRef(
124
- (props, forwardedRef) => {
125
- const {
126
- min,
127
- max,
128
- onSlideStart,
129
- onSlideMove,
130
- onStepKeyDown,
131
- onSlideEnd,
132
- ...sliderProps
133
- } = props;
134
- const [state, setState] = React.useState(() => ({ size: 0, offset: 0 }));
135
- const sliderRef = React.useRef(null);
136
- function getValueFromPointer(pointerPosition) {
137
- const input = [0, state.size];
138
- const output = [max, min];
139
- const value = linearScale(input, output);
140
- return value(pointerPosition);
141
- }
142
- const measure = () => {
143
- sliderRef.current?.measure((_x, _y, _width, height, _pageX, pageY) => {
144
- setState({
145
- size: height,
146
- offset: pageY
147
- });
148
- });
149
- };
150
- if (isClient) {
151
- useOnDebouncedWindowResize(measure);
152
- }
153
- return <SliderOrientationProvider
154
- scope={props.__scopeSlider}
155
- startEdge="bottom"
156
- endEdge="top"
157
- sizeProp="height"
158
- size={state.size}
159
- direction={1}
160
- ><SliderImpl
161
- ref={composeRefs(forwardedRef, sliderRef)}
162
- {...sliderProps}
163
- orientation="vertical"
164
- onLayout={measure}
165
- onSlideStart={(event, target) => {
166
- const value = getValueFromPointer(event.nativeEvent.locationY);
167
- if (value) {
168
- onSlideStart?.(value, target, event);
169
- }
170
- }}
171
- onSlideMove={(event) => {
172
- const value = getValueFromPointer(event.nativeEvent.pageY - state.offset);
173
- if (value) {
174
- onSlideMove?.(value, event);
175
- }
176
- }}
177
- onSlideEnd={(event) => {
178
- const value = getValueFromPointer(event.nativeEvent.pageY - state.offset);
179
- onSlideEnd?.(event, value);
180
- }}
181
- onStepKeyDown={(event) => {
182
- const isBackKey = BACK_KEYS.ltr.includes(event.key);
183
- onStepKeyDown?.({ event, direction: isBackKey ? -1 : 1 });
184
- }}
185
- /></SliderOrientationProvider>;
186
- }
187
- );
188
- const TRACK_NAME = "SliderTrack";
189
- const SliderTrackFrame = styled(SliderFrame, {
190
- name: "SliderTrack",
191
- variants: {
192
- unstyled: {
193
- false: {
194
- height: "100%",
195
- width: "100%",
196
- backgroundColor: "$background",
197
- position: "relative",
198
- borderRadius: 1e5,
199
- overflow: "hidden"
200
- }
201
- }
202
- },
203
- defaultVariants: {
204
- unstyled: false
205
- }
206
- });
207
- const SliderTrack = React.forwardRef(
208
- (props, forwardedRef) => {
209
- const { __scopeSlider, ...trackProps } = props;
210
- const context = useSliderContext(TRACK_NAME, __scopeSlider);
211
- return <SliderTrackFrame
212
- data-disabled={context.disabled ? "" : void 0}
213
- data-orientation={context.orientation}
214
- orientation={context.orientation}
215
- size={context.size}
216
- {...trackProps}
217
- ref={forwardedRef}
218
- />;
219
- }
220
- );
221
- SliderTrack.displayName = TRACK_NAME;
222
- const RANGE_NAME = "SliderTrackActive";
223
- const SliderTrackActiveFrame = styled(SliderFrame, {
224
- name: "SliderTrackActive",
225
- backgroundColor: "$background",
226
- position: "absolute"
227
- });
228
- const SliderTrackActive = React.forwardRef(
229
- (props, forwardedRef) => {
230
- const { __scopeSlider, ...rangeProps } = props;
231
- const context = useSliderContext(RANGE_NAME, __scopeSlider);
232
- const orientation = useSliderOrientationContext(RANGE_NAME, __scopeSlider);
233
- const ref = React.useRef(null);
234
- const composedRefs = useComposedRefs(forwardedRef, ref);
235
- const valuesCount = context.values.length;
236
- const percentages = context.values.map(
237
- (value) => convertValueToPercentage(value, context.min, context.max)
238
- );
239
- const offsetStart = valuesCount > 1 ? Math.min(...percentages) : 0;
240
- const offsetEnd = 100 - Math.max(...percentages);
241
- return <SliderTrackActiveFrame
242
- orientation={context.orientation}
243
- data-orientation={context.orientation}
244
- data-disabled={context.disabled ? "" : void 0}
245
- size={context.size}
246
- {...rangeProps}
247
- ref={composedRefs}
248
- {...{
249
- [orientation.startEdge]: `${offsetStart}%`,
250
- [orientation.endEdge]: `${offsetEnd}%`
251
- }}
252
- {...orientation.sizeProp === "width" ? {
253
- height: "100%"
254
- } : {
255
- left: 0,
256
- right: 0
257
- }}
258
- />;
259
- }
260
- );
261
- SliderTrackActive.displayName = RANGE_NAME;
262
- const THUMB_NAME = "SliderThumb";
263
- const getThumbSize = (val) => {
264
- const tokens = getTokens();
265
- const size = typeof val === "number" ? val : getSize(tokens.size[val], {
266
- shift: -1
267
- });
268
- return {
269
- width: size,
270
- height: size,
271
- minWidth: size,
272
- minHeight: size
273
- };
274
- };
275
- const SliderThumbFrame = styled(ThemeableStack, {
276
- name: "SliderThumb",
277
- variants: {
278
- size: {
279
- "...size": getThumbSize
280
- },
281
- unstyled: {
282
- false: {
283
- position: "absolute",
284
- bordered: 2,
285
- borderWidth: 2,
286
- backgrounded: true,
287
- pressTheme: isWeb,
288
- focusTheme: isWeb,
289
- hoverTheme: isWeb
290
- }
291
- }
292
- },
293
- defaultVariants: {
294
- unstyled: false
295
- }
296
- });
297
- const SliderThumb = SliderThumbFrame.styleable(function SliderThumb2(props, forwardedRef) {
298
- const { __scopeSlider, index, size: sizeProp, ...thumbProps } = props;
299
- const context = useSliderContext(THUMB_NAME, __scopeSlider);
300
- const orientation = useSliderOrientationContext(THUMB_NAME, __scopeSlider);
301
- const [thumb, setThumb] = React.useState(null);
302
- const composedRefs = useComposedRefs(
303
- forwardedRef,
304
- (node) => setThumb(node)
305
- );
306
- const value = context.values[index];
307
- const percent = value === void 0 ? 0 : convertValueToPercentage(value, context.min, context.max);
308
- const label = getLabel(index, context.values.length);
309
- const sizeIn = sizeProp ?? context.size ?? "$true";
310
- const [size, setSize] = React.useState(() => {
311
- const estimatedSize = getVariableValue(getThumbSize(sizeIn).width);
312
- return estimatedSize;
313
- });
314
- const thumbInBoundsOffset = size ? getThumbInBoundsOffset(size, percent, orientation.direction) : 0;
315
- React.useEffect(() => {
316
- if (thumb) {
317
- context.thumbs.add(thumb);
318
- return () => {
319
- context.thumbs.delete(thumb);
320
- };
321
- }
322
- }, [thumb, context.thumbs]);
323
- const positionalStyles = context.orientation === "horizontal" ? {
324
- x: thumbInBoundsOffset - size / 2,
325
- y: -size / 2,
326
- top: "50%",
327
- ...size === 0 && {
328
- top: "auto",
329
- bottom: "auto"
330
- }
331
- } : {
332
- x: -size / 2,
333
- y: size / 2,
334
- left: "50%",
335
- ...size === 0 && {
336
- left: "auto",
337
- right: "auto"
338
- }
339
- };
340
- return <SliderThumbFrame
341
- ref={composedRefs}
342
- role="slider"
343
- aria-label={props["aria-label"] || label}
344
- aria-valuemin={context.min}
345
- aria-valuenow={value}
346
- aria-valuemax={context.max}
347
- aria-orientation={context.orientation}
348
- data-orientation={context.orientation}
349
- data-disabled={context.disabled ? "" : void 0}
350
- tabIndex={context.disabled ? void 0 : 0}
351
- animateOnly={["transform"]}
352
- {...positionalStyles}
353
- {...{
354
- [orientation.startEdge]: `${percent}%`
355
- }}
356
- size={sizeIn}
357
- {...thumbProps}
358
- onLayout={(e) => {
359
- setSize(e.nativeEvent.layout[orientation.sizeProp]);
360
- }}
361
- onFocus={composeEventHandlers(props.onFocus, () => {
362
- context.valueIndexToChangeRef.current = index;
363
- })}
364
- />;
365
- });
366
- const SliderComponent = React.forwardRef(
367
- (props, forwardedRef) => {
368
- const {
369
- name,
370
- min = 0,
371
- max = 100,
372
- step = 1,
373
- orientation = "horizontal",
374
- disabled = false,
375
- minStepsBetweenThumbs = 0,
376
- defaultValue = [min],
377
- value,
378
- onValueChange = () => {
379
- },
380
- size: sizeProp,
381
- onSlideEnd,
382
- onSlideMove,
383
- onSlideStart,
384
- ...sliderProps
385
- } = props;
386
- const sliderRef = React.useRef(null);
387
- const composedRefs = useComposedRefs(sliderRef, forwardedRef);
388
- const thumbRefs = React.useRef(/* @__PURE__ */ new Set());
389
- const valueIndexToChangeRef = React.useRef(0);
390
- const isHorizontal = orientation === "horizontal";
391
- const [values = [], setValues] = useControllableState({
392
- prop: value,
393
- defaultProp: defaultValue,
394
- transition: true,
395
- onChange: (value2) => {
396
- if (isWeb) {
397
- const thumbs = [...thumbRefs.current];
398
- thumbs[valueIndexToChangeRef.current]?.focus();
399
- }
400
- onValueChange(value2);
401
- }
402
- });
403
- if (isWeb) {
404
- React.useEffect(() => {
405
- const node = sliderRef.current;
406
- if (!node)
407
- return;
408
- const preventDefault = (e) => {
409
- e.preventDefault();
410
- };
411
- node.addEventListener("touchstart", preventDefault);
412
- return () => {
413
- node.removeEventListener("touchstart", preventDefault);
414
- };
415
- }, []);
416
- }
417
- function handleSlideMove(value2, event) {
418
- updateValues(value2, valueIndexToChangeRef.current);
419
- onSlideMove?.(event, value2);
420
- }
421
- function updateValues(value2, atIndex) {
422
- const decimalCount = getDecimalCount(step);
423
- const snapToStep = roundValue(
424
- Math.round((value2 - min) / step) * step + min,
425
- decimalCount
426
- );
427
- const nextValue = clamp(snapToStep, [min, max]);
428
- setValues((prevValues = []) => {
429
- const nextValues = getNextSortedValues(prevValues, nextValue, atIndex);
430
- if (hasMinStepsBetweenValues(nextValues, minStepsBetweenThumbs * step)) {
431
- valueIndexToChangeRef.current = nextValues.indexOf(nextValue);
432
- return String(nextValues) === String(prevValues) ? prevValues : nextValues;
433
- } else {
434
- return prevValues;
435
- }
436
- });
437
- }
438
- const SliderOriented = isHorizontal ? SliderHorizontal : SliderVertical;
439
- return <SliderProvider
440
- scope={props.__scopeSlider}
441
- disabled={disabled}
442
- min={min}
443
- max={max}
444
- valueIndexToChangeRef={valueIndexToChangeRef}
445
- thumbs={thumbRefs.current}
446
- values={values}
447
- orientation={orientation}
448
- size={sizeProp}
449
- >
450
- <SliderOriented
451
- aria-disabled={disabled}
452
- data-disabled={disabled ? "" : void 0}
453
- {...sliderProps}
454
- ref={composedRefs}
455
- min={min}
456
- max={max}
457
- onSlideEnd={onSlideEnd}
458
- onSlideStart={disabled ? void 0 : (value2, target, event) => {
459
- if (target !== "thumb") {
460
- const closestIndex = getClosestValueIndex(values, value2);
461
- updateValues(value2, closestIndex);
462
- onSlideStart?.(event, value2, target);
463
- }
464
- }}
465
- onSlideMove={disabled ? void 0 : handleSlideMove}
466
- onHomeKeyDown={() => !disabled && updateValues(min, 0)}
467
- onEndKeyDown={() => !disabled && updateValues(max, values.length - 1)}
468
- onStepKeyDown={({ event, direction: stepDirection }) => {
469
- if (!disabled) {
470
- const isPageKey = PAGE_KEYS.includes(event.key);
471
- const isSkipKey = isPageKey || event.shiftKey && ARROW_KEYS.includes(event.key);
472
- const multiplier = isSkipKey ? 10 : 1;
473
- const atIndex = valueIndexToChangeRef.current;
474
- const value2 = values[atIndex];
475
- const stepInDirection = step * multiplier * stepDirection;
476
- updateValues(value2 + stepInDirection, atIndex);
477
- }
478
- }}
479
- />
480
- {
481
- /* {isFormControl &&
482
- values.map((value, index) => (
483
- <BubbleInput
484
- key={index}
485
- name={name ? name + (values.length > 1 ? '[]' : '') : undefined}
486
- value={value}
487
- />
488
- ))} */
489
- }
490
- </SliderProvider>;
491
- }
492
- );
493
- const Slider = withStaticProperties(SliderComponent, {
494
- Track: SliderTrack,
495
- TrackActive: SliderTrackActive,
496
- Thumb: SliderThumb
497
- });
498
- Slider.displayName = SLIDER_NAME;
499
- const Track = SliderTrack;
500
- const Range = SliderTrackActive;
501
- const Thumb = SliderThumb;
502
- export {
503
- Range,
504
- Slider,
505
- SliderThumb,
506
- SliderThumbFrame,
507
- SliderTrack,
508
- SliderTrackActive,
509
- SliderTrackActiveFrame,
510
- SliderTrackFrame,
511
- Thumb,
512
- Track
513
- };
514
- //# sourceMappingURL=Slider.mjs.map
@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/Slider.tsx"],
4
- "mappings": "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",
5
- "names": ["SliderThumb", "value"]
6
- }
@@ -1,100 +0,0 @@
1
- import { composeEventHandlers, getVariableValue, isWeb, styled } from "@tamagui/core";
2
- import { getSize } from "@tamagui/get-token";
3
- import { YStack } from "@tamagui/stacks";
4
- import * as React from "react";
5
- import { ARROW_KEYS, PAGE_KEYS, SLIDER_NAME, useSliderContext } from "./constants";
6
- const DirectionalYStack = styled(YStack, {
7
- variants: {
8
- orientation: {
9
- horizontal: {},
10
- vertical: {}
11
- }
12
- }
13
- });
14
- const SliderFrame = styled(DirectionalYStack, {
15
- position: "relative",
16
- variants: {
17
- size: (val, extras) => {
18
- const orientation = extras.props.orientation;
19
- const size = Math.round(getVariableValue(getSize(val)) / 6);
20
- if (orientation === "horizontal") {
21
- return {
22
- height: size,
23
- borderRadius: size,
24
- justifyContent: "center"
25
- };
26
- }
27
- return {
28
- width: size,
29
- borderRadius: size,
30
- alignItems: "center"
31
- };
32
- }
33
- }
34
- });
35
- const SliderImpl = React.forwardRef(
36
- (props, forwardedRef) => {
37
- const {
38
- __scopeSlider,
39
- onSlideStart,
40
- onSlideMove,
41
- onSlideEnd,
42
- onHomeKeyDown,
43
- onEndKeyDown,
44
- onStepKeyDown,
45
- ...sliderProps
46
- } = props;
47
- const context = useSliderContext(SLIDER_NAME, __scopeSlider);
48
- return <SliderFrame
49
- size="$4"
50
- {...sliderProps}
51
- data-orientation={sliderProps.orientation}
52
- ref={forwardedRef}
53
- {...isWeb && {
54
- onKeyDown: (event) => {
55
- if (event.key === "Home") {
56
- onHomeKeyDown(event);
57
- event.preventDefault();
58
- } else if (event.key === "End") {
59
- onEndKeyDown(event);
60
- event.preventDefault();
61
- } else if (PAGE_KEYS.concat(ARROW_KEYS).includes(event.key)) {
62
- onStepKeyDown(event);
63
- event.preventDefault();
64
- }
65
- }
66
- }}
67
- onMoveShouldSetResponderCapture={() => true}
68
- onScrollShouldSetResponder={() => true}
69
- onScrollShouldSetResponderCapture={() => true}
70
- onMoveShouldSetResponder={() => true}
71
- onStartShouldSetResponder={() => true}
72
- onResponderTerminationRequest={() => {
73
- return false;
74
- }}
75
- onResponderGrant={composeEventHandlers(props.onResponderGrant, (event) => {
76
- const target = event.target;
77
- const isStartingOnThumb = context.thumbs.has(target);
78
- if (isWeb && target instanceof HTMLElement) {
79
- if (context.thumbs.has(target)) {
80
- target.focus();
81
- }
82
- }
83
- onSlideStart(event, isStartingOnThumb ? "thumb" : "track");
84
- })}
85
- onResponderMove={composeEventHandlers(props.onResponderMove, (event) => {
86
- event.stopPropagation();
87
- onSlideMove(event);
88
- })}
89
- onResponderRelease={composeEventHandlers(props.onResponderRelease, (event) => {
90
- onSlideEnd(event);
91
- })}
92
- />;
93
- }
94
- );
95
- export {
96
- DirectionalYStack,
97
- SliderFrame,
98
- SliderImpl
99
- };
100
- //# sourceMappingURL=SliderImpl.mjs.map
@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/SliderImpl.tsx"],
4
- "mappings": "AAIA,SAAS,sBAAsB,kBAAkB,OAAO,cAAc;AACtE,SAAS,eAAe;AACxB,SAAS,cAAc;AACvB,YAAY,WAAW;AAGvB,SAAS,YAAY,WAAW,aAAa,wBAAwB;AAG9D,MAAM,oBAAoB,OAAO,QAAQ;AAAA,EAC9C,UAAU;AAAA,IACR,aAAa;AAAA,MACX,YAAY,CAAC;AAAA,MACb,UAAU,CAAC;AAAA,IACb;AAAA,EACF;AACF,CAAC;AAEM,MAAM,cAAc,OAAO,mBAAmB;AAAA,EACnD,UAAU;AAAA,EAEV,UAAU;AAAA,IACR,MAAM,CAAC,KAAK,WAAW;AACrB,YAAM,cAAc,OAAO,MAAM;AACjC,YAAM,OAAO,KAAK,MAAM,iBAAiB,QAAQ,GAAG,CAAC,IAAI,CAAC;AAC1D,UAAI,gBAAgB,cAAc;AAChC,eAAO;AAAA,UACL,QAAQ;AAAA,UACR,cAAc;AAAA,UACd,gBAAgB;AAAA,QAClB;AAAA,MACF;AACA,aAAO;AAAA,QACL,OAAO;AAAA,QACP,cAAc;AAAA,QACd,YAAY;AAAA,MACd;AAAA,IACF;AAAA,EACF;AACF,CAAC;AAEM,MAAM,aAAa,MAAM;AAAA,EAC9B,CAAC,OAAqC,iBAAiB;AACrD,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL,IAAI;AACJ,UAAM,UAAU,iBAAiB,aAAa,aAAa;AAC3D,WACE,CAAC;AAAA,MACC,KAAK;AAAA,UACD;AAAA,MACJ,kBAAkB,YAAY;AAAA,MAC9B,KAAK;AAAA,UACA,SAAS;AAAA,QACZ,WAAW,CAAC,UAAU;AACpB,cAAI,MAAM,QAAQ,QAAQ;AACxB,0BAAc,KAAK;AAEnB,kBAAM,eAAe;AAAA,UACvB,WAAW,MAAM,QAAQ,OAAO;AAC9B,yBAAa,KAAK;AAElB,kBAAM,eAAe;AAAA,UACvB,WAAW,UAAU,OAAO,UAAU,EAAE,SAAS,MAAM,GAAG,GAAG;AAC3D,0BAAc,KAAK;AAEnB,kBAAM,eAAe;AAAA,UACvB;AAAA,QACF;AAAA,MACF;AAAA,MACA,iCAAiC,MAAM;AAAA,MACvC,4BAA4B,MAAM;AAAA,MAClC,mCAAmC,MAAM;AAAA,MACzC,0BAA0B,MAAM;AAAA,MAChC,2BAA2B,MAAM;AAAA,MAEjC,+BAA+B,MAAM;AACnC,eAAO;AAAA,MACT;AAAA,MACA,kBAAkB,qBAAqB,MAAM,kBAAkB,CAAC,UAAU;AACxE,cAAM,SAAS,MAAM;AACrB,cAAM,oBAAoB,QAAQ,OAAO,IAAI,MAAM;AAInD,YAAI,SAAS,kBAAkB,aAAa;AAC1C,cAAI,QAAQ,OAAO,IAAI,MAAM,GAAG;AAC9B,mBAAO,MAAM;AAAA,UACf;AAAA,QACF;AACA,qBAAa,OAAO,oBAAoB,UAAU,OAAO;AAAA,MAC3D,CAAC;AAAA,MACD,iBAAiB,qBAAqB,MAAM,iBAAiB,CAAC,UAAU;AACtE,cAAM,gBAAgB;AAEtB,oBAAY,KAAK;AAAA,MACnB,CAAC;AAAA,MACD,oBAAoB,qBAAqB,MAAM,oBAAoB,CAAC,UAAU;AAE5E,mBAAW,KAAK;AAAA,MAClB,CAAC;AAAA,IACH;AAAA,EAEJ;AACF;",
5
- "names": []
6
- }
@@ -1,30 +0,0 @@
1
- import { createContextScope } from "@tamagui/create-context";
2
- const SLIDER_NAME = "Slider";
3
- const [createSliderContext, createSliderScope] = createContextScope(SLIDER_NAME);
4
- const [SliderProvider, useSliderContext] = createSliderContext(SLIDER_NAME);
5
- const [SliderOrientationProvider, useSliderOrientationContext] = createSliderContext(SLIDER_NAME, {
6
- startEdge: "left",
7
- endEdge: "right",
8
- sizeProp: "width",
9
- size: 0,
10
- direction: 1
11
- });
12
- const PAGE_KEYS = ["PageUp", "PageDown"];
13
- const ARROW_KEYS = ["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"];
14
- const BACK_KEYS = {
15
- ltr: ["ArrowDown", "Home", "ArrowLeft", "PageDown"],
16
- rtl: ["ArrowDown", "Home", "ArrowRight", "PageDown"]
17
- };
18
- export {
19
- ARROW_KEYS,
20
- BACK_KEYS,
21
- PAGE_KEYS,
22
- SLIDER_NAME,
23
- SliderOrientationProvider,
24
- SliderProvider,
25
- createSliderContext,
26
- createSliderScope,
27
- useSliderContext,
28
- useSliderOrientationContext
29
- };
30
- //# sourceMappingURL=constants.mjs.map
@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/constants.tsx"],
4
- "mappings": "AACA,SAAS,0BAA0B;AAI5B,MAAM,cAAc;AAEpB,MAAM,CAAC,qBAAqB,iBAAiB,IAClD,mBAAmB,WAAW;AAEzB,MAAM,CAAC,gBAAgB,gBAAgB,IAC5C,oBAAwC,WAAW;AAE9C,MAAM,CAAC,2BAA2B,2BAA2B,IAClE,oBAMG,aAAa;AAAA,EACd,WAAW;AAAA,EACX,SAAS;AAAA,EACT,UAAU;AAAA,EACV,MAAM;AAAA,EACN,WAAW;AACb,CAAC;AAEI,MAAM,YAAY,CAAC,UAAU,UAAU;AACvC,MAAM,aAAa,CAAC,WAAW,aAAa,aAAa,YAAY;AACrE,MAAM,YAAyC;AAAA,EACpD,KAAK,CAAC,aAAa,QAAQ,aAAa,UAAU;AAAA,EAClD,KAAK,CAAC,aAAa,QAAQ,cAAc,UAAU;AACrD;",
5
- "names": []
6
- }
@@ -1,70 +0,0 @@
1
- function getNextSortedValues(prevValues = [], nextValue, atIndex) {
2
- const nextValues = [...prevValues];
3
- nextValues[atIndex] = nextValue;
4
- return nextValues.sort((a, b) => a - b);
5
- }
6
- function convertValueToPercentage(value, min, max) {
7
- const maxSteps = max - min;
8
- const percentPerStep = 100 / maxSteps;
9
- return percentPerStep * (value - min);
10
- }
11
- function getLabel(index, totalValues) {
12
- if (totalValues > 2) {
13
- return `Value ${index + 1} of ${totalValues}`;
14
- } else if (totalValues === 2) {
15
- return ["Minimum", "Maximum"][index];
16
- } else {
17
- return void 0;
18
- }
19
- }
20
- function getClosestValueIndex(values, nextValue) {
21
- if (values.length === 1)
22
- return 0;
23
- const distances = values.map((value) => Math.abs(value - nextValue));
24
- const closestDistance = Math.min(...distances);
25
- return distances.indexOf(closestDistance);
26
- }
27
- function getThumbInBoundsOffset(width, left, direction) {
28
- const halfWidth = width / 2;
29
- const halfPercent = 50;
30
- const offset = linearScale([0, halfPercent], [0, halfWidth]);
31
- return (halfWidth - offset(left) * direction) * direction;
32
- }
33
- function getStepsBetweenValues(values) {
34
- return values.slice(0, -1).map((value, index) => values[index + 1] - value);
35
- }
36
- function hasMinStepsBetweenValues(values, minStepsBetweenValues) {
37
- if (minStepsBetweenValues > 0) {
38
- const stepsBetweenValues = getStepsBetweenValues(values);
39
- const actualMinStepsBetweenValues = Math.min(...stepsBetweenValues);
40
- return actualMinStepsBetweenValues >= minStepsBetweenValues;
41
- }
42
- return true;
43
- }
44
- function linearScale(input, output) {
45
- return (value) => {
46
- if (input[0] === input[1] || output[0] === output[1])
47
- return output[0];
48
- const ratio = (output[1] - output[0]) / (input[1] - input[0]);
49
- return output[0] + ratio * (value - input[0]);
50
- };
51
- }
52
- function getDecimalCount(value) {
53
- return (String(value).split(".")[1] || "").length;
54
- }
55
- function roundValue(value, decimalCount) {
56
- const rounder = Math.pow(10, decimalCount);
57
- return Math.round(value * rounder) / rounder;
58
- }
59
- export {
60
- convertValueToPercentage,
61
- getClosestValueIndex,
62
- getDecimalCount,
63
- getLabel,
64
- getNextSortedValues,
65
- getThumbInBoundsOffset,
66
- hasMinStepsBetweenValues,
67
- linearScale,
68
- roundValue
69
- };
70
- //# sourceMappingURL=helpers.mjs.map
@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/helpers.tsx"],
4
- "mappings": "AAAO,SAAS,oBACd,aAAuB,CAAC,GACxB,WACA,SACA;AACA,QAAM,aAAa,CAAC,GAAG,UAAU;AACjC,aAAW,OAAO,IAAI;AACtB,SAAO,WAAW,KAAK,CAAC,GAAG,MAAM,IAAI,CAAC;AACxC;AAEO,SAAS,yBAAyB,OAAe,KAAa,KAAa;AAChF,QAAM,WAAW,MAAM;AACvB,QAAM,iBAAiB,MAAM;AAC7B,SAAO,kBAAkB,QAAQ;AACnC;AAKO,SAAS,SAAS,OAAe,aAAqB;AAC3D,MAAI,cAAc,GAAG;AACnB,WAAO,SAAS,QAAQ,QAAQ;AAAA,EAClC,WAAW,gBAAgB,GAAG;AAC5B,WAAO,CAAC,WAAW,SAAS,EAAE,KAAK;AAAA,EACrC,OAAO;AACL,WAAO;AAAA,EACT;AACF;AAUO,SAAS,qBAAqB,QAAkB,WAAmB;AACxE,MAAI,OAAO,WAAW;AAAG,WAAO;AAChC,QAAM,YAAY,OAAO,IAAI,CAAC,UAAU,KAAK,IAAI,QAAQ,SAAS,CAAC;AACnE,QAAM,kBAAkB,KAAK,IAAI,GAAG,SAAS;AAC7C,SAAO,UAAU,QAAQ,eAAe;AAC1C;AAMO,SAAS,uBACd,OACA,MACA,WACA;AACA,QAAM,YAAY,QAAQ;AAC1B,QAAM,cAAc;AACpB,QAAM,SAAS,YAAY,CAAC,GAAG,WAAW,GAAG,CAAC,GAAG,SAAS,CAAC;AAC3D,UAAQ,YAAY,OAAO,IAAI,IAAI,aAAa;AAClD;AASA,SAAS,sBAAsB,QAAkB;AAC/C,SAAO,OAAO,MAAM,GAAG,EAAE,EAAE,IAAI,CAAC,OAAO,UAAU,OAAO,QAAQ,CAAC,IAAI,KAAK;AAC5E;AAcO,SAAS,yBACd,QACA,uBACA;AACA,MAAI,wBAAwB,GAAG;AAC7B,UAAM,qBAAqB,sBAAsB,MAAM;AACvD,UAAM,8BAA8B,KAAK,IAAI,GAAG,kBAAkB;AAClE,WAAO,+BAA+B;AAAA,EACxC;AACA,SAAO;AACT;AAGO,SAAS,YACd,OACA,QACA;AACA,SAAO,CAAC,UAAkB;AACxB,QAAI,MAAM,CAAC,MAAM,MAAM,CAAC,KAAK,OAAO,CAAC,MAAM,OAAO,CAAC;AAAG,aAAO,OAAO,CAAC;AACrE,UAAM,SAAS,OAAO,CAAC,IAAI,OAAO,CAAC,MAAM,MAAM,CAAC,IAAI,MAAM,CAAC;AAC3D,WAAO,OAAO,CAAC,IAAI,SAAS,QAAQ,MAAM,CAAC;AAAA,EAC7C;AACF;AAEO,SAAS,gBAAgB,OAAe;AAC7C,UAAQ,OAAO,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC,KAAK,IAAI;AAC7C;AAEO,SAAS,WAAW,OAAe,cAAsB;AAC9D,QAAM,UAAU,KAAK,IAAI,IAAI,YAAY;AACzC,SAAO,KAAK,MAAM,QAAQ,OAAO,IAAI;AACvC;",
5
- "names": []
6
- }
@@ -1,7 +0,0 @@
1
- export * from "./Slider";
2
- import { SliderFrame, DirectionalYStack } from "./SliderImpl";
3
- export {
4
- DirectionalYStack,
5
- SliderFrame
6
- };
7
- //# sourceMappingURL=index.mjs.map
@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../src/index.ts"],
4
- "mappings": "AAAA,cAAc;AAEd,SAAS,aAAa,yBAAyB;",
5
- "names": []
6
- }
@@ -1 +0,0 @@
1
- //# sourceMappingURL=types.mjs.map
@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": [],
4
- "mappings": "",
5
- "names": []
6
- }