react-native-timer-picker 2.4.0 → 2.6.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/README.md +35 -25
- package/package.json +143 -126
- package/dist/commonjs/components/DurationScroll/DurationScroll.js +0 -403
- package/dist/commonjs/components/DurationScroll/DurationScroll.js.map +0 -1
- package/dist/commonjs/components/DurationScroll/index.js +0 -27
- package/dist/commonjs/components/DurationScroll/index.js.map +0 -1
- package/dist/commonjs/components/DurationScroll/types.js +0 -6
- package/dist/commonjs/components/DurationScroll/types.js.map +0 -1
- package/dist/commonjs/components/Modal/Modal.js +0 -107
- package/dist/commonjs/components/Modal/Modal.js.map +0 -1
- package/dist/commonjs/components/Modal/index.js +0 -27
- package/dist/commonjs/components/Modal/index.js.map +0 -1
- package/dist/commonjs/components/Modal/styles.js +0 -25
- package/dist/commonjs/components/Modal/styles.js.map +0 -1
- package/dist/commonjs/components/Modal/types.js +0 -6
- package/dist/commonjs/components/Modal/types.js.map +0 -1
- package/dist/commonjs/components/PickerItem/PickerItem.js +0 -45
- package/dist/commonjs/components/PickerItem/PickerItem.js.map +0 -1
- package/dist/commonjs/components/PickerItem/index.js +0 -14
- package/dist/commonjs/components/PickerItem/index.js.map +0 -1
- package/dist/commonjs/components/TimerPicker/TimerPicker.js +0 -236
- package/dist/commonjs/components/TimerPicker/TimerPicker.js.map +0 -1
- package/dist/commonjs/components/TimerPicker/index.js +0 -39
- package/dist/commonjs/components/TimerPicker/index.js.map +0 -1
- package/dist/commonjs/components/TimerPicker/styles.js +0 -121
- package/dist/commonjs/components/TimerPicker/styles.js.map +0 -1
- package/dist/commonjs/components/TimerPicker/types.js +0 -6
- package/dist/commonjs/components/TimerPicker/types.js.map +0 -1
- package/dist/commonjs/components/TimerPickerModal/TimerPickerModal.js +0 -153
- package/dist/commonjs/components/TimerPickerModal/TimerPickerModal.js.map +0 -1
- package/dist/commonjs/components/TimerPickerModal/index.js +0 -39
- package/dist/commonjs/components/TimerPickerModal/index.js.map +0 -1
- package/dist/commonjs/components/TimerPickerModal/styles.js +0 -89
- package/dist/commonjs/components/TimerPickerModal/styles.js.map +0 -1
- package/dist/commonjs/components/TimerPickerModal/types.js +0 -6
- package/dist/commonjs/components/TimerPickerModal/types.js.map +0 -1
- package/dist/commonjs/index.js +0 -57
- package/dist/commonjs/index.js.map +0 -1
- package/dist/commonjs/tests/DurationScroll.test.js +0 -163
- package/dist/commonjs/tests/DurationScroll.test.js.map +0 -1
- package/dist/commonjs/tests/Modal.test.js +0 -119
- package/dist/commonjs/tests/Modal.test.js.map +0 -1
- package/dist/commonjs/tests/TimerPicker.test.js +0 -169
- package/dist/commonjs/tests/TimerPicker.test.js.map +0 -1
- package/dist/commonjs/tests/TimerPickerModal.test.js +0 -276
- package/dist/commonjs/tests/TimerPickerModal.test.js.map +0 -1
- package/dist/commonjs/tests/colorToRgba.test.js +0 -176
- package/dist/commonjs/tests/colorToRgba.test.js.map +0 -1
- package/dist/commonjs/tests/generateNumbers.test.js +0 -350
- package/dist/commonjs/tests/generateNumbers.test.js.map +0 -1
- package/dist/commonjs/tests/getAdjustedLimit.test.js +0 -324
- package/dist/commonjs/tests/getAdjustedLimit.test.js.map +0 -1
- package/dist/commonjs/tests/getDurationAndIndexFromScrollOffset.test.js +0 -424
- package/dist/commonjs/tests/getDurationAndIndexFromScrollOffset.test.js.map +0 -1
- package/dist/commonjs/tests/getInitialScrollIndex.test.js +0 -396
- package/dist/commonjs/tests/getInitialScrollIndex.test.js.map +0 -1
- package/dist/commonjs/tests/getSafeInitialValue.test.js +0 -497
- package/dist/commonjs/tests/getSafeInitialValue.test.js.map +0 -1
- package/dist/commonjs/tests/padNumber.test.js +0 -301
- package/dist/commonjs/tests/padNumber.test.js.map +0 -1
- package/dist/commonjs/utils/colorToRgba.js +0 -87
- package/dist/commonjs/utils/colorToRgba.js.map +0 -1
- package/dist/commonjs/utils/generateNumbers.js +0 -124
- package/dist/commonjs/utils/generateNumbers.js.map +0 -1
- package/dist/commonjs/utils/getAdjustedLimit.js +0 -58
- package/dist/commonjs/utils/getAdjustedLimit.js.map +0 -1
- package/dist/commonjs/utils/getDurationAndIndexFromScrollOffset.js +0 -62
- package/dist/commonjs/utils/getDurationAndIndexFromScrollOffset.js.map +0 -1
- package/dist/commonjs/utils/getInitialScrollIndex.js +0 -57
- package/dist/commonjs/utils/getInitialScrollIndex.js.map +0 -1
- package/dist/commonjs/utils/getSafeInitialValue.js +0 -41
- package/dist/commonjs/utils/getSafeInitialValue.js.map +0 -1
- package/dist/commonjs/utils/padNumber.js +0 -40
- package/dist/commonjs/utils/padNumber.js.map +0 -1
- package/dist/module/components/DurationScroll/DurationScroll.js +0 -395
- package/dist/module/components/DurationScroll/DurationScroll.js.map +0 -1
- package/dist/module/components/DurationScroll/index.js +0 -3
- package/dist/module/components/DurationScroll/index.js.map +0 -1
- package/dist/module/components/DurationScroll/types.js +0 -2
- package/dist/module/components/DurationScroll/types.js.map +0 -1
- package/dist/module/components/Modal/Modal.js +0 -99
- package/dist/module/components/Modal/Modal.js.map +0 -1
- package/dist/module/components/Modal/index.js +0 -3
- package/dist/module/components/Modal/index.js.map +0 -1
- package/dist/module/components/Modal/styles.js +0 -19
- package/dist/module/components/Modal/styles.js.map +0 -1
- package/dist/module/components/Modal/types.js +0 -2
- package/dist/module/components/Modal/types.js.map +0 -1
- package/dist/module/components/PickerItem/PickerItem.js +0 -38
- package/dist/module/components/PickerItem/PickerItem.js.map +0 -1
- package/dist/module/components/PickerItem/index.js +0 -2
- package/dist/module/components/PickerItem/index.js.map +0 -1
- package/dist/module/components/TimerPicker/TimerPicker.js +0 -228
- package/dist/module/components/TimerPicker/TimerPicker.js.map +0 -1
- package/dist/module/components/TimerPicker/index.js +0 -4
- package/dist/module/components/TimerPicker/index.js.map +0 -1
- package/dist/module/components/TimerPicker/styles.js +0 -114
- package/dist/module/components/TimerPicker/styles.js.map +0 -1
- package/dist/module/components/TimerPicker/types.js +0 -2
- package/dist/module/components/TimerPicker/types.js.map +0 -1
- package/dist/module/components/TimerPickerModal/TimerPickerModal.js +0 -145
- package/dist/module/components/TimerPickerModal/TimerPickerModal.js.map +0 -1
- package/dist/module/components/TimerPickerModal/index.js +0 -4
- package/dist/module/components/TimerPickerModal/index.js.map +0 -1
- package/dist/module/components/TimerPickerModal/styles.js +0 -82
- package/dist/module/components/TimerPickerModal/styles.js.map +0 -1
- package/dist/module/components/TimerPickerModal/types.js +0 -2
- package/dist/module/components/TimerPickerModal/types.js.map +0 -1
- package/dist/module/index.js +0 -3
- package/dist/module/index.js.map +0 -1
- package/dist/module/tests/DurationScroll.test.js +0 -160
- package/dist/module/tests/DurationScroll.test.js.map +0 -1
- package/dist/module/tests/Modal.test.js +0 -116
- package/dist/module/tests/Modal.test.js.map +0 -1
- package/dist/module/tests/TimerPicker.test.js +0 -166
- package/dist/module/tests/TimerPicker.test.js.map +0 -1
- package/dist/module/tests/TimerPickerModal.test.js +0 -273
- package/dist/module/tests/TimerPickerModal.test.js.map +0 -1
- package/dist/module/tests/colorToRgba.test.js +0 -174
- package/dist/module/tests/colorToRgba.test.js.map +0 -1
- package/dist/module/tests/generateNumbers.test.js +0 -348
- package/dist/module/tests/generateNumbers.test.js.map +0 -1
- package/dist/module/tests/getAdjustedLimit.test.js +0 -322
- package/dist/module/tests/getAdjustedLimit.test.js.map +0 -1
- package/dist/module/tests/getDurationAndIndexFromScrollOffset.test.js +0 -422
- package/dist/module/tests/getDurationAndIndexFromScrollOffset.test.js.map +0 -1
- package/dist/module/tests/getInitialScrollIndex.test.js +0 -394
- package/dist/module/tests/getInitialScrollIndex.test.js.map +0 -1
- package/dist/module/tests/getSafeInitialValue.test.js +0 -495
- package/dist/module/tests/getSafeInitialValue.test.js.map +0 -1
- package/dist/module/tests/padNumber.test.js +0 -299
- package/dist/module/tests/padNumber.test.js.map +0 -1
- package/dist/module/utils/colorToRgba.js +0 -80
- package/dist/module/utils/colorToRgba.js.map +0 -1
- package/dist/module/utils/generateNumbers.js +0 -117
- package/dist/module/utils/generateNumbers.js.map +0 -1
- package/dist/module/utils/getAdjustedLimit.js +0 -51
- package/dist/module/utils/getAdjustedLimit.js.map +0 -1
- package/dist/module/utils/getDurationAndIndexFromScrollOffset.js +0 -55
- package/dist/module/utils/getDurationAndIndexFromScrollOffset.js.map +0 -1
- package/dist/module/utils/getInitialScrollIndex.js +0 -50
- package/dist/module/utils/getInitialScrollIndex.js.map +0 -1
- package/dist/module/utils/getSafeInitialValue.js +0 -34
- package/dist/module/utils/getSafeInitialValue.js.map +0 -1
- package/dist/module/utils/padNumber.js +0 -33
- package/dist/module/utils/padNumber.js.map +0 -1
- package/dist/typescript/components/DurationScroll/DurationScroll.d.ts +0 -4
- package/dist/typescript/components/DurationScroll/index.d.ts +0 -2
- package/dist/typescript/components/DurationScroll/types.d.ts +0 -66
- package/dist/typescript/components/Modal/Modal.d.ts +0 -5
- package/dist/typescript/components/Modal/index.d.ts +0 -2
- package/dist/typescript/components/Modal/styles.d.ts +0 -17
- package/dist/typescript/components/Modal/types.d.ts +0 -15
- package/dist/typescript/components/PickerItem/PickerItem.d.ts +0 -14
- package/dist/typescript/components/PickerItem/index.d.ts +0 -1
- package/dist/typescript/components/TimerPicker/TimerPicker.d.ts +0 -4
- package/dist/typescript/components/TimerPicker/index.d.ts +0 -3
- package/dist/typescript/components/TimerPicker/styles.d.ts +0 -1451
- package/dist/typescript/components/TimerPicker/types.d.ts +0 -90
- package/dist/typescript/components/TimerPickerModal/TimerPickerModal.d.ts +0 -4
- package/dist/typescript/components/TimerPickerModal/index.d.ts +0 -3
- package/dist/typescript/components/TimerPickerModal/styles.d.ts +0 -947
- package/dist/typescript/components/TimerPickerModal/types.d.ts +0 -55
- package/dist/typescript/index.d.ts +0 -2
- package/dist/typescript/utils/colorToRgba.d.ts +0 -38
- package/dist/typescript/utils/generateNumbers.d.ts +0 -80
- package/dist/typescript/utils/getAdjustedLimit.d.ts +0 -30
- package/dist/typescript/utils/getDurationAndIndexFromScrollOffset.d.ts +0 -49
- package/dist/typescript/utils/getInitialScrollIndex.d.ts +0 -46
- package/dist/typescript/utils/getSafeInitialValue.d.ts +0 -38
- package/dist/typescript/utils/padNumber.d.ts +0 -28
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["React","useRef","useCallback","forwardRef","useImperativeHandle","useState","useEffect","useMemo","View","Text","FlatList","RNFlatList","colorToRgba","generate12HourNumbers","generateNumbers","getAdjustedLimit","getDurationAndIndexFromScrollOffset","getInitialScrollIndex","PickerItem","keyExtractor","item","index","toString","DurationScroll","props","ref","aggressivelyGetLatestDuration","allowFontScaling","amLabel","Audio","clickSoundAsset","decelerationRate","disableInfiniteScroll","Haptics","initialValue","interval","is12HourPicker","isDisabled","label","limit","LinearGradient","MaskedView","maximumValue","onDurationChange","padNumbersWithZero","padWithNItems","pickerFeedback","pickerGradientOverlayProps","pmLabel","repeatNumbersNTimes","repeatNumbersNTimesNotExplicitlySet","styles","testID","numberOfItems","Math","floor","safeRepeatNumbersNTimes","isNaN","max","round","numbersForFlatList","repeatNTimes","initialScrollIndex","value","adjustedLimited","numberOfItemsToShow","latestDuration","lastFeedbackIndex","flatListRef","clickSound","setClickSound","soundInstance","loadSound","sound","newSound","Sound","createAsync","uri","shouldPlay","error","console","warn","_soundInstance","unloadAsync","playClickSound","replayAsync","renderItem","createElement","adjustedLimitedMax","adjustedLimitedMin","min","onScroll","e","newValues","itemHeight","pickerItemContainer","height","yContentOffset","nativeEvent","contentOffset","y","duration","current","feedbackIndex","selectionAsync","onMomentumScrollEnd","_flatListRef$current","targetScrollIndex","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","renderContent","Fragment","key","contentContainerStyle","durationScrollFlatListContentContainer","data","nestedScrollEnabled","scrollEnabled","scrollEventThrottle","showsVerticalScrollIndicator","snapToAlignment","snapToOffsets","Array","map","i","style","durationScrollFlatList","windowSize","pointerEvents","pickerLabelContainer","pickerLabel","renderLinearGradient","colors","backgroundColor","pickerContainer","transparentBackgroundColor","color","opacity","gradientHeight","_extends","locations","pickerGradientOverlay","durationScrollFlatListContainer","disabledPickerContainer","maskElement","maskedView","memo"],"sources":["DurationScroll.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 FlatListProps,\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\";\nimport PickerItem from \"../PickerItem\";\n\nimport type {\n DurationScrollProps,\n DurationScrollRef,\n ExpoAvAudioInstance,\n} from \"./types\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst keyExtractor = (item: any, index: number) => index.toString();\n\nconst DurationScroll = forwardRef<DurationScrollRef, DurationScrollProps>(\n (props, ref) => {\n const {\n aggressivelyGetLatestDuration,\n allowFontScaling = false,\n amLabel,\n Audio,\n clickSoundAsset,\n decelerationRate = 0.88,\n disableInfiniteScroll = false,\n FlatList = RNFlatList,\n Haptics,\n initialValue = 0,\n interval,\n is12HourPicker,\n isDisabled,\n label,\n limit,\n LinearGradient,\n MaskedView,\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 } = 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] =\n useState<ExpoAvAudioInstance | null>(null);\n\n useEffect(() => {\n // Audio prop deprecated in v2.2.0 (use pickerFeedback instead) - will be removed in a future version\n\n // preload the sound when the component mounts\n let soundInstance: ExpoAvAudioInstance | null = null;\n\n const loadSound = async () => {\n if (!Audio) {\n return;\n }\n\n try {\n const { sound: newSound } = 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 soundInstance = newSound;\n setClickSound(newSound);\n } catch (error) {\n console.warn(\"Failed to load click sound:\", error);\n }\n };\n\n loadSound();\n\n return () => {\n // unload sound when component unmounts\n soundInstance?.unloadAsync();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [Audio]);\n\n const playClickSound = useCallback(async () => {\n if (!clickSound) return;\n\n try {\n await clickSound.replayAsync();\n } catch (error) {\n console.warn(\"Failed to play click sound:\", error);\n }\n }, [clickSound]);\n\n const renderItem = useCallback<\n NonNullable<FlatListProps<string>[\"renderItem\"]>\n >(\n ({ item }) => (\n <PickerItem\n adjustedLimitedMax={adjustedLimited.max}\n adjustedLimitedMin={adjustedLimited.min}\n allowFontScaling={allowFontScaling}\n amLabel={amLabel}\n is12HourPicker={is12HourPicker}\n item={item}\n pmLabel={pmLabel}\n styles={styles}\n />\n ),\n [\n adjustedLimited.max,\n adjustedLimited.min,\n allowFontScaling,\n amLabel,\n is12HourPicker,\n pmLabel,\n styles,\n ]\n );\n\n const onScroll = useCallback<\n NonNullable<FlatListProps<string>[\"onScroll\"]>\n >(\n (e) => {\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 (pickerFeedback || 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 playClickSound();\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 playClickSound,\n disableInfiniteScroll,\n interval,\n numberOfItems,\n padWithNItems,\n styles.pickerItemContainer.height,\n ]\n );\n\n const onMomentumScrollEnd = useCallback<\n NonNullable<FlatListProps<string>[\"onMomentumScrollEnd\"]>\n >(\n (e) => {\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 NonNullable<FlatListProps<string>[\"onViewableItemsChanged\"]>\n >(\n ({ viewableItems }) => {\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 NonNullable<FlatListProps<string>[\"getItemLayout\"]>\n >(\n (_, index) => ({\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 const renderContent = useMemo(() => {\n return (\n <>\n <FlatList\n key={flatListRenderKey}\n ref={flatListRef}\n contentContainerStyle={\n styles.durationScrollFlatListContentContainer\n }\n data={numbersForFlatList}\n decelerationRate={decelerationRate}\n getItemLayout={getItemLayout}\n initialScrollIndex={initialScrollIndex}\n keyExtractor={keyExtractor}\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={[\n ...Array(numbersForFlatList.length),\n ].map((_, i) => i * styles.pickerItemContainer.height)}\n style={styles.durationScrollFlatList}\n testID=\"duration-scroll-flatlist\"\n viewabilityConfigCallbackPairs={\n viewabilityConfigCallbackPairs\n }\n windowSize={numberOfItemsToShow}\n />\n <View\n pointerEvents=\"none\"\n 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 </>\n );\n }, [\n FlatList,\n allowFontScaling,\n decelerationRate,\n flatListRenderKey,\n getItemLayout,\n initialScrollIndex,\n isDisabled,\n label,\n numberOfItemsToShow,\n numbersForFlatList,\n onMomentumScrollEnd,\n onScroll,\n renderItem,\n styles.durationScrollFlatList,\n styles.durationScrollFlatListContentContainer,\n styles.pickerItemContainer.height,\n styles.pickerLabel,\n styles.pickerLabelContainer,\n viewabilityConfigCallbackPairs,\n ]);\n\n const renderLinearGradient = useMemo(() => {\n if (!LinearGradient) {\n return null;\n }\n\n let colors: string[];\n\n if (MaskedView) {\n // if using masked view, we only care about the opacity\n colors = [\n \"rgba(0,0,0,0)\",\n \"rgba(0,0,0,1)\",\n \"rgba(0,0,0,1)\",\n \"rgba(0,0,0,0)\",\n ];\n } else {\n const backgroundColor =\n styles.pickerContainer.backgroundColor ?? \"white\";\n const transparentBackgroundColor = colorToRgba({\n color: backgroundColor,\n opacity: 0,\n });\n colors = [\n backgroundColor,\n transparentBackgroundColor,\n transparentBackgroundColor,\n backgroundColor,\n ];\n }\n\n // calculate the gradient height to cover the top item and bottom item\n const gradientHeight =\n padWithNItems > 0 ? 1 / (padWithNItems * 2 + 1) : 0.3;\n\n return (\n <LinearGradient\n colors={colors}\n locations={[0, gradientHeight, 1 - gradientHeight, 1]}\n pointerEvents=\"none\"\n style={styles.pickerGradientOverlay}\n {...pickerGradientOverlayProps}\n />\n );\n }, [\n LinearGradient,\n MaskedView,\n padWithNItems,\n pickerGradientOverlayProps,\n styles.pickerContainer.backgroundColor,\n styles.pickerGradientOverlay,\n ]);\n\n return (\n <View\n pointerEvents={isDisabled ? \"none\" : undefined}\n style={[\n styles.durationScrollFlatListContainer,\n {\n height:\n styles.pickerItemContainer.height *\n numberOfItemsToShow,\n },\n isDisabled && styles.disabledPickerContainer,\n ]}\n testID={testID}>\n {MaskedView ? (\n <MaskedView\n maskElement={renderLinearGradient}\n style={[styles.maskedView]}>\n {renderContent}\n </MaskedView>\n ) : (\n <>\n {renderContent}\n {renderLinearGradient}\n </>\n )}\n </View>\n );\n }\n);\n\nexport default React.memo(DurationScroll);\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["default"],"sources":["index.ts"],"sourcesContent":["export { default } from \"./DurationScroll\";\n\nexport * from \"./types\";\n"],"mappings":"AAAA,SAASA,OAAO,QAAQ,kBAAkB;AAE1C,cAAc,SAAS","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { RefObject } from \"react\";\n\nimport type { View } from \"react-native\";\n\nimport type { generateStyles } from \"../TimerPicker/styles\";\n\nexport interface DurationScrollProps {\n Audio?: any;\n FlatList?: any;\n Haptics?: any;\n LinearGradient?: any;\n MaskedView?: any;\n aggressivelyGetLatestDuration: boolean;\n allowFontScaling?: boolean;\n amLabel?: string;\n clickSoundAsset?: SoundAsset;\n decelerationRate?: number | \"normal\" | \"fast\";\n disableInfiniteScroll?: boolean;\n initialValue?: number;\n interval: number;\n is12HourPicker?: boolean;\n isDisabled?: boolean;\n label?: string | React.ReactElement;\n limit?: Limit;\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}\n\nexport interface DurationScrollRef {\n latestDuration: RefObject<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 Limit = {\n max?: number;\n min?: number;\n};\n\nexport type SoundAsset =\n | number\n | {\n headers?: Record<string, string>;\n overrideFileExtensionAndroid?: string;\n uri: string;\n };\n\nexport type ExpoAvAudioInstance = {\n replayAsync: () => Promise<void>;\n unloadAsync: () => Promise<void>;\n};\n"],"mappings":"","ignoreList":[]}
|
|
@@ -1,99 +0,0 @@
|
|
|
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
|
-
import React, { useCallback, useEffect, useRef } from "react";
|
|
3
|
-
import { Animated, Easing, Modal as ReactNativeModal, TouchableWithoutFeedback, useWindowDimensions } from "react-native";
|
|
4
|
-
import { styles } from "./styles";
|
|
5
|
-
export const Modal = props => {
|
|
6
|
-
const {
|
|
7
|
-
animationDuration = 300,
|
|
8
|
-
children,
|
|
9
|
-
contentStyle,
|
|
10
|
-
isVisible = false,
|
|
11
|
-
modalProps,
|
|
12
|
-
onHide,
|
|
13
|
-
onOverlayPress,
|
|
14
|
-
overlayOpacity = 0.4,
|
|
15
|
-
overlayStyle,
|
|
16
|
-
testID = "modal"
|
|
17
|
-
} = props;
|
|
18
|
-
const {
|
|
19
|
-
height: screenHeight,
|
|
20
|
-
width: screenWidth
|
|
21
|
-
} = useWindowDimensions();
|
|
22
|
-
const isMounted = useRef(false);
|
|
23
|
-
const animatedOpacity = useRef(new Animated.Value(0));
|
|
24
|
-
useEffect(() => {
|
|
25
|
-
isMounted.current = true;
|
|
26
|
-
if (isVisible) {
|
|
27
|
-
show();
|
|
28
|
-
}
|
|
29
|
-
return () => {
|
|
30
|
-
isMounted.current = false;
|
|
31
|
-
};
|
|
32
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
33
|
-
}, []);
|
|
34
|
-
const backdropAnimatedStyle = {
|
|
35
|
-
opacity: animatedOpacity.current.interpolate({
|
|
36
|
-
inputRange: [0, 1],
|
|
37
|
-
outputRange: [0, overlayOpacity]
|
|
38
|
-
})
|
|
39
|
-
};
|
|
40
|
-
const contentAnimatedStyle = {
|
|
41
|
-
transform: [{
|
|
42
|
-
translateY: animatedOpacity.current.interpolate({
|
|
43
|
-
inputRange: [0, 1],
|
|
44
|
-
outputRange: [screenHeight, 0],
|
|
45
|
-
extrapolate: "clamp"
|
|
46
|
-
})
|
|
47
|
-
}]
|
|
48
|
-
};
|
|
49
|
-
const show = useCallback(() => {
|
|
50
|
-
Animated.timing(animatedOpacity.current, {
|
|
51
|
-
easing: Easing.inOut(Easing.quad),
|
|
52
|
-
// Using native driver in the modal makes the content flash
|
|
53
|
-
useNativeDriver: true,
|
|
54
|
-
duration: animationDuration,
|
|
55
|
-
toValue: 1
|
|
56
|
-
}).start();
|
|
57
|
-
}, [animationDuration]);
|
|
58
|
-
const hide = useCallback(() => {
|
|
59
|
-
Animated.timing(animatedOpacity.current, {
|
|
60
|
-
easing: Easing.inOut(Easing.quad),
|
|
61
|
-
// Using native driver in the modal makes the content flash
|
|
62
|
-
useNativeDriver: true,
|
|
63
|
-
duration: animationDuration,
|
|
64
|
-
toValue: 0
|
|
65
|
-
}).start(() => {
|
|
66
|
-
if (isMounted.current) {
|
|
67
|
-
onHide === null || onHide === void 0 || onHide();
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
}, [animationDuration, onHide]);
|
|
71
|
-
useEffect(() => {
|
|
72
|
-
if (isVisible) {
|
|
73
|
-
show();
|
|
74
|
-
} else {
|
|
75
|
-
hide();
|
|
76
|
-
}
|
|
77
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
78
|
-
}, [isVisible]);
|
|
79
|
-
return /*#__PURE__*/React.createElement(ReactNativeModal, _extends({
|
|
80
|
-
animationType: "fade",
|
|
81
|
-
transparent: true,
|
|
82
|
-
visible: isVisible
|
|
83
|
-
}, modalProps, {
|
|
84
|
-
testID: testID
|
|
85
|
-
}), /*#__PURE__*/React.createElement(TouchableWithoutFeedback, {
|
|
86
|
-
onPress: onOverlayPress,
|
|
87
|
-
testID: "modal-backdrop"
|
|
88
|
-
}, /*#__PURE__*/React.createElement(Animated.View, {
|
|
89
|
-
style: [styles.backdrop, backdropAnimatedStyle, {
|
|
90
|
-
width: screenWidth,
|
|
91
|
-
height: screenHeight
|
|
92
|
-
}, overlayStyle]
|
|
93
|
-
})), /*#__PURE__*/React.createElement(Animated.View, {
|
|
94
|
-
pointerEvents: "box-none",
|
|
95
|
-
style: [styles.content, contentAnimatedStyle, contentStyle]
|
|
96
|
-
}, children));
|
|
97
|
-
};
|
|
98
|
-
export default /*#__PURE__*/React.memo(Modal);
|
|
99
|
-
//# sourceMappingURL=Modal.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["React","useCallback","useEffect","useRef","Animated","Easing","Modal","ReactNativeModal","TouchableWithoutFeedback","useWindowDimensions","styles","props","animationDuration","children","contentStyle","isVisible","modalProps","onHide","onOverlayPress","overlayOpacity","overlayStyle","testID","height","screenHeight","width","screenWidth","isMounted","animatedOpacity","Value","current","show","backdropAnimatedStyle","opacity","interpolate","inputRange","outputRange","contentAnimatedStyle","transform","translateY","extrapolate","timing","easing","inOut","quad","useNativeDriver","duration","toValue","start","hide","createElement","_extends","animationType","transparent","visible","onPress","View","style","backdrop","pointerEvents","content","memo"],"sources":["Modal.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef } from \"react\";\n\nimport {\n Animated,\n Easing,\n Modal as ReactNativeModal,\n TouchableWithoutFeedback,\n useWindowDimensions,\n} from \"react-native\";\n\nimport { styles } from \"./styles\";\nimport type { ModalProps } from \"./types\";\n\nexport const Modal = (props: ModalProps) => {\n const {\n animationDuration = 300,\n children,\n contentStyle,\n isVisible = false,\n modalProps,\n onHide,\n onOverlayPress,\n overlayOpacity = 0.4,\n overlayStyle,\n testID = \"modal\",\n } = props;\n\n const { height: screenHeight, width: screenWidth } = useWindowDimensions();\n\n const isMounted = useRef(false);\n const animatedOpacity = useRef(new Animated.Value(0));\n\n useEffect(() => {\n isMounted.current = true;\n if (isVisible) {\n show();\n }\n\n return () => {\n isMounted.current = false;\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const backdropAnimatedStyle = {\n opacity: animatedOpacity.current.interpolate({\n inputRange: [0, 1],\n outputRange: [0, overlayOpacity],\n }),\n };\n const contentAnimatedStyle = {\n transform: [\n {\n translateY: animatedOpacity.current.interpolate({\n inputRange: [0, 1],\n outputRange: [screenHeight, 0],\n extrapolate: \"clamp\",\n }),\n },\n ],\n };\n\n const show = useCallback(() => {\n Animated.timing(animatedOpacity.current, {\n easing: Easing.inOut(Easing.quad),\n // Using native driver in the modal makes the content flash\n useNativeDriver: true,\n duration: animationDuration,\n toValue: 1,\n }).start();\n }, [animationDuration]);\n\n const hide = useCallback(() => {\n Animated.timing(animatedOpacity.current, {\n easing: Easing.inOut(Easing.quad),\n // Using native driver in the modal makes the content flash\n useNativeDriver: true,\n duration: animationDuration,\n toValue: 0,\n }).start(() => {\n if (isMounted.current) {\n onHide?.();\n }\n });\n }, [animationDuration, onHide]);\n\n useEffect(() => {\n if (isVisible) {\n show();\n } else {\n hide();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isVisible]);\n\n return (\n <ReactNativeModal\n animationType=\"fade\"\n transparent\n visible={isVisible}\n {...modalProps}\n testID={testID}>\n <TouchableWithoutFeedback\n onPress={onOverlayPress}\n testID=\"modal-backdrop\">\n <Animated.View\n style={[\n styles.backdrop,\n backdropAnimatedStyle,\n { width: screenWidth, height: screenHeight },\n overlayStyle,\n ]}\n />\n </TouchableWithoutFeedback>\n <Animated.View\n pointerEvents=\"box-none\"\n style={[styles.content, contentAnimatedStyle, contentStyle]}>\n {children}\n </Animated.View>\n </ReactNativeModal>\n );\n};\n\nexport default React.memo(Modal);\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["default"],"sources":["index.ts"],"sourcesContent":["export { default } from \"./Modal\";\n\nexport * from \"./types\";\n"],"mappings":"AAAA,SAASA,OAAO,QAAQ,SAAS;AAEjC,cAAc,SAAS","ignoreList":[]}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { StyleSheet } from "react-native";
|
|
2
|
-
export const styles = StyleSheet.create({
|
|
3
|
-
backdrop: {
|
|
4
|
-
position: "absolute",
|
|
5
|
-
top: 0,
|
|
6
|
-
bottom: 0,
|
|
7
|
-
left: 0,
|
|
8
|
-
right: 0,
|
|
9
|
-
backgroundColor: "black",
|
|
10
|
-
opacity: 0
|
|
11
|
-
},
|
|
12
|
-
content: {
|
|
13
|
-
flex: 1,
|
|
14
|
-
justifyContent: "center",
|
|
15
|
-
alignItems: "center",
|
|
16
|
-
zIndex: 1
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
//# sourceMappingURL=styles.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["StyleSheet","styles","create","backdrop","position","top","bottom","left","right","backgroundColor","opacity","content","flex","justifyContent","alignItems","zIndex"],"sources":["styles.ts"],"sourcesContent":["import { StyleSheet } from \"react-native\";\n\nexport const styles = StyleSheet.create({\n backdrop: {\n position: \"absolute\",\n top: 0,\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: \"black\",\n opacity: 0,\n },\n content: {\n flex: 1,\n justifyContent: \"center\",\n alignItems: \"center\",\n zIndex: 1,\n },\n});"],"mappings":"AAAA,SAASA,UAAU,QAAQ,cAAc;AAEzC,OAAO,MAAMC,MAAM,GAAGD,UAAU,CAACE,MAAM,CAAC;EACpCC,QAAQ,EAAE;IACNC,QAAQ,EAAE,UAAU;IACpBC,GAAG,EAAE,CAAC;IACNC,MAAM,EAAE,CAAC;IACTC,IAAI,EAAE,CAAC;IACPC,KAAK,EAAE,CAAC;IACRC,eAAe,EAAE,OAAO;IACxBC,OAAO,EAAE;EACb,CAAC;EACDC,OAAO,EAAE;IACLC,IAAI,EAAE,CAAC;IACPC,cAAc,EAAE,QAAQ;IACxBC,UAAU,EAAE,QAAQ;IACpBC,MAAM,EAAE;EACZ;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import type { ComponentProps } from \"react\";\n\nimport type { ViewStyle } from \"react-native\";\nimport type { Modal as ReactNativeModal } from \"react-native\";\n\nexport interface ModalProps {\n animationDuration?: number;\n children?: React.ReactElement;\n contentStyle?: ViewStyle;\n isVisible?: boolean;\n modalProps?: ComponentProps<typeof ReactNativeModal>;\n onHide?: () => void;\n onOverlayPress?: () => void;\n overlayOpacity?: number;\n overlayStyle?: ViewStyle;\n testID?: string;\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
import { View, Text } from "react-native";
|
|
3
|
-
const PickerItem = /*#__PURE__*/React.memo(({
|
|
4
|
-
adjustedLimitedMax,
|
|
5
|
-
adjustedLimitedMin,
|
|
6
|
-
allowFontScaling,
|
|
7
|
-
amLabel,
|
|
8
|
-
is12HourPicker,
|
|
9
|
-
item,
|
|
10
|
-
pmLabel,
|
|
11
|
-
styles
|
|
12
|
-
}) => {
|
|
13
|
-
let stringItem = item;
|
|
14
|
-
let intItem;
|
|
15
|
-
let isAm;
|
|
16
|
-
if (!is12HourPicker) {
|
|
17
|
-
intItem = parseInt(item);
|
|
18
|
-
} else {
|
|
19
|
-
isAm = item.includes("AM");
|
|
20
|
-
stringItem = item.replace(/\s[AP]M/g, "");
|
|
21
|
-
intItem = parseInt(stringItem);
|
|
22
|
-
}
|
|
23
|
-
return /*#__PURE__*/React.createElement(View, {
|
|
24
|
-
key: item,
|
|
25
|
-
style: styles.pickerItemContainer,
|
|
26
|
-
testID: "picker-item"
|
|
27
|
-
}, /*#__PURE__*/React.createElement(Text, {
|
|
28
|
-
allowFontScaling: allowFontScaling,
|
|
29
|
-
style: [styles.pickerItem, intItem > adjustedLimitedMax || intItem < adjustedLimitedMin ? styles.disabledPickerItem : {}]
|
|
30
|
-
}, stringItem), is12HourPicker && /*#__PURE__*/React.createElement(View, {
|
|
31
|
-
style: styles.pickerAmPmContainer
|
|
32
|
-
}, /*#__PURE__*/React.createElement(Text, {
|
|
33
|
-
allowFontScaling: allowFontScaling,
|
|
34
|
-
style: styles.pickerAmPmLabel
|
|
35
|
-
}, isAm ? amLabel : pmLabel)));
|
|
36
|
-
});
|
|
37
|
-
export default PickerItem;
|
|
38
|
-
//# sourceMappingURL=PickerItem.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["React","View","Text","PickerItem","memo","adjustedLimitedMax","adjustedLimitedMin","allowFontScaling","amLabel","is12HourPicker","item","pmLabel","styles","stringItem","intItem","isAm","parseInt","includes","replace","createElement","key","style","pickerItemContainer","testID","pickerItem","disabledPickerItem","pickerAmPmContainer","pickerAmPmLabel"],"sources":["PickerItem.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { View, Text } from \"react-native\";\n\nimport type { generateStyles } from \"../TimerPicker/styles\";\n\ninterface PickerItemProps {\n adjustedLimitedMax: number;\n adjustedLimitedMin: number;\n allowFontScaling: boolean;\n amLabel?: string;\n is12HourPicker?: boolean;\n item: string;\n pmLabel?: string;\n styles: ReturnType<typeof generateStyles>;\n}\n\nconst PickerItem = React.memo<PickerItemProps>(\n ({\n adjustedLimitedMax,\n adjustedLimitedMin,\n allowFontScaling,\n amLabel,\n is12HourPicker,\n item,\n pmLabel,\n styles,\n }) => {\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 > adjustedLimitedMax ||\n intItem < adjustedLimitedMin\n ? styles.disabledPickerItem\n : {},\n ]}>\n {stringItem}\n </Text>\n {is12HourPicker && (\n <View style={styles.pickerAmPmContainer}>\n <Text\n allowFontScaling={allowFontScaling}\n style={styles.pickerAmPmLabel}>\n {isAm ? amLabel : pmLabel}\n </Text>\n </View>\n )}\n </View>\n );\n }\n);\n\nexport default PickerItem;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAASC,IAAI,EAAEC,IAAI,QAAQ,cAAc;AAezC,MAAMC,UAAU,gBAAGH,KAAK,CAACI,IAAI,CACzB,CAAC;EACGC,kBAAkB;EAClBC,kBAAkB;EAClBC,gBAAgB;EAChBC,OAAO;EACPC,cAAc;EACdC,IAAI;EACJC,OAAO;EACPC;AACJ,CAAC,KAAK;EACF,IAAIC,UAAU,GAAGH,IAAI;EACrB,IAAII,OAAe;EACnB,IAAIC,IAAyB;EAE7B,IAAI,CAACN,cAAc,EAAE;IACjBK,OAAO,GAAGE,QAAQ,CAACN,IAAI,CAAC;EAC5B,CAAC,MAAM;IACHK,IAAI,GAAGL,IAAI,CAACO,QAAQ,CAAC,IAAI,CAAC;IAC1BJ,UAAU,GAAGH,IAAI,CAACQ,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;IACzCJ,OAAO,GAAGE,QAAQ,CAACH,UAAU,CAAC;EAClC;EAEA,oBACIb,KAAA,CAAAmB,aAAA,CAAClB,IAAI;IACDmB,GAAG,EAAEV,IAAK;IACVW,KAAK,EAAET,MAAM,CAACU,mBAAoB;IAClCC,MAAM,EAAC;EAAa,gBACpBvB,KAAA,CAAAmB,aAAA,CAACjB,IAAI;IACDK,gBAAgB,EAAEA,gBAAiB;IACnCc,KAAK,EAAE,CACHT,MAAM,CAACY,UAAU,EACjBV,OAAO,GAAGT,kBAAkB,IAC5BS,OAAO,GAAGR,kBAAkB,GACtBM,MAAM,CAACa,kBAAkB,GACzB,CAAC,CAAC;EACV,GACDZ,UACC,CAAC,EACNJ,cAAc,iBACXT,KAAA,CAAAmB,aAAA,CAAClB,IAAI;IAACoB,KAAK,EAAET,MAAM,CAACc;EAAoB,gBACpC1B,KAAA,CAAAmB,aAAA,CAACjB,IAAI;IACDK,gBAAgB,EAAEA,gBAAiB;IACnCc,KAAK,EAAET,MAAM,CAACe;EAAgB,GAC7BZ,IAAI,GAAGP,OAAO,GAAGG,OAChB,CACJ,CAER,CAAC;AAEf,CACJ,CAAC;AAED,eAAeR,UAAU","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["default"],"sources":["index.ts"],"sourcesContent":["export { default } from \"./PickerItem\";\n"],"mappings":"AAAA,SAASA,OAAO,QAAQ,cAAc","ignoreList":[]}
|
|
@@ -1,228 +0,0 @@
|
|
|
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
|
-
import React, { forwardRef, useEffect, useImperativeHandle, useMemo, useRef, useState } from "react";
|
|
3
|
-
import { View } from "react-native";
|
|
4
|
-
import { getSafeInitialValue } from "../../utils/getSafeInitialValue";
|
|
5
|
-
import DurationScroll from "../DurationScroll";
|
|
6
|
-
import { generateStyles } from "./styles";
|
|
7
|
-
const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
|
|
8
|
-
const {
|
|
9
|
-
aggressivelyGetLatestDuration = false,
|
|
10
|
-
allowFontScaling = false,
|
|
11
|
-
amLabel = "am",
|
|
12
|
-
dayInterval = 1,
|
|
13
|
-
dayLabel,
|
|
14
|
-
dayLimit,
|
|
15
|
-
daysPickerIsDisabled = false,
|
|
16
|
-
decelerationRate = 0.88,
|
|
17
|
-
disableInfiniteScroll = false,
|
|
18
|
-
hideDays = true,
|
|
19
|
-
hideHours = false,
|
|
20
|
-
hideMinutes = false,
|
|
21
|
-
hideSeconds = false,
|
|
22
|
-
hourInterval = 1,
|
|
23
|
-
hourLabel,
|
|
24
|
-
hourLimit,
|
|
25
|
-
hoursPickerIsDisabled = false,
|
|
26
|
-
initialValue,
|
|
27
|
-
maximumDays = 30,
|
|
28
|
-
maximumHours = 23,
|
|
29
|
-
maximumMinutes = 59,
|
|
30
|
-
maximumSeconds = 59,
|
|
31
|
-
minuteInterval = 1,
|
|
32
|
-
minuteLabel,
|
|
33
|
-
minuteLimit,
|
|
34
|
-
minutesPickerIsDisabled = false,
|
|
35
|
-
onDurationChange,
|
|
36
|
-
padDaysWithZero = false,
|
|
37
|
-
padHoursWithZero = false,
|
|
38
|
-
padMinutesWithZero = true,
|
|
39
|
-
padSecondsWithZero = true,
|
|
40
|
-
padWithNItems = 1,
|
|
41
|
-
pickerContainerProps,
|
|
42
|
-
pmLabel = "pm",
|
|
43
|
-
repeatDayNumbersNTimes = 3,
|
|
44
|
-
repeatHourNumbersNTimes = 8,
|
|
45
|
-
repeatMinuteNumbersNTimes = 3,
|
|
46
|
-
repeatSecondNumbersNTimes = 3,
|
|
47
|
-
secondInterval = 1,
|
|
48
|
-
secondLabel,
|
|
49
|
-
secondLimit,
|
|
50
|
-
secondsPickerIsDisabled = false,
|
|
51
|
-
styles: customStyles,
|
|
52
|
-
use12HourPicker = false,
|
|
53
|
-
...otherProps
|
|
54
|
-
} = props;
|
|
55
|
-
useEffect(() => {
|
|
56
|
-
if (otherProps.Audio) {
|
|
57
|
-
console.warn('The "Audio" prop is deprecated and will be removed in a future version. Please use the "pickerFeedback" prop instead.');
|
|
58
|
-
}
|
|
59
|
-
if (otherProps.Haptics) {
|
|
60
|
-
console.warn('The "Haptics" prop is deprecated and will be removed in a future version. Please use the "pickerFeedback" prop instead.');
|
|
61
|
-
}
|
|
62
|
-
if (otherProps.clickSoundAsset) {
|
|
63
|
-
console.warn('The "clickSoundAsset" prop is deprecated and will be removed in a future version. Please use the "pickerFeedback" prop instead.');
|
|
64
|
-
}
|
|
65
|
-
}, [otherProps.Audio, otherProps.Haptics, otherProps.clickSoundAsset]);
|
|
66
|
-
const safePadWithNItems = useMemo(() => {
|
|
67
|
-
if (padWithNItems < 0 || isNaN(padWithNItems)) {
|
|
68
|
-
return 0;
|
|
69
|
-
}
|
|
70
|
-
const maxPadWithNItems = hideHours ? 15 : 6;
|
|
71
|
-
if (padWithNItems > maxPadWithNItems) {
|
|
72
|
-
return maxPadWithNItems;
|
|
73
|
-
}
|
|
74
|
-
return Math.round(padWithNItems);
|
|
75
|
-
}, [hideHours, padWithNItems]);
|
|
76
|
-
const safeInitialValue = useMemo(() => getSafeInitialValue({
|
|
77
|
-
days: initialValue === null || initialValue === void 0 ? void 0 : initialValue.days,
|
|
78
|
-
hours: initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours,
|
|
79
|
-
minutes: initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes,
|
|
80
|
-
seconds: initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds
|
|
81
|
-
}), [initialValue === null || initialValue === void 0 ? void 0 : initialValue.days, 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]);
|
|
82
|
-
const styles = useMemo(() => generateStyles(customStyles), [customStyles]);
|
|
83
|
-
const [selectedDays, setSelectedDays] = useState(safeInitialValue.days);
|
|
84
|
-
const [selectedHours, setSelectedHours] = useState(safeInitialValue.hours);
|
|
85
|
-
const [selectedMinutes, setSelectedMinutes] = useState(safeInitialValue.minutes);
|
|
86
|
-
const [selectedSeconds, setSelectedSeconds] = useState(safeInitialValue.seconds);
|
|
87
|
-
useEffect(() => {
|
|
88
|
-
onDurationChange === null || onDurationChange === void 0 || onDurationChange({
|
|
89
|
-
days: selectedDays,
|
|
90
|
-
hours: selectedHours,
|
|
91
|
-
minutes: selectedMinutes,
|
|
92
|
-
seconds: selectedSeconds
|
|
93
|
-
});
|
|
94
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
95
|
-
}, [selectedDays, selectedHours, selectedMinutes, selectedSeconds]);
|
|
96
|
-
const daysDurationScrollRef = useRef(null);
|
|
97
|
-
const hoursDurationScrollRef = useRef(null);
|
|
98
|
-
const minutesDurationScrollRef = useRef(null);
|
|
99
|
-
const secondsDurationScrollRef = useRef(null);
|
|
100
|
-
useImperativeHandle(ref, () => {
|
|
101
|
-
var _daysDurationScrollRe3, _hoursDurationScrollR3, _minutesDurationScrol3, _secondsDurationScrol3;
|
|
102
|
-
return {
|
|
103
|
-
reset: options => {
|
|
104
|
-
var _daysDurationScrollRe, _hoursDurationScrollR, _minutesDurationScrol, _secondsDurationScrol;
|
|
105
|
-
setSelectedDays(safeInitialValue.days);
|
|
106
|
-
setSelectedHours(safeInitialValue.hours);
|
|
107
|
-
setSelectedMinutes(safeInitialValue.minutes);
|
|
108
|
-
setSelectedSeconds(safeInitialValue.seconds);
|
|
109
|
-
(_daysDurationScrollRe = daysDurationScrollRef.current) === null || _daysDurationScrollRe === void 0 || _daysDurationScrollRe.reset(options);
|
|
110
|
-
(_hoursDurationScrollR = hoursDurationScrollRef.current) === null || _hoursDurationScrollR === void 0 || _hoursDurationScrollR.reset(options);
|
|
111
|
-
(_minutesDurationScrol = minutesDurationScrollRef.current) === null || _minutesDurationScrol === void 0 || _minutesDurationScrol.reset(options);
|
|
112
|
-
(_secondsDurationScrol = secondsDurationScrollRef.current) === null || _secondsDurationScrol === void 0 || _secondsDurationScrol.reset(options);
|
|
113
|
-
},
|
|
114
|
-
setValue: (value, options) => {
|
|
115
|
-
if (value.days) {
|
|
116
|
-
var _daysDurationScrollRe2;
|
|
117
|
-
setSelectedDays(value.days);
|
|
118
|
-
(_daysDurationScrollRe2 = daysDurationScrollRef.current) === null || _daysDurationScrollRe2 === void 0 || _daysDurationScrollRe2.setValue(value.days, options);
|
|
119
|
-
}
|
|
120
|
-
if (value.hours) {
|
|
121
|
-
var _hoursDurationScrollR2;
|
|
122
|
-
setSelectedHours(value.hours);
|
|
123
|
-
(_hoursDurationScrollR2 = hoursDurationScrollRef.current) === null || _hoursDurationScrollR2 === void 0 || _hoursDurationScrollR2.setValue(value.hours, options);
|
|
124
|
-
}
|
|
125
|
-
if (value.minutes) {
|
|
126
|
-
var _minutesDurationScrol2;
|
|
127
|
-
setSelectedMinutes(value.minutes);
|
|
128
|
-
(_minutesDurationScrol2 = minutesDurationScrollRef.current) === null || _minutesDurationScrol2 === void 0 || _minutesDurationScrol2.setValue(value.minutes, options);
|
|
129
|
-
}
|
|
130
|
-
if (value.seconds) {
|
|
131
|
-
var _secondsDurationScrol2;
|
|
132
|
-
setSelectedSeconds(value.seconds);
|
|
133
|
-
(_secondsDurationScrol2 = secondsDurationScrollRef.current) === null || _secondsDurationScrol2 === void 0 || _secondsDurationScrol2.setValue(value.seconds, options);
|
|
134
|
-
}
|
|
135
|
-
},
|
|
136
|
-
latestDuration: {
|
|
137
|
-
days: (_daysDurationScrollRe3 = daysDurationScrollRef.current) === null || _daysDurationScrollRe3 === void 0 ? void 0 : _daysDurationScrollRe3.latestDuration,
|
|
138
|
-
hours: (_hoursDurationScrollR3 = hoursDurationScrollRef.current) === null || _hoursDurationScrollR3 === void 0 ? void 0 : _hoursDurationScrollR3.latestDuration,
|
|
139
|
-
minutes: (_minutesDurationScrol3 = minutesDurationScrollRef.current) === null || _minutesDurationScrol3 === void 0 ? void 0 : _minutesDurationScrol3.latestDuration,
|
|
140
|
-
seconds: (_secondsDurationScrol3 = secondsDurationScrollRef.current) === null || _secondsDurationScrol3 === void 0 ? void 0 : _secondsDurationScrol3.latestDuration
|
|
141
|
-
}
|
|
142
|
-
};
|
|
143
|
-
});
|
|
144
|
-
return /*#__PURE__*/React.createElement(View, _extends({}, pickerContainerProps, {
|
|
145
|
-
style: styles.pickerContainer,
|
|
146
|
-
testID: "timer-picker"
|
|
147
|
-
}), !hideDays ? /*#__PURE__*/React.createElement(DurationScroll, _extends({
|
|
148
|
-
ref: daysDurationScrollRef,
|
|
149
|
-
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
150
|
-
allowFontScaling: allowFontScaling,
|
|
151
|
-
disableInfiniteScroll: disableInfiniteScroll,
|
|
152
|
-
initialValue: safeInitialValue.days,
|
|
153
|
-
interval: dayInterval,
|
|
154
|
-
isDisabled: daysPickerIsDisabled,
|
|
155
|
-
label: dayLabel ?? "d",
|
|
156
|
-
limit: dayLimit,
|
|
157
|
-
maximumValue: maximumDays,
|
|
158
|
-
onDurationChange: setSelectedDays,
|
|
159
|
-
padNumbersWithZero: padDaysWithZero,
|
|
160
|
-
padWithNItems: safePadWithNItems,
|
|
161
|
-
repeatNumbersNTimes: repeatDayNumbersNTimes,
|
|
162
|
-
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatDayNumbersNTimes) === undefined,
|
|
163
|
-
styles: styles,
|
|
164
|
-
testID: "duration-scroll-day"
|
|
165
|
-
}, otherProps)) : null, !hideHours ? /*#__PURE__*/React.createElement(DurationScroll, _extends({
|
|
166
|
-
ref: hoursDurationScrollRef,
|
|
167
|
-
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
168
|
-
allowFontScaling: allowFontScaling,
|
|
169
|
-
amLabel: amLabel,
|
|
170
|
-
decelerationRate: decelerationRate,
|
|
171
|
-
disableInfiniteScroll: disableInfiniteScroll,
|
|
172
|
-
initialValue: safeInitialValue.hours,
|
|
173
|
-
interval: hourInterval,
|
|
174
|
-
is12HourPicker: use12HourPicker,
|
|
175
|
-
isDisabled: hoursPickerIsDisabled,
|
|
176
|
-
label: hourLabel ?? (!use12HourPicker ? "h" : undefined),
|
|
177
|
-
limit: hourLimit,
|
|
178
|
-
maximumValue: maximumHours,
|
|
179
|
-
onDurationChange: setSelectedHours,
|
|
180
|
-
padNumbersWithZero: padHoursWithZero,
|
|
181
|
-
padWithNItems: safePadWithNItems,
|
|
182
|
-
pmLabel: pmLabel,
|
|
183
|
-
repeatNumbersNTimes: repeatHourNumbersNTimes,
|
|
184
|
-
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatHourNumbersNTimes) === undefined,
|
|
185
|
-
styles: styles,
|
|
186
|
-
testID: "duration-scroll-hour"
|
|
187
|
-
}, otherProps)) : null, !hideMinutes ? /*#__PURE__*/React.createElement(DurationScroll, _extends({
|
|
188
|
-
ref: minutesDurationScrollRef,
|
|
189
|
-
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
190
|
-
allowFontScaling: allowFontScaling,
|
|
191
|
-
decelerationRate: decelerationRate,
|
|
192
|
-
disableInfiniteScroll: disableInfiniteScroll,
|
|
193
|
-
initialValue: safeInitialValue.minutes,
|
|
194
|
-
interval: minuteInterval,
|
|
195
|
-
isDisabled: minutesPickerIsDisabled,
|
|
196
|
-
label: minuteLabel ?? "m",
|
|
197
|
-
limit: minuteLimit,
|
|
198
|
-
maximumValue: maximumMinutes,
|
|
199
|
-
onDurationChange: setSelectedMinutes,
|
|
200
|
-
padNumbersWithZero: padMinutesWithZero,
|
|
201
|
-
padWithNItems: safePadWithNItems,
|
|
202
|
-
repeatNumbersNTimes: repeatMinuteNumbersNTimes,
|
|
203
|
-
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatMinuteNumbersNTimes) === undefined,
|
|
204
|
-
styles: styles,
|
|
205
|
-
testID: "duration-scroll-minute"
|
|
206
|
-
}, otherProps)) : null, !hideSeconds ? /*#__PURE__*/React.createElement(DurationScroll, _extends({
|
|
207
|
-
ref: secondsDurationScrollRef,
|
|
208
|
-
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
209
|
-
allowFontScaling: allowFontScaling,
|
|
210
|
-
decelerationRate: decelerationRate,
|
|
211
|
-
disableInfiniteScroll: disableInfiniteScroll,
|
|
212
|
-
initialValue: safeInitialValue.seconds,
|
|
213
|
-
interval: secondInterval,
|
|
214
|
-
isDisabled: secondsPickerIsDisabled,
|
|
215
|
-
label: secondLabel ?? "s",
|
|
216
|
-
limit: secondLimit,
|
|
217
|
-
maximumValue: maximumSeconds,
|
|
218
|
-
onDurationChange: setSelectedSeconds,
|
|
219
|
-
padNumbersWithZero: padSecondsWithZero,
|
|
220
|
-
padWithNItems: safePadWithNItems,
|
|
221
|
-
repeatNumbersNTimes: repeatSecondNumbersNTimes,
|
|
222
|
-
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatSecondNumbersNTimes) === undefined,
|
|
223
|
-
styles: styles,
|
|
224
|
-
testID: "duration-scroll-second"
|
|
225
|
-
}, otherProps)) : null);
|
|
226
|
-
});
|
|
227
|
-
export default /*#__PURE__*/React.memo(TimerPicker);
|
|
228
|
-
//# sourceMappingURL=TimerPicker.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["React","forwardRef","useEffect","useImperativeHandle","useMemo","useRef","useState","View","getSafeInitialValue","DurationScroll","generateStyles","TimerPicker","props","ref","aggressivelyGetLatestDuration","allowFontScaling","amLabel","dayInterval","dayLabel","dayLimit","daysPickerIsDisabled","decelerationRate","disableInfiniteScroll","hideDays","hideHours","hideMinutes","hideSeconds","hourInterval","hourLabel","hourLimit","hoursPickerIsDisabled","initialValue","maximumDays","maximumHours","maximumMinutes","maximumSeconds","minuteInterval","minuteLabel","minuteLimit","minutesPickerIsDisabled","onDurationChange","padDaysWithZero","padHoursWithZero","padMinutesWithZero","padSecondsWithZero","padWithNItems","pickerContainerProps","pmLabel","repeatDayNumbersNTimes","repeatHourNumbersNTimes","repeatMinuteNumbersNTimes","repeatSecondNumbersNTimes","secondInterval","secondLabel","secondLimit","secondsPickerIsDisabled","styles","customStyles","use12HourPicker","otherProps","Audio","console","warn","Haptics","clickSoundAsset","safePadWithNItems","isNaN","maxPadWithNItems","Math","round","safeInitialValue","days","hours","minutes","seconds","selectedDays","setSelectedDays","selectedHours","setSelectedHours","selectedMinutes","setSelectedMinutes","selectedSeconds","setSelectedSeconds","daysDurationScrollRef","hoursDurationScrollRef","minutesDurationScrollRef","secondsDurationScrollRef","_daysDurationScrollRe3","_hoursDurationScrollR3","_minutesDurationScrol3","_secondsDurationScrol3","reset","options","_daysDurationScrollRe","_hoursDurationScrollR","_minutesDurationScrol","_secondsDurationScrol","current","setValue","value","_daysDurationScrollRe2","_hoursDurationScrollR2","_minutesDurationScrol2","_secondsDurationScrol2","latestDuration","createElement","_extends","style","pickerContainer","testID","interval","isDisabled","label","limit","maximumValue","padNumbersWithZero","repeatNumbersNTimes","repeatNumbersNTimesNotExplicitlySet","undefined","is12HourPicker","memo"],"sources":["TimerPicker.tsx"],"sourcesContent":["import React, {\n forwardRef,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\n\nimport { View } from \"react-native\";\n\nimport { getSafeInitialValue } from \"../../utils/getSafeInitialValue\";\nimport DurationScroll from \"../DurationScroll\";\nimport type { DurationScrollRef } from \"../DurationScroll\";\n\nimport { generateStyles } from \"./styles\";\nimport type { TimerPickerProps, TimerPickerRef } from \"./types\";\n\nconst TimerPicker = forwardRef<TimerPickerRef, TimerPickerProps>(\n (props, ref) => {\n const {\n aggressivelyGetLatestDuration = false,\n allowFontScaling = false,\n amLabel = \"am\",\n dayInterval = 1,\n dayLabel,\n dayLimit,\n daysPickerIsDisabled = false,\n decelerationRate = 0.88,\n disableInfiniteScroll = false,\n hideDays = true,\n hideHours = false,\n hideMinutes = false,\n hideSeconds = false,\n hourInterval = 1,\n hourLabel,\n hourLimit,\n hoursPickerIsDisabled = false,\n initialValue,\n maximumDays = 30,\n maximumHours = 23,\n maximumMinutes = 59,\n maximumSeconds = 59,\n minuteInterval = 1,\n minuteLabel,\n minuteLimit,\n minutesPickerIsDisabled = false,\n onDurationChange,\n padDaysWithZero = false,\n padHoursWithZero = false,\n padMinutesWithZero = true,\n padSecondsWithZero = true,\n padWithNItems = 1,\n pickerContainerProps,\n pmLabel = \"pm\",\n repeatDayNumbersNTimes = 3,\n repeatHourNumbersNTimes = 8,\n repeatMinuteNumbersNTimes = 3,\n repeatSecondNumbersNTimes = 3,\n secondInterval = 1,\n secondLabel,\n secondLimit,\n secondsPickerIsDisabled = false,\n styles: customStyles,\n use12HourPicker = false,\n ...otherProps\n } = props;\n\n useEffect(() => {\n if (otherProps.Audio) {\n console.warn(\n 'The \"Audio\" prop is deprecated and will be removed in a future version. Please use the \"pickerFeedback\" prop instead.'\n );\n }\n if (otherProps.Haptics) {\n console.warn(\n 'The \"Haptics\" prop is deprecated and will be removed in a future version. Please use the \"pickerFeedback\" prop instead.'\n );\n }\n if (otherProps.clickSoundAsset) {\n console.warn(\n 'The \"clickSoundAsset\" prop is deprecated and will be removed in a future version. Please use the \"pickerFeedback\" prop instead.'\n );\n }\n }, [otherProps.Audio, otherProps.Haptics, otherProps.clickSoundAsset]);\n\n const safePadWithNItems = useMemo(() => {\n if (padWithNItems < 0 || isNaN(padWithNItems)) {\n return 0;\n }\n\n const maxPadWithNItems = hideHours ? 15 : 6;\n\n if (padWithNItems > maxPadWithNItems) {\n return maxPadWithNItems;\n }\n\n return Math.round(padWithNItems);\n }, [hideHours, padWithNItems]);\n\n const safeInitialValue = useMemo(\n () =>\n getSafeInitialValue({\n days: initialValue?.days,\n hours: initialValue?.hours,\n minutes: initialValue?.minutes,\n seconds: initialValue?.seconds,\n }),\n [\n initialValue?.days,\n initialValue?.hours,\n initialValue?.minutes,\n initialValue?.seconds,\n ]\n );\n\n const styles = useMemo(\n () => generateStyles(customStyles),\n\n [customStyles]\n );\n\n const [selectedDays, setSelectedDays] = useState(safeInitialValue.days);\n const [selectedHours, setSelectedHours] = useState(\n safeInitialValue.hours\n );\n const [selectedMinutes, setSelectedMinutes] = useState(\n safeInitialValue.minutes\n );\n const [selectedSeconds, setSelectedSeconds] = useState(\n safeInitialValue.seconds\n );\n\n useEffect(() => {\n onDurationChange?.({\n days: selectedDays,\n hours: selectedHours,\n minutes: selectedMinutes,\n seconds: selectedSeconds,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [selectedDays, selectedHours, selectedMinutes, selectedSeconds]);\n\n const daysDurationScrollRef = useRef<DurationScrollRef>(null);\n const hoursDurationScrollRef = useRef<DurationScrollRef>(null);\n const minutesDurationScrollRef = useRef<DurationScrollRef>(null);\n const secondsDurationScrollRef = useRef<DurationScrollRef>(null);\n\n useImperativeHandle(ref, () => ({\n reset: (options) => {\n setSelectedDays(safeInitialValue.days);\n setSelectedHours(safeInitialValue.hours);\n setSelectedMinutes(safeInitialValue.minutes);\n setSelectedSeconds(safeInitialValue.seconds);\n daysDurationScrollRef.current?.reset(options);\n hoursDurationScrollRef.current?.reset(options);\n minutesDurationScrollRef.current?.reset(options);\n secondsDurationScrollRef.current?.reset(options);\n },\n setValue: (value, options) => {\n if (value.days) {\n setSelectedDays(value.days);\n daysDurationScrollRef.current?.setValue(\n value.days,\n options\n );\n }\n if (value.hours) {\n setSelectedHours(value.hours);\n hoursDurationScrollRef.current?.setValue(\n value.hours,\n options\n );\n }\n if (value.minutes) {\n setSelectedMinutes(value.minutes);\n minutesDurationScrollRef.current?.setValue(\n value.minutes,\n options\n );\n }\n if (value.seconds) {\n setSelectedSeconds(value.seconds);\n secondsDurationScrollRef.current?.setValue(\n value.seconds,\n options\n );\n }\n },\n latestDuration: {\n days: daysDurationScrollRef.current?.latestDuration,\n hours: hoursDurationScrollRef.current?.latestDuration,\n minutes: minutesDurationScrollRef.current?.latestDuration,\n seconds: secondsDurationScrollRef.current?.latestDuration,\n },\n }));\n\n return (\n <View\n {...pickerContainerProps}\n style={styles.pickerContainer}\n testID=\"timer-picker\">\n {!hideDays ? (\n <DurationScroll\n ref={daysDurationScrollRef}\n aggressivelyGetLatestDuration={\n aggressivelyGetLatestDuration\n }\n allowFontScaling={allowFontScaling}\n disableInfiniteScroll={disableInfiniteScroll}\n initialValue={safeInitialValue.days}\n interval={dayInterval}\n isDisabled={daysPickerIsDisabled}\n label={dayLabel ?? \"d\"}\n limit={dayLimit}\n maximumValue={maximumDays}\n onDurationChange={setSelectedDays}\n padNumbersWithZero={padDaysWithZero}\n padWithNItems={safePadWithNItems}\n repeatNumbersNTimes={repeatDayNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={\n props?.repeatDayNumbersNTimes === undefined\n }\n styles={styles}\n testID=\"duration-scroll-day\"\n {...otherProps}\n />\n ) : null}\n {!hideHours ? (\n <DurationScroll\n ref={hoursDurationScrollRef}\n aggressivelyGetLatestDuration={\n aggressivelyGetLatestDuration\n }\n allowFontScaling={allowFontScaling}\n amLabel={amLabel}\n decelerationRate={decelerationRate}\n disableInfiniteScroll={disableInfiniteScroll}\n initialValue={safeInitialValue.hours}\n interval={hourInterval}\n is12HourPicker={use12HourPicker}\n isDisabled={hoursPickerIsDisabled}\n label={\n hourLabel ?? (!use12HourPicker ? \"h\" : undefined)\n }\n limit={hourLimit}\n maximumValue={maximumHours}\n onDurationChange={setSelectedHours}\n padNumbersWithZero={padHoursWithZero}\n padWithNItems={safePadWithNItems}\n pmLabel={pmLabel}\n repeatNumbersNTimes={repeatHourNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={\n props?.repeatHourNumbersNTimes === undefined\n }\n styles={styles}\n testID=\"duration-scroll-hour\"\n {...otherProps}\n />\n ) : null}\n {!hideMinutes ? (\n <DurationScroll\n ref={minutesDurationScrollRef}\n aggressivelyGetLatestDuration={\n aggressivelyGetLatestDuration\n }\n allowFontScaling={allowFontScaling}\n decelerationRate={decelerationRate}\n disableInfiniteScroll={disableInfiniteScroll}\n initialValue={safeInitialValue.minutes}\n interval={minuteInterval}\n isDisabled={minutesPickerIsDisabled}\n label={minuteLabel ?? \"m\"}\n limit={minuteLimit}\n maximumValue={maximumMinutes}\n onDurationChange={setSelectedMinutes}\n padNumbersWithZero={padMinutesWithZero}\n padWithNItems={safePadWithNItems}\n repeatNumbersNTimes={repeatMinuteNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={\n props?.repeatMinuteNumbersNTimes === undefined\n }\n styles={styles}\n testID=\"duration-scroll-minute\"\n {...otherProps}\n />\n ) : null}\n {!hideSeconds ? (\n <DurationScroll\n ref={secondsDurationScrollRef}\n aggressivelyGetLatestDuration={\n aggressivelyGetLatestDuration\n }\n allowFontScaling={allowFontScaling}\n decelerationRate={decelerationRate}\n disableInfiniteScroll={disableInfiniteScroll}\n initialValue={safeInitialValue.seconds}\n interval={secondInterval}\n isDisabled={secondsPickerIsDisabled}\n label={secondLabel ?? \"s\"}\n limit={secondLimit}\n maximumValue={maximumSeconds}\n onDurationChange={setSelectedSeconds}\n padNumbersWithZero={padSecondsWithZero}\n padWithNItems={safePadWithNItems}\n repeatNumbersNTimes={repeatSecondNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={\n props?.repeatSecondNumbersNTimes === undefined\n }\n styles={styles}\n testID=\"duration-scroll-second\"\n {...otherProps}\n />\n ) : null}\n </View>\n );\n }\n);\n\nexport default React.memo(TimerPicker);\n"],"mappings":"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","ignoreList":[]}
|