@yelon/util 15.2.0 → 15.2.2

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 (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