react-native-dates-picker 0.0.9 → 0.1.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/README.md +27 -28
- package/lib/commonjs/CalendarContext.js.map +1 -1
- package/lib/commonjs/DateTimePicker.js +15 -8
- package/lib/commonjs/DateTimePicker.js.map +1 -1
- package/lib/commonjs/components/Calendar.js +14 -12
- package/lib/commonjs/components/Calendar.js.map +1 -1
- package/lib/commonjs/components/DatePicker.js +46 -58
- package/lib/commonjs/components/DatePicker.js.map +1 -1
- package/lib/commonjs/components/Day.js +18 -16
- package/lib/commonjs/components/Day.js.map +1 -1
- package/lib/commonjs/components/DaySelector.js +12 -12
- package/lib/commonjs/components/DaySelector.js.map +1 -1
- package/lib/commonjs/components/Header.js +27 -25
- package/lib/commonjs/components/Header.js.map +1 -1
- package/lib/commonjs/components/MonthSelector.js +9 -7
- package/lib/commonjs/components/MonthSelector.js.map +1 -1
- package/lib/commonjs/components/TimeSelector.js +22 -17
- package/lib/commonjs/components/TimeSelector.js.map +1 -1
- package/lib/commonjs/components/WheelPicker/Wheel.js +9 -4
- package/lib/commonjs/components/WheelPicker/Wheel.js.map +1 -1
- package/lib/commonjs/components/WheelPicker/WheelNative.js +14 -47
- package/lib/commonjs/components/WheelPicker/WheelNative.js.map +1 -1
- package/lib/commonjs/components/WheelPicker/WheelNativePicker/index.js +10 -0
- package/lib/commonjs/components/WheelPicker/WheelNativePicker/index.js.map +1 -0
- package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker-item.js +130 -0
- package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker-item.js.map +1 -0
- package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker.js +174 -0
- package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker.js.map +1 -0
- package/lib/commonjs/components/WheelPicker/WheelWeb.js +51 -38
- package/lib/commonjs/components/WheelPicker/WheelWeb.js.map +1 -1
- package/lib/commonjs/components/WheelPicker/animated-math.js +26 -0
- package/lib/commonjs/components/WheelPicker/animated-math.js.map +1 -0
- package/lib/commonjs/components/WheelPicker/period-native.js +36 -0
- package/lib/commonjs/components/WheelPicker/period-native.js.map +1 -0
- package/lib/commonjs/components/WheelPicker/period-picker.js +19 -0
- package/lib/commonjs/components/WheelPicker/period-picker.js.map +1 -0
- package/lib/commonjs/components/WheelPicker/period-web.js +34 -0
- package/lib/commonjs/components/WheelPicker/period-web.js.map +1 -0
- package/lib/commonjs/components/YearSelector.js +10 -8
- package/lib/commonjs/components/YearSelector.js.map +1 -1
- package/lib/commonjs/enums.js +5 -4
- package/lib/commonjs/enums.js.map +1 -1
- package/lib/commonjs/utils.js +4 -1
- package/lib/commonjs/utils.js.map +1 -1
- package/lib/module/CalendarContext.js.map +1 -1
- package/lib/module/DateTimePicker.js +11 -6
- package/lib/module/DateTimePicker.js.map +1 -1
- package/lib/module/components/Calendar.js +4 -4
- package/lib/module/components/Calendar.js.map +1 -1
- package/lib/module/components/DatePicker.js +36 -50
- package/lib/module/components/DatePicker.js.map +1 -1
- package/lib/module/components/Day.js +8 -8
- package/lib/module/components/Day.js.map +1 -1
- package/lib/module/components/DaySelector.js +4 -4
- package/lib/module/components/DaySelector.js.map +1 -1
- package/lib/module/components/Header.js +3 -3
- package/lib/module/components/Header.js.map +1 -1
- package/lib/module/components/MonthSelector.js +3 -2
- package/lib/module/components/MonthSelector.js.map +1 -1
- package/lib/module/components/TimeSelector.js +10 -7
- package/lib/module/components/TimeSelector.js.map +1 -1
- package/lib/module/components/WheelPicker/Wheel.js +6 -3
- package/lib/module/components/WheelPicker/Wheel.js.map +1 -1
- package/lib/module/components/WheelPicker/WheelNative.js +10 -45
- package/lib/module/components/WheelPicker/WheelNative.js.map +1 -1
- package/lib/module/components/WheelPicker/WheelNativePicker/index.js +3 -0
- package/lib/module/components/WheelPicker/WheelNativePicker/index.js.map +1 -0
- package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker-item.js +122 -0
- package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker-item.js.map +1 -0
- package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker.js +165 -0
- package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker.js.map +1 -0
- package/lib/module/components/WheelPicker/WheelWeb.js +48 -37
- package/lib/module/components/WheelPicker/WheelWeb.js.map +1 -1
- package/lib/module/components/WheelPicker/animated-math.js +20 -0
- package/lib/module/components/WheelPicker/animated-math.js.map +1 -0
- package/lib/module/components/WheelPicker/period-native.js +27 -0
- package/lib/module/components/WheelPicker/period-native.js.map +1 -0
- package/lib/module/components/WheelPicker/period-picker.js +10 -0
- package/lib/module/components/WheelPicker/period-picker.js.map +1 -0
- package/lib/module/components/WheelPicker/period-web.js +26 -0
- package/lib/module/components/WheelPicker/period-web.js.map +1 -0
- package/lib/module/components/YearSelector.js +3 -3
- package/lib/module/components/YearSelector.js.map +1 -1
- package/lib/module/enums.js +4 -3
- package/lib/module/enums.js.map +1 -1
- package/lib/module/utils.js +4 -1
- package/lib/module/utils.js.map +1 -1
- package/lib/typescript/CalendarContext.d.ts.map +1 -1
- package/lib/typescript/DateTimePicker.d.ts +3 -3
- package/lib/typescript/DateTimePicker.d.ts.map +1 -1
- package/lib/typescript/components/Calendar.d.ts +3 -3
- package/lib/typescript/components/Calendar.d.ts.map +1 -1
- package/lib/typescript/components/DatePicker.d.ts +2 -2
- package/lib/typescript/components/DatePicker.d.ts.map +1 -1
- package/lib/typescript/components/Day.d.ts +4 -5
- package/lib/typescript/components/Day.d.ts.map +1 -1
- package/lib/typescript/components/DaySelector.d.ts +2 -2
- package/lib/typescript/components/DaySelector.d.ts.map +1 -1
- package/lib/typescript/components/Header.d.ts +3 -3
- package/lib/typescript/components/Header.d.ts.map +1 -1
- package/lib/typescript/components/MonthSelector.d.ts +2 -2
- package/lib/typescript/components/MonthSelector.d.ts.map +1 -1
- package/lib/typescript/components/TimeSelector.d.ts +2 -2
- package/lib/typescript/components/TimeSelector.d.ts.map +1 -1
- package/lib/typescript/components/WheelPicker/Wheel.d.ts +5 -6
- package/lib/typescript/components/WheelPicker/Wheel.d.ts.map +1 -1
- package/lib/typescript/components/WheelPicker/WheelNative.d.ts +7 -8
- package/lib/typescript/components/WheelPicker/WheelNative.d.ts.map +1 -1
- package/lib/typescript/components/WheelPicker/WheelNativePicker/index.d.ts +3 -0
- package/lib/typescript/components/WheelPicker/WheelNativePicker/index.d.ts.map +1 -0
- package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker-item.d.ts +16 -0
- package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker-item.d.ts.map +1 -0
- package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker.d.ts +19 -0
- package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker.d.ts.map +1 -0
- package/lib/typescript/components/WheelPicker/WheelWeb.d.ts +6 -5
- package/lib/typescript/components/WheelPicker/WheelWeb.d.ts.map +1 -1
- package/lib/typescript/components/WheelPicker/animated-math.d.ts +5 -0
- package/lib/typescript/components/WheelPicker/animated-math.d.ts.map +1 -0
- package/lib/typescript/components/WheelPicker/period-native.d.ts +8 -0
- package/lib/typescript/components/WheelPicker/period-native.d.ts.map +1 -0
- package/lib/typescript/components/WheelPicker/period-picker.d.ts +8 -0
- package/lib/typescript/components/WheelPicker/period-picker.d.ts.map +1 -0
- package/lib/typescript/components/WheelPicker/period-web.d.ts +8 -0
- package/lib/typescript/components/WheelPicker/period-web.d.ts.map +1 -0
- package/lib/typescript/components/YearSelector.d.ts +2 -2
- package/lib/typescript/components/YearSelector.d.ts.map +1 -1
- package/lib/typescript/enums.d.ts +2 -1
- package/lib/typescript/enums.d.ts.map +1 -1
- package/lib/typescript/types.d.ts +5 -2
- package/lib/typescript/types.d.ts.map +1 -1
- package/lib/typescript/utils.d.ts +2 -2
- package/lib/typescript/utils.d.ts.map +1 -1
- package/package.json +7 -6
- package/src/DateTimePicker.tsx +20 -15
- package/src/components/Calendar.tsx +8 -8
- package/src/components/DatePicker.tsx +38 -66
- package/src/components/Day.tsx +9 -9
- package/src/components/DaySelector.tsx +6 -6
- package/src/components/Header.tsx +5 -5
- package/src/components/MonthSelector.tsx +4 -3
- package/src/components/TimeSelector.tsx +11 -12
- package/src/components/WheelPicker/Wheel.tsx +10 -10
- package/src/components/WheelPicker/WheelNative.tsx +13 -47
- package/src/components/WheelPicker/WheelNativePicker/index.ts +3 -0
- package/src/components/WheelPicker/WheelNativePicker/wheel-picker-item.tsx +140 -0
- package/src/components/WheelPicker/WheelNativePicker/wheel-picker.tsx +220 -0
- package/src/components/WheelPicker/WheelWeb.tsx +92 -65
- package/src/components/WheelPicker/animated-math.ts +33 -0
- package/src/components/WheelPicker/period-native.tsx +39 -0
- package/src/components/WheelPicker/period-picker.tsx +16 -0
- package/src/components/WheelPicker/period-web.tsx +37 -0
- package/src/components/YearSelector.tsx +4 -4
- package/src/enums.ts +4 -3
- package/src/types.ts +6 -2
- package/src/utils.ts +3 -3
- /package/src/{CalendarContext.tsx → CalendarContext.ts} +0 -0
|
@@ -3,57 +3,24 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.default =
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
var _CalendarContext = require("../../CalendarContext");
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
var _WheelNativePicker = _interopRequireDefault(require("./WheelNativePicker"));
|
|
10
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
-
function
|
|
10
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
11
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
12
|
+
const WheelNative = ({
|
|
12
13
|
value,
|
|
13
14
|
setValue = () => {},
|
|
14
|
-
items
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
theme
|
|
19
|
-
} = (0, _CalendarContext.useCalendarContext)();
|
|
20
|
-
return /*#__PURE__*/React.createElement(_reactNativeWheely.default, {
|
|
21
|
-
selectedIndex: value < 0 ? 0 : value,
|
|
15
|
+
items
|
|
16
|
+
}) => {
|
|
17
|
+
return /*#__PURE__*/_react.default.createElement(_WheelNativePicker.default, {
|
|
18
|
+
value: value,
|
|
22
19
|
options: items,
|
|
23
20
|
onChange: setValue,
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
...(theme === null || theme === void 0 ? void 0 : theme.wheelPickerContainerStyle)
|
|
27
|
-
},
|
|
28
|
-
itemStyle: theme === null || theme === void 0 ? void 0 : theme.wheelPickerItemStyle,
|
|
29
|
-
itemTextStyle: {
|
|
30
|
-
...styles.wheelPickerText,
|
|
31
|
-
...(theme === null || theme === void 0 ? void 0 : theme.wheelPickerTextStyle)
|
|
32
|
-
},
|
|
33
|
-
selectedIndicatorStyle: {
|
|
34
|
-
...styles.wheelSelectedIndicator,
|
|
35
|
-
...indicatorStyle,
|
|
36
|
-
...(theme === null || theme === void 0 ? void 0 : theme.wheelPickerIndicatorStyle)
|
|
37
|
-
},
|
|
38
|
-
itemHeight: 45,
|
|
39
|
-
decelerationRate: theme === null || theme === void 0 ? void 0 : theme.wheelPickerDecelerationRate
|
|
21
|
+
itemHeight: 44,
|
|
22
|
+
decelerationRate: "fast"
|
|
40
23
|
});
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
container: {
|
|
44
|
-
display: 'flex',
|
|
45
|
-
..._reactNative.Platform.select({
|
|
46
|
-
web: {
|
|
47
|
-
userSelect: 'none'
|
|
48
|
-
}
|
|
49
|
-
})
|
|
50
|
-
},
|
|
51
|
-
wheelSelectedIndicator: {
|
|
52
|
-
borderRadius: 10
|
|
53
|
-
},
|
|
54
|
-
wheelPickerText: {
|
|
55
|
-
fontSize: 18,
|
|
56
|
-
fontWeight: '500'
|
|
57
|
-
}
|
|
58
|
-
});
|
|
24
|
+
};
|
|
25
|
+
var _default = exports.default = /*#__PURE__*/(0, _react.memo)(WheelNative);
|
|
59
26
|
//# sourceMappingURL=WheelNative.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_WheelNativePicker","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","WheelNative","value","setValue","items","createElement","options","onChange","itemHeight","decelerationRate","_default","exports","memo"],"sourceRoot":"../../../../src","sources":["components/WheelPicker/WheelNative.tsx"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,kBAAA,GAAAC,sBAAA,CAAAF,OAAA;AAA8C,SAAAE,uBAAAC,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAR,wBAAAQ,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAH,UAAA,SAAAG,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAF,OAAA,EAAAE,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAC,GAAA,CAAAJ,CAAA,UAAAG,CAAA,CAAAE,GAAA,CAAAL,CAAA,OAAAM,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAZ,CAAA,oBAAAY,CAAA,IAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAY,CAAA,SAAAI,CAAA,GAAAR,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,CAAA,EAAAY,CAAA,UAAAI,CAAA,KAAAA,CAAA,CAAAX,GAAA,IAAAW,CAAA,CAAAC,GAAA,IAAAR,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAI,CAAA,IAAAV,CAAA,CAAAM,CAAA,IAAAZ,CAAA,CAAAY,CAAA,YAAAN,CAAA,CAAAR,OAAA,GAAAE,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAc,GAAA,CAAAjB,CAAA,EAAAM,CAAA,GAAAA,CAAA;AAS9C,MAAMY,WAAiC,GAAGA,CAAC;EACzCC,KAAK;EACLC,QAAQ,GAAGA,CAAA,KAAM,CAAC,CAAC;EACnBC;AACF,CAAC,KAAK;EACJ,oBACE9B,MAAA,CAAAO,OAAA,CAAAwB,aAAA,CAAC5B,kBAAA,CAAAI,OAAW;IACVqB,KAAK,EAAEA,KAAM;IACbI,OAAO,EAAEF,KAAM;IACfG,QAAQ,EAAEJ,QAAS;IACnBK,UAAU,EAAE,EAAG;IACfC,gBAAgB,EAAC;EAAM,CACxB,CAAC;AAEN,CAAC;AAAC,IAAAC,QAAA,GAAAC,OAAA,CAAA9B,OAAA,gBAEa,IAAA+B,WAAI,EAACX,WAAW,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _wheelPicker = _interopRequireDefault(require("./wheel-picker"));
|
|
8
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
9
|
+
var _default = exports.default = _wheelPicker.default;
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_wheelPicker","_interopRequireDefault","require","obj","__esModule","default","_default","exports","WheelPicker"],"sourceRoot":"../../../../../src","sources":["components/WheelPicker/WheelNativePicker/index.ts"],"mappings":";;;;;;AAAA,IAAAA,YAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAyC,SAAAD,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,IAAAG,QAAA,GAAAC,OAAA,CAAAF,OAAA,GAE1BG,oBAAW"}
|
|
@@ -0,0 +1,130 @@
|
|
|
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 _CalendarContext = require("src/CalendarContext");
|
|
10
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
11
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
12
|
+
const WheelPickerItem = ({
|
|
13
|
+
height,
|
|
14
|
+
option,
|
|
15
|
+
index,
|
|
16
|
+
visibleRest,
|
|
17
|
+
currentScrollIndex,
|
|
18
|
+
opacityFunction,
|
|
19
|
+
rotationFunction,
|
|
20
|
+
scaleFunction
|
|
21
|
+
}) => {
|
|
22
|
+
const {
|
|
23
|
+
theme
|
|
24
|
+
} = (0, _CalendarContext.useCalendarContext)();
|
|
25
|
+
const relativeScrollIndex = _reactNative.Animated.subtract(index, currentScrollIndex);
|
|
26
|
+
const translateY = relativeScrollIndex.interpolate({
|
|
27
|
+
inputRange: (() => {
|
|
28
|
+
const range = [0];
|
|
29
|
+
for (let i = 1; i <= visibleRest + 1; i++) {
|
|
30
|
+
range.unshift(-i);
|
|
31
|
+
range.push(i);
|
|
32
|
+
}
|
|
33
|
+
return range;
|
|
34
|
+
})(),
|
|
35
|
+
outputRange: (() => {
|
|
36
|
+
const range = [0];
|
|
37
|
+
for (let i = 1; i <= visibleRest + 1; i++) {
|
|
38
|
+
let y = height / 2 * (1 - Math.sin(Math.PI / 2 - rotationFunction(i)));
|
|
39
|
+
for (let j = 1; j < i; j++) {
|
|
40
|
+
y += height * (1 - Math.sin(Math.PI / 2 - rotationFunction(j)));
|
|
41
|
+
}
|
|
42
|
+
range.unshift(y);
|
|
43
|
+
range.push(-y);
|
|
44
|
+
}
|
|
45
|
+
return range;
|
|
46
|
+
})()
|
|
47
|
+
});
|
|
48
|
+
const opacity = relativeScrollIndex.interpolate({
|
|
49
|
+
inputRange: (() => {
|
|
50
|
+
const range = [0];
|
|
51
|
+
for (let i = 1; i <= visibleRest + 1; i++) {
|
|
52
|
+
range.unshift(-i);
|
|
53
|
+
range.push(i);
|
|
54
|
+
}
|
|
55
|
+
return range;
|
|
56
|
+
})(),
|
|
57
|
+
outputRange: (() => {
|
|
58
|
+
const range = [1];
|
|
59
|
+
for (let x = 1; x <= visibleRest + 1; x++) {
|
|
60
|
+
const y = opacityFunction(x);
|
|
61
|
+
range.unshift(y);
|
|
62
|
+
range.push(y);
|
|
63
|
+
}
|
|
64
|
+
return range;
|
|
65
|
+
})()
|
|
66
|
+
});
|
|
67
|
+
const scale = relativeScrollIndex.interpolate({
|
|
68
|
+
inputRange: (() => {
|
|
69
|
+
const range = [0];
|
|
70
|
+
for (let i = 1; i <= visibleRest + 1; i++) {
|
|
71
|
+
range.unshift(-i);
|
|
72
|
+
range.push(i);
|
|
73
|
+
}
|
|
74
|
+
return range;
|
|
75
|
+
})(),
|
|
76
|
+
outputRange: (() => {
|
|
77
|
+
const range = [1.0];
|
|
78
|
+
for (let x = 1; x <= visibleRest + 1; x++) {
|
|
79
|
+
const y = scaleFunction(x);
|
|
80
|
+
range.unshift(y);
|
|
81
|
+
range.push(y);
|
|
82
|
+
}
|
|
83
|
+
return range;
|
|
84
|
+
})()
|
|
85
|
+
});
|
|
86
|
+
const rotateX = relativeScrollIndex.interpolate({
|
|
87
|
+
inputRange: (() => {
|
|
88
|
+
const range = [0];
|
|
89
|
+
for (let i = 1; i <= visibleRest + 1; i++) {
|
|
90
|
+
range.unshift(-i);
|
|
91
|
+
range.push(i);
|
|
92
|
+
}
|
|
93
|
+
return range;
|
|
94
|
+
})(),
|
|
95
|
+
outputRange: (() => {
|
|
96
|
+
const range = ['0deg'];
|
|
97
|
+
for (let x = 1; x <= visibleRest + 1; x++) {
|
|
98
|
+
const y = rotationFunction(x);
|
|
99
|
+
range.unshift(`${y}deg`);
|
|
100
|
+
range.push(`${y}deg`);
|
|
101
|
+
}
|
|
102
|
+
return range;
|
|
103
|
+
})()
|
|
104
|
+
});
|
|
105
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.Animated.View, {
|
|
106
|
+
style: [styles.option, {
|
|
107
|
+
height,
|
|
108
|
+
opacity,
|
|
109
|
+
transform: [{
|
|
110
|
+
translateY
|
|
111
|
+
}, {
|
|
112
|
+
rotateX
|
|
113
|
+
}, {
|
|
114
|
+
scale
|
|
115
|
+
}]
|
|
116
|
+
}, theme.wheelPickerItemStyle]
|
|
117
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Text, {
|
|
118
|
+
style: theme.wheelPickerTextStyle
|
|
119
|
+
}, option === null || option === void 0 ? void 0 : option.text));
|
|
120
|
+
};
|
|
121
|
+
const styles = _reactNative.StyleSheet.create({
|
|
122
|
+
option: {
|
|
123
|
+
alignItems: 'center',
|
|
124
|
+
justifyContent: 'center',
|
|
125
|
+
paddingHorizontal: 10,
|
|
126
|
+
zIndex: 100
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
var _default = exports.default = /*#__PURE__*/(0, _react.memo)(WheelPickerItem);
|
|
130
|
+
//# sourceMappingURL=wheel-picker-item.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_CalendarContext","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","WheelPickerItem","height","option","index","visibleRest","currentScrollIndex","opacityFunction","rotationFunction","scaleFunction","theme","useCalendarContext","relativeScrollIndex","Animated","subtract","translateY","interpolate","inputRange","range","unshift","push","outputRange","y","Math","sin","PI","j","opacity","x","scale","rotateX","createElement","View","style","styles","transform","wheelPickerItemStyle","Text","wheelPickerTextStyle","text","StyleSheet","create","alignItems","justifyContent","paddingHorizontal","zIndex","_default","exports","memo"],"sourceRoot":"../../../../../src","sources":["components/WheelPicker/WheelNativePicker/wheel-picker-item.tsx"],"mappings":"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"}
|
|
@@ -0,0 +1,174 @@
|
|
|
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 _wheelPickerItem = _interopRequireDefault(require("./wheel-picker-item"));
|
|
10
|
+
var _CalendarContext = require("src/CalendarContext");
|
|
11
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
12
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
13
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
14
|
+
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
15
|
+
const WheelPicker = ({
|
|
16
|
+
value,
|
|
17
|
+
options,
|
|
18
|
+
onChange,
|
|
19
|
+
itemHeight = 40,
|
|
20
|
+
scaleFunction = x => 1.0 ** x,
|
|
21
|
+
rotationFunction = x => 1 - Math.pow(1 / 2, x),
|
|
22
|
+
opacityFunction = x => Math.pow(1 / 3, x),
|
|
23
|
+
visibleRest = 2,
|
|
24
|
+
decelerationRate = 'normal',
|
|
25
|
+
containerProps = {},
|
|
26
|
+
flatListProps = {}
|
|
27
|
+
}) => {
|
|
28
|
+
const {
|
|
29
|
+
theme
|
|
30
|
+
} = (0, _CalendarContext.useCalendarContext)();
|
|
31
|
+
const momentumStarted = (0, _react.useRef)(false);
|
|
32
|
+
const selectedIndex = options.findIndex(item => item.value === value);
|
|
33
|
+
const flatListRef = (0, _react.useRef)(null);
|
|
34
|
+
const [scrollY] = (0, _react.useState)(new _reactNative.Animated.Value(selectedIndex * itemHeight));
|
|
35
|
+
const containerHeight = (1 + visibleRest * 2) * itemHeight;
|
|
36
|
+
const paddedOptions = (0, _react.useMemo)(() => {
|
|
37
|
+
const array = [...options];
|
|
38
|
+
for (let i = 0; i < visibleRest; i++) {
|
|
39
|
+
array.unshift(null);
|
|
40
|
+
array.push(null);
|
|
41
|
+
}
|
|
42
|
+
return array;
|
|
43
|
+
}, [options, visibleRest]);
|
|
44
|
+
const offsets = (0, _react.useMemo)(() => [...Array(paddedOptions.length)].map((_, i) => i * itemHeight), [paddedOptions, itemHeight]);
|
|
45
|
+
const currentScrollIndex = (0, _react.useMemo)(() => _reactNative.Animated.add(_reactNative.Animated.divide(scrollY, itemHeight), visibleRest), [visibleRest, scrollY, itemHeight]);
|
|
46
|
+
const handleScrollEnd = event => {
|
|
47
|
+
const offsetY = Math.min(itemHeight * (options.length - 1), Math.max(event.nativeEvent.contentOffset.y, 0));
|
|
48
|
+
let index = Math.floor(offsetY / itemHeight);
|
|
49
|
+
const remainder = offsetY % itemHeight;
|
|
50
|
+
if (remainder > itemHeight / 2) {
|
|
51
|
+
index++;
|
|
52
|
+
}
|
|
53
|
+
if (index !== selectedIndex) {
|
|
54
|
+
var _options$index;
|
|
55
|
+
onChange(((_options$index = options[index]) === null || _options$index === void 0 ? void 0 : _options$index.value) || 0);
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
const handleMomentumScrollBegin = () => {
|
|
59
|
+
momentumStarted.current = true;
|
|
60
|
+
};
|
|
61
|
+
const handleMomentumScrollEnd = event => {
|
|
62
|
+
momentumStarted.current = false;
|
|
63
|
+
handleScrollEnd(event);
|
|
64
|
+
};
|
|
65
|
+
const handleScrollEndDrag = event => {
|
|
66
|
+
var _event$nativeEvent$co;
|
|
67
|
+
// Capture the offset value immediately
|
|
68
|
+
const offsetY = (_event$nativeEvent$co = event.nativeEvent.contentOffset) === null || _event$nativeEvent$co === void 0 ? void 0 : _event$nativeEvent$co.y;
|
|
69
|
+
|
|
70
|
+
// We'll start a short timer to see if momentum scroll begins
|
|
71
|
+
setTimeout(() => {
|
|
72
|
+
// If momentum scroll hasn't started within the timeout,
|
|
73
|
+
// then it was a slow scroll that won't trigger momentum
|
|
74
|
+
if (!momentumStarted.current && offsetY !== undefined) {
|
|
75
|
+
// Create a synthetic event with just the data we need
|
|
76
|
+
const syntheticEvent = {
|
|
77
|
+
nativeEvent: {
|
|
78
|
+
contentOffset: {
|
|
79
|
+
y: offsetY
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
handleScrollEnd(syntheticEvent);
|
|
84
|
+
}
|
|
85
|
+
}, 50);
|
|
86
|
+
};
|
|
87
|
+
(0, _react.useEffect)(() => {
|
|
88
|
+
if (selectedIndex < 0 || selectedIndex >= options.length) {
|
|
89
|
+
throw new Error(`Selected index ${selectedIndex} is out of bounds [0, ${options.length - 1}]`);
|
|
90
|
+
}
|
|
91
|
+
}, [selectedIndex, options]);
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* If selectedIndex is changed from outside (not via onChange) we need to scroll to the specified index.
|
|
95
|
+
* This ensures that what the user sees as selected in the picker always corresponds to the value state.
|
|
96
|
+
*/
|
|
97
|
+
(0, _react.useEffect)(() => {
|
|
98
|
+
var _flatListRef$current;
|
|
99
|
+
(_flatListRef$current = flatListRef.current) === null || _flatListRef$current === void 0 || _flatListRef$current.scrollToIndex({
|
|
100
|
+
index: selectedIndex,
|
|
101
|
+
animated: _reactNative.Platform.OS === 'ios'
|
|
102
|
+
});
|
|
103
|
+
}, [selectedIndex, itemHeight]);
|
|
104
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, _extends({
|
|
105
|
+
style: [styles.container, {
|
|
106
|
+
height: containerHeight
|
|
107
|
+
}, theme.wheelPickerContainerStyle]
|
|
108
|
+
}, containerProps), /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
109
|
+
style: [styles.selectedIndicator, {
|
|
110
|
+
transform: [{
|
|
111
|
+
translateY: -itemHeight / 2
|
|
112
|
+
}],
|
|
113
|
+
height: itemHeight
|
|
114
|
+
}, theme.wheelPickerSelectedIndicatorStyle]
|
|
115
|
+
}), /*#__PURE__*/_react.default.createElement(_reactNative.Animated.FlatList, _extends({}, flatListProps, {
|
|
116
|
+
ref: flatListRef,
|
|
117
|
+
nestedScrollEnabled: true,
|
|
118
|
+
style: styles.scrollView,
|
|
119
|
+
showsVerticalScrollIndicator: false,
|
|
120
|
+
onScroll: _reactNative.Animated.event([{
|
|
121
|
+
nativeEvent: {
|
|
122
|
+
contentOffset: {
|
|
123
|
+
y: scrollY
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}], {
|
|
127
|
+
useNativeDriver: true
|
|
128
|
+
}),
|
|
129
|
+
onScrollEndDrag: handleScrollEndDrag,
|
|
130
|
+
onMomentumScrollBegin: handleMomentumScrollBegin,
|
|
131
|
+
onMomentumScrollEnd: handleMomentumScrollEnd,
|
|
132
|
+
snapToOffsets: offsets,
|
|
133
|
+
decelerationRate: decelerationRate,
|
|
134
|
+
initialScrollIndex: selectedIndex,
|
|
135
|
+
getItemLayout: (_, index) => ({
|
|
136
|
+
length: itemHeight,
|
|
137
|
+
offset: itemHeight * index,
|
|
138
|
+
index
|
|
139
|
+
}),
|
|
140
|
+
data: paddedOptions,
|
|
141
|
+
keyExtractor: (item, index) => item ? `${item.value}-${item.text}-${index}` : `null-${index}`,
|
|
142
|
+
renderItem: ({
|
|
143
|
+
item: option,
|
|
144
|
+
index
|
|
145
|
+
}) => /*#__PURE__*/_react.default.createElement(_wheelPickerItem.default, {
|
|
146
|
+
key: `option-${index}`,
|
|
147
|
+
index: index,
|
|
148
|
+
option: option,
|
|
149
|
+
height: itemHeight,
|
|
150
|
+
currentScrollIndex: currentScrollIndex,
|
|
151
|
+
scaleFunction: scaleFunction,
|
|
152
|
+
rotationFunction: rotationFunction,
|
|
153
|
+
opacityFunction: opacityFunction,
|
|
154
|
+
visibleRest: visibleRest
|
|
155
|
+
})
|
|
156
|
+
})));
|
|
157
|
+
};
|
|
158
|
+
const styles = _reactNative.StyleSheet.create({
|
|
159
|
+
container: {
|
|
160
|
+
display: 'flex',
|
|
161
|
+
position: 'relative'
|
|
162
|
+
},
|
|
163
|
+
selectedIndicator: {
|
|
164
|
+
position: 'absolute',
|
|
165
|
+
width: '100%',
|
|
166
|
+
top: '50%'
|
|
167
|
+
},
|
|
168
|
+
scrollView: {
|
|
169
|
+
overflow: 'hidden',
|
|
170
|
+
flex: 1
|
|
171
|
+
}
|
|
172
|
+
});
|
|
173
|
+
var _default = exports.default = /*#__PURE__*/(0, _react.memo)(WheelPicker);
|
|
174
|
+
//# sourceMappingURL=wheel-picker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_wheelPickerItem","_interopRequireDefault","_CalendarContext","obj","__esModule","default","_getRequireWildcardCache","e","WeakMap","r","t","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","_extends","assign","bind","target","arguments","length","source","key","apply","WheelPicker","value","options","onChange","itemHeight","scaleFunction","x","rotationFunction","Math","pow","opacityFunction","visibleRest","decelerationRate","containerProps","flatListProps","theme","useCalendarContext","momentumStarted","useRef","selectedIndex","findIndex","item","flatListRef","scrollY","useState","Animated","Value","containerHeight","paddedOptions","useMemo","array","unshift","push","offsets","Array","map","_","currentScrollIndex","add","divide","handleScrollEnd","event","offsetY","min","max","nativeEvent","contentOffset","y","index","floor","remainder","_options$index","handleMomentumScrollBegin","current","handleMomentumScrollEnd","handleScrollEndDrag","_event$nativeEvent$co","setTimeout","undefined","syntheticEvent","useEffect","Error","_flatListRef$current","scrollToIndex","animated","Platform","OS","createElement","View","style","styles","container","height","wheelPickerContainerStyle","selectedIndicator","transform","translateY","wheelPickerSelectedIndicatorStyle","FlatList","ref","nestedScrollEnabled","scrollView","showsVerticalScrollIndicator","onScroll","useNativeDriver","onScrollEndDrag","onMomentumScrollBegin","onMomentumScrollEnd","snapToOffsets","initialScrollIndex","getItemLayout","offset","data","keyExtractor","text","renderItem","option","StyleSheet","create","display","position","width","top","overflow","flex","_default","exports","memo"],"sourceRoot":"../../../../../src","sources":["components/WheelPicker/WheelNativePicker/wheel-picker.tsx"],"mappings":"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"}
|
|
@@ -4,12 +4,16 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
var _react = require("react");
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
8
|
var _reactNative = require("react-native");
|
|
9
|
-
var
|
|
10
|
-
var
|
|
11
|
-
var
|
|
9
|
+
var _lodash = require("lodash");
|
|
10
|
+
var _enums = require("src/enums");
|
|
11
|
+
var _CalendarContext = require("src/CalendarContext");
|
|
12
|
+
var _animatedMath = require("./animated-math");
|
|
13
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
14
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
12
15
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
16
|
+
const ITEM_HEIGHT = 44;
|
|
13
17
|
const WheelWeb = ({
|
|
14
18
|
value,
|
|
15
19
|
setValue = () => {},
|
|
@@ -22,9 +26,11 @@ const WheelWeb = ({
|
|
|
22
26
|
const translateY = (0, _react.useRef)(new _reactNative.Animated.Value(0)).current;
|
|
23
27
|
const renderCount = displayCount * 2 < items.length ? displayCount * 8 : displayCount * 2 - 1;
|
|
24
28
|
const circular = items.length >= displayCount;
|
|
25
|
-
const height =
|
|
29
|
+
const height = 140;
|
|
26
30
|
const radius = height / 2;
|
|
27
|
-
const valueIndex = (0, _react.useMemo)(() =>
|
|
31
|
+
const valueIndex = (0, _react.useMemo)(() => {
|
|
32
|
+
return items.findIndex(item => item.value === value) || 0;
|
|
33
|
+
}, [items, value]);
|
|
28
34
|
const panResponder = (0, _react.useMemo)(() => {
|
|
29
35
|
return _reactNative.PanResponder.create({
|
|
30
36
|
onMoveShouldSetPanResponder: () => true,
|
|
@@ -37,14 +43,15 @@ const WheelWeb = ({
|
|
|
37
43
|
evt.stopPropagation();
|
|
38
44
|
},
|
|
39
45
|
onPanResponderRelease: (_, gestureState) => {
|
|
46
|
+
var _items$;
|
|
40
47
|
translateY.extractOffset();
|
|
41
48
|
let newValueIndex = valueIndex - Math.round(gestureState.dy / (radius * 2 / displayCount));
|
|
42
49
|
if (circular) newValueIndex = (newValueIndex + items.length) % items.length;else if (newValueIndex < 0) newValueIndex = 0;else if (newValueIndex >= items.length) newValueIndex = items.length - 1;
|
|
43
|
-
const newValue = items[newValueIndex]
|
|
44
|
-
if (newValue ===
|
|
50
|
+
const newValue = items[newValueIndex];
|
|
51
|
+
if ((newValue === null || newValue === void 0 ? void 0 : newValue.value) === value) {
|
|
45
52
|
translateY.setOffset(0);
|
|
46
53
|
translateY.setValue(0);
|
|
47
|
-
} else setValue(
|
|
54
|
+
} else if (newValue !== null && newValue !== void 0 && newValue.value) setValue(newValue.value);else if ((_items$ = items[0]) !== null && _items$ !== void 0 && _items$.value) setValue(items[0].value);
|
|
48
55
|
}
|
|
49
56
|
});
|
|
50
57
|
}, [circular, displayCount, radius, setValue, value, valueIndex, items, translateY]);
|
|
@@ -54,17 +61,14 @@ const WheelWeb = ({
|
|
|
54
61
|
length: renderCount
|
|
55
62
|
}, (_, index) => {
|
|
56
63
|
let targetIndex = valueIndex + index - centerIndex;
|
|
57
|
-
if (targetIndex
|
|
58
|
-
|
|
59
|
-
targetIndex = (targetIndex + items.length) % items.length;
|
|
60
|
-
}
|
|
61
|
-
return items[targetIndex] || 0;
|
|
64
|
+
if (circular) targetIndex = (targetIndex % items.length + items.length) % items.length;else targetIndex = Math.max(0, Math.min(targetIndex, items.length - 1));
|
|
65
|
+
return items[targetIndex] || items[0];
|
|
62
66
|
});
|
|
63
67
|
}, [renderCount, valueIndex, items, circular]);
|
|
64
68
|
const animatedAngles = (0, _react.useMemo)(() => {
|
|
65
69
|
//translateY.setValue(0);
|
|
66
70
|
translateY.setOffset(0);
|
|
67
|
-
const currentIndex = displayValues.
|
|
71
|
+
const currentIndex = displayValues.findIndex(item => (item === null || item === void 0 ? void 0 : item.value) === value);
|
|
68
72
|
return displayValues && displayValues.length > 0 ? displayValues.map((_, index) => translateY.interpolate({
|
|
69
73
|
inputRange: [-radius, radius],
|
|
70
74
|
outputRange: [-radius + radius * 2 / displayCount * (index - currentIndex), radius + radius * 2 / displayCount * (index - currentIndex)],
|
|
@@ -75,22 +79,26 @@ const WheelWeb = ({
|
|
|
75
79
|
extrapolate: 'clamp'
|
|
76
80
|
})) : [];
|
|
77
81
|
}, [displayValues, radius, value, displayCount, translateY]);
|
|
78
|
-
return /*#__PURE__*/
|
|
79
|
-
style: [
|
|
80
|
-
}, panResponder.panHandlers),
|
|
82
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, _extends({
|
|
83
|
+
style: [defaultStyles.container, theme.wheelPickerContainerStyle]
|
|
84
|
+
}, panResponder.panHandlers), /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
85
|
+
style: [defaultStyles.selectedIndicator, {
|
|
86
|
+
transform: [{
|
|
87
|
+
translateY: -ITEM_HEIGHT / 2
|
|
88
|
+
}],
|
|
89
|
+
height: ITEM_HEIGHT
|
|
90
|
+
}, theme.wheelPickerSelectedIndicatorStyle]
|
|
91
|
+
}), displayValues === null || displayValues === void 0 ? void 0 : displayValues.map((displayValue, index) => {
|
|
81
92
|
const animatedAngle = animatedAngles[index];
|
|
82
|
-
return /*#__PURE__*/
|
|
83
|
-
key: `${displayValue}-${index}
|
|
84
|
-
style: [{
|
|
85
|
-
...styles.wheelPickerText,
|
|
86
|
-
...(theme === null || theme === void 0 ? void 0 : theme.wheelPickerTextStyle)
|
|
87
|
-
},
|
|
93
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.Animated.View, {
|
|
94
|
+
key: `${displayValue === null || displayValue === void 0 ? void 0 : displayValue.text}-${index}`
|
|
88
95
|
// eslint-disable-next-line react-native/no-inline-styles
|
|
89
|
-
|
|
96
|
+
,
|
|
97
|
+
style: {
|
|
90
98
|
position: 'absolute',
|
|
91
|
-
height:
|
|
99
|
+
height: ITEM_HEIGHT - 10,
|
|
92
100
|
transform: animatedAngle ? [{
|
|
93
|
-
translateY: _reactNative.Animated.multiply(radius, (0,
|
|
101
|
+
translateY: _reactNative.Animated.multiply(radius, (0, _animatedMath.sin)(animatedAngle))
|
|
94
102
|
}, {
|
|
95
103
|
rotateX: animatedAngle.interpolate({
|
|
96
104
|
inputRange: [-Math.PI / 2, Math.PI / 2],
|
|
@@ -98,18 +106,20 @@ const WheelWeb = ({
|
|
|
98
106
|
extrapolate: 'clamp'
|
|
99
107
|
})
|
|
100
108
|
}] : [],
|
|
101
|
-
opacity: displayValue
|
|
102
|
-
}
|
|
103
|
-
},
|
|
109
|
+
opacity: (displayValue === null || displayValue === void 0 ? void 0 : displayValue.value) !== value ? 0.3 : 1
|
|
110
|
+
}
|
|
111
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Text, {
|
|
112
|
+
style: theme === null || theme === void 0 ? void 0 : theme.wheelPickerTextStyle
|
|
113
|
+
}, displayValue === null || displayValue === void 0 ? void 0 : displayValue.text));
|
|
104
114
|
}));
|
|
105
115
|
};
|
|
106
|
-
const
|
|
116
|
+
const defaultStyles = _reactNative.StyleSheet.create({
|
|
107
117
|
container: {
|
|
108
118
|
minWidth: 30,
|
|
109
119
|
overflow: 'hidden',
|
|
110
120
|
alignItems: 'center',
|
|
111
121
|
justifyContent: 'center',
|
|
112
|
-
height: _enums.
|
|
122
|
+
height: _enums.CONTAINER_HEIGHT / 2,
|
|
113
123
|
..._reactNative.Platform.select({
|
|
114
124
|
web: {
|
|
115
125
|
cursor: 'pointer',
|
|
@@ -121,12 +131,15 @@ const styles = _reactNative.StyleSheet.create({
|
|
|
121
131
|
justifyContent: 'space-between',
|
|
122
132
|
alignItems: 'center'
|
|
123
133
|
},
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
134
|
+
selectedIndicator: {
|
|
135
|
+
position: 'absolute',
|
|
136
|
+
width: '100%',
|
|
137
|
+
top: '50%'
|
|
127
138
|
}
|
|
128
139
|
});
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
140
|
+
const customComparator = (prev, next) => {
|
|
141
|
+
const areEqual = prev.value === next.value && prev.setValue === next.setValue && (0, _lodash.isEqual)(prev.items, next.items);
|
|
142
|
+
return areEqual;
|
|
143
|
+
};
|
|
144
|
+
var _default = exports.default = /*#__PURE__*/(0, _react.memo)(WheelWeb, customComparator);
|
|
132
145
|
//# sourceMappingURL=WheelWeb.js.map
|