ng-mo-date-picker 1.0.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.
@@ -0,0 +1,451 @@
1
+ import * as i0 from '@angular/core';
2
+ import { Injectable, output, inject, ElementRef, HostListener, Directive, input, signal, computed, effect, forwardRef, ChangeDetectionStrategy, Component } from '@angular/core';
3
+ import moment from 'moment-hijri';
4
+ import * as i1 from '@angular/common';
5
+ import { CommonModule } from '@angular/common';
6
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
7
+
8
+ class HijriConverterService {
9
+ gregorianToHijri(date) {
10
+ const m = moment(date);
11
+ return {
12
+ year: m.iYear(),
13
+ month: m.iMonth() + 1,
14
+ day: m.iDate()
15
+ };
16
+ }
17
+ hijriToGregorian(year, month, day) {
18
+ const m = moment(`${year}/${month}/${day}`, 'iYYYY/iM/iD');
19
+ return m.toDate();
20
+ }
21
+ getMonthName(month) {
22
+ const months = ['محرم', 'صفر', 'ربيع الأول', 'ربيع الآخر',
23
+ 'جمادى الأولى', 'جمادى الآخرة', 'رجب', 'شعبان',
24
+ 'رمضان', 'شوال', 'ذو القعدة', 'ذو الحجة'];
25
+ return months[month - 1];
26
+ }
27
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: HijriConverterService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
28
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: HijriConverterService, providedIn: 'root' });
29
+ }
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: HijriConverterService, decorators: [{
31
+ type: Injectable,
32
+ args: [{
33
+ providedIn: 'root'
34
+ }]
35
+ }] });
36
+
37
+ class ClickOutside {
38
+ clickOutside = output();
39
+ elementRef = inject(ElementRef);
40
+ onClick(event) {
41
+ const target = event.target;
42
+ if (!target)
43
+ return;
44
+ const clickedInside = this.elementRef.nativeElement.contains(target);
45
+ if (!clickedInside) {
46
+ this.clickOutside.emit();
47
+ }
48
+ }
49
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ClickOutside, deps: [], target: i0.ɵɵFactoryTarget.Directive });
50
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "21.0.6", type: ClickOutside, isStandalone: true, selector: "[moClickOutside]", outputs: { clickOutside: "clickOutside" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0 });
51
+ }
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: ClickOutside, decorators: [{
53
+ type: Directive,
54
+ args: [{
55
+ selector: '[moClickOutside]',
56
+ }]
57
+ }], propDecorators: { clickOutside: [{ type: i0.Output, args: ["clickOutside"] }], onClick: [{
58
+ type: HostListener,
59
+ args: ['document:click', ['$event']]
60
+ }] } });
61
+
62
+ const TRANSLATIONS = {
63
+ ar: {
64
+ gregorianMonths: ['يناير', 'فبراير', 'مارس', 'أبريل', 'مايو', 'يونيو',
65
+ 'يوليو', 'أغسطس', 'سبتمبر', 'أكتوبر', 'نوفمبر', 'ديسمبر'],
66
+ hijriMonths: ['محرم', 'صفر', 'ربيع الأول', 'ربيع الآخر', 'جمادى الأولى',
67
+ 'جمادى الآخرة', 'رجب', 'شعبان', 'رمضان', 'شوال', 'ذو القعدة', 'ذو الحجة'],
68
+ days: ['ح', 'ن', 'ث', 'ر', 'خ', 'ج', 'س'],
69
+ today: 'اليوم',
70
+ clear: 'مسح',
71
+ gregorian: 'ميلادي',
72
+ hijri: 'هجري',
73
+ placeholder: 'اختر تاريخ'
74
+ },
75
+ en: {
76
+ gregorianMonths: ['January', 'February', 'March', 'April', 'May', 'June',
77
+ 'July', 'August', 'September', 'October', 'November', 'December'],
78
+ hijriMonths: ['Muharram', 'Safar', 'Rabi al-Awwal', 'Rabi al-Thani', 'Jumada al-Awwal',
79
+ 'Jumada al-Thani', 'Rajab', 'Shaban', 'Ramadan', 'Shawwal', 'Dhu al-Qadah', 'Dhu al-Hijjah'],
80
+ days: ['S', 'M', 'T', 'W', 'T', 'F', 'S'],
81
+ today: 'Today',
82
+ clear: 'Clear',
83
+ gregorian: 'Gregorian',
84
+ hijri: 'Hijri',
85
+ placeholder: 'Select date'
86
+ }
87
+ };
88
+
89
+ class NgMoDatePicker {
90
+ // ==================== INPUTS ====================
91
+ calendarType = input('gregorian', ...(ngDevMode ? [{ debugName: "calendarType" }] : []));
92
+ locale = input('ar', ...(ngDevMode ? [{ debugName: "locale" }] : []));
93
+ showIcon = input(true, ...(ngDevMode ? [{ debugName: "showIcon" }] : []));
94
+ customIcon = input('📅', ...(ngDevMode ? [{ debugName: "customIcon" }] : []));
95
+ inputClass = input('', ...(ngDevMode ? [{ debugName: "inputClass" }] : []));
96
+ calendarClass = input('', ...(ngDevMode ? [{ debugName: "calendarClass" }] : []));
97
+ disabled = input(false, ...(ngDevMode ? [{ debugName: "disabled" }] : []));
98
+ readonly = input(false, ...(ngDevMode ? [{ debugName: "readonly" }] : []));
99
+ placeholder = input(undefined, ...(ngDevMode ? [{ debugName: "placeholder" }] : []));
100
+ name = input(undefined, ...(ngDevMode ? [{ debugName: "name" }] : []));
101
+ id = input(undefined, ...(ngDevMode ? [{ debugName: "id" }] : []));
102
+ // ==================== OUTPUTS ====================
103
+ dateChange = output();
104
+ calendarToggle = output();
105
+ // ==================== SERVICES ====================
106
+ hijriService = inject(HijriConverterService);
107
+ // ==================== STATE SIGNALS ====================
108
+ internalCalendarType = signal('gregorian', ...(ngDevMode ? [{ debugName: "internalCalendarType" }] : []));
109
+ selectedDate = signal(null, ...(ngDevMode ? [{ debugName: "selectedDate" }] : []));
110
+ isOpen = signal(false, ...(ngDevMode ? [{ debugName: "isOpen" }] : []));
111
+ // Gregorian state
112
+ currentMonth = signal(new Date().getMonth(), ...(ngDevMode ? [{ debugName: "currentMonth" }] : []));
113
+ currentYear = signal(new Date().getFullYear(), ...(ngDevMode ? [{ debugName: "currentYear" }] : []));
114
+ // Hijri state
115
+ currentHijriMonth = signal(1, ...(ngDevMode ? [{ debugName: "currentHijriMonth" }] : []));
116
+ currentHijriYear = signal(1446, ...(ngDevMode ? [{ debugName: "currentHijriYear" }] : []));
117
+ // Calendar days
118
+ days = signal([], ...(ngDevMode ? [{ debugName: "days" }] : []));
119
+ // ==================== COMPUTED SIGNALS ====================
120
+ translations = computed(() => TRANSLATIONS[this.locale()], ...(ngDevMode ? [{ debugName: "translations" }] : []));
121
+ daysShortNames = computed(() => this.translations().days, ...(ngDevMode ? [{ debugName: "daysShortNames" }] : []));
122
+ monthName = computed(() => {
123
+ if (this.internalCalendarType() === 'hijri') {
124
+ return this.translations().hijriMonths[this.currentHijriMonth() - 1];
125
+ }
126
+ return this.translations().gregorianMonths[this.currentMonth()];
127
+ }, ...(ngDevMode ? [{ debugName: "monthName" }] : []));
128
+ currentYearDisplay = computed(() => this.internalCalendarType() === 'hijri'
129
+ ? this.currentHijriYear()
130
+ : this.currentYear(), ...(ngDevMode ? [{ debugName: "currentYearDisplay" }] : []));
131
+ formattedDate = computed(() => {
132
+ if (!this.selectedDate())
133
+ return '';
134
+ const date = this.selectedDate();
135
+ if (this.internalCalendarType() === 'hijri') {
136
+ const hijri = this.hijriService.gregorianToHijri(date);
137
+ return `${hijri.day}/${hijri.month}/${hijri.year}`;
138
+ }
139
+ return this.formatGregorianDate(date);
140
+ }, ...(ngDevMode ? [{ debugName: "formattedDate" }] : []));
141
+ placeholderText = computed(() => this.placeholder() || this.translations().placeholder, ...(ngDevMode ? [{ debugName: "placeholderText" }] : []));
142
+ // CSS Classes Computed Signals
143
+ wrapperCssClasses = computed(() => ({
144
+ 'mo-datepicker-wrapper': true,
145
+ 'rtl': this.locale() === 'ar',
146
+ 'ltr': this.locale() === 'en'
147
+ }), ...(ngDevMode ? [{ debugName: "wrapperCssClasses" }] : []));
148
+ inputCssClasses = computed(() => ({
149
+ 'mo-input': true,
150
+ 'rtl': this.locale() === 'ar',
151
+ 'ltr': this.locale() === 'en',
152
+ [this.inputClass()]: !!this.inputClass()
153
+ }), ...(ngDevMode ? [{ debugName: "inputCssClasses" }] : []));
154
+ iconBtnCssClasses = computed(() => ({
155
+ 'mo-icon-btn': true,
156
+ 'rtl': this.locale() === 'ar',
157
+ 'ltr': this.locale() === 'en'
158
+ }), ...(ngDevMode ? [{ debugName: "iconBtnCssClasses" }] : []));
159
+ calendarCssClasses = computed(() => ({
160
+ 'mo-calendar': true,
161
+ 'rtl': this.locale() === 'ar',
162
+ 'ltr': this.locale() === 'en',
163
+ [this.calendarClass()]: !!this.calendarClass()
164
+ }), ...(ngDevMode ? [{ debugName: "calendarCssClasses" }] : []));
165
+ // Date Comparison Optimization
166
+ selectedDateTimestamp = computed(() => {
167
+ const date = this.selectedDate();
168
+ if (!date)
169
+ return null;
170
+ return new Date(date.getFullYear(), date.getMonth(), date.getDate()).getTime();
171
+ }, ...(ngDevMode ? [{ debugName: "selectedDateTimestamp" }] : []));
172
+ todayTimestamp = (() => {
173
+ const today = new Date();
174
+ return new Date(today.getFullYear(), today.getMonth(), today.getDate()).getTime();
175
+ })();
176
+ // ==================== FORMS INTEGRATION ====================
177
+ onChange = () => { };
178
+ onTouched = () => { };
179
+ writeValue(value) {
180
+ this.selectedDate.set(value);
181
+ }
182
+ registerOnChange(fn) {
183
+ this.onChange = fn;
184
+ }
185
+ registerOnTouched(fn) {
186
+ this.onTouched = fn;
187
+ }
188
+ // ==================== LIFECYCLE ====================
189
+ constructor() {
190
+ const today = new Date();
191
+ const hijriToday = this.hijriService.gregorianToHijri(today);
192
+ this.currentHijriYear.set(hijriToday.year);
193
+ this.currentHijriMonth.set(hijriToday.month);
194
+ effect(() => {
195
+ this.internalCalendarType.set(this.calendarType());
196
+ });
197
+ effect(() => {
198
+ this.currentMonth();
199
+ this.currentYear();
200
+ this.currentHijriMonth();
201
+ this.currentHijriYear();
202
+ this.internalCalendarType();
203
+ this.generateCalendar();
204
+ });
205
+ }
206
+ // ==================== CALENDAR GENERATION ====================
207
+ generateCalendar() {
208
+ if (this.internalCalendarType() === 'hijri') {
209
+ this.generateHijriCalendar();
210
+ }
211
+ else {
212
+ this.generateGregorianCalendar();
213
+ }
214
+ }
215
+ generateGregorianCalendar() {
216
+ const year = this.currentYear();
217
+ const month = this.currentMonth();
218
+ const firstDayOfMonth = new Date(year, month, 1);
219
+ const lastDayOfMonth = new Date(year, month + 1, 0);
220
+ const startDayOfWeek = firstDayOfMonth.getDay();
221
+ const daysInMonth = lastDayOfMonth.getDate();
222
+ const emptyDays = Array.from({ length: startDayOfWeek }, () => ({
223
+ date: null,
224
+ day: null,
225
+ isEmpty: true
226
+ }));
227
+ const monthDays = Array.from({ length: daysInMonth }, (_, i) => ({
228
+ date: new Date(year, month, i + 1),
229
+ day: i + 1,
230
+ isEmpty: false
231
+ }));
232
+ const totalUsedDays = emptyDays.length + monthDays.length;
233
+ const remainingDays = Array.from({ length: 42 - totalUsedDays }, () => ({
234
+ date: null,
235
+ day: null,
236
+ isEmpty: true
237
+ }));
238
+ this.days.set([...emptyDays, ...monthDays, ...remainingDays]);
239
+ }
240
+ generateHijriCalendar() {
241
+ const year = this.currentHijriYear();
242
+ const month = this.currentHijriMonth();
243
+ const firstDayGregorian = this.hijriService.hijriToGregorian(year, month, 1);
244
+ const startDayOfWeek = firstDayGregorian.getDay();
245
+ const monthLengths = [30, 29, 30, 29, 30, 29, 30, 29, 30, 29, 30, 29];
246
+ const daysInMonth = monthLengths[month - 1];
247
+ const emptyDays = Array.from({ length: startDayOfWeek }, () => ({
248
+ date: null,
249
+ day: null,
250
+ isEmpty: true
251
+ }));
252
+ const monthDays = Array.from({ length: daysInMonth }, (_, i) => {
253
+ const gregorianDate = this.hijriService.hijriToGregorian(year, month, i + 1);
254
+ return {
255
+ date: gregorianDate,
256
+ day: i + 1,
257
+ isEmpty: false
258
+ };
259
+ });
260
+ const totalUsedDays = emptyDays.length + monthDays.length;
261
+ const remainingDays = Array.from({ length: 42 - totalUsedDays }, () => ({
262
+ date: null,
263
+ day: null,
264
+ isEmpty: true
265
+ }));
266
+ this.days.set([...emptyDays, ...monthDays, ...remainingDays]);
267
+ }
268
+ // ==================== NAVIGATION ====================
269
+ previousMonth() {
270
+ if (this.internalCalendarType() === 'hijri') {
271
+ if (this.currentHijriMonth() === 1) {
272
+ this.currentHijriMonth.set(12);
273
+ this.currentHijriYear.update(y => y - 1);
274
+ }
275
+ else {
276
+ this.currentHijriMonth.update(m => m - 1);
277
+ }
278
+ }
279
+ else {
280
+ if (this.currentMonth() === 0) {
281
+ this.currentMonth.set(11);
282
+ this.currentYear.update(y => y - 1);
283
+ }
284
+ else {
285
+ this.currentMonth.update(m => m - 1);
286
+ }
287
+ }
288
+ }
289
+ nextMonth() {
290
+ if (this.internalCalendarType() === 'hijri') {
291
+ if (this.currentHijriMonth() === 12) {
292
+ this.currentHijriMonth.set(1);
293
+ this.currentHijriYear.update(y => y + 1);
294
+ }
295
+ else {
296
+ this.currentHijriMonth.update(m => m + 1);
297
+ }
298
+ }
299
+ else {
300
+ if (this.currentMonth() === 11) {
301
+ this.currentMonth.set(0);
302
+ this.currentYear.update(y => y + 1);
303
+ }
304
+ else {
305
+ this.currentMonth.update(m => m + 1);
306
+ }
307
+ }
308
+ }
309
+ // ==================== DATE SELECTION ====================
310
+ selectDate(day) {
311
+ if (day.isEmpty || !day.date)
312
+ return;
313
+ this.selectedDate.set(day.date);
314
+ const hijri = this.hijriService.gregorianToHijri(day.date);
315
+ const output = {
316
+ gregorianDate: day.date,
317
+ gregorianFormatted: this.formatGregorianDate(day.date),
318
+ hijriDate: {
319
+ ...hijri,
320
+ monthName: this.translations().hijriMonths[hijri.month - 1]
321
+ },
322
+ hijriFormatted: this.formatHijriDate(hijri),
323
+ calendarType: this.internalCalendarType(),
324
+ locale: this.locale()
325
+ };
326
+ this.onChange(day.date);
327
+ this.onTouched();
328
+ this.dateChange.emit(output);
329
+ this.isOpen.set(false);
330
+ }
331
+ selectToday() {
332
+ const today = new Date();
333
+ this.selectedDate.set(today);
334
+ this.currentMonth.set(today.getMonth());
335
+ this.currentYear.set(today.getFullYear());
336
+ const hijri = this.hijriService.gregorianToHijri(today);
337
+ this.currentHijriYear.set(hijri.year);
338
+ this.currentHijriMonth.set(hijri.month);
339
+ const output = {
340
+ gregorianDate: today,
341
+ gregorianFormatted: this.formatGregorianDate(today),
342
+ hijriDate: {
343
+ ...hijri,
344
+ monthName: this.translations().hijriMonths[hijri.month - 1]
345
+ },
346
+ hijriFormatted: this.formatHijriDate(hijri),
347
+ calendarType: this.internalCalendarType(),
348
+ locale: this.locale()
349
+ };
350
+ this.onChange(today);
351
+ this.onTouched();
352
+ this.dateChange.emit(output);
353
+ this.isOpen.set(false);
354
+ }
355
+ clearDate() {
356
+ this.selectedDate.set(null);
357
+ this.onChange(null);
358
+ this.onTouched();
359
+ this.dateChange.emit(null);
360
+ this.isOpen.set(false);
361
+ }
362
+ // ==================== UI INTERACTIONS ====================
363
+ toggleCalendar() {
364
+ const wasOpen = this.isOpen();
365
+ this.isOpen.update(val => !val);
366
+ this.calendarToggle.emit(this.isOpen());
367
+ if (!wasOpen && this.isOpen()) {
368
+ const reference = this.selectedDate() || new Date();
369
+ this.currentMonth.set(reference.getMonth());
370
+ this.currentYear.set(reference.getFullYear());
371
+ const hijri = this.hijriService.gregorianToHijri(reference);
372
+ this.currentHijriYear.set(hijri.year);
373
+ this.currentHijriMonth.set(hijri.month);
374
+ }
375
+ }
376
+ setCalendarType(type) {
377
+ this.internalCalendarType.set(type);
378
+ const referenceDate = this.selectedDate() || new Date();
379
+ if (type === 'hijri') {
380
+ const hijri = this.hijriService.gregorianToHijri(referenceDate);
381
+ this.currentHijriYear.set(hijri.year);
382
+ this.currentHijriMonth.set(hijri.month);
383
+ }
384
+ else {
385
+ this.currentMonth.set(referenceDate.getMonth());
386
+ this.currentYear.set(referenceDate.getFullYear());
387
+ }
388
+ }
389
+ onClickOutside() {
390
+ if (this.isOpen()) {
391
+ this.isOpen.set(false);
392
+ }
393
+ }
394
+ // ==================== HELPERS ====================
395
+ isSelected(day) {
396
+ if (!day.date || day.isEmpty)
397
+ return false;
398
+ const timestamp = this.selectedDateTimestamp();
399
+ if (!timestamp)
400
+ return false;
401
+ const dayTimestamp = new Date(day.date.getFullYear(), day.date.getMonth(), day.date.getDate()).getTime();
402
+ return dayTimestamp === timestamp;
403
+ }
404
+ isToday(day) {
405
+ if (!day.date || day.isEmpty)
406
+ return false;
407
+ const dayTimestamp = new Date(day.date.getFullYear(), day.date.getMonth(), day.date.getDate()).getTime();
408
+ return dayTimestamp === this.todayTimestamp;
409
+ }
410
+ // ==================== FORMATTING ====================
411
+ formatGregorianDate(date) {
412
+ const day = date.getDate().toString().padStart(2, '0');
413
+ const month = (date.getMonth() + 1).toString().padStart(2, '0');
414
+ const year = date.getFullYear();
415
+ return `${day}/${month}/${year}`;
416
+ }
417
+ formatHijriDate(hijri) {
418
+ const monthName = this.translations().hijriMonths[hijri.month - 1];
419
+ const suffix = this.locale() === 'ar' ? 'هـ' : 'AH';
420
+ return `${hijri.day} ${monthName} ${hijri.year} ${suffix}`;
421
+ }
422
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: NgMoDatePicker, deps: [], target: i0.ɵɵFactoryTarget.Component });
423
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.6", type: NgMoDatePicker, isStandalone: true, selector: "ng-mo-date-picker", inputs: { calendarType: { classPropertyName: "calendarType", publicName: "calendarType", isSignal: true, isRequired: false, transformFunction: null }, locale: { classPropertyName: "locale", publicName: "locale", isSignal: true, isRequired: false, transformFunction: null }, showIcon: { classPropertyName: "showIcon", publicName: "showIcon", isSignal: true, isRequired: false, transformFunction: null }, customIcon: { classPropertyName: "customIcon", publicName: "customIcon", isSignal: true, isRequired: false, transformFunction: null }, inputClass: { classPropertyName: "inputClass", publicName: "inputClass", isSignal: true, isRequired: false, transformFunction: null }, calendarClass: { classPropertyName: "calendarClass", publicName: "calendarClass", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { dateChange: "dateChange", calendarToggle: "calendarToggle" }, providers: [
424
+ {
425
+ provide: NG_VALUE_ACCESSOR,
426
+ useExisting: forwardRef(() => NgMoDatePicker),
427
+ multi: true
428
+ }
429
+ ], ngImport: i0, template: "<div [ngClass]=\"wrapperCssClasses()\" moClickOutside (clickOutside)=\"onClickOutside()\">\r\n <div class=\"mo-input-container\">\r\n <input type=\"text\" [value]=\"formattedDate()\" (click)=\"!disabled() && toggleCalendar()\" [disabled]=\"disabled()\"\r\n [readonly]=\"readonly()\" [placeholder]=\"placeholderText()\" [name]=\"name()\" [id]=\"id()\"\r\n [ngClass]=\"inputCssClasses()\" />\r\n\r\n @if (showIcon()) {\r\n <button type=\"button\" (click)=\"!disabled() && toggleCalendar()\" [disabled]=\"disabled()\"\r\n [ngClass]=\"iconBtnCssClasses()\">\r\n {{ customIcon() }}\r\n </button>\r\n }\r\n </div>\r\n\r\n @if (isOpen()) {\r\n <div [ngClass]=\"calendarCssClasses()\">\r\n\r\n <div class=\"mo-toggle-container\">\r\n <button (click)=\"setCalendarType('gregorian')\" class=\"mo-toggle-btn\"\r\n [class.active]=\"internalCalendarType() === 'gregorian'\">\r\n {{ translations().gregorian }}\r\n </button>\r\n\r\n <button (click)=\"setCalendarType('hijri')\" class=\"mo-toggle-btn\"\r\n [class.active]=\"internalCalendarType() === 'hijri'\">\r\n {{ translations().hijri }}\r\n </button>\r\n </div>\r\n\r\n <div class=\"mo-nav\">\r\n <button (click)=\"previousMonth()\" class=\"mo-nav-btn\">\r\n \u2039\r\n </button>\r\n\r\n <span class=\"mo-month-year\">\r\n {{ monthName() }} {{ currentYearDisplay() }}\r\n </span>\r\n\r\n <button (click)=\"nextMonth()\" class=\"mo-nav-btn\">\r\n \u203A\r\n </button>\r\n </div>\r\n\r\n <div class=\"mo-days-header\">\r\n @for (day of daysShortNames(); track $index) {\r\n <div class=\"mo-day-name\">{{ day }}</div>\r\n }\r\n </div>\r\n\r\n <div class=\"mo-days-grid\">\r\n @for (day of days(); track $index) {\r\n @if (day.isEmpty) {\r\n <div class=\"mo-day empty\"></div>\r\n } @else {\r\n <button (click)=\"selectDate(day)\" class=\"mo-day\" [class.selected]=\"isSelected(day)\"\r\n [class.today]=\"isToday(day) && !isSelected(day)\">\r\n {{ day.day }}\r\n </button>\r\n }\r\n }\r\n </div>\r\n\r\n <div class=\"mo-footer\">\r\n <button (click)=\"selectToday()\" class=\"mo-footer-btn\">\r\n {{ translations().today }}\r\n </button>\r\n\r\n <button (click)=\"clearDate()\" class=\"mo-footer-btn\">\r\n {{ translations().clear }}\r\n </button>\r\n </div>\r\n\r\n </div>\r\n }\r\n</div>", styles: [".mo-datepicker-wrapper{position:relative;display:inline-block;width:100%;max-width:320px;font-family:Arial,sans-serif}.mo-datepicker-wrapper.rtl{direction:rtl}.mo-datepicker-wrapper.ltr{direction:ltr}.mo-input-container{position:relative;display:flex;align-items:center}.mo-input{width:100%;cursor:pointer;border-radius:.375rem;border:1px solid #d1d5db;background:#fff;padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.mo-input:hover{border-color:#3b82f6}.mo-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.mo-input.rtl{text-align:right;padding-left:2.5rem}.mo-input.ltr{text-align:left;padding-right:2.5rem}.mo-input:disabled{background:#f3f4f6;cursor:not-allowed}.mo-icon-btn{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1.25rem;color:#6b7280;transition:color .2s;padding:.25rem}.mo-icon-btn:hover{color:#3b82f6}.mo-icon-btn.rtl{left:.5rem}.mo-icon-btn.ltr{right:.5rem}.mo-calendar{position:absolute;top:calc(100% + .5rem);z-index:1000;width:100%;max-width:320px;border-radius:.5rem;border:1px solid #e5e7eb;background:#fff;box-shadow:0 10px 25px #0000001a;padding:1rem}.mo-calendar.rtl{right:0}.mo-calendar.ltr{left:0}.mo-toggle-container{display:flex;gap:.5rem;margin-bottom:.75rem}.mo-toggle-btn{flex:1;border-radius:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;transition:all .2s;cursor:pointer;border:none;background:#f3f4f6;color:#374151}.mo-toggle-btn.active{background:#3b82f6;color:#fff}.mo-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.mo-nav-btn{background:none;border:none;cursor:pointer;padding:0 .5rem;font-size:1.5rem;color:#6b7280;transition:color .2s}.mo-nav-btn:hover{color:#3b82f6}.mo-month-year{font-size:.875rem;font-weight:600;color:#111827}.mo-days-header{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.mo-day-name{text-align:center;font-size:.75rem;font-weight:600;color:#6b7280;padding:.25rem}.mo-days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.mo-day{width:100%;aspect-ratio:1;border:none;background:none;cursor:pointer;border-radius:.25rem;font-size:.875rem;transition:all .2s;display:flex;align-items:center;justify-content:center;color:#374151}.mo-day:hover{background:#e0f2fe;color:#1e40af}.mo-day.selected{background:#1e40af;color:#fff;font-weight:600}.mo-day.today{background:#dbeafe;color:#2563eb;font-weight:600}.mo-day.empty{display:none}.mo-footer{display:flex;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.mo-footer-btn{flex:1;padding:.5rem;border:1px solid #d1d5db;background:#fff;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s;color:#374151}.mo-footer-btn:hover{background:#f9fafb;border-color:#3b82f6;color:#3b82f6}@media(max-width:480px){.mo-calendar{max-width:100%;padding:.75rem}.mo-day{font-size:.8rem}.mo-toggle-btn{font-size:.7rem}.mo-footer-btn{font-size:.8rem;padding:.4rem}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: ClickOutside, selector: "[moClickOutside]", outputs: ["clickOutside"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
430
+ }
431
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.6", ngImport: i0, type: NgMoDatePicker, decorators: [{
432
+ type: Component,
433
+ args: [{ selector: 'ng-mo-date-picker', imports: [CommonModule, ClickOutside], providers: [
434
+ {
435
+ provide: NG_VALUE_ACCESSOR,
436
+ useExisting: forwardRef(() => NgMoDatePicker),
437
+ multi: true
438
+ }
439
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngClass]=\"wrapperCssClasses()\" moClickOutside (clickOutside)=\"onClickOutside()\">\r\n <div class=\"mo-input-container\">\r\n <input type=\"text\" [value]=\"formattedDate()\" (click)=\"!disabled() && toggleCalendar()\" [disabled]=\"disabled()\"\r\n [readonly]=\"readonly()\" [placeholder]=\"placeholderText()\" [name]=\"name()\" [id]=\"id()\"\r\n [ngClass]=\"inputCssClasses()\" />\r\n\r\n @if (showIcon()) {\r\n <button type=\"button\" (click)=\"!disabled() && toggleCalendar()\" [disabled]=\"disabled()\"\r\n [ngClass]=\"iconBtnCssClasses()\">\r\n {{ customIcon() }}\r\n </button>\r\n }\r\n </div>\r\n\r\n @if (isOpen()) {\r\n <div [ngClass]=\"calendarCssClasses()\">\r\n\r\n <div class=\"mo-toggle-container\">\r\n <button (click)=\"setCalendarType('gregorian')\" class=\"mo-toggle-btn\"\r\n [class.active]=\"internalCalendarType() === 'gregorian'\">\r\n {{ translations().gregorian }}\r\n </button>\r\n\r\n <button (click)=\"setCalendarType('hijri')\" class=\"mo-toggle-btn\"\r\n [class.active]=\"internalCalendarType() === 'hijri'\">\r\n {{ translations().hijri }}\r\n </button>\r\n </div>\r\n\r\n <div class=\"mo-nav\">\r\n <button (click)=\"previousMonth()\" class=\"mo-nav-btn\">\r\n \u2039\r\n </button>\r\n\r\n <span class=\"mo-month-year\">\r\n {{ monthName() }} {{ currentYearDisplay() }}\r\n </span>\r\n\r\n <button (click)=\"nextMonth()\" class=\"mo-nav-btn\">\r\n \u203A\r\n </button>\r\n </div>\r\n\r\n <div class=\"mo-days-header\">\r\n @for (day of daysShortNames(); track $index) {\r\n <div class=\"mo-day-name\">{{ day }}</div>\r\n }\r\n </div>\r\n\r\n <div class=\"mo-days-grid\">\r\n @for (day of days(); track $index) {\r\n @if (day.isEmpty) {\r\n <div class=\"mo-day empty\"></div>\r\n } @else {\r\n <button (click)=\"selectDate(day)\" class=\"mo-day\" [class.selected]=\"isSelected(day)\"\r\n [class.today]=\"isToday(day) && !isSelected(day)\">\r\n {{ day.day }}\r\n </button>\r\n }\r\n }\r\n </div>\r\n\r\n <div class=\"mo-footer\">\r\n <button (click)=\"selectToday()\" class=\"mo-footer-btn\">\r\n {{ translations().today }}\r\n </button>\r\n\r\n <button (click)=\"clearDate()\" class=\"mo-footer-btn\">\r\n {{ translations().clear }}\r\n </button>\r\n </div>\r\n\r\n </div>\r\n }\r\n</div>", styles: [".mo-datepicker-wrapper{position:relative;display:inline-block;width:100%;max-width:320px;font-family:Arial,sans-serif}.mo-datepicker-wrapper.rtl{direction:rtl}.mo-datepicker-wrapper.ltr{direction:ltr}.mo-input-container{position:relative;display:flex;align-items:center}.mo-input{width:100%;cursor:pointer;border-radius:.375rem;border:1px solid #d1d5db;background:#fff;padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.mo-input:hover{border-color:#3b82f6}.mo-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.mo-input.rtl{text-align:right;padding-left:2.5rem}.mo-input.ltr{text-align:left;padding-right:2.5rem}.mo-input:disabled{background:#f3f4f6;cursor:not-allowed}.mo-icon-btn{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1.25rem;color:#6b7280;transition:color .2s;padding:.25rem}.mo-icon-btn:hover{color:#3b82f6}.mo-icon-btn.rtl{left:.5rem}.mo-icon-btn.ltr{right:.5rem}.mo-calendar{position:absolute;top:calc(100% + .5rem);z-index:1000;width:100%;max-width:320px;border-radius:.5rem;border:1px solid #e5e7eb;background:#fff;box-shadow:0 10px 25px #0000001a;padding:1rem}.mo-calendar.rtl{right:0}.mo-calendar.ltr{left:0}.mo-toggle-container{display:flex;gap:.5rem;margin-bottom:.75rem}.mo-toggle-btn{flex:1;border-radius:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;transition:all .2s;cursor:pointer;border:none;background:#f3f4f6;color:#374151}.mo-toggle-btn.active{background:#3b82f6;color:#fff}.mo-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.mo-nav-btn{background:none;border:none;cursor:pointer;padding:0 .5rem;font-size:1.5rem;color:#6b7280;transition:color .2s}.mo-nav-btn:hover{color:#3b82f6}.mo-month-year{font-size:.875rem;font-weight:600;color:#111827}.mo-days-header{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.mo-day-name{text-align:center;font-size:.75rem;font-weight:600;color:#6b7280;padding:.25rem}.mo-days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem}.mo-day{width:100%;aspect-ratio:1;border:none;background:none;cursor:pointer;border-radius:.25rem;font-size:.875rem;transition:all .2s;display:flex;align-items:center;justify-content:center;color:#374151}.mo-day:hover{background:#e0f2fe;color:#1e40af}.mo-day.selected{background:#1e40af;color:#fff;font-weight:600}.mo-day.today{background:#dbeafe;color:#2563eb;font-weight:600}.mo-day.empty{display:none}.mo-footer{display:flex;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.mo-footer-btn{flex:1;padding:.5rem;border:1px solid #d1d5db;background:#fff;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s;color:#374151}.mo-footer-btn:hover{background:#f9fafb;border-color:#3b82f6;color:#3b82f6}@media(max-width:480px){.mo-calendar{max-width:100%;padding:.75rem}.mo-day{font-size:.8rem}.mo-toggle-btn{font-size:.7rem}.mo-footer-btn{font-size:.8rem;padding:.4rem}}\n"] }]
440
+ }], ctorParameters: () => [], propDecorators: { calendarType: [{ type: i0.Input, args: [{ isSignal: true, alias: "calendarType", required: false }] }], locale: [{ type: i0.Input, args: [{ isSignal: true, alias: "locale", required: false }] }], showIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "showIcon", required: false }] }], customIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "customIcon", required: false }] }], inputClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "inputClass", required: false }] }], calendarClass: [{ type: i0.Input, args: [{ isSignal: true, alias: "calendarClass", required: false }] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "disabled", required: false }] }], readonly: [{ type: i0.Input, args: [{ isSignal: true, alias: "readonly", required: false }] }], placeholder: [{ type: i0.Input, args: [{ isSignal: true, alias: "placeholder", required: false }] }], name: [{ type: i0.Input, args: [{ isSignal: true, alias: "name", required: false }] }], id: [{ type: i0.Input, args: [{ isSignal: true, alias: "id", required: false }] }], dateChange: [{ type: i0.Output, args: ["dateChange"] }], calendarToggle: [{ type: i0.Output, args: ["calendarToggle"] }] } });
441
+
442
+ /*
443
+ * Public API Surface of ng-mo-date-picker
444
+ */
445
+
446
+ /**
447
+ * Generated bundle index. Do not edit.
448
+ */
449
+
450
+ export { ClickOutside, HijriConverterService, NgMoDatePicker };
451
+ //# sourceMappingURL=ng-mo-date-picker.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ng-mo-date-picker.mjs","sources":["../../../projects/ng-mo-date-picker/src/lib/services/hijri-converter.service.ts","../../../projects/ng-mo-date-picker/src/lib/directives/click-outside.ts","../../../projects/ng-mo-date-picker/src/lib/constants/translations.ts","../../../projects/ng-mo-date-picker/src/lib/components/ng-mo-date-picker/ng-mo-date-picker.ts","../../../projects/ng-mo-date-picker/src/lib/components/ng-mo-date-picker/ng-mo-date-picker.html","../../../projects/ng-mo-date-picker/src/public-api.ts","../../../projects/ng-mo-date-picker/src/ng-mo-date-picker.ts"],"sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport moment from 'moment-hijri';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class HijriConverterService {\r\n\r\n gregorianToHijri(date: Date) {\r\n const m = moment(date);\r\n\r\n return {\r\n year: m.iYear(),\r\n month: m.iMonth() + 1,\r\n day: m.iDate()\r\n };\r\n }\r\n\r\n hijriToGregorian(year: number, month: number, day: number): Date {\r\n const m = moment(`${year}/${month}/${day}`, 'iYYYY/iM/iD');\r\n return m.toDate();\r\n }\r\n\r\n\r\n getMonthName(month: number): string {\r\n const months = ['محرم', 'صفر', 'ربيع الأول', 'ربيع الآخر',\r\n 'جمادى الأولى', 'جمادى الآخرة', 'رجب', 'شعبان',\r\n 'رمضان', 'شوال', 'ذو القعدة', 'ذو الحجة'];\r\n return months[month - 1];\r\n }\r\n}","import { Directive, ElementRef, HostListener, inject, output } from '@angular/core';\r\n\r\n@Directive({\r\n selector: '[moClickOutside]',\r\n})\r\nexport class ClickOutside {\r\n\r\n clickOutside = output<void>();\r\n\r\n private elementRef = inject(ElementRef);\r\n\r\n\r\n @HostListener('document:click', ['$event'])\r\n onClick(event: MouseEvent) {\r\n const target = event.target as HTMLElement;\r\n if (!target) return;\r\n\r\n const clickedInside = this.elementRef.nativeElement.contains(target);\r\n if (!clickedInside) {\r\n this.clickOutside.emit();\r\n }\r\n }\r\n\r\n}\r\n","export const TRANSLATIONS = {\r\n ar: {\r\n gregorianMonths: ['يناير', 'فبراير', 'مارس', 'أبريل', 'مايو', 'يونيو',\r\n 'يوليو', 'أغسطس', 'سبتمبر', 'أكتوبر', 'نوفمبر', 'ديسمبر'],\r\n hijriMonths: ['محرم', 'صفر', 'ربيع الأول', 'ربيع الآخر', 'جمادى الأولى',\r\n 'جمادى الآخرة', 'رجب', 'شعبان', 'رمضان', 'شوال', 'ذو القعدة', 'ذو الحجة'],\r\n days: ['ح', 'ن', 'ث', 'ر', 'خ', 'ج', 'س'],\r\n today: 'اليوم',\r\n clear: 'مسح',\r\n gregorian: 'ميلادي',\r\n hijri: 'هجري',\r\n placeholder: 'اختر تاريخ'\r\n },\r\n en: {\r\n gregorianMonths: ['January', 'February', 'March', 'April', 'May', 'June',\r\n 'July', 'August', 'September', 'October', 'November', 'December'],\r\n hijriMonths: ['Muharram', 'Safar', 'Rabi al-Awwal', 'Rabi al-Thani', 'Jumada al-Awwal',\r\n 'Jumada al-Thani', 'Rajab', 'Shaban', 'Ramadan', 'Shawwal', 'Dhu al-Qadah', 'Dhu al-Hijjah'],\r\n days: ['S', 'M', 'T', 'W', 'T', 'F', 'S'],\r\n today: 'Today',\r\n clear: 'Clear',\r\n gregorian: 'Gregorian',\r\n hijri: 'Hijri',\r\n placeholder: 'Select date'\r\n }\r\n} as const;\r\n\r\nexport type Locale = keyof typeof TRANSLATIONS;","import { ChangeDetectionStrategy, Component, computed, effect, forwardRef, inject, input, output, signal } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nimport { HijriConverterService } from '../../services/hijri-converter.service';\r\nimport { ClickOutside } from '../../directives/click-outside';\r\nimport { DatePickerOutput } from '../../interfaces/idatepicker';\r\nimport { TRANSLATIONS } from '../../constants/translations';\r\n\r\n@Component({\r\n selector: 'ng-mo-date-picker',\r\n imports: [CommonModule, ClickOutside],\r\n providers: [\r\n {\r\n provide: NG_VALUE_ACCESSOR,\r\n useExisting: forwardRef(() => NgMoDatePicker),\r\n multi: true\r\n }\r\n ],\r\n templateUrl: './ng-mo-date-picker.html',\r\n styleUrls: ['./ng-mo-date-picker.css'],\r\n changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class NgMoDatePicker {\r\n\r\n // ==================== INPUTS ====================\r\n calendarType = input<'gregorian' | 'hijri'>('gregorian');\r\n locale = input<'ar' | 'en'>('ar');\r\n showIcon = input<boolean>(true);\r\n customIcon = input<string>('📅');\r\n inputClass = input<string>('');\r\n calendarClass = input<string>('');\r\n disabled = input<boolean>(false);\r\n readonly = input<boolean>(false);\r\n placeholder = input<string | undefined>(undefined);\r\n name = input<string | undefined>(undefined);\r\n id = input<string | undefined>(undefined);\r\n\r\n // ==================== OUTPUTS ====================\r\n dateChange = output<DatePickerOutput | null>();\r\n calendarToggle = output<boolean>();\r\n\r\n // ==================== SERVICES ====================\r\n private hijriService = inject(HijriConverterService);\r\n\r\n // ==================== STATE SIGNALS ====================\r\n internalCalendarType = signal<'gregorian' | 'hijri'>('gregorian');\r\n selectedDate = signal<Date | null>(null);\r\n isOpen = signal<boolean>(false);\r\n\r\n // Gregorian state\r\n currentMonth = signal<number>(new Date().getMonth());\r\n currentYear = signal<number>(new Date().getFullYear());\r\n\r\n // Hijri state\r\n currentHijriMonth = signal<number>(1);\r\n currentHijriYear = signal<number>(1446);\r\n\r\n // Calendar days\r\n days = signal<Array<{\r\n date: Date | null;\r\n day: number | null;\r\n isEmpty: boolean;\r\n }>>([]);\r\n\r\n // ==================== COMPUTED SIGNALS ====================\r\n translations = computed(() => TRANSLATIONS[this.locale()]);\r\n\r\n daysShortNames = computed(() => this.translations().days);\r\n\r\n monthName = computed(() => {\r\n if (this.internalCalendarType() === 'hijri') {\r\n return this.translations().hijriMonths[this.currentHijriMonth() - 1];\r\n }\r\n return this.translations().gregorianMonths[this.currentMonth()];\r\n });\r\n\r\n currentYearDisplay = computed(() =>\r\n this.internalCalendarType() === 'hijri'\r\n ? this.currentHijriYear()\r\n : this.currentYear()\r\n );\r\n\r\n formattedDate = computed(() => {\r\n if (!this.selectedDate()) return '';\r\n const date = this.selectedDate()!;\r\n if (this.internalCalendarType() === 'hijri') {\r\n const hijri = this.hijriService.gregorianToHijri(date);\r\n return `${hijri.day}/${hijri.month}/${hijri.year}`;\r\n }\r\n return this.formatGregorianDate(date);\r\n });\r\n\r\n placeholderText = computed(() =>\r\n this.placeholder() || this.translations().placeholder\r\n );\r\n\r\n // CSS Classes Computed Signals\r\n wrapperCssClasses = computed(() => ({\r\n 'mo-datepicker-wrapper': true,\r\n 'rtl': this.locale() === 'ar',\r\n 'ltr': this.locale() === 'en'\r\n }));\r\n\r\n inputCssClasses = computed(() => ({\r\n 'mo-input': true,\r\n 'rtl': this.locale() === 'ar',\r\n 'ltr': this.locale() === 'en',\r\n [this.inputClass()]: !!this.inputClass()\r\n }));\r\n\r\n iconBtnCssClasses = computed(() => ({\r\n 'mo-icon-btn': true,\r\n 'rtl': this.locale() === 'ar',\r\n 'ltr': this.locale() === 'en'\r\n }));\r\n\r\n calendarCssClasses = computed(() => ({\r\n 'mo-calendar': true,\r\n 'rtl': this.locale() === 'ar',\r\n 'ltr': this.locale() === 'en',\r\n [this.calendarClass()]: !!this.calendarClass()\r\n }));\r\n\r\n // Date Comparison Optimization\r\n private selectedDateTimestamp = computed(() => {\r\n const date = this.selectedDate();\r\n if (!date) return null;\r\n return new Date(date.getFullYear(), date.getMonth(), date.getDate()).getTime();\r\n });\r\n\r\n private readonly todayTimestamp = (() => {\r\n const today = new Date();\r\n return new Date(today.getFullYear(), today.getMonth(), today.getDate()).getTime();\r\n })();\r\n\r\n // ==================== FORMS INTEGRATION ====================\r\n private onChange: any = () => { };\r\n private onTouched: any = () => { };\r\n\r\n writeValue(value: Date | null): void {\r\n this.selectedDate.set(value);\r\n }\r\n\r\n registerOnChange(fn: any): void {\r\n this.onChange = fn;\r\n }\r\n\r\n registerOnTouched(fn: any): void {\r\n this.onTouched = fn;\r\n }\r\n\r\n // ==================== LIFECYCLE ====================\r\n constructor() {\r\n const today = new Date();\r\n const hijriToday = this.hijriService.gregorianToHijri(today);\r\n this.currentHijriYear.set(hijriToday.year);\r\n this.currentHijriMonth.set(hijriToday.month);\r\n\r\n effect(() => {\r\n this.internalCalendarType.set(this.calendarType());\r\n });\r\n\r\n effect(() => {\r\n this.currentMonth();\r\n this.currentYear();\r\n this.currentHijriMonth();\r\n this.currentHijriYear();\r\n this.internalCalendarType();\r\n this.generateCalendar();\r\n });\r\n }\r\n\r\n // ==================== CALENDAR GENERATION ====================\r\n generateCalendar() {\r\n if (this.internalCalendarType() === 'hijri') {\r\n this.generateHijriCalendar();\r\n } else {\r\n this.generateGregorianCalendar();\r\n }\r\n }\r\n\r\n private generateGregorianCalendar() {\r\n const year = this.currentYear();\r\n const month = this.currentMonth();\r\n const firstDayOfMonth = new Date(year, month, 1);\r\n const lastDayOfMonth = new Date(year, month + 1, 0);\r\n const startDayOfWeek = firstDayOfMonth.getDay();\r\n const daysInMonth = lastDayOfMonth.getDate();\r\n\r\n const emptyDays = Array.from(\r\n { length: startDayOfWeek },\r\n () => ({\r\n date: null,\r\n day: null,\r\n isEmpty: true\r\n })\r\n );\r\n\r\n const monthDays = Array.from(\r\n { length: daysInMonth },\r\n (_, i) => ({\r\n date: new Date(year, month, i + 1),\r\n day: i + 1,\r\n isEmpty: false\r\n })\r\n );\r\n\r\n const totalUsedDays = emptyDays.length + monthDays.length;\r\n const remainingDays = Array.from(\r\n { length: 42 - totalUsedDays },\r\n () => ({\r\n date: null,\r\n day: null,\r\n isEmpty: true\r\n })\r\n );\r\n\r\n this.days.set([...emptyDays, ...monthDays, ...remainingDays]);\r\n }\r\n\r\n private generateHijriCalendar() {\r\n const year = this.currentHijriYear();\r\n const month = this.currentHijriMonth();\r\n\r\n const firstDayGregorian = this.hijriService.hijriToGregorian(year, month, 1);\r\n const startDayOfWeek = firstDayGregorian.getDay();\r\n\r\n const monthLengths = [30, 29, 30, 29, 30, 29, 30, 29, 30, 29, 30, 29];\r\n const daysInMonth = monthLengths[month - 1];\r\n\r\n const emptyDays = Array.from(\r\n { length: startDayOfWeek },\r\n () => ({\r\n date: null,\r\n day: null,\r\n isEmpty: true\r\n })\r\n );\r\n\r\n const monthDays = Array.from(\r\n { length: daysInMonth },\r\n (_, i) => {\r\n const gregorianDate = this.hijriService.hijriToGregorian(year, month, i + 1);\r\n return {\r\n date: gregorianDate,\r\n day: i + 1,\r\n isEmpty: false\r\n };\r\n }\r\n );\r\n\r\n const totalUsedDays = emptyDays.length + monthDays.length;\r\n const remainingDays = Array.from(\r\n { length: 42 - totalUsedDays },\r\n () => ({\r\n date: null,\r\n day: null,\r\n isEmpty: true\r\n })\r\n );\r\n\r\n this.days.set([...emptyDays, ...monthDays, ...remainingDays]);\r\n }\r\n\r\n // ==================== NAVIGATION ====================\r\n previousMonth() {\r\n if (this.internalCalendarType() === 'hijri') {\r\n if (this.currentHijriMonth() === 1) {\r\n this.currentHijriMonth.set(12);\r\n this.currentHijriYear.update(y => y - 1);\r\n } else {\r\n this.currentHijriMonth.update(m => m - 1);\r\n }\r\n } else {\r\n if (this.currentMonth() === 0) {\r\n this.currentMonth.set(11);\r\n this.currentYear.update(y => y - 1);\r\n } else {\r\n this.currentMonth.update(m => m - 1);\r\n }\r\n }\r\n }\r\n\r\n nextMonth() {\r\n if (this.internalCalendarType() === 'hijri') {\r\n if (this.currentHijriMonth() === 12) {\r\n this.currentHijriMonth.set(1);\r\n this.currentHijriYear.update(y => y + 1);\r\n } else {\r\n this.currentHijriMonth.update(m => m + 1);\r\n }\r\n } else {\r\n if (this.currentMonth() === 11) {\r\n this.currentMonth.set(0);\r\n this.currentYear.update(y => y + 1);\r\n } else {\r\n this.currentMonth.update(m => m + 1);\r\n }\r\n }\r\n }\r\n\r\n // ==================== DATE SELECTION ====================\r\n selectDate(day: { date: Date | null; day: number | null; isEmpty: boolean }) {\r\n if (day.isEmpty || !day.date) return;\r\n\r\n this.selectedDate.set(day.date);\r\n\r\n const hijri = this.hijriService.gregorianToHijri(day.date);\r\n\r\n const output: DatePickerOutput = {\r\n gregorianDate: day.date,\r\n gregorianFormatted: this.formatGregorianDate(day.date),\r\n hijriDate: {\r\n ...hijri,\r\n monthName: this.translations().hijriMonths[hijri.month - 1]\r\n },\r\n hijriFormatted: this.formatHijriDate(hijri),\r\n calendarType: this.internalCalendarType(),\r\n locale: this.locale()\r\n };\r\n\r\n this.onChange(day.date);\r\n this.onTouched();\r\n this.dateChange.emit(output);\r\n this.isOpen.set(false);\r\n }\r\n\r\n selectToday() {\r\n const today = new Date();\r\n this.selectedDate.set(today);\r\n this.currentMonth.set(today.getMonth());\r\n this.currentYear.set(today.getFullYear());\r\n\r\n const hijri = this.hijriService.gregorianToHijri(today);\r\n this.currentHijriYear.set(hijri.year);\r\n this.currentHijriMonth.set(hijri.month);\r\n\r\n const output: DatePickerOutput = {\r\n gregorianDate: today,\r\n gregorianFormatted: this.formatGregorianDate(today),\r\n hijriDate: {\r\n ...hijri,\r\n monthName: this.translations().hijriMonths[hijri.month - 1]\r\n },\r\n hijriFormatted: this.formatHijriDate(hijri),\r\n calendarType: this.internalCalendarType(),\r\n locale: this.locale()\r\n };\r\n\r\n this.onChange(today);\r\n this.onTouched();\r\n this.dateChange.emit(output);\r\n this.isOpen.set(false);\r\n }\r\n\r\n clearDate() {\r\n this.selectedDate.set(null);\r\n this.onChange(null);\r\n this.onTouched();\r\n this.dateChange.emit(null);\r\n this.isOpen.set(false);\r\n }\r\n\r\n // ==================== UI INTERACTIONS ====================\r\n toggleCalendar() {\r\n const wasOpen = this.isOpen();\r\n this.isOpen.update(val => !val);\r\n this.calendarToggle.emit(this.isOpen());\r\n\r\n if (!wasOpen && this.isOpen()) {\r\n const reference = this.selectedDate() || new Date();\r\n this.currentMonth.set(reference.getMonth());\r\n this.currentYear.set(reference.getFullYear());\r\n\r\n const hijri = this.hijriService.gregorianToHijri(reference);\r\n this.currentHijriYear.set(hijri.year);\r\n this.currentHijriMonth.set(hijri.month);\r\n }\r\n }\r\n\r\n setCalendarType(type: 'gregorian' | 'hijri') {\r\n this.internalCalendarType.set(type);\r\n const referenceDate = this.selectedDate() || new Date();\r\n\r\n if (type === 'hijri') {\r\n const hijri = this.hijriService.gregorianToHijri(referenceDate);\r\n this.currentHijriYear.set(hijri.year);\r\n this.currentHijriMonth.set(hijri.month);\r\n } else {\r\n this.currentMonth.set(referenceDate.getMonth());\r\n this.currentYear.set(referenceDate.getFullYear());\r\n }\r\n }\r\n\r\n onClickOutside() {\r\n if (this.isOpen()) {\r\n this.isOpen.set(false);\r\n }\r\n }\r\n\r\n // ==================== HELPERS ====================\r\n isSelected(day: { date: Date | null; day: number | null; isEmpty: boolean }): boolean {\r\n if (!day.date || day.isEmpty) return false;\r\n const timestamp = this.selectedDateTimestamp();\r\n if (!timestamp) return false;\r\n\r\n const dayTimestamp = new Date(\r\n day.date.getFullYear(),\r\n day.date.getMonth(),\r\n day.date.getDate()\r\n ).getTime();\r\n\r\n return dayTimestamp === timestamp;\r\n }\r\n\r\n isToday(day: { date: Date | null; day: number | null; isEmpty: boolean }): boolean {\r\n if (!day.date || day.isEmpty) return false;\r\n\r\n const dayTimestamp = new Date(\r\n day.date.getFullYear(),\r\n day.date.getMonth(),\r\n day.date.getDate()\r\n ).getTime();\r\n\r\n return dayTimestamp === this.todayTimestamp;\r\n }\r\n\r\n // ==================== FORMATTING ====================\r\n private formatGregorianDate(date: Date): string {\r\n const day = date.getDate().toString().padStart(2, '0');\r\n const month = (date.getMonth() + 1).toString().padStart(2, '0');\r\n const year = date.getFullYear();\r\n return `${day}/${month}/${year}`;\r\n }\r\n\r\n private formatHijriDate(hijri: { year: number; month: number; day: number }): string {\r\n const monthName = this.translations().hijriMonths[hijri.month - 1];\r\n const suffix = this.locale() === 'ar' ? 'هـ' : 'AH';\r\n return `${hijri.day} ${monthName} ${hijri.year} ${suffix}`;\r\n }\r\n}","<div [ngClass]=\"wrapperCssClasses()\" moClickOutside (clickOutside)=\"onClickOutside()\">\r\n <div class=\"mo-input-container\">\r\n <input type=\"text\" [value]=\"formattedDate()\" (click)=\"!disabled() && toggleCalendar()\" [disabled]=\"disabled()\"\r\n [readonly]=\"readonly()\" [placeholder]=\"placeholderText()\" [name]=\"name()\" [id]=\"id()\"\r\n [ngClass]=\"inputCssClasses()\" />\r\n\r\n @if (showIcon()) {\r\n <button type=\"button\" (click)=\"!disabled() && toggleCalendar()\" [disabled]=\"disabled()\"\r\n [ngClass]=\"iconBtnCssClasses()\">\r\n {{ customIcon() }}\r\n </button>\r\n }\r\n </div>\r\n\r\n @if (isOpen()) {\r\n <div [ngClass]=\"calendarCssClasses()\">\r\n\r\n <div class=\"mo-toggle-container\">\r\n <button (click)=\"setCalendarType('gregorian')\" class=\"mo-toggle-btn\"\r\n [class.active]=\"internalCalendarType() === 'gregorian'\">\r\n {{ translations().gregorian }}\r\n </button>\r\n\r\n <button (click)=\"setCalendarType('hijri')\" class=\"mo-toggle-btn\"\r\n [class.active]=\"internalCalendarType() === 'hijri'\">\r\n {{ translations().hijri }}\r\n </button>\r\n </div>\r\n\r\n <div class=\"mo-nav\">\r\n <button (click)=\"previousMonth()\" class=\"mo-nav-btn\">\r\n ‹\r\n </button>\r\n\r\n <span class=\"mo-month-year\">\r\n {{ monthName() }} {{ currentYearDisplay() }}\r\n </span>\r\n\r\n <button (click)=\"nextMonth()\" class=\"mo-nav-btn\">\r\n ›\r\n </button>\r\n </div>\r\n\r\n <div class=\"mo-days-header\">\r\n @for (day of daysShortNames(); track $index) {\r\n <div class=\"mo-day-name\">{{ day }}</div>\r\n }\r\n </div>\r\n\r\n <div class=\"mo-days-grid\">\r\n @for (day of days(); track $index) {\r\n @if (day.isEmpty) {\r\n <div class=\"mo-day empty\"></div>\r\n } @else {\r\n <button (click)=\"selectDate(day)\" class=\"mo-day\" [class.selected]=\"isSelected(day)\"\r\n [class.today]=\"isToday(day) && !isSelected(day)\">\r\n {{ day.day }}\r\n </button>\r\n }\r\n }\r\n </div>\r\n\r\n <div class=\"mo-footer\">\r\n <button (click)=\"selectToday()\" class=\"mo-footer-btn\">\r\n {{ translations().today }}\r\n </button>\r\n\r\n <button (click)=\"clearDate()\" class=\"mo-footer-btn\">\r\n {{ translations().clear }}\r\n </button>\r\n </div>\r\n\r\n </div>\r\n }\r\n</div>","/*\r\n * Public API Surface of ng-mo-date-picker\r\n */\r\n\r\nexport * from './lib/services/hijri-converter.service';\r\nexport * from './lib/components/ng-mo-date-picker/ng-mo-date-picker';\r\nexport * from './lib/directives/click-outside';\r\nexport type { DatePickerOutput } from './lib/interfaces/idatepicker';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;;;;;;MAMa,qBAAqB,CAAA;AAEhC,IAAA,gBAAgB,CAAC,IAAU,EAAA;AACzB,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC;QAEtB,OAAO;AACL,YAAA,IAAI,EAAE,CAAC,CAAC,KAAK,EAAE;AACf,YAAA,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,GAAG,CAAC;AACrB,YAAA,GAAG,EAAE,CAAC,CAAC,KAAK;SACb;IACH;AAEA,IAAA,gBAAgB,CAAC,IAAY,EAAE,KAAa,EAAE,GAAW,EAAA;AACvD,QAAA,MAAM,CAAC,GAAG,MAAM,CAAC,GAAG,IAAI,CAAA,CAAA,EAAI,KAAK,CAAA,CAAA,EAAI,GAAG,CAAA,CAAE,EAAE,aAAa,CAAC;AAC1D,QAAA,OAAO,CAAC,CAAC,MAAM,EAAE;IACnB;AAGA,IAAA,YAAY,CAAC,KAAa,EAAA;QACxB,MAAM,MAAM,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,YAAY;AACvD,YAAA,cAAc,EAAE,cAAc,EAAE,KAAK,EAAE,OAAO;AAC9C,YAAA,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,CAAC;AAC3C,QAAA,OAAO,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;IAC1B;uGAvBW,qBAAqB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA;AAArB,IAAA,OAAA,KAAA,GAAA,EAAA,CAAA,qBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,qBAAqB,cAFpB,MAAM,EAAA,CAAA;;2FAEP,qBAAqB,EAAA,UAAA,EAAA,CAAA;kBAHjC,UAAU;AAAC,YAAA,IAAA,EAAA,CAAA;AACV,oBAAA,UAAU,EAAE;AACb,iBAAA;;;MCAY,YAAY,CAAA;IAEvB,YAAY,GAAG,MAAM,EAAQ;AAErB,IAAA,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;AAIvC,IAAA,OAAO,CAAC,KAAiB,EAAA;AACvB,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB;AAC1C,QAAA,IAAI,CAAC,MAAM;YAAE;AAEb,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC;QACpE,IAAI,CAAC,aAAa,EAAE;AAClB,YAAA,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE;QAC1B;IACF;uGAhBW,YAAY,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;2FAAZ,YAAY,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,OAAA,EAAA,EAAA,YAAA,EAAA,cAAA,EAAA,EAAA,IAAA,EAAA,EAAA,SAAA,EAAA,EAAA,gBAAA,EAAA,iBAAA,EAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA;;2FAAZ,YAAY,EAAA,UAAA,EAAA,CAAA;kBAHxB,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACT,oBAAA,QAAQ,EAAE,kBAAkB;AAC7B,iBAAA;;sBAQE,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;;;ACZrC,MAAM,YAAY,GAAG;AACxB,IAAA,EAAE,EAAE;AACA,QAAA,eAAe,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO;YACjE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC;QAC7D,WAAW,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,cAAc;AACnE,YAAA,cAAc,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,CAAC;AAC7E,QAAA,IAAI,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;AACzC,QAAA,KAAK,EAAE,OAAO;AACd,QAAA,KAAK,EAAE,KAAK;AACZ,QAAA,SAAS,EAAE,QAAQ;AACnB,QAAA,KAAK,EAAE,MAAM;AACb,QAAA,WAAW,EAAE;AAChB,KAAA;AACD,IAAA,EAAE,EAAE;AACA,QAAA,eAAe,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM;YACpE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,CAAC;QACrE,WAAW,EAAE,CAAC,UAAU,EAAE,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,iBAAiB;AAClF,YAAA,iBAAiB,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,EAAE,eAAe,CAAC;AAChG,QAAA,IAAI,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;AACzC,QAAA,KAAK,EAAE,OAAO;AACd,QAAA,KAAK,EAAE,OAAO;AACd,QAAA,SAAS,EAAE,WAAW;AACtB,QAAA,KAAK,EAAE,OAAO;AACd,QAAA,WAAW,EAAE;AAChB;CACK;;MCFG,cAAc,CAAA;;AAGzB,IAAA,YAAY,GAAG,KAAK,CAAwB,WAAW,wDAAC;AACxD,IAAA,MAAM,GAAG,KAAK,CAAc,IAAI,kDAAC;AACjC,IAAA,QAAQ,GAAG,KAAK,CAAU,IAAI,oDAAC;AAC/B,IAAA,UAAU,GAAG,KAAK,CAAS,IAAI,sDAAC;AAChC,IAAA,UAAU,GAAG,KAAK,CAAS,EAAE,sDAAC;AAC9B,IAAA,aAAa,GAAG,KAAK,CAAS,EAAE,yDAAC;AACjC,IAAA,QAAQ,GAAG,KAAK,CAAU,KAAK,oDAAC;AAChC,IAAA,QAAQ,GAAG,KAAK,CAAU,KAAK,oDAAC;AAChC,IAAA,WAAW,GAAG,KAAK,CAAqB,SAAS,uDAAC;AAClD,IAAA,IAAI,GAAG,KAAK,CAAqB,SAAS,gDAAC;AAC3C,IAAA,EAAE,GAAG,KAAK,CAAqB,SAAS,8CAAC;;IAGzC,UAAU,GAAG,MAAM,EAA2B;IAC9C,cAAc,GAAG,MAAM,EAAW;;AAG1B,IAAA,YAAY,GAAG,MAAM,CAAC,qBAAqB,CAAC;;AAGpD,IAAA,oBAAoB,GAAG,MAAM,CAAwB,WAAW,gEAAC;AACjE,IAAA,YAAY,GAAG,MAAM,CAAc,IAAI,wDAAC;AACxC,IAAA,MAAM,GAAG,MAAM,CAAU,KAAK,kDAAC;;IAG/B,YAAY,GAAG,MAAM,CAAS,IAAI,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,cAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;IACpD,WAAW,GAAG,MAAM,CAAS,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,aAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;;AAGtD,IAAA,iBAAiB,GAAG,MAAM,CAAS,CAAC,6DAAC;AACrC,IAAA,gBAAgB,GAAG,MAAM,CAAS,IAAI,4DAAC;;AAGvC,IAAA,IAAI,GAAG,MAAM,CAIT,EAAE,gDAAC;;AAGP,IAAA,YAAY,GAAG,QAAQ,CAAC,MAAM,YAAY,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,wDAAC;AAE1D,IAAA,cAAc,GAAG,QAAQ,CAAC,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC,IAAI,0DAAC;AAEzD,IAAA,SAAS,GAAG,QAAQ,CAAC,MAAK;AACxB,QAAA,IAAI,IAAI,CAAC,oBAAoB,EAAE,KAAK,OAAO,EAAE;AAC3C,YAAA,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,EAAE,GAAG,CAAC,CAAC;QACtE;AACA,QAAA,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;AACjE,IAAA,CAAC,qDAAC;IAEF,kBAAkB,GAAG,QAAQ,CAAC,MAC5B,IAAI,CAAC,oBAAoB,EAAE,KAAK;AAC9B,UAAE,IAAI,CAAC,gBAAgB;AACvB,UAAE,IAAI,CAAC,WAAW,EAAE,8DACvB;AAED,IAAA,aAAa,GAAG,QAAQ,CAAC,MAAK;AAC5B,QAAA,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;AAAE,YAAA,OAAO,EAAE;AACnC,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,EAAG;AACjC,QAAA,IAAI,IAAI,CAAC,oBAAoB,EAAE,KAAK,OAAO,EAAE;YAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,CAAC;AACtD,YAAA,OAAO,CAAA,EAAG,KAAK,CAAC,GAAG,CAAA,CAAA,EAAI,KAAK,CAAC,KAAK,CAAA,CAAA,EAAI,KAAK,CAAC,IAAI,EAAE;QACpD;AACA,QAAA,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC;AACvC,IAAA,CAAC,yDAAC;AAEF,IAAA,eAAe,GAAG,QAAQ,CAAC,MACzB,IAAI,CAAC,WAAW,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC,WAAW,2DACtD;;AAGD,IAAA,iBAAiB,GAAG,QAAQ,CAAC,OAAO;AAClC,QAAA,uBAAuB,EAAE,IAAI;AAC7B,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI;AAC7B,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK;AAC1B,KAAA,CAAC,6DAAC;AAEH,IAAA,eAAe,GAAG,QAAQ,CAAC,OAAO;AAChC,QAAA,UAAU,EAAE,IAAI;AAChB,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI;AAC7B,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI;QAC7B,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU;AACvC,KAAA,CAAC,2DAAC;AAEH,IAAA,iBAAiB,GAAG,QAAQ,CAAC,OAAO;AAClC,QAAA,aAAa,EAAE,IAAI;AACnB,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI;AAC7B,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK;AAC1B,KAAA,CAAC,6DAAC;AAEH,IAAA,kBAAkB,GAAG,QAAQ,CAAC,OAAO;AACnC,QAAA,aAAa,EAAE,IAAI;AACnB,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI;AAC7B,QAAA,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI;QAC7B,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,aAAa;AAC7C,KAAA,CAAC,8DAAC;;AAGK,IAAA,qBAAqB,GAAG,QAAQ,CAAC,MAAK;AAC5C,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,EAAE;AAChC,QAAA,IAAI,CAAC,IAAI;AAAE,YAAA,OAAO,IAAI;QACtB,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE;AAChF,IAAA,CAAC,iEAAC;IAEe,cAAc,GAAG,CAAC,MAAK;AACtC,QAAA,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE;QACxB,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE;IACnF,CAAC,GAAG;;AAGI,IAAA,QAAQ,GAAQ,MAAK,EAAG,CAAC;AACzB,IAAA,SAAS,GAAQ,MAAK,EAAG,CAAC;AAElC,IAAA,UAAU,CAAC,KAAkB,EAAA;AAC3B,QAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC;IAC9B;AAEA,IAAA,gBAAgB,CAAC,EAAO,EAAA;AACtB,QAAA,IAAI,CAAC,QAAQ,GAAG,EAAE;IACpB;AAEA,IAAA,iBAAiB,CAAC,EAAO,EAAA;AACvB,QAAA,IAAI,CAAC,SAAS,GAAG,EAAE;IACrB;;AAGA,IAAA,WAAA,GAAA;AACE,QAAA,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE;QACxB,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,CAAC;QAC5D,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC;QAC1C,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC;QAE5C,MAAM,CAAC,MAAK;YACV,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;AACpD,QAAA,CAAC,CAAC;QAEF,MAAM,CAAC,MAAK;YACV,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,iBAAiB,EAAE;YACxB,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,oBAAoB,EAAE;YAC3B,IAAI,CAAC,gBAAgB,EAAE;AACzB,QAAA,CAAC,CAAC;IACJ;;IAGA,gBAAgB,GAAA;AACd,QAAA,IAAI,IAAI,CAAC,oBAAoB,EAAE,KAAK,OAAO,EAAE;YAC3C,IAAI,CAAC,qBAAqB,EAAE;QAC9B;aAAO;YACL,IAAI,CAAC,yBAAyB,EAAE;QAClC;IACF;IAEQ,yBAAyB,GAAA;AAC/B,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE;AAC/B,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE;QACjC,MAAM,eAAe,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;AAChD,QAAA,MAAM,cAAc,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC;AACnD,QAAA,MAAM,cAAc,GAAG,eAAe,CAAC,MAAM,EAAE;AAC/C,QAAA,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,EAAE;AAE5C,QAAA,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAC1B,EAAE,MAAM,EAAE,cAAc,EAAE,EAC1B,OAAO;AACL,YAAA,IAAI,EAAE,IAAI;AACV,YAAA,GAAG,EAAE,IAAI;AACT,YAAA,OAAO,EAAE;AACV,SAAA,CAAC,CACH;AAED,QAAA,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAC1B,EAAE,MAAM,EAAE,WAAW,EAAE,EACvB,CAAC,CAAC,EAAE,CAAC,MAAM;YACT,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC;YAClC,GAAG,EAAE,CAAC,GAAG,CAAC;AACV,YAAA,OAAO,EAAE;AACV,SAAA,CAAC,CACH;QAED,MAAM,aAAa,GAAG,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM;AACzD,QAAA,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAC9B,EAAE,MAAM,EAAE,EAAE,GAAG,aAAa,EAAE,EAC9B,OAAO;AACL,YAAA,IAAI,EAAE,IAAI;AACV,YAAA,GAAG,EAAE,IAAI;AACT,YAAA,OAAO,EAAE;AACV,SAAA,CAAC,CACH;AAED,QAAA,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,GAAG,SAAS,EAAE,GAAG,aAAa,CAAC,CAAC;IAC/D;IAEQ,qBAAqB,GAAA;AAC3B,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,EAAE;AACpC,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,iBAAiB,EAAE;AAEtC,QAAA,MAAM,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;AAC5E,QAAA,MAAM,cAAc,GAAG,iBAAiB,CAAC,MAAM,EAAE;QAEjD,MAAM,YAAY,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;QACrE,MAAM,WAAW,GAAG,YAAY,CAAC,KAAK,GAAG,CAAC,CAAC;AAE3C,QAAA,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAC1B,EAAE,MAAM,EAAE,cAAc,EAAE,EAC1B,OAAO;AACL,YAAA,IAAI,EAAE,IAAI;AACV,YAAA,GAAG,EAAE,IAAI;AACT,YAAA,OAAO,EAAE;AACV,SAAA,CAAC,CACH;AAED,QAAA,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAC1B,EAAE,MAAM,EAAE,WAAW,EAAE,EACvB,CAAC,CAAC,EAAE,CAAC,KAAI;AACP,YAAA,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC;YAC5E,OAAO;AACL,gBAAA,IAAI,EAAE,aAAa;gBACnB,GAAG,EAAE,CAAC,GAAG,CAAC;AACV,gBAAA,OAAO,EAAE;aACV;AACH,QAAA,CAAC,CACF;QAED,MAAM,aAAa,GAAG,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM;AACzD,QAAA,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAC9B,EAAE,MAAM,EAAE,EAAE,GAAG,aAAa,EAAE,EAC9B,OAAO;AACL,YAAA,IAAI,EAAE,IAAI;AACV,YAAA,GAAG,EAAE,IAAI;AACT,YAAA,OAAO,EAAE;AACV,SAAA,CAAC,CACH;AAED,QAAA,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,SAAS,EAAE,GAAG,SAAS,EAAE,GAAG,aAAa,CAAC,CAAC;IAC/D;;IAGA,aAAa,GAAA;AACX,QAAA,IAAI,IAAI,CAAC,oBAAoB,EAAE,KAAK,OAAO,EAAE;AAC3C,YAAA,IAAI,IAAI,CAAC,iBAAiB,EAAE,KAAK,CAAC,EAAE;AAClC,gBAAA,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,EAAE,CAAC;AAC9B,gBAAA,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC1C;iBAAO;AACL,gBAAA,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC3C;QACF;aAAO;AACL,YAAA,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,EAAE;AAC7B,gBAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,CAAC;AACzB,gBAAA,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACrC;iBAAO;AACL,gBAAA,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACtC;QACF;IACF;IAEA,SAAS,GAAA;AACP,QAAA,IAAI,IAAI,CAAC,oBAAoB,EAAE,KAAK,OAAO,EAAE;AAC3C,YAAA,IAAI,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,EAAE;AACnC,gBAAA,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC;AAC7B,gBAAA,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC1C;iBAAO;AACL,gBAAA,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC3C;QACF;aAAO;AACL,YAAA,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,EAAE,EAAE;AAC9B,gBAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;AACxB,gBAAA,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACrC;iBAAO;AACL,gBAAA,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACtC;QACF;IACF;;AAGA,IAAA,UAAU,CAAC,GAAgE,EAAA;AACzE,QAAA,IAAI,GAAG,CAAC,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI;YAAE;QAE9B,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC;AAE/B,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC;AAE1D,QAAA,MAAM,MAAM,GAAqB;YAC/B,aAAa,EAAE,GAAG,CAAC,IAAI;YACvB,kBAAkB,EAAE,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC;AACtD,YAAA,SAAS,EAAE;AACT,gBAAA,GAAG,KAAK;AACR,gBAAA,SAAS,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC;AAC3D,aAAA;AACD,YAAA,cAAc,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC;AAC3C,YAAA,YAAY,EAAE,IAAI,CAAC,oBAAoB,EAAE;AACzC,YAAA,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB;AAED,QAAA,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC;QACvB,IAAI,CAAC,SAAS,EAAE;AAChB,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC;AAC5B,QAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC;IACxB;IAEA,WAAW,GAAA;AACT,QAAA,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE;AACxB,QAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACvC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;QAEzC,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,CAAC;QACvD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;QACrC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC;AAEvC,QAAA,MAAM,MAAM,GAAqB;AAC/B,YAAA,aAAa,EAAE,KAAK;AACpB,YAAA,kBAAkB,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC;AACnD,YAAA,SAAS,EAAE;AACT,gBAAA,GAAG,KAAK;AACR,gBAAA,SAAS,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC;AAC3D,aAAA;AACD,YAAA,cAAc,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC;AAC3C,YAAA,YAAY,EAAE,IAAI,CAAC,oBAAoB,EAAE;AACzC,YAAA,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB;AAED,QAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QACpB,IAAI,CAAC,SAAS,EAAE;AAChB,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC;AAC5B,QAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC;IACxB;IAEA,SAAS,GAAA;AACP,QAAA,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC;AAC3B,QAAA,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;QACnB,IAAI,CAAC,SAAS,EAAE;AAChB,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC;IACxB;;IAGA,cAAc,GAAA;AACZ,QAAA,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,EAAE;AAC7B,QAAA,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;QAC/B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QAEvC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;YAC7B,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,IAAI,IAAI,EAAE;YACnD,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;YAC3C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;YAE7C,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,SAAS,CAAC;YAC3D,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;YACrC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC;QACzC;IACF;AAEA,IAAA,eAAe,CAAC,IAA2B,EAAA;AACzC,QAAA,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC;QACnC,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,IAAI,IAAI,EAAE;AAEvD,QAAA,IAAI,IAAI,KAAK,OAAO,EAAE;YACpB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,aAAa,CAAC;YAC/D,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;YACrC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC;QACzC;aAAO;YACL,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YAC/C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;QACnD;IACF;IAEA,cAAc,GAAA;AACZ,QAAA,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;AACjB,YAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC;QACxB;IACF;;AAGA,IAAA,UAAU,CAAC,GAAgE,EAAA;AACzE,QAAA,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,OAAO;AAAE,YAAA,OAAO,KAAK;AAC1C,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,qBAAqB,EAAE;AAC9C,QAAA,IAAI,CAAC,SAAS;AAAE,YAAA,OAAO,KAAK;AAE5B,QAAA,MAAM,YAAY,GAAG,IAAI,IAAI,CAC3B,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,EACtB,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,EACnB,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,CACnB,CAAC,OAAO,EAAE;QAEX,OAAO,YAAY,KAAK,SAAS;IACnC;AAEA,IAAA,OAAO,CAAC,GAAgE,EAAA;AACtE,QAAA,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,OAAO;AAAE,YAAA,OAAO,KAAK;AAE1C,QAAA,MAAM,YAAY,GAAG,IAAI,IAAI,CAC3B,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,EACtB,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,EACnB,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,CACnB,CAAC,OAAO,EAAE;AAEX,QAAA,OAAO,YAAY,KAAK,IAAI,CAAC,cAAc;IAC7C;;AAGQ,IAAA,mBAAmB,CAAC,IAAU,EAAA;AACpC,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;QACtD,MAAM,KAAK,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;AAC/D,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE;AAC/B,QAAA,OAAO,GAAG,GAAG,CAAA,CAAA,EAAI,KAAK,CAAA,CAAA,EAAI,IAAI,EAAE;IAClC;AAEQ,IAAA,eAAe,CAAC,KAAmD,EAAA;AACzE,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC;AAClE,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,GAAG,IAAI,GAAG,IAAI;AACnD,QAAA,OAAO,CAAA,EAAG,KAAK,CAAC,GAAG,CAAA,CAAA,EAAI,SAAS,CAAA,CAAA,EAAI,KAAK,CAAC,IAAI,CAAA,CAAA,EAAI,MAAM,EAAE;IAC5D;uGAjaW,cAAc,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAAd,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,cAAc,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,MAAA,EAAA,EAAA,YAAA,EAAA,EAAA,iBAAA,EAAA,cAAA,EAAA,UAAA,EAAA,cAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,MAAA,EAAA,EAAA,iBAAA,EAAA,QAAA,EAAA,UAAA,EAAA,QAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,QAAA,EAAA,EAAA,iBAAA,EAAA,UAAA,EAAA,UAAA,EAAA,UAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,iBAAA,EAAA,YAAA,EAAA,UAAA,EAAA,YAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,iBAAA,EAAA,YAAA,EAAA,UAAA,EAAA,YAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,aAAA,EAAA,EAAA,iBAAA,EAAA,eAAA,EAAA,UAAA,EAAA,eAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,QAAA,EAAA,EAAA,iBAAA,EAAA,UAAA,EAAA,UAAA,EAAA,UAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,QAAA,EAAA,EAAA,iBAAA,EAAA,UAAA,EAAA,UAAA,EAAA,UAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,WAAA,EAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,UAAA,EAAA,aAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,IAAA,EAAA,EAAA,iBAAA,EAAA,MAAA,EAAA,UAAA,EAAA,MAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,OAAA,EAAA,EAAA,UAAA,EAAA,YAAA,EAAA,cAAA,EAAA,gBAAA,EAAA,EAAA,SAAA,EAXd;AACT,YAAA;AACE,gBAAA,OAAO,EAAE,iBAAiB;AAC1B,gBAAA,WAAW,EAAE,UAAU,CAAC,MAAM,cAAc,CAAC;AAC7C,gBAAA,KAAK,EAAE;AACR;AACF,SAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EClBH,q8EA0EM,EAAA,MAAA,EAAA,CAAA,w7FAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,ED/DM,YAAY,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAE,YAAY,EAAA,QAAA,EAAA,kBAAA,EAAA,OAAA,EAAA,CAAA,cAAA,CAAA,EAAA,CAAA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,MAAA,EAAA,CAAA;;2FAYzB,cAAc,EAAA,UAAA,EAAA,CAAA;kBAd1B,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,mBAAmB,WACpB,CAAC,YAAY,EAAE,YAAY,CAAC,EAAA,SAAA,EAC1B;AACT,wBAAA;AACE,4BAAA,OAAO,EAAE,iBAAiB;AAC1B,4BAAA,WAAW,EAAE,UAAU,CAAC,oBAAoB,CAAC;AAC7C,4BAAA,KAAK,EAAE;AACR;qBACF,EAAA,eAAA,EAGgB,uBAAuB,CAAC,MAAM,EAAA,QAAA,EAAA,q8EAAA,EAAA,MAAA,EAAA,CAAA,w7FAAA,CAAA,EAAA;;;AErBjD;;AAEG;;ACFH;;AAEG;;;;"}
Binary file
package/package.json ADDED
@@ -0,0 +1,46 @@
1
+ {
2
+ "name": "ng-mo-date-picker",
3
+ "version": "1.0.0",
4
+ "description": "Angular Hijri/Gregorian Date Picker with RTL/LTR support",
5
+ "repository": {
6
+ "type": "git",
7
+ "url": "https://github.com/3Mowafy/ng-mo-date-picker"
8
+ },
9
+ "bugs": {
10
+ "url": "https://github.com/3Mowafy/ng-mo-date-picker/issues"
11
+ },
12
+ "homepage": "https://github.com/3Mowafy/ng-mo-date-picker#readme",
13
+ "keywords": [
14
+ "angular",
15
+ "datepicker",
16
+ "hijri",
17
+ "gregorian",
18
+ "islamic",
19
+ "calendar",
20
+ "rtl",
21
+ "arabic"
22
+ ],
23
+ "author": "Mohamed Mowafy",
24
+ "license": "MIT",
25
+ "peerDependencies": {
26
+ "@angular/common": "^21.0.0",
27
+ "@angular/core": "^21.0.0",
28
+ "@angular/forms": "^21.0.0",
29
+ "moment-hijri": "^3.0.0"
30
+ },
31
+ "dependencies": {
32
+ "tslib": "^2.3.0"
33
+ },
34
+ "module": "fesm2022/ng-mo-date-picker.mjs",
35
+ "typings": "types/ng-mo-date-picker.d.ts",
36
+ "exports": {
37
+ "./package.json": {
38
+ "default": "./package.json"
39
+ },
40
+ ".": {
41
+ "types": "./types/ng-mo-date-picker.d.ts",
42
+ "default": "./fesm2022/ng-mo-date-picker.mjs"
43
+ }
44
+ },
45
+ "sideEffects": false
46
+ }