@zgfe/business-lib 1.2.51 → 1.2.53

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 (49) hide show
  1. package/es/assets/colorIcon/demo_index.html +717 -4
  2. package/es/assets/colorIcon/iconfont.css +128 -4
  3. package/es/assets/colorIcon/iconfont.js +16 -16
  4. package/es/assets/colorIcon/iconfont.json +217 -0
  5. package/es/assets/colorIcon/iconfont.svg +62 -0
  6. package/es/assets/colorIcon/iconfont.ttf +0 -0
  7. package/es/assets/colorIcon/iconfont.woff +0 -0
  8. package/es/assets/colorIcon/iconfont.woff2 +0 -0
  9. package/es/assets/iconfont/demo_index.html +310 -11
  10. package/es/assets/iconfont/iconfont.css +57 -5
  11. package/es/assets/iconfont/iconfont.js +14 -15
  12. package/es/assets/iconfont/iconfont.json +93 -2
  13. package/es/assets/iconfont/iconfont.ttf +0 -0
  14. package/es/assets/iconfont/iconfont.woff +0 -0
  15. package/es/assets/iconfont/iconfont.woff2 +0 -0
  16. package/es/assets/styles/resetAntd.less +3 -2
  17. package/es/datePicker/demo/index.js +3 -1
  18. package/es/datePickerV2/context.d.ts +13 -0
  19. package/es/datePickerV2/context.js +3 -0
  20. package/es/datePickerV2/datePicker.d.ts +7 -0
  21. package/es/datePickerV2/datePicker.js +149 -0
  22. package/es/datePickerV2/demo/customType.d.ts +4 -0
  23. package/es/datePickerV2/demo/customType.js +38 -0
  24. package/es/datePickerV2/demo/day.d.ts +4 -0
  25. package/es/datePickerV2/demo/day.js +47 -0
  26. package/es/datePickerV2/demo/index.d.ts +4 -0
  27. package/es/datePickerV2/demo/index.js +67 -0
  28. package/es/datePickerV2/index.d.ts +6 -0
  29. package/es/datePickerV2/index.js +243 -0
  30. package/es/datePickerV2/popoverContent.d.ts +13 -0
  31. package/es/datePickerV2/popoverContent.js +53 -0
  32. package/es/datePickerV2/shortcut.d.ts +7 -0
  33. package/es/datePickerV2/shortcut.js +120 -0
  34. package/es/datePickerV2/styles/index.less +184 -0
  35. package/es/datePickerV2/types.d.ts +38 -0
  36. package/es/datePickerV2/types.js +12 -0
  37. package/es/datePickerV2/utils.d.ts +30 -0
  38. package/es/datePickerV2/utils.js +139 -0
  39. package/es/index.d.ts +2 -1
  40. package/es/index.js +2 -1
  41. package/package.json +3 -3
  42. package/es/table/font_2545884_ievcoe4sky/demo.css +0 -539
  43. package/es/table/font_2545884_ievcoe4sky/demo_index.html +0 -4857
  44. package/es/table/font_2545884_ievcoe4sky/iconfont.css +0 -827
  45. package/es/table/font_2545884_ievcoe4sky/iconfont.js +0 -43
  46. package/es/table/font_2545884_ievcoe4sky/iconfont.json +0 -1430
  47. package/es/table/font_2545884_ievcoe4sky/iconfont.ttf +0 -0
  48. package/es/table/font_2545884_ievcoe4sky/iconfont.woff +0 -0
  49. package/es/table/font_2545884_ievcoe4sky/iconfont.woff2 +0 -0
@@ -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;
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { DatePickerTypes } from './types';
3
+ interface PopoverContent {
4
+ setDateRange?: any;
5
+ setOpen?: any;
6
+ timeRangeOpen?: number;
7
+ selectRange?: number;
8
+ currentType?: DatePickerTypes.Unit;
9
+ relative?: any[];
10
+ selectRangeUnit?: 'days' | 'weeks' | 'months' | 'quarter';
11
+ }
12
+ declare const _default: (props: PopoverContent) => React.JSX.Element;
13
+ export default _default;
@@ -0,0 +1,53 @@
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
+ import { Button, Tabs } from 'antd';
8
+ import React, { useRef } from 'react';
9
+ import PickerShortcut from './shortcut';
10
+ import BizDate from './datePicker';
11
+ import { classPrefix } from '.';
12
+ import { DatePickerTypes } from './types';
13
+ export default (function (props) {
14
+ var selectRange = props.selectRange,
15
+ setDateRange = props.setDateRange,
16
+ setOpen = props.setOpen,
17
+ currentType = props.currentType,
18
+ relative = props.relative,
19
+ selectRangeUnit = props.selectRangeUnit;
20
+ var ref = useRef();
21
+ return /*#__PURE__*/React.createElement(Tabs, {
22
+ defaultActiveKey: relative ? '1' : '2'
23
+ }, currentType != DatePickerTypes.Unit.custom && /*#__PURE__*/React.createElement(Tabs.TabPane, {
24
+ tab: "\u6700\u8FD1",
25
+ key: "1"
26
+ }, /*#__PURE__*/React.createElement(PickerShortcut, {
27
+ selectRange: selectRange,
28
+ selectRangeUnit: selectRangeUnit
29
+ })), /*#__PURE__*/React.createElement(Tabs.TabPane, {
30
+ tab: "\u81EA\u5B9A\u4E49",
31
+ key: "2"
32
+ }, /*#__PURE__*/React.createElement(BizDate, _objectSpread({
33
+ ref: ref
34
+ }, props)), /*#__PURE__*/React.createElement("div", {
35
+ className: "".concat(classPrefix, "-popoverContent-btns")
36
+ }, /*#__PURE__*/React.createElement(Button, {
37
+ onClick: function onClick() {
38
+ return setOpen(false);
39
+ }
40
+ }, "\u53D6\u6D88"), /*#__PURE__*/React.createElement(Button, {
41
+ type: "primary",
42
+ onClick: function onClick() {
43
+ if (ref.current) {
44
+ var _ref$current;
45
+ var dateValue = (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.getDateValue();
46
+ if (dateValue === null || dateValue === void 0 ? void 0 : dateValue.begin) {
47
+ setDateRange(dateValue);
48
+ }
49
+ setOpen(false);
50
+ }
51
+ }
52
+ }, "\u786E\u5B9A"))));
53
+ });
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ declare const PickerShortcut: React.FC<{
3
+ selectRange?: number;
4
+ selectRangeUnit?: string;
5
+ timeRangeOpen?: number;
6
+ }>;
7
+ export default PickerShortcut;
@@ -0,0 +1,120 @@
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, { useContext, useEffect, useState } from 'react';
8
+ import { DatePickerTypes } from './types';
9
+ import { classPrefix } from '.';
10
+ import DatePickerContext from './context';
11
+ import { DateOptionMap, getDateRange, getTypeList } from './utils';
12
+ import { Button, InputNumber } from 'antd';
13
+ import BizGlobalDataContext from '../context';
14
+ import moment from 'moment';
15
+ var PickerShortcut = function PickerShortcut(_ref) {
16
+ var selectRange = _ref.selectRange,
17
+ selectRangeUnit = _ref.selectRangeUnit,
18
+ timeRangeOpen = _ref.timeRangeOpen;
19
+ var _useContext = useContext(DatePickerContext),
20
+ currentType = _useContext.currentType,
21
+ includeToday = _useContext.includeToday,
22
+ relative = _useContext.relative,
23
+ setDateRange = _useContext.setDateRange,
24
+ setRelative = _useContext.setRelative,
25
+ setOpen = _useContext.setOpen;
26
+ var _useContext2 = useContext(BizGlobalDataContext),
27
+ envs = _useContext2.envs;
28
+ var list = getTypeList(currentType, includeToday);
29
+ var _useState = useState(),
30
+ _useState2 = _slicedToArray(_useState, 2),
31
+ active = _useState2[0],
32
+ setActive = _useState2[1];
33
+ var _useState3 = useState(active),
34
+ _useState4 = _slicedToArray(_useState3, 2),
35
+ numbers = _useState4[0],
36
+ setNumbers = _useState4[1];
37
+ var _useState5 = useState(false),
38
+ _useState6 = _slicedToArray(_useState5, 2),
39
+ isError = _useState6[0],
40
+ setIsError = _useState6[1];
41
+ useEffect(function () {
42
+ list = getTypeList(currentType, includeToday);
43
+ if (relative) {
44
+ setActive(relative[0]);
45
+ setNumbers(relative[0]);
46
+ }
47
+ }, [currentType, includeToday]);
48
+ function getMax() {
49
+ var _timeRangeOpen = timeRangeOpen || 12;
50
+ if (envs === null || envs === void 0 ? void 0 : envs.timeRangeOpen) {
51
+ _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;
52
+ }
53
+ _timeRangeOpen = moment.duration(_timeRangeOpen, 'months').asDays();
54
+ var selectRangeCount = moment.duration(selectRange, selectRangeUnit).asDays();
55
+ var count = selectRange ? _timeRangeOpen > selectRangeCount ? selectRangeCount : _timeRangeOpen : _timeRangeOpen;
56
+ var max = moment.duration(count, 'days').asDays();
57
+ var duration = moment.duration(count, 'days');
58
+ switch (currentType) {
59
+ case 'week':
60
+ max = Math.round(duration.asWeeks());
61
+ break;
62
+ case 'month':
63
+ max = Math.round(duration.asMonths());
64
+ break;
65
+ default:
66
+ break;
67
+ }
68
+ return max;
69
+ }
70
+ return /*#__PURE__*/React.createElement("div", {
71
+ className: "".concat(classPrefix, "-shortcut")
72
+ }, /*#__PURE__*/React.createElement("div", {
73
+ className: "".concat(classPrefix, "-list")
74
+ }, list.map(function (item, index) {
75
+ return /*#__PURE__*/React.createElement("div", {
76
+ key: index,
77
+ className: "".concat(classPrefix, "-item ").concat(active === item.count ? 'active' : ''),
78
+ onClick: function onClick() {
79
+ setActive(item.count);
80
+ if (setRelative) setRelative([item.count, includeToday ? 0 : 1]);
81
+ setDateRange === null || setDateRange === void 0 ? void 0 : setDateRange(getDateRange(currentType, item.count, includeToday));
82
+ setOpen === null || setOpen === void 0 ? void 0 : setOpen(false);
83
+ }
84
+ }, item.value);
85
+ })), ![DatePickerTypes.Unit.hour, DatePickerTypes.Unit.quarter].includes(currentType) && /*#__PURE__*/React.createElement("div", {
86
+ className: "".concat(classPrefix, "-list-relative")
87
+ }, /*#__PURE__*/React.createElement("div", {
88
+ className: "".concat(classPrefix, "-list-relative-content")
89
+ }, /*#__PURE__*/React.createElement("span", null, "\u8FD1"), /*#__PURE__*/React.createElement(InputNumber, {
90
+ className: isError ? "".concat(classPrefix, "-input-error") : '',
91
+ min: 1,
92
+ max: getMax(),
93
+ controls: false,
94
+ style: {
95
+ width: '58px'
96
+ },
97
+ value: numbers,
98
+ onChange: function onChange(value) {
99
+ return setNumbers(value);
100
+ },
101
+ onBlur: function onBlur() {
102
+ if (numbers) {
103
+ setIsError(false);
104
+ }
105
+ }
106
+ }), /*#__PURE__*/React.createElement("span", null, Reflect.get(DateOptionMap, currentType))), /*#__PURE__*/React.createElement(Button, {
107
+ type: "primary",
108
+ onClick: function onClick() {
109
+ if (!numbers) {
110
+ setIsError(true);
111
+ return;
112
+ }
113
+ var date = getDateRange(currentType, numbers, includeToday);
114
+ setDateRange === null || setDateRange === void 0 ? void 0 : setDateRange(date);
115
+ setRelative === null || setRelative === void 0 ? void 0 : setRelative([numbers, includeToday ? 0 : 1]);
116
+ setOpen === null || setOpen === void 0 ? void 0 : setOpen(false);
117
+ }
118
+ }, "\u786E\u8BA4")));
119
+ };
120
+ export default PickerShortcut;
@@ -0,0 +1,184 @@
1
+ @import '../../assets/styles/inner.less';
2
+
3
+ .biz-date-picker-old-wrap {
4
+ display: flex;
5
+
6
+ &-type {
7
+ width: 88px;
8
+ }
9
+
10
+ &-shortcut {
11
+ display: flex;
12
+ }
13
+
14
+ &-list {
15
+ display: flex;
16
+ // margin: 0 16px 0 0;
17
+
18
+ &-relative {
19
+ display: flex;
20
+ gap: 24px;
21
+ align-items: center;
22
+ margin-left: 16px;
23
+
24
+ &-content {
25
+ display: flex;
26
+ align-items: center;
27
+ span {
28
+ margin: 0 8px;
29
+ }
30
+
31
+ .ant-input-number {
32
+ background-color: #fff !important;
33
+ border: 1px solid var(---, #ecedf0);
34
+ border-radius: 4px;
35
+ }
36
+ }
37
+ }
38
+ }
39
+
40
+ .biz-select-handle {
41
+ margin-right: 8px;
42
+ padding: 0;
43
+ }
44
+
45
+ &-item {
46
+ display: flex;
47
+ align-items: center;
48
+ justify-content: center;
49
+ width: 58px;
50
+ height: @height-base;
51
+ color: @text-color-secondary;
52
+ border: 1px solid @border-color-base;
53
+ cursor: pointer;
54
+
55
+ &:first-child {
56
+ border-radius: @border-radius-small 0px 0px @border-radius-small;
57
+ }
58
+
59
+ &:last-child {
60
+ border-radius: 0px @border-radius-small @border-radius-small 0px;
61
+ }
62
+
63
+ &:hover {
64
+ .__default-hover();
65
+ border-color: @border-color-base;
66
+ }
67
+
68
+ &.active {
69
+ color: @primary-color;
70
+ background: @primary-color-hover;
71
+ border: 1px solid @primary-color;
72
+ }
73
+ }
74
+
75
+ &-input {
76
+ display: flex;
77
+ flex-shrink: 0;
78
+ gap: 4px;
79
+ align-items: center;
80
+ justify-content: space-between;
81
+ width: 262px;
82
+ padding: 0px 12px;
83
+ font-size: 14px;
84
+ background: #fff;
85
+ border: 1px solid var(---, #ecedf0);
86
+ border-radius: 4px;
87
+
88
+ &-label {
89
+ display: flex;
90
+ gap: 4px;
91
+ align-items: center;
92
+ }
93
+
94
+ &:hover {
95
+ // color: #165dff;
96
+ border-color: @primary-color;
97
+ cursor: pointer;
98
+ }
99
+
100
+ &:focus {
101
+ border-color: @primary-color;
102
+ }
103
+
104
+ &:active {
105
+ border-color: @primary-color;
106
+ }
107
+
108
+ &-active {
109
+ border-color: @primary-color;
110
+ box-shadow: 0 0 0 4px #f0f7ff;
111
+ }
112
+
113
+ &-popover {
114
+ padding-top: 0 !important;
115
+ .ant-popover-arrow {
116
+ display: none;
117
+ }
118
+
119
+ .ant-popover-inner-content {
120
+ padding: 0 16px 16px;
121
+ }
122
+
123
+ .ant-picker-dropdown {
124
+ padding-top: 0;
125
+
126
+ .ant-picker-range-arrow {
127
+ display: none;
128
+ }
129
+ }
130
+
131
+ .ant-tabs-top > .ant-tabs-nav::before {
132
+ border-bottom: 1px solid #fafafb;
133
+ }
134
+
135
+ .ant-tabs-tab {
136
+ padding: 12px 0 !important;
137
+ font-size: 14px !important;
138
+ }
139
+
140
+ .ant-popover-inner {
141
+ background: #fff;
142
+ border-radius: 8px;
143
+ box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.1);
144
+ }
145
+ }
146
+
147
+ &-error {
148
+ position: relative;
149
+ border: 1px solid var(--io-Error-E-, #fb5547) !important;
150
+
151
+ &::after {
152
+ position: absolute;
153
+ width: 67px;
154
+ color: red;
155
+ font-size: 12px;
156
+ content: '请输入内容';
157
+ }
158
+ }
159
+ }
160
+
161
+ &-panel {
162
+ & div:last-of-type {
163
+ position: relative !important;
164
+ }
165
+
166
+ .ant-picker-panel-container {
167
+ background: #fff;
168
+ border: 1px solid var(--io-n-02, #fafafb);
169
+ border-radius: 10px;
170
+ box-shadow: none;
171
+ }
172
+
173
+ .ant-picker-panel-container .ant-picker-panel-focused {
174
+ border-color: var(--io-n-02, #fafafb);
175
+ }
176
+ }
177
+
178
+ &-popoverContent-btns {
179
+ display: flex;
180
+ gap: 16px;
181
+ justify-content: flex-end;
182
+ padding-top: 16px;
183
+ }
184
+ }
@@ -0,0 +1,38 @@
1
+ export declare namespace DatePickerTypes {
2
+ enum Unit {
3
+ 'hour' = "hour",
4
+ 'day' = "day",
5
+ 'week' = "week",
6
+ 'month' = "month",
7
+ 'quarter' = "quarter",
8
+ 'custom' = "custom"
9
+ }
10
+ interface Range {
11
+ begin?: string;
12
+ end?: string;
13
+ }
14
+ interface Value extends Range {
15
+ unit: Unit;
16
+ relative?: [number, number];
17
+ }
18
+ interface Props {
19
+ defaultValue?: Value;
20
+ value?: Value;
21
+ includeToday?: boolean;
22
+ selectRange?: number;
23
+ timeRangeOpen?: number;
24
+ selectRangeUnit?: 'days' | 'weeks' | 'months' | 'quarter';
25
+ onChange?: (data: Value) => void;
26
+ onOpenChange?: (data: boolean) => void;
27
+ dateTypeList?: Unit[];
28
+ }
29
+ interface Option {
30
+ label: string;
31
+ value: Unit;
32
+ children: ListOption[];
33
+ }
34
+ interface ListOption {
35
+ count: number;
36
+ value: string;
37
+ }
38
+ }
@@ -0,0 +1,12 @@
1
+ export var DatePickerTypes;
2
+ (function (DatePickerTypes) {
3
+ var Unit;
4
+ (function (Unit) {
5
+ Unit["hour"] = "hour";
6
+ Unit["day"] = "day";
7
+ Unit["week"] = "week";
8
+ Unit["month"] = "month";
9
+ Unit["quarter"] = "quarter";
10
+ Unit["custom"] = "custom";
11
+ })(Unit = DatePickerTypes.Unit || (DatePickerTypes.Unit = {}));
12
+ })(DatePickerTypes || (DatePickerTypes = {}));