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.
- package/lib/DateEditor/mb-editor/index.js +2 -1
- package/lib/DateEditor/pc-editor.js +2 -1
- package/lib/DateFormatter/index.js +2 -2
- package/lib/GeolocationEditor/mb-editor/map-editor/index.js +3 -0
- package/lib/InputItem/custom-input.js +3 -1
- package/lib/utils/dateFormat.js +211 -0
- package/package.json +1 -1
|
@@ -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:
|
|
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:
|
|
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
|
|
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,
|
|
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,
|
|
@@ -262,7 +262,9 @@ class NumberInput extends React.Component {
|
|
|
262
262
|
getContainer: () => this.getContainer()
|
|
263
263
|
}, this.getComponent());
|
|
264
264
|
} else {
|
|
265
|
-
|
|
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
|
+
}
|