@zgfe/business-lib 1.2.52 → 1.2.54-plat.0

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.
@@ -1398,9 +1398,9 @@
1398
1398
  <pre><code class="language-css"
1399
1399
  >@font-face {
1400
1400
  font-family: 'bsicon';
1401
- src: url('iconfont.woff2?t=1724138087342') format('woff2'),
1402
- url('iconfont.woff?t=1724138087342') format('woff'),
1403
- url('iconfont.ttf?t=1724138087342') format('truetype');
1401
+ src: url('iconfont.woff2?t=1724237872032') format('woff2'),
1402
+ url('iconfont.woff?t=1724237872032') format('woff'),
1403
+ url('iconfont.ttf?t=1724237872032') format('truetype');
1404
1404
  }
1405
1405
  </code></pre>
1406
1406
  <h3 id="-iconfont-">第二步:定义使用 iconfont 的样式</h3>
@@ -1,8 +1,8 @@
1
1
  @font-face {
2
2
  font-family: "bsicon"; /* Project id 2545884 */
3
- src: url('iconfont.woff2?t=1724138087342') format('woff2'),
4
- url('iconfont.woff?t=1724138087342') format('woff'),
5
- url('iconfont.ttf?t=1724138087342') format('truetype');
3
+ src: url('iconfont.woff2?t=1724237872032') format('woff2'),
4
+ url('iconfont.woff?t=1724237872032') format('woff'),
5
+ url('iconfont.ttf?t=1724237872032') format('truetype');
6
6
  }
7
7
 
8
8
  .bsicon {
Binary file
Binary file
Binary file
@@ -41,6 +41,8 @@ export default (function () {
41
41
  key: "".concat(includeToday, "--2"),
42
42
  onChange: handleChange,
43
43
  includeToday: includeToday,
44
- defaultValue: time
44
+ defaultValue: time,
45
+ selectRange: 365,
46
+ selectRangeUnit: "days"
45
47
  }), /*#__PURE__*/React.createElement("p", null, "\u5F53\u524D\u503C\uFF1A", JSON.stringify(time))));
46
48
  });
@@ -0,0 +1,13 @@
1
+ import { Dispatch, SetStateAction } from 'react';
2
+ import { DatePickerTypes } from './types';
3
+ export interface DatePickerContextProps {
4
+ dateRange?: DatePickerTypes.Range;
5
+ setDateRange?: (range: DatePickerTypes.Range) => void;
6
+ includeToday?: boolean;
7
+ currentType?: DatePickerTypes.Unit;
8
+ relative?: [number, number];
9
+ setRelative?: (relative?: [number, number]) => void;
10
+ setOpen?: Dispatch<SetStateAction<boolean>>;
11
+ }
12
+ declare const DatePickerContext: import("react").Context<DatePickerContextProps>;
13
+ export default DatePickerContext;
@@ -0,0 +1,3 @@
1
+ import { createContext } from 'react';
2
+ var DatePickerContext = /*#__PURE__*/createContext({});
3
+ export default DatePickerContext;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ declare const BizDate: React.ForwardRefExoticComponent<{
3
+ selectRange?: number | undefined;
4
+ timeRangeOpen?: number | undefined;
5
+ selectRangeUnit?: "quarter" | "months" | "weeks" | "days" | undefined;
6
+ } & React.RefAttributes<any>>;
7
+ export default BizDate;
@@ -0,0 +1,149 @@
1
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
+ 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."); }
3
+ 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); }
4
+ 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; }
5
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
6
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
+ import { DatePicker, message } from 'antd';
8
+ import moment from 'moment';
9
+ import React, { useContext, useState, useEffect, useImperativeHandle } from 'react';
10
+ import { classPrefix } from '.';
11
+ import IconFont from '../icon/iconFont';
12
+ import { DatePickerTypes } from './types';
13
+ import locale from 'antd/es/date-picker/locale/zh_CN';
14
+ import DatePickerContext from './context';
15
+ import BizGlobalDataContext from '../context';
16
+ import { isTodayInRange } from './utils';
17
+ import _ from 'lodash';
18
+ var RangePicker = DatePicker.RangePicker;
19
+ var BizDateBeyondRange = false;
20
+ var BizDate = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
21
+ var selectRange = _ref.selectRange,
22
+ selectRangeUnit = _ref.selectRangeUnit,
23
+ timeRangeOpen = _ref.timeRangeOpen;
24
+ var _useContext = useContext(DatePickerContext),
25
+ includeToday = _useContext.includeToday,
26
+ currentType = _useContext.currentType,
27
+ dateRange = _useContext.dateRange,
28
+ setRelative = _useContext.setRelative;
29
+ var _useContext2 = useContext(BizGlobalDataContext),
30
+ envs = _useContext2.envs;
31
+ function disabledDate(current) {
32
+ var step = includeToday ? 0 : 1;
33
+ var max = moment().subtract(step, 'days');
34
+ var _timeRangeOpen = timeRangeOpen || 12;
35
+ if (envs === null || envs === void 0 ? void 0 : envs.timeRangeOpen) {
36
+ _timeRangeOpen = typeof (envs === null || envs === void 0 ? void 0 : envs.timeRangeOpen) === 'boolean' ? (envs === null || envs === void 0 ? void 0 : envs.timeRangeOpen) ? 200 : 12 : envs === null || envs === void 0 ? void 0 : envs.timeRangeOpen;
37
+ }
38
+ var min = moment(max).subtract(_timeRangeOpen, 'month');
39
+ return current > max || current < min;
40
+ }
41
+ var _useState = useState(currentType === DatePickerTypes.Unit.hour ? moment(dateRange === null || dateRange === void 0 ? void 0 : dateRange.begin, 'YYYY-MM-DD') : [moment(dateRange === null || dateRange === void 0 ? void 0 : dateRange.begin, 'YYYY-MM-DD'), moment(dateRange === null || dateRange === void 0 ? void 0 : dateRange.end, 'YYYY-MM-DD')]),
42
+ _useState2 = _slicedToArray(_useState, 2),
43
+ value = _useState2[0],
44
+ setValue = _useState2[1];
45
+ var _useState3 = useState('个月'),
46
+ _useState4 = _slicedToArray(_useState3, 2),
47
+ selectRangeUnitText = _useState4[0],
48
+ setSelectRangeUnitText = _useState4[1];
49
+ useEffect(function () {
50
+ if (selectRangeUnit) {
51
+ switch (selectRangeUnit) {
52
+ case 'days':
53
+ setSelectRangeUnitText('天');
54
+ break;
55
+ case 'weeks':
56
+ setSelectRangeUnitText('周');
57
+ break;
58
+ case 'months':
59
+ setSelectRangeUnitText('个月');
60
+ break;
61
+ case 'quarter':
62
+ setSelectRangeUnitText('个季度');
63
+ break;
64
+ }
65
+ }
66
+ }, [selectRangeUnit]);
67
+ useImperativeHandle(ref, function () {
68
+ return {
69
+ getDateValue: function getDateValue() {
70
+ var _value$, _value$2;
71
+ if (setRelative) setRelative(undefined);
72
+ if (BizDateBeyondRange) {
73
+ message.error("\u65F6\u95F4\u6BB5\u6700\u5927\u652F\u6301".concat(selectRange ? selectRange : 12).concat(selectRangeUnitText));
74
+ BizDateBeyondRange = false;
75
+ return false;
76
+ }
77
+ return Array.isArray(value) ? {
78
+ begin: (_value$ = value[0]) === null || _value$ === void 0 ? void 0 : _value$.format('YYYY-MM-DD'),
79
+ end: (_value$2 = value[1]) === null || _value$2 === void 0 ? void 0 : _value$2.format('YYYY-MM-DD')
80
+ } : {
81
+ begin: value === null || value === void 0 ? void 0 : value.format('YYYY-MM-DD'),
82
+ end: value === null || value === void 0 ? void 0 : value.format('YYYY-MM-DD')
83
+ };
84
+ }
85
+ };
86
+ });
87
+ if (!dateRange) {
88
+ return /*#__PURE__*/React.createElement(DatePicker, {
89
+ disabled: true
90
+ });
91
+ }
92
+ return /*#__PURE__*/React.createElement("div", {
93
+ className: "".concat(classPrefix, "-panel")
94
+ }, currentType === DatePickerTypes.Unit.hour ? /*#__PURE__*/React.createElement(DatePicker, {
95
+ value: value,
96
+ allowClear: false,
97
+ inputReadOnly: true,
98
+ popupClassName: "".concat(classPrefix, "-drop"),
99
+ locale: locale,
100
+ showToday: false,
101
+ placement: "bottomLeft",
102
+ getPopupContainer: function getPopupContainer(trigger) {
103
+ return trigger.parentNode;
104
+ },
105
+ placeholder: "\u81EA\u5B9A\u4E49",
106
+ suffixIcon: /*#__PURE__*/React.createElement(IconFont, {
107
+ type: 'shijian1'
108
+ }),
109
+ disabledDate: disabledDate,
110
+ open: true,
111
+ onChange: function onChange(date) {
112
+ if (date) {
113
+ setValue(moment(date, 'YYYY-MM-DD'));
114
+ }
115
+ }
116
+ }) : /*#__PURE__*/React.createElement(RangePicker, {
117
+ value: value,
118
+ allowClear: false,
119
+ popupClassName: "".concat(classPrefix, "-drop"),
120
+ inputReadOnly: true,
121
+ locale: locale,
122
+ placement: "bottomLeft",
123
+ separator: '至',
124
+ suffixIcon: /*#__PURE__*/React.createElement(IconFont, {
125
+ type: 'shijian1'
126
+ }),
127
+ format: 'YYYY-MM-DD',
128
+ disabledDate: disabledDate,
129
+ open: true,
130
+ getPopupContainer: function getPopupContainer(trigger) {
131
+ return trigger.parentNode;
132
+ },
133
+ onChange: function onChange(value) {
134
+ var subtractDays = 0;
135
+ if (includeToday && value && value.length === 2 && isTodayInRange(value[0], value[1])) {
136
+ subtractDays = 1;
137
+ }
138
+ if (value && value.length === 2 && moment(_.cloneDeep(value[1]).subtract(subtractDays, 'days').format('YYYY-MM-DD')).diff(moment(value[0].format('YYYY-MM-DD')), selectRangeUnit || 'months') > (selectRange ? selectRange : 12)) {
139
+ BizDateBeyondRange = true;
140
+ return;
141
+ }
142
+ if (value && value.length === 2) {
143
+ BizDateBeyondRange = false;
144
+ setValue([moment(value[0], 'YYYY-MM-DD'), moment(value[1], 'YYYY-MM-DD')]);
145
+ }
146
+ }
147
+ }));
148
+ });
149
+ export default BizDate;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import '@zgfe/business-lib/es/assets/styles/resetAntd.less';
3
+ declare const _default: () => React.JSX.Element;
4
+ export default _default;
@@ -0,0 +1,38 @@
1
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
+ 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."); }
3
+ 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); }
4
+ 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; }
5
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
6
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
+ import React, { useState } from 'react';
8
+ import { BizDatePicker } from '@zgfe/business-lib';
9
+ import '@zgfe/business-lib/es/assets/styles/resetAntd.less';
10
+ import { Switch } from 'antd';
11
+ export default (function () {
12
+ var _useState = useState({
13
+ begin: '2022-05-03',
14
+ end: '2022-05-30',
15
+ relative: [0, 1]
16
+ }),
17
+ _useState2 = _slicedToArray(_useState, 2),
18
+ time = _useState2[0],
19
+ setTime = _useState2[1];
20
+ var _useState3 = useState(false),
21
+ _useState4 = _slicedToArray(_useState3, 2),
22
+ includeToday = _useState4[0],
23
+ setIncludeToday = _useState4[1];
24
+ var handleChange = function handleChange(data) {
25
+ setTime(data);
26
+ };
27
+ return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", null, "\u5305\u542B\u300C\u4ECA\u5929\u300D: ", /*#__PURE__*/React.createElement(Switch, {
28
+ defaultChecked: includeToday,
29
+ onChange: setIncludeToday
30
+ })), /*#__PURE__*/React.createElement(BizDatePicker, {
31
+ onChange: handleChange,
32
+ dateTypeList: ['week', 'month', 'quarter'],
33
+ selectRange: 365,
34
+ selectRangeUnit: 'days',
35
+ includeToday: includeToday,
36
+ defaultValue: time
37
+ }), /*#__PURE__*/React.createElement("p", null, "\u5F53\u524D\u503C\uFF1A", JSON.stringify(time)));
38
+ });
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import '@zgfe/business-lib/es/assets/styles/resetAntd.less';
3
+ declare const _default: () => React.JSX.Element;
4
+ export default _default;
@@ -0,0 +1,47 @@
1
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
+ 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."); }
3
+ 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); }
4
+ 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; }
5
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
6
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
+ import { BizDatePicker } from '@zgfe/business-lib';
8
+ import React, { useState } from 'react';
9
+ import '@zgfe/business-lib/es/assets/styles/resetAntd.less';
10
+ import { Button, Divider, Space, Switch } from 'antd';
11
+ export default (function () {
12
+ var _useState = useState({
13
+ unit: 'day',
14
+ begin: '2022-05-03',
15
+ end: '2022-05-30',
16
+ relative: [0, 1]
17
+ }),
18
+ _useState2 = _slicedToArray(_useState, 2),
19
+ time = _useState2[0],
20
+ setTime = _useState2[1];
21
+ var aaa = {
22
+ unit: 'week',
23
+ relative: [7, 1]
24
+ };
25
+ var _useState3 = useState(false),
26
+ _useState4 = _slicedToArray(_useState3, 2),
27
+ includeToday = _useState4[0],
28
+ setIncludeToday = _useState4[1];
29
+ var handleChange = function handleChange(data) {
30
+ setTime(data);
31
+ };
32
+ return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Button, {
33
+ onClick: function onClick() {
34
+ return setTime(aaa);
35
+ }
36
+ }, "\u624B\u52A8\u8BBE\u7F6E\u65F6\u95F4"), /*#__PURE__*/React.createElement("span", null, JSON.stringify(aaa))), /*#__PURE__*/React.createElement("div", null, "\u5305\u542B\u300C\u4ECA\u5929\u300D: ", /*#__PURE__*/React.createElement(Switch, {
37
+ defaultChecked: includeToday,
38
+ onChange: setIncludeToday
39
+ })), /*#__PURE__*/React.createElement(Divider, null), /*#__PURE__*/React.createElement(BizDatePicker, {
40
+ onChange: handleChange,
41
+ includeToday: true,
42
+ value: time,
43
+ defaultValue: time,
44
+ selectRange: 1,
45
+ selectRangeUnit: 'weeks'
46
+ }), /*#__PURE__*/React.createElement("br", null), /*#__PURE__*/React.createElement("p", null, "\u5F53\u524D\u503C\uFF1A", JSON.stringify(time)));
47
+ });
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import '@zgfe/business-lib/es/assets/styles/resetAntd.less';
3
+ declare const _default: () => React.JSX.Element;
4
+ export default _default;
@@ -0,0 +1,67 @@
1
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
+ 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."); }
3
+ 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); }
4
+ 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; }
5
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
6
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
+ import { BizDatePickerOld } from '@zgfe/business-lib';
8
+ import React, { useState } from 'react';
9
+ import '@zgfe/business-lib/es/assets/styles/resetAntd.less';
10
+ import { Divider, Space, Switch } from 'antd';
11
+ import { DatePickerTypes } from '../types';
12
+ import moment from 'moment';
13
+ export default (function () {
14
+ var _useState = useState({
15
+ begin: '2024-07-01',
16
+ end: '2024-08-09',
17
+ relative: [5, 0],
18
+ unit: 'week'
19
+ }),
20
+ _useState2 = _slicedToArray(_useState, 2),
21
+ time = _useState2[0],
22
+ setTime = _useState2[1];
23
+ var _useState3 = useState(false),
24
+ _useState4 = _slicedToArray(_useState3, 2),
25
+ includeToday = _useState4[0],
26
+ setIncludeToday = _useState4[1];
27
+ var handleChange = function handleChange(data) {
28
+ setTime(data);
29
+ };
30
+ console.log(moment().subtract(360, 'days').format('YYYY-MM-DD'));
31
+ function calculateTimeUnits(selectRange, selectRangeUnit, currentType) {
32
+ var duration = moment.duration(1, currentType);
33
+ switch (selectRangeUnit) {
34
+ case 'days':
35
+ duration.add(selectRange, 'days');
36
+ break;
37
+ case 'weeks':
38
+ duration.add(selectRange, 'weeks');
39
+ break;
40
+ case 'months':
41
+ duration.add(selectRange, 'months');
42
+ break;
43
+ case 'quarter':
44
+ duration.add(selectRange * 3, 'months');
45
+ break;
46
+ default:
47
+ break;
48
+ }
49
+ var result = duration.get(currentType);
50
+ return result;
51
+ }
52
+ console.log(calculateTimeUnits(365, 'days', 'weeks'));
53
+ return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Space, {
54
+ direction: "vertical"
55
+ }, /*#__PURE__*/React.createElement("div", null, "\u5305\u542B\u300C\u4ECA\u5929\u300D: ", /*#__PURE__*/React.createElement(Switch, {
56
+ defaultChecked: includeToday,
57
+ onChange: setIncludeToday
58
+ })), /*#__PURE__*/React.createElement(Divider, null), /*#__PURE__*/React.createElement(BizDatePickerOld, {
59
+ includeToday: includeToday,
60
+ value: time,
61
+ defaultValue: time,
62
+ dateTypeList: [DatePickerTypes.Unit.hour, DatePickerTypes.Unit.day, DatePickerTypes.Unit.week, DatePickerTypes.Unit.month, DatePickerTypes.Unit.quarter, DatePickerTypes.Unit.custom],
63
+ selectRange: 365,
64
+ selectRangeUnit: "days",
65
+ onChange: handleChange
66
+ }), /*#__PURE__*/React.createElement("p", null, "\u5F53\u524D\u503C\uFF1A", JSON.stringify(time))));
67
+ });
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import { DatePickerTypes } from './types';
3
+ import './styles/index.less';
4
+ export declare const classPrefix = "biz-date-picker-old-wrap";
5
+ declare const BizDatePicker: React.FC<DatePickerTypes.Props>;
6
+ export default BizDatePicker;
@@ -0,0 +1,243 @@
1
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
3
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
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; }
5
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
+ function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
7
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
8
+ 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."); }
9
+ 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); }
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; }
11
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
12
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
13
+ import React, { useEffect, useState } from 'react';
14
+ import BizSelect from '../select';
15
+ import { DatePickerTypes } from './types';
16
+ import './styles/index.less';
17
+ import { Popover, Skeleton } from 'antd';
18
+ import DatePickerContext from './context';
19
+ import _ from 'lodash';
20
+ import { DateOptionMap, getDateRange, getTypeList } from './utils';
21
+ import PopoverContent from './popoverContent';
22
+ import IconFont from '../icon/iconFont';
23
+ import moment from 'moment';
24
+ export var classPrefix = 'biz-date-picker-old-wrap';
25
+ var typeMap = {
26
+ hour: '按小时',
27
+ day: '按天',
28
+ week: '按周',
29
+ month: '按月',
30
+ quarter: '按季度',
31
+ custom: '自定义'
32
+ };
33
+ var BizDatePicker = function BizDatePicker(_ref) {
34
+ var defaultValue = _ref.defaultValue,
35
+ value = _ref.value,
36
+ includeToday = _ref.includeToday,
37
+ dateTypeList = _ref.dateTypeList,
38
+ onChange = _ref.onChange,
39
+ selectRange = _ref.selectRange,
40
+ selectRangeUnit = _ref.selectRangeUnit,
41
+ timeRangeOpen = _ref.timeRangeOpen;
42
+ var _useState = useState(false),
43
+ _useState2 = _slicedToArray(_useState, 2),
44
+ ready = _useState2[0],
45
+ setReady = _useState2[1];
46
+ var _useState3 = useState([]),
47
+ _useState4 = _slicedToArray(_useState3, 2),
48
+ typeList = _useState4[0],
49
+ setTypeList = _useState4[1];
50
+ var _useState5 = useState(),
51
+ _useState6 = _slicedToArray(_useState5, 2),
52
+ currentType = _useState6[0],
53
+ setCurrentType = _useState6[1];
54
+ var _useState7 = useState(),
55
+ _useState8 = _slicedToArray(_useState7, 2),
56
+ dateRange = _useState8[0],
57
+ setDateRange = _useState8[1];
58
+ var _useState9 = useState(),
59
+ _useState10 = _slicedToArray(_useState9, 2),
60
+ relative = _useState10[0],
61
+ setRelative = _useState10[1];
62
+ var _useState11 = useState(),
63
+ _useState12 = _slicedToArray(_useState11, 2),
64
+ setTimer = _useState12[1];
65
+ var _useState13 = useState(false),
66
+ _useState14 = _slicedToArray(_useState13, 2),
67
+ open = _useState14[0],
68
+ setOpen = _useState14[1];
69
+ function init(initValue) {
70
+ setReady(false);
71
+ var list = dateTypeList === null || dateTypeList === void 0 ? void 0 : dateTypeList.map(function (type) {
72
+ return {
73
+ label: typeMap[type],
74
+ value: type
75
+ };
76
+ });
77
+ setTypeList(list);
78
+ var currentType = (initValue === null || initValue === void 0 ? void 0 : initValue.unit) ? list.find(function (item) {
79
+ return item.value === initValue.unit;
80
+ }) : list[0];
81
+ setCurrentType(currentType);
82
+ if (initValue === null || initValue === void 0 ? void 0 : initValue.relative) {
83
+ setRelative(initValue.relative);
84
+ }
85
+ var typeList = getTypeList(currentType === null || currentType === void 0 ? void 0 : currentType.value, includeToday);
86
+ var begin = initValue.begin,
87
+ end = initValue.end;
88
+ var item = typeList.find(function (item) {
89
+ var match = getDateRange(currentType === null || currentType === void 0 ? void 0 : currentType.value, item.count, includeToday);
90
+ return moment(begin).isSame(match.begin) && moment(end).isSame(match.end);
91
+ });
92
+ var active = item === null || item === void 0 ? void 0 : item.count;
93
+ if (active) {
94
+ setDateRange({
95
+ begin: initValue.begin,
96
+ end: initValue.end
97
+ });
98
+ } else {
99
+ if (initValue.relative) {
100
+ setDateRange(getDateRange(currentType === null || currentType === void 0 ? void 0 : currentType.value, initValue.relative[0], includeToday));
101
+ } else {
102
+ setDateRange({
103
+ begin: initValue.begin,
104
+ end: initValue.end
105
+ });
106
+ }
107
+ }
108
+ setReady(true);
109
+ }
110
+ useEffect(function () {
111
+ if (defaultValue) init(defaultValue);
112
+ }, []);
113
+ useEffect(function () {
114
+ if (_.isEqual(value, _objectSpread(_objectSpread({}, dateRange), {}, {
115
+ relative: relative,
116
+ unit: currentType === null || currentType === void 0 ? void 0 : currentType.value
117
+ })) || !value) return;
118
+ init(value);
119
+ }, [value]);
120
+ useEffect(function () {
121
+ if (!onChange || !ready) return;
122
+ setTimer(function (pre) {
123
+ clearTimeout(pre);
124
+ return setTimeout(function () {
125
+ onChange(_objectSpread(_objectSpread({}, dateRange), {}, {
126
+ relative: relative,
127
+ unit: currentType === null || currentType === void 0 ? void 0 : currentType.value
128
+ }));
129
+ }, 100);
130
+ });
131
+ }, [dateRange, currentType, relative, ready]);
132
+ var renderLabel = function renderLabel() {
133
+ var typeList = getTypeList(currentType === null || currentType === void 0 ? void 0 : currentType.value, includeToday);
134
+ if (relative) {
135
+ var type = typeList.find(function (item) {
136
+ return item.count == relative[0];
137
+ });
138
+ if (type) {
139
+ if ((currentType === null || currentType === void 0 ? void 0 : currentType.value) == DatePickerTypes.Unit.hour) {
140
+ return type.value;
141
+ }
142
+ return '最近' + type.value;
143
+ } else {
144
+ return '最近' + relative[0] + Reflect.get(DateOptionMap, currentType === null || currentType === void 0 ? void 0 : currentType.value);
145
+ }
146
+ } else {
147
+ if ((currentType === null || currentType === void 0 ? void 0 : currentType.value) == DatePickerTypes.Unit.hour) {
148
+ return dateRange === null || dateRange === void 0 ? void 0 : dateRange.begin;
149
+ } else {
150
+ return (dateRange === null || dateRange === void 0 ? void 0 : dateRange.begin) + ' 至 ' + (dateRange === null || dateRange === void 0 ? void 0 : dateRange.end);
151
+ }
152
+ }
153
+ };
154
+ if (!typeList.length || !currentType || !ready) {
155
+ return /*#__PURE__*/React.createElement("div", {
156
+ className: classPrefix
157
+ }, /*#__PURE__*/React.createElement(Skeleton.Input, {
158
+ active: true
159
+ }));
160
+ }
161
+ return /*#__PURE__*/React.createElement("div", {
162
+ className: classPrefix
163
+ }, /*#__PURE__*/React.createElement(DatePickerContext.Provider, {
164
+ value: {
165
+ includeToday: includeToday,
166
+ dateRange: dateRange,
167
+ setDateRange: setDateRange,
168
+ currentType: currentType.value,
169
+ relative: relative,
170
+ setRelative: setRelative,
171
+ setOpen: setOpen
172
+ }
173
+ }, /*#__PURE__*/React.createElement(BizSelect, {
174
+ className: "".concat(classPrefix, "-type"),
175
+ theme: "secondary",
176
+ keyField: "value",
177
+ labelField: "label",
178
+ value: currentType,
179
+ options: typeList,
180
+ onChange: function onChange(type) {
181
+ setCurrentType(type);
182
+ if (type.value === 'hour') {
183
+ setDateRange(getDateRange(DatePickerTypes.Unit.day, 1, includeToday));
184
+ setRelative([1, 1]);
185
+ }
186
+ if (type.value === 'day') {
187
+ setDateRange(getDateRange(DatePickerTypes.Unit.day, 7, includeToday));
188
+ setRelative([7, includeToday ? 0 : 1]);
189
+ }
190
+ if (type.value === 'week') {
191
+ setDateRange(getDateRange(DatePickerTypes.Unit.week, 4, includeToday));
192
+ setRelative([4, includeToday ? 0 : 1]);
193
+ }
194
+ if (type.value === 'month') {
195
+ setDateRange(getDateRange(DatePickerTypes.Unit.month, 1, includeToday));
196
+ setRelative([1, includeToday ? 0 : 1]);
197
+ }
198
+ if (type.value === 'quarter') {
199
+ setDateRange(getDateRange(DatePickerTypes.Unit.quarter, 1, includeToday));
200
+ setRelative([1, includeToday ? 0 : 1]);
201
+ }
202
+ if (type.value == 'custom') {
203
+ setRelative(undefined);
204
+ }
205
+ }
206
+ }), /*#__PURE__*/React.createElement(Popover, {
207
+ overlayClassName: "".concat(classPrefix, "-input-popover"),
208
+ open: open,
209
+ placement: "bottomLeft",
210
+ trigger: "click",
211
+ destroyTooltipOnHide: true,
212
+ content: /*#__PURE__*/React.createElement(PopoverContent, {
213
+ setDateRange: setDateRange,
214
+ setOpen: setOpen,
215
+ selectRange: selectRange,
216
+ selectRangeUnit: selectRangeUnit,
217
+ timeRangeOpen: timeRangeOpen,
218
+ currentType: currentType.value,
219
+ relative: relative
220
+ }),
221
+ onOpenChange: function onOpenChange() {
222
+ return setOpen(!open);
223
+ }
224
+ }, /*#__PURE__*/React.createElement("div", {
225
+ className: "".concat(classPrefix, "-input ").concat(open ? classPrefix + '-input-active' : ''),
226
+ onClick: function onClick() {
227
+ return setOpen(true);
228
+ }
229
+ }, /*#__PURE__*/React.createElement("div", {
230
+ className: "".concat(classPrefix, "-input-label")
231
+ }, /*#__PURE__*/React.createElement(IconFont, {
232
+ type: "rili-2",
233
+ size: 14
234
+ }), /*#__PURE__*/React.createElement("span", null, renderLabel())), /*#__PURE__*/React.createElement(IconFont, {
235
+ type: "xiangxia",
236
+ size: 14
237
+ })))));
238
+ };
239
+ BizDatePicker.defaultProps = {
240
+ includeToday: true,
241
+ dateTypeList: [DatePickerTypes.Unit.hour, DatePickerTypes.Unit.day, DatePickerTypes.Unit.week, DatePickerTypes.Unit.month]
242
+ };
243
+ export default BizDatePicker;