react-native-timer-picker 2.0.0 → 2.0.2

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 (29) hide show
  1. package/README.md +3 -0
  2. package/dist/commonjs/components/DurationScroll/index.js +5 -4
  3. package/dist/commonjs/components/DurationScroll/index.js.map +1 -1
  4. package/dist/commonjs/components/TimerPicker/index.js +7 -6
  5. package/dist/commonjs/components/TimerPicker/index.js.map +1 -1
  6. package/dist/commonjs/components/TimerPicker/styles.js +11 -0
  7. package/dist/commonjs/components/TimerPicker/styles.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/utils/getSafeInitialValue.js +13 -0
  13. package/dist/commonjs/utils/getSafeInitialValue.js.map +1 -0
  14. package/dist/module/components/DurationScroll/index.js +5 -4
  15. package/dist/module/components/DurationScroll/index.js.map +1 -1
  16. package/dist/module/components/TimerPicker/index.js +7 -6
  17. package/dist/module/components/TimerPicker/index.js.map +1 -1
  18. package/dist/module/components/TimerPicker/styles.js +11 -0
  19. package/dist/module/components/TimerPicker/styles.js.map +1 -1
  20. package/dist/module/components/TimerPickerModal/index.js +10 -7
  21. package/dist/module/components/TimerPickerModal/index.js.map +1 -1
  22. package/dist/module/components/TimerPickerModal/styles.js +87 -54
  23. package/dist/module/components/TimerPickerModal/styles.js.map +1 -1
  24. package/dist/module/utils/getSafeInitialValue.js +6 -0
  25. package/dist/module/utils/getSafeInitialValue.js.map +1 -0
  26. package/dist/typescript/components/TimerPicker/styles.d.ts +276 -0
  27. package/dist/typescript/components/TimerPickerModal/styles.d.ts +120 -8
  28. package/dist/typescript/utils/getSafeInitialValue.d.ts +9 -0
  29. package/package.json +1 -1
@@ -9,59 +9,92 @@ const DARK_MODE_BACKGROUND_COLOR = "#232323";
9
9
  const DARK_MODE_TEXT_COLOR = "#E9E9E9";
10
10
  const LIGHT_MODE_BACKGROUND_COLOR = "#F1F1F1";
11
11
  const LIGHT_MODE_TEXT_COLOR = "#1B1B1B";
12
- const generateStyles = customStyles => _reactNative.StyleSheet.create({
13
- container: {
14
- justifyContent: "center",
15
- alignItems: "center",
16
- overflow: "hidden",
17
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.container)
18
- },
19
- contentContainer: {
20
- backgroundColor: (customStyles === null || customStyles === void 0 ? void 0 : customStyles.backgroundColor) ?? ((customStyles === null || customStyles === void 0 ? void 0 : customStyles.theme) === "dark" ? DARK_MODE_BACKGROUND_COLOR : LIGHT_MODE_BACKGROUND_COLOR),
21
- justifyContent: "center",
22
- alignItems: "center",
23
- borderRadius: 20,
24
- padding: 20,
25
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.contentContainer)
26
- },
27
- buttonContainer: {
28
- flexDirection: "row",
29
- marginTop: 25,
30
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.buttonContainer)
31
- },
32
- button: {
33
- marginHorizontal: 12,
34
- paddingVertical: 10,
35
- paddingHorizontal: 20,
36
- borderWidth: 1,
37
- borderRadius: 10,
38
- fontSize: 16,
39
- overflow: "hidden",
40
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.text),
41
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.button)
42
- },
43
- cancelButton: {
44
- borderColor: "gray",
45
- color: (customStyles === null || customStyles === void 0 ? void 0 : customStyles.theme) === "dark" ? DARK_MODE_TEXT_COLOR : "gray",
46
- backgroundColor: (customStyles === null || customStyles === void 0 ? void 0 : customStyles.theme) === "dark" ? "gray" : undefined,
47
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.text),
48
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.cancelButton)
49
- },
50
- confirmButton: {
51
- borderColor: "green",
52
- color: (customStyles === null || customStyles === void 0 ? void 0 : customStyles.theme) === "dark" ? DARK_MODE_TEXT_COLOR : "green",
53
- backgroundColor: (customStyles === null || customStyles === void 0 ? void 0 : customStyles.theme) === "dark" ? "green" : undefined,
54
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.text),
55
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.confirmButton)
56
- },
57
- modalTitle: {
58
- fontSize: 24,
59
- fontWeight: "600",
60
- marginBottom: 15,
61
- color: (customStyles === null || customStyles === void 0 ? void 0 : customStyles.theme) === "dark" ? DARK_MODE_TEXT_COLOR : LIGHT_MODE_TEXT_COLOR,
62
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.text),
63
- ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.modalTitle)
64
- }
65
- });
12
+ const generateStyles = (customStyles, variables) => {
13
+ const {
14
+ button: customButtonStyle,
15
+ buttonContainer: customButtonContainerStyle,
16
+ cancelButton: customCancelButtonStyle,
17
+ confirmButton: customConfirmButtonStyle,
18
+ container: customContainerStyle,
19
+ contentContainer: customContentContainerStyle,
20
+ modalTitle: customModalTitleStyle,
21
+ ...customTimerPickerStyles
22
+ } = customStyles ?? {};
23
+ return _reactNative.StyleSheet.create({
24
+ container: {
25
+ justifyContent: "center",
26
+ overflow: "hidden",
27
+ ...customContainerStyle,
28
+ // disable setting alignItems here because it can affect
29
+ // the FlatList's ability to calculate its layout, which can
30
+ // stop snapToOffsets working properly
31
+ alignItems: undefined
32
+ },
33
+ contentContainer: {
34
+ backgroundColor: (customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.backgroundColor) ?? ((customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.theme) === "dark" ? DARK_MODE_BACKGROUND_COLOR : LIGHT_MODE_BACKGROUND_COLOR),
35
+ justifyContent: "center",
36
+ alignItems: "center",
37
+ borderRadius: 20,
38
+ overflow: "hidden",
39
+ ...customContentContainerStyle,
40
+ // disable setting padding here because it can affect
41
+ // the FlatList's ability to calculate its layout, which can
42
+ // stop snapToOffsets working properly
43
+ paddingHorizontal: 0,
44
+ paddingVertical: 0
45
+ },
46
+ buttonContainer: {
47
+ flexDirection: "row",
48
+ marginTop: 25,
49
+ marginBottom: 20,
50
+ ...customButtonContainerStyle
51
+ },
52
+ button: {
53
+ marginHorizontal: 12,
54
+ paddingVertical: 10,
55
+ paddingHorizontal: 20,
56
+ borderWidth: 1,
57
+ borderRadius: 10,
58
+ fontSize: 16,
59
+ overflow: "hidden",
60
+ ...(customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.text),
61
+ ...customButtonStyle
62
+ },
63
+ cancelButton: {
64
+ borderColor: "gray",
65
+ color: (customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.theme) === "dark" ? DARK_MODE_TEXT_COLOR : "gray",
66
+ backgroundColor: (customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.theme) === "dark" ? "gray" : undefined,
67
+ ...(customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.text),
68
+ ...customCancelButtonStyle
69
+ },
70
+ confirmButton: {
71
+ borderColor: "green",
72
+ color: (customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.theme) === "dark" ? DARK_MODE_TEXT_COLOR : "green",
73
+ backgroundColor: (customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.theme) === "dark" ? "green" : undefined,
74
+ ...(customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.text),
75
+ ...customConfirmButtonStyle
76
+ },
77
+ modalTitle: {
78
+ fontSize: 24,
79
+ fontWeight: "600",
80
+ marginTop: 20,
81
+ marginBottom: 15,
82
+ color: (customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.theme) === "dark" ? DARK_MODE_TEXT_COLOR : LIGHT_MODE_TEXT_COLOR,
83
+ ...(customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.text),
84
+ ...customModalTitleStyle
85
+ },
86
+ timerPickerStyles: {
87
+ ...customTimerPickerStyles,
88
+ pickerContainer: {
89
+ // set padding here instead of on modal content container because it can affect
90
+ // the FlatList's ability to calculate its layout, which can
91
+ // stop snapToOffsets working properly
92
+ paddingHorizontal: 20,
93
+ paddingTop: !(variables !== null && variables !== void 0 && variables.hasModalTitle) ? 20 : 0,
94
+ ...((customTimerPickerStyles === null || customTimerPickerStyles === void 0 ? void 0 : customTimerPickerStyles.pickerContainer) ?? {})
95
+ }
96
+ }
97
+ });
98
+ };
66
99
  exports.generateStyles = generateStyles;
67
100
  //# sourceMappingURL=styles.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["_reactNative","require","DARK_MODE_BACKGROUND_COLOR","DARK_MODE_TEXT_COLOR","LIGHT_MODE_BACKGROUND_COLOR","LIGHT_MODE_TEXT_COLOR","generateStyles","customStyles","StyleSheet","create","container","justifyContent","alignItems","overflow","contentContainer","backgroundColor","theme","borderRadius","padding","buttonContainer","flexDirection","marginTop","button","marginHorizontal","paddingVertical","paddingHorizontal","borderWidth","fontSize","text","cancelButton","borderColor","color","undefined","confirmButton","modalTitle","fontWeight","marginBottom","exports"],"sources":["styles.ts"],"sourcesContent":["import { StyleSheet } from \"react-native\";\nimport type { TextStyle, ViewStyle } from \"react-native\";\n\nimport type { CustomTimerPickerStyles } from \"../TimerPicker/styles\";\n\nexport interface CustomTimerPickerModalStyles extends CustomTimerPickerStyles {\n button?: TextStyle;\n buttonContainer?: ViewStyle;\n cancelButton?: TextStyle;\n confirmButton?: TextStyle;\n container?: ViewStyle;\n contentContainer?: ViewStyle;\n modalTitle?: TextStyle;\n}\n\nconst DARK_MODE_BACKGROUND_COLOR = \"#232323\";\nconst DARK_MODE_TEXT_COLOR = \"#E9E9E9\";\nconst LIGHT_MODE_BACKGROUND_COLOR = \"#F1F1F1\";\nconst LIGHT_MODE_TEXT_COLOR = \"#1B1B1B\";\n\nexport const generateStyles = (\n customStyles: CustomTimerPickerModalStyles | undefined\n) =>\n StyleSheet.create({\n container: {\n justifyContent: \"center\",\n alignItems: \"center\",\n overflow: \"hidden\",\n ...customStyles?.container,\n },\n contentContainer: {\n backgroundColor:\n customStyles?.backgroundColor ??\n (customStyles?.theme === \"dark\"\n ? DARK_MODE_BACKGROUND_COLOR\n : LIGHT_MODE_BACKGROUND_COLOR),\n justifyContent: \"center\",\n alignItems: \"center\",\n borderRadius: 20,\n padding: 20,\n ...customStyles?.contentContainer,\n },\n buttonContainer: {\n flexDirection: \"row\",\n marginTop: 25,\n ...customStyles?.buttonContainer,\n },\n button: {\n marginHorizontal: 12,\n paddingVertical: 10,\n paddingHorizontal: 20,\n borderWidth: 1,\n borderRadius: 10,\n fontSize: 16,\n overflow: \"hidden\",\n ...customStyles?.text,\n ...customStyles?.button,\n },\n cancelButton: {\n borderColor: \"gray\",\n color:\n customStyles?.theme === \"dark\" ? DARK_MODE_TEXT_COLOR : \"gray\",\n backgroundColor:\n customStyles?.theme === \"dark\" ? \"gray\" : undefined,\n ...customStyles?.text,\n ...customStyles?.cancelButton,\n },\n confirmButton: {\n borderColor: \"green\",\n color:\n customStyles?.theme === \"dark\" ? DARK_MODE_TEXT_COLOR : \"green\",\n backgroundColor:\n customStyles?.theme === \"dark\" ? \"green\" : undefined,\n ...customStyles?.text,\n ...customStyles?.confirmButton,\n },\n modalTitle: {\n fontSize: 24,\n fontWeight: \"600\",\n marginBottom: 15,\n color:\n customStyles?.theme === \"dark\"\n ? DARK_MODE_TEXT_COLOR\n : LIGHT_MODE_TEXT_COLOR,\n ...customStyles?.text,\n ...customStyles?.modalTitle,\n },\n });\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_reactNative","require","DARK_MODE_BACKGROUND_COLOR","DARK_MODE_TEXT_COLOR","LIGHT_MODE_BACKGROUND_COLOR","LIGHT_MODE_TEXT_COLOR","generateStyles","customStyles","variables","button","customButtonStyle","buttonContainer","customButtonContainerStyle","cancelButton","customCancelButtonStyle","confirmButton","customConfirmButtonStyle","container","customContainerStyle","contentContainer","customContentContainerStyle","modalTitle","customModalTitleStyle","customTimerPickerStyles","StyleSheet","create","justifyContent","overflow","alignItems","undefined","backgroundColor","theme","borderRadius","paddingHorizontal","paddingVertical","flexDirection","marginTop","marginBottom","marginHorizontal","borderWidth","fontSize","text","borderColor","color","fontWeight","timerPickerStyles","pickerContainer","paddingTop","hasModalTitle","exports"],"sources":["styles.ts"],"sourcesContent":["import { StyleSheet } from \"react-native\";\nimport type { TextStyle, ViewStyle } from \"react-native\";\n\nimport type { CustomTimerPickerStyles } from \"../TimerPicker/styles\";\n\nexport interface CustomTimerPickerModalStyles extends CustomTimerPickerStyles {\n button?: TextStyle;\n buttonContainer?: ViewStyle;\n cancelButton?: TextStyle;\n confirmButton?: TextStyle;\n container?: ViewStyle;\n contentContainer?: ViewStyle;\n modalTitle?: TextStyle;\n}\n\nconst DARK_MODE_BACKGROUND_COLOR = \"#232323\";\nconst DARK_MODE_TEXT_COLOR = \"#E9E9E9\";\nconst LIGHT_MODE_BACKGROUND_COLOR = \"#F1F1F1\";\nconst LIGHT_MODE_TEXT_COLOR = \"#1B1B1B\";\n\nexport const generateStyles = (\n customStyles: CustomTimerPickerModalStyles | undefined,\n variables?: {\n hasModalTitle: boolean;\n }\n) => {\n const {\n button: customButtonStyle,\n buttonContainer: customButtonContainerStyle,\n cancelButton: customCancelButtonStyle,\n confirmButton: customConfirmButtonStyle,\n container: customContainerStyle,\n contentContainer: customContentContainerStyle,\n modalTitle: customModalTitleStyle,\n ...customTimerPickerStyles\n } = customStyles ?? {};\n\n return StyleSheet.create({\n container: {\n justifyContent: \"center\",\n overflow: \"hidden\",\n ...customContainerStyle,\n // disable setting alignItems here because it can affect\n // the FlatList's ability to calculate its layout, which can\n // stop snapToOffsets working properly\n alignItems: undefined,\n },\n contentContainer: {\n backgroundColor:\n customTimerPickerStyles?.backgroundColor ??\n (customTimerPickerStyles?.theme === \"dark\"\n ? DARK_MODE_BACKGROUND_COLOR\n : LIGHT_MODE_BACKGROUND_COLOR),\n justifyContent: \"center\",\n alignItems: \"center\",\n borderRadius: 20,\n overflow: \"hidden\",\n ...customContentContainerStyle,\n // disable setting padding here because it can affect\n // the FlatList's ability to calculate its layout, which can\n // stop snapToOffsets working properly\n paddingHorizontal: 0,\n paddingVertical: 0,\n },\n buttonContainer: {\n flexDirection: \"row\",\n marginTop: 25,\n marginBottom: 20,\n ...customButtonContainerStyle,\n },\n button: {\n marginHorizontal: 12,\n paddingVertical: 10,\n paddingHorizontal: 20,\n borderWidth: 1,\n borderRadius: 10,\n fontSize: 16,\n overflow: \"hidden\",\n ...customTimerPickerStyles?.text,\n ...customButtonStyle,\n },\n cancelButton: {\n borderColor: \"gray\",\n color:\n customTimerPickerStyles?.theme === \"dark\"\n ? DARK_MODE_TEXT_COLOR\n : \"gray\",\n backgroundColor:\n customTimerPickerStyles?.theme === \"dark\" ? \"gray\" : undefined,\n ...customTimerPickerStyles?.text,\n ...customCancelButtonStyle,\n },\n confirmButton: {\n borderColor: \"green\",\n color:\n customTimerPickerStyles?.theme === \"dark\"\n ? DARK_MODE_TEXT_COLOR\n : \"green\",\n backgroundColor:\n customTimerPickerStyles?.theme === \"dark\" ? \"green\" : undefined,\n ...customTimerPickerStyles?.text,\n ...customConfirmButtonStyle,\n },\n modalTitle: {\n fontSize: 24,\n fontWeight: \"600\",\n marginTop: 20,\n marginBottom: 15,\n color:\n customTimerPickerStyles?.theme === \"dark\"\n ? DARK_MODE_TEXT_COLOR\n : LIGHT_MODE_TEXT_COLOR,\n ...customTimerPickerStyles?.text,\n ...customModalTitleStyle,\n },\n timerPickerStyles: {\n ...customTimerPickerStyles,\n pickerContainer: {\n // set padding here instead of on modal content container because it can affect\n // the FlatList's ability to calculate its layout, which can\n // stop snapToOffsets working properly\n paddingHorizontal: 20,\n paddingTop: !variables?.hasModalTitle ? 20 : 0,\n ...(customTimerPickerStyles?.pickerContainer ?? {}),\n },\n },\n });\n};\n"],"mappings":";;;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AAeA,MAAMC,0BAA0B,GAAG,SAAS;AAC5C,MAAMC,oBAAoB,GAAG,SAAS;AACtC,MAAMC,2BAA2B,GAAG,SAAS;AAC7C,MAAMC,qBAAqB,GAAG,SAAS;AAEhC,MAAMC,cAAc,GAAGA,CAC1BC,YAAsD,EACtDC,SAEC,KACA;EACD,MAAM;IACFC,MAAM,EAAEC,iBAAiB;IACzBC,eAAe,EAAEC,0BAA0B;IAC3CC,YAAY,EAAEC,uBAAuB;IACrCC,aAAa,EAAEC,wBAAwB;IACvCC,SAAS,EAAEC,oBAAoB;IAC/BC,gBAAgB,EAAEC,2BAA2B;IAC7CC,UAAU,EAAEC,qBAAqB;IACjC,GAAGC;EACP,CAAC,GAAGhB,YAAY,IAAI,CAAC,CAAC;EAEtB,OAAOiB,uBAAU,CAACC,MAAM,CAAC;IACrBR,SAAS,EAAE;MACPS,cAAc,EAAE,QAAQ;MACxBC,QAAQ,EAAE,QAAQ;MAClB,GAAGT,oBAAoB;MACvB;MACA;MACA;MACAU,UAAU,EAAEC;IAChB,CAAC;IACDV,gBAAgB,EAAE;MACdW,eAAe,EACX,CAAAP,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEO,eAAe,MACvC,CAAAP,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEQ,KAAK,MAAK,MAAM,GACpC7B,0BAA0B,GAC1BE,2BAA2B,CAAC;MACtCsB,cAAc,EAAE,QAAQ;MACxBE,UAAU,EAAE,QAAQ;MACpBI,YAAY,EAAE,EAAE;MAChBL,QAAQ,EAAE,QAAQ;MAClB,GAAGP,2BAA2B;MAC9B;MACA;MACA;MACAa,iBAAiB,EAAE,CAAC;MACpBC,eAAe,EAAE;IACrB,CAAC;IACDvB,eAAe,EAAE;MACbwB,aAAa,EAAE,KAAK;MACpBC,SAAS,EAAE,EAAE;MACbC,YAAY,EAAE,EAAE;MAChB,GAAGzB;IACP,CAAC;IACDH,MAAM,EAAE;MACJ6B,gBAAgB,EAAE,EAAE;MACpBJ,eAAe,EAAE,EAAE;MACnBD,iBAAiB,EAAE,EAAE;MACrBM,WAAW,EAAE,CAAC;MACdP,YAAY,EAAE,EAAE;MAChBQ,QAAQ,EAAE,EAAE;MACZb,QAAQ,EAAE,QAAQ;MAClB,IAAGJ,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEkB,IAAI;MAChC,GAAG/B;IACP,CAAC;IACDG,YAAY,EAAE;MACV6B,WAAW,EAAE,MAAM;MACnBC,KAAK,EACD,CAAApB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEQ,KAAK,MAAK,MAAM,GACnC5B,oBAAoB,GACpB,MAAM;MAChB2B,eAAe,EACX,CAAAP,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEQ,KAAK,MAAK,MAAM,GAAG,MAAM,GAAGF,SAAS;MAClE,IAAGN,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEkB,IAAI;MAChC,GAAG3B;IACP,CAAC;IACDC,aAAa,EAAE;MACX2B,WAAW,EAAE,OAAO;MACpBC,KAAK,EACD,CAAApB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEQ,KAAK,MAAK,MAAM,GACnC5B,oBAAoB,GACpB,OAAO;MACjB2B,eAAe,EACX,CAAAP,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEQ,KAAK,MAAK,MAAM,GAAG,OAAO,GAAGF,SAAS;MACnE,IAAGN,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEkB,IAAI;MAChC,GAAGzB;IACP,CAAC;IACDK,UAAU,EAAE;MACRmB,QAAQ,EAAE,EAAE;MACZI,UAAU,EAAE,KAAK;MACjBR,SAAS,EAAE,EAAE;MACbC,YAAY,EAAE,EAAE;MAChBM,KAAK,EACD,CAAApB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEQ,KAAK,MAAK,MAAM,GACnC5B,oBAAoB,GACpBE,qBAAqB;MAC/B,IAAGkB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEkB,IAAI;MAChC,GAAGnB;IACP,CAAC;IACDuB,iBAAiB,EAAE;MACf,GAAGtB,uBAAuB;MAC1BuB,eAAe,EAAE;QACb;QACA;QACA;QACAb,iBAAiB,EAAE,EAAE;QACrBc,UAAU,EAAE,EAACvC,SAAS,aAATA,SAAS,eAATA,SAAS,CAAEwC,aAAa,IAAG,EAAE,GAAG,CAAC;QAC9C,IAAI,CAAAzB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEuB,eAAe,KAAI,CAAC,CAAC;MACtD;IACJ;EACJ,CAAC,CAAC;AACN,CAAC;AAACG,OAAA,CAAA3C,cAAA,GAAAA,cAAA","ignoreList":[]}
@@ -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":[]}
@@ -51,7 +51,7 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
51
51
  }
52
52
  if (!disableInfiniteScroll && repeatNumbersNTimes < 2) {
53
53
  return 2;
54
- } else if (repeatNumbersNTimes < 1) {
54
+ } else if (repeatNumbersNTimes < 1 || isNaN(repeatNumbersNTimes)) {
55
55
  return 1;
56
56
  }
57
57
 
@@ -320,14 +320,14 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
320
320
  }));
321
321
  return /*#__PURE__*/React.createElement(View, {
322
322
  pointerEvents: isDisabled ? "none" : undefined,
323
- style: [{
324
- height: styles.pickerItemContainer.height * numberOfItemsToShow,
325
- overflow: "visible"
323
+ style: [styles.durationScrollFlatListContainer, {
324
+ height: styles.pickerItemContainer.height * numberOfItemsToShow
326
325
  }, isDisabled && styles.disabledPickerContainer],
327
326
  testID: testID
328
327
  }, /*#__PURE__*/React.createElement(FlatList, {
329
328
  key: flatListRenderKey,
330
329
  ref: flatListRef,
330
+ contentContainerStyle: styles.durationScrollFlatListContentContainer,
331
331
  data: numbersForFlatList,
332
332
  decelerationRate: 0.88,
333
333
  getItemLayout: getItemLayout,
@@ -344,6 +344,7 @@ const DurationScroll = /*#__PURE__*/forwardRef((props, ref) => {
344
344
  // used in place of snapToInterval due to bug on Android
345
345
  ,
346
346
  snapToOffsets: [...Array(numbersForFlatList.length)].map((_, i) => i * styles.pickerItemContainer.height),
347
+ style: styles.durationScrollFlatList,
347
348
  testID: "duration-scroll-flatlist",
348
349
  viewabilityConfigCallbackPairs: viewabilityConfigCallbackPairs,
349
350
  windowSize: numberOfItemsToShow
@@ -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","interval","is12HourPicker","isDisabled","label","limit","LinearGradient","maximumValue","onDurationChange","padNumbersWithZero","padWithNItems","pickerFeedback","pickerGradientOverlayProps","pmLabel","repeatNumbersNTimes","repeatNumbersNTimesNotExplicitlySet","styles","testID","topPickerGradientOverlayProps","numberOfItems","Math","floor","safeRepeatNumbersNTimes","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) {\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
+ {"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","durationScrollFlatListContainer","disabledPickerContainer","contentContainerStyle","durationScrollFlatListContentContainer","data","decelerationRate","keyExtractor","toString","nestedScrollEnabled","scrollEnabled","scrollEventThrottle","showsVerticalScrollIndicator","snapToAlignment","snapToOffsets","Array","map","i","durationScrollFlatList","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 styles.durationScrollFlatListContainer,\n {\n height:\n styles.pickerItemContainer.height *\n numberOfItemsToShow,\n },\n isDisabled && styles.disabledPickerContainer,\n ]}\n testID={testID}>\n <FlatList\n key={flatListRenderKey}\n ref={flatListRef}\n contentContainerStyle={\n styles.durationScrollFlatListContentContainer\n }\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 style={styles.durationScrollFlatList}\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,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) => {
@@ -43,7 +44,7 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
43
44
  ...otherProps
44
45
  } = props;
45
46
  const safePadWithNItems = useMemo(() => {
46
- if (padWithNItems < 0) {
47
+ if (padWithNItems < 0 || isNaN(padWithNItems)) {
47
48
  return 0;
48
49
  }
49
50
  const maxPadWithNItems = hideHours ? 15 : 6;
@@ -52,14 +53,14 @@ const TimerPicker = /*#__PURE__*/forwardRef((props, ref) => {
52
53
  }
53
54
  return Math.round(padWithNItems);
54
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]);
55
61
  const styles = useMemo(() => generateStyles(customStyles, {
56
62
  padWithNItems: safePadWithNItems
57
63
  }), [safePadWithNItems, customStyles]);
58
- const safeInitialValue = useMemo(() => ({
59
- hours: (initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours) ?? 0,
60
- minutes: (initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes) ?? 0,
61
- seconds: (initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds) ?? 0
62
- }), [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]);
63
64
  const [selectedHours, setSelectedHours] = useState(safeInitialValue.hours);
64
65
  const [selectedMinutes, setSelectedMinutes] = useState(safeInitialValue.minutes);
65
66
  const [selectedSeconds, setSelectedSeconds] = useState(safeInitialValue.seconds);
@@ -1 +1 @@
1
- {"version":3,"names":["React","forwardRef","useEffect","useImperativeHandle","useMemo","useRef","useState","View","DurationScroll","generateStyles","TimerPicker","props","ref","aggressivelyGetLatestDuration","allowFontScaling","amLabel","disableInfiniteScroll","hideHours","hideMinutes","hideSeconds","hourInterval","hourLabel","hourLimit","hoursPickerIsDisabled","initialValue","maximumHours","maximumMinutes","maximumSeconds","minuteInterval","minuteLabel","minuteLimit","minutesPickerIsDisabled","onDurationChange","padHoursWithZero","padMinutesWithZero","padSecondsWithZero","padWithNItems","pickerContainerProps","pmLabel","repeatHourNumbersNTimes","repeatMinuteNumbersNTimes","repeatSecondNumbersNTimes","secondInterval","secondLabel","secondLimit","secondsPickerIsDisabled","styles","customStyles","use12HourPicker","otherProps","safePadWithNItems","maxPadWithNItems","Math","round","safeInitialValue","hours","minutes","seconds","selectedHours","setSelectedHours","selectedMinutes","setSelectedMinutes","selectedSeconds","setSelectedSeconds","hoursDurationScrollRef","minutesDurationScrollRef","secondsDurationScrollRef","_hoursDurationScrollR3","_minutesDurationScrol3","_secondsDurationScrol3","reset","options","_hoursDurationScrollR","_minutesDurationScrol","_secondsDurationScrol","current","setValue","value","_hoursDurationScrollR2","_minutesDurationScrol2","_secondsDurationScrol2","latestDuration","createElement","_extends","style","pickerContainer","testID","interval","is12HourPicker","isDisabled","label","undefined","limit","maximumValue","padNumbersWithZero","repeatNumbersNTimes","repeatNumbersNTimesNotExplicitlySet","memo"],"sources":["index.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 DurationScroll from \"../DurationScroll\";\nimport type { DurationScrollRef } from \"../DurationScroll/types\";\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 disableInfiniteScroll = false,\n hideHours = false,\n hideMinutes = false,\n hideSeconds = false,\n hourInterval = 1,\n hourLabel,\n hourLimit,\n hoursPickerIsDisabled = false,\n initialValue,\n maximumHours = 23,\n maximumMinutes = 59,\n maximumSeconds = 59,\n minuteInterval = 1,\n minuteLabel,\n minuteLimit,\n minutesPickerIsDisabled = false,\n onDurationChange,\n padHoursWithZero = false,\n padMinutesWithZero = true,\n padSecondsWithZero = true,\n padWithNItems = 1,\n pickerContainerProps,\n pmLabel = \"pm\",\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 const safePadWithNItems = useMemo(() => {\n if (padWithNItems < 0) {\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 styles = useMemo(\n () =>\n generateStyles(customStyles, {\n padWithNItems: safePadWithNItems,\n }),\n\n [safePadWithNItems, customStyles]\n );\n\n const safeInitialValue = useMemo(\n () => ({\n hours: initialValue?.hours ?? 0,\n minutes: initialValue?.minutes ?? 0,\n seconds: initialValue?.seconds ?? 0,\n }),\n [initialValue?.hours, initialValue?.minutes, initialValue?.seconds]\n );\n\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 hours: selectedHours,\n minutes: selectedMinutes,\n seconds: selectedSeconds,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [selectedHours, selectedMinutes, selectedSeconds]);\n\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 setSelectedHours(safeInitialValue.hours);\n setSelectedMinutes(safeInitialValue.minutes);\n setSelectedSeconds(safeInitialValue.seconds);\n hoursDurationScrollRef.current?.reset(options);\n minutesDurationScrollRef.current?.reset(options);\n secondsDurationScrollRef.current?.reset(options);\n },\n setValue: (value, options) => {\n setSelectedHours(value.hours);\n setSelectedMinutes(value.minutes);\n setSelectedSeconds(value.seconds);\n hoursDurationScrollRef.current?.setValue(value.hours, options);\n minutesDurationScrollRef.current?.setValue(\n value.minutes,\n options\n );\n secondsDurationScrollRef.current?.setValue(\n value.seconds,\n options\n );\n },\n 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 {!hideHours ? (\n <DurationScroll\n ref={hoursDurationScrollRef}\n aggressivelyGetLatestDuration={\n aggressivelyGetLatestDuration\n }\n allowFontScaling={allowFontScaling}\n amLabel={amLabel}\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 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 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":[]}
1
+ {"version":3,"names":["React","forwardRef","useEffect","useImperativeHandle","useMemo","useRef","useState","View","getSafeInitialValue","DurationScroll","generateStyles","TimerPicker","props","ref","aggressivelyGetLatestDuration","allowFontScaling","amLabel","disableInfiniteScroll","hideHours","hideMinutes","hideSeconds","hourInterval","hourLabel","hourLimit","hoursPickerIsDisabled","initialValue","maximumHours","maximumMinutes","maximumSeconds","minuteInterval","minuteLabel","minuteLimit","minutesPickerIsDisabled","onDurationChange","padHoursWithZero","padMinutesWithZero","padSecondsWithZero","padWithNItems","pickerContainerProps","pmLabel","repeatHourNumbersNTimes","repeatMinuteNumbersNTimes","repeatSecondNumbersNTimes","secondInterval","secondLabel","secondLimit","secondsPickerIsDisabled","styles","customStyles","use12HourPicker","otherProps","safePadWithNItems","isNaN","maxPadWithNItems","Math","round","safeInitialValue","hours","minutes","seconds","selectedHours","setSelectedHours","selectedMinutes","setSelectedMinutes","selectedSeconds","setSelectedSeconds","hoursDurationScrollRef","minutesDurationScrollRef","secondsDurationScrollRef","_hoursDurationScrollR3","_minutesDurationScrol3","_secondsDurationScrol3","reset","options","_hoursDurationScrollR","_minutesDurationScrol","_secondsDurationScrol","current","setValue","value","_hoursDurationScrollR2","_minutesDurationScrol2","_secondsDurationScrol2","latestDuration","createElement","_extends","style","pickerContainer","testID","interval","is12HourPicker","isDisabled","label","undefined","limit","maximumValue","padNumbersWithZero","repeatNumbersNTimes","repeatNumbersNTimesNotExplicitlySet","memo"],"sources":["index.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/types\";\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 disableInfiniteScroll = false,\n hideHours = false,\n hideMinutes = false,\n hideSeconds = false,\n hourInterval = 1,\n hourLabel,\n hourLimit,\n hoursPickerIsDisabled = false,\n initialValue,\n maximumHours = 23,\n maximumMinutes = 59,\n maximumSeconds = 59,\n minuteInterval = 1,\n minuteLabel,\n minuteLimit,\n minutesPickerIsDisabled = false,\n onDurationChange,\n padHoursWithZero = false,\n padMinutesWithZero = true,\n padSecondsWithZero = true,\n padWithNItems = 1,\n pickerContainerProps,\n pmLabel = \"pm\",\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 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 hours: initialValue?.hours,\n minutes: initialValue?.minutes,\n seconds: initialValue?.seconds,\n }),\n [initialValue?.hours, initialValue?.minutes, initialValue?.seconds]\n );\n\n const styles = useMemo(\n () =>\n generateStyles(customStyles, {\n padWithNItems: safePadWithNItems,\n }),\n\n [safePadWithNItems, customStyles]\n );\n\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 hours: selectedHours,\n minutes: selectedMinutes,\n seconds: selectedSeconds,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [selectedHours, selectedMinutes, selectedSeconds]);\n\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 setSelectedHours(safeInitialValue.hours);\n setSelectedMinutes(safeInitialValue.minutes);\n setSelectedSeconds(safeInitialValue.seconds);\n hoursDurationScrollRef.current?.reset(options);\n minutesDurationScrollRef.current?.reset(options);\n secondsDurationScrollRef.current?.reset(options);\n },\n setValue: (value, options) => {\n setSelectedHours(value.hours);\n setSelectedMinutes(value.minutes);\n setSelectedSeconds(value.seconds);\n hoursDurationScrollRef.current?.setValue(value.hours, options);\n minutesDurationScrollRef.current?.setValue(\n value.minutes,\n options\n );\n secondsDurationScrollRef.current?.setValue(\n value.seconds,\n options\n );\n },\n 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 {!hideHours ? (\n <DurationScroll\n ref={hoursDurationScrollRef}\n aggressivelyGetLatestDuration={\n aggressivelyGetLatestDuration\n }\n allowFontScaling={allowFontScaling}\n amLabel={amLabel}\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 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 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":[]}
@@ -76,6 +76,17 @@ export const generateStyles = (customStyles, options) => {
76
76
  right: 0,
77
77
  height: options.padWithNItems === 0 ? "30%" : ((customStyles === null || customStyles === void 0 || (_customStyles$pickerI4 = customStyles.pickerItemContainer) === null || _customStyles$pickerI4 === void 0 ? void 0 : _customStyles$pickerI4.height) ?? 50) * 0.8,
78
78
  ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.pickerGradientOverlay)
79
+ },
80
+ durationScrollFlatList: {
81
+ minWidth: 1,
82
+ ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.durationScrollFlatList)
83
+ },
84
+ durationScrollFlatListContainer: {
85
+ overflow: "visible",
86
+ ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.durationScrollFlatListContainer)
87
+ },
88
+ durationScrollFlatListContentContainer: {
89
+ ...(customStyles === null || customStyles === void 0 ? void 0 : customStyles.durationScrollFlatListContentContainer)
79
90
  }
80
91
  });
81
92
  };