dtable-ui-component 6.0.38 → 6.0.39-alpha42

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.
@@ -76,10 +76,11 @@ class MBDateEditor extends _react.default.PureComponent {
76
76
  const {
77
77
  time
78
78
  } = this.state;
79
+ const calanderFormat = Array.of(this.format);
79
80
  const calendar = /*#__PURE__*/_react.default.createElement(_seafileCalendar.default, {
80
81
  className: (0, _classnames.default)('dtable-rc-calendar', className),
81
82
  locale: (0, _editorUtils.initDateEditorLanguage)(lang),
82
- format: this.format,
83
+ format: calanderFormat,
83
84
  defaultValue: this.defaultCalendarValue,
84
85
  showDateInput: false,
85
86
  focusablePanel: false,
@@ -143,13 +143,14 @@ class PCDateEditor extends _react.default.Component {
143
143
  } = this.props;
144
144
  let defaultValue = (0, _dayjs.default)().clone();
145
145
  const defaultTime = this.getDefaultTime();
146
+ const calanderFormat = Array.isArray(dateFormat) ? dateFormat : Array.of(dateFormat);
146
147
  return /*#__PURE__*/_react.default.createElement(_seafileCalendar.default, {
147
148
  className: (0, _classnames.default)('dtable-rc-calendar', className),
148
149
  locale: (0, _editorUtils.initDateEditorLanguage)(lang),
149
150
  style: {
150
151
  zIndex: 1001
151
152
  },
152
- format: dateFormat,
153
+ format: calanderFormat,
153
154
  defaultValue: defaultValue,
154
155
  showHourAndMinute: showHourAndMinute,
155
156
  defaultMinutesTime: defaultTime,
@@ -7,7 +7,7 @@ Object.defineProperty(exports, "__esModule", {
7
7
  exports.default = void 0;
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
  var _classnames = _interopRequireDefault(require("classnames"));
10
- var _dtableUtils = require("dtable-utils");
10
+ var _dateFormat = require("../utils/dateFormat.js");
11
11
  require("./index.css");
12
12
  class DateFormatter extends _react.default.Component {
13
13
  render() {
@@ -18,7 +18,7 @@ class DateFormatter extends _react.default.Component {
18
18
  } = this.props;
19
19
  let classname = (0, _classnames.default)('dtable-ui cell-formatter-container date-formatter', containerClassName);
20
20
  if (date !== '') {
21
- date = (0, _dtableUtils.getDateDisplayString)(date, format);
21
+ date = (0, _dateFormat.renderDisplayContent)(date, format, (0, _dateFormat.delimate)(format));
22
22
  }
23
23
  return /*#__PURE__*/_react.default.createElement("div", {
24
24
  title: date,
@@ -472,6 +472,9 @@ class MapEditor extends _react.default.Component {
472
472
  }
473
473
  return;
474
474
  }
475
+ this.setState({
476
+ isLoading: false
477
+ });
475
478
  }
476
479
  componentWillUnmount() {
477
480
  let center = {};
@@ -262,7 +262,9 @@ class NumberInput extends React.Component {
262
262
  getContainer: () => this.getContainer()
263
263
  }, this.getComponent());
264
264
  } else {
265
- customNumberKeyboard = ReactDOM.unstable_renderSubtreeIntoContainer(this, this.getComponent(), this.getContainer());
265
+ const container = this.getContainer();
266
+ const root = ReactDOM.createRoot(container);
267
+ root.render(this.getComponent());
266
268
  }
267
269
  }
268
270
  renderPortal() {
@@ -0,0 +1,211 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.currentYear = exports.currentTime = exports.DATE_FORMATS = void 0;
8
+ exports.delimate = delimate;
9
+ exports.formatDateLocal = formatDateLocal;
10
+ exports.fullValidYear = fullValidYear;
11
+ exports.getDay = getDay;
12
+ exports.getMonth = getMonth;
13
+ exports.getYear = getYear;
14
+ exports.renderDisplayContent = renderDisplayContent;
15
+ exports.renderFilterInputFormat = renderFilterInputFormat;
16
+ var _dayjs = _interopRequireDefault(require("dayjs"));
17
+ var _utc = _interopRequireDefault(require("dayjs/plugin/utc"));
18
+ _dayjs.default.extend(_utc.default);
19
+ const currentTime = exports.currentTime = (0, _dayjs.default)().format('HH:mm');
20
+ const currentYear = exports.currentYear = (0, _dayjs.default)().year();
21
+ const DATE_FORMATS = exports.DATE_FORMATS = {
22
+ ISO: 'yyyy-mm-dd',
23
+ ISOAndTime: 'yyyy-mm-dd hh:mm',
24
+ US: 'm/d/yyyy',
25
+ USAndTime: 'm/d/yyyy hh:mm',
26
+ European: 'dd/mm/yyyy',
27
+ EuropeanAndTime: 'dd/mm/yyyy hh:mm',
28
+ Germany_Russia_etc: 'dd.mm.yyyy',
29
+ Germany_Russia_etcAndTime: 'dd.mm.yyyy hh:mm'
30
+ };
31
+ function fullValidYear(yearStr) {
32
+ const year = yearStr;
33
+ if (!year || isNaN(year)) return currentYear;
34
+ if (year.length === 2) {
35
+ if (Number(year) >= 0 && Number(year) < 69) {
36
+ return year ? "20".concat(year) : currentYear;
37
+ } else if (Number(year) >= 69 && Number(year) < 100) {
38
+ return year ? "19".concat(year) : currentYear;
39
+ }
40
+ }
41
+ if (year.length === 4) {
42
+ return year;
43
+ }
44
+ return year ? year.padStart(4, '0') : currentYear;
45
+ }
46
+ function formatDateLocal(formatStr, localeFormat) {
47
+ const str = formatStr || '';
48
+ const format = String(localeFormat).toLowerCase();
49
+ let cleanStr;
50
+ switch (format) {
51
+ case DATE_FORMATS.ISO:
52
+ case DATE_FORMATS.ISOAndTime:
53
+ cleanStr = str.replace(/[^0-9]+/g, '-');
54
+ return cleanStr.split('-').filter(Boolean).map(String);
55
+ case DATE_FORMATS.US:
56
+ case DATE_FORMATS.USAndTime:
57
+ case DATE_FORMATS.European:
58
+ case DATE_FORMATS.EuropeanAndTime:
59
+ cleanStr = str.replace(/[^0-9]+/g, '/');
60
+ return cleanStr.split('/').filter(Boolean).map(String);
61
+ case DATE_FORMATS.Germany_Russia_etc:
62
+ case DATE_FORMATS.Germany_Russia_etcAndTime:
63
+ cleanStr = str.replace(/[^0-9]+/g, '.');
64
+ return cleanStr.split('.').filter(Boolean).map(String);
65
+ default:
66
+ return [];
67
+ }
68
+ }
69
+ function delimate(localeFormat) {
70
+ const formatPrefix = String(localeFormat).toLowerCase();
71
+ let delimiter;
72
+ if (formatPrefix === DATE_FORMATS.Germany_Russia_etc || formatPrefix === DATE_FORMATS.Germany_Russia_etcAndTime) {
73
+ delimiter = '.';
74
+ } else if (formatPrefix === DATE_FORMATS.ISO || formatPrefix === DATE_FORMATS.ISOAndTime) {
75
+ delimiter = '-';
76
+ } else {
77
+ delimiter = '/';
78
+ }
79
+ return delimiter;
80
+ }
81
+ function renderDisplayContent(str, localeFormat, delimiter) {
82
+ const format = String(localeFormat).toLowerCase();
83
+ const parts = formatDateLocal(str, localeFormat);
84
+ if (parts.length < 3) {
85
+ return '';
86
+ }
87
+ let day = parts[2];
88
+ let month = parts[1];
89
+ let year = String(fullValidYear(parts[0])).padStart(4, '0');
90
+ let time = "".concat(parts[3], ":").concat(parts[4]) || currentTime;
91
+ if (format === DATE_FORMATS.ISO) {
92
+ return "".concat(year).concat(delimiter).concat(month).concat(delimiter).concat(day);
93
+ }
94
+ if (format === DATE_FORMATS.ISOAndTime) {
95
+ return "".concat(year).concat(delimiter).concat(month).concat(delimiter).concat(day, " ").concat(time);
96
+ }
97
+ if (format === DATE_FORMATS.US) {
98
+ return "".concat(Number(month)).concat(delimiter).concat(Number(day)).concat(delimiter).concat(year);
99
+ }
100
+ if (format === DATE_FORMATS.USAndTime) {
101
+ return "".concat(Number(month)).concat(delimiter).concat(Number(day)).concat(delimiter).concat(year, " ").concat(time);
102
+ }
103
+ if (format === DATE_FORMATS.European || format === DATE_FORMATS.Germany_Russia_etc) {
104
+ return "".concat(Number(day)).concat(delimiter).concat(Number(month)).concat(delimiter).concat(year);
105
+ }
106
+ if (format === DATE_FORMATS.EuropeanAndTime || format === DATE_FORMATS.Germany_Russia_etcAndTime) {
107
+ return "".concat(Number(day)).concat(delimiter).concat(Number(month)).concat(delimiter).concat(year, " ").concat(time);
108
+ }
109
+ }
110
+ function renderFilterInputFormat(str, localeFormat, delimiter) {
111
+ const format = String(localeFormat).toLowerCase();
112
+ const parts = formatDateLocal(str, localeFormat);
113
+ // console.log('parts', str, parts);
114
+ if (parts.length < 3) {
115
+ return '';
116
+ }
117
+ let day;
118
+ let month;
119
+ let year;
120
+ let time = "".concat(parts[3], ":").concat(parts[4]) || currentTime;
121
+ if (format === DATE_FORMATS.ISO) {
122
+ day = parts[2];
123
+ month = parts[1];
124
+ year = String(fullValidYear(parts[0])).padStart(4, '0');
125
+ return "".concat(year).concat(delimiter).concat(month).concat(delimiter).concat(day);
126
+ }
127
+ if (format === DATE_FORMATS.ISOAndTime) {
128
+ day = parts[2];
129
+ month = parts[1];
130
+ year = String(fullValidYear(parts[0])).padStart(4, '0');
131
+ return "".concat(year).concat(delimiter).concat(month).concat(delimiter).concat(day, " ").concat(time);
132
+ }
133
+ if (format === DATE_FORMATS.US) {
134
+ day = parts[1];
135
+ month = parts[0];
136
+ year = String(fullValidYear(parts[2])).padStart(4, '0');
137
+ return "".concat(Number(month)).concat(delimiter).concat(Number(day)).concat(delimiter).concat(year);
138
+ }
139
+ if (format === DATE_FORMATS.USAndTime) {
140
+ day = parts[1];
141
+ month = parts[0];
142
+ year = String(fullValidYear(parts[2])).padStart(4, '0');
143
+ return "".concat(Number(month)).concat(delimiter).concat(Number(day)).concat(delimiter).concat(year, " ").concat(time);
144
+ }
145
+ if (format === DATE_FORMATS.European || format === DATE_FORMATS.Germany_Russia_etc) {
146
+ day = parts[0];
147
+ month = parts[1];
148
+ year = String(fullValidYear(parts[2])).padStart(4, '0');
149
+ return "".concat(Number(day)).concat(delimiter).concat(Number(month)).concat(delimiter).concat(year);
150
+ }
151
+ if (format === DATE_FORMATS.EuropeanAndTime || format === DATE_FORMATS.Germany_Russia_etcAndTime) {
152
+ day = parts[0];
153
+ month = parts[1];
154
+ year = String(fullValidYear(parts[2])).padStart(4, '0');
155
+ return "".concat(Number(day)).concat(delimiter).concat(Number(month)).concat(delimiter).concat(year, " ").concat(time);
156
+ }
157
+ }
158
+ function getDay(str, localeFormat, mode) {
159
+ const format = String(localeFormat).toLowerCase();
160
+ const parts = formatDateLocal(str, format);
161
+ if (parts.length < 3) {
162
+ return '';
163
+ }
164
+ if (!mode) {
165
+ if (format === DATE_FORMATS.ISO || format === DATE_FORMATS.ISOAndTime) {
166
+ return String(parts[2]).padStart(2, '0');
167
+ }
168
+ return String(Number(parts[2]));
169
+ }
170
+ if (format === DATE_FORMATS.ISO || format === DATE_FORMATS.ISOAndTime) {
171
+ return String(parts[2]).padStart(2, '0');
172
+ }
173
+ if (format === DATE_FORMATS.US || format === DATE_FORMATS.USAndTime) {
174
+ return String(Number(parts[1]));
175
+ }
176
+ return String(Number(parts[0]));
177
+ }
178
+ function getMonth(str, localeFormat, mode) {
179
+ const format = String(localeFormat).toLowerCase();
180
+ const parts = formatDateLocal(str, format);
181
+ if (parts.length < 3) {
182
+ return '';
183
+ }
184
+ if (!mode) {
185
+ if (format === DATE_FORMATS.ISO || format === DATE_FORMATS.ISOAndTime) {
186
+ return String(Number(parts[1]) - 1).padStart(2, '0');
187
+ }
188
+ return String(Number(parts[1]) - 1);
189
+ }
190
+ if (format === DATE_FORMATS.ISO || format === DATE_FORMATS.ISOAndTime) {
191
+ return String(Number(parts[1]) - 1).padStart(2, '0');
192
+ }
193
+ if (format === DATE_FORMATS.US || format === DATE_FORMATS.USAndTime) {
194
+ return String(Number(parts[0]) - 1);
195
+ }
196
+ return String(Number(parts[1]) - 1);
197
+ }
198
+ function getYear(str, localeFormat, mode) {
199
+ const format = String(localeFormat).toLowerCase();
200
+ const parts = formatDateLocal(str, format);
201
+ if (parts.length < 3) {
202
+ return '';
203
+ }
204
+ if (!mode) {
205
+ return String(fullValidYear(parts[0])).padStart(4, '0');
206
+ }
207
+ if (format === DATE_FORMATS.ISO || format === DATE_FORMATS.ISOAndTime) {
208
+ return String(fullValidYear(parts[0])).padStart(4, '0');
209
+ }
210
+ return String(fullValidYear(parts[2])).padStart(4, '0');
211
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dtable-ui-component",
3
- "version": "6.0.38",
3
+ "version": "6.0.39-alpha42",
4
4
  "main": "./lib/index.js",
5
5
  "dependencies": {
6
6
  "@seafile/react-image-lightbox": "4.0.2",