react-native-timer-picker 1.10.3 → 2.0.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.
Files changed (66) hide show
  1. package/README.md +81 -52
  2. package/dist/commonjs/components/DurationScroll/index.js +77 -20
  3. package/dist/commonjs/components/DurationScroll/index.js.map +1 -1
  4. package/dist/commonjs/components/DurationScroll/types.js.map +1 -1
  5. package/dist/commonjs/components/TimerPicker/index.js +23 -10
  6. package/dist/commonjs/components/TimerPicker/index.js.map +1 -1
  7. package/dist/commonjs/components/TimerPicker/types.js.map +1 -1
  8. package/dist/commonjs/components/TimerPickerModal/index.js +10 -7
  9. package/dist/commonjs/components/TimerPickerModal/index.js.map +1 -1
  10. package/dist/commonjs/components/TimerPickerModal/styles.js +87 -54
  11. package/dist/commonjs/components/TimerPickerModal/styles.js.map +1 -1
  12. package/dist/commonjs/tests/DurationScroll.test.js +3 -3
  13. package/dist/commonjs/tests/DurationScroll.test.js.map +1 -1
  14. package/dist/commonjs/tests/Modal.test.js +3 -3
  15. package/dist/commonjs/tests/Modal.test.js.map +1 -1
  16. package/dist/commonjs/tests/TimerPicker.test.js +4 -4
  17. package/dist/commonjs/tests/TimerPicker.test.js.map +1 -1
  18. package/dist/commonjs/tests/TimerPickerModal.test.js +6 -6
  19. package/dist/commonjs/tests/TimerPickerModal.test.js.map +1 -1
  20. package/dist/commonjs/utils/generateNumbers.js +4 -3
  21. package/dist/commonjs/utils/generateNumbers.js.map +1 -1
  22. package/dist/commonjs/utils/getAdjustedLimit.js +5 -5
  23. package/dist/commonjs/utils/getAdjustedLimit.js.map +1 -1
  24. package/dist/commonjs/utils/getDurationAndIndexFromScrollOffset.js +2 -1
  25. package/dist/commonjs/utils/getDurationAndIndexFromScrollOffset.js.map +1 -1
  26. package/dist/commonjs/utils/getInitialScrollIndex.js +2 -1
  27. package/dist/commonjs/utils/getInitialScrollIndex.js.map +1 -1
  28. package/dist/commonjs/utils/getSafeInitialValue.js +13 -0
  29. package/dist/commonjs/utils/getSafeInitialValue.js.map +1 -0
  30. package/dist/module/components/DurationScroll/index.js +77 -20
  31. package/dist/module/components/DurationScroll/index.js.map +1 -1
  32. package/dist/module/components/DurationScroll/types.js.map +1 -1
  33. package/dist/module/components/TimerPicker/index.js +23 -10
  34. package/dist/module/components/TimerPicker/index.js.map +1 -1
  35. package/dist/module/components/TimerPicker/types.js.map +1 -1
  36. package/dist/module/components/TimerPickerModal/index.js +10 -7
  37. package/dist/module/components/TimerPickerModal/index.js.map +1 -1
  38. package/dist/module/components/TimerPickerModal/styles.js +87 -54
  39. package/dist/module/components/TimerPickerModal/styles.js.map +1 -1
  40. package/dist/module/tests/DurationScroll.test.js +3 -3
  41. package/dist/module/tests/DurationScroll.test.js.map +1 -1
  42. package/dist/module/tests/Modal.test.js +3 -3
  43. package/dist/module/tests/Modal.test.js.map +1 -1
  44. package/dist/module/tests/TimerPicker.test.js +4 -4
  45. package/dist/module/tests/TimerPicker.test.js.map +1 -1
  46. package/dist/module/tests/TimerPickerModal.test.js +6 -6
  47. package/dist/module/tests/TimerPickerModal.test.js.map +1 -1
  48. package/dist/module/utils/generateNumbers.js +4 -3
  49. package/dist/module/utils/generateNumbers.js.map +1 -1
  50. package/dist/module/utils/getAdjustedLimit.js +5 -5
  51. package/dist/module/utils/getAdjustedLimit.js.map +1 -1
  52. package/dist/module/utils/getDurationAndIndexFromScrollOffset.js +2 -1
  53. package/dist/module/utils/getDurationAndIndexFromScrollOffset.js.map +1 -1
  54. package/dist/module/utils/getInitialScrollIndex.js +2 -1
  55. package/dist/module/utils/getInitialScrollIndex.js.map +1 -1
  56. package/dist/module/utils/getSafeInitialValue.js +6 -0
  57. package/dist/module/utils/getSafeInitialValue.js.map +1 -0
  58. package/dist/typescript/components/DurationScroll/types.d.ts +4 -1
  59. package/dist/typescript/components/TimerPicker/types.d.ts +7 -0
  60. package/dist/typescript/components/TimerPickerModal/styles.d.ts +117 -8
  61. package/dist/typescript/utils/generateNumbers.d.ts +2 -0
  62. package/dist/typescript/utils/getAdjustedLimit.d.ts +1 -1
  63. package/dist/typescript/utils/getDurationAndIndexFromScrollOffset.d.ts +1 -0
  64. package/dist/typescript/utils/getInitialScrollIndex.d.ts +1 -0
  65. package/dist/typescript/utils/getSafeInitialValue.d.ts +9 -0
  66. package/package.json +14 -10
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getSafeInitialValue = void 0;
7
+ const getSafeInitialValue = initialValue => ({
8
+ hours: typeof (initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours) === "number" && !isNaN(initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours) ? initialValue.hours : 0,
9
+ minutes: typeof (initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes) === "number" && !isNaN(initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes) ? initialValue.minutes : 0,
10
+ seconds: typeof (initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds) === "number" && !isNaN(initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds) ? initialValue.seconds : 0
11
+ });
12
+ exports.getSafeInitialValue = getSafeInitialValue;
13
+ //# sourceMappingURL=getSafeInitialValue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getSafeInitialValue","initialValue","hours","isNaN","minutes","seconds","exports"],"sources":["getSafeInitialValue.ts"],"sourcesContent":["export const getSafeInitialValue = (\n initialValue:\n | {\n hours?: number;\n minutes?: number;\n seconds?: number;\n }\n | undefined\n) => ({\n hours:\n typeof initialValue?.hours === \"number\" && !isNaN(initialValue?.hours)\n ? initialValue.hours\n : 0,\n minutes:\n typeof initialValue?.minutes === \"number\" &&\n !isNaN(initialValue?.minutes)\n ? initialValue.minutes\n : 0,\n seconds:\n typeof initialValue?.seconds === \"number\" &&\n !isNaN(initialValue?.seconds)\n ? initialValue.seconds\n : 0,\n});\n"],"mappings":";;;;;;AAAO,MAAMA,mBAAmB,GAC5BC,YAMe,KACb;EACFC,KAAK,EACD,QAAOD,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEC,KAAK,MAAK,QAAQ,IAAI,CAACC,KAAK,CAACF,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEC,KAAK,CAAC,GAChED,YAAY,CAACC,KAAK,GAClB,CAAC;EACXE,OAAO,EACH,QAAOH,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEG,OAAO,MAAK,QAAQ,IACzC,CAACD,KAAK,CAACF,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEG,OAAO,CAAC,GACvBH,YAAY,CAACG,OAAO,GACpB,CAAC;EACXC,OAAO,EACH,QAAOJ,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEI,OAAO,MAAK,QAAQ,IACzC,CAACF,KAAK,CAACF,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEI,OAAO,CAAC,GACvBJ,YAAY,CAACI,OAAO,GACpB;AACd,CAAC,CAAC;AAACC,OAAA,CAAAN,mBAAA,GAAAA,mBAAA","ignoreList":[]}
@@ -18,54 +18,78 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
18
18
  FlatList = RNFlatList,
19
19
  Haptics,
20
20
  initialValue = 0,
21
+ interval,
21
22
  is12HourPicker,
22
23
  isDisabled,
23
24
  label,
24
25
  limit,
25
26
  LinearGradient,
26
- numberOfItems,
27
+ maximumValue,
27
28
  onDurationChange,
28
29
  padNumbersWithZero = false,
29
30
  padWithNItems,
31
+ pickerFeedback,
30
32
  pickerGradientOverlayProps,
31
33
  pmLabel,
32
34
  repeatNumbersNTimes = 3,
35
+ repeatNumbersNTimesNotExplicitlySet,
33
36
  styles,
34
37
  testID,
35
38
  topPickerGradientOverlayProps
36
39
  } = props;
40
+ const numberOfItems = useMemo(() => {
41
+ // guard against negative maximum values
42
+ if (maximumValue < 0) {
43
+ return 1;
44
+ }
45
+ return Math.floor(maximumValue / interval) + 1;
46
+ }, [interval, maximumValue]);
37
47
  const safeRepeatNumbersNTimes = useMemo(() => {
48
+ // do not repeat numbers if there is only one option
49
+ if (numberOfItems === 1) {
50
+ return 1;
51
+ }
38
52
  if (!disableInfiniteScroll && repeatNumbersNTimes < 2) {
39
53
  return 2;
40
- } else if (repeatNumbersNTimes < 1) {
54
+ } else if (repeatNumbersNTimes < 1 || isNaN(repeatNumbersNTimes)) {
41
55
  return 1;
42
56
  }
57
+
58
+ // if this variable is not explicitly set, we calculate a reasonable value based on
59
+ // the number of items in the picker, avoiding regular jumps up/down the list
60
+ // whilst avoiding rendering too many items in the picker
61
+ if (repeatNumbersNTimesNotExplicitlySet) {
62
+ return Math.max(Math.round(180 / numberOfItems), 1);
63
+ }
43
64
  return Math.round(repeatNumbersNTimes);
44
- }, [disableInfiniteScroll, repeatNumbersNTimes]);
65
+ }, [disableInfiniteScroll, numberOfItems, repeatNumbersNTimes, repeatNumbersNTimesNotExplicitlySet]);
45
66
  const numbersForFlatList = useMemo(() => {
46
67
  if (is12HourPicker) {
47
68
  return generate12HourNumbers({
48
69
  padNumbersWithZero,
49
70
  repeatNTimes: safeRepeatNumbersNTimes,
50
71
  disableInfiniteScroll,
51
- padWithNItems
72
+ padWithNItems,
73
+ interval
52
74
  });
53
75
  }
54
76
  return generateNumbers(numberOfItems, {
55
77
  padNumbersWithZero,
56
78
  repeatNTimes: safeRepeatNumbersNTimes,
57
79
  disableInfiniteScroll,
58
- padWithNItems
80
+ padWithNItems,
81
+ interval
59
82
  });
60
- }, [disableInfiniteScroll, is12HourPicker, numberOfItems, padNumbersWithZero, padWithNItems, safeRepeatNumbersNTimes]);
83
+ }, [disableInfiniteScroll, is12HourPicker, interval, numberOfItems, padNumbersWithZero, padWithNItems, safeRepeatNumbersNTimes]);
61
84
  const initialScrollIndex = useMemo(() => getInitialScrollIndex({
62
85
  disableInfiniteScroll,
86
+ interval,
63
87
  numberOfItems,
64
88
  padWithNItems,
65
89
  repeatNumbersNTimes: safeRepeatNumbersNTimes,
66
90
  value: initialValue
67
- }), [disableInfiniteScroll, initialValue, numberOfItems, padWithNItems, safeRepeatNumbersNTimes]);
68
- const adjustedLimited = useMemo(() => getAdjustedLimit(limit, numberOfItems), [limit, numberOfItems]);
91
+ }), [disableInfiniteScroll, initialValue, interval, numberOfItems, padWithNItems, safeRepeatNumbersNTimes]);
92
+ const adjustedLimited = useMemo(() => getAdjustedLimit(limit, numberOfItems, interval), [interval, limit, numberOfItems]);
69
93
  const numberOfItemsToShow = 1 + padWithNItems * 2;
70
94
 
71
95
  // keep track of the latest duration as it scrolls
@@ -131,12 +155,13 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
131
155
  // this function is only used when the picker is in a modal and/or has Haptic/Audio feedback
132
156
  // it is used to ensure that the modal gets the latest duration on clicking
133
157
  // the confirm button, even if the scrollview is still scrolling
134
- if (!aggressivelyGetLatestDuration && !Haptics && !Audio) {
158
+ if (!aggressivelyGetLatestDuration && !Haptics && !Audio && !pickerFeedback) {
135
159
  return;
136
160
  }
137
161
  if (aggressivelyGetLatestDuration) {
138
162
  const newValues = getDurationAndIndexFromScrollOffset({
139
163
  disableInfiniteScroll,
164
+ interval,
140
165
  itemHeight: styles.pickerItemContainer.height,
141
166
  numberOfItems,
142
167
  padWithNItems,
@@ -152,7 +177,7 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
152
177
  latestDuration.current = newValues.duration;
153
178
  }
154
179
  }
155
- if (Haptics || Audio) {
180
+ if (Haptics || Audio || pickerFeedback) {
156
181
  const feedbackIndex = Math.round((e.nativeEvent.contentOffset.y + styles.pickerItemContainer.height / 2) / styles.pickerItemContainer.height);
157
182
  if (feedbackIndex !== lastFeedbackIndex.current) {
158
183
  // this check stops the feedback firing when the component mounts
@@ -170,16 +195,24 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
170
195
  } catch {
171
196
  // do nothing
172
197
  }
198
+
199
+ // fire custom feedback if available
200
+ try {
201
+ pickerFeedback === null || pickerFeedback === void 0 || pickerFeedback();
202
+ } catch {
203
+ // do nothing
204
+ }
173
205
  }
174
206
  lastFeedbackIndex.current = feedbackIndex;
175
207
  }
176
208
  }
177
209
  },
178
210
  // eslint-disable-next-line react-hooks/exhaustive-deps
179
- [adjustedLimited.max, adjustedLimited.min, aggressivelyGetLatestDuration, clickSound, disableInfiniteScroll, numberOfItems, padWithNItems, styles.pickerItemContainer.height]);
211
+ [adjustedLimited.max, adjustedLimited.min, aggressivelyGetLatestDuration, clickSound, disableInfiniteScroll, interval, numberOfItems, padWithNItems, styles.pickerItemContainer.height]);
180
212
  const onMomentumScrollEnd = useCallback(e => {
181
213
  const newValues = getDurationAndIndexFromScrollOffset({
182
214
  disableInfiniteScroll,
215
+ interval,
183
216
  itemHeight: styles.pickerItemContainer.height,
184
217
  numberOfItems,
185
218
  padWithNItems,
@@ -209,11 +242,14 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
209
242
  newValues.duration = adjustedLimited.min;
210
243
  }
211
244
  onDurationChange(newValues.duration);
212
- }, [adjustedLimited.max, adjustedLimited.min, numbersForFlatList.length, disableInfiniteScroll, numberOfItems, onDurationChange, padWithNItems, styles.pickerItemContainer.height]);
245
+ }, [disableInfiniteScroll, interval, styles.pickerItemContainer.height, numberOfItems, padWithNItems, adjustedLimited.max, adjustedLimited.min, onDurationChange, numbersForFlatList.length]);
213
246
  const onViewableItemsChanged = useCallback(({
214
247
  viewableItems
215
248
  }) => {
216
249
  var _viewableItems$, _viewableItems$2;
250
+ if (numberOfItems === 1) {
251
+ return;
252
+ }
217
253
  if ((_viewableItems$ = viewableItems[0]) !== null && _viewableItems$ !== void 0 && _viewableItems$.index && viewableItems[0].index < numberOfItems * 0.5) {
218
254
  var _flatListRef$current3;
219
255
  (_flatListRef$current3 = flatListRef.current) === null || _flatListRef$current3 === void 0 || _flatListRef$current3.scrollToIndex({
@@ -228,17 +264,36 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
228
264
  });
229
265
  }
230
266
  }, [numberOfItems, safeRepeatNumbersNTimes]);
267
+ const [viewabilityConfigCallbackPairs, setViewabilityConfigCallbackPairs] = useState(!disableInfiniteScroll ? [{
268
+ viewabilityConfig: {
269
+ viewAreaCoveragePercentThreshold: 0
270
+ },
271
+ onViewableItemsChanged: onViewableItemsChanged
272
+ }] : undefined);
273
+ const [flatListRenderKey, setFlatListRenderKey] = useState(0);
274
+ const initialRender = useRef(true);
275
+ useEffect(() => {
276
+ // don't run on first render
277
+ if (initialRender.current) {
278
+ initialRender.current = false;
279
+ return;
280
+ }
281
+
282
+ // if the onViewableItemsChanged callback changes, we need to update viewabilityConfigCallbackPairs
283
+ // which requires the FlatList to be remounted, hence the increase of the FlatList key
284
+ setFlatListRenderKey(prev => prev + 1);
285
+ setViewabilityConfigCallbackPairs(!disableInfiniteScroll ? [{
286
+ viewabilityConfig: {
287
+ viewAreaCoveragePercentThreshold: 0
288
+ },
289
+ onViewableItemsChanged: onViewableItemsChanged
290
+ }] : undefined);
291
+ }, [disableInfiniteScroll, onViewableItemsChanged]);
231
292
  const getItemLayout = useCallback((_, index) => ({
232
293
  length: styles.pickerItemContainer.height,
233
294
  offset: styles.pickerItemContainer.height * index,
234
295
  index
235
296
  }), [styles.pickerItemContainer.height]);
236
- const viewabilityConfigCallbackPairs = useRef([{
237
- viewabilityConfig: {
238
- viewAreaCoveragePercentThreshold: 0
239
- },
240
- onViewableItemsChanged: onViewableItemsChanged
241
- }]);
242
297
  useImperativeHandle(ref, () => ({
243
298
  reset: options => {
244
299
  var _flatListRef$current5;
@@ -253,6 +308,7 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
253
308
  animated: (options === null || options === void 0 ? void 0 : options.animated) ?? false,
254
309
  index: getInitialScrollIndex({
255
310
  disableInfiniteScroll,
311
+ interval,
256
312
  numberOfItems,
257
313
  padWithNItems,
258
314
  repeatNumbersNTimes: safeRepeatNumbersNTimes,
@@ -270,6 +326,7 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
270
326
  }, isDisabled && styles.disabledPickerContainer],
271
327
  testID: testID
272
328
  }, /*#__PURE__*/React.createElement(FlatList, {
329
+ key: flatListRenderKey,
273
330
  ref: flatListRef,
274
331
  data: numbersForFlatList,
275
332
  decelerationRate: 0.88,
@@ -284,11 +341,11 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
284
341
  scrollEventThrottle: 16,
285
342
  showsVerticalScrollIndicator: false,
286
343
  snapToAlignment: "start"
287
- // used in place of snapToOffset due to bug on Android
344
+ // used in place of snapToInterval due to bug on Android
288
345
  ,
289
346
  snapToOffsets: [...Array(numbersForFlatList.length)].map((_, i) => i * styles.pickerItemContainer.height),
290
347
  testID: "duration-scroll-flatlist",
291
- viewabilityConfigCallbackPairs: !disableInfiniteScroll ? viewabilityConfigCallbackPairs === null || viewabilityConfigCallbackPairs === void 0 ? void 0 : viewabilityConfigCallbackPairs.current : undefined,
348
+ viewabilityConfigCallbackPairs: viewabilityConfigCallbackPairs,
292
349
  windowSize: numberOfItemsToShow
293
350
  }), /*#__PURE__*/React.createElement(View, {
294
351
  pointerEvents: "none",
@@ -1 +1 @@
1
- {"version":3,"names":["React","useRef","useCallback","forwardRef","useImperativeHandle","useState","useEffect","useMemo","View","Text","FlatList","RNFlatList","colorToRgba","generate12HourNumbers","generateNumbers","getAdjustedLimit","getDurationAndIndexFromScrollOffset","getInitialScrollIndex","DurationScroll","props","ref","aggressivelyGetLatestDuration","allowFontScaling","amLabel","Audio","bottomPickerGradientOverlayProps","clickSoundAsset","disableInfiniteScroll","Haptics","initialValue","is12HourPicker","isDisabled","label","limit","LinearGradient","numberOfItems","onDurationChange","padNumbersWithZero","padWithNItems","pickerGradientOverlayProps","pmLabel","repeatNumbersNTimes","styles","testID","topPickerGradientOverlayProps","safeRepeatNumbersNTimes","Math","round","numbersForFlatList","repeatNTimes","initialScrollIndex","value","adjustedLimited","numberOfItemsToShow","latestDuration","lastFeedbackIndex","flatListRef","clickSound","setClickSound","loadSound","sound","Sound","createAsync","uri","shouldPlay","unloadAsync","renderItem","item","stringItem","intItem","isAm","parseInt","includes","replace","createElement","key","style","pickerItemContainer","pickerItem","max","min","disabledPickerItem","pointerEvents","pickerAmPmContainer","pickerAmPmLabel","onScroll","e","newValues","itemHeight","height","yContentOffset","nativeEvent","contentOffset","y","duration","current","feedbackIndex","selectionAsync","replayAsync","onMomentumScrollEnd","_flatListRef$current","targetScrollIndex","index","scrollToIndex","animated","_flatListRef$current2","length","onViewableItemsChanged","viewableItems","_viewableItems$","_viewableItems$2","_flatListRef$current3","_flatListRef$current4","getItemLayout","_","offset","viewabilityConfigCallbackPairs","viewabilityConfig","viewAreaCoveragePercentThreshold","reset","options","_flatListRef$current5","setValue","_flatListRef$current6","undefined","overflow","disabledPickerContainer","data","decelerationRate","keyExtractor","toString","nestedScrollEnabled","scrollEnabled","scrollEventThrottle","showsVerticalScrollIndicator","snapToAlignment","snapToOffsets","Array","map","i","windowSize","pickerLabelContainer","pickerLabel","Fragment","_extends","colors","pickerContainer","backgroundColor","color","opacity","end","x","start","pickerGradientOverlay","top","bottom","memo"],"sources":["index.tsx"],"sourcesContent":["import React, {\n useRef,\n useCallback,\n forwardRef,\n useImperativeHandle,\n useState,\n useEffect,\n useMemo,\n} from \"react\";\n\nimport { View, Text, FlatList as RNFlatList } from \"react-native\";\nimport type {\n ViewabilityConfigCallbackPairs,\n ViewToken,\n NativeSyntheticEvent,\n NativeScrollEvent,\n} from \"react-native\";\n\nimport { colorToRgba } from \"../../utils/colorToRgba\";\nimport {\n generate12HourNumbers,\n generateNumbers,\n} from \"../../utils/generateNumbers\";\nimport { getAdjustedLimit } from \"../../utils/getAdjustedLimit\";\nimport { getDurationAndIndexFromScrollOffset } from \"../../utils/getDurationAndIndexFromScrollOffset\";\nimport { getInitialScrollIndex } from \"../../utils/getInitialScrollIndex\";\n\nimport type { DurationScrollProps, DurationScrollRef } from \"./types\";\n\nconst DurationScroll = forwardRef<DurationScrollRef, DurationScrollProps>(\n (props, ref) => {\n const {\n aggressivelyGetLatestDuration,\n allowFontScaling = false,\n amLabel,\n Audio,\n bottomPickerGradientOverlayProps,\n clickSoundAsset,\n disableInfiniteScroll = false,\n FlatList = RNFlatList,\n Haptics,\n initialValue = 0,\n is12HourPicker,\n isDisabled,\n label,\n limit,\n LinearGradient,\n numberOfItems,\n onDurationChange,\n padNumbersWithZero = false,\n padWithNItems,\n pickerGradientOverlayProps,\n pmLabel,\n repeatNumbersNTimes = 3,\n styles,\n testID,\n topPickerGradientOverlayProps,\n } = props;\n\n const safeRepeatNumbersNTimes = useMemo(() => {\n if (!disableInfiniteScroll && repeatNumbersNTimes < 2) {\n return 2;\n } else if (repeatNumbersNTimes < 1) {\n return 1;\n }\n\n return Math.round(repeatNumbersNTimes);\n }, [disableInfiniteScroll, repeatNumbersNTimes]);\n\n const numbersForFlatList = useMemo(() => {\n if (is12HourPicker) {\n return generate12HourNumbers({\n padNumbersWithZero,\n repeatNTimes: safeRepeatNumbersNTimes,\n disableInfiniteScroll,\n padWithNItems,\n });\n }\n\n return generateNumbers(numberOfItems, {\n padNumbersWithZero,\n repeatNTimes: safeRepeatNumbersNTimes,\n disableInfiniteScroll,\n padWithNItems,\n });\n }, [\n disableInfiniteScroll,\n is12HourPicker,\n numberOfItems,\n padNumbersWithZero,\n padWithNItems,\n safeRepeatNumbersNTimes,\n ]);\n\n const initialScrollIndex = useMemo(\n () =>\n getInitialScrollIndex({\n disableInfiniteScroll,\n numberOfItems,\n padWithNItems,\n repeatNumbersNTimes: safeRepeatNumbersNTimes,\n value: initialValue,\n }),\n [\n disableInfiniteScroll,\n initialValue,\n numberOfItems,\n padWithNItems,\n safeRepeatNumbersNTimes,\n ]\n );\n\n const adjustedLimited = useMemo(\n () => getAdjustedLimit(limit, numberOfItems),\n [limit, numberOfItems]\n );\n\n const numberOfItemsToShow = 1 + padWithNItems * 2;\n\n // keep track of the latest duration as it scrolls\n const latestDuration = useRef(0);\n // keep track of the last index scrolled past for haptic/audio feedback\n const lastFeedbackIndex = useRef(0);\n\n const flatListRef = useRef<RNFlatList | null>(null);\n\n const [clickSound, setClickSound] = useState<\n | {\n replayAsync: () => Promise<void>;\n unloadAsync: () => Promise<void>;\n }\n | undefined\n >();\n\n // Preload the sound when the component mounts\n useEffect(() => {\n const loadSound = async () => {\n if (Audio) {\n const { sound } = await Audio.Sound.createAsync(\n clickSoundAsset ?? {\n // use a hosted sound as a fallback (do not use local asset due to loader issues\n // in some environments when including mp3 in library)\n uri: \"https://drive.google.com/uc?export=download&id=10e1YkbNsRh-vGx1jmS1Nntz8xzkBp4_I\",\n },\n { shouldPlay: false }\n );\n setClickSound(sound);\n }\n };\n\n loadSound();\n\n // Unload sound when component unmounts\n return () => {\n clickSound?.unloadAsync();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [Audio]);\n\n const renderItem = useCallback(\n ({ item }: { item: string }) => {\n let stringItem = item;\n let intItem: number;\n let isAm: boolean | undefined;\n\n if (!is12HourPicker) {\n intItem = parseInt(item);\n } else {\n isAm = item.includes(\"AM\");\n stringItem = item.replace(/\\s[AP]M/g, \"\");\n intItem = parseInt(stringItem);\n }\n\n return (\n <View\n key={item}\n style={styles.pickerItemContainer}\n testID=\"picker-item\">\n <Text\n allowFontScaling={allowFontScaling}\n style={[\n styles.pickerItem,\n intItem > adjustedLimited.max ||\n intItem < adjustedLimited.min\n ? styles.disabledPickerItem\n : {},\n ]}>\n {stringItem}\n </Text>\n {is12HourPicker ? (\n <View\n pointerEvents=\"none\"\n style={styles.pickerAmPmContainer}>\n <Text\n allowFontScaling={allowFontScaling}\n style={[styles.pickerAmPmLabel]}>\n {isAm ? amLabel : pmLabel}\n </Text>\n </View>\n ) : null}\n </View>\n );\n },\n [\n adjustedLimited.max,\n adjustedLimited.min,\n allowFontScaling,\n amLabel,\n is12HourPicker,\n pmLabel,\n styles.disabledPickerItem,\n styles.pickerAmPmContainer,\n styles.pickerAmPmLabel,\n styles.pickerItem,\n styles.pickerItemContainer,\n ]\n );\n\n const onScroll = useCallback(\n (e: NativeSyntheticEvent<NativeScrollEvent>) => {\n // this function is only used when the picker is in a modal and/or has Haptic/Audio feedback\n // it is used to ensure that the modal gets the latest duration on clicking\n // the confirm button, even if the scrollview is still scrolling\n if (!aggressivelyGetLatestDuration && !Haptics && !Audio) {\n return;\n }\n\n if (aggressivelyGetLatestDuration) {\n const newValues = getDurationAndIndexFromScrollOffset({\n disableInfiniteScroll,\n itemHeight: styles.pickerItemContainer.height,\n numberOfItems,\n padWithNItems,\n yContentOffset: e.nativeEvent.contentOffset.y,\n });\n\n if (newValues.duration !== latestDuration.current) {\n // check limits\n if (newValues.duration > adjustedLimited.max) {\n newValues.duration = adjustedLimited.max;\n } else if (newValues.duration < adjustedLimited.min) {\n newValues.duration = adjustedLimited.min;\n }\n\n latestDuration.current = newValues.duration;\n }\n }\n\n if (Haptics || Audio) {\n const feedbackIndex = Math.round(\n (e.nativeEvent.contentOffset.y +\n styles.pickerItemContainer.height / 2) /\n styles.pickerItemContainer.height\n );\n\n if (feedbackIndex !== lastFeedbackIndex.current) {\n // this check stops the feedback firing when the component mounts\n if (lastFeedbackIndex.current) {\n // fire haptic feedback if available\n try {\n Haptics?.selectionAsync();\n } catch {\n // do nothing\n }\n\n // play click sound if available\n try {\n clickSound?.replayAsync();\n } catch {\n // do nothing\n }\n }\n\n lastFeedbackIndex.current = feedbackIndex;\n }\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n adjustedLimited.max,\n adjustedLimited.min,\n aggressivelyGetLatestDuration,\n clickSound,\n disableInfiniteScroll,\n numberOfItems,\n padWithNItems,\n styles.pickerItemContainer.height,\n ]\n );\n\n const onMomentumScrollEnd = useCallback(\n (e: NativeSyntheticEvent<NativeScrollEvent>) => {\n const newValues = getDurationAndIndexFromScrollOffset({\n disableInfiniteScroll,\n itemHeight: styles.pickerItemContainer.height,\n numberOfItems,\n padWithNItems,\n yContentOffset: e.nativeEvent.contentOffset.y,\n });\n\n // check limits\n if (newValues.duration > adjustedLimited.max) {\n const targetScrollIndex =\n newValues.index -\n (newValues.duration - adjustedLimited.max);\n flatListRef.current?.scrollToIndex({\n animated: true,\n index:\n // guard against scrolling beyond end of list\n targetScrollIndex >= 0\n ? targetScrollIndex\n : adjustedLimited.max - 1,\n }); // scroll down to max\n newValues.duration = adjustedLimited.max;\n } else if (newValues.duration < adjustedLimited.min) {\n const targetScrollIndex =\n newValues.index +\n (adjustedLimited.min - newValues.duration);\n flatListRef.current?.scrollToIndex({\n animated: true,\n index:\n // guard against scrolling beyond end of list\n targetScrollIndex <= numbersForFlatList.length - 1\n ? targetScrollIndex\n : adjustedLimited.min,\n }); // scroll up to min\n newValues.duration = adjustedLimited.min;\n }\n\n onDurationChange(newValues.duration);\n },\n [\n adjustedLimited.max,\n adjustedLimited.min,\n numbersForFlatList.length,\n disableInfiniteScroll,\n numberOfItems,\n onDurationChange,\n padWithNItems,\n styles.pickerItemContainer.height,\n ]\n );\n\n const onViewableItemsChanged = useCallback(\n ({ viewableItems }: { viewableItems: ViewToken[] }) => {\n if (\n viewableItems[0]?.index &&\n viewableItems[0].index < numberOfItems * 0.5\n ) {\n flatListRef.current?.scrollToIndex({\n animated: false,\n index: viewableItems[0].index + numberOfItems,\n });\n } else if (\n viewableItems[0]?.index &&\n viewableItems[0].index >=\n numberOfItems * (safeRepeatNumbersNTimes - 0.5)\n ) {\n flatListRef.current?.scrollToIndex({\n animated: false,\n index: viewableItems[0].index - numberOfItems,\n });\n }\n },\n [numberOfItems, safeRepeatNumbersNTimes]\n );\n\n const getItemLayout = useCallback(\n (_: ArrayLike<string> | null | undefined, index: number) => ({\n length: styles.pickerItemContainer.height,\n offset: styles.pickerItemContainer.height * index,\n index,\n }),\n [styles.pickerItemContainer.height]\n );\n\n const viewabilityConfigCallbackPairs =\n useRef<ViewabilityConfigCallbackPairs>([\n {\n viewabilityConfig: { viewAreaCoveragePercentThreshold: 0 },\n onViewableItemsChanged: onViewableItemsChanged,\n },\n ]);\n\n useImperativeHandle(ref, () => ({\n reset: (options) => {\n flatListRef.current?.scrollToIndex({\n animated: options?.animated ?? false,\n index: initialScrollIndex,\n });\n },\n setValue: (value, options) => {\n flatListRef.current?.scrollToIndex({\n animated: options?.animated ?? false,\n index: getInitialScrollIndex({\n disableInfiniteScroll,\n numberOfItems,\n padWithNItems,\n repeatNumbersNTimes: safeRepeatNumbersNTimes,\n value: value,\n }),\n });\n },\n latestDuration: latestDuration,\n }));\n\n return (\n <View\n pointerEvents={isDisabled ? \"none\" : undefined}\n style={[\n {\n height:\n styles.pickerItemContainer.height *\n numberOfItemsToShow,\n overflow: \"visible\",\n },\n isDisabled && styles.disabledPickerContainer,\n ]}\n testID={testID}>\n <FlatList\n ref={flatListRef}\n data={numbersForFlatList}\n decelerationRate={0.88}\n getItemLayout={getItemLayout}\n initialScrollIndex={initialScrollIndex}\n keyExtractor={(_, index) => index.toString()}\n nestedScrollEnabled\n onMomentumScrollEnd={onMomentumScrollEnd}\n onScroll={onScroll}\n renderItem={renderItem}\n scrollEnabled={!isDisabled}\n scrollEventThrottle={16}\n showsVerticalScrollIndicator={false}\n snapToAlignment=\"start\"\n // used in place of snapToOffset due to bug on Android\n snapToOffsets={[...Array(numbersForFlatList.length)].map(\n (_, i) => i * styles.pickerItemContainer.height\n )}\n testID=\"duration-scroll-flatlist\"\n viewabilityConfigCallbackPairs={\n !disableInfiniteScroll\n ? viewabilityConfigCallbackPairs?.current\n : undefined\n }\n windowSize={numberOfItemsToShow}\n />\n <View pointerEvents=\"none\" style={styles.pickerLabelContainer}>\n {typeof label === \"string\" ? (\n <Text\n allowFontScaling={allowFontScaling}\n style={styles.pickerLabel}>\n {label}\n </Text>\n ) : (\n label ?? null\n )}\n </View>\n {LinearGradient ? (\n <>\n <LinearGradient\n colors={[\n styles.pickerContainer.backgroundColor ??\n \"white\",\n colorToRgba({\n color:\n styles.pickerContainer\n .backgroundColor ?? \"white\",\n opacity: 0,\n }),\n ]}\n end={{ x: 1, y: 1 }}\n pointerEvents=\"none\"\n start={{ x: 1, y: 0.3 }}\n {...pickerGradientOverlayProps}\n {...topPickerGradientOverlayProps}\n style={[styles.pickerGradientOverlay, { top: 0 }]}\n />\n <LinearGradient\n colors={[\n colorToRgba({\n color:\n styles.pickerContainer\n .backgroundColor ?? \"white\",\n opacity: 0,\n }),\n styles.pickerContainer.backgroundColor ??\n \"white\",\n ]}\n end={{ x: 1, y: 0.7 }}\n pointerEvents=\"none\"\n start={{ x: 1, y: 0 }}\n {...pickerGradientOverlayProps}\n {...bottomPickerGradientOverlayProps}\n style={[\n styles.pickerGradientOverlay,\n { bottom: -1 },\n ]}\n />\n </>\n ) : null}\n </View>\n );\n }\n);\n\nexport default React.memo(DurationScroll);\n"],"mappings":";AAAA,OAAOA,KAAK,IACRC,MAAM,EACNC,WAAW,EACXC,UAAU,EACVC,mBAAmB,EACnBC,QAAQ,EACRC,SAAS,EACTC,OAAO,QACJ,OAAO;AAEd,SAASC,IAAI,EAAEC,IAAI,EAAEC,QAAQ,IAAIC,UAAU,QAAQ,cAAc;AAQjE,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SACIC,qBAAqB,EACrBC,eAAe,QACZ,6BAA6B;AACpC,SAASC,gBAAgB,QAAQ,8BAA8B;AAC/D,SAASC,mCAAmC,QAAQ,iDAAiD;AACrG,SAASC,qBAAqB,QAAQ,mCAAmC;AAIzE,MAAMC,cAAc,gBAAGf,UAAU,CAC7B,CAACgB,KAAK,EAAEC,GAAG,KAAK;EACZ,MAAM;IACFC,6BAA6B;IAC7BC,gBAAgB,GAAG,KAAK;IACxBC,OAAO;IACPC,KAAK;IACLC,gCAAgC;IAChCC,eAAe;IACfC,qBAAqB,GAAG,KAAK;IAC7BjB,QAAQ,GAAGC,UAAU;IACrBiB,OAAO;IACPC,YAAY,GAAG,CAAC;IAChBC,cAAc;IACdC,UAAU;IACVC,KAAK;IACLC,KAAK;IACLC,cAAc;IACdC,aAAa;IACbC,gBAAgB;IAChBC,kBAAkB,GAAG,KAAK;IAC1BC,aAAa;IACbC,0BAA0B;IAC1BC,OAAO;IACPC,mBAAmB,GAAG,CAAC;IACvBC,MAAM;IACNC,MAAM;IACNC;EACJ,CAAC,GAAGzB,KAAK;EAET,MAAM0B,uBAAuB,GAAGtC,OAAO,CAAC,MAAM;IAC1C,IAAI,CAACoB,qBAAqB,IAAIc,mBAAmB,GAAG,CAAC,EAAE;MACnD,OAAO,CAAC;IACZ,CAAC,MAAM,IAAIA,mBAAmB,GAAG,CAAC,EAAE;MAChC,OAAO,CAAC;IACZ;IAEA,OAAOK,IAAI,CAACC,KAAK,CAACN,mBAAmB,CAAC;EAC1C,CAAC,EAAE,CAACd,qBAAqB,EAAEc,mBAAmB,CAAC,CAAC;EAEhD,MAAMO,kBAAkB,GAAGzC,OAAO,CAAC,MAAM;IACrC,IAAIuB,cAAc,EAAE;MAChB,OAAOjB,qBAAqB,CAAC;QACzBwB,kBAAkB;QAClBY,YAAY,EAAEJ,uBAAuB;QACrClB,qBAAqB;QACrBW;MACJ,CAAC,CAAC;IACN;IAEA,OAAOxB,eAAe,CAACqB,aAAa,EAAE;MAClCE,kBAAkB;MAClBY,YAAY,EAAEJ,uBAAuB;MACrClB,qBAAqB;MACrBW;IACJ,CAAC,CAAC;EACN,CAAC,EAAE,CACCX,qBAAqB,EACrBG,cAAc,EACdK,aAAa,EACbE,kBAAkB,EAClBC,aAAa,EACbO,uBAAuB,CAC1B,CAAC;EAEF,MAAMK,kBAAkB,GAAG3C,OAAO,CAC9B,MACIU,qBAAqB,CAAC;IAClBU,qBAAqB;IACrBQ,aAAa;IACbG,aAAa;IACbG,mBAAmB,EAAEI,uBAAuB;IAC5CM,KAAK,EAAEtB;EACX,CAAC,CAAC,EACN,CACIF,qBAAqB,EACrBE,YAAY,EACZM,aAAa,EACbG,aAAa,EACbO,uBAAuB,CAE/B,CAAC;EAED,MAAMO,eAAe,GAAG7C,OAAO,CAC3B,MAAMQ,gBAAgB,CAACkB,KAAK,EAAEE,aAAa,CAAC,EAC5C,CAACF,KAAK,EAAEE,aAAa,CACzB,CAAC;EAED,MAAMkB,mBAAmB,GAAG,CAAC,GAAGf,aAAa,GAAG,CAAC;;EAEjD;EACA,MAAMgB,cAAc,GAAGrD,MAAM,CAAC,CAAC,CAAC;EAChC;EACA,MAAMsD,iBAAiB,GAAGtD,MAAM,CAAC,CAAC,CAAC;EAEnC,MAAMuD,WAAW,GAAGvD,MAAM,CAAoB,IAAI,CAAC;EAEnD,MAAM,CAACwD,UAAU,EAAEC,aAAa,CAAC,GAAGrD,QAAQ,CAM1C,CAAC;;EAEH;EACAC,SAAS,CAAC,MAAM;IACZ,MAAMqD,SAAS,GAAG,MAAAA,CAAA,KAAY;MAC1B,IAAInC,KAAK,EAAE;QACP,MAAM;UAAEoC;QAAM,CAAC,GAAG,MAAMpC,KAAK,CAACqC,KAAK,CAACC,WAAW,CAC3CpC,eAAe,IAAI;UACf;UACA;UACAqC,GAAG,EAAE;QACT,CAAC,EACD;UAAEC,UAAU,EAAE;QAAM,CACxB,CAAC;QACDN,aAAa,CAACE,KAAK,CAAC;MACxB;IACJ,CAAC;IAEDD,SAAS,CAAC,CAAC;;IAEX;IACA,OAAO,MAAM;MACTF,UAAU,aAAVA,UAAU,eAAVA,UAAU,CAAEQ,WAAW,CAAC,CAAC;IAC7B,CAAC;IACD;EACJ,CAAC,EAAE,CAACzC,KAAK,CAAC,CAAC;EAEX,MAAM0C,UAAU,GAAGhE,WAAW,CAC1B,CAAC;IAAEiE;EAAuB,CAAC,KAAK;IAC5B,IAAIC,UAAU,GAAGD,IAAI;IACrB,IAAIE,OAAe;IACnB,IAAIC,IAAyB;IAE7B,IAAI,CAACxC,cAAc,EAAE;MACjBuC,OAAO,GAAGE,QAAQ,CAACJ,IAAI,CAAC;IAC5B,CAAC,MAAM;MACHG,IAAI,GAAGH,IAAI,CAACK,QAAQ,CAAC,IAAI,CAAC;MAC1BJ,UAAU,GAAGD,IAAI,CAACM,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;MACzCJ,OAAO,GAAGE,QAAQ,CAACH,UAAU,CAAC;IAClC;IAEA,oBACIpE,KAAA,CAAA0E,aAAA,CAAClE,IAAI;MACDmE,GAAG,EAAER,IAAK;MACVS,KAAK,EAAElC,MAAM,CAACmC,mBAAoB;MAClClC,MAAM,EAAC;IAAa,gBACpB3C,KAAA,CAAA0E,aAAA,CAACjE,IAAI;MACDa,gBAAgB,EAAEA,gBAAiB;MACnCsD,KAAK,EAAE,CACHlC,MAAM,CAACoC,UAAU,EACjBT,OAAO,GAAGjB,eAAe,CAAC2B,GAAG,IAC7BV,OAAO,GAAGjB,eAAe,CAAC4B,GAAG,GACvBtC,MAAM,CAACuC,kBAAkB,GACzB,CAAC,CAAC;IACV,GACDb,UACC,CAAC,EACNtC,cAAc,gBACX9B,KAAA,CAAA0E,aAAA,CAAClE,IAAI;MACD0E,aAAa,EAAC,MAAM;MACpBN,KAAK,EAAElC,MAAM,CAACyC;IAAoB,gBAClCnF,KAAA,CAAA0E,aAAA,CAACjE,IAAI;MACDa,gBAAgB,EAAEA,gBAAiB;MACnCsD,KAAK,EAAE,CAAClC,MAAM,CAAC0C,eAAe;IAAE,GAC/Bd,IAAI,GAAG/C,OAAO,GAAGiB,OAChB,CACJ,CAAC,GACP,IACF,CAAC;EAEf,CAAC,EACD,CACIY,eAAe,CAAC2B,GAAG,EACnB3B,eAAe,CAAC4B,GAAG,EACnB1D,gBAAgB,EAChBC,OAAO,EACPO,cAAc,EACdU,OAAO,EACPE,MAAM,CAACuC,kBAAkB,EACzBvC,MAAM,CAACyC,mBAAmB,EAC1BzC,MAAM,CAAC0C,eAAe,EACtB1C,MAAM,CAACoC,UAAU,EACjBpC,MAAM,CAACmC,mBAAmB,CAElC,CAAC;EAED,MAAMQ,QAAQ,GAAGnF,WAAW,CACvBoF,CAA0C,IAAK;IAC5C;IACA;IACA;IACA,IAAI,CAACjE,6BAA6B,IAAI,CAACO,OAAO,IAAI,CAACJ,KAAK,EAAE;MACtD;IACJ;IAEA,IAAIH,6BAA6B,EAAE;MAC/B,MAAMkE,SAAS,GAAGvE,mCAAmC,CAAC;QAClDW,qBAAqB;QACrB6D,UAAU,EAAE9C,MAAM,CAACmC,mBAAmB,CAACY,MAAM;QAC7CtD,aAAa;QACbG,aAAa;QACboD,cAAc,EAAEJ,CAAC,CAACK,WAAW,CAACC,aAAa,CAACC;MAChD,CAAC,CAAC;MAEF,IAAIN,SAAS,CAACO,QAAQ,KAAKxC,cAAc,CAACyC,OAAO,EAAE;QAC/C;QACA,IAAIR,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC2B,GAAG,EAAE;UAC1CQ,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC2B,GAAG;QAC5C,CAAC,MAAM,IAAIQ,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC4B,GAAG,EAAE;UACjDO,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC4B,GAAG;QAC5C;QAEA1B,cAAc,CAACyC,OAAO,GAAGR,SAAS,CAACO,QAAQ;MAC/C;IACJ;IAEA,IAAIlE,OAAO,IAAIJ,KAAK,EAAE;MAClB,MAAMwE,aAAa,GAAGlD,IAAI,CAACC,KAAK,CAC5B,CAACuC,CAAC,CAACK,WAAW,CAACC,aAAa,CAACC,CAAC,GAC1BnD,MAAM,CAACmC,mBAAmB,CAACY,MAAM,GAAG,CAAC,IACrC/C,MAAM,CAACmC,mBAAmB,CAACY,MACnC,CAAC;MAED,IAAIO,aAAa,KAAKzC,iBAAiB,CAACwC,OAAO,EAAE;QAC7C;QACA,IAAIxC,iBAAiB,CAACwC,OAAO,EAAE;UAC3B;UACA,IAAI;YACAnE,OAAO,aAAPA,OAAO,eAAPA,OAAO,CAAEqE,cAAc,CAAC,CAAC;UAC7B,CAAC,CAAC,MAAM;YACJ;UAAA;;UAGJ;UACA,IAAI;YACAxC,UAAU,aAAVA,UAAU,eAAVA,UAAU,CAAEyC,WAAW,CAAC,CAAC;UAC7B,CAAC,CAAC,MAAM;YACJ;UAAA;QAER;QAEA3C,iBAAiB,CAACwC,OAAO,GAAGC,aAAa;MAC7C;IACJ;EACJ,CAAC;EACD;EACA,CACI5C,eAAe,CAAC2B,GAAG,EACnB3B,eAAe,CAAC4B,GAAG,EACnB3D,6BAA6B,EAC7BoC,UAAU,EACV9B,qBAAqB,EACrBQ,aAAa,EACbG,aAAa,EACbI,MAAM,CAACmC,mBAAmB,CAACY,MAAM,CAEzC,CAAC;EAED,MAAMU,mBAAmB,GAAGjG,WAAW,CAClCoF,CAA0C,IAAK;IAC5C,MAAMC,SAAS,GAAGvE,mCAAmC,CAAC;MAClDW,qBAAqB;MACrB6D,UAAU,EAAE9C,MAAM,CAACmC,mBAAmB,CAACY,MAAM;MAC7CtD,aAAa;MACbG,aAAa;MACboD,cAAc,EAAEJ,CAAC,CAACK,WAAW,CAACC,aAAa,CAACC;IAChD,CAAC,CAAC;;IAEF;IACA,IAAIN,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC2B,GAAG,EAAE;MAAA,IAAAqB,oBAAA;MAC1C,MAAMC,iBAAiB,GACnBd,SAAS,CAACe,KAAK,IACdf,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC2B,GAAG,CAAC;MAC9C,CAAAqB,oBAAA,GAAA5C,WAAW,CAACuC,OAAO,cAAAK,oBAAA,eAAnBA,oBAAA,CAAqBG,aAAa,CAAC;QAC/BC,QAAQ,EAAE,IAAI;QACdF,KAAK;QACD;QACAD,iBAAiB,IAAI,CAAC,GAChBA,iBAAiB,GACjBjD,eAAe,CAAC2B,GAAG,GAAG;MACpC,CAAC,CAAC,CAAC,CAAC;MACJQ,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC2B,GAAG;IAC5C,CAAC,MAAM,IAAIQ,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC4B,GAAG,EAAE;MAAA,IAAAyB,qBAAA;MACjD,MAAMJ,iBAAiB,GACnBd,SAAS,CAACe,KAAK,IACdlD,eAAe,CAAC4B,GAAG,GAAGO,SAAS,CAACO,QAAQ,CAAC;MAC9C,CAAAW,qBAAA,GAAAjD,WAAW,CAACuC,OAAO,cAAAU,qBAAA,eAAnBA,qBAAA,CAAqBF,aAAa,CAAC;QAC/BC,QAAQ,EAAE,IAAI;QACdF,KAAK;QACD;QACAD,iBAAiB,IAAIrD,kBAAkB,CAAC0D,MAAM,GAAG,CAAC,GAC5CL,iBAAiB,GACjBjD,eAAe,CAAC4B;MAC9B,CAAC,CAAC,CAAC,CAAC;MACJO,SAAS,CAACO,QAAQ,GAAG1C,eAAe,CAAC4B,GAAG;IAC5C;IAEA5C,gBAAgB,CAACmD,SAAS,CAACO,QAAQ,CAAC;EACxC,CAAC,EACD,CACI1C,eAAe,CAAC2B,GAAG,EACnB3B,eAAe,CAAC4B,GAAG,EACnBhC,kBAAkB,CAAC0D,MAAM,EACzB/E,qBAAqB,EACrBQ,aAAa,EACbC,gBAAgB,EAChBE,aAAa,EACbI,MAAM,CAACmC,mBAAmB,CAACY,MAAM,CAEzC,CAAC;EAED,MAAMkB,sBAAsB,GAAGzG,WAAW,CACtC,CAAC;IAAE0G;EAA8C,CAAC,KAAK;IAAA,IAAAC,eAAA,EAAAC,gBAAA;IACnD,IACI,CAAAD,eAAA,GAAAD,aAAa,CAAC,CAAC,CAAC,cAAAC,eAAA,eAAhBA,eAAA,CAAkBP,KAAK,IACvBM,aAAa,CAAC,CAAC,CAAC,CAACN,KAAK,GAAGnE,aAAa,GAAG,GAAG,EAC9C;MAAA,IAAA4E,qBAAA;MACE,CAAAA,qBAAA,GAAAvD,WAAW,CAACuC,OAAO,cAAAgB,qBAAA,eAAnBA,qBAAA,CAAqBR,aAAa,CAAC;QAC/BC,QAAQ,EAAE,KAAK;QACfF,KAAK,EAAEM,aAAa,CAAC,CAAC,CAAC,CAACN,KAAK,GAAGnE;MACpC,CAAC,CAAC;IACN,CAAC,MAAM,IACH,CAAA2E,gBAAA,GAAAF,aAAa,CAAC,CAAC,CAAC,cAAAE,gBAAA,eAAhBA,gBAAA,CAAkBR,KAAK,IACvBM,aAAa,CAAC,CAAC,CAAC,CAACN,KAAK,IAClBnE,aAAa,IAAIU,uBAAuB,GAAG,GAAG,CAAC,EACrD;MAAA,IAAAmE,qBAAA;MACE,CAAAA,qBAAA,GAAAxD,WAAW,CAACuC,OAAO,cAAAiB,qBAAA,eAAnBA,qBAAA,CAAqBT,aAAa,CAAC;QAC/BC,QAAQ,EAAE,KAAK;QACfF,KAAK,EAAEM,aAAa,CAAC,CAAC,CAAC,CAACN,KAAK,GAAGnE;MACpC,CAAC,CAAC;IACN;EACJ,CAAC,EACD,CAACA,aAAa,EAAEU,uBAAuB,CAC3C,CAAC;EAED,MAAMoE,aAAa,GAAG/G,WAAW,CAC7B,CAACgH,CAAuC,EAAEZ,KAAa,MAAM;IACzDI,MAAM,EAAEhE,MAAM,CAACmC,mBAAmB,CAACY,MAAM;IACzC0B,MAAM,EAAEzE,MAAM,CAACmC,mBAAmB,CAACY,MAAM,GAAGa,KAAK;IACjDA;EACJ,CAAC,CAAC,EACF,CAAC5D,MAAM,CAACmC,mBAAmB,CAACY,MAAM,CACtC,CAAC;EAED,MAAM2B,8BAA8B,GAChCnH,MAAM,CAAiC,CACnC;IACIoH,iBAAiB,EAAE;MAAEC,gCAAgC,EAAE;IAAE,CAAC;IAC1DX,sBAAsB,EAAEA;EAC5B,CAAC,CACJ,CAAC;EAENvG,mBAAmB,CAACgB,GAAG,EAAE,OAAO;IAC5BmG,KAAK,EAAGC,OAAO,IAAK;MAAA,IAAAC,qBAAA;MAChB,CAAAA,qBAAA,GAAAjE,WAAW,CAACuC,OAAO,cAAA0B,qBAAA,eAAnBA,qBAAA,CAAqBlB,aAAa,CAAC;QAC/BC,QAAQ,EAAE,CAAAgB,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEhB,QAAQ,KAAI,KAAK;QACpCF,KAAK,EAAEpD;MACX,CAAC,CAAC;IACN,CAAC;IACDwE,QAAQ,EAAEA,CAACvE,KAAK,EAAEqE,OAAO,KAAK;MAAA,IAAAG,qBAAA;MAC1B,CAAAA,qBAAA,GAAAnE,WAAW,CAACuC,OAAO,cAAA4B,qBAAA,eAAnBA,qBAAA,CAAqBpB,aAAa,CAAC;QAC/BC,QAAQ,EAAE,CAAAgB,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEhB,QAAQ,KAAI,KAAK;QACpCF,KAAK,EAAErF,qBAAqB,CAAC;UACzBU,qBAAqB;UACrBQ,aAAa;UACbG,aAAa;UACbG,mBAAmB,EAAEI,uBAAuB;UAC5CM,KAAK,EAAEA;QACX,CAAC;MACL,CAAC,CAAC;IACN,CAAC;IACDG,cAAc,EAAEA;EACpB,CAAC,CAAC,CAAC;EAEH,oBACItD,KAAA,CAAA0E,aAAA,CAAClE,IAAI;IACD0E,aAAa,EAAEnD,UAAU,GAAG,MAAM,GAAG6F,SAAU;IAC/ChD,KAAK,EAAE,CACH;MACIa,MAAM,EACF/C,MAAM,CAACmC,mBAAmB,CAACY,MAAM,GACjCpC,mBAAmB;MACvBwE,QAAQ,EAAE;IACd,CAAC,EACD9F,UAAU,IAAIW,MAAM,CAACoF,uBAAuB,CAC9C;IACFnF,MAAM,EAAEA;EAAO,gBACf3C,KAAA,CAAA0E,aAAA,CAAChE,QAAQ;IACLU,GAAG,EAAEoC,WAAY;IACjBuE,IAAI,EAAE/E,kBAAmB;IACzBgF,gBAAgB,EAAE,IAAK;IACvBf,aAAa,EAAEA,aAAc;IAC7B/D,kBAAkB,EAAEA,kBAAmB;IACvC+E,YAAY,EAAEA,CAACf,CAAC,EAAEZ,KAAK,KAAKA,KAAK,CAAC4B,QAAQ,CAAC,CAAE;IAC7CC,mBAAmB;IACnBhC,mBAAmB,EAAEA,mBAAoB;IACzCd,QAAQ,EAAEA,QAAS;IACnBnB,UAAU,EAAEA,UAAW;IACvBkE,aAAa,EAAE,CAACrG,UAAW;IAC3BsG,mBAAmB,EAAE,EAAG;IACxBC,4BAA4B,EAAE,KAAM;IACpCC,eAAe,EAAC;IAChB;IAAA;IACAC,aAAa,EAAE,CAAC,GAAGC,KAAK,CAACzF,kBAAkB,CAAC0D,MAAM,CAAC,CAAC,CAACgC,GAAG,CACpD,CAACxB,CAAC,EAAEyB,CAAC,KAAKA,CAAC,GAAGjG,MAAM,CAACmC,mBAAmB,CAACY,MAC7C,CAAE;IACF9C,MAAM,EAAC,0BAA0B;IACjCyE,8BAA8B,EAC1B,CAACzF,qBAAqB,GAChByF,8BAA8B,aAA9BA,8BAA8B,uBAA9BA,8BAA8B,CAAErB,OAAO,GACvC6B,SACT;IACDgB,UAAU,EAAEvF;EAAoB,CACnC,CAAC,eACFrD,KAAA,CAAA0E,aAAA,CAAClE,IAAI;IAAC0E,aAAa,EAAC,MAAM;IAACN,KAAK,EAAElC,MAAM,CAACmG;EAAqB,GACzD,OAAO7G,KAAK,KAAK,QAAQ,gBACtBhC,KAAA,CAAA0E,aAAA,CAACjE,IAAI;IACDa,gBAAgB,EAAEA,gBAAiB;IACnCsD,KAAK,EAAElC,MAAM,CAACoG;EAAY,GACzB9G,KACC,CAAC,GAEPA,KAAK,IAAI,IAEX,CAAC,EACNE,cAAc,gBACXlC,KAAA,CAAA0E,aAAA,CAAA1E,KAAA,CAAA+I,QAAA,qBACI/I,KAAA,CAAA0E,aAAA,CAACxC,cAAc,EAAA8G,QAAA;IACXC,MAAM,EAAE,CACJvG,MAAM,CAACwG,eAAe,CAACC,eAAe,IAClC,OAAO,EACXvI,WAAW,CAAC;MACRwI,KAAK,EACD1G,MAAM,CAACwG,eAAe,CACjBC,eAAe,IAAI,OAAO;MACnCE,OAAO,EAAE;IACb,CAAC,CAAC,CACJ;IACFC,GAAG,EAAE;MAAEC,CAAC,EAAE,CAAC;MAAE1D,CAAC,EAAE;IAAE,CAAE;IACpBX,aAAa,EAAC,MAAM;IACpBsE,KAAK,EAAE;MAAED,CAAC,EAAE,CAAC;MAAE1D,CAAC,EAAE;IAAI;EAAE,GACpBtD,0BAA0B,EAC1BK,6BAA6B;IACjCgC,KAAK,EAAE,CAAClC,MAAM,CAAC+G,qBAAqB,EAAE;MAAEC,GAAG,EAAE;IAAE,CAAC;EAAE,EACrD,CAAC,eACF1J,KAAA,CAAA0E,aAAA,CAACxC,cAAc,EAAA8G,QAAA;IACXC,MAAM,EAAE,CACJrI,WAAW,CAAC;MACRwI,KAAK,EACD1G,MAAM,CAACwG,eAAe,CACjBC,eAAe,IAAI,OAAO;MACnCE,OAAO,EAAE;IACb,CAAC,CAAC,EACF3G,MAAM,CAACwG,eAAe,CAACC,eAAe,IAClC,OAAO,CACb;IACFG,GAAG,EAAE;MAAEC,CAAC,EAAE,CAAC;MAAE1D,CAAC,EAAE;IAAI,CAAE;IACtBX,aAAa,EAAC,MAAM;IACpBsE,KAAK,EAAE;MAAED,CAAC,EAAE,CAAC;MAAE1D,CAAC,EAAE;IAAE;EAAE,GAClBtD,0BAA0B,EAC1Bd,gCAAgC;IACpCmD,KAAK,EAAE,CACHlC,MAAM,CAAC+G,qBAAqB,EAC5B;MAAEE,MAAM,EAAE,CAAC;IAAE,CAAC;EAChB,EACL,CACH,CAAC,GACH,IACF,CAAC;AAEf,CACJ,CAAC;AAED,4BAAe3J,KAAK,CAAC4J,IAAI,CAAC1I,cAAc,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["React","useRef","useCallback","forwardRef","useImperativeHandle","useState","useEffect","useMemo","View","Text","FlatList","RNFlatList","colorToRgba","generate12HourNumbers","generateNumbers","getAdjustedLimit","getDurationAndIndexFromScrollOffset","getInitialScrollIndex","DurationScroll","props","ref","aggressivelyGetLatestDuration","allowFontScaling","amLabel","Audio","bottomPickerGradientOverlayProps","clickSoundAsset","disableInfiniteScroll","Haptics","initialValue","interval","is12HourPicker","isDisabled","label","limit","LinearGradient","maximumValue","onDurationChange","padNumbersWithZero","padWithNItems","pickerFeedback","pickerGradientOverlayProps","pmLabel","repeatNumbersNTimes","repeatNumbersNTimesNotExplicitlySet","styles","testID","topPickerGradientOverlayProps","numberOfItems","Math","floor","safeRepeatNumbersNTimes","isNaN","max","round","numbersForFlatList","repeatNTimes","initialScrollIndex","value","adjustedLimited","numberOfItemsToShow","latestDuration","lastFeedbackIndex","flatListRef","clickSound","setClickSound","loadSound","sound","Sound","createAsync","uri","shouldPlay","unloadAsync","renderItem","item","stringItem","intItem","isAm","parseInt","includes","replace","createElement","key","style","pickerItemContainer","pickerItem","min","disabledPickerItem","pointerEvents","pickerAmPmContainer","pickerAmPmLabel","onScroll","e","newValues","itemHeight","height","yContentOffset","nativeEvent","contentOffset","y","duration","current","feedbackIndex","selectionAsync","replayAsync","onMomentumScrollEnd","_flatListRef$current","targetScrollIndex","index","scrollToIndex","animated","_flatListRef$current2","length","onViewableItemsChanged","viewableItems","_viewableItems$","_viewableItems$2","_flatListRef$current3","_flatListRef$current4","viewabilityConfigCallbackPairs","setViewabilityConfigCallbackPairs","viewabilityConfig","viewAreaCoveragePercentThreshold","undefined","flatListRenderKey","setFlatListRenderKey","initialRender","prev","getItemLayout","_","offset","reset","options","_flatListRef$current5","setValue","_flatListRef$current6","overflow","disabledPickerContainer","data","decelerationRate","keyExtractor","toString","nestedScrollEnabled","scrollEnabled","scrollEventThrottle","showsVerticalScrollIndicator","snapToAlignment","snapToOffsets","Array","map","i","windowSize","pickerLabelContainer","pickerLabel","Fragment","_extends","colors","pickerContainer","backgroundColor","color","opacity","end","x","start","pickerGradientOverlay","top","bottom","memo"],"sources":["index.tsx"],"sourcesContent":["import React, {\n useRef,\n useCallback,\n forwardRef,\n useImperativeHandle,\n useState,\n useEffect,\n useMemo,\n} from \"react\";\n\nimport { View, Text, FlatList as RNFlatList } from \"react-native\";\nimport type {\n ViewabilityConfigCallbackPairs,\n ViewToken,\n NativeSyntheticEvent,\n NativeScrollEvent,\n} from \"react-native\";\n\nimport { colorToRgba } from \"../../utils/colorToRgba\";\nimport {\n generate12HourNumbers,\n generateNumbers,\n} from \"../../utils/generateNumbers\";\nimport { getAdjustedLimit } from \"../../utils/getAdjustedLimit\";\nimport { getDurationAndIndexFromScrollOffset } from \"../../utils/getDurationAndIndexFromScrollOffset\";\nimport { getInitialScrollIndex } from \"../../utils/getInitialScrollIndex\";\n\nimport type { DurationScrollProps, DurationScrollRef } from \"./types\";\n\nconst DurationScroll = forwardRef<DurationScrollRef, DurationScrollProps>(\n (props, ref) => {\n const {\n aggressivelyGetLatestDuration,\n allowFontScaling = false,\n amLabel,\n Audio,\n bottomPickerGradientOverlayProps,\n clickSoundAsset,\n disableInfiniteScroll = false,\n FlatList = RNFlatList,\n Haptics,\n initialValue = 0,\n interval,\n is12HourPicker,\n isDisabled,\n label,\n limit,\n LinearGradient,\n maximumValue,\n onDurationChange,\n padNumbersWithZero = false,\n padWithNItems,\n pickerFeedback,\n pickerGradientOverlayProps,\n pmLabel,\n repeatNumbersNTimes = 3,\n repeatNumbersNTimesNotExplicitlySet,\n styles,\n testID,\n topPickerGradientOverlayProps,\n } = props;\n\n const numberOfItems = useMemo(() => {\n // guard against negative maximum values\n if (maximumValue < 0) {\n return 1;\n }\n\n return Math.floor(maximumValue / interval) + 1;\n }, [interval, maximumValue]);\n\n const safeRepeatNumbersNTimes = useMemo(() => {\n // do not repeat numbers if there is only one option\n if (numberOfItems === 1) {\n return 1;\n }\n\n if (!disableInfiniteScroll && repeatNumbersNTimes < 2) {\n return 2;\n } else if (repeatNumbersNTimes < 1 || isNaN(repeatNumbersNTimes)) {\n return 1;\n }\n\n // if this variable is not explicitly set, we calculate a reasonable value based on\n // the number of items in the picker, avoiding regular jumps up/down the list\n // whilst avoiding rendering too many items in the picker\n if (repeatNumbersNTimesNotExplicitlySet) {\n return Math.max(Math.round(180 / numberOfItems), 1);\n }\n\n return Math.round(repeatNumbersNTimes);\n }, [\n disableInfiniteScroll,\n numberOfItems,\n repeatNumbersNTimes,\n repeatNumbersNTimesNotExplicitlySet,\n ]);\n\n const numbersForFlatList = useMemo(() => {\n if (is12HourPicker) {\n return generate12HourNumbers({\n padNumbersWithZero,\n repeatNTimes: safeRepeatNumbersNTimes,\n disableInfiniteScroll,\n padWithNItems,\n interval,\n });\n }\n\n return generateNumbers(numberOfItems, {\n padNumbersWithZero,\n repeatNTimes: safeRepeatNumbersNTimes,\n disableInfiniteScroll,\n padWithNItems,\n interval,\n });\n }, [\n disableInfiniteScroll,\n is12HourPicker,\n interval,\n numberOfItems,\n padNumbersWithZero,\n padWithNItems,\n safeRepeatNumbersNTimes,\n ]);\n\n const initialScrollIndex = useMemo(\n () =>\n getInitialScrollIndex({\n disableInfiniteScroll,\n interval,\n numberOfItems,\n padWithNItems,\n repeatNumbersNTimes: safeRepeatNumbersNTimes,\n value: initialValue,\n }),\n [\n disableInfiniteScroll,\n initialValue,\n interval,\n numberOfItems,\n padWithNItems,\n safeRepeatNumbersNTimes,\n ]\n );\n\n const adjustedLimited = useMemo(\n () => getAdjustedLimit(limit, numberOfItems, interval),\n [interval, limit, numberOfItems]\n );\n\n const numberOfItemsToShow = 1 + padWithNItems * 2;\n\n // keep track of the latest duration as it scrolls\n const latestDuration = useRef(0);\n // keep track of the last index scrolled past for haptic/audio feedback\n const lastFeedbackIndex = useRef(0);\n\n const flatListRef = useRef<RNFlatList | null>(null);\n\n const [clickSound, setClickSound] = useState<\n | {\n replayAsync: () => Promise<void>;\n unloadAsync: () => Promise<void>;\n }\n | undefined\n >();\n\n // Preload the sound when the component mounts\n useEffect(() => {\n const loadSound = async () => {\n if (Audio) {\n const { sound } = await Audio.Sound.createAsync(\n clickSoundAsset ?? {\n // use a hosted sound as a fallback (do not use local asset due to loader issues\n // in some environments when including mp3 in library)\n uri: \"https://drive.google.com/uc?export=download&id=10e1YkbNsRh-vGx1jmS1Nntz8xzkBp4_I\",\n },\n { shouldPlay: false }\n );\n setClickSound(sound);\n }\n };\n\n loadSound();\n\n // Unload sound when component unmounts\n return () => {\n clickSound?.unloadAsync();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [Audio]);\n\n const renderItem = useCallback(\n ({ item }: { item: string }) => {\n let stringItem = item;\n let intItem: number;\n let isAm: boolean | undefined;\n\n if (!is12HourPicker) {\n intItem = parseInt(item);\n } else {\n isAm = item.includes(\"AM\");\n stringItem = item.replace(/\\s[AP]M/g, \"\");\n intItem = parseInt(stringItem);\n }\n\n return (\n <View\n key={item}\n style={styles.pickerItemContainer}\n testID=\"picker-item\">\n <Text\n allowFontScaling={allowFontScaling}\n style={[\n styles.pickerItem,\n intItem > adjustedLimited.max ||\n intItem < adjustedLimited.min\n ? styles.disabledPickerItem\n : {},\n ]}>\n {stringItem}\n </Text>\n {is12HourPicker ? (\n <View\n pointerEvents=\"none\"\n style={styles.pickerAmPmContainer}>\n <Text\n allowFontScaling={allowFontScaling}\n style={[styles.pickerAmPmLabel]}>\n {isAm ? amLabel : pmLabel}\n </Text>\n </View>\n ) : null}\n </View>\n );\n },\n [\n adjustedLimited.max,\n adjustedLimited.min,\n allowFontScaling,\n amLabel,\n is12HourPicker,\n pmLabel,\n styles.disabledPickerItem,\n styles.pickerAmPmContainer,\n styles.pickerAmPmLabel,\n styles.pickerItem,\n styles.pickerItemContainer,\n ]\n );\n\n const onScroll = useCallback(\n (e: NativeSyntheticEvent<NativeScrollEvent>) => {\n // this function is only used when the picker is in a modal and/or has Haptic/Audio feedback\n // it is used to ensure that the modal gets the latest duration on clicking\n // the confirm button, even if the scrollview is still scrolling\n if (\n !aggressivelyGetLatestDuration &&\n !Haptics &&\n !Audio &&\n !pickerFeedback\n ) {\n return;\n }\n\n if (aggressivelyGetLatestDuration) {\n const newValues = getDurationAndIndexFromScrollOffset({\n disableInfiniteScroll,\n interval,\n itemHeight: styles.pickerItemContainer.height,\n numberOfItems,\n padWithNItems,\n yContentOffset: e.nativeEvent.contentOffset.y,\n });\n\n if (newValues.duration !== latestDuration.current) {\n // check limits\n if (newValues.duration > adjustedLimited.max) {\n newValues.duration = adjustedLimited.max;\n } else if (newValues.duration < adjustedLimited.min) {\n newValues.duration = adjustedLimited.min;\n }\n\n latestDuration.current = newValues.duration;\n }\n }\n\n if (Haptics || Audio || pickerFeedback) {\n const feedbackIndex = Math.round(\n (e.nativeEvent.contentOffset.y +\n styles.pickerItemContainer.height / 2) /\n styles.pickerItemContainer.height\n );\n\n if (feedbackIndex !== lastFeedbackIndex.current) {\n // this check stops the feedback firing when the component mounts\n if (lastFeedbackIndex.current) {\n // fire haptic feedback if available\n try {\n Haptics?.selectionAsync();\n } catch {\n // do nothing\n }\n\n // play click sound if available\n try {\n clickSound?.replayAsync();\n } catch {\n // do nothing\n }\n\n // fire custom feedback if available\n try {\n pickerFeedback?.();\n } catch {\n // do nothing\n }\n }\n\n lastFeedbackIndex.current = feedbackIndex;\n }\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n adjustedLimited.max,\n adjustedLimited.min,\n aggressivelyGetLatestDuration,\n clickSound,\n disableInfiniteScroll,\n interval,\n numberOfItems,\n padWithNItems,\n styles.pickerItemContainer.height,\n ]\n );\n\n const onMomentumScrollEnd = useCallback(\n (e: NativeSyntheticEvent<NativeScrollEvent>) => {\n const newValues = getDurationAndIndexFromScrollOffset({\n disableInfiniteScroll,\n interval,\n itemHeight: styles.pickerItemContainer.height,\n numberOfItems,\n padWithNItems,\n yContentOffset: e.nativeEvent.contentOffset.y,\n });\n\n // check limits\n if (newValues.duration > adjustedLimited.max) {\n const targetScrollIndex =\n newValues.index -\n (newValues.duration - adjustedLimited.max);\n flatListRef.current?.scrollToIndex({\n animated: true,\n index:\n // guard against scrolling beyond end of list\n targetScrollIndex >= 0\n ? targetScrollIndex\n : adjustedLimited.max - 1,\n }); // scroll down to max\n newValues.duration = adjustedLimited.max;\n } else if (newValues.duration < adjustedLimited.min) {\n const targetScrollIndex =\n newValues.index +\n (adjustedLimited.min - newValues.duration);\n flatListRef.current?.scrollToIndex({\n animated: true,\n index:\n // guard against scrolling beyond end of list\n targetScrollIndex <= numbersForFlatList.length - 1\n ? targetScrollIndex\n : adjustedLimited.min,\n }); // scroll up to min\n newValues.duration = adjustedLimited.min;\n }\n\n onDurationChange(newValues.duration);\n },\n [\n disableInfiniteScroll,\n interval,\n styles.pickerItemContainer.height,\n numberOfItems,\n padWithNItems,\n adjustedLimited.max,\n adjustedLimited.min,\n onDurationChange,\n numbersForFlatList.length,\n ]\n );\n\n const onViewableItemsChanged = useCallback(\n ({ viewableItems }: { viewableItems: ViewToken[] }) => {\n if (numberOfItems === 1) {\n return;\n }\n\n if (\n viewableItems[0]?.index &&\n viewableItems[0].index < numberOfItems * 0.5\n ) {\n flatListRef.current?.scrollToIndex({\n animated: false,\n index: viewableItems[0].index + numberOfItems,\n });\n } else if (\n viewableItems[0]?.index &&\n viewableItems[0].index >=\n numberOfItems * (safeRepeatNumbersNTimes - 0.5)\n ) {\n flatListRef.current?.scrollToIndex({\n animated: false,\n index: viewableItems[0].index - numberOfItems,\n });\n }\n },\n [numberOfItems, safeRepeatNumbersNTimes]\n );\n\n const [\n viewabilityConfigCallbackPairs,\n setViewabilityConfigCallbackPairs,\n ] = useState<ViewabilityConfigCallbackPairs | undefined>(\n !disableInfiniteScroll\n ? [\n {\n viewabilityConfig: {\n viewAreaCoveragePercentThreshold: 0,\n },\n onViewableItemsChanged: onViewableItemsChanged,\n },\n ]\n : undefined\n );\n\n const [flatListRenderKey, setFlatListRenderKey] = useState(0);\n\n const initialRender = useRef(true);\n\n useEffect(() => {\n // don't run on first render\n if (initialRender.current) {\n initialRender.current = false;\n return;\n }\n\n // if the onViewableItemsChanged callback changes, we need to update viewabilityConfigCallbackPairs\n // which requires the FlatList to be remounted, hence the increase of the FlatList key\n setFlatListRenderKey((prev) => prev + 1);\n setViewabilityConfigCallbackPairs(\n !disableInfiniteScroll\n ? [\n {\n viewabilityConfig: {\n viewAreaCoveragePercentThreshold: 0,\n },\n onViewableItemsChanged: onViewableItemsChanged,\n },\n ]\n : undefined\n );\n }, [disableInfiniteScroll, onViewableItemsChanged]);\n\n const getItemLayout = useCallback(\n (_: ArrayLike<string> | null | undefined, index: number) => ({\n length: styles.pickerItemContainer.height,\n offset: styles.pickerItemContainer.height * index,\n index,\n }),\n [styles.pickerItemContainer.height]\n );\n\n useImperativeHandle(ref, () => ({\n reset: (options) => {\n flatListRef.current?.scrollToIndex({\n animated: options?.animated ?? false,\n index: initialScrollIndex,\n });\n },\n setValue: (value, options) => {\n flatListRef.current?.scrollToIndex({\n animated: options?.animated ?? false,\n index: getInitialScrollIndex({\n disableInfiniteScroll,\n interval,\n numberOfItems,\n padWithNItems,\n repeatNumbersNTimes: safeRepeatNumbersNTimes,\n value: value,\n }),\n });\n },\n latestDuration: latestDuration,\n }));\n\n return (\n <View\n pointerEvents={isDisabled ? \"none\" : undefined}\n style={[\n {\n height:\n styles.pickerItemContainer.height *\n numberOfItemsToShow,\n overflow: \"visible\",\n },\n isDisabled && styles.disabledPickerContainer,\n ]}\n testID={testID}>\n <FlatList\n key={flatListRenderKey}\n ref={flatListRef}\n data={numbersForFlatList}\n decelerationRate={0.88}\n getItemLayout={getItemLayout}\n initialScrollIndex={initialScrollIndex}\n keyExtractor={(_, index) => index.toString()}\n nestedScrollEnabled\n onMomentumScrollEnd={onMomentumScrollEnd}\n onScroll={onScroll}\n renderItem={renderItem}\n scrollEnabled={!isDisabled}\n scrollEventThrottle={16}\n showsVerticalScrollIndicator={false}\n snapToAlignment=\"start\"\n // used in place of snapToInterval due to bug on Android\n snapToOffsets={[...Array(numbersForFlatList.length)].map(\n (_, i) => i * styles.pickerItemContainer.height\n )}\n testID=\"duration-scroll-flatlist\"\n viewabilityConfigCallbackPairs={\n viewabilityConfigCallbackPairs\n }\n windowSize={numberOfItemsToShow}\n />\n <View pointerEvents=\"none\" style={styles.pickerLabelContainer}>\n {typeof label === \"string\" ? (\n <Text\n allowFontScaling={allowFontScaling}\n style={styles.pickerLabel}>\n {label}\n </Text>\n ) : (\n label ?? null\n )}\n </View>\n {LinearGradient ? (\n <>\n <LinearGradient\n colors={[\n styles.pickerContainer.backgroundColor ??\n \"white\",\n colorToRgba({\n color:\n styles.pickerContainer\n .backgroundColor ?? \"white\",\n opacity: 0,\n }),\n ]}\n end={{ x: 1, y: 1 }}\n pointerEvents=\"none\"\n start={{ x: 1, y: 0.3 }}\n {...pickerGradientOverlayProps}\n {...topPickerGradientOverlayProps}\n style={[styles.pickerGradientOverlay, { top: 0 }]}\n />\n <LinearGradient\n colors={[\n colorToRgba({\n color:\n styles.pickerContainer\n .backgroundColor ?? \"white\",\n opacity: 0,\n }),\n styles.pickerContainer.backgroundColor ??\n \"white\",\n ]}\n end={{ x: 1, y: 0.7 }}\n pointerEvents=\"none\"\n start={{ x: 1, y: 0 }}\n {...pickerGradientOverlayProps}\n {...bottomPickerGradientOverlayProps}\n style={[\n styles.pickerGradientOverlay,\n { bottom: -1 },\n ]}\n />\n </>\n ) : null}\n </View>\n );\n }\n);\n\nexport default React.memo(DurationScroll);\n"],"mappings":"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","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { MutableRefObject } from \"react\";\n\nimport type {\n View,\n FlatList as RNFlatList,\n FlatListProps as RNFlatListProps,\n} from \"react-native\";\n\nimport type { generateStyles } from \"../TimerPicker/styles\";\n\nexport type CustomFlatList = <ItemT = any>(\n props: React.PropsWithChildren<\n RNFlatListProps<ItemT> & React.RefAttributes<RNFlatList<ItemT>>\n >,\n ref: React.ForwardedRef<RNFlatList<ItemT>>\n) => React.ReactElement | null;\n\nexport interface DurationScrollProps {\n Audio?: any;\n FlatList?: CustomFlatList;\n Haptics?: any;\n LinearGradient?: any;\n aggressivelyGetLatestDuration: boolean;\n allowFontScaling?: boolean;\n amLabel?: string;\n bottomPickerGradientOverlayProps?: Partial<LinearGradientProps>;\n clickSoundAsset?: SoundAssetType;\n disableInfiniteScroll?: boolean;\n initialValue?: number;\n is12HourPicker?: boolean;\n isDisabled?: boolean;\n label?: string | React.ReactElement;\n limit?: LimitType;\n numberOfItems: number;\n onDurationChange: (duration: number) => void;\n padNumbersWithZero?: boolean;\n padWithNItems: number;\n pickerGradientOverlayProps?: Partial<LinearGradientProps>;\n pmLabel?: string;\n repeatNumbersNTimes?: number;\n styles: ReturnType<typeof generateStyles>;\n testID?: string;\n topPickerGradientOverlayProps?: Partial<LinearGradientProps>;\n}\n\nexport interface DurationScrollRef {\n latestDuration: MutableRefObject<number>;\n reset: (options?: { animated?: boolean }) => void;\n setValue: (value: number, options?: { animated?: boolean }) => void;\n}\n\ntype LinearGradientPoint = {\n x: number;\n y: number;\n};\n\nexport type LinearGradientProps = React.ComponentProps<typeof View> & {\n colors: string[];\n end?: LinearGradientPoint | null;\n locations?: number[] | null;\n start?: LinearGradientPoint | null;\n};\n\nexport type LimitType = {\n max?: number;\n min?: number;\n};\n\nexport type SoundAssetType =\n | number\n | {\n headers?: Record<string, string>;\n overrideFileExtensionAndroid?: string;\n uri: string;\n };\n"],"mappings":"","ignoreList":[]}
1
+ {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { MutableRefObject } from \"react\";\n\nimport type {\n View,\n FlatList as RNFlatList,\n FlatListProps as RNFlatListProps,\n} from \"react-native\";\n\nimport type { generateStyles } from \"../TimerPicker/styles\";\n\nexport type CustomFlatList = <ItemT = any>(\n props: React.PropsWithChildren<\n RNFlatListProps<ItemT> & React.RefAttributes<RNFlatList<ItemT>>\n >,\n ref: React.ForwardedRef<RNFlatList<ItemT>>\n) => React.ReactElement | null;\n\nexport interface DurationScrollProps {\n Audio?: any;\n FlatList?: CustomFlatList;\n Haptics?: any;\n LinearGradient?: any;\n aggressivelyGetLatestDuration: boolean;\n allowFontScaling?: boolean;\n amLabel?: string;\n bottomPickerGradientOverlayProps?: Partial<LinearGradientProps>;\n clickSoundAsset?: SoundAssetType;\n disableInfiniteScroll?: boolean;\n initialValue?: number;\n interval: number;\n is12HourPicker?: boolean;\n isDisabled?: boolean;\n label?: string | React.ReactElement;\n limit?: LimitType;\n maximumValue: number;\n onDurationChange: (duration: number) => void;\n padNumbersWithZero?: boolean;\n padWithNItems: number;\n pickerFeedback?: () => void | Promise<void>;\n pickerGradientOverlayProps?: Partial<LinearGradientProps>;\n pmLabel?: string;\n repeatNumbersNTimes?: number;\n repeatNumbersNTimesNotExplicitlySet: boolean;\n styles: ReturnType<typeof generateStyles>;\n testID?: string;\n topPickerGradientOverlayProps?: Partial<LinearGradientProps>;\n}\n\nexport interface DurationScrollRef {\n latestDuration: MutableRefObject<number>;\n reset: (options?: { animated?: boolean }) => void;\n setValue: (value: number, options?: { animated?: boolean }) => void;\n}\n\ntype LinearGradientPoint = {\n x: number;\n y: number;\n};\n\nexport type LinearGradientProps = React.ComponentProps<typeof View> & {\n colors: string[];\n end?: LinearGradientPoint | null;\n locations?: number[] | null;\n start?: LinearGradientPoint | null;\n};\n\nexport type LimitType = {\n max?: number;\n min?: number;\n};\n\nexport type SoundAssetType =\n | number\n | {\n headers?: Record<string, string>;\n overrideFileExtensionAndroid?: string;\n uri: string;\n };\n"],"mappings":"","ignoreList":[]}
@@ -1,6 +1,7 @@
1
1
  function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
2
2
  import React, { forwardRef, useEffect, useImperativeHandle, useMemo, useRef, useState } from "react";
3
3
  import { View } from "react-native";
4
+ import { getSafeInitialValue } from "../../utils/getSafeInitialValue";
4
5
  import DurationScroll from "../DurationScroll";
5
6
  import { generateStyles } from "./styles";
6
7
  const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
@@ -12,10 +13,15 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
12
13
  hideHours = false,
13
14
  hideMinutes = false,
14
15
  hideSeconds = false,
16
+ hourInterval = 1,
15
17
  hourLabel,
16
18
  hourLimit,
17
19
  hoursPickerIsDisabled = false,
18
20
  initialValue,
21
+ maximumHours = 23,
22
+ maximumMinutes = 59,
23
+ maximumSeconds = 59,
24
+ minuteInterval = 1,
19
25
  minuteLabel,
20
26
  minuteLimit,
21
27
  minutesPickerIsDisabled = false,
@@ -26,9 +32,10 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
26
32
  padWithNItems = 1,
27
33
  pickerContainerProps,
28
34
  pmLabel = "pm",
29
- repeatHourNumbersNTimes = 7,
35
+ repeatHourNumbersNTimes = 8,
30
36
  repeatMinuteNumbersNTimes = 3,
31
37
  repeatSecondNumbersNTimes = 3,
38
+ secondInterval = 1,
32
39
  secondLabel,
33
40
  secondLimit,
34
41
  secondsPickerIsDisabled = false,
@@ -37,7 +44,7 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
37
44
  ...otherProps
38
45
  } = props;
39
46
  const safePadWithNItems = useMemo(() => {
40
- if (padWithNItems < 0) {
47
+ if (padWithNItems < 0 || isNaN(padWithNItems)) {
41
48
  return 0;
42
49
  }
43
50
  const maxPadWithNItems = hideHours ? 15 : 6;
@@ -46,14 +53,14 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
46
53
  }
47
54
  return Math.round(padWithNItems);
48
55
  }, [hideHours, padWithNItems]);
56
+ const safeInitialValue = useMemo(() => getSafeInitialValue({
57
+ hours: initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours,
58
+ minutes: initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes,
59
+ seconds: initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds
60
+ }), [initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours, initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes, initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds]);
49
61
  const styles = useMemo(() => generateStyles(customStyles, {
50
62
  padWithNItems: safePadWithNItems
51
63
  }), [safePadWithNItems, customStyles]);
52
- const safeInitialValue = useMemo(() => ({
53
- hours: (initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours) ?? 0,
54
- minutes: (initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes) ?? 0,
55
- seconds: (initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds) ?? 0
56
- }), [initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours, initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes, initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds]);
57
64
  const [selectedHours, setSelectedHours] = useState(safeInitialValue.hours);
58
65
  const [selectedMinutes, setSelectedMinutes] = useState(safeInitialValue.minutes);
59
66
  const [selectedSeconds, setSelectedSeconds] = useState(safeInitialValue.seconds);
@@ -106,16 +113,18 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
106
113
  amLabel: amLabel,
107
114
  disableInfiniteScroll: disableInfiniteScroll,
108
115
  initialValue: safeInitialValue.hours,
116
+ interval: hourInterval,
109
117
  is12HourPicker: use12HourPicker,
110
118
  isDisabled: hoursPickerIsDisabled,
111
119
  label: hourLabel ?? (!use12HourPicker ? "h" : undefined),
112
120
  limit: hourLimit,
113
- numberOfItems: 24,
121
+ maximumValue: maximumHours,
114
122
  onDurationChange: setSelectedHours,
115
123
  padNumbersWithZero: padHoursWithZero,
116
124
  padWithNItems: safePadWithNItems,
117
125
  pmLabel: pmLabel,
118
126
  repeatNumbersNTimes: repeatHourNumbersNTimes,
127
+ repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatHourNumbersNTimes) === undefined,
119
128
  styles: styles,
120
129
  testID: "duration-scroll-hour"
121
130
  }, otherProps)) : null, !hideMinutes ? /*#__PURE__*/React.createElement(DurationScroll, _extends({
@@ -124,14 +133,16 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
124
133
  allowFontScaling: allowFontScaling,
125
134
  disableInfiniteScroll: disableInfiniteScroll,
126
135
  initialValue: safeInitialValue.minutes,
136
+ interval: minuteInterval,
127
137
  isDisabled: minutesPickerIsDisabled,
128
138
  label: minuteLabel ?? "m",
129
139
  limit: minuteLimit,
130
- numberOfItems: 60,
140
+ maximumValue: maximumMinutes,
131
141
  onDurationChange: setSelectedMinutes,
132
142
  padNumbersWithZero: padMinutesWithZero,
133
143
  padWithNItems: safePadWithNItems,
134
144
  repeatNumbersNTimes: repeatMinuteNumbersNTimes,
145
+ repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatMinuteNumbersNTimes) === undefined,
135
146
  styles: styles,
136
147
  testID: "duration-scroll-minute"
137
148
  }, otherProps)) : null, !hideSeconds ? /*#__PURE__*/React.createElement(DurationScroll, _extends({
@@ -140,14 +151,16 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
140
151
  allowFontScaling: allowFontScaling,
141
152
  disableInfiniteScroll: disableInfiniteScroll,
142
153
  initialValue: safeInitialValue.seconds,
154
+ interval: secondInterval,
143
155
  isDisabled: secondsPickerIsDisabled,
144
156
  label: secondLabel ?? "s",
145
157
  limit: secondLimit,
146
- numberOfItems: 60,
158
+ maximumValue: maximumSeconds,
147
159
  onDurationChange: setSelectedSeconds,
148
160
  padNumbersWithZero: padSecondsWithZero,
149
161
  padWithNItems: safePadWithNItems,
150
162
  repeatNumbersNTimes: repeatSecondNumbersNTimes,
163
+ repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatSecondNumbersNTimes) === undefined,
151
164
  styles: styles,
152
165
  testID: "duration-scroll-second"
153
166
  }, otherProps)) : null);