@yelon/util 15.2.0 → 15.2.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (229) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +22 -22
  3. package/analysis/global-event.subject.d.ts +7 -0
  4. package/analysis/index.d.ts +1 -0
  5. package/array/array-type.service.d.ts +68 -68
  6. package/array/array.service.d.ts +78 -78
  7. package/array/index.d.ts +2 -2
  8. package/browser/cookie.service.d.ts +67 -67
  9. package/browser/copy.d.ts +6 -6
  10. package/browser/index.d.ts +5 -5
  11. package/browser/is-empty.d.ts +6 -6
  12. package/browser/scroll.service.d.ts +37 -37
  13. package/browser/style.d.ts +21 -21
  14. package/config/abc/date-picker.type.d.ts +52 -52
  15. package/config/abc/error-collect.type.d.ts +10 -10
  16. package/config/abc/exception.type.d.ts +9 -9
  17. package/config/abc/image.type.d.ts +15 -15
  18. package/config/abc/index.d.ts +17 -17
  19. package/config/abc/loading.type.d.ts +31 -31
  20. package/config/abc/lodop.type.d.ts +33 -33
  21. package/config/abc/media.type.d.ts +11 -11
  22. package/config/abc/onboarding.type.d.ts +4 -4
  23. package/config/abc/page-header.type.d.ts +39 -39
  24. package/config/abc/pdf.type.d.ts +35 -35
  25. package/config/abc/qr.type.d.ts +25 -25
  26. package/config/abc/se.type.d.ts +32 -32
  27. package/config/abc/sg.type.d.ts +10 -10
  28. package/config/abc/st.type.d.ts +465 -465
  29. package/config/abc/sv.type.d.ts +14 -14
  30. package/config/abc/xlsx.type.d.ts +12 -12
  31. package/config/abc/zip.type.d.ts +10 -10
  32. package/config/acl/acl.type.d.ts +32 -32
  33. package/config/auth/auth.type.d.ts +55 -55
  34. package/config/bis/bis.type.d.ts +7 -7
  35. package/config/cache/cache.type.d.ts +40 -40
  36. package/config/chart/chart.type.d.ts +33 -33
  37. package/config/config.service.d.ts +13 -13
  38. package/config/config.types.d.ts +48 -48
  39. package/config/index.d.ts +14 -14
  40. package/config/mock/mock.type.d.ts +18 -18
  41. package/config/sf/sf.type.d.ts +133 -133
  42. package/config/socket/socket.type.d.ts +4 -4
  43. package/config/theme/http.type.d.ts +14 -14
  44. package/config/theme/i18n.type.d.ts +14 -14
  45. package/config/theme/index.d.ts +3 -3
  46. package/config/theme/responsive.type.d.ts +12 -12
  47. package/config/util/array.type.d.ts +22 -22
  48. package/config/util/currency.type.d.ts +39 -39
  49. package/date-time/index.d.ts +2 -2
  50. package/date-time/picker.d.ts +68 -68
  51. package/date-time/time.d.ts +29 -29
  52. package/decorator/convert.d.ts +24 -24
  53. package/decorator/index.d.ts +2 -2
  54. package/decorator/zone-outside.d.ts +35 -35
  55. package/esm2020/analysis/analysis.mjs +5 -0
  56. package/esm2020/analysis/global-event.subject.mjs +17 -0
  57. package/esm2020/analysis/index.mjs +2 -0
  58. package/esm2020/array/array-type.service.mjs +1 -1
  59. package/esm2020/array/array.mjs +4 -4
  60. package/esm2020/array/array.service.mjs +276 -276
  61. package/esm2020/array/index.mjs +2 -2
  62. package/esm2020/browser/browser.mjs +4 -4
  63. package/esm2020/browser/cookie.service.mjs +102 -102
  64. package/esm2020/browser/copy.mjs +27 -27
  65. package/esm2020/browser/index.mjs +5 -5
  66. package/esm2020/browser/is-empty.mjs +18 -18
  67. package/esm2020/browser/scroll.service.mjs +87 -87
  68. package/esm2020/browser/style.mjs +37 -37
  69. package/esm2020/config/abc/date-picker.type.mjs +1 -1
  70. package/esm2020/config/abc/error-collect.type.mjs +1 -1
  71. package/esm2020/config/abc/exception.type.mjs +1 -1
  72. package/esm2020/config/abc/image.type.mjs +1 -1
  73. package/esm2020/config/abc/index.mjs +17 -17
  74. package/esm2020/config/abc/loading.type.mjs +1 -1
  75. package/esm2020/config/abc/lodop.type.mjs +1 -1
  76. package/esm2020/config/abc/media.type.mjs +1 -1
  77. package/esm2020/config/abc/onboarding.type.mjs +1 -1
  78. package/esm2020/config/abc/page-header.type.mjs +1 -1
  79. package/esm2020/config/abc/pdf.type.mjs +1 -1
  80. package/esm2020/config/abc/qr.type.mjs +1 -1
  81. package/esm2020/config/abc/se.type.mjs +1 -1
  82. package/esm2020/config/abc/sg.type.mjs +1 -1
  83. package/esm2020/config/abc/st.type.mjs +1 -1
  84. package/esm2020/config/abc/sv.type.mjs +2 -2
  85. package/esm2020/config/abc/xlsx.type.mjs +1 -1
  86. package/esm2020/config/abc/zip.type.mjs +1 -1
  87. package/esm2020/config/acl/acl.type.mjs +1 -1
  88. package/esm2020/config/auth/auth.type.mjs +1 -1
  89. package/esm2020/config/bis/bis.type.mjs +1 -1
  90. package/esm2020/config/cache/cache.type.mjs +1 -1
  91. package/esm2020/config/chart/chart.type.mjs +1 -1
  92. package/esm2020/config/config.mjs +4 -4
  93. package/esm2020/config/config.service.mjs +36 -36
  94. package/esm2020/config/config.types.mjs +8 -8
  95. package/esm2020/config/index.mjs +14 -14
  96. package/esm2020/config/mock/mock.type.mjs +1 -1
  97. package/esm2020/config/sf/sf.type.mjs +1 -1
  98. package/esm2020/config/socket/socket.type.mjs +1 -1
  99. package/esm2020/config/theme/http.type.mjs +1 -1
  100. package/esm2020/config/theme/i18n.type.mjs +1 -1
  101. package/esm2020/config/theme/index.mjs +3 -3
  102. package/esm2020/config/theme/responsive.type.mjs +1 -1
  103. package/esm2020/config/util/array.type.mjs +1 -1
  104. package/esm2020/config/util/currency.type.mjs +1 -1
  105. package/esm2020/date-time/date-time.mjs +4 -4
  106. package/esm2020/date-time/index.mjs +2 -2
  107. package/esm2020/date-time/picker.mjs +115 -115
  108. package/esm2020/date-time/time.mjs +88 -88
  109. package/esm2020/decorator/convert.mjs +57 -57
  110. package/esm2020/decorator/decorator.mjs +4 -4
  111. package/esm2020/decorator/index.mjs +2 -2
  112. package/esm2020/decorator/zone-outside.mjs +56 -56
  113. package/esm2020/form/form.mjs +4 -4
  114. package/esm2020/form/index.mjs +2 -2
  115. package/esm2020/form/match-control.mjs +29 -29
  116. package/esm2020/form/validators.mjs +80 -80
  117. package/esm2020/format/currency.service.mjs +237 -237
  118. package/esm2020/format/currency.types.mjs +7 -7
  119. package/esm2020/format/format.mjs +4 -4
  120. package/esm2020/format/index.mjs +4 -4
  121. package/esm2020/format/string.mjs +84 -84
  122. package/esm2020/format/validate.mjs +93 -93
  123. package/esm2020/index.mjs +13 -12
  124. package/esm2020/math/in-range.mjs +24 -24
  125. package/esm2020/math/index.mjs +2 -2
  126. package/esm2020/math/math.mjs +4 -4
  127. package/esm2020/math/round.mjs +52 -52
  128. package/esm2020/other/assert.mjs +66 -66
  129. package/esm2020/other/deep.mjs +77 -77
  130. package/esm2020/other/favicon.mjs +28 -28
  131. package/esm2020/other/index.mjs +7 -7
  132. package/esm2020/other/lazy.service.mjs +131 -131
  133. package/esm2020/other/logger.mjs +32 -32
  134. package/esm2020/other/other.mjs +4 -4
  135. package/esm2020/other/path-to-regexp.service.mjs +238 -238
  136. package/esm2020/other/resize.mjs +3 -3
  137. package/esm2020/pipes/currency/cny.pipe.mjs +22 -22
  138. package/esm2020/pipes/currency/index.mjs +4 -4
  139. package/esm2020/pipes/currency/mega.pipe.mjs +28 -28
  140. package/esm2020/pipes/currency/module.mjs +18 -18
  141. package/esm2020/pipes/currency/pipe-currency.mjs +4 -4
  142. package/esm2020/pipes/currency/price.pipe.mjs +26 -26
  143. package/esm2020/pipes/filter/filter.pipe.mjs +18 -18
  144. package/esm2020/pipes/filter/index.mjs +2 -2
  145. package/esm2020/pipes/filter/module.mjs +16 -16
  146. package/esm2020/pipes/filter/pipe-filter.mjs +4 -4
  147. package/esm2020/pipes/format/index.mjs +2 -2
  148. package/esm2020/pipes/format/mask.pipe.mjs +33 -33
  149. package/esm2020/pipes/format/module.mjs +16 -16
  150. package/esm2020/pipes/format/pipe-format.mjs +4 -4
  151. package/esm2020/pipes/index.mjs +3 -3
  152. package/esm2020/pipes/pipes.mjs +4 -4
  153. package/esm2020/token/index.mjs +2 -2
  154. package/esm2020/token/page-visibility.mjs +14 -14
  155. package/esm2020/token/token.mjs +4 -4
  156. package/esm2020/token/window.mjs +16 -16
  157. package/esm2020/yelon-util.mjs +4 -4
  158. package/fesm2015/analysis.mjs +24 -0
  159. package/fesm2015/analysis.mjs.map +1 -0
  160. package/fesm2015/array.mjs +254 -254
  161. package/fesm2015/browser.mjs +283 -283
  162. package/fesm2015/config.mjs +56 -56
  163. package/fesm2015/date-time.mjs +207 -207
  164. package/fesm2015/decorator.mjs +121 -121
  165. package/fesm2015/form.mjs +118 -118
  166. package/fesm2015/format.mjs +413 -413
  167. package/fesm2015/math.mjs +85 -85
  168. package/fesm2015/other.mjs +589 -589
  169. package/fesm2015/pipe-currency.mjs +96 -96
  170. package/fesm2015/pipe-filter.mjs +40 -40
  171. package/fesm2015/pipe-format.mjs +55 -55
  172. package/fesm2015/pipes.mjs +8 -8
  173. package/fesm2015/token.mjs +37 -37
  174. package/fesm2015/yelon-util.mjs +17 -16
  175. package/fesm2015/yelon-util.mjs.map +1 -1
  176. package/fesm2020/analysis.mjs +24 -0
  177. package/fesm2020/analysis.mjs.map +1 -0
  178. package/fesm2020/array.mjs +284 -284
  179. package/fesm2020/browser.mjs +279 -279
  180. package/fesm2020/config.mjs +54 -54
  181. package/fesm2020/date-time.mjs +211 -211
  182. package/fesm2020/decorator.mjs +121 -121
  183. package/fesm2020/form.mjs +118 -118
  184. package/fesm2020/format.mjs +431 -431
  185. package/fesm2020/math.mjs +85 -85
  186. package/fesm2020/other.mjs +586 -586
  187. package/fesm2020/pipe-currency.mjs +94 -94
  188. package/fesm2020/pipe-filter.mjs +40 -40
  189. package/fesm2020/pipe-format.mjs +55 -55
  190. package/fesm2020/pipes.mjs +8 -8
  191. package/fesm2020/token.mjs +37 -37
  192. package/fesm2020/yelon-util.mjs +17 -16
  193. package/fesm2020/yelon-util.mjs.map +1 -1
  194. package/form/index.d.ts +2 -2
  195. package/form/match-control.d.ts +15 -15
  196. package/form/validators.d.ts +62 -62
  197. package/format/currency.service.d.ts +37 -37
  198. package/format/currency.types.d.ts +77 -77
  199. package/format/index.d.ts +4 -4
  200. package/format/string.d.ts +44 -44
  201. package/format/validate.d.ts +72 -72
  202. package/index.d.ts +12 -11
  203. package/math/in-range.d.ts +14 -14
  204. package/math/index.d.ts +2 -2
  205. package/math/round.d.ts +33 -33
  206. package/other/assert.d.ts +36 -36
  207. package/other/deep.d.ts +35 -35
  208. package/other/favicon.d.ts +2 -2
  209. package/other/index.d.ts +7 -7
  210. package/other/lazy.service.d.ts +48 -48
  211. package/other/logger.d.ts +5 -5
  212. package/other/path-to-regexp.service.d.ts +26 -26
  213. package/other/resize.d.ts +1 -1
  214. package/package.json +165 -157
  215. package/pipes/currency/cny.pipe.d.ts +15 -15
  216. package/pipes/currency/index.d.ts +4 -4
  217. package/pipes/currency/mega.pipe.d.ts +16 -16
  218. package/pipes/currency/module.d.ts +9 -9
  219. package/pipes/currency/price.pipe.d.ts +19 -19
  220. package/pipes/filter/filter.pipe.d.ts +13 -13
  221. package/pipes/filter/index.d.ts +2 -2
  222. package/pipes/filter/module.d.ts +7 -7
  223. package/pipes/format/index.d.ts +2 -2
  224. package/pipes/format/mask.pipe.d.ts +27 -27
  225. package/pipes/format/module.d.ts +7 -7
  226. package/pipes/index.d.ts +3 -3
  227. package/token/index.d.ts +2 -2
  228. package/token/page-visibility.d.ts +8 -8
  229. package/token/window.d.ts +7 -7
@@ -1,211 +1,211 @@
1
- import { parse, addDays, startOfYear, subYears, endOfYear, startOfMonth, subMonths, endOfMonth, startOfWeek, subWeeks, endOfWeek, startOfDay, endOfDay, parseISO, format, differenceInCalendarDays, addSeconds } from 'date-fns';
2
-
3
- /**
4
- * Get the time range, return `[ Date, Date]` for the start and end dates
5
- *
6
- * 获取时间范围
7
- *
8
- * @param type 类型,带 `-` 表示过去一个时间,若指定 `number` 表示天数
9
- * @param time 开始时间
10
- * @param ignoreMaxTime 忽略追加结束日期的最大时间值
11
- */
12
- function getTimeDistance(type, time, options) {
13
- time = time
14
- ? typeof time === 'string'
15
- ? parse(time, 'yyyy-MM-dd HH:mm:ss', new Date())
16
- : new Date(time)
17
- : new Date();
18
- const opt = { weekStartsOn: 1 };
19
- let res;
20
- switch (type) {
21
- case 'today':
22
- res = [time, time];
23
- break;
24
- case '-today':
25
- res = [addDays(time, -1), time];
26
- break;
27
- case 'yesterday':
28
- res = [addDays(time, -1), addDays(time, -1)];
29
- break;
30
- case 'week':
31
- res = [startOfWeek(time, opt), endOfWeek(time, opt)];
32
- break;
33
- case '-week':
34
- res = [startOfWeek(subWeeks(time, 1), opt), endOfWeek(subWeeks(time, 1), opt)];
35
- break;
36
- case 'month':
37
- res = [startOfMonth(time), endOfMonth(time)];
38
- break;
39
- case '-month':
40
- res = [startOfMonth(subMonths(time, 1)), endOfMonth(subMonths(time, 1))];
41
- break;
42
- case 'year':
43
- res = [startOfYear(time), endOfYear(time)];
44
- break;
45
- case '-year':
46
- res = [startOfYear(subYears(time, 1)), endOfYear(subYears(time, 1))];
47
- break;
48
- default:
49
- res = type > 0 ? [time, addDays(time, type)] : [addDays(time, type), time];
50
- break;
51
- }
52
- return options?.ignoreMaxTime ? res : fixEndTimeOfRange(res);
53
- }
54
- /**
55
- * fix time is the most, big value
56
- */
57
- function fixEndTimeOfRange(dates) {
58
- return [startOfDay(dates[0]), endOfDay(dates[1])];
59
- }
60
- /**
61
- * Return the date parsed from string using the given format string
62
- * - If the argument is a number, it is treated as a timestamp.
63
- *
64
- * @param formatString If parsing fails try to parse the date by pressing `formatString`
65
- * @param defaultValue If parsing fails returned default value, default: `new Date(NaN)`
66
- */
67
- function toDate(value, options) {
68
- if (typeof options === 'string')
69
- options = { formatString: options };
70
- const { formatString, defaultValue } = {
71
- formatString: 'yyyy-MM-dd HH:mm:ss',
72
- defaultValue: new Date(NaN),
73
- ...options
74
- };
75
- if (value == null) {
76
- return defaultValue;
77
- }
78
- if (value instanceof Date) {
79
- return value;
80
- }
81
- if (typeof value === 'number' || (typeof value === 'string' && /[0-9]{10,13}/.test(value))) {
82
- return new Date(+value);
83
- }
84
- let tryDate = parseISO(value);
85
- if (isNaN(tryDate)) {
86
- tryDate = parse(value, formatString, new Date());
87
- }
88
- return isNaN(tryDate) ? defaultValue : tryDate;
89
- }
90
-
91
- // TODO: timezone process
92
- class DateTimePickerUtil {
93
- /**
94
- * Current local time
95
- *
96
- * 当前本地时间
97
- */
98
- get now() {
99
- return new Date();
100
- }
101
- /**
102
- * Current local date (not including time part)
103
- *
104
- * 当前本地日期(不包含时间部分)
105
- */
106
- get date() {
107
- return this.removeTime(this.now);
108
- }
109
- /**
110
- * Remove the time part of the date
111
- *
112
- * 移除日期的时间部分
113
- */
114
- removeTime(d) {
115
- return new Date(d.toDateString());
116
- }
117
- /**
118
- * Format date-time
119
- *
120
- * 格式化日期
121
- */
122
- format(d, formatString = 'yyyy-MM-dd HH:mm:ss') {
123
- return format(d, formatString);
124
- }
125
- genTick(count) {
126
- return new Array(count).fill(0).map((_, idx) => idx);
127
- }
128
- /**
129
- * Calculate the number of days between two dates, `0` means the same day
130
- *
131
- * 计算两个日期相差天数,`0` 表示同一天
132
- */
133
- getDiffDays(dateLeft, dateRight) {
134
- return differenceInCalendarDays(dateLeft, typeof dateRight === 'number' ? addDays(this.date, dateRight) : dateRight || this.date);
135
- }
136
- /**
137
- * Disabled Before date (Default: today), Generally serves `nzDisabledDate`
138
- *
139
- * 禁用之前日期(默认:今天),一般服务于 `nzDisabledDate`
140
- */
141
- disabledBeforeDate(options) {
142
- return (d) => this.getDiffDays(d, options?.offsetDays) < 0;
143
- }
144
- /**
145
- * Disabled After date (Default: today), Generally serves `nzDisabledDate`
146
- *
147
- * 禁用之后日期(默认:今天),一般服务于 `nzDisabledDate`
148
- */
149
- disabledAfterDate(options) {
150
- return (d) => this.getDiffDays(d, options?.offsetDays) > 0;
151
- }
152
- baseDisabledTime(type, offsetSeconds) {
153
- const tick24 = this.genTick(24);
154
- const tick60 = this.genTick(60);
155
- return (current) => {
156
- const cur = current;
157
- if (cur == null) {
158
- return {};
159
- }
160
- const now = addSeconds(this.now, offsetSeconds || 0);
161
- const nowHours = now.getHours();
162
- const nowMinutes = now.getMinutes();
163
- const curHours = cur.getHours();
164
- const isToday = this.getDiffDays(this.removeTime(cur)) === 0;
165
- return {
166
- nzDisabledHours: () => {
167
- if (!isToday)
168
- return [];
169
- return type === 'before' ? tick24.slice(0, nowHours) : tick24.slice(nowHours + 1);
170
- },
171
- nzDisabledMinutes: () => {
172
- if (isToday && curHours === nowHours) {
173
- return type === 'before' ? tick60.slice(0, nowMinutes) : tick60.slice(nowMinutes + 1);
174
- }
175
- return [];
176
- },
177
- nzDisabledSeconds: () => {
178
- if (isToday && curHours === nowHours && cur.getMinutes() === nowMinutes) {
179
- const nowSeconds = now.getSeconds();
180
- return type === 'before' ? tick60.slice(0, nowSeconds) : tick60.slice(nowSeconds + 1);
181
- }
182
- return [];
183
- }
184
- };
185
- };
186
- }
187
- /**
188
- * Disabled Before time (Default: now), Generally serves `nzDisabledTime`
189
- *
190
- * 禁用之前时间(默认:现在),一般服务于 `nzDisabledTime`
191
- */
192
- disabledBeforeTime(options) {
193
- return this.baseDisabledTime('before', options?.offsetSeconds);
194
- }
195
- /**
196
- * Disabled After time (Default: now), Generally serves `nzDisabledTime`
197
- *
198
- * 禁用之后时间(默认:现在),一般服务于 `nzDisabledTime`
199
- */
200
- disabledAfterTime(options) {
201
- return this.baseDisabledTime('after', options?.offsetSeconds);
202
- }
203
- }
204
- const dateTimePickerUtil = new DateTimePickerUtil();
205
-
206
- /**
207
- * Generated bundle index. Do not edit.
208
- */
209
-
210
- export { DateTimePickerUtil, dateTimePickerUtil, fixEndTimeOfRange, getTimeDistance, toDate };
211
- //# sourceMappingURL=date-time.mjs.map
1
+ import { parse, addDays, startOfYear, subYears, endOfYear, startOfMonth, subMonths, endOfMonth, startOfWeek, subWeeks, endOfWeek, startOfDay, endOfDay, parseISO, format, differenceInCalendarDays, addSeconds } from 'date-fns';
2
+
3
+ /**
4
+ * Get the time range, return `[ Date, Date]` for the start and end dates
5
+ *
6
+ * 获取时间范围
7
+ *
8
+ * @param type 类型,带 `-` 表示过去一个时间,若指定 `number` 表示天数
9
+ * @param time 开始时间
10
+ * @param ignoreMaxTime 忽略追加结束日期的最大时间值
11
+ */
12
+ function getTimeDistance(type, time, options) {
13
+ time = time
14
+ ? typeof time === 'string'
15
+ ? parse(time, 'yyyy-MM-dd HH:mm:ss', new Date())
16
+ : new Date(time)
17
+ : new Date();
18
+ const opt = { weekStartsOn: 1 };
19
+ let res;
20
+ switch (type) {
21
+ case 'today':
22
+ res = [time, time];
23
+ break;
24
+ case '-today':
25
+ res = [addDays(time, -1), time];
26
+ break;
27
+ case 'yesterday':
28
+ res = [addDays(time, -1), addDays(time, -1)];
29
+ break;
30
+ case 'week':
31
+ res = [startOfWeek(time, opt), endOfWeek(time, opt)];
32
+ break;
33
+ case '-week':
34
+ res = [startOfWeek(subWeeks(time, 1), opt), endOfWeek(subWeeks(time, 1), opt)];
35
+ break;
36
+ case 'month':
37
+ res = [startOfMonth(time), endOfMonth(time)];
38
+ break;
39
+ case '-month':
40
+ res = [startOfMonth(subMonths(time, 1)), endOfMonth(subMonths(time, 1))];
41
+ break;
42
+ case 'year':
43
+ res = [startOfYear(time), endOfYear(time)];
44
+ break;
45
+ case '-year':
46
+ res = [startOfYear(subYears(time, 1)), endOfYear(subYears(time, 1))];
47
+ break;
48
+ default:
49
+ res = type > 0 ? [time, addDays(time, type)] : [addDays(time, type), time];
50
+ break;
51
+ }
52
+ return options?.ignoreMaxTime ? res : fixEndTimeOfRange(res);
53
+ }
54
+ /**
55
+ * fix time is the most, big value
56
+ */
57
+ function fixEndTimeOfRange(dates) {
58
+ return [startOfDay(dates[0]), endOfDay(dates[1])];
59
+ }
60
+ /**
61
+ * Return the date parsed from string using the given format string
62
+ * - If the argument is a number, it is treated as a timestamp.
63
+ *
64
+ * @param formatString If parsing fails try to parse the date by pressing `formatString`
65
+ * @param defaultValue If parsing fails returned default value, default: `new Date(NaN)`
66
+ */
67
+ function toDate(value, options) {
68
+ if (typeof options === 'string')
69
+ options = { formatString: options };
70
+ const { formatString, defaultValue } = {
71
+ formatString: 'yyyy-MM-dd HH:mm:ss',
72
+ defaultValue: new Date(NaN),
73
+ ...options
74
+ };
75
+ if (value == null) {
76
+ return defaultValue;
77
+ }
78
+ if (value instanceof Date) {
79
+ return value;
80
+ }
81
+ if (typeof value === 'number' || (typeof value === 'string' && /[0-9]{10,13}/.test(value))) {
82
+ return new Date(+value);
83
+ }
84
+ let tryDate = parseISO(value);
85
+ if (isNaN(tryDate)) {
86
+ tryDate = parse(value, formatString, new Date());
87
+ }
88
+ return isNaN(tryDate) ? defaultValue : tryDate;
89
+ }
90
+
91
+ // TODO: timezone process
92
+ class DateTimePickerUtil {
93
+ /**
94
+ * Current local time
95
+ *
96
+ * 当前本地时间
97
+ */
98
+ get now() {
99
+ return new Date();
100
+ }
101
+ /**
102
+ * Current local date (not including time part)
103
+ *
104
+ * 当前本地日期(不包含时间部分)
105
+ */
106
+ get date() {
107
+ return this.removeTime(this.now);
108
+ }
109
+ /**
110
+ * Remove the time part of the date
111
+ *
112
+ * 移除日期的时间部分
113
+ */
114
+ removeTime(d) {
115
+ return new Date(d.toDateString());
116
+ }
117
+ /**
118
+ * Format date-time
119
+ *
120
+ * 格式化日期
121
+ */
122
+ format(d, formatString = 'yyyy-MM-dd HH:mm:ss') {
123
+ return format(d, formatString);
124
+ }
125
+ genTick(count) {
126
+ return new Array(count).fill(0).map((_, idx) => idx);
127
+ }
128
+ /**
129
+ * Calculate the number of days between two dates, `0` means the same day
130
+ *
131
+ * 计算两个日期相差天数,`0` 表示同一天
132
+ */
133
+ getDiffDays(dateLeft, dateRight) {
134
+ return differenceInCalendarDays(dateLeft, typeof dateRight === 'number' ? addDays(this.date, dateRight) : dateRight || this.date);
135
+ }
136
+ /**
137
+ * Disabled Before date (Default: today), Generally serves `nzDisabledDate`
138
+ *
139
+ * 禁用之前日期(默认:今天),一般服务于 `nzDisabledDate`
140
+ */
141
+ disabledBeforeDate(options) {
142
+ return (d) => this.getDiffDays(d, options?.offsetDays) < 0;
143
+ }
144
+ /**
145
+ * Disabled After date (Default: today), Generally serves `nzDisabledDate`
146
+ *
147
+ * 禁用之后日期(默认:今天),一般服务于 `nzDisabledDate`
148
+ */
149
+ disabledAfterDate(options) {
150
+ return (d) => this.getDiffDays(d, options?.offsetDays) > 0;
151
+ }
152
+ baseDisabledTime(type, offsetSeconds) {
153
+ const tick24 = this.genTick(24);
154
+ const tick60 = this.genTick(60);
155
+ return (current) => {
156
+ const cur = current;
157
+ if (cur == null) {
158
+ return {};
159
+ }
160
+ const now = addSeconds(this.now, offsetSeconds || 0);
161
+ const nowHours = now.getHours();
162
+ const nowMinutes = now.getMinutes();
163
+ const curHours = cur.getHours();
164
+ const isToday = this.getDiffDays(this.removeTime(cur)) === 0;
165
+ return {
166
+ nzDisabledHours: () => {
167
+ if (!isToday)
168
+ return [];
169
+ return type === 'before' ? tick24.slice(0, nowHours) : tick24.slice(nowHours + 1);
170
+ },
171
+ nzDisabledMinutes: () => {
172
+ if (isToday && curHours === nowHours) {
173
+ return type === 'before' ? tick60.slice(0, nowMinutes) : tick60.slice(nowMinutes + 1);
174
+ }
175
+ return [];
176
+ },
177
+ nzDisabledSeconds: () => {
178
+ if (isToday && curHours === nowHours && cur.getMinutes() === nowMinutes) {
179
+ const nowSeconds = now.getSeconds();
180
+ return type === 'before' ? tick60.slice(0, nowSeconds) : tick60.slice(nowSeconds + 1);
181
+ }
182
+ return [];
183
+ }
184
+ };
185
+ };
186
+ }
187
+ /**
188
+ * Disabled Before time (Default: now), Generally serves `nzDisabledTime`
189
+ *
190
+ * 禁用之前时间(默认:现在),一般服务于 `nzDisabledTime`
191
+ */
192
+ disabledBeforeTime(options) {
193
+ return this.baseDisabledTime('before', options?.offsetSeconds);
194
+ }
195
+ /**
196
+ * Disabled After time (Default: now), Generally serves `nzDisabledTime`
197
+ *
198
+ * 禁用之后时间(默认:现在),一般服务于 `nzDisabledTime`
199
+ */
200
+ disabledAfterTime(options) {
201
+ return this.baseDisabledTime('after', options?.offsetSeconds);
202
+ }
203
+ }
204
+ const dateTimePickerUtil = new DateTimePickerUtil();
205
+
206
+ /**
207
+ * Generated bundle index. Do not edit.
208
+ */
209
+
210
+ export { DateTimePickerUtil, dateTimePickerUtil, fixEndTimeOfRange, getTimeDistance, toDate };
211
+ //# sourceMappingURL=date-time.mjs.map
@@ -1,121 +1,121 @@
1
- import { warn } from '@yelon/util/other';
2
-
3
- function propDecoratorFactory(name, fallback, defaultValue) {
4
- function propDecorator(target, propName, originalDescriptor) {
5
- const privatePropName = `$$__${propName}`;
6
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
7
- if (Object.prototype.hasOwnProperty.call(target, privatePropName)) {
8
- warn(`The prop "${privatePropName}" is already exist, it will be overrided by ${name} decorator.`);
9
- }
10
- }
11
- Object.defineProperty(target, privatePropName, {
12
- configurable: true,
13
- writable: true
14
- });
15
- return {
16
- get() {
17
- return originalDescriptor && originalDescriptor.get
18
- ? originalDescriptor.get.bind(this)()
19
- : this[privatePropName];
20
- },
21
- set(value) {
22
- if (originalDescriptor && originalDescriptor.set) {
23
- originalDescriptor.set.bind(this)(fallback(value, defaultValue));
24
- }
25
- this[privatePropName] = fallback(value, defaultValue);
26
- }
27
- };
28
- }
29
- return propDecorator;
30
- }
31
- function toBoolean(value, defaultValue = false) {
32
- return value == null ? defaultValue : `${value}` !== 'false';
33
- }
34
- /**
35
- * Input decorator that handle a prop to do get/set automatically with toBoolean
36
- *
37
- * ```ts
38
- * {AT}Input() {AT}InputBoolean() visible: boolean = false;
39
- * {AT}Input() {AT}InputBoolean(null) visible: boolean = false;
40
- * ```
41
- */
42
- function InputBoolean(defaultValue = false) {
43
- return propDecoratorFactory('InputBoolean', toBoolean, defaultValue);
44
- }
45
- function toNumber(value, fallbackValue = 0) {
46
- return !isNaN(parseFloat(value)) && !isNaN(Number(value)) ? Number(value) : fallbackValue;
47
- }
48
- /**
49
- * Input decorator that handle a prop to do get/set automatically with toNumber
50
- *
51
- * ```ts
52
- * {AT}Input() {AT}InputNumber() visible: number = 1;
53
- * {AT}Input() {AT}InputNumber(null) visible: number = 2;
54
- * ```
55
- */
56
- function InputNumber(defaultValue = 0) {
57
- return propDecoratorFactory('InputNumber', toNumber, defaultValue);
58
- }
59
-
60
- function makeFn(type, options) {
61
- return (_, __, descriptor) => {
62
- const source = descriptor.value;
63
- descriptor.value = function (...data) {
64
- const that = this;
65
- const ngZone = that[options?.ngZoneName || 'ngZone'];
66
- if (!ngZone) {
67
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
68
- warn(`ZoneOutside: Decorator should have 'ngZone' property with 'NgZone' class.`);
69
- }
70
- return source.call(this, ...data);
71
- }
72
- let res;
73
- ngZone[type](() => {
74
- res = source.call(this, ...data);
75
- });
76
- return res;
77
- };
78
- return descriptor;
79
- };
80
- }
81
- /**
82
- * The decoration method runs in `runOutsideAngular`
83
- *
84
- * 装饰方法运行在 `runOutsideAngular` 内
85
- *
86
- * ```ts
87
- * class MockClass {
88
- * constructor(public ngZone: NgZone) {}
89
- *
90
- * {AT}ZoneOutside()
91
- * runOutsideAngular(): void {}
92
- * }
93
- * ```
94
- */
95
- function ZoneOutside(options) {
96
- return makeFn('runOutsideAngular', options);
97
- }
98
- /**
99
- * The decoration method runs in `run`
100
- *
101
- * 装饰方法运行在 `run` 内
102
- *
103
- * ```ts
104
- * class MockClass {
105
- * constructor(public ngZone: NgZone) {}
106
- *
107
- * {AT}ZoneRun()
108
- * run(): void {}
109
- * }
110
- * ```
111
- */
112
- function ZoneRun(options) {
113
- return makeFn('run', options);
114
- }
115
-
116
- /**
117
- * Generated bundle index. Do not edit.
118
- */
119
-
120
- export { InputBoolean, InputNumber, ZoneOutside, ZoneRun, toBoolean, toNumber };
121
- //# sourceMappingURL=decorator.mjs.map
1
+ import { warn } from '@yelon/util/other';
2
+
3
+ function propDecoratorFactory(name, fallback, defaultValue) {
4
+ function propDecorator(target, propName, originalDescriptor) {
5
+ const privatePropName = `$$__${propName}`;
6
+ if (typeof ngDevMode === 'undefined' || ngDevMode) {
7
+ if (Object.prototype.hasOwnProperty.call(target, privatePropName)) {
8
+ warn(`The prop "${privatePropName}" is already exist, it will be overrided by ${name} decorator.`);
9
+ }
10
+ }
11
+ Object.defineProperty(target, privatePropName, {
12
+ configurable: true,
13
+ writable: true
14
+ });
15
+ return {
16
+ get() {
17
+ return originalDescriptor && originalDescriptor.get
18
+ ? originalDescriptor.get.bind(this)()
19
+ : this[privatePropName];
20
+ },
21
+ set(value) {
22
+ if (originalDescriptor && originalDescriptor.set) {
23
+ originalDescriptor.set.bind(this)(fallback(value, defaultValue));
24
+ }
25
+ this[privatePropName] = fallback(value, defaultValue);
26
+ }
27
+ };
28
+ }
29
+ return propDecorator;
30
+ }
31
+ function toBoolean(value, defaultValue = false) {
32
+ return value == null ? defaultValue : `${value}` !== 'false';
33
+ }
34
+ /**
35
+ * Input decorator that handle a prop to do get/set automatically with toBoolean
36
+ *
37
+ * ```ts
38
+ * {AT}Input() {AT}InputBoolean() visible: boolean = false;
39
+ * {AT}Input() {AT}InputBoolean(null) visible: boolean = false;
40
+ * ```
41
+ */
42
+ function InputBoolean(defaultValue = false) {
43
+ return propDecoratorFactory('InputBoolean', toBoolean, defaultValue);
44
+ }
45
+ function toNumber(value, fallbackValue = 0) {
46
+ return !isNaN(parseFloat(value)) && !isNaN(Number(value)) ? Number(value) : fallbackValue;
47
+ }
48
+ /**
49
+ * Input decorator that handle a prop to do get/set automatically with toNumber
50
+ *
51
+ * ```ts
52
+ * {AT}Input() {AT}InputNumber() visible: number = 1;
53
+ * {AT}Input() {AT}InputNumber(null) visible: number = 2;
54
+ * ```
55
+ */
56
+ function InputNumber(defaultValue = 0) {
57
+ return propDecoratorFactory('InputNumber', toNumber, defaultValue);
58
+ }
59
+
60
+ function makeFn(type, options) {
61
+ return (_, __, descriptor) => {
62
+ const source = descriptor.value;
63
+ descriptor.value = function (...data) {
64
+ const that = this;
65
+ const ngZone = that[options?.ngZoneName || 'ngZone'];
66
+ if (!ngZone) {
67
+ if (typeof ngDevMode === 'undefined' || ngDevMode) {
68
+ warn(`ZoneOutside: Decorator should have 'ngZone' property with 'NgZone' class.`);
69
+ }
70
+ return source.call(this, ...data);
71
+ }
72
+ let res;
73
+ ngZone[type](() => {
74
+ res = source.call(this, ...data);
75
+ });
76
+ return res;
77
+ };
78
+ return descriptor;
79
+ };
80
+ }
81
+ /**
82
+ * The decoration method runs in `runOutsideAngular`
83
+ *
84
+ * 装饰方法运行在 `runOutsideAngular` 内
85
+ *
86
+ * ```ts
87
+ * class MockClass {
88
+ * constructor(public ngZone: NgZone) {}
89
+ *
90
+ * {AT}ZoneOutside()
91
+ * runOutsideAngular(): void {}
92
+ * }
93
+ * ```
94
+ */
95
+ function ZoneOutside(options) {
96
+ return makeFn('runOutsideAngular', options);
97
+ }
98
+ /**
99
+ * The decoration method runs in `run`
100
+ *
101
+ * 装饰方法运行在 `run` 内
102
+ *
103
+ * ```ts
104
+ * class MockClass {
105
+ * constructor(public ngZone: NgZone) {}
106
+ *
107
+ * {AT}ZoneRun()
108
+ * run(): void {}
109
+ * }
110
+ * ```
111
+ */
112
+ function ZoneRun(options) {
113
+ return makeFn('run', options);
114
+ }
115
+
116
+ /**
117
+ * Generated bundle index. Do not edit.
118
+ */
119
+
120
+ export { InputBoolean, InputNumber, ZoneOutside, ZoneRun, toBoolean, toNumber };
121
+ //# sourceMappingURL=decorator.mjs.map