@trionesdev/antd-taro-react 0.0.2-beta.12 → 0.0.2-beta.13

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 (68) hide show
  1. package/dist/Calendar/touchable-calendar-grid.js +16 -16
  2. package/dist/CalendarDatetimePicker/CalendarDatetimePicker.d.ts +4 -4
  3. package/dist/CalendarDatetimePicker/CalendarDatetimePicker.js +144 -48
  4. package/dist/CalendarDatetimePicker/style.scss +52 -14
  5. package/dist/CalendarDatetimePicker/types.d.ts +4 -0
  6. package/dist/CalendarDatetimePicker/types.js +6 -1
  7. package/dist/CalendarDatetimePickerCell/CalendarDatetimePickerCell.d.ts +9 -0
  8. package/dist/CalendarDatetimePickerCell/CalendarDatetimePickerCell.js +60 -0
  9. package/dist/CalendarDatetimePickerCell/index.d.ts +3 -0
  10. package/dist/CalendarDatetimePickerCell/index.js +2 -0
  11. package/dist/CalendarPicker/CalendarPicker.d.ts +4 -0
  12. package/dist/{CalendarPopup/CalendarPopup.js → CalendarPicker/CalendarPicker.js} +3 -2
  13. package/dist/CalendarPicker/CalendarRangePicker.d.ts +4 -0
  14. package/dist/{CalendarPopup/CalendarRangePopup.js → CalendarPicker/CalendarRangePicker.js} +3 -2
  15. package/dist/CalendarPicker/index.d.ts +8 -0
  16. package/dist/CalendarPicker/index.js +5 -0
  17. package/dist/{CalendarPopup → CalendarPicker}/style.scss +2 -2
  18. package/dist/{CalendarPopup → CalendarPicker}/types.d.ts +3 -3
  19. package/dist/CalendarPicker/types.js +1 -0
  20. package/dist/CalendarPickerCell/CalendarPickerCell.d.ts +11 -0
  21. package/dist/CalendarPickerCell/CalendarPickerCell.js +54 -0
  22. package/dist/CalendarPickerCell/CalendarRangePickerCell.d.ts +11 -0
  23. package/dist/CalendarPickerCell/CalendarRangePickerCell.js +56 -0
  24. package/dist/CalendarPickerCell/index.d.ts +8 -0
  25. package/dist/CalendarPickerCell/index.js +5 -0
  26. package/dist/{CascaderPopup/cascader-popup.d.ts → CascaderPicker/cascader-picker.d.ts} +2 -2
  27. package/dist/{CascaderPopup/cascader-popup.js → CascaderPicker/cascader-picker.js} +8 -8
  28. package/dist/CascaderPicker/index.d.ts +1 -1
  29. package/dist/CascaderPicker/index.js +1 -1
  30. package/dist/CascaderPicker/style.scss +33 -12
  31. package/dist/{CascaderPicker/CascaderPicker.d.ts → CascaderPickerCell/CascaderPickerCell.d.ts} +4 -9
  32. package/dist/{CascaderPicker/CascaderPicker.js → CascaderPickerCell/CascaderPickerCell.js} +6 -14
  33. package/dist/CascaderPickerCell/index.d.ts +3 -0
  34. package/dist/CascaderPickerCell/index.js +2 -0
  35. package/dist/DatePicker/DatePicker.d.ts +8 -6
  36. package/dist/DatePicker/DatePicker.js +293 -50
  37. package/dist/DatePicker/index.d.ts +2 -1
  38. package/dist/DatePicker/style.scss +1 -24
  39. package/dist/DatePickerCell/DatePickerCell.d.ts +14 -0
  40. package/dist/DatePickerCell/DatePickerCell.js +79 -0
  41. package/dist/DatePickerCell/index.d.ts +3 -0
  42. package/dist/DatePickerCell/index.js +2 -0
  43. package/dist/Input/taro-input.js +5 -2
  44. package/dist/Input/types.d.ts +1 -0
  45. package/dist/index.d.ts +11 -6
  46. package/dist/index.js +5 -3
  47. package/dist/utils/dayjs.d.ts +2 -1
  48. package/dist/utils/dayjs.js +13 -0
  49. package/package.json +4 -4
  50. package/dist/CalendarDatetimePopup/CalendarDatetimePopup.d.ts +0 -11
  51. package/dist/CalendarDatetimePopup/CalendarDatetimePopup.js +0 -164
  52. package/dist/CalendarDatetimePopup/index.d.ts +0 -3
  53. package/dist/CalendarDatetimePopup/index.js +0 -2
  54. package/dist/CalendarDatetimePopup/style.scss +0 -62
  55. package/dist/CalendarDatetimePopup/types.d.ts +0 -5
  56. package/dist/CalendarDatetimePopup/types.js +0 -6
  57. package/dist/CalendarPopup/CalendarPopup.d.ts +0 -4
  58. package/dist/CalendarPopup/CalendarRangePopup.d.ts +0 -4
  59. package/dist/CalendarPopup/index.d.ts +0 -8
  60. package/dist/CalendarPopup/index.js +0 -5
  61. package/dist/CalendarPopup/types.js +0 -1
  62. package/dist/CascaderPopup/index.d.ts +0 -3
  63. package/dist/CascaderPopup/index.js +0 -2
  64. package/dist/CascaderPopup/style.scss +0 -45
  65. package/dist/DatePicker/DatePickerPopup.d.ts +0 -18
  66. package/dist/DatePicker/DatePickerPopup.js +0 -329
  67. /package/dist/{CalendarDatetimePopup → CalendarDatetimePicker}/DateTimeSwitch.d.ts +0 -0
  68. /package/dist/{CalendarDatetimePopup → CalendarDatetimePicker}/DateTimeSwitch.js +0 -0
@@ -1,4 +1,6 @@
1
1
  function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
2
4
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
3
5
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
4
6
  function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
@@ -8,78 +10,319 @@ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o =
8
10
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
9
11
  function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
10
12
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
11
- import React, { useEffect, useMemo, useState } from "react";
13
+ import { useEffect, useMemo, useState } from "react";
14
+ import Popup from "../Popup";
15
+ import PickerView from "../PickerView";
16
+ import React from "react";
12
17
  import classNames from "classnames";
13
- import { cls } from "../CalendarDatetimePicker/types";
18
+ import ConfigProvider from "../ConfigProvider";
19
+ import { isEqual } from "lodash-es";
14
20
  import dayjs from "dayjs";
15
- import DatePickerPopup from "./DatePickerPopup";
21
+ var cls = 'triones-antm-date-picker';
16
22
  export var DatePicker = function DatePicker(_ref) {
17
- var placeholder = _ref.placeholder,
18
- value = _ref.value,
19
- format = _ref.format,
20
- onChange = _ref.onChange,
21
- _ref$align = _ref.align,
22
- align = _ref$align === void 0 ? 'left' : _ref$align,
23
+ var open = _ref.open,
24
+ onClose = _ref.onClose,
25
+ title = _ref.title,
23
26
  _ref$mode = _ref.mode,
24
27
  mode = _ref$mode === void 0 ? 'date' : _ref$mode,
25
- _ref$showTime = _ref.showTime,
26
- showTime = _ref$showTime === void 0 ? false : _ref$showTime,
28
+ format = _ref.format,
29
+ showTime = _ref.showTime,
30
+ value = _ref.value,
31
+ onOk = _ref.onOk,
27
32
  minDate = _ref.minDate,
28
33
  maxDate = _ref.maxDate;
29
- var _React$useState = React.useState(false),
30
- _React$useState2 = _slicedToArray(_React$useState, 2),
31
- innerOpen = _React$useState2[0],
32
- setInnerOpen = _React$useState2[1];
33
- var _useState = useState(value),
34
+ var cleanFormat = format === null || format === void 0 ? void 0 : format.replace(/\[([^\]]+)\]/g, '');
35
+ var hasYear = cleanFormat === null || cleanFormat === void 0 ? void 0 : cleanFormat.includes('Y');
36
+ var hasMouth = cleanFormat === null || cleanFormat === void 0 ? void 0 : cleanFormat.includes('M');
37
+ var hasDate = cleanFormat === null || cleanFormat === void 0 ? void 0 : cleanFormat.includes('D');
38
+ var hasHour = cleanFormat === null || cleanFormat === void 0 ? void 0 : cleanFormat.includes('H');
39
+ var hasMinute = cleanFormat === null || cleanFormat === void 0 ? void 0 : cleanFormat.includes('m');
40
+ var hasSecond = cleanFormat === null || cleanFormat === void 0 ? void 0 : cleanFormat.includes('s');
41
+ var _ConfigProvider$useCo = ConfigProvider.useConfig(),
42
+ locale = _ConfigProvider$useCo.locale;
43
+ var _useState = useState({
44
+ year: (value === null || value === void 0 ? void 0 : value.year()) || dayjs().year(),
45
+ mouth: ((value === null || value === void 0 ? void 0 : value.month()) || dayjs().month()) + 1,
46
+ date: (value === null || value === void 0 ? void 0 : value.date()) || dayjs().date(),
47
+ hour: (value === null || value === void 0 ? void 0 : value.hour()) || dayjs().hour(),
48
+ minute: (value === null || value === void 0 ? void 0 : value.minute()) || dayjs().minute(),
49
+ second: (value === null || value === void 0 ? void 0 : value.second()) || dayjs().second()
50
+ }),
34
51
  _useState2 = _slicedToArray(_useState, 2),
35
52
  internalValue = _useState2[0],
36
53
  setInternalValue = _useState2[1];
37
- var renderFormat = useMemo(function () {
38
- if (format) {
39
- return format;
54
+ var years = useMemo(function () {
55
+ if (minDate && maxDate) {
56
+ return Array.from({
57
+ length: maxDate.year() - minDate.year() + 1
58
+ }, function (_, i) {
59
+ return minDate.year() + i;
60
+ });
61
+ }
62
+ if (minDate) {
63
+ return Array.from({
64
+ length: dayjs().year() - minDate.year() + 1
65
+ }, function (_, i) {
66
+ return minDate.year() + i;
67
+ });
68
+ }
69
+ if (maxDate) {
70
+ return Array.from({
71
+ length: maxDate.year() - dayjs().year() + 1
72
+ }, function (_, i) {
73
+ return dayjs().year() + i;
74
+ });
75
+ }
76
+ var startYear = dayjs().year() + 30 - 100;
77
+ return Array.from({
78
+ length: 100
79
+ }, function (_, i) {
80
+ return startYear + i;
81
+ });
82
+ }, [internalValue.year, minDate, maxDate]);
83
+ var mouths = useMemo(function () {
84
+ var start = 0;
85
+ var end = 11;
86
+ if (minDate && minDate.year() === internalValue.year) {
87
+ start = minDate.month();
88
+ }
89
+ if (maxDate && maxDate.year() === internalValue.year) {
90
+ end = maxDate.month();
40
91
  }
92
+ return Array.from({
93
+ length: end - start + 1
94
+ }, function (_, i) {
95
+ return start + i + 1;
96
+ });
97
+ }, [internalValue.year, minDate, maxDate]);
98
+ var days = useMemo(function () {
99
+ var start = 1;
100
+ var end = dayjs().year(internalValue.year || dayjs().year()).month((internalValue.mouth || 1) - 1).daysInMonth();
101
+ if (minDate && minDate.year() === internalValue.year && minDate.month() + 1 === internalValue.mouth) {
102
+ start = minDate.date();
103
+ }
104
+ if (maxDate && maxDate.year() === internalValue.year && maxDate.month() + 1 === internalValue.mouth) {
105
+ end = maxDate.date();
106
+ }
107
+ return Array.from({
108
+ length: end - start + 1
109
+ }, function (_, i) {
110
+ return start + i;
111
+ });
112
+ }, [internalValue.year, internalValue.mouth, minDate, maxDate]);
113
+ var hours = Array.from({
114
+ length: 24
115
+ }, function (_, i) {
116
+ return i;
117
+ });
118
+ var minutes = Array.from({
119
+ length: 60
120
+ }, function (_, i) {
121
+ return i;
122
+ });
123
+ var seconds = Array.from({
124
+ length: 60
125
+ }, function (_, i) {
126
+ return i;
127
+ });
128
+ var columns = useMemo(function () {
129
+ if (mode === 'date') {
130
+ var dateColumns = [];
131
+ if (!format) {
132
+ dateColumns.push(years.map(function (v) {
133
+ return {
134
+ label: "".concat(v, "\u5E74"),
135
+ value: v
136
+ };
137
+ }), mouths.map(function (v) {
138
+ return {
139
+ label: "".concat(v, "\u6708"),
140
+ value: v
141
+ };
142
+ }), days.map(function (v) {
143
+ return {
144
+ label: "".concat(v, "\u65E5"),
145
+ value: v
146
+ };
147
+ }));
148
+ } else {
149
+ if (hasYear) {
150
+ dateColumns.push(years.map(function (v) {
151
+ return {
152
+ label: "".concat(v, "\u5E74"),
153
+ value: v
154
+ };
155
+ }));
156
+ }
157
+ if (hasMouth) {
158
+ dateColumns.push(mouths.map(function (v) {
159
+ return {
160
+ label: "".concat(v, "\u6708"),
161
+ value: v
162
+ };
163
+ }));
164
+ }
165
+ if (hasDate) {
166
+ dateColumns.push(days.map(function (v) {
167
+ return {
168
+ label: "".concat(v, "\u65E5"),
169
+ value: v
170
+ };
171
+ }));
172
+ }
173
+ }
174
+ if (showTime) {
175
+ if (hasHour) {
176
+ dateColumns.push(hours.map(function (v) {
177
+ return {
178
+ label: "".concat(v, "\u65F6"),
179
+ value: v
180
+ };
181
+ }));
182
+ }
183
+ if (hasMinute) {
184
+ dateColumns.push(minutes.map(function (v) {
185
+ return {
186
+ label: "".concat(v, "\u5206"),
187
+ value: v
188
+ };
189
+ }));
190
+ }
191
+ if (hasSecond) {
192
+ dateColumns.push(seconds.map(function (v) {
193
+ return {
194
+ label: "".concat(v, "\u79D2"),
195
+ value: v
196
+ };
197
+ }));
198
+ }
199
+ }
200
+ return dateColumns;
201
+ } else if (mode === 'time') {
202
+ var timeColumns = [];
203
+ if (!format) {
204
+ timeColumns.push(hours.map(function (v) {
205
+ return {
206
+ label: "".concat(v, "\u65F6"),
207
+ value: v
208
+ };
209
+ }), minutes.map(function (v) {
210
+ return {
211
+ label: "".concat(v, "\u5206"),
212
+ value: v
213
+ };
214
+ }), seconds.map(function (v) {
215
+ return {
216
+ label: "".concat(v, "\u79D2"),
217
+ value: v
218
+ };
219
+ }));
220
+ } else {
221
+ if (hasHour) {
222
+ timeColumns.push(hours.map(function (v) {
223
+ return {
224
+ label: "".concat(v, "\u65F6"),
225
+ value: v
226
+ };
227
+ }));
228
+ }
229
+ if (hasMinute) {
230
+ timeColumns.push(minutes.map(function (v) {
231
+ return {
232
+ label: "".concat(v, "\u5206"),
233
+ value: v
234
+ };
235
+ }));
236
+ }
237
+ if (hasSecond) {
238
+ timeColumns.push(seconds.map(function (v) {
239
+ return {
240
+ label: "".concat(v, "\u79D2"),
241
+ value: v
242
+ };
243
+ }));
244
+ }
245
+ }
246
+ return timeColumns;
247
+ }
248
+ return [];
249
+ }, [mode, showTime, years, days]);
250
+ var handleOk = function handleOk() {
251
+ var now = dayjs();
252
+ onOk === null || onOk === void 0 || onOk(dayjs(new Date(internalValue.year || now.year(), (internalValue.mouth || now.month()) - 1, internalValue.date || now.date(), internalValue.hour || now.hour(), internalValue.minute || now.minute())));
253
+ onClose === null || onClose === void 0 || onClose();
254
+ };
255
+ var handelCancel = function handelCancel() {
256
+ onClose === null || onClose === void 0 || onClose();
257
+ };
258
+ var handleValueChange = function handleValueChange(value) {
259
+ var changedValue = _objectSpread({}, internalValue);
41
260
  if (mode === 'date') {
42
- return showTime ? 'YYYY-MM-DD HH:mm:ss' : 'YYYY-MM-DD';
261
+ changedValue.year = value[0];
262
+ changedValue.mouth = value[1];
263
+ changedValue.date = value[2];
264
+ if (showTime) {
265
+ changedValue.hour = value[3];
266
+ changedValue.minute = value[4];
267
+ }
43
268
  } else if (mode === 'time') {
44
- return 'HH:mm:ss';
269
+ changedValue.hour = value[0];
270
+ changedValue.minute = value[1];
45
271
  }
46
- return 'YYYY-MM-DD';
47
- }, [mode, format, showTime]);
48
- var handleValueRender = function handleValueRender() {
49
- if (internalValue) {
50
- return dayjs(internalValue).format(renderFormat);
272
+ if (!isEqual(internalValue, changedValue)) {
273
+ setInternalValue(changedValue);
51
274
  }
52
- return null;
53
275
  };
54
276
  useEffect(function () {
55
277
  if (value === undefined) {
56
278
  return;
57
279
  }
58
- if (value !== internalValue) {
59
- setInternalValue(value);
280
+ if (value.year() !== internalValue.year || value.month() + 1 !== internalValue.mouth || value.date() !== internalValue.date || value.hour() !== internalValue.hour || value.minute() !== internalValue.minute || value.second() !== internalValue.second) {
281
+ setInternalValue({
282
+ year: value.year(),
283
+ mouth: value.month() + 1,
284
+ date: value.date(),
285
+ hour: value.hour(),
286
+ minute: value.minute(),
287
+ second: value.second()
288
+ });
60
289
  }
61
290
  }, [value]);
62
- return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(DatePickerPopup, {
63
- open: innerOpen,
64
- onClose: function onClose() {
65
- setInnerOpen(false);
66
- },
67
- mode: mode,
68
- format: format,
69
- showTime: showTime,
70
- minDate: minDate,
71
- maxDate: maxDate,
72
- value: internalValue,
73
- onOk: function onOk(value) {
74
- setInternalValue(value);
75
- onChange === null || onChange === void 0 || onChange(value);
291
+ var pickerValue = useMemo(function () {
292
+ if (mode === 'time') {
293
+ return [internalValue.hour, internalValue.minute, internalValue.second];
294
+ } else if (mode === 'date') {
295
+ if (showTime) {
296
+ return [internalValue.year, internalValue.mouth, internalValue.date, internalValue.hour, internalValue.minute, internalValue.second];
297
+ } else {
298
+ return [internalValue.year, internalValue.mouth, internalValue.date];
299
+ }
76
300
  }
77
- }), /*#__PURE__*/React.createElement("div", {
78
- className: classNames(cls, _defineProperty({}, "".concat(cls, "-").concat(align), true)),
79
- onClick: function onClick() {
80
- setInnerOpen(true);
301
+ }, [internalValue]);
302
+ return /*#__PURE__*/React.createElement(Popup, {
303
+ open: open,
304
+ onClose: onClose,
305
+ round: true
306
+ }, /*#__PURE__*/React.createElement("div", {
307
+ className: classNames("".concat(cls))
308
+ }, /*#__PURE__*/React.createElement("div", {
309
+ className: classNames("".concat(cls, "-header"))
310
+ }, /*#__PURE__*/React.createElement("a", {
311
+ className: classNames("".concat(cls, "-header-button"), "".concat(cls, "-header-button-cancel")),
312
+ onClick: handelCancel
313
+ }, locale.common.cancel), title && /*#__PURE__*/React.createElement("div", {
314
+ className: classNames("".concat(cls, "-header-title"))
315
+ }, title), /*#__PURE__*/React.createElement("a", {
316
+ className: classNames("".concat(cls, "-header-button"), "".concat(cls, "-header-button-ok")),
317
+ onClick: handleOk
318
+ }, locale.common.confirm)), /*#__PURE__*/React.createElement("div", {
319
+ className: classNames("".concat(cls, "-body"))
320
+ }, /*#__PURE__*/React.createElement(PickerView, {
321
+ columns: columns,
322
+ value: pickerValue,
323
+ onChange: function onChange(v) {
324
+ console.log(v);
325
+ handleValueChange(v);
81
326
  }
82
- }, !internalValue ? /*#__PURE__*/React.createElement("div", {
83
- className: "".concat(cls, "-placeholder")
84
- }, placeholder) : /*#__PURE__*/React.createElement("div", null, handleValueRender())));
327
+ }))));
85
328
  };
@@ -1,3 +1,4 @@
1
- import { DatePicker } from "./DatePicker";
1
+ import { DatePicker, DatePickerPops } from "./DatePicker";
2
2
  import "./style.scss";
3
+ export type { DatePickerPops };
3
4
  export default DatePicker;
@@ -1,31 +1,8 @@
1
1
  @use "../style/variable" as variable;
2
+
2
3
  $datePickerCls: 'triones-antm-date-picker';
3
4
 
4
5
  .#{$datePickerCls} {
5
- width: 100%;
6
- line-height: 1.4;
7
- display: flex;
8
-
9
- &-left {
10
- justify-content: flex-start;
11
- }
12
-
13
- &-center {
14
- justify-content: center;
15
- }
16
-
17
- &-right {
18
- justify-content: flex-end;
19
- }
20
-
21
- &-placeholder {
22
- color: variable.$trionesColorTextPlaceholder;
23
- }
24
- }
25
-
26
- $datePickerPopupCls: 'triones-antm-date-picker-popup';
27
-
28
- .#{$datePickerPopupCls} {
29
6
  border-top-left-radius: variable.$trionesBorderRadius;
30
7
  border-top-right-radius: variable.$trionesBorderRadius;
31
8
 
@@ -0,0 +1,14 @@
1
+ import { FC } from "react";
2
+ import dayjs from "dayjs";
3
+ import { Mode } from "../DatePicker/types";
4
+ import { CellProps } from "../Cell";
5
+ export type DatePickerCellPops = Omit<CellProps, 'value'> & {
6
+ value?: dayjs.Dayjs;
7
+ format?: string;
8
+ onChange?: (value?: dayjs.Dayjs) => void;
9
+ mode?: Mode;
10
+ showTime?: boolean;
11
+ minDate?: dayjs.Dayjs;
12
+ maxDate?: dayjs.Dayjs;
13
+ };
14
+ export declare const DatePickerCell: FC<DatePickerCellPops>;
@@ -0,0 +1,79 @@
1
+ var _excluded = ["value", "format", "onChange", "mode", "showTime", "minDate", "maxDate"];
2
+ 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); }
3
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
4
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
5
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
6
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
7
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
8
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
9
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
10
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
11
+ import React, { useEffect, useMemo, useState } from "react";
12
+ import dayjs from "dayjs";
13
+ import DatePicker from "../DatePicker";
14
+ import Cell from "../Cell";
15
+ export var DatePickerCell = function DatePickerCell(_ref) {
16
+ var value = _ref.value,
17
+ format = _ref.format,
18
+ onChange = _ref.onChange,
19
+ _ref$mode = _ref.mode,
20
+ mode = _ref$mode === void 0 ? 'date' : _ref$mode,
21
+ _ref$showTime = _ref.showTime,
22
+ showTime = _ref$showTime === void 0 ? false : _ref$showTime,
23
+ minDate = _ref.minDate,
24
+ maxDate = _ref.maxDate,
25
+ rest = _objectWithoutProperties(_ref, _excluded);
26
+ var _React$useState = React.useState(false),
27
+ _React$useState2 = _slicedToArray(_React$useState, 2),
28
+ innerOpen = _React$useState2[0],
29
+ setInnerOpen = _React$useState2[1];
30
+ var _useState = useState(value),
31
+ _useState2 = _slicedToArray(_useState, 2),
32
+ internalValue = _useState2[0],
33
+ setInternalValue = _useState2[1];
34
+ var renderFormat = useMemo(function () {
35
+ if (format) {
36
+ return format;
37
+ }
38
+ if (mode === 'date') {
39
+ return showTime ? 'YYYY-MM-DD HH:mm:ss' : 'YYYY-MM-DD';
40
+ } else if (mode === 'time') {
41
+ return 'HH:mm:ss';
42
+ }
43
+ return 'YYYY-MM-DD';
44
+ }, [mode, format, showTime]);
45
+ var handleValueRender = function handleValueRender() {
46
+ if (internalValue) {
47
+ return dayjs(internalValue).format(renderFormat);
48
+ }
49
+ return null;
50
+ };
51
+ useEffect(function () {
52
+ if (value === undefined) {
53
+ return;
54
+ }
55
+ if (value !== internalValue) {
56
+ setInternalValue(value);
57
+ }
58
+ }, [value]);
59
+ return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(DatePicker, {
60
+ open: innerOpen,
61
+ onClose: function onClose() {
62
+ setInnerOpen(false);
63
+ },
64
+ mode: mode,
65
+ format: format,
66
+ showTime: showTime,
67
+ minDate: minDate,
68
+ maxDate: maxDate,
69
+ value: internalValue,
70
+ onOk: function onOk(value) {
71
+ setInternalValue(value);
72
+ onChange === null || onChange === void 0 || onChange(value);
73
+ }
74
+ }), /*#__PURE__*/React.createElement(Cell, _extends({
75
+ onClick: function onClick() {
76
+ setInnerOpen(true);
77
+ }
78
+ }, rest), handleValueRender()));
79
+ };
@@ -0,0 +1,3 @@
1
+ import { DatePickerCell, DatePickerCellPops } from "./DatePickerCell";
2
+ export type { DatePickerCellPops };
3
+ export default DatePickerCell;
@@ -0,0 +1,2 @@
1
+ import { DatePickerCell } from "./DatePickerCell";
2
+ export default DatePickerCell;
@@ -1,4 +1,4 @@
1
- var _excluded = ["value", "onChange", "type", "size"];
1
+ var _excluded = ["value", "onChange", "type", "size", "align"];
2
2
  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); }
3
3
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
4
4
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
@@ -17,6 +17,8 @@ export var TaroInput = function TaroInput(_ref) {
17
17
  type = _ref.type,
18
18
  _ref$size = _ref.size,
19
19
  size = _ref$size === void 0 ? 'middle' : _ref$size,
20
+ _ref$align = _ref.align,
21
+ align = _ref$align === void 0 ? 'left' : _ref$align,
20
22
  rest = _objectWithoutProperties(_ref, _excluded);
21
23
  var _React$useState = React.useState(value),
22
24
  _React$useState2 = _slicedToArray(_React$useState, 2),
@@ -39,7 +41,8 @@ export var TaroInput = function TaroInput(_ref) {
39
41
  }
40
42
  }), /*#__PURE__*/React.createElement(InternalTaroInput, {
41
43
  style: {
42
- flex: 1
44
+ flex: 1,
45
+ textAlign: align
43
46
  },
44
47
  type: type,
45
48
  defaultValue: rest.defaultValue,
@@ -8,6 +8,7 @@ export type InputProps = {
8
8
  placeholder?: string;
9
9
  size?: SizeType;
10
10
  disabled?: boolean;
11
+ align?: 'left' | 'center' | 'right';
11
12
  allowClear?: boolean;
12
13
  prefix?: React.ReactNode;
13
14
  suffix?: React.ReactNode;
package/dist/index.d.ts CHANGED
@@ -12,16 +12,18 @@ export { default as Calendar, CalendarGrid, TouchableCalendarGrid, } from './Cal
12
12
  export type { CalendarGridProps, CalendarProps } from './Calendar';
13
13
  export { default as CalendarDatetimePicker } from './CalendarDatetimePicker';
14
14
  export type { CalendarDatetimePickerProps } from './CalendarDatetimePicker';
15
- export { default as CalendarDatetimePopup } from './CalendarDatetimePopup';
16
- export type { CalendarDatetimePopupProps } from './CalendarDatetimePopup';
17
- export { default as CalendarPopup } from './CalendarPopup';
18
- export type { CalendarPopupProps, CalendarPopupRangeProps } from './CalendarPopup';
15
+ export { default as CalendarDatetimePickerCell } from './CalendarDatetimePickerCell';
16
+ export type { CalendarDatetimePickerCellProps } from './CalendarDatetimePickerCell';
17
+ export { default as CalendarPicker } from './CalendarPicker';
18
+ export type { CalendarPickerProps, CalendarPickerRangeProps } from './CalendarPicker';
19
+ export { default as CalendarPickerCell } from './CalendarPickerCell';
20
+ export type { CalendarPickerCellProps, CalendarRangePickerCellProps } from './CalendarPickerCell';
19
21
  export { default as Card } from './Card';
20
22
  export type { CardProps } from './Card';
23
+ export { default as CascaderPickerCell } from './CascaderPickerCell';
24
+ export type { CascaderPickerCellProps } from './CascaderPickerCell';
21
25
  export { default as CascaderPicker } from './CascaderPicker';
22
26
  export type { CascaderPickerProps } from './CascaderPicker';
23
- export { default as CascaderPopup } from './CascaderPopup';
24
- export type { CascaderPopupProps } from './CascaderPopup';
25
27
  export { default as CascaderView } from './CascaderView';
26
28
  export type { CascaderViewProps } from './CascaderView';
27
29
  export { default as Cell } from './Cell';
@@ -31,6 +33,9 @@ export type { CheckboxProps } from './Checkbox';
31
33
  export { default as ConfigProvider } from './ConfigProvider';
32
34
  export type { ConfigProviderProps } from './ConfigProvider';
33
35
  export { default as DatePicker } from './DatePicker';
36
+ export type { DatePickerPops } from './DatePicker';
37
+ export { default as DatePickerCell } from './DatePickerCell';
38
+ export type { DatePickerCellPops } from './DatePickerCell';
34
39
  export { default as Descriptions } from "./Descriptions";
35
40
  export type { DescriptionsProps } from "./Descriptions";
36
41
  export { default as Divider } from './Divider';
package/dist/index.js CHANGED
@@ -5,16 +5,18 @@ export { default as Badge } from "./Badge";
5
5
  export { default as Button } from "./Button";
6
6
  export { default as Calendar, CalendarGrid, TouchableCalendarGrid } from "./Calendar";
7
7
  export { default as CalendarDatetimePicker } from "./CalendarDatetimePicker";
8
- export { default as CalendarDatetimePopup } from "./CalendarDatetimePopup";
9
- export { default as CalendarPopup } from "./CalendarPopup";
8
+ export { default as CalendarDatetimePickerCell } from "./CalendarDatetimePickerCell";
9
+ export { default as CalendarPicker } from "./CalendarPicker";
10
+ export { default as CalendarPickerCell } from "./CalendarPickerCell";
10
11
  export { default as Card } from "./Card";
12
+ export { default as CascaderPickerCell } from "./CascaderPickerCell";
11
13
  export { default as CascaderPicker } from "./CascaderPicker";
12
- export { default as CascaderPopup } from "./CascaderPopup";
13
14
  export { default as CascaderView } from "./CascaderView";
14
15
  export { default as Cell } from "./Cell";
15
16
  export { default as Checkbox } from "./Checkbox";
16
17
  export { default as ConfigProvider } from "./ConfigProvider";
17
18
  export { default as DatePicker } from "./DatePicker";
19
+ export { default as DatePickerCell } from "./DatePickerCell";
18
20
  export { default as Descriptions } from "./Descriptions";
19
21
  export { default as Divider } from "./Divider";
20
22
  export { default as Ellipsis } from "./Ellipsis";
@@ -1,3 +1,4 @@
1
1
  import dayjs, { OpUnitType } from "dayjs";
2
- export declare const toDayjsArray: (dateArr?: Date[] | dayjs.Dayjs[]) => dayjs.Dayjs[] | undefined;
2
+ export declare const toDayjsArray: (dateArr?: (dayjs.Dayjs | Date)[]) => dayjs.Dayjs[] | undefined;
3
3
  export declare const isSame: (x?: dayjs.Dayjs | Date, y?: dayjs.Dayjs | Date, unit?: OpUnitType) => boolean;
4
+ export declare const isSameArray: (x?: (dayjs.Dayjs | Date)[], y?: (dayjs.Dayjs | Date)[], unit?: OpUnitType) => boolean;
@@ -26,4 +26,17 @@ export var isSame = function isSame(x, y, unit) {
26
26
  var _dayjs;
27
27
  return Boolean((_dayjs = dayjs(x)) === null || _dayjs === void 0 ? void 0 : _dayjs.isSame(y, unit));
28
28
  }
29
+ };
30
+ export var isSameArray = function isSameArray(x, y, unit) {
31
+ var xa = x !== null && x !== void 0 ? x : [];
32
+ var ya = y !== null && y !== void 0 ? y : [];
33
+ if (xa.length === 0 && ya.length === 0) {
34
+ return true;
35
+ }
36
+ if (xa.length !== ya.length) {
37
+ return false;
38
+ }
39
+ return xa.every(function (date, index) {
40
+ return isSame(date, ya[index], unit);
41
+ });
29
42
  };