@acorex/core 7.22.0 → 7.23.0

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 (140) hide show
  1. package/{dateTime → date-time}/README.md +2 -2
  2. package/{dateTime → date-time}/lib/datetime.class.d.ts +1 -0
  3. package/{dateTime → date-time}/lib/formatters/datetime-formatter.d.ts +1 -1
  4. package/{dateTime → date-time}/lib/formatters/timeleft-formatter.d.ts +1 -1
  5. package/esm2022/acorex-core.mjs +1 -1
  6. package/esm2022/config/lib/configs.mjs +1 -1
  7. package/esm2022/config/lib/configs.service.mjs +3 -3
  8. package/esm2022/date-time/acorex-core-date-time.mjs +5 -0
  9. package/esm2022/date-time/index.mjs +11 -0
  10. package/esm2022/date-time/lib/calendar.service.mjs +100 -0
  11. package/esm2022/date-time/lib/dateTime.config.mjs +50 -0
  12. package/esm2022/date-time/lib/datetime.class.mjs +337 -0
  13. package/esm2022/date-time/lib/datetime.module.mjs +27 -0
  14. package/esm2022/date-time/lib/datetime.pipe.mjs +29 -0
  15. package/esm2022/date-time/lib/formatters/datetime-formatter.mjs +32 -0
  16. package/esm2022/date-time/lib/formatters/timeleft-formatter.mjs +91 -0
  17. package/esm2022/date-time/lib/georgian.calendar.mjs +203 -0
  18. package/esm2022/date-time/lib/holidays.loader.mjs +13 -0
  19. package/esm2022/date-time/lib/jalali.calendar.mjs +440 -0
  20. package/esm2022/events/lib/event.service.mjs +4 -4
  21. package/esm2022/events/lib/event.type.mjs +1 -1
  22. package/esm2022/file/lib/file-download-ref.class.mjs +1 -1
  23. package/esm2022/file/lib/file-size-formatter.mjs +4 -4
  24. package/esm2022/file/lib/file-upload-ref.class.mjs +1 -1
  25. package/esm2022/file/lib/file.module.mjs +6 -6
  26. package/esm2022/file/lib/file.service.mjs +5 -5
  27. package/esm2022/format/lib/format.config.mjs +1 -1
  28. package/esm2022/format/lib/format.module.mjs +13 -16
  29. package/esm2022/format/lib/format.pipe.mjs +10 -6
  30. package/esm2022/format/lib/format.service.mjs +19 -16
  31. package/esm2022/format/lib/format.types.mjs +1 -1
  32. package/esm2022/format/lib/formatters/number-formatter.mjs +6 -7
  33. package/esm2022/format/lib/formatters/string-formatter.mjs +1 -1
  34. package/esm2022/image/lib/image.service.mjs +4 -4
  35. package/esm2022/index.mjs +2 -2
  36. package/esm2022/lib/core.component.mjs +12 -0
  37. package/esm2022/memorize/lib/memorize.decorator.mjs +1 -1
  38. package/esm2022/pipes/lib/safe/safe.pipe.mjs +4 -4
  39. package/esm2022/platform/lib/platform.service.mjs +47 -42
  40. package/esm2022/storage/cookie-storage.service.mjs +15 -8
  41. package/esm2022/storage/local-storage.service.mjs +46 -10
  42. package/esm2022/storage/session-storage.service.mjs +3 -3
  43. package/esm2022/translation/lib/translation-scope.resolver.mjs +4 -4
  44. package/esm2022/translation/lib/translation.config.mjs +2 -2
  45. package/esm2022/translation/lib/translation.loader.mjs +3 -3
  46. package/esm2022/translation/lib/translation.module.mjs +10 -10
  47. package/esm2022/translation/lib/translation.service.mjs +19 -11
  48. package/esm2022/translation/lib/translation.types.mjs +1 -1
  49. package/esm2022/translation/lib/translator.directive.mjs +5 -5
  50. package/esm2022/translation/lib/translator.pipe.mjs +4 -4
  51. package/esm2022/utils/lib/auto-unsubscribe.mjs +4 -4
  52. package/esm2022/utils/lib/color-util.mjs +4 -2
  53. package/esm2022/utils/lib/drawing-util.mjs +6 -3
  54. package/esm2022/utils/lib/html-util.mjs +17 -3
  55. package/esm2022/utils/lib/string-util.mjs +1 -1
  56. package/esm2022/validation/lib/rules/between-rule.mjs +7 -7
  57. package/esm2022/validation/lib/rules/callback-rule.mjs +10 -7
  58. package/esm2022/validation/lib/rules/equal-rule.mjs +7 -7
  59. package/esm2022/validation/lib/rules/greater-than.mjs +12 -8
  60. package/esm2022/validation/lib/rules/length-rule.mjs +10 -7
  61. package/esm2022/validation/lib/rules/less-than-rule.mjs +12 -8
  62. package/esm2022/validation/lib/rules/maxlength-rule.mjs +12 -9
  63. package/esm2022/validation/lib/rules/minlength-rule.mjs +12 -9
  64. package/esm2022/validation/lib/rules/regex-rule.mjs +15 -12
  65. package/esm2022/validation/lib/rules/required-rule.mjs +14 -14
  66. package/esm2022/validation/lib/validation.config.mjs +3 -3
  67. package/esm2022/validation/lib/validation.module.mjs +15 -19
  68. package/esm2022/validation/lib/validation.service.mjs +19 -16
  69. package/esm2022/validation/lib/validation.types.mjs +1 -1
  70. package/fesm2022/acorex-core-config.mjs +3 -3
  71. package/fesm2022/acorex-core-config.mjs.map +1 -1
  72. package/fesm2022/{acorex-core-dateTime.mjs → acorex-core-date-time.mjs} +96 -45
  73. package/fesm2022/acorex-core-date-time.mjs.map +1 -0
  74. package/fesm2022/acorex-core-events.mjs +3 -3
  75. package/fesm2022/acorex-core-events.mjs.map +1 -1
  76. package/fesm2022/acorex-core-file.mjs +12 -12
  77. package/fesm2022/acorex-core-file.mjs.map +1 -1
  78. package/fesm2022/acorex-core-format.mjs +43 -40
  79. package/fesm2022/acorex-core-format.mjs.map +1 -1
  80. package/fesm2022/acorex-core-image.mjs +3 -3
  81. package/fesm2022/acorex-core-image.mjs.map +1 -1
  82. package/fesm2022/acorex-core-memorize.mjs.map +1 -1
  83. package/fesm2022/acorex-core-pipes.mjs +3 -3
  84. package/fesm2022/acorex-core-pipes.mjs.map +1 -1
  85. package/fesm2022/acorex-core-platform.mjs +46 -41
  86. package/fesm2022/acorex-core-platform.mjs.map +1 -1
  87. package/fesm2022/acorex-core-storage.mjs +63 -20
  88. package/fesm2022/acorex-core-storage.mjs.map +1 -1
  89. package/fesm2022/acorex-core-translation.mjs +31 -23
  90. package/fesm2022/acorex-core-translation.mjs.map +1 -1
  91. package/fesm2022/acorex-core-utils.mjs +27 -8
  92. package/fesm2022/acorex-core-utils.mjs.map +1 -1
  93. package/fesm2022/acorex-core-validation.mjs +110 -88
  94. package/fesm2022/acorex-core-validation.mjs.map +1 -1
  95. package/fesm2022/acorex-core.mjs +14 -1
  96. package/fesm2022/acorex-core.mjs.map +1 -1
  97. package/file/lib/file-size-formatter.d.ts +1 -1
  98. package/format/lib/format.config.d.ts +1 -1
  99. package/format/lib/format.service.d.ts +5 -5
  100. package/format/lib/formatters/number-formatter.d.ts +1 -1
  101. package/format/lib/formatters/string-formatter.d.ts +1 -1
  102. package/index.d.ts +1 -2
  103. package/lib/core.component.d.ts +5 -0
  104. package/package.json +15 -15
  105. package/storage/local-storage.service.d.ts +6 -0
  106. package/translation/lib/translation-scope.resolver.d.ts +1 -1
  107. package/translation/lib/translation.config.d.ts +2 -2
  108. package/translation/lib/translation.loader.d.ts +3 -3
  109. package/validation/lib/rules/between-rule.d.ts +2 -2
  110. package/validation/lib/rules/callback-rule.d.ts +2 -2
  111. package/validation/lib/rules/equal-rule.d.ts +2 -2
  112. package/validation/lib/rules/greater-than.d.ts +2 -2
  113. package/validation/lib/rules/length-rule.d.ts +2 -2
  114. package/validation/lib/rules/less-than-rule.d.ts +2 -2
  115. package/validation/lib/rules/maxlength-rule.d.ts +2 -2
  116. package/validation/lib/rules/minlength-rule.d.ts +2 -2
  117. package/validation/lib/rules/regex-rule.d.ts +2 -2
  118. package/validation/lib/rules/required-rule.d.ts +2 -2
  119. package/validation/lib/validation.service.d.ts +4 -4
  120. package/esm2022/dateTime/acorex-core-dateTime.mjs +0 -5
  121. package/esm2022/dateTime/index.mjs +0 -11
  122. package/esm2022/dateTime/lib/calendar.service.mjs +0 -91
  123. package/esm2022/dateTime/lib/dateTime.config.mjs +0 -50
  124. package/esm2022/dateTime/lib/datetime.class.mjs +0 -325
  125. package/esm2022/dateTime/lib/datetime.module.mjs +0 -21
  126. package/esm2022/dateTime/lib/datetime.pipe.mjs +0 -29
  127. package/esm2022/dateTime/lib/formatters/datetime-formatter.mjs +0 -30
  128. package/esm2022/dateTime/lib/formatters/timeleft-formatter.mjs +0 -91
  129. package/esm2022/dateTime/lib/georgian.calendar.mjs +0 -198
  130. package/esm2022/dateTime/lib/holidays.loader.mjs +0 -13
  131. package/esm2022/dateTime/lib/jalali.calendar.mjs +0 -423
  132. package/fesm2022/acorex-core-dateTime.mjs.map +0 -1
  133. /package/{dateTime → date-time}/index.d.ts +0 -0
  134. /package/{dateTime → date-time}/lib/calendar.service.d.ts +0 -0
  135. /package/{dateTime → date-time}/lib/dateTime.config.d.ts +0 -0
  136. /package/{dateTime → date-time}/lib/datetime.module.d.ts +0 -0
  137. /package/{dateTime → date-time}/lib/datetime.pipe.d.ts +0 -0
  138. /package/{dateTime → date-time}/lib/georgian.calendar.d.ts +0 -0
  139. /package/{dateTime → date-time}/lib/holidays.loader.d.ts +0 -0
  140. /package/{dateTime → date-time}/lib/jalali.calendar.d.ts +0 -0
@@ -1,423 +0,0 @@
1
- import { AXCalendar, AXDateTime } from './datetime.class';
2
- export class JalaliCalendar extends AXCalendar {
3
- /**
4
- * @ignore
5
- */
6
- constructor(config) {
7
- super(config);
8
- /*
9
- Jalaali years starting the 33-year rule.
10
- */
11
- this.breaks = [
12
- -61, 9, 38, 199, 426, 686, 756, 818, 1111, 1181, 1210, 1635, 2060, 2097, 2192, 2262, 2324, 2394, 2456,
13
- 3178,
14
- ];
15
- }
16
- create(value) {
17
- const a = this.toGregorian(value.year, value.month, value.date);
18
- return new AXDateTime(new Date(a.getFullYear(), a.getMonth(), a.getDate(), value.hours || 0, value.minutes || 0, value.seconds || 0, value.ms || 0), this);
19
- }
20
- name() {
21
- return 'jalali';
22
- }
23
- dayOfMonth(date) {
24
- return this.toJalaali(date).day;
25
- }
26
- dayOfYear(date) {
27
- const j = this.toJalaali(date);
28
- return (j.month <= 6 ? (j.month - 1) * 31 : 6 * 31 + (j.month - 7) * 30) + j.day;
29
- }
30
- dayOfWeek(date) {
31
- return date.getDay() == 6 ? 1 : date.getDay() + 2;
32
- }
33
- weekOfYear(date) {
34
- //TODO : apply jalali
35
- const firstDay = new AXDateTime(date, this).startOf('year');
36
- return Math.ceil(((date.getTime() - firstDay.date.getTime()) / 86400000 + firstDay.date.getDay() + 1) / 7);
37
- }
38
- year(date) {
39
- return this.toJalaali(date).year;
40
- }
41
- monthOfYear(date) {
42
- return this.toJalaali(date).month;
43
- }
44
- add(date, unit, amount) {
45
- let value = date.valueOf();
46
- switch (unit) {
47
- case 'second':
48
- value += 1000 * amount;
49
- break;
50
- case 'minute':
51
- value += 60000 * amount;
52
- break;
53
- case 'hour':
54
- value += 3600000 * amount;
55
- break;
56
- case 'month': {
57
- // const v = new Date(value);
58
- // let jd = this.dayOfMonth(date);
59
- // let jm = this.monthOfYear(date);
60
- // let jy = this.year(date);
61
- // const nm = jm + amount;
62
- // const ny = nm % 12 ? Math.floor(nm / 12) : 0;
63
- // jy += ny;
64
- // jm = nm - ny * 12;
65
- // const vv = this.toGregorian(jy, jm, jd);
66
- // v.setFullYear(vv.getFullYear());
67
- // v.setMonth(vv.getMonth());
68
- // v.setDate(vv.getDate());
69
- // value = v.valueOf();
70
- // break;
71
- let jd = this.dayOfMonth(date);
72
- let jm = this.monthOfYear(date);
73
- let jy = this.year(date);
74
- let newMonth = jm + amount;
75
- let yearsToAdd = Math.floor(newMonth / 12);
76
- newMonth = newMonth % 12;
77
- if (newMonth <= 0) {
78
- newMonth += 12;
79
- yearsToAdd--;
80
- }
81
- jy += yearsToAdd;
82
- // Temporary set to first of the month to prevent rollover
83
- const tempDate = this.toGregorian(jy, newMonth, 1);
84
- const gregorianDate = new Date(tempDate.getFullYear(), tempDate.getMonth(), tempDate.getDate());
85
- // Adjust the day to either the original day or the last day of the new month, whichever is smaller
86
- const lastDayOfNewMonth = this.jalaaliMonthLength(jy, newMonth); // Implement this method to find the last day in a Jalali month
87
- jd = Math.min(jd, lastDayOfNewMonth);
88
- const finalDate = this.toGregorian(jy, newMonth, jd);
89
- gregorianDate.setFullYear(finalDate.getFullYear());
90
- gregorianDate.setMonth(finalDate.getMonth());
91
- gregorianDate.setDate(finalDate.getDate());
92
- value = gregorianDate.valueOf();
93
- break;
94
- }
95
- case 'week':
96
- value += 7 * 86400000 * amount;
97
- break;
98
- case 'year': {
99
- const v = new Date(value);
100
- let jd = this.dayOfMonth(date);
101
- let jm = this.monthOfYear(date);
102
- let jy = this.year(date);
103
- const vv = this.toGregorian(jy + amount, jm, jd);
104
- v.setFullYear(vv.getFullYear());
105
- v.setMonth(vv.getMonth());
106
- v.setDate(vv.getDate());
107
- value = v.valueOf();
108
- break;
109
- }
110
- case 'day':
111
- default:
112
- value += 86400000 * amount;
113
- }
114
- return new AXDateTime(new Date(value), this);
115
- }
116
- set(date, unit, value) {
117
- const clone = new Date(date.valueOf());
118
- const jDate = this.toJalaali(clone);
119
- switch (unit) {
120
- case 'second':
121
- clone.setHours(clone.getHours(), clone.getMinutes(), value, clone.getMilliseconds());
122
- break;
123
- case 'minute':
124
- clone.setHours(clone.getHours(), value, clone.getSeconds(), clone.getMilliseconds());
125
- break;
126
- case 'hour':
127
- clone.setHours(value, clone.getMinutes(), clone.getSeconds(), clone.getMilliseconds());
128
- break;
129
- default:
130
- case 'day': {
131
- const gDate = this.toGregorian(jDate.year, jDate.month, value);
132
- clone.setDate(gDate.getDate());
133
- break;
134
- }
135
- case 'week':
136
- break;
137
- case 'month': {
138
- const gDate2 = this.toGregorian(jDate.year, value, jDate.day);
139
- clone.setMonth(gDate2.getMonth());
140
- break;
141
- }
142
- case 'year': {
143
- const gDate3 = this.toGregorian(value, jDate.month, jDate.day);
144
- clone.setFullYear(gDate3.getFullYear());
145
- break;
146
- }
147
- }
148
- return new AXDateTime(clone, this);
149
- }
150
- startOf(date, unit) {
151
- const clone = new Date(date.valueOf());
152
- switch (unit) {
153
- case 'second':
154
- clone.setHours(clone.getHours(), clone.getMinutes(), clone.getSeconds(), 0);
155
- return new AXDateTime(clone, this);
156
- case 'minute':
157
- clone.setHours(clone.getHours(), clone.getMinutes(), 0, 0);
158
- return new AXDateTime(clone, this);
159
- case 'hour':
160
- clone.setHours(clone.getHours(), 0, 0, 0);
161
- return new AXDateTime(clone, this);
162
- default:
163
- case 'day':
164
- clone.setHours(0, 0, 0, 0);
165
- return new AXDateTime(clone, this);
166
- case 'week':
167
- return new AXDateTime(clone, this).add('day', -this.dayOfWeek(clone) + 1).startOf('day');
168
- case 'month': {
169
- const jy = this.year(date);
170
- const jm = this.monthOfYear(date);
171
- const gDate = this.toGregorian(jy, jm, 1);
172
- return new AXDateTime(gDate, this).startOf('day');
173
- }
174
- case 'year': {
175
- const jy = this.year(date);
176
- const gDate = this.toGregorian(jy, 1, 1);
177
- return new AXDateTime(gDate, this).startOf('day');
178
- }
179
- }
180
- }
181
- endOf(date, unit) {
182
- const clone = new Date(date.valueOf());
183
- switch (unit) {
184
- case 'second':
185
- clone.setHours(clone.getHours(), clone.getMinutes(), clone.getSeconds(), 999);
186
- return new AXDateTime(clone, this);
187
- case 'minute':
188
- clone.setHours(clone.getHours(), clone.getMinutes(), 59, 999);
189
- return new AXDateTime(clone, this);
190
- case 'hour':
191
- clone.setHours(clone.getHours(), 59, 59, 999);
192
- return new AXDateTime(clone, this);
193
- default:
194
- case 'day':
195
- clone.setHours(23, 59, 59, 999);
196
- return new AXDateTime(clone, this);
197
- case 'week': {
198
- return this.startOf(date, 'week').add('day', 6).endOf('day');
199
- }
200
- case 'month': {
201
- const jy = this.year(date);
202
- const jm = this.monthOfYear(date);
203
- const jd = this.jalaaliMonthLength(jy, jm);
204
- const gDate = this.toGregorian(jy, jm, jd);
205
- return new AXDateTime(gDate, this).endOf('day');
206
- }
207
- case 'year': {
208
- const jy = this.year(date);
209
- const gDate = this.toGregorian(jy, 12, this.jalaaliMonthLength(jy, 12));
210
- return new AXDateTime(gDate, this).endOf('day');
211
- }
212
- }
213
- }
214
- parse(value) {
215
- const [y, M, d, h, m, s, ms] = value.split(/[^a-zA-Z0-9]+/gi);
216
- const date = this.toGregorian(Number(y) ?? 0, Number(M) ?? 1, Number(d) ?? 1);
217
- if (h != null)
218
- date.setHours(Number(h));
219
- if (m != null)
220
- date.setMinutes(Number(m));
221
- if (s != null)
222
- date.setSeconds(Number(s));
223
- if (ms != null)
224
- date.setMilliseconds(Number(d));
225
- return new AXDateTime(date, this);
226
- }
227
- /*
228
- Converts a Gregorian date to Jalaali.
229
- */
230
- toJalaali(date) {
231
- const gd = date.getDate();
232
- const gm = date.getMonth() + 1;
233
- const gy = date.getFullYear();
234
- const r = this.d2j(this.g2d(gy, gm, gd));
235
- return {
236
- year: r.jy,
237
- month: r.jm,
238
- day: r.jd,
239
- };
240
- }
241
- /*
242
- Converts a Jalaali date to Gregorian.
243
- */
244
- toGregorian(jy, jm, jd) {
245
- const g = this.d2g(this.j2d(jy, jm, jd));
246
- return new Date(g.gy, g.gm - 1, g.gd);
247
- }
248
- /*
249
- Checks whether a Jalaali date is valid or not.
250
- */
251
- isValidJalaaliDate(jy, jm, jd) {
252
- return jy >= -61 && jy <= 3177 && jm >= 1 && jm <= 12 && jd >= 1 && jd <= this.jalaaliMonthLength(jy, jm);
253
- }
254
- /*
255
- Is this a leap year or not?
256
- */
257
- isLeapJalaaliYear(jy) {
258
- return this.jalCalLeap(jy) === 0;
259
- }
260
- /*
261
- Number of days in a given month in a Jalaali year.
262
- */
263
- jalaaliMonthLength(jy, jm) {
264
- if (jm <= 6)
265
- return 31;
266
- if (jm <= 11)
267
- return 30;
268
- if (this.isLeapJalaaliYear(jy))
269
- return 30;
270
- return 29;
271
- }
272
- /*
273
- This determines if the Jalaali (Persian) year is
274
- leap (366-day long) or is the common year (365 days)
275
-
276
- @param jy Jalaali calendar year (-61 to 3177)
277
- @returns number of years since the last leap year (0 to 4)
278
- */
279
- jalCalLeap(jy) {
280
- let bl = this.breaks.length, jp = this.breaks[0], jm, jump, leap, n, i;
281
- if (jy < jp || jy >= this.breaks[bl - 1])
282
- throw new Error('Invalid Jalaali year ' + jy);
283
- for (i = 1; i < bl; i += 1) {
284
- jm = this.breaks[i];
285
- jump = jm - jp;
286
- if (jy < jm)
287
- break;
288
- jp = jm;
289
- }
290
- n = jy - jp;
291
- if (jump - n < 6)
292
- n = n - jump + this.div(jump + 4, 33) * 33;
293
- leap = this.mod(this.mod(n + 1, 33) - 1, 4);
294
- if (leap === -1) {
295
- leap = 4;
296
- }
297
- return leap;
298
- }
299
- jalCal(jy, withoutLeap) {
300
- let bl = this.breaks.length, gy = jy + 621, leapJ = -14, jp = this.breaks[0], jm, jump, leap, leapG, march, n, i;
301
- if (jy < jp || jy >= this.breaks[bl - 1])
302
- throw new Error('Invalid Jalaali year ' + jy);
303
- // Find the limiting years for the Jalaali year jy.
304
- for (i = 1; i < bl; i += 1) {
305
- jm = this.breaks[i];
306
- jump = jm - jp;
307
- if (jy < jm)
308
- break;
309
- leapJ = leapJ + this.div(jump, 33) * 8 + this.div(this.mod(jump, 33), 4);
310
- jp = jm;
311
- }
312
- n = jy - jp;
313
- // Find the number of leap years from AD 621 to the beginning
314
- // of the current Jalaali year in the Persian calendar.
315
- leapJ = leapJ + this.div(n, 33) * 8 + this.div(this.mod(n, 33) + 3, 4);
316
- if (this.mod(jump, 33) === 4 && jump - n === 4)
317
- leapJ += 1;
318
- // And the same in the Gregorian calendar (until the year gy).
319
- leapG = this.div(gy, 4) - this.div((this.div(gy, 100) + 1) * 3, 4) - 150;
320
- // Determine the Gregorian date of Farvardin the 1st.
321
- march = 20 + leapJ - leapG;
322
- // return with gy and march when we don't need leap
323
- if (withoutLeap)
324
- return { gy: gy, march: march };
325
- // Find how many years have passed since the last leap year.
326
- if (jump - n < 6)
327
- n = n - jump + this.div(jump + 4, 33) * 33;
328
- leap = this.mod(this.mod(n + 1, 33) - 1, 4);
329
- if (leap === -1) {
330
- leap = 4;
331
- }
332
- return {
333
- leap: leap,
334
- gy: gy,
335
- march: march,
336
- };
337
- }
338
- j2d(jy, jm, jd) {
339
- let r = this.jalCal(jy, true);
340
- return this.g2d(r.gy, 3, r.march) + (jm - 1) * 31 - this.div(jm, 7) * (jm - 7) + jd - 1;
341
- }
342
- d2j(jdn) {
343
- let gy = this.d2g(jdn).gy, // Calculate Gregorian year (gy).
344
- jy = gy - 621, r = this.jalCal(jy, false), jdn1f = this.g2d(gy, 3, r.march), jd, jm, k;
345
- // Find number of days that passed since 1 Farvardin.
346
- k = jdn - jdn1f;
347
- if (k >= 0) {
348
- if (k <= 185) {
349
- // The first 6 months.
350
- jm = 1 + this.div(k, 31);
351
- jd = this.mod(k, 31) + 1;
352
- return {
353
- jy: jy,
354
- jm: jm,
355
- jd: jd,
356
- };
357
- }
358
- else {
359
- // The remaining months.
360
- k -= 186;
361
- }
362
- }
363
- else {
364
- // Previous Jalaali year.
365
- jy -= 1;
366
- k += 179;
367
- if (r.leap === 1)
368
- k += 1;
369
- }
370
- jm = 7 + this.div(k, 30);
371
- jd = this.mod(k, 30) + 1;
372
- return {
373
- jy: jy,
374
- jm: jm,
375
- jd: jd,
376
- };
377
- }
378
- g2d(gy, gm, gd) {
379
- let d = this.div((gy + this.div(gm - 8, 6) + 100100) * 1461, 4) +
380
- this.div(153 * this.mod(gm + 9, 12) + 2, 5) +
381
- gd -
382
- 34840408;
383
- d = d - this.div(this.div(gy + 100100 + this.div(gm - 8, 6), 100) * 3, 4) + 752;
384
- return d;
385
- }
386
- d2g(jdn) {
387
- let j, i, gd, gm, gy;
388
- j = 4 * jdn + 139361631;
389
- j = j + this.div(this.div(4 * jdn + 183187720, 146097) * 3, 4) * 4 - 3908;
390
- i = this.div(this.mod(j, 1461), 4) * 5 + 308;
391
- gd = this.div(this.mod(i, 153), 5) + 1;
392
- gm = this.mod(this.div(i, 153), 12) + 1;
393
- gy = this.div(j, 1461) - 100100 + this.div(8 - gm, 6);
394
- return {
395
- gy: gy,
396
- gm: gm,
397
- gd: gd,
398
- };
399
- }
400
- jalaaliWeek(jy, jm, jd) {
401
- let dayOfWeek = this.jalaaliToDateObject(jy, jm, jd, 0, 0, 0, 0).getDay();
402
- let startDayDifference = dayOfWeek == 6 ? 0 : -(dayOfWeek + 1);
403
- let endDayDifference = 6 + startDayDifference;
404
- return {
405
- saturday: this.d2j(this.j2d(jy, jm, jd + startDayDifference)),
406
- friday: this.d2j(this.j2d(jy, jm, jd + endDayDifference)),
407
- };
408
- }
409
- jalaaliToDateObject(jy, jm, jd, h = 0, m = 0, s = 0, ms = 0) {
410
- let gregorianCalenderDate = this.toGregorian(jy, jm, jd);
411
- return new Date(gregorianCalenderDate.getFullYear(), gregorianCalenderDate.getMonth() - 1, gregorianCalenderDate.getDate(), h || 0, m || 0, s || 0, ms || 0);
412
- }
413
- /*
414
- Utility helper functions.
415
- */
416
- div(a, b) {
417
- return ~~(a / b);
418
- }
419
- mod(a, b) {
420
- return a - ~~(a / b) * b;
421
- }
422
- }
423
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jalali.calendar.js","sourceRoot":"","sources":["../../../../../../libs/core/dateTime/src/lib/jalali.calendar.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXCalendar, AXCalendarConfig, AXDateTime, AXDateValue, TimeUnit } from './datetime.class';\n\nexport class JalaliCalendar extends AXCalendar {\n  /**\n   * @ignore\n   */\n  constructor(config: AXCalendarConfig) {\n    super(config);\n  }\n\n  /*\n  Jalaali years starting the 33-year rule.\n*/\n  private breaks = [\n    -61, 9, 38, 199, 426, 686, 756, 818, 1111, 1181, 1210, 1635, 2060, 2097, 2192, 2262, 2324, 2394, 2456,\n    3178,\n  ];\n\n  create(value: AXDateValue): AXDateTime {\n    const a = this.toGregorian(value.year, value.month, value.date);\n    return new AXDateTime(\n      new Date(\n        a.getFullYear(),\n        a.getMonth(),\n        a.getDate(),\n        value.hours || 0,\n        value.minutes || 0,\n        value.seconds || 0,\n        value.ms || 0,\n      ),\n      this,\n    );\n  }\n\n  name(): string {\n    return 'jalali';\n  }\n\n  dayOfMonth(date: Date): number {\n    return this.toJalaali(date).day;\n  }\n\n  dayOfYear(date: Date): number {\n    const j = this.toJalaali(date);\n    return (j.month <= 6 ? (j.month - 1) * 31 : 6 * 31 + (j.month - 7) * 30) + j.day;\n  }\n\n  dayOfWeek(date: Date): number {\n    return date.getDay() == 6 ? 1 : date.getDay() + 2;\n  }\n\n  weekOfYear(date: Date): number {\n    //TODO : apply jalali\n    const firstDay = new AXDateTime(date, this).startOf('year');\n    return Math.ceil(\n      ((date.getTime() - firstDay.date.getTime()) / 86400000 + firstDay.date.getDay() + 1) / 7,\n    );\n  }\n\n  year(date: Date): number {\n    return this.toJalaali(date).year;\n  }\n\n  monthOfYear(date: Date): number {\n    return this.toJalaali(date).month;\n  }\n\n  add(date: Date, unit: TimeUnit, amount: number): AXDateTime {\n    let value = date.valueOf();\n    switch (unit) {\n      case 'second':\n        value += 1000 * amount;\n        break;\n      case 'minute':\n        value += 60000 * amount;\n        break;\n      case 'hour':\n        value += 3600000 * amount;\n        break;\n      case 'month': {\n        // const v = new Date(value);\n        // let jd = this.dayOfMonth(date);\n        // let jm = this.monthOfYear(date);\n        // let jy = this.year(date);\n        // const nm = jm + amount;\n        // const ny = nm % 12 ? Math.floor(nm / 12) : 0;\n        // jy += ny;\n        // jm = nm - ny * 12;\n        // const vv = this.toGregorian(jy, jm, jd);\n        // v.setFullYear(vv.getFullYear());\n        // v.setMonth(vv.getMonth());\n        // v.setDate(vv.getDate());\n        // value = v.valueOf();\n        // break;\n        let jd = this.dayOfMonth(date);\n        let jm = this.monthOfYear(date);\n        let jy = this.year(date);\n\n        let newMonth = jm + amount;\n        let yearsToAdd = Math.floor(newMonth / 12);\n        newMonth = newMonth % 12;\n        if (newMonth <= 0) {\n          newMonth += 12;\n          yearsToAdd--;\n        }\n\n        jy += yearsToAdd;\n\n        // Temporary set to first of the month to prevent rollover\n        const tempDate = this.toGregorian(jy, newMonth, 1);\n        const gregorianDate = new Date(tempDate.getFullYear(), tempDate.getMonth(), tempDate.getDate());\n\n        // Adjust the day to either the original day or the last day of the new month, whichever is smaller\n        const lastDayOfNewMonth = this.jalaaliMonthLength(jy, newMonth); // Implement this method to find the last day in a Jalali month\n        jd = Math.min(jd, lastDayOfNewMonth);\n\n        const finalDate = this.toGregorian(jy, newMonth, jd);\n        gregorianDate.setFullYear(finalDate.getFullYear());\n        gregorianDate.setMonth(finalDate.getMonth());\n        gregorianDate.setDate(finalDate.getDate());\n\n        value = gregorianDate.valueOf();\n        break;\n      }\n      case 'week':\n        value += 7 * 86400000 * amount;\n        break;\n      case 'year': {\n        const v = new Date(value);\n        let jd = this.dayOfMonth(date);\n        let jm = this.monthOfYear(date);\n        let jy = this.year(date);\n        const vv = this.toGregorian(jy + amount, jm, jd);\n        v.setFullYear(vv.getFullYear());\n        v.setMonth(vv.getMonth());\n        v.setDate(vv.getDate());\n        value = v.valueOf();\n        break;\n      }\n      case 'day':\n      default:\n        value += 86400000 * amount;\n    }\n    return new AXDateTime(new Date(value), this);\n  }\n\n  set(date: Date, unit: TimeUnit, value: number): AXDateTime {\n    const clone = new Date(date.valueOf());\n    const jDate = this.toJalaali(clone);\n    switch (unit) {\n      case 'second':\n        clone.setHours(clone.getHours(), clone.getMinutes(), value, clone.getMilliseconds());\n        break;\n      case 'minute':\n        clone.setHours(clone.getHours(), value, clone.getSeconds(), clone.getMilliseconds());\n        break;\n      case 'hour':\n        clone.setHours(value, clone.getMinutes(), clone.getSeconds(), clone.getMilliseconds());\n        break;\n      default:\n      case 'day': {\n        const gDate = this.toGregorian(jDate.year, jDate.month, value);\n        clone.setDate(gDate.getDate());\n        break;\n      }\n      case 'week':\n        break;\n      case 'month': {\n        const gDate2 = this.toGregorian(jDate.year, value, jDate.day);\n        clone.setMonth(gDate2.getMonth());\n        break;\n      }\n      case 'year': {\n        const gDate3 = this.toGregorian(value, jDate.month, jDate.day);\n        clone.setFullYear(gDate3.getFullYear());\n        break;\n      }\n    }\n    return new AXDateTime(clone, this);\n  }\n\n  startOf(date: Date, unit: TimeUnit): AXDateTime {\n    const clone = new Date(date.valueOf());\n    switch (unit) {\n      case 'second':\n        clone.setHours(clone.getHours(), clone.getMinutes(), clone.getSeconds(), 0);\n        return new AXDateTime(clone, this);\n      case 'minute':\n        clone.setHours(clone.getHours(), clone.getMinutes(), 0, 0);\n        return new AXDateTime(clone, this);\n      case 'hour':\n        clone.setHours(clone.getHours(), 0, 0, 0);\n        return new AXDateTime(clone, this);\n      default:\n      case 'day':\n        clone.setHours(0, 0, 0, 0);\n        return new AXDateTime(clone, this);\n      case 'week':\n        return new AXDateTime(clone, this).add('day', -this.dayOfWeek(clone) + 1).startOf('day');\n      case 'month': {\n        const jy = this.year(date);\n        const jm = this.monthOfYear(date);\n        const gDate = this.toGregorian(jy, jm, 1);\n        return new AXDateTime(gDate, this).startOf('day');\n      }\n      case 'year': {\n        const jy = this.year(date);\n        const gDate = this.toGregorian(jy, 1, 1);\n        return new AXDateTime(gDate, this).startOf('day');\n      }\n    }\n  }\n\n  endOf(date: Date, unit: TimeUnit): AXDateTime {\n    const clone = new Date(date.valueOf());\n    switch (unit) {\n      case 'second':\n        clone.setHours(clone.getHours(), clone.getMinutes(), clone.getSeconds(), 999);\n        return new AXDateTime(clone, this);\n      case 'minute':\n        clone.setHours(clone.getHours(), clone.getMinutes(), 59, 999);\n        return new AXDateTime(clone, this);\n      case 'hour':\n        clone.setHours(clone.getHours(), 59, 59, 999);\n        return new AXDateTime(clone, this);\n      default:\n      case 'day':\n        clone.setHours(23, 59, 59, 999);\n        return new AXDateTime(clone, this);\n      case 'week': {\n        return this.startOf(date, 'week').add('day', 6).endOf('day');\n      }\n      case 'month': {\n        const jy = this.year(date);\n        const jm = this.monthOfYear(date);\n        const jd = this.jalaaliMonthLength(jy, jm);\n        const gDate = this.toGregorian(jy, jm, jd);\n        return new AXDateTime(gDate, this).endOf('day');\n      }\n      case 'year': {\n        const jy = this.year(date);\n        const gDate = this.toGregorian(jy, 12, this.jalaaliMonthLength(jy, 12));\n        return new AXDateTime(gDate, this).endOf('day');\n      }\n    }\n  }\n\n  parse(value: string): AXDateTime {\n    const [y, M, d, h, m, s, ms] = value.split(/[^a-zA-Z0-9]+/gi);\n    const date = this.toGregorian(Number(y) ?? 0, Number(M) ?? 1, Number(d) ?? 1);\n    if (h != null) date.setHours(Number(h));\n    if (m != null) date.setMinutes(Number(m));\n    if (s != null) date.setSeconds(Number(s));\n    if (ms != null) date.setMilliseconds(Number(d));\n    return new AXDateTime(date, this);\n  }\n\n  /*\n  Converts a Gregorian date to Jalaali.\n*/\n  toJalaali(date: Date): { year: number; month: number; day: number } {\n    const gd = date.getDate();\n    const gm = date.getMonth() + 1;\n    const gy = date.getFullYear();\n    const r = this.d2j(this.g2d(gy, gm, gd));\n    return {\n      year: r.jy,\n      month: r.jm,\n      day: r.jd,\n    };\n  }\n\n  /*\n    Converts a Jalaali date to Gregorian.\n  */\n  toGregorian(jy, jm, jd): Date {\n    const g = this.d2g(this.j2d(jy, jm, jd));\n    return new Date(g.gy, g.gm - 1, g.gd);\n  }\n\n  /*\n    Checks whether a Jalaali date is valid or not.\n  */\n  isValidJalaaliDate(jy, jm, jd) {\n    return jy >= -61 && jy <= 3177 && jm >= 1 && jm <= 12 && jd >= 1 && jd <= this.jalaaliMonthLength(jy, jm);\n  }\n\n  /*\n    Is this a leap year or not?\n  */\n  isLeapJalaaliYear(jy) {\n    return this.jalCalLeap(jy) === 0;\n  }\n\n  /*\n    Number of days in a given month in a Jalaali year.\n  */\n  jalaaliMonthLength(jy, jm) {\n    if (jm <= 6) return 31;\n    if (jm <= 11) return 30;\n    if (this.isLeapJalaaliYear(jy)) return 30;\n    return 29;\n  }\n\n  /*\n      This determines if the Jalaali (Persian) year is\n      leap (366-day long) or is the common year (365 days)\n  \n      @param jy Jalaali calendar year (-61 to 3177)\n      @returns number of years since the last leap year (0 to 4)\n   */\n  private jalCalLeap(jy: number) {\n    let bl = this.breaks.length,\n      jp = this.breaks[0],\n      jm,\n      jump,\n      leap,\n      n,\n      i;\n\n    if (jy < jp || jy >= this.breaks[bl - 1]) throw new Error('Invalid Jalaali year ' + jy);\n\n    for (i = 1; i < bl; i += 1) {\n      jm = this.breaks[i];\n      jump = jm - jp;\n      if (jy < jm) break;\n      jp = jm;\n    }\n    n = jy - jp;\n\n    if (jump - n < 6) n = n - jump + this.div(jump + 4, 33) * 33;\n    leap = this.mod(this.mod(n + 1, 33) - 1, 4);\n    if (leap === -1) {\n      leap = 4;\n    }\n\n    return leap;\n  }\n\n  private jalCal(jy: number, withoutLeap: boolean) {\n    let bl = this.breaks.length,\n      gy = jy + 621,\n      leapJ = -14,\n      jp = this.breaks[0],\n      jm,\n      jump,\n      leap,\n      leapG,\n      march,\n      n,\n      i;\n\n    if (jy < jp || jy >= this.breaks[bl - 1]) throw new Error('Invalid Jalaali year ' + jy);\n\n    // Find the limiting years for the Jalaali year jy.\n    for (i = 1; i < bl; i += 1) {\n      jm = this.breaks[i];\n      jump = jm - jp;\n      if (jy < jm) break;\n      leapJ = leapJ + this.div(jump, 33) * 8 + this.div(this.mod(jump, 33), 4);\n      jp = jm;\n    }\n    n = jy - jp;\n\n    // Find the number of leap years from AD 621 to the beginning\n    // of the current Jalaali year in the Persian calendar.\n    leapJ = leapJ + this.div(n, 33) * 8 + this.div(this.mod(n, 33) + 3, 4);\n    if (this.mod(jump, 33) === 4 && jump - n === 4) leapJ += 1;\n\n    // And the same in the Gregorian calendar (until the year gy).\n    leapG = this.div(gy, 4) - this.div((this.div(gy, 100) + 1) * 3, 4) - 150;\n\n    // Determine the Gregorian date of Farvardin the 1st.\n    march = 20 + leapJ - leapG;\n\n    // return with gy and march when we don't need leap\n    if (withoutLeap) return { gy: gy, march: march };\n\n    // Find how many years have passed since the last leap year.\n    if (jump - n < 6) n = n - jump + this.div(jump + 4, 33) * 33;\n    leap = this.mod(this.mod(n + 1, 33) - 1, 4);\n    if (leap === -1) {\n      leap = 4;\n    }\n\n    return {\n      leap: leap,\n      gy: gy,\n      march: march,\n    };\n  }\n\n  private j2d(jy, jm, jd): number {\n    let r = this.jalCal(jy, true);\n    return this.g2d(r.gy, 3, r.march) + (jm - 1) * 31 - this.div(jm, 7) * (jm - 7) + jd - 1;\n  }\n\n  private d2j(jdn: number) {\n    let gy = this.d2g(jdn).gy, // Calculate Gregorian year (gy).\n      jy = gy - 621,\n      r = this.jalCal(jy, false),\n      jdn1f = this.g2d(gy, 3, r.march),\n      jd,\n      jm,\n      k;\n\n    // Find number of days that passed since 1 Farvardin.\n    k = jdn - jdn1f;\n    if (k >= 0) {\n      if (k <= 185) {\n        // The first 6 months.\n        jm = 1 + this.div(k, 31);\n        jd = this.mod(k, 31) + 1;\n        return {\n          jy: jy,\n          jm: jm,\n          jd: jd,\n        };\n      } else {\n        // The remaining months.\n        k -= 186;\n      }\n    } else {\n      // Previous Jalaali year.\n      jy -= 1;\n      k += 179;\n      if (r.leap === 1) k += 1;\n    }\n    jm = 7 + this.div(k, 30);\n    jd = this.mod(k, 30) + 1;\n    return {\n      jy: jy,\n      jm: jm,\n      jd: jd,\n    };\n  }\n\n  private g2d(gy: number, gm: number, gd: number): number {\n    let d =\n      this.div((gy + this.div(gm - 8, 6) + 100100) * 1461, 4) +\n      this.div(153 * this.mod(gm + 9, 12) + 2, 5) +\n      gd -\n      34840408;\n    d = d - this.div(this.div(gy + 100100 + this.div(gm - 8, 6), 100) * 3, 4) + 752;\n    return d;\n  }\n\n  private d2g(jdn: number) {\n    let j, i, gd, gm, gy;\n    j = 4 * jdn + 139361631;\n    j = j + this.div(this.div(4 * jdn + 183187720, 146097) * 3, 4) * 4 - 3908;\n    i = this.div(this.mod(j, 1461), 4) * 5 + 308;\n    gd = this.div(this.mod(i, 153), 5) + 1;\n    gm = this.mod(this.div(i, 153), 12) + 1;\n    gy = this.div(j, 1461) - 100100 + this.div(8 - gm, 6);\n    return {\n      gy: gy,\n      gm: gm,\n      gd: gd,\n    };\n  }\n\n  private jalaaliWeek(jy: number, jm: number, jd: number): { saturday: any; friday: any } {\n    let dayOfWeek = this.jalaaliToDateObject(jy, jm, jd, 0, 0, 0, 0).getDay();\n\n    let startDayDifference = dayOfWeek == 6 ? 0 : -(dayOfWeek + 1);\n    let endDayDifference = 6 + startDayDifference;\n\n    return {\n      saturday: this.d2j(this.j2d(jy, jm, jd + startDayDifference)),\n      friday: this.d2j(this.j2d(jy, jm, jd + endDayDifference)),\n    };\n  }\n\n  private jalaaliToDateObject(\n    jy: number,\n    jm: number,\n    jd: number,\n    h: number = 0,\n    m: number = 0,\n    s: number = 0,\n    ms: number = 0,\n  ) {\n    let gregorianCalenderDate = this.toGregorian(jy, jm, jd);\n\n    return new Date(\n      gregorianCalenderDate.getFullYear(),\n      gregorianCalenderDate.getMonth() - 1,\n      gregorianCalenderDate.getDate(),\n      h || 0,\n      m || 0,\n      s || 0,\n      ms || 0,\n    );\n  }\n\n  /*\n    Utility helper functions.\n  */\n\n  private div(a: number, b: number) {\n    return ~~(a / b);\n  }\n\n  private mod(a: number, b: number) {\n    return a - ~~(a / b) * b;\n  }\n}\n"]}