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.
Files changed (156) hide show
  1. package/README.md +27 -28
  2. package/lib/commonjs/CalendarContext.js.map +1 -1
  3. package/lib/commonjs/DateTimePicker.js +15 -8
  4. package/lib/commonjs/DateTimePicker.js.map +1 -1
  5. package/lib/commonjs/components/Calendar.js +14 -12
  6. package/lib/commonjs/components/Calendar.js.map +1 -1
  7. package/lib/commonjs/components/DatePicker.js +46 -58
  8. package/lib/commonjs/components/DatePicker.js.map +1 -1
  9. package/lib/commonjs/components/Day.js +18 -16
  10. package/lib/commonjs/components/Day.js.map +1 -1
  11. package/lib/commonjs/components/DaySelector.js +12 -12
  12. package/lib/commonjs/components/DaySelector.js.map +1 -1
  13. package/lib/commonjs/components/Header.js +27 -25
  14. package/lib/commonjs/components/Header.js.map +1 -1
  15. package/lib/commonjs/components/MonthSelector.js +9 -7
  16. package/lib/commonjs/components/MonthSelector.js.map +1 -1
  17. package/lib/commonjs/components/TimeSelector.js +22 -17
  18. package/lib/commonjs/components/TimeSelector.js.map +1 -1
  19. package/lib/commonjs/components/WheelPicker/Wheel.js +9 -4
  20. package/lib/commonjs/components/WheelPicker/Wheel.js.map +1 -1
  21. package/lib/commonjs/components/WheelPicker/WheelNative.js +14 -47
  22. package/lib/commonjs/components/WheelPicker/WheelNative.js.map +1 -1
  23. package/lib/commonjs/components/WheelPicker/WheelNativePicker/index.js +10 -0
  24. package/lib/commonjs/components/WheelPicker/WheelNativePicker/index.js.map +1 -0
  25. package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker-item.js +130 -0
  26. package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker-item.js.map +1 -0
  27. package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker.js +174 -0
  28. package/lib/commonjs/components/WheelPicker/WheelNativePicker/wheel-picker.js.map +1 -0
  29. package/lib/commonjs/components/WheelPicker/WheelWeb.js +51 -38
  30. package/lib/commonjs/components/WheelPicker/WheelWeb.js.map +1 -1
  31. package/lib/commonjs/components/WheelPicker/animated-math.js +26 -0
  32. package/lib/commonjs/components/WheelPicker/animated-math.js.map +1 -0
  33. package/lib/commonjs/components/WheelPicker/period-native.js +36 -0
  34. package/lib/commonjs/components/WheelPicker/period-native.js.map +1 -0
  35. package/lib/commonjs/components/WheelPicker/period-picker.js +19 -0
  36. package/lib/commonjs/components/WheelPicker/period-picker.js.map +1 -0
  37. package/lib/commonjs/components/WheelPicker/period-web.js +34 -0
  38. package/lib/commonjs/components/WheelPicker/period-web.js.map +1 -0
  39. package/lib/commonjs/components/YearSelector.js +10 -8
  40. package/lib/commonjs/components/YearSelector.js.map +1 -1
  41. package/lib/commonjs/enums.js +5 -4
  42. package/lib/commonjs/enums.js.map +1 -1
  43. package/lib/commonjs/utils.js +4 -1
  44. package/lib/commonjs/utils.js.map +1 -1
  45. package/lib/module/CalendarContext.js.map +1 -1
  46. package/lib/module/DateTimePicker.js +11 -6
  47. package/lib/module/DateTimePicker.js.map +1 -1
  48. package/lib/module/components/Calendar.js +4 -4
  49. package/lib/module/components/Calendar.js.map +1 -1
  50. package/lib/module/components/DatePicker.js +36 -50
  51. package/lib/module/components/DatePicker.js.map +1 -1
  52. package/lib/module/components/Day.js +8 -8
  53. package/lib/module/components/Day.js.map +1 -1
  54. package/lib/module/components/DaySelector.js +4 -4
  55. package/lib/module/components/DaySelector.js.map +1 -1
  56. package/lib/module/components/Header.js +3 -3
  57. package/lib/module/components/Header.js.map +1 -1
  58. package/lib/module/components/MonthSelector.js +3 -2
  59. package/lib/module/components/MonthSelector.js.map +1 -1
  60. package/lib/module/components/TimeSelector.js +10 -7
  61. package/lib/module/components/TimeSelector.js.map +1 -1
  62. package/lib/module/components/WheelPicker/Wheel.js +6 -3
  63. package/lib/module/components/WheelPicker/Wheel.js.map +1 -1
  64. package/lib/module/components/WheelPicker/WheelNative.js +10 -45
  65. package/lib/module/components/WheelPicker/WheelNative.js.map +1 -1
  66. package/lib/module/components/WheelPicker/WheelNativePicker/index.js +3 -0
  67. package/lib/module/components/WheelPicker/WheelNativePicker/index.js.map +1 -0
  68. package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker-item.js +122 -0
  69. package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker-item.js.map +1 -0
  70. package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker.js +165 -0
  71. package/lib/module/components/WheelPicker/WheelNativePicker/wheel-picker.js.map +1 -0
  72. package/lib/module/components/WheelPicker/WheelWeb.js +48 -37
  73. package/lib/module/components/WheelPicker/WheelWeb.js.map +1 -1
  74. package/lib/module/components/WheelPicker/animated-math.js +20 -0
  75. package/lib/module/components/WheelPicker/animated-math.js.map +1 -0
  76. package/lib/module/components/WheelPicker/period-native.js +27 -0
  77. package/lib/module/components/WheelPicker/period-native.js.map +1 -0
  78. package/lib/module/components/WheelPicker/period-picker.js +10 -0
  79. package/lib/module/components/WheelPicker/period-picker.js.map +1 -0
  80. package/lib/module/components/WheelPicker/period-web.js +26 -0
  81. package/lib/module/components/WheelPicker/period-web.js.map +1 -0
  82. package/lib/module/components/YearSelector.js +3 -3
  83. package/lib/module/components/YearSelector.js.map +1 -1
  84. package/lib/module/enums.js +4 -3
  85. package/lib/module/enums.js.map +1 -1
  86. package/lib/module/utils.js +4 -1
  87. package/lib/module/utils.js.map +1 -1
  88. package/lib/typescript/CalendarContext.d.ts.map +1 -1
  89. package/lib/typescript/DateTimePicker.d.ts +3 -3
  90. package/lib/typescript/DateTimePicker.d.ts.map +1 -1
  91. package/lib/typescript/components/Calendar.d.ts +3 -3
  92. package/lib/typescript/components/Calendar.d.ts.map +1 -1
  93. package/lib/typescript/components/DatePicker.d.ts +2 -2
  94. package/lib/typescript/components/DatePicker.d.ts.map +1 -1
  95. package/lib/typescript/components/Day.d.ts +4 -5
  96. package/lib/typescript/components/Day.d.ts.map +1 -1
  97. package/lib/typescript/components/DaySelector.d.ts +2 -2
  98. package/lib/typescript/components/DaySelector.d.ts.map +1 -1
  99. package/lib/typescript/components/Header.d.ts +3 -3
  100. package/lib/typescript/components/Header.d.ts.map +1 -1
  101. package/lib/typescript/components/MonthSelector.d.ts +2 -2
  102. package/lib/typescript/components/MonthSelector.d.ts.map +1 -1
  103. package/lib/typescript/components/TimeSelector.d.ts +2 -2
  104. package/lib/typescript/components/TimeSelector.d.ts.map +1 -1
  105. package/lib/typescript/components/WheelPicker/Wheel.d.ts +5 -6
  106. package/lib/typescript/components/WheelPicker/Wheel.d.ts.map +1 -1
  107. package/lib/typescript/components/WheelPicker/WheelNative.d.ts +7 -8
  108. package/lib/typescript/components/WheelPicker/WheelNative.d.ts.map +1 -1
  109. package/lib/typescript/components/WheelPicker/WheelNativePicker/index.d.ts +3 -0
  110. package/lib/typescript/components/WheelPicker/WheelNativePicker/index.d.ts.map +1 -0
  111. package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker-item.d.ts +16 -0
  112. package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker-item.d.ts.map +1 -0
  113. package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker.d.ts +19 -0
  114. package/lib/typescript/components/WheelPicker/WheelNativePicker/wheel-picker.d.ts.map +1 -0
  115. package/lib/typescript/components/WheelPicker/WheelWeb.d.ts +6 -5
  116. package/lib/typescript/components/WheelPicker/WheelWeb.d.ts.map +1 -1
  117. package/lib/typescript/components/WheelPicker/animated-math.d.ts +5 -0
  118. package/lib/typescript/components/WheelPicker/animated-math.d.ts.map +1 -0
  119. package/lib/typescript/components/WheelPicker/period-native.d.ts +8 -0
  120. package/lib/typescript/components/WheelPicker/period-native.d.ts.map +1 -0
  121. package/lib/typescript/components/WheelPicker/period-picker.d.ts +8 -0
  122. package/lib/typescript/components/WheelPicker/period-picker.d.ts.map +1 -0
  123. package/lib/typescript/components/WheelPicker/period-web.d.ts +8 -0
  124. package/lib/typescript/components/WheelPicker/period-web.d.ts.map +1 -0
  125. package/lib/typescript/components/YearSelector.d.ts +2 -2
  126. package/lib/typescript/components/YearSelector.d.ts.map +1 -1
  127. package/lib/typescript/enums.d.ts +2 -1
  128. package/lib/typescript/enums.d.ts.map +1 -1
  129. package/lib/typescript/types.d.ts +5 -2
  130. package/lib/typescript/types.d.ts.map +1 -1
  131. package/lib/typescript/utils.d.ts +2 -2
  132. package/lib/typescript/utils.d.ts.map +1 -1
  133. package/package.json +7 -6
  134. package/src/DateTimePicker.tsx +20 -15
  135. package/src/components/Calendar.tsx +8 -8
  136. package/src/components/DatePicker.tsx +38 -66
  137. package/src/components/Day.tsx +9 -9
  138. package/src/components/DaySelector.tsx +6 -6
  139. package/src/components/Header.tsx +5 -5
  140. package/src/components/MonthSelector.tsx +4 -3
  141. package/src/components/TimeSelector.tsx +11 -12
  142. package/src/components/WheelPicker/Wheel.tsx +10 -10
  143. package/src/components/WheelPicker/WheelNative.tsx +13 -47
  144. package/src/components/WheelPicker/WheelNativePicker/index.ts +3 -0
  145. package/src/components/WheelPicker/WheelNativePicker/wheel-picker-item.tsx +140 -0
  146. package/src/components/WheelPicker/WheelNativePicker/wheel-picker.tsx +220 -0
  147. package/src/components/WheelPicker/WheelWeb.tsx +92 -65
  148. package/src/components/WheelPicker/animated-math.ts +33 -0
  149. package/src/components/WheelPicker/period-native.tsx +39 -0
  150. package/src/components/WheelPicker/period-picker.tsx +16 -0
  151. package/src/components/WheelPicker/period-web.tsx +37 -0
  152. package/src/components/YearSelector.tsx +4 -4
  153. package/src/enums.ts +4 -3
  154. package/src/types.ts +6 -2
  155. package/src/utils.ts +3 -3
  156. /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 = WheelNative;
7
- var _reactNative = require("react-native");
8
- var _reactNativeWheely = _interopRequireDefault(require("react-native-wheely"));
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 WheelNative({
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
- indicatorStyle
16
- }) {
17
- const {
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
- containerStyle: {
25
- ...styles.container,
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
- const styles = _reactNative.StyleSheet.create({
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":["_reactNative","require","_reactNativeWheely","_interopRequireDefault","_CalendarContext","obj","__esModule","default","WheelNative","value","setValue","items","indicatorStyle","theme","useCalendarContext","React","createElement","selectedIndex","options","onChange","containerStyle","styles","container","wheelPickerContainerStyle","itemStyle","wheelPickerItemStyle","itemTextStyle","wheelPickerText","wheelPickerTextStyle","selectedIndicatorStyle","wheelSelectedIndicator","wheelPickerIndicatorStyle","itemHeight","decelerationRate","wheelPickerDecelerationRate","StyleSheet","create","display","Platform","select","web","userSelect","borderRadius","fontSize","fontWeight"],"sourceRoot":"../../../../src","sources":["components/WheelPicker/WheelNative.tsx"],"mappings":";;;;;;AAAA,IAAAA,YAAA,GAAAC,OAAA;AACA,IAAAC,kBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,gBAAA,GAAAH,OAAA;AAA2D,SAAAE,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAS5C,SAASG,WAAWA,CAAC;EAClCC,KAAK;EACLC,QAAQ,GAAGA,CAAA,KAAM,CAAC,CAAC;EACnBC,KAAK;EACLC;AACU,CAAC,EAAE;EACb,MAAM;IAAEC;EAAM,CAAC,GAAG,IAAAC,mCAAkB,EAAC,CAAC;EAEtC,oBACEC,KAAA,CAAAC,aAAA,CAACd,kBAAA,CAAAK,OAAW;IACVU,aAAa,EAAER,KAAK,GAAG,CAAC,GAAG,CAAC,GAAGA,KAAM;IACrCS,OAAO,EAAEP,KAAM;IACfQ,QAAQ,EAAET,QAAS;IACnBU,cAAc,EAAE;MACd,GAAGC,MAAM,CAACC,SAAS;MACnB,IAAGT,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEU,yBAAyB;IACrC,CAAE;IACFC,SAAS,EAAEX,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEY,oBAAqB;IACvCC,aAAa,EAAE;MACb,GAAGL,MAAM,CAACM,eAAe;MACzB,IAAGd,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEe,oBAAoB;IAChC,CAAE;IACFC,sBAAsB,EAAE;MACtB,GAAGR,MAAM,CAACS,sBAAsB;MAChC,GAAGlB,cAAc;MACjB,IAAGC,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEkB,yBAAyB;IACrC,CAAE;IACFC,UAAU,EAAE,EAAG;IACfC,gBAAgB,EAAEpB,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEqB;EAA4B,CACtD,CAAC;AAEN;AAEA,MAAMb,MAAM,GAAGc,uBAAU,CAACC,MAAM,CAAC;EAC/Bd,SAAS,EAAE;IACTe,OAAO,EAAE,MAAM;IACf,GAAGC,qBAAQ,CAACC,MAAM,CAAC;MACjBC,GAAG,EAAE;QACHC,UAAU,EAAE;MACd;IACF,CAAC;EACH,CAAC;EACDX,sBAAsB,EAAE;IACtBY,YAAY,EAAE;EAChB,CAAC;EACDf,eAAe,EAAE;IACfgB,QAAQ,EAAE,EAAE;IACZC,UAAU,EAAE;EACd;AACF,CAAC,CAAC"}
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 _CalendarContext = require("../../CalendarContext");
10
- var _AnimatedMath = require("./AnimatedMath");
11
- var _enums = require("../../enums");
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 = 130;
29
+ const height = 140;
26
30
  const radius = height / 2;
27
- const valueIndex = (0, _react.useMemo)(() => items.indexOf(('0' + value).slice(-2)), [items, value]);
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] || '00';
44
- if (newValue === ('0' + value).slice(-2)) {
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(parseInt(newValue, 10));
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 < 0 || targetIndex >= items.length) {
58
- if (!circular) return 0;
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.indexOf(('0' + value).slice(-2));
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__*/React.createElement(_reactNative.View, _extends({
79
- style: [styles.container]
80
- }, panResponder.panHandlers), displayValues === null || displayValues === void 0 ? void 0 : displayValues.map((displayValue, index) => {
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__*/React.createElement(_reactNative.Animated.Text, {
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: 25,
99
+ height: ITEM_HEIGHT - 10,
92
100
  transform: animatedAngle ? [{
93
- translateY: _reactNative.Animated.multiply(radius, (0, _AnimatedMath.sin)(animatedAngle))
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 !== ('0' + value).slice(-2) ? 0.3 : 1
102
- }]
103
- }, displayValue);
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 styles = _reactNative.StyleSheet.create({
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.CALENDAR_HEIGHT / 2,
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
- wheelPickerText: {
125
- fontSize: 20,
126
- fontWeight: '500'
134
+ selectedIndicator: {
135
+ position: 'absolute',
136
+ width: '100%',
137
+ top: '50%'
127
138
  }
128
139
  });
129
- var _default = exports.default = /*#__PURE__*/(0, _react.memo)(WheelWeb, (prevProps, nextProps) => {
130
- return prevProps.value === nextProps.value && prevProps.setValue === nextProps.setValue;
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