react-native-timer-picker 2.6.0 → 2.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commonjs/components/DurationScroll/DurationScroll.js +426 -0
- package/dist/commonjs/components/DurationScroll/DurationScroll.js.map +1 -0
- package/dist/commonjs/components/DurationScroll/index.js +27 -0
- package/dist/commonjs/components/DurationScroll/index.js.map +1 -0
- package/dist/commonjs/components/DurationScroll/types.js +6 -0
- package/dist/commonjs/components/DurationScroll/types.js.map +1 -0
- package/dist/commonjs/components/Modal/Modal.js +107 -0
- package/dist/commonjs/components/Modal/Modal.js.map +1 -0
- package/dist/commonjs/components/Modal/index.js +27 -0
- package/dist/commonjs/components/Modal/index.js.map +1 -0
- package/dist/commonjs/components/Modal/styles.js +25 -0
- package/dist/commonjs/components/Modal/styles.js.map +1 -0
- package/dist/commonjs/components/Modal/types.js +6 -0
- package/dist/commonjs/components/Modal/types.js.map +1 -0
- package/dist/commonjs/components/PickerItem/PickerItem.js +48 -0
- package/dist/commonjs/components/PickerItem/PickerItem.js.map +1 -0
- package/dist/commonjs/components/PickerItem/index.js +14 -0
- package/dist/commonjs/components/PickerItem/index.js.map +1 -0
- package/dist/commonjs/components/TimerPicker/TimerPicker.js +266 -0
- package/dist/commonjs/components/TimerPicker/TimerPicker.js.map +1 -0
- package/dist/commonjs/components/TimerPicker/index.js +39 -0
- package/dist/commonjs/components/TimerPicker/index.js.map +1 -0
- package/dist/commonjs/components/TimerPicker/styles.js +140 -0
- package/dist/commonjs/components/TimerPicker/styles.js.map +1 -0
- package/dist/commonjs/components/TimerPicker/types.js +6 -0
- package/dist/commonjs/components/TimerPicker/types.js.map +1 -0
- package/dist/commonjs/components/TimerPickerModal/TimerPickerModal.js +173 -0
- package/dist/commonjs/components/TimerPickerModal/TimerPickerModal.js.map +1 -0
- package/dist/commonjs/components/TimerPickerModal/index.js +39 -0
- package/dist/commonjs/components/TimerPickerModal/index.js.map +1 -0
- package/dist/commonjs/components/TimerPickerModal/styles.js +95 -0
- package/dist/commonjs/components/TimerPickerModal/styles.js.map +1 -0
- package/dist/commonjs/components/TimerPickerModal/types.js +6 -0
- package/dist/commonjs/components/TimerPickerModal/types.js.map +1 -0
- package/dist/commonjs/index.js +21 -0
- package/dist/commonjs/index.js.map +1 -0
- package/dist/commonjs/tests/DurationScroll.test.js +163 -0
- package/dist/commonjs/tests/DurationScroll.test.js.map +1 -0
- package/dist/commonjs/tests/Modal.test.js +99 -0
- package/dist/commonjs/tests/Modal.test.js.map +1 -0
- package/dist/commonjs/tests/TimerPicker.test.js +161 -0
- package/dist/commonjs/tests/TimerPicker.test.js.map +1 -0
- package/dist/commonjs/tests/TimerPickerModal.test.js +276 -0
- package/dist/commonjs/tests/TimerPickerModal.test.js.map +1 -0
- package/dist/commonjs/tests/colorToRgba.test.js +176 -0
- package/dist/commonjs/tests/colorToRgba.test.js.map +1 -0
- package/dist/commonjs/tests/generateNumbers.test.js +350 -0
- package/dist/commonjs/tests/generateNumbers.test.js.map +1 -0
- package/dist/commonjs/tests/getAdjustedLimit.test.js +324 -0
- package/dist/commonjs/tests/getAdjustedLimit.test.js.map +1 -0
- package/dist/commonjs/tests/getDurationAndIndexFromScrollOffset.test.js +424 -0
- package/dist/commonjs/tests/getDurationAndIndexFromScrollOffset.test.js.map +1 -0
- package/dist/commonjs/tests/getInitialScrollIndex.test.js +396 -0
- package/dist/commonjs/tests/getInitialScrollIndex.test.js.map +1 -0
- package/dist/commonjs/tests/getSafeInitialValue.test.js +499 -0
- package/dist/commonjs/tests/getSafeInitialValue.test.js.map +1 -0
- package/dist/commonjs/tests/padNumber.test.js +301 -0
- package/dist/commonjs/tests/padNumber.test.js.map +1 -0
- package/dist/commonjs/utils/colorToRgba.js +87 -0
- package/dist/commonjs/utils/colorToRgba.js.map +1 -0
- package/dist/commonjs/utils/generateNumbers.js +124 -0
- package/dist/commonjs/utils/generateNumbers.js.map +1 -0
- package/dist/commonjs/utils/getAdjustedLimit.js +58 -0
- package/dist/commonjs/utils/getAdjustedLimit.js.map +1 -0
- package/dist/commonjs/utils/getDurationAndIndexFromScrollOffset.js +62 -0
- package/dist/commonjs/utils/getDurationAndIndexFromScrollOffset.js.map +1 -0
- package/dist/commonjs/utils/getInitialScrollIndex.js +57 -0
- package/dist/commonjs/utils/getInitialScrollIndex.js.map +1 -0
- package/dist/commonjs/utils/getSafeInitialValue.js +41 -0
- package/dist/commonjs/utils/getSafeInitialValue.js.map +1 -0
- package/dist/commonjs/utils/padNumber.js +40 -0
- package/dist/commonjs/utils/padNumber.js.map +1 -0
- package/dist/module/components/DurationScroll/DurationScroll.js +418 -0
- package/dist/module/components/DurationScroll/DurationScroll.js.map +1 -0
- package/dist/module/components/DurationScroll/index.js +3 -0
- package/dist/module/components/DurationScroll/index.js.map +1 -0
- package/dist/module/components/DurationScroll/types.js +2 -0
- package/dist/module/components/DurationScroll/types.js.map +1 -0
- package/dist/module/components/Modal/Modal.js +99 -0
- package/dist/module/components/Modal/Modal.js.map +1 -0
- package/dist/module/components/Modal/index.js +3 -0
- package/dist/module/components/Modal/index.js.map +1 -0
- package/dist/module/components/Modal/styles.js +19 -0
- package/dist/module/components/Modal/styles.js.map +1 -0
- package/dist/module/components/Modal/types.js +2 -0
- package/dist/module/components/Modal/types.js.map +1 -0
- package/dist/module/components/PickerItem/PickerItem.js +41 -0
- package/dist/module/components/PickerItem/PickerItem.js.map +1 -0
- package/dist/module/components/PickerItem/index.js +2 -0
- package/dist/module/components/PickerItem/index.js.map +1 -0
- package/dist/module/components/TimerPicker/TimerPicker.js +258 -0
- package/dist/module/components/TimerPicker/TimerPicker.js.map +1 -0
- package/dist/module/components/TimerPicker/index.js +4 -0
- package/dist/module/components/TimerPicker/index.js.map +1 -0
- package/dist/module/components/TimerPicker/styles.js +133 -0
- package/dist/module/components/TimerPicker/styles.js.map +1 -0
- package/dist/module/components/TimerPicker/types.js +2 -0
- package/dist/module/components/TimerPicker/types.js.map +1 -0
- package/dist/module/components/TimerPickerModal/TimerPickerModal.js +165 -0
- package/dist/module/components/TimerPickerModal/TimerPickerModal.js.map +1 -0
- package/dist/module/components/TimerPickerModal/index.js +4 -0
- package/dist/module/components/TimerPickerModal/index.js.map +1 -0
- package/dist/module/components/TimerPickerModal/styles.js +88 -0
- package/dist/module/components/TimerPickerModal/styles.js.map +1 -0
- package/dist/module/components/TimerPickerModal/types.js +2 -0
- package/dist/module/components/TimerPickerModal/types.js.map +1 -0
- package/dist/module/index.js +3 -0
- package/dist/module/index.js.map +1 -0
- package/dist/module/tests/DurationScroll.test.js +160 -0
- package/dist/module/tests/DurationScroll.test.js.map +1 -0
- package/dist/module/tests/Modal.test.js +96 -0
- package/dist/module/tests/Modal.test.js.map +1 -0
- package/dist/module/tests/TimerPicker.test.js +159 -0
- package/dist/module/tests/TimerPicker.test.js.map +1 -0
- package/dist/module/tests/TimerPickerModal.test.js +273 -0
- package/dist/module/tests/TimerPickerModal.test.js.map +1 -0
- package/dist/module/tests/colorToRgba.test.js +174 -0
- package/dist/module/tests/colorToRgba.test.js.map +1 -0
- package/dist/module/tests/generateNumbers.test.js +348 -0
- package/dist/module/tests/generateNumbers.test.js.map +1 -0
- package/dist/module/tests/getAdjustedLimit.test.js +322 -0
- package/dist/module/tests/getAdjustedLimit.test.js.map +1 -0
- package/dist/module/tests/getDurationAndIndexFromScrollOffset.test.js +422 -0
- package/dist/module/tests/getDurationAndIndexFromScrollOffset.test.js.map +1 -0
- package/dist/module/tests/getInitialScrollIndex.test.js +394 -0
- package/dist/module/tests/getInitialScrollIndex.test.js.map +1 -0
- package/dist/module/tests/getSafeInitialValue.test.js +496 -0
- package/dist/module/tests/getSafeInitialValue.test.js.map +1 -0
- package/dist/module/tests/padNumber.test.js +299 -0
- package/dist/module/tests/padNumber.test.js.map +1 -0
- package/dist/module/utils/colorToRgba.js +80 -0
- package/dist/module/utils/colorToRgba.js.map +1 -0
- package/dist/module/utils/generateNumbers.js +117 -0
- package/dist/module/utils/generateNumbers.js.map +1 -0
- package/dist/module/utils/getAdjustedLimit.js +51 -0
- package/dist/module/utils/getAdjustedLimit.js.map +1 -0
- package/dist/module/utils/getDurationAndIndexFromScrollOffset.js +55 -0
- package/dist/module/utils/getDurationAndIndexFromScrollOffset.js.map +1 -0
- package/dist/module/utils/getInitialScrollIndex.js +50 -0
- package/dist/module/utils/getInitialScrollIndex.js.map +1 -0
- package/dist/module/utils/getSafeInitialValue.js +34 -0
- package/dist/module/utils/getSafeInitialValue.js.map +1 -0
- package/dist/module/utils/padNumber.js +33 -0
- package/dist/module/utils/padNumber.js.map +1 -0
- package/dist/typescript/components/DurationScroll/DurationScroll.d.ts +4 -0
- package/dist/typescript/components/DurationScroll/index.d.ts +2 -0
- package/dist/typescript/components/DurationScroll/types.d.ts +70 -0
- package/dist/typescript/components/Modal/Modal.d.ts +5 -0
- package/dist/typescript/components/Modal/index.d.ts +2 -0
- package/dist/typescript/components/Modal/styles.d.ts +17 -0
- package/dist/typescript/components/Modal/types.d.ts +16 -0
- package/dist/typescript/components/PickerItem/PickerItem.d.ts +19 -0
- package/dist/typescript/components/PickerItem/index.d.ts +1 -0
- package/dist/typescript/components/TimerPicker/TimerPicker.d.ts +4 -0
- package/dist/typescript/components/TimerPicker/index.d.ts +3 -0
- package/dist/typescript/components/TimerPicker/styles.d.ts +1583 -0
- package/dist/typescript/components/TimerPicker/types.d.ts +91 -0
- package/dist/typescript/components/TimerPickerModal/TimerPickerModal.d.ts +4 -0
- package/dist/typescript/components/TimerPickerModal/index.d.ts +3 -0
- package/dist/typescript/components/TimerPickerModal/styles.d.ts +952 -0
- package/dist/typescript/components/TimerPickerModal/types.d.ts +56 -0
- package/dist/typescript/index.d.ts +4 -0
- package/dist/typescript/tests/DurationScroll.test.d.ts +1 -0
- package/dist/typescript/tests/Modal.test.d.ts +1 -0
- package/dist/typescript/tests/TimerPicker.test.d.ts +1 -0
- package/dist/typescript/tests/TimerPickerModal.test.d.ts +1 -0
- package/dist/typescript/tests/colorToRgba.test.d.ts +1 -0
- package/dist/typescript/tests/generateNumbers.test.d.ts +1 -0
- package/dist/typescript/tests/getAdjustedLimit.test.d.ts +1 -0
- package/dist/typescript/tests/getDurationAndIndexFromScrollOffset.test.d.ts +1 -0
- package/dist/typescript/tests/getInitialScrollIndex.test.d.ts +1 -0
- package/dist/typescript/tests/getSafeInitialValue.test.d.ts +1 -0
- package/dist/typescript/tests/padNumber.test.d.ts +1 -0
- package/dist/typescript/utils/colorToRgba.d.ts +38 -0
- package/dist/typescript/utils/generateNumbers.d.ts +80 -0
- package/dist/typescript/utils/getAdjustedLimit.d.ts +30 -0
- package/dist/typescript/utils/getDurationAndIndexFromScrollOffset.d.ts +49 -0
- package/dist/typescript/utils/getInitialScrollIndex.d.ts +46 -0
- package/dist/typescript/utils/getSafeInitialValue.d.ts +38 -0
- package/dist/typescript/utils/padNumber.d.ts +28 -0
- package/package.json +3 -2
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = exports.Modal = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
var _styles = require("./styles");
|
|
10
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
11
|
+
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); }
|
|
12
|
+
const Modal = props => {
|
|
13
|
+
const {
|
|
14
|
+
animationDuration = 300,
|
|
15
|
+
children,
|
|
16
|
+
contentStyle,
|
|
17
|
+
isVisible = false,
|
|
18
|
+
modalProps,
|
|
19
|
+
onHide,
|
|
20
|
+
onOverlayPress,
|
|
21
|
+
overlayOpacity = 0.4,
|
|
22
|
+
overlayStyle,
|
|
23
|
+
testID = "modal"
|
|
24
|
+
} = props;
|
|
25
|
+
const {
|
|
26
|
+
height: screenHeight,
|
|
27
|
+
width: screenWidth
|
|
28
|
+
} = (0, _reactNative.useWindowDimensions)();
|
|
29
|
+
const isMounted = (0, _react.useRef)(false);
|
|
30
|
+
const animatedOpacity = (0, _react.useRef)(new _reactNative.Animated.Value(0));
|
|
31
|
+
(0, _react.useEffect)(() => {
|
|
32
|
+
isMounted.current = true;
|
|
33
|
+
if (isVisible) {
|
|
34
|
+
show();
|
|
35
|
+
}
|
|
36
|
+
return () => {
|
|
37
|
+
isMounted.current = false;
|
|
38
|
+
};
|
|
39
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
40
|
+
}, []);
|
|
41
|
+
const backdropAnimatedStyle = {
|
|
42
|
+
opacity: animatedOpacity.current.interpolate({
|
|
43
|
+
inputRange: [0, 1],
|
|
44
|
+
outputRange: [0, overlayOpacity]
|
|
45
|
+
})
|
|
46
|
+
};
|
|
47
|
+
const contentAnimatedStyle = {
|
|
48
|
+
transform: [{
|
|
49
|
+
translateY: animatedOpacity.current.interpolate({
|
|
50
|
+
extrapolate: "clamp",
|
|
51
|
+
inputRange: [0, 1],
|
|
52
|
+
outputRange: [screenHeight, 0]
|
|
53
|
+
})
|
|
54
|
+
}]
|
|
55
|
+
};
|
|
56
|
+
const show = (0, _react.useCallback)(() => {
|
|
57
|
+
_reactNative.Animated.timing(animatedOpacity.current, {
|
|
58
|
+
duration: animationDuration,
|
|
59
|
+
easing: _reactNative.Easing.inOut(_reactNative.Easing.quad),
|
|
60
|
+
toValue: 1,
|
|
61
|
+
// Using native driver in the modal makes the content flash
|
|
62
|
+
useNativeDriver: true
|
|
63
|
+
}).start();
|
|
64
|
+
}, [animationDuration]);
|
|
65
|
+
const hide = (0, _react.useCallback)(() => {
|
|
66
|
+
_reactNative.Animated.timing(animatedOpacity.current, {
|
|
67
|
+
duration: animationDuration,
|
|
68
|
+
easing: _reactNative.Easing.inOut(_reactNative.Easing.quad),
|
|
69
|
+
toValue: 0,
|
|
70
|
+
// Using native driver in the modal makes the content flash
|
|
71
|
+
useNativeDriver: true
|
|
72
|
+
}).start(() => {
|
|
73
|
+
if (isMounted.current) {
|
|
74
|
+
onHide === null || onHide === void 0 || onHide();
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}, [animationDuration, onHide]);
|
|
78
|
+
(0, _react.useEffect)(() => {
|
|
79
|
+
if (isVisible) {
|
|
80
|
+
show();
|
|
81
|
+
} else {
|
|
82
|
+
hide();
|
|
83
|
+
}
|
|
84
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
85
|
+
}, [isVisible]);
|
|
86
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.Modal, _extends({
|
|
87
|
+
animationType: "fade",
|
|
88
|
+
transparent: true,
|
|
89
|
+
visible: isVisible
|
|
90
|
+
}, modalProps, {
|
|
91
|
+
testID: testID
|
|
92
|
+
}), /*#__PURE__*/_react.default.createElement(_reactNative.TouchableWithoutFeedback, {
|
|
93
|
+
onPress: onOverlayPress,
|
|
94
|
+
testID: "modal-backdrop"
|
|
95
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Animated.View, {
|
|
96
|
+
style: [_styles.styles.backdrop, backdropAnimatedStyle, {
|
|
97
|
+
height: screenHeight,
|
|
98
|
+
width: screenWidth
|
|
99
|
+
}, overlayStyle]
|
|
100
|
+
})), /*#__PURE__*/_react.default.createElement(_reactNative.Animated.View, {
|
|
101
|
+
pointerEvents: "box-none",
|
|
102
|
+
style: [_styles.styles.content, contentAnimatedStyle, contentStyle]
|
|
103
|
+
}, children));
|
|
104
|
+
};
|
|
105
|
+
exports.Modal = Modal;
|
|
106
|
+
var _default = exports.default = /*#__PURE__*/_react.default.memo(Modal);
|
|
107
|
+
//# sourceMappingURL=Modal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_styles","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","Modal","props","animationDuration","children","contentStyle","isVisible","modalProps","onHide","onOverlayPress","overlayOpacity","overlayStyle","testID","height","screenHeight","width","screenWidth","useWindowDimensions","isMounted","useRef","animatedOpacity","Animated","Value","useEffect","current","show","backdropAnimatedStyle","opacity","interpolate","inputRange","outputRange","contentAnimatedStyle","transform","translateY","extrapolate","useCallback","timing","duration","easing","Easing","inOut","quad","toValue","useNativeDriver","start","hide","createElement","animationType","transparent","visible","TouchableWithoutFeedback","onPress","View","style","styles","backdrop","pointerEvents","content","exports","_default","React","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 extrapolate: \"clamp\",\n inputRange: [0, 1],\n outputRange: [screenHeight, 0],\n }),\n },\n ],\n };\n\n const show = useCallback(() => {\n Animated.timing(animatedOpacity.current, {\n duration: animationDuration,\n easing: Easing.inOut(Easing.quad),\n toValue: 1,\n // Using native driver in the modal makes the content flash\n useNativeDriver: true,\n }).start();\n }, [animationDuration]);\n\n const hide = useCallback(() => {\n Animated.timing(animatedOpacity.current, {\n duration: animationDuration,\n easing: Easing.inOut(Easing.quad),\n toValue: 0,\n // Using native driver in the modal makes the content flash\n useNativeDriver: true,\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 >\n <TouchableWithoutFeedback onPress={onOverlayPress} testID=\"modal-backdrop\">\n <Animated.View\n style={[\n styles.backdrop,\n backdropAnimatedStyle,\n { height: screenHeight, width: screenWidth },\n overlayStyle,\n ]}\n />\n </TouchableWithoutFeedback>\n <Animated.View\n pointerEvents=\"box-none\"\n style={[styles.content, contentAnimatedStyle, contentStyle]}\n >\n {children}\n </Animated.View>\n </ReactNativeModal>\n );\n};\n\nexport default React.memo(Modal);\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAEA,IAAAC,YAAA,GAAAD,OAAA;AAQA,IAAAE,OAAA,GAAAF,OAAA;AAAkC,SAAAD,wBAAAI,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAN,uBAAA,YAAAA,CAAAI,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,QAAAC,OAAA,EAAAV,CAAA,iBAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,gBAAAP,CAAA,IAAAD,CAAA,gBAAAC,CAAA,OAAAa,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAC,CAAA,OAAAM,CAAA,IAAAD,CAAA,GAAAU,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAlB,CAAA,EAAAC,CAAA,OAAAM,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAP,CAAA,EAAAM,CAAA,IAAAC,CAAA,CAAAP,CAAA,IAAAD,CAAA,CAAAC,CAAA,WAAAO,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAAA,SAAAkB,SAAA,WAAAA,QAAA,GAAAH,MAAA,CAAAI,MAAA,GAAAJ,MAAA,CAAAI,MAAA,CAAAC,IAAA,eAAAjB,CAAA,aAAAJ,CAAA,MAAAA,CAAA,GAAAsB,SAAA,CAAAC,MAAA,EAAAvB,CAAA,UAAAC,CAAA,GAAAqB,SAAA,CAAAtB,CAAA,YAAAG,CAAA,IAAAF,CAAA,OAAAa,cAAA,CAAAC,IAAA,CAAAd,CAAA,EAAAE,CAAA,MAAAC,CAAA,CAAAD,CAAA,IAAAF,CAAA,CAAAE,CAAA,aAAAC,CAAA,KAAAe,QAAA,CAAAK,KAAA,OAAAF,SAAA;AAG3B,MAAMG,KAAK,GAAIC,KAAiB,IAAK;EAC1C,MAAM;IACJC,iBAAiB,GAAG,GAAG;IACvBC,QAAQ;IACRC,YAAY;IACZC,SAAS,GAAG,KAAK;IACjBC,UAAU;IACVC,MAAM;IACNC,cAAc;IACdC,cAAc,GAAG,GAAG;IACpBC,YAAY;IACZC,MAAM,GAAG;EACX,CAAC,GAAGV,KAAK;EAET,MAAM;IAAEW,MAAM,EAAEC,YAAY;IAAEC,KAAK,EAAEC;EAAY,CAAC,GAAG,IAAAC,gCAAmB,EAAC,CAAC;EAE1E,MAAMC,SAAS,GAAG,IAAAC,aAAM,EAAC,KAAK,CAAC;EAC/B,MAAMC,eAAe,GAAG,IAAAD,aAAM,EAAC,IAAIE,qBAAQ,CAACC,KAAK,CAAC,CAAC,CAAC,CAAC;EAErD,IAAAC,gBAAS,EAAC,MAAM;IACdL,SAAS,CAACM,OAAO,GAAG,IAAI;IACxB,IAAIlB,SAAS,EAAE;MACbmB,IAAI,CAAC,CAAC;IACR;IAEA,OAAO,MAAM;MACXP,SAAS,CAACM,OAAO,GAAG,KAAK;IAC3B,CAAC;IACD;EACF,CAAC,EAAE,EAAE,CAAC;EAEN,MAAME,qBAAqB,GAAG;IAC5BC,OAAO,EAAEP,eAAe,CAACI,OAAO,CAACI,WAAW,CAAC;MAC3CC,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;MAClBC,WAAW,EAAE,CAAC,CAAC,EAAEpB,cAAc;IACjC,CAAC;EACH,CAAC;EACD,MAAMqB,oBAAoB,GAAG;IAC3BC,SAAS,EAAE,CACT;MACEC,UAAU,EAAEb,eAAe,CAACI,OAAO,CAACI,WAAW,CAAC;QAC9CM,WAAW,EAAE,OAAO;QACpBL,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAClBC,WAAW,EAAE,CAAChB,YAAY,EAAE,CAAC;MAC/B,CAAC;IACH,CAAC;EAEL,CAAC;EAED,MAAMW,IAAI,GAAG,IAAAU,kBAAW,EAAC,MAAM;IAC7Bd,qBAAQ,CAACe,MAAM,CAAChB,eAAe,CAACI,OAAO,EAAE;MACvCa,QAAQ,EAAElC,iBAAiB;MAC3BmC,MAAM,EAAEC,mBAAM,CAACC,KAAK,CAACD,mBAAM,CAACE,IAAI,CAAC;MACjCC,OAAO,EAAE,CAAC;MACV;MACAC,eAAe,EAAE;IACnB,CAAC,CAAC,CAACC,KAAK,CAAC,CAAC;EACZ,CAAC,EAAE,CAACzC,iBAAiB,CAAC,CAAC;EAEvB,MAAM0C,IAAI,GAAG,IAAAV,kBAAW,EAAC,MAAM;IAC7Bd,qBAAQ,CAACe,MAAM,CAAChB,eAAe,CAACI,OAAO,EAAE;MACvCa,QAAQ,EAAElC,iBAAiB;MAC3BmC,MAAM,EAAEC,mBAAM,CAACC,KAAK,CAACD,mBAAM,CAACE,IAAI,CAAC;MACjCC,OAAO,EAAE,CAAC;MACV;MACAC,eAAe,EAAE;IACnB,CAAC,CAAC,CAACC,KAAK,CAAC,MAAM;MACb,IAAI1B,SAAS,CAACM,OAAO,EAAE;QACrBhB,MAAM,aAANA,MAAM,eAANA,MAAM,CAAG,CAAC;MACZ;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACL,iBAAiB,EAAEK,MAAM,CAAC,CAAC;EAE/B,IAAAe,gBAAS,EAAC,MAAM;IACd,IAAIjB,SAAS,EAAE;MACbmB,IAAI,CAAC,CAAC;IACR,CAAC,MAAM;MACLoB,IAAI,CAAC,CAAC;IACR;IACA;EACF,CAAC,EAAE,CAACvC,SAAS,CAAC,CAAC;EAEf,oBACEnC,MAAA,CAAAe,OAAA,CAAA4D,aAAA,CAACxE,YAAA,CAAA2B,KAAgB,EAAAN,QAAA;IACfoD,aAAa,EAAC,MAAM;IACpBC,WAAW;IACXC,OAAO,EAAE3C;EAAU,GACfC,UAAU;IACdK,MAAM,EAAEA;EAAO,iBAEfzC,MAAA,CAAAe,OAAA,CAAA4D,aAAA,CAACxE,YAAA,CAAA4E,wBAAwB;IAACC,OAAO,EAAE1C,cAAe;IAACG,MAAM,EAAC;EAAgB,gBACxEzC,MAAA,CAAAe,OAAA,CAAA4D,aAAA,CAACxE,YAAA,CAAA+C,QAAQ,CAAC+B,IAAI;IACZC,KAAK,EAAE,CACLC,cAAM,CAACC,QAAQ,EACf7B,qBAAqB,EACrB;MAAEb,MAAM,EAAEC,YAAY;MAAEC,KAAK,EAAEC;IAAY,CAAC,EAC5CL,YAAY;EACZ,CACH,CACuB,CAAC,eAC3BxC,MAAA,CAAAe,OAAA,CAAA4D,aAAA,CAACxE,YAAA,CAAA+C,QAAQ,CAAC+B,IAAI;IACZI,aAAa,EAAC,UAAU;IACxBH,KAAK,EAAE,CAACC,cAAM,CAACG,OAAO,EAAE1B,oBAAoB,EAAE1B,YAAY;EAAE,GAE3DD,QACY,CACC,CAAC;AAEvB,CAAC;AAACsD,OAAA,CAAAzD,KAAA,GAAAA,KAAA;AAAA,IAAA0D,QAAA,GAAAD,OAAA,CAAAxE,OAAA,gBAEa0E,cAAK,CAACC,IAAI,CAAC5D,KAAK,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _exportNames = {};
|
|
7
|
+
Object.defineProperty(exports, "default", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _Modal.default;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
var _Modal = _interopRequireDefault(require("./Modal"));
|
|
14
|
+
var _types = require("./types");
|
|
15
|
+
Object.keys(_types).forEach(function (key) {
|
|
16
|
+
if (key === "default" || key === "__esModule") return;
|
|
17
|
+
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
18
|
+
if (key in exports && exports[key] === _types[key]) return;
|
|
19
|
+
Object.defineProperty(exports, key, {
|
|
20
|
+
enumerable: true,
|
|
21
|
+
get: function () {
|
|
22
|
+
return _types[key];
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_Modal","_interopRequireDefault","require","_types","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","e","__esModule","default"],"sources":["index.ts"],"sourcesContent":["export { default } from \"./Modal\";\n\nexport * from \"./types\";\n"],"mappings":";;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,MAAA,GAAAD,OAAA;AAAAE,MAAA,CAAAC,IAAA,CAAAF,MAAA,EAAAG,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAC,YAAA,EAAAJ,GAAA;EAAA,IAAAA,GAAA,IAAAK,OAAA,IAAAA,OAAA,CAAAL,GAAA,MAAAJ,MAAA,CAAAI,GAAA;EAAAH,MAAA,CAAAS,cAAA,CAAAD,OAAA,EAAAL,GAAA;IAAAO,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAZ,MAAA,CAAAI,GAAA;IAAA;EAAA;AAAA;AAAwB,SAAAN,uBAAAe,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA","ignoreList":[]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.styles = void 0;
|
|
7
|
+
var _reactNative = require("react-native");
|
|
8
|
+
const styles = exports.styles = _reactNative.StyleSheet.create({
|
|
9
|
+
backdrop: {
|
|
10
|
+
backgroundColor: "black",
|
|
11
|
+
bottom: 0,
|
|
12
|
+
left: 0,
|
|
13
|
+
opacity: 0,
|
|
14
|
+
position: "absolute",
|
|
15
|
+
right: 0,
|
|
16
|
+
top: 0
|
|
17
|
+
},
|
|
18
|
+
content: {
|
|
19
|
+
alignItems: "center",
|
|
20
|
+
flex: 1,
|
|
21
|
+
justifyContent: "center",
|
|
22
|
+
zIndex: 1
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
//# sourceMappingURL=styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_reactNative","require","styles","exports","StyleSheet","create","backdrop","backgroundColor","bottom","left","opacity","position","right","top","content","alignItems","flex","justifyContent","zIndex"],"sources":["styles.ts"],"sourcesContent":["import { StyleSheet } from \"react-native\";\n\nexport const styles = StyleSheet.create({\n backdrop: {\n backgroundColor: \"black\",\n bottom: 0,\n left: 0,\n opacity: 0,\n position: \"absolute\",\n right: 0,\n top: 0,\n },\n content: {\n alignItems: \"center\",\n flex: 1,\n justifyContent: \"center\",\n zIndex: 1,\n },\n});\n"],"mappings":";;;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AAEO,MAAMC,MAAM,GAAAC,OAAA,CAAAD,MAAA,GAAGE,uBAAU,CAACC,MAAM,CAAC;EACtCC,QAAQ,EAAE;IACRC,eAAe,EAAE,OAAO;IACxBC,MAAM,EAAE,CAAC;IACTC,IAAI,EAAE,CAAC;IACPC,OAAO,EAAE,CAAC;IACVC,QAAQ,EAAE,UAAU;IACpBC,KAAK,EAAE,CAAC;IACRC,GAAG,EAAE;EACP,CAAC;EACDC,OAAO,EAAE;IACPC,UAAU,EAAE,QAAQ;IACpBC,IAAI,EAAE,CAAC;IACPC,cAAc,EAAE,QAAQ;IACxBC,MAAM,EAAE;EACV;AACF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import type React from \"react\";\nimport { 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":[]}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
10
|
+
const PickerItem = /*#__PURE__*/_react.default.memo(({
|
|
11
|
+
adjustedLimitedMax,
|
|
12
|
+
adjustedLimitedMin,
|
|
13
|
+
allowFontScaling,
|
|
14
|
+
amLabel,
|
|
15
|
+
is12HourPicker,
|
|
16
|
+
item,
|
|
17
|
+
pickerAmPmPositionStyle,
|
|
18
|
+
pmLabel,
|
|
19
|
+
selectedValue,
|
|
20
|
+
styles
|
|
21
|
+
}) => {
|
|
22
|
+
let stringItem = item;
|
|
23
|
+
let intItem;
|
|
24
|
+
let isAm;
|
|
25
|
+
if (!is12HourPicker) {
|
|
26
|
+
intItem = parseInt(item);
|
|
27
|
+
} else {
|
|
28
|
+
isAm = item.includes("AM");
|
|
29
|
+
stringItem = item.replace(/\s[AP]M/g, "");
|
|
30
|
+
intItem = parseInt(stringItem);
|
|
31
|
+
}
|
|
32
|
+
const isSelected = intItem === selectedValue;
|
|
33
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
34
|
+
key: item,
|
|
35
|
+
style: styles.pickerItemContainer,
|
|
36
|
+
testID: "picker-item"
|
|
37
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Text, {
|
|
38
|
+
allowFontScaling: allowFontScaling,
|
|
39
|
+
style: [styles.pickerItem, isSelected && styles.selectedPickerItem, intItem > adjustedLimitedMax || intItem < adjustedLimitedMin ? styles.disabledPickerItem : {}]
|
|
40
|
+
}, stringItem), is12HourPicker && /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
41
|
+
style: [styles.pickerAmPmContainer, pickerAmPmPositionStyle]
|
|
42
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Text, {
|
|
43
|
+
allowFontScaling: allowFontScaling,
|
|
44
|
+
style: styles.pickerAmPmLabel
|
|
45
|
+
}, isAm ? amLabel : pmLabel)));
|
|
46
|
+
});
|
|
47
|
+
var _default = exports.default = PickerItem;
|
|
48
|
+
//# sourceMappingURL=PickerItem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_reactNative","e","__esModule","default","PickerItem","React","memo","adjustedLimitedMax","adjustedLimitedMin","allowFontScaling","amLabel","is12HourPicker","item","pickerAmPmPositionStyle","pmLabel","selectedValue","styles","stringItem","intItem","isAm","parseInt","includes","replace","isSelected","createElement","View","key","style","pickerItemContainer","testID","Text","pickerItem","selectedPickerItem","disabledPickerItem","pickerAmPmContainer","pickerAmPmLabel","_default","exports"],"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 pickerAmPmPositionStyle?: { left: \"50%\"; marginLeft: number };\n pmLabel?: string;\n selectedValue?: number;\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 pickerAmPmPositionStyle,\n pmLabel,\n selectedValue,\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 const isSelected = intItem === selectedValue;\n\n return (\n <View key={item} style={styles.pickerItemContainer} testID=\"picker-item\">\n <Text\n allowFontScaling={allowFontScaling}\n style={[\n styles.pickerItem,\n isSelected && styles.selectedPickerItem,\n intItem > adjustedLimitedMax || intItem < adjustedLimitedMin\n ? styles.disabledPickerItem\n : {},\n ]}\n >\n {stringItem}\n </Text>\n {is12HourPicker && (\n <View style={[styles.pickerAmPmContainer, pickerAmPmPositionStyle]}>\n <Text allowFontScaling={allowFontScaling} style={styles.pickerAmPmLabel}>\n {isAm ? amLabel : pmLabel}\n </Text>\n </View>\n )}\n </View>\n );\n }\n);\n\nexport default PickerItem;\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,YAAA,GAAAD,OAAA;AAA0C,SAAAD,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAiB1C,MAAMG,UAAU,gBAAGC,cAAK,CAACC,IAAI,CAC3B,CAAC;EACCC,kBAAkB;EAClBC,kBAAkB;EAClBC,gBAAgB;EAChBC,OAAO;EACPC,cAAc;EACdC,IAAI;EACJC,uBAAuB;EACvBC,OAAO;EACPC,aAAa;EACbC;AACF,CAAC,KAAK;EACJ,IAAIC,UAAU,GAAGL,IAAI;EACrB,IAAIM,OAAe;EACnB,IAAIC,IAAyB;EAE7B,IAAI,CAACR,cAAc,EAAE;IACnBO,OAAO,GAAGE,QAAQ,CAACR,IAAI,CAAC;EAC1B,CAAC,MAAM;IACLO,IAAI,GAAGP,IAAI,CAACS,QAAQ,CAAC,IAAI,CAAC;IAC1BJ,UAAU,GAAGL,IAAI,CAACU,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;IACzCJ,OAAO,GAAGE,QAAQ,CAACH,UAAU,CAAC;EAChC;EAEA,MAAMM,UAAU,GAAGL,OAAO,KAAKH,aAAa;EAE5C,oBACElB,MAAA,CAAAM,OAAA,CAAAqB,aAAA,CAACxB,YAAA,CAAAyB,IAAI;IAACC,GAAG,EAAEd,IAAK;IAACe,KAAK,EAAEX,MAAM,CAACY,mBAAoB;IAACC,MAAM,EAAC;EAAa,gBACtEhC,MAAA,CAAAM,OAAA,CAAAqB,aAAA,CAACxB,YAAA,CAAA8B,IAAI;IACHrB,gBAAgB,EAAEA,gBAAiB;IACnCkB,KAAK,EAAE,CACLX,MAAM,CAACe,UAAU,EACjBR,UAAU,IAAIP,MAAM,CAACgB,kBAAkB,EACvCd,OAAO,GAAGX,kBAAkB,IAAIW,OAAO,GAAGV,kBAAkB,GACxDQ,MAAM,CAACiB,kBAAkB,GACzB,CAAC,CAAC;EACN,GAEDhB,UACG,CAAC,EACNN,cAAc,iBACbd,MAAA,CAAAM,OAAA,CAAAqB,aAAA,CAACxB,YAAA,CAAAyB,IAAI;IAACE,KAAK,EAAE,CAACX,MAAM,CAACkB,mBAAmB,EAAErB,uBAAuB;EAAE,gBACjEhB,MAAA,CAAAM,OAAA,CAAAqB,aAAA,CAACxB,YAAA,CAAA8B,IAAI;IAACrB,gBAAgB,EAAEA,gBAAiB;IAACkB,KAAK,EAAEX,MAAM,CAACmB;EAAgB,GACrEhB,IAAI,GAAGT,OAAO,GAAGI,OACd,CACF,CAEJ,CAAC;AAEX,CACF,CAAC;AAAC,IAAAsB,QAAA,GAAAC,OAAA,CAAAlC,OAAA,GAEaC,UAAU","ignoreList":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
Object.defineProperty(exports, "default", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _PickerItem.default;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
var _PickerItem = _interopRequireDefault(require("./PickerItem"));
|
|
13
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_PickerItem","_interopRequireDefault","require","e","__esModule","default"],"sources":["index.ts"],"sourcesContent":["export { default } from \"./PickerItem\";\n"],"mappings":";;;;;;;;;;;AAAA,IAAAA,WAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAuC,SAAAD,uBAAAE,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA","ignoreList":[]}
|
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
var _getSafeInitialValue = require("../../utils/getSafeInitialValue");
|
|
10
|
+
var _DurationScroll = _interopRequireDefault(require("../DurationScroll"));
|
|
11
|
+
var _styles = require("./styles");
|
|
12
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
13
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
14
|
+
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); }
|
|
15
|
+
const resolvePerColumn = (value, column) => {
|
|
16
|
+
if (value == null) {
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
19
|
+
if (typeof value === "number") {
|
|
20
|
+
return value;
|
|
21
|
+
}
|
|
22
|
+
return value[column];
|
|
23
|
+
};
|
|
24
|
+
const TimerPicker = /*#__PURE__*/(0, _react.forwardRef)((props, ref) => {
|
|
25
|
+
const {
|
|
26
|
+
aggressivelyGetLatestDuration = false,
|
|
27
|
+
allowFontScaling = false,
|
|
28
|
+
amLabel = "am",
|
|
29
|
+
dayInterval = 1,
|
|
30
|
+
dayLabel,
|
|
31
|
+
dayLimit,
|
|
32
|
+
daysPickerIsDisabled = false,
|
|
33
|
+
decelerationRate = 0.88,
|
|
34
|
+
disableInfiniteScroll = false,
|
|
35
|
+
hideDays = true,
|
|
36
|
+
hideHours = false,
|
|
37
|
+
hideMinutes = false,
|
|
38
|
+
hideSeconds = false,
|
|
39
|
+
hourInterval = 1,
|
|
40
|
+
hourLabel,
|
|
41
|
+
hourLimit,
|
|
42
|
+
hoursPickerIsDisabled = false,
|
|
43
|
+
initialValue,
|
|
44
|
+
maximumDays = 30,
|
|
45
|
+
maximumHours = 23,
|
|
46
|
+
maximumMinutes = 59,
|
|
47
|
+
maximumSeconds = 59,
|
|
48
|
+
minuteInterval = 1,
|
|
49
|
+
minuteLabel,
|
|
50
|
+
minuteLimit,
|
|
51
|
+
minutesPickerIsDisabled = false,
|
|
52
|
+
onDurationChange,
|
|
53
|
+
padDaysWithZero = false,
|
|
54
|
+
padHoursWithZero = false,
|
|
55
|
+
padMinutesWithZero = true,
|
|
56
|
+
padSecondsWithZero = true,
|
|
57
|
+
padWithNItems = 1,
|
|
58
|
+
pickerContainerProps,
|
|
59
|
+
pmLabel = "pm",
|
|
60
|
+
repeatDayNumbersNTimes = 3,
|
|
61
|
+
repeatHourNumbersNTimes = 8,
|
|
62
|
+
repeatMinuteNumbersNTimes = 3,
|
|
63
|
+
repeatSecondNumbersNTimes = 3,
|
|
64
|
+
secondInterval = 1,
|
|
65
|
+
secondLabel,
|
|
66
|
+
secondLimit,
|
|
67
|
+
secondsPickerIsDisabled = false,
|
|
68
|
+
styles: customStyles,
|
|
69
|
+
use12HourPicker = false,
|
|
70
|
+
...otherProps
|
|
71
|
+
} = props;
|
|
72
|
+
(0, _react.useEffect)(() => {
|
|
73
|
+
if (otherProps.Audio) {
|
|
74
|
+
console.warn('The "Audio" prop is deprecated and will be removed in a future version. Please use the "pickerFeedback" prop instead.');
|
|
75
|
+
}
|
|
76
|
+
if (otherProps.Haptics) {
|
|
77
|
+
console.warn('The "Haptics" prop is deprecated and will be removed in a future version. Please use the "pickerFeedback" prop instead.');
|
|
78
|
+
}
|
|
79
|
+
if (otherProps.clickSoundAsset) {
|
|
80
|
+
console.warn('The "clickSoundAsset" prop is deprecated and will be removed in a future version. Please use the "pickerFeedback" prop instead.');
|
|
81
|
+
}
|
|
82
|
+
if ((customStyles === null || customStyles === void 0 ? void 0 : customStyles.labelOffsetPercentage) != null) {
|
|
83
|
+
if ((customStyles === null || customStyles === void 0 ? void 0 : customStyles.pickerLabelGap) != null) {
|
|
84
|
+
console.warn("labelOffsetPercentage is ignored when pickerLabelGap is set. Please remove labelOffsetPercentage.");
|
|
85
|
+
} else {
|
|
86
|
+
console.warn('The "labelOffsetPercentage" style prop is deprecated and will be removed in a future version. Please use the "pickerLabelGap" style prop instead.');
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}, [otherProps.Audio, otherProps.Haptics, otherProps.clickSoundAsset, customStyles === null || customStyles === void 0 ? void 0 : customStyles.labelOffsetPercentage, customStyles === null || customStyles === void 0 ? void 0 : customStyles.pickerLabelGap]);
|
|
90
|
+
const safePadWithNItems = (0, _react.useMemo)(() => {
|
|
91
|
+
if (padWithNItems < 0 || isNaN(padWithNItems)) {
|
|
92
|
+
return 0;
|
|
93
|
+
}
|
|
94
|
+
const maxPadWithNItems = hideHours ? 15 : 6;
|
|
95
|
+
if (padWithNItems > maxPadWithNItems) {
|
|
96
|
+
return maxPadWithNItems;
|
|
97
|
+
}
|
|
98
|
+
return Math.round(padWithNItems);
|
|
99
|
+
}, [hideHours, padWithNItems]);
|
|
100
|
+
const safeInitialValue = (0, _react.useMemo)(() => (0, _getSafeInitialValue.getSafeInitialValue)({
|
|
101
|
+
days: initialValue === null || initialValue === void 0 ? void 0 : initialValue.days,
|
|
102
|
+
hours: initialValue === null || initialValue === void 0 ? void 0 : initialValue.hours,
|
|
103
|
+
minutes: initialValue === null || initialValue === void 0 ? void 0 : initialValue.minutes,
|
|
104
|
+
seconds: initialValue === null || initialValue === void 0 ? void 0 : initialValue.seconds
|
|
105
|
+
}), [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]);
|
|
106
|
+
const pickerLabelGap = customStyles === null || customStyles === void 0 ? void 0 : customStyles.pickerLabelGap;
|
|
107
|
+
const pickerColumnWidth = customStyles === null || customStyles === void 0 ? void 0 : customStyles.pickerColumnWidth;
|
|
108
|
+
const styles = (0, _react.useMemo)(() => (0, _styles.generateStyles)(customStyles), [customStyles]);
|
|
109
|
+
const [selectedDays, setSelectedDays] = (0, _react.useState)(safeInitialValue.days);
|
|
110
|
+
const [selectedHours, setSelectedHours] = (0, _react.useState)(safeInitialValue.hours);
|
|
111
|
+
const [selectedMinutes, setSelectedMinutes] = (0, _react.useState)(safeInitialValue.minutes);
|
|
112
|
+
const [selectedSeconds, setSelectedSeconds] = (0, _react.useState)(safeInitialValue.seconds);
|
|
113
|
+
(0, _react.useEffect)(() => {
|
|
114
|
+
onDurationChange === null || onDurationChange === void 0 || onDurationChange({
|
|
115
|
+
days: selectedDays,
|
|
116
|
+
hours: selectedHours,
|
|
117
|
+
minutes: selectedMinutes,
|
|
118
|
+
seconds: selectedSeconds
|
|
119
|
+
});
|
|
120
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
121
|
+
}, [selectedDays, selectedHours, selectedMinutes, selectedSeconds]);
|
|
122
|
+
const daysDurationScrollRef = (0, _react.useRef)(null);
|
|
123
|
+
const hoursDurationScrollRef = (0, _react.useRef)(null);
|
|
124
|
+
const minutesDurationScrollRef = (0, _react.useRef)(null);
|
|
125
|
+
const secondsDurationScrollRef = (0, _react.useRef)(null);
|
|
126
|
+
(0, _react.useImperativeHandle)(ref, () => {
|
|
127
|
+
var _daysDurationScrollRe, _hoursDurationScrollR, _minutesDurationScrol, _secondsDurationScrol;
|
|
128
|
+
return {
|
|
129
|
+
latestDuration: {
|
|
130
|
+
days: (_daysDurationScrollRe = daysDurationScrollRef.current) === null || _daysDurationScrollRe === void 0 ? void 0 : _daysDurationScrollRe.latestDuration,
|
|
131
|
+
hours: (_hoursDurationScrollR = hoursDurationScrollRef.current) === null || _hoursDurationScrollR === void 0 ? void 0 : _hoursDurationScrollR.latestDuration,
|
|
132
|
+
minutes: (_minutesDurationScrol = minutesDurationScrollRef.current) === null || _minutesDurationScrol === void 0 ? void 0 : _minutesDurationScrol.latestDuration,
|
|
133
|
+
seconds: (_secondsDurationScrol = secondsDurationScrollRef.current) === null || _secondsDurationScrol === void 0 ? void 0 : _secondsDurationScrol.latestDuration
|
|
134
|
+
},
|
|
135
|
+
reset: options => {
|
|
136
|
+
var _daysDurationScrollRe2, _hoursDurationScrollR2, _minutesDurationScrol2, _secondsDurationScrol2;
|
|
137
|
+
setSelectedDays(safeInitialValue.days);
|
|
138
|
+
setSelectedHours(safeInitialValue.hours);
|
|
139
|
+
setSelectedMinutes(safeInitialValue.minutes);
|
|
140
|
+
setSelectedSeconds(safeInitialValue.seconds);
|
|
141
|
+
(_daysDurationScrollRe2 = daysDurationScrollRef.current) === null || _daysDurationScrollRe2 === void 0 || _daysDurationScrollRe2.reset(options);
|
|
142
|
+
(_hoursDurationScrollR2 = hoursDurationScrollRef.current) === null || _hoursDurationScrollR2 === void 0 || _hoursDurationScrollR2.reset(options);
|
|
143
|
+
(_minutesDurationScrol2 = minutesDurationScrollRef.current) === null || _minutesDurationScrol2 === void 0 || _minutesDurationScrol2.reset(options);
|
|
144
|
+
(_secondsDurationScrol2 = secondsDurationScrollRef.current) === null || _secondsDurationScrol2 === void 0 || _secondsDurationScrol2.reset(options);
|
|
145
|
+
},
|
|
146
|
+
setValue: (value, options) => {
|
|
147
|
+
if (value.days !== undefined) {
|
|
148
|
+
var _daysDurationScrollRe3;
|
|
149
|
+
setSelectedDays(value.days);
|
|
150
|
+
(_daysDurationScrollRe3 = daysDurationScrollRef.current) === null || _daysDurationScrollRe3 === void 0 || _daysDurationScrollRe3.setValue(value.days, options);
|
|
151
|
+
}
|
|
152
|
+
if (value.hours !== undefined) {
|
|
153
|
+
var _hoursDurationScrollR3;
|
|
154
|
+
setSelectedHours(value.hours);
|
|
155
|
+
(_hoursDurationScrollR3 = hoursDurationScrollRef.current) === null || _hoursDurationScrollR3 === void 0 || _hoursDurationScrollR3.setValue(value.hours, options);
|
|
156
|
+
}
|
|
157
|
+
if (value.minutes !== undefined) {
|
|
158
|
+
var _minutesDurationScrol3;
|
|
159
|
+
setSelectedMinutes(value.minutes);
|
|
160
|
+
(_minutesDurationScrol3 = minutesDurationScrollRef.current) === null || _minutesDurationScrol3 === void 0 || _minutesDurationScrol3.setValue(value.minutes, options);
|
|
161
|
+
}
|
|
162
|
+
if (value.seconds !== undefined) {
|
|
163
|
+
var _secondsDurationScrol3;
|
|
164
|
+
setSelectedSeconds(value.seconds);
|
|
165
|
+
(_secondsDurationScrol3 = secondsDurationScrollRef.current) === null || _secondsDurationScrol3 === void 0 || _secondsDurationScrol3.setValue(value.seconds, options);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
});
|
|
170
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, _extends({}, pickerContainerProps, {
|
|
171
|
+
style: styles.pickerContainer,
|
|
172
|
+
testID: "timer-picker"
|
|
173
|
+
}), !hideDays ? /*#__PURE__*/_react.default.createElement(_DurationScroll.default, _extends({
|
|
174
|
+
ref: daysDurationScrollRef,
|
|
175
|
+
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
176
|
+
allowFontScaling: allowFontScaling,
|
|
177
|
+
disableInfiniteScroll: disableInfiniteScroll,
|
|
178
|
+
initialValue: safeInitialValue.days,
|
|
179
|
+
interval: dayInterval,
|
|
180
|
+
isDisabled: daysPickerIsDisabled,
|
|
181
|
+
label: dayLabel ?? "d",
|
|
182
|
+
limit: dayLimit,
|
|
183
|
+
maximumValue: maximumDays,
|
|
184
|
+
onDurationChange: setSelectedDays,
|
|
185
|
+
padNumbersWithZero: padDaysWithZero,
|
|
186
|
+
padWithNItems: safePadWithNItems,
|
|
187
|
+
pickerColumnWidth: resolvePerColumn(pickerColumnWidth, "days"),
|
|
188
|
+
pickerLabelGap: resolvePerColumn(pickerLabelGap, "days"),
|
|
189
|
+
repeatNumbersNTimes: repeatDayNumbersNTimes,
|
|
190
|
+
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatDayNumbersNTimes) === undefined,
|
|
191
|
+
selectedValue: selectedDays,
|
|
192
|
+
styles: styles,
|
|
193
|
+
testID: "duration-scroll-day"
|
|
194
|
+
}, otherProps)) : null, !hideHours ? /*#__PURE__*/_react.default.createElement(_DurationScroll.default, _extends({
|
|
195
|
+
ref: hoursDurationScrollRef,
|
|
196
|
+
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
197
|
+
allowFontScaling: allowFontScaling,
|
|
198
|
+
amLabel: amLabel,
|
|
199
|
+
decelerationRate: decelerationRate,
|
|
200
|
+
disableInfiniteScroll: disableInfiniteScroll,
|
|
201
|
+
initialValue: safeInitialValue.hours,
|
|
202
|
+
interval: hourInterval,
|
|
203
|
+
is12HourPicker: use12HourPicker,
|
|
204
|
+
isDisabled: hoursPickerIsDisabled,
|
|
205
|
+
label: hourLabel ?? (!use12HourPicker ? "h" : undefined),
|
|
206
|
+
limit: hourLimit,
|
|
207
|
+
maximumValue: maximumHours,
|
|
208
|
+
onDurationChange: setSelectedHours,
|
|
209
|
+
padNumbersWithZero: padHoursWithZero,
|
|
210
|
+
padWithNItems: safePadWithNItems,
|
|
211
|
+
pickerColumnWidth: resolvePerColumn(pickerColumnWidth, "hours"),
|
|
212
|
+
pickerLabelGap: resolvePerColumn(pickerLabelGap, "hours"),
|
|
213
|
+
pmLabel: pmLabel,
|
|
214
|
+
repeatNumbersNTimes: repeatHourNumbersNTimes,
|
|
215
|
+
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatHourNumbersNTimes) === undefined,
|
|
216
|
+
selectedValue: selectedHours,
|
|
217
|
+
styles: styles,
|
|
218
|
+
testID: "duration-scroll-hour"
|
|
219
|
+
}, otherProps)) : null, !hideMinutes ? /*#__PURE__*/_react.default.createElement(_DurationScroll.default, _extends({
|
|
220
|
+
ref: minutesDurationScrollRef,
|
|
221
|
+
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
222
|
+
allowFontScaling: allowFontScaling,
|
|
223
|
+
decelerationRate: decelerationRate,
|
|
224
|
+
disableInfiniteScroll: disableInfiniteScroll,
|
|
225
|
+
initialValue: safeInitialValue.minutes,
|
|
226
|
+
interval: minuteInterval,
|
|
227
|
+
isDisabled: minutesPickerIsDisabled,
|
|
228
|
+
label: minuteLabel ?? "m",
|
|
229
|
+
limit: minuteLimit,
|
|
230
|
+
maximumValue: maximumMinutes,
|
|
231
|
+
onDurationChange: setSelectedMinutes,
|
|
232
|
+
padNumbersWithZero: padMinutesWithZero,
|
|
233
|
+
padWithNItems: safePadWithNItems,
|
|
234
|
+
pickerColumnWidth: resolvePerColumn(pickerColumnWidth, "minutes"),
|
|
235
|
+
pickerLabelGap: resolvePerColumn(pickerLabelGap, "minutes"),
|
|
236
|
+
repeatNumbersNTimes: repeatMinuteNumbersNTimes,
|
|
237
|
+
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatMinuteNumbersNTimes) === undefined,
|
|
238
|
+
selectedValue: selectedMinutes,
|
|
239
|
+
styles: styles,
|
|
240
|
+
testID: "duration-scroll-minute"
|
|
241
|
+
}, otherProps)) : null, !hideSeconds ? /*#__PURE__*/_react.default.createElement(_DurationScroll.default, _extends({
|
|
242
|
+
ref: secondsDurationScrollRef,
|
|
243
|
+
aggressivelyGetLatestDuration: aggressivelyGetLatestDuration,
|
|
244
|
+
allowFontScaling: allowFontScaling,
|
|
245
|
+
decelerationRate: decelerationRate,
|
|
246
|
+
disableInfiniteScroll: disableInfiniteScroll,
|
|
247
|
+
initialValue: safeInitialValue.seconds,
|
|
248
|
+
interval: secondInterval,
|
|
249
|
+
isDisabled: secondsPickerIsDisabled,
|
|
250
|
+
label: secondLabel ?? "s",
|
|
251
|
+
limit: secondLimit,
|
|
252
|
+
maximumValue: maximumSeconds,
|
|
253
|
+
onDurationChange: setSelectedSeconds,
|
|
254
|
+
padNumbersWithZero: padSecondsWithZero,
|
|
255
|
+
padWithNItems: safePadWithNItems,
|
|
256
|
+
pickerColumnWidth: resolvePerColumn(pickerColumnWidth, "seconds"),
|
|
257
|
+
pickerLabelGap: resolvePerColumn(pickerLabelGap, "seconds"),
|
|
258
|
+
repeatNumbersNTimes: repeatSecondNumbersNTimes,
|
|
259
|
+
repeatNumbersNTimesNotExplicitlySet: (props === null || props === void 0 ? void 0 : props.repeatSecondNumbersNTimes) === undefined,
|
|
260
|
+
selectedValue: selectedSeconds,
|
|
261
|
+
styles: styles,
|
|
262
|
+
testID: "duration-scroll-second"
|
|
263
|
+
}, otherProps)) : null);
|
|
264
|
+
});
|
|
265
|
+
var _default = exports.default = /*#__PURE__*/_react.default.memo(TimerPicker);
|
|
266
|
+
//# sourceMappingURL=TimerPicker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_getSafeInitialValue","_DurationScroll","_interopRequireDefault","_styles","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","resolvePerColumn","value","column","undefined","TimerPicker","forwardRef","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","useEffect","Audio","console","warn","Haptics","clickSoundAsset","labelOffsetPercentage","pickerLabelGap","safePadWithNItems","useMemo","isNaN","maxPadWithNItems","Math","round","safeInitialValue","getSafeInitialValue","days","hours","minutes","seconds","pickerColumnWidth","generateStyles","selectedDays","setSelectedDays","useState","selectedHours","setSelectedHours","selectedMinutes","setSelectedMinutes","selectedSeconds","setSelectedSeconds","daysDurationScrollRef","useRef","hoursDurationScrollRef","minutesDurationScrollRef","secondsDurationScrollRef","useImperativeHandle","_daysDurationScrollRe","_hoursDurationScrollR","_minutesDurationScrol","_secondsDurationScrol","latestDuration","current","reset","options","_daysDurationScrollRe2","_hoursDurationScrollR2","_minutesDurationScrol2","_secondsDurationScrol2","setValue","_daysDurationScrollRe3","_hoursDurationScrollR3","_minutesDurationScrol3","_secondsDurationScrol3","createElement","View","style","pickerContainer","testID","interval","isDisabled","label","limit","maximumValue","padNumbersWithZero","repeatNumbersNTimes","repeatNumbersNTimesNotExplicitlySet","selectedValue","is12HourPicker","_default","exports","React","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\";\nimport { generateStyles } from \"./styles\";\nimport type { PerColumnValue, PickerColumn } from \"./styles\";\nimport type { TimerPickerProps, TimerPickerRef } from \"./types\";\n\nconst resolvePerColumn = (\n value: PerColumnValue | undefined,\n column: PickerColumn\n): number | undefined => {\n if (value == null) {\n return undefined;\n }\n\n if (typeof value === \"number\") {\n return value;\n }\n\n return value[column];\n};\n\nconst TimerPicker = forwardRef<TimerPickerRef, TimerPickerProps>((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 if (customStyles?.labelOffsetPercentage != null) {\n if (customStyles?.pickerLabelGap != null) {\n console.warn(\n \"labelOffsetPercentage is ignored when pickerLabelGap is set. Please remove labelOffsetPercentage.\"\n );\n } else {\n console.warn(\n 'The \"labelOffsetPercentage\" style prop is deprecated and will be removed in a future version. Please use the \"pickerLabelGap\" style prop instead.'\n );\n }\n }\n }, [\n otherProps.Audio,\n otherProps.Haptics,\n otherProps.clickSoundAsset,\n customStyles?.labelOffsetPercentage,\n customStyles?.pickerLabelGap,\n ]);\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 [initialValue?.days, initialValue?.hours, initialValue?.minutes, initialValue?.seconds]\n );\n\n const pickerLabelGap = customStyles?.pickerLabelGap;\n const pickerColumnWidth = customStyles?.pickerColumnWidth;\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(safeInitialValue.hours);\n const [selectedMinutes, setSelectedMinutes] = useState(safeInitialValue.minutes);\n const [selectedSeconds, setSelectedSeconds] = useState(safeInitialValue.seconds);\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 latestDuration: {\n days: daysDurationScrollRef.current?.latestDuration,\n hours: hoursDurationScrollRef.current?.latestDuration,\n minutes: minutesDurationScrollRef.current?.latestDuration,\n seconds: secondsDurationScrollRef.current?.latestDuration,\n },\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 !== undefined) {\n setSelectedDays(value.days);\n daysDurationScrollRef.current?.setValue(value.days, options);\n }\n if (value.hours !== undefined) {\n setSelectedHours(value.hours);\n hoursDurationScrollRef.current?.setValue(value.hours, options);\n }\n if (value.minutes !== undefined) {\n setSelectedMinutes(value.minutes);\n minutesDurationScrollRef.current?.setValue(value.minutes, options);\n }\n if (value.seconds !== undefined) {\n setSelectedSeconds(value.seconds);\n secondsDurationScrollRef.current?.setValue(value.seconds, options);\n }\n },\n }));\n\n return (\n <View {...pickerContainerProps} style={styles.pickerContainer} testID=\"timer-picker\">\n {!hideDays ? (\n <DurationScroll\n ref={daysDurationScrollRef}\n aggressivelyGetLatestDuration={aggressivelyGetLatestDuration}\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 pickerColumnWidth={resolvePerColumn(pickerColumnWidth, \"days\")}\n pickerLabelGap={resolvePerColumn(pickerLabelGap, \"days\")}\n repeatNumbersNTimes={repeatDayNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={props?.repeatDayNumbersNTimes === undefined}\n selectedValue={selectedDays}\n styles={styles}\n testID=\"duration-scroll-day\"\n {...otherProps}\n />\n ) : null}\n {!hideHours ? (\n <DurationScroll\n ref={hoursDurationScrollRef}\n aggressivelyGetLatestDuration={aggressivelyGetLatestDuration}\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={hourLabel ?? (!use12HourPicker ? \"h\" : undefined)}\n limit={hourLimit}\n maximumValue={maximumHours}\n onDurationChange={setSelectedHours}\n padNumbersWithZero={padHoursWithZero}\n padWithNItems={safePadWithNItems}\n pickerColumnWidth={resolvePerColumn(pickerColumnWidth, \"hours\")}\n pickerLabelGap={resolvePerColumn(pickerLabelGap, \"hours\")}\n pmLabel={pmLabel}\n repeatNumbersNTimes={repeatHourNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={props?.repeatHourNumbersNTimes === undefined}\n selectedValue={selectedHours}\n styles={styles}\n testID=\"duration-scroll-hour\"\n {...otherProps}\n />\n ) : null}\n {!hideMinutes ? (\n <DurationScroll\n ref={minutesDurationScrollRef}\n aggressivelyGetLatestDuration={aggressivelyGetLatestDuration}\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 pickerColumnWidth={resolvePerColumn(pickerColumnWidth, \"minutes\")}\n pickerLabelGap={resolvePerColumn(pickerLabelGap, \"minutes\")}\n repeatNumbersNTimes={repeatMinuteNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={props?.repeatMinuteNumbersNTimes === undefined}\n selectedValue={selectedMinutes}\n styles={styles}\n testID=\"duration-scroll-minute\"\n {...otherProps}\n />\n ) : null}\n {!hideSeconds ? (\n <DurationScroll\n ref={secondsDurationScrollRef}\n aggressivelyGetLatestDuration={aggressivelyGetLatestDuration}\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 pickerColumnWidth={resolvePerColumn(pickerColumnWidth, \"seconds\")}\n pickerLabelGap={resolvePerColumn(pickerLabelGap, \"seconds\")}\n repeatNumbersNTimes={repeatSecondNumbersNTimes}\n repeatNumbersNTimesNotExplicitlySet={props?.repeatSecondNumbersNTimes === undefined}\n selectedValue={selectedSeconds}\n styles={styles}\n testID=\"duration-scroll-second\"\n {...otherProps}\n />\n ) : null}\n </View>\n );\n});\n\nexport default React.memo(TimerPicker);\n"],"mappings":"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","ignoreList":[]}
|