@yoozsoft/yoozsoft-ng 1.3.2-alpha.0 → 2.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +16 -9
- package/datepicker/public-api.d.ts +2 -0
- package/datepicker/src/ys-datepicker/ys-datepicker.component.d.ts +32 -0
- package/datepicker/src/ys-datepicker-persian/ys-datepicker-persian.component.d.ts +38 -0
- package/datepicker/src/ys-datepicker-popup/ys-datepicker-popup.component.d.ts +3 -2
- package/datepicker/src/ys-datepicker-popup-persian/ys-datepicker-popup-persian.component.d.ts +3 -2
- package/datepicker/src/ys-datepicker-range-popup/ys-datepicker-range-popup.component.d.ts +3 -2
- package/datepicker/src/ys-datepicker-range-popup-persian/ys-datepicker-range-popup-persian.component.d.ts +3 -2
- package/directives/src/password-mismatch/password-mismatch.directive.d.ts +1 -1
- package/esm2022/datepicker/public-api.mjs +3 -1
- package/esm2022/datepicker/src/models/jalali-date.mjs +2 -3
- package/esm2022/datepicker/src/services/ys-date-parser-formatter.service.mjs +5 -6
- package/esm2022/datepicker/src/services/ys-datepicker-i18n.service.mjs +10 -12
- package/esm2022/datepicker/src/ys-datepicker/ys-datepicker.component.mjs +108 -0
- package/esm2022/datepicker/src/ys-datepicker-persian/ys-datepicker-persian.component.mjs +127 -0
- package/esm2022/datepicker/src/ys-datepicker-popup/ys-datepicker-popup.component.mjs +12 -10
- package/esm2022/datepicker/src/ys-datepicker-popup-persian/ys-datepicker-popup-persian.component.mjs +12 -10
- package/esm2022/datepicker/src/ys-datepicker-range-popup/ys-datepicker-range-popup.component.mjs +12 -10
- package/esm2022/datepicker/src/ys-datepicker-range-popup-persian/ys-datepicker-range-popup-persian.component.mjs +12 -10
- package/esm2022/directives/src/password-mismatch/password-mismatch.directive.mjs +5 -6
- package/esm2022/footer/src/ys-footer/ys-footer.component.mjs +5 -6
- package/esm2022/layout/src/ys-layout/ys-layout.component.mjs +6 -7
- package/esm2022/loading/src/ys-loading-mask/ys-loading-mask.component.mjs +5 -6
- package/esm2022/navbar/src/ys-navbar/ys-navbar.component.mjs +7 -8
- package/esm2022/overlay/src/ys-overlay/ys-overlay.component.mjs +6 -7
- package/esm2022/progress/src/services/progress.service.mjs +5 -6
- package/esm2022/progress/src/ys-progress/ys-progress.component.mjs +6 -7
- package/esm2022/select/src/ys-select/ys-select.component.mjs +5 -6
- package/esm2022/sidebar/src/services/sidebar.service.mjs +5 -6
- package/esm2022/sidebar/src/ys-sidebar/ys-sidebar.component.mjs +7 -8
- package/esm2022/toasts/src/services/toast.service.mjs +5 -6
- package/esm2022/toasts/src/ys-toasts/ys-toasts.component.mjs +8 -9
- package/fesm2022/yoozsoft-yoozsoft-ng-datepicker.mjs +269 -40
- package/fesm2022/yoozsoft-yoozsoft-ng-datepicker.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-directives.mjs +3 -3
- package/fesm2022/yoozsoft-yoozsoft-ng-directives.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-footer.mjs +3 -3
- package/fesm2022/yoozsoft-yoozsoft-ng-footer.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-layout.mjs +4 -4
- package/fesm2022/yoozsoft-yoozsoft-ng-layout.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-loading.mjs +3 -3
- package/fesm2022/yoozsoft-yoozsoft-ng-loading.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-navbar.mjs +5 -5
- package/fesm2022/yoozsoft-yoozsoft-ng-navbar.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-overlay.mjs +4 -4
- package/fesm2022/yoozsoft-yoozsoft-ng-overlay.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-progress.mjs +7 -7
- package/fesm2022/yoozsoft-yoozsoft-ng-progress.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-select.mjs +3 -3
- package/fesm2022/yoozsoft-yoozsoft-ng-select.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-sidebar.mjs +8 -8
- package/fesm2022/yoozsoft-yoozsoft-ng-sidebar.mjs.map +1 -1
- package/fesm2022/yoozsoft-yoozsoft-ng-toasts.mjs +9 -9
- package/fesm2022/yoozsoft-yoozsoft-ng-toasts.mjs.map +1 -1
- package/footer/src/ys-footer/ys-footer.component.d.ts +1 -1
- package/layout/src/ys-layout/ys-layout.component.d.ts +1 -1
- package/loading/src/ys-loading-mask/ys-loading-mask.component.d.ts +1 -1
- package/navbar/src/ys-navbar/ys-navbar.component.d.ts +1 -1
- package/overlay/src/ys-overlay/ys-overlay.component.d.ts +1 -1
- package/package.json +15 -15
- package/progress/src/ys-progress/ys-progress.component.d.ts +1 -1
- package/select/src/ys-select/ys-select.component.d.ts +1 -1
- package/sidebar/src/ys-sidebar/ys-sidebar.component.d.ts +1 -1
- package/toasts/src/ys-toasts/ys-toasts.component.d.ts +1 -1
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { JsonPipe, NgIf } from '@angular/common';
|
|
2
|
+
import { Component, Input, forwardRef, inject } from '@angular/core';
|
|
3
|
+
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
+
import { NgbCalendar, NgbCalendarPersian, NgbDateParserFormatter, NgbDatepickerI18n, NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';
|
|
5
|
+
import { JalaliDate } from '../models';
|
|
6
|
+
import { I18n, LanguageType, YsDateParserFormatterService, YsDatepickerI18nService } from '../services';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../services";
|
|
9
|
+
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
10
|
+
import * as i3 from "@angular/forms";
|
|
11
|
+
export class YsDatepickerPersianComponent {
|
|
12
|
+
get language() {
|
|
13
|
+
return this._language;
|
|
14
|
+
}
|
|
15
|
+
set language(value) {
|
|
16
|
+
this._language = value;
|
|
17
|
+
this.i18N.language = this._language;
|
|
18
|
+
}
|
|
19
|
+
get value() {
|
|
20
|
+
return this._value;
|
|
21
|
+
}
|
|
22
|
+
set value(val) {
|
|
23
|
+
this._value = val;
|
|
24
|
+
}
|
|
25
|
+
constructor(i18N) {
|
|
26
|
+
this.i18N = i18N;
|
|
27
|
+
this.calendar = inject(NgbCalendar);
|
|
28
|
+
this.today = inject(NgbCalendar).getToday();
|
|
29
|
+
this.firstDayOfWeek = 6;
|
|
30
|
+
this.weekend = [5];
|
|
31
|
+
this._language = LanguageType[LanguageType.fa];
|
|
32
|
+
this.isFooter = true;
|
|
33
|
+
this.todayLabel = "امروز";
|
|
34
|
+
this.footer = null;
|
|
35
|
+
this._value = null;
|
|
36
|
+
this.disabled = false;
|
|
37
|
+
this.onChange = () => { };
|
|
38
|
+
this.onTouched = () => { };
|
|
39
|
+
this.markDisabled = (date, current) => date.month !== current?.month;
|
|
40
|
+
this.isWeekend = (date) => this.weekend.includes(this.calendar.getWeekday(date));
|
|
41
|
+
this.language = LanguageType[LanguageType.fa];
|
|
42
|
+
}
|
|
43
|
+
writeValue(obj) {
|
|
44
|
+
if (!obj) {
|
|
45
|
+
this.value = null;
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
var date = obj;
|
|
49
|
+
let persianDate = JalaliDate.gregorianToJalali(date.getFullYear(), date.getMonth() + 1, date.getDate());
|
|
50
|
+
this.value = { year: persianDate[0], month: persianDate[1], day: persianDate[2] };
|
|
51
|
+
}
|
|
52
|
+
registerOnChange(fn) {
|
|
53
|
+
this.onChange = fn;
|
|
54
|
+
}
|
|
55
|
+
registerOnTouched(fn) {
|
|
56
|
+
this.onTouched = fn;
|
|
57
|
+
}
|
|
58
|
+
setDisabledState(isDisabled) {
|
|
59
|
+
this.disabled = isDisabled;
|
|
60
|
+
}
|
|
61
|
+
valueChanged(newDate) {
|
|
62
|
+
if (newDate) {
|
|
63
|
+
if (typeof newDate == 'string') {
|
|
64
|
+
let temp = newDate.split('/');
|
|
65
|
+
let convertedDate = JalaliDate.jalaliToGregorian(+temp[0], (+temp[1]) - 1, +temp[2]);
|
|
66
|
+
let res = new Date(+convertedDate[0], (+convertedDate[1]) - 1, +convertedDate[2]);
|
|
67
|
+
this.onChange(res);
|
|
68
|
+
this.onTouched(res);
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
let convertedDate = JalaliDate.jalaliToGregorian(newDate.year, newDate.month, newDate.day);
|
|
72
|
+
var res = new Date(+convertedDate[0], +convertedDate[1] - 1, +convertedDate[2]);
|
|
73
|
+
this.onChange(res);
|
|
74
|
+
this.onTouched(res);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
this.onChange(null);
|
|
79
|
+
this.onTouched(null);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
setToday() {
|
|
83
|
+
this.value = this.today;
|
|
84
|
+
this.valueChanged(this.value);
|
|
85
|
+
}
|
|
86
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: YsDatepickerPersianComponent, deps: [{ token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
87
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: YsDatepickerPersianComponent, isStandalone: true, selector: "ys-datepicker-persian", inputs: { firstDayOfWeek: "firstDayOfWeek", weekend: "weekend", language: "language", isFooter: "isFooter", todayLabel: "todayLabel", footer: "footer", disabled: "disabled" }, providers: [
|
|
88
|
+
{
|
|
89
|
+
provide: NG_VALUE_ACCESSOR,
|
|
90
|
+
useExisting: forwardRef(() => YsDatepickerPersianComponent),
|
|
91
|
+
multi: true
|
|
92
|
+
},
|
|
93
|
+
I18n,
|
|
94
|
+
{ provide: NgbCalendar, useClass: NgbCalendarPersian },
|
|
95
|
+
{ provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },
|
|
96
|
+
{ provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }
|
|
97
|
+
], ngImport: i0, template: "<ngb-datepicker #dp [(ngModel)]=\"value\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n [footerTemplate]=\"footerTemplate\" placeholder=\"yyyy/mm/dd\" [disabled]=\"disabled\" (ngModelChange)=\"valueChanged(value)\" />\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n {{ date.day }}\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n <span *ngIf=\"isFooter\">\r\n <hr class=\"my-0\" />\r\n <span *ngIf=\"footer\">\r\n {{footer}}\r\n </span>\r\n <span *ngIf=\"!footer\">\r\n <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday();\"\r\n [disabled]=\"disabled\">{{todayLabel}}</button>\r\n </span>\r\n </span>\r\n</ng-template>", styles: ["::ng-deep html[dir=rtl] .ngb-dp-arrow-prev .ngb-dp-navigation-chevron{transform:rotate(45deg)}::ng-deep html[dir=rtl] .ngb-dp-arrow-next .ngb-dp-navigation-chevron{transform:rotate(-135deg)}::ng-deep html[dir=rtl] .form-select{background-position:left .75rem center}::ng-deep html[dir=rtl] .ngb-dp-month:first-child .ngb-dp-week{padding-right:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month:last-child .ngb-dp-week{padding-left:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-right:1rem}::ng-deep html[dir=rtl] .input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0;border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}::ng-deep html[dir=rtl] .input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-right:calc(var(--bs-border-width) * -1);border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-top-right-radius:0;border-bottom-right-radius:0}::ng-deep .ngb-dp-day{display:flex;align-items:center}.custom-day{text-align:center;padding:.185rem .25rem;border-radius:.25rem;display:inline-block;width:2rem;height:2rem;line-height:1.7}.weekend{color:var(--bs-danger)}.custom-day:hover,.custom-day.focused{background-color:var(--bs-gray-300)}.hidden{display:none}\n"], dependencies: [{ kind: "ngmodule", type: NgbDatepickerModule }, { kind: "component", type: i2.NgbDatepicker, selector: "ngb-datepicker", inputs: ["contentTemplate", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "maxDate", "minDate", "navigation", "outsideDays", "showWeekNumbers", "startDate", "weekdays"], outputs: ["navigate", "dateSelect"], exportAs: ["ngbDatepicker"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
98
|
+
}
|
|
99
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: YsDatepickerPersianComponent, decorators: [{
|
|
100
|
+
type: Component,
|
|
101
|
+
args: [{ selector: 'ys-datepicker-persian', standalone: true, imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf], providers: [
|
|
102
|
+
{
|
|
103
|
+
provide: NG_VALUE_ACCESSOR,
|
|
104
|
+
useExisting: forwardRef(() => YsDatepickerPersianComponent),
|
|
105
|
+
multi: true
|
|
106
|
+
},
|
|
107
|
+
I18n,
|
|
108
|
+
{ provide: NgbCalendar, useClass: NgbCalendarPersian },
|
|
109
|
+
{ provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },
|
|
110
|
+
{ provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }
|
|
111
|
+
], template: "<ngb-datepicker #dp [(ngModel)]=\"value\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n [footerTemplate]=\"footerTemplate\" placeholder=\"yyyy/mm/dd\" [disabled]=\"disabled\" (ngModelChange)=\"valueChanged(value)\" />\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n {{ date.day }}\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n <span *ngIf=\"isFooter\">\r\n <hr class=\"my-0\" />\r\n <span *ngIf=\"footer\">\r\n {{footer}}\r\n </span>\r\n <span *ngIf=\"!footer\">\r\n <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday();\"\r\n [disabled]=\"disabled\">{{todayLabel}}</button>\r\n </span>\r\n </span>\r\n</ng-template>", styles: ["::ng-deep html[dir=rtl] .ngb-dp-arrow-prev .ngb-dp-navigation-chevron{transform:rotate(45deg)}::ng-deep html[dir=rtl] .ngb-dp-arrow-next .ngb-dp-navigation-chevron{transform:rotate(-135deg)}::ng-deep html[dir=rtl] .form-select{background-position:left .75rem center}::ng-deep html[dir=rtl] .ngb-dp-month:first-child .ngb-dp-week{padding-right:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month:last-child .ngb-dp-week{padding-left:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-right:1rem}::ng-deep html[dir=rtl] .input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0;border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}::ng-deep html[dir=rtl] .input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-right:calc(var(--bs-border-width) * -1);border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-top-right-radius:0;border-bottom-right-radius:0}::ng-deep .ngb-dp-day{display:flex;align-items:center}.custom-day{text-align:center;padding:.185rem .25rem;border-radius:.25rem;display:inline-block;width:2rem;height:2rem;line-height:1.7}.weekend{color:var(--bs-danger)}.custom-day:hover,.custom-day.focused{background-color:var(--bs-gray-300)}.hidden{display:none}\n"] }]
|
|
112
|
+
}], ctorParameters: () => [{ type: i1.I18n }], propDecorators: { firstDayOfWeek: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], weekend: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], language: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], isFooter: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], todayLabel: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], footer: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], disabled: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}] } });
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ys-datepicker-persian.component.js","sourceRoot":"","sources":["../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-persian/ys-datepicker-persian.component.ts","../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-persian/ys-datepicker-persian.component.html"],"names":[],"mappings":"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","sourcesContent":["import { JsonPipe, NgIf } from '@angular/common';\r\nimport { Component, Input, TemplateRef, forwardRef, inject } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgbCalendar, NgbCalendarPersian, NgbDate, NgbDateParserFormatter, NgbDateStruct, NgbDatepickerI18n, NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';\r\nimport { JalaliDate } from '../models';\r\nimport { I18n, LanguageType, YsDateParserFormatterService, YsDatepickerI18nService } from '../services';\r\n\r\n@Component({\r\n  selector: 'ys-datepicker-persian',\r\n  standalone: true,\r\n  imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf],\r\n  templateUrl: './ys-datepicker-persian.component.html',\r\n  styleUrls: ['./ys-datepicker-persian.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => YsDatepickerPersianComponent),\r\n      multi: true\r\n    },\r\n    I18n,\r\n    { provide: NgbCalendar, useClass: NgbCalendarPersian },\r\n    { provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },\r\n    { provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }\r\n  ]\r\n})\r\nexport class YsDatepickerPersianComponent implements ControlValueAccessor {\r\n\r\n  calendar = inject(NgbCalendar);\r\n  today = inject(NgbCalendar).getToday();\r\n\r\n  @Input() firstDayOfWeek: number = 6;\r\n  @Input() weekend: number[] = [5];\r\n\r\n  private _language: string = LanguageType[LanguageType.fa];\r\n  @Input()\r\n  get language(): string {\r\n    return this._language;\r\n  }\r\n  set language(value: string) {\r\n    this._language = value;\r\n    this.i18N.language = this._language;\r\n  }\r\n\r\n  @Input() isFooter: boolean = true;\r\n  @Input() todayLabel: string = \"امروز\";\r\n  @Input() footer: TemplateRef<any> | null = null;\r\n\r\n  _value: NgbDateStruct | null = null;\r\n  get value(): NgbDateStruct | null {\r\n    return this._value;\r\n  }\r\n  set value(val: NgbDateStruct | null) {\r\n    this._value = val;\r\n  }\r\n\r\n  @Input() disabled: boolean = false;\r\n  onChange: any = () => { }\r\n  onTouched: any = () => { }\r\n\r\n  constructor(private i18N: I18n) {\r\n    this.language = LanguageType[LanguageType.fa];\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    if (!obj) {\r\n      this.value = null;\r\n      return;\r\n    }\r\n\r\n    var date: Date = obj;\r\n    let persianDate: number[] = JalaliDate.gregorianToJalali(date.getFullYear(), date.getMonth() + 1, date.getDate());\r\n    this.value = { year: persianDate[0], month: persianDate[1], day: persianDate[2] };\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  markDisabled = (date: NgbDate, current?: { month: number; year: number }) => date.month !== current?.month;\r\n  isWeekend = (date: NgbDate) => this.weekend.includes(this.calendar.getWeekday(date));\r\n\r\n  valueChanged(newDate: NgbDateStruct | string | null) {\r\n    if (newDate) {\r\n      if (typeof newDate == 'string') {\r\n        let temp = newDate.split('/');\r\n        let convertedDate: number[] = JalaliDate.jalaliToGregorian(+temp[0], (+temp[1]) - 1, +temp[2]);\r\n        let res: Date = new Date(+convertedDate[0], (+convertedDate[1]) - 1, +convertedDate[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      } else {\r\n        let convertedDate: number[] = JalaliDate.jalaliToGregorian(newDate.year, newDate.month, newDate.day);\r\n        var res: Date = new Date(+convertedDate[0], +convertedDate[1] - 1, +convertedDate[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      }\r\n    } else {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    }\r\n  }\r\n\r\n  setToday() {\r\n    this.value = this.today;\r\n    this.valueChanged(this.value);\r\n  }\r\n\r\n}\r\n","<ngb-datepicker #dp [(ngModel)]=\"value\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n    [footerTemplate]=\"footerTemplate\" placeholder=\"yyyy/mm/dd\" [disabled]=\"disabled\" (ngModelChange)=\"valueChanged(value)\" />\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n    let-focused=\"focused\">\r\n    <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n        [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n        {{ date.day }}\r\n    </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n    <span *ngIf=\"isFooter\">\r\n        <hr class=\"my-0\" />\r\n        <span *ngIf=\"footer\">\r\n            {{footer}}\r\n        </span>\r\n        <span *ngIf=\"!footer\">\r\n            <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday();\"\r\n                [disabled]=\"disabled\">{{todayLabel}}</button>\r\n        </span>\r\n    </span>\r\n</ng-template>"]}
|
|
@@ -7,7 +7,7 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
import * as i1 from "../services";
|
|
8
8
|
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
9
9
|
import * as i3 from "@angular/forms";
|
|
10
|
-
class YsDatepickerPopupComponent {
|
|
10
|
+
export class YsDatepickerPopupComponent {
|
|
11
11
|
get value() {
|
|
12
12
|
return this._value;
|
|
13
13
|
}
|
|
@@ -26,7 +26,7 @@ class YsDatepickerPopupComponent {
|
|
|
26
26
|
this.calendar = inject(NgbCalendar);
|
|
27
27
|
this.today = inject(NgbCalendar).getToday();
|
|
28
28
|
this._value = null;
|
|
29
|
-
this.container =
|
|
29
|
+
this.container = null;
|
|
30
30
|
this.firstDayOfWeek = 1;
|
|
31
31
|
this.weekend = [6, 7];
|
|
32
32
|
this._language = LanguageType[LanguageType.en];
|
|
@@ -34,6 +34,7 @@ class YsDatepickerPopupComponent {
|
|
|
34
34
|
this.closeLabel = "Close";
|
|
35
35
|
this.todayLabel = "Today";
|
|
36
36
|
this.footer = null;
|
|
37
|
+
this.calendarIconClass = "fa-solid fa-calendar-days";
|
|
37
38
|
this.disabled = false;
|
|
38
39
|
this.onChange = () => { };
|
|
39
40
|
this.onTouched = () => { };
|
|
@@ -81,8 +82,8 @@ class YsDatepickerPopupComponent {
|
|
|
81
82
|
this.value = this.today;
|
|
82
83
|
this.valueChanged(this.value);
|
|
83
84
|
}
|
|
84
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
85
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
85
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: YsDatepickerPopupComponent, deps: [{ token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
86
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: YsDatepickerPopupComponent, isStandalone: true, selector: "ys-datepicker-popup", inputs: { container: "container", firstDayOfWeek: "firstDayOfWeek", weekend: "weekend", language: "language", isFooter: "isFooter", closeLabel: "closeLabel", todayLabel: "todayLabel", footer: "footer", calendarIconClass: "calendarIconClass", disabled: "disabled" }, providers: [
|
|
86
87
|
{
|
|
87
88
|
provide: NG_VALUE_ACCESSOR,
|
|
88
89
|
useExisting: forwardRef(() => YsDatepickerPopupComponent),
|
|
@@ -91,10 +92,9 @@ class YsDatepickerPopupComponent {
|
|
|
91
92
|
I18n,
|
|
92
93
|
{ provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },
|
|
93
94
|
{ provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }
|
|
94
|
-
], ngImport: i0, template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"
|
|
95
|
+
], ngImport: i0, template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"{{calendarIconClass}}\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n {{ date.day }}\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n <span *ngIf=\"isFooter\">\r\n <hr class=\"my-0\" />\r\n <span *ngIf=\"footer\">\r\n {{footer}}\r\n </span>\r\n <span *ngIf=\"!footer\">\r\n <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n [disabled]=\"disabled\">{{todayLabel}}</button>\r\n <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n </span>\r\n </span>\r\n</ng-template>", styles: ["::ng-deep html[dir=rtl] .ngb-dp-arrow-prev .ngb-dp-navigation-chevron{transform:rotate(45deg)}::ng-deep html[dir=rtl] .ngb-dp-arrow-next .ngb-dp-navigation-chevron{transform:rotate(-135deg)}::ng-deep html[dir=rtl] .form-select{background-position:left .75rem center}::ng-deep html[dir=rtl] .ngb-dp-month:first-child .ngb-dp-week{padding-right:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month:last-child .ngb-dp-week{padding-left:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-right:1rem}::ng-deep html[dir=rtl] .input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0;border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}::ng-deep html[dir=rtl] .input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-right:calc(var(--bs-border-width) * -1);border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-top-right-radius:0;border-bottom-right-radius:0}::ng-deep .ngb-dp-day{display:flex;align-items:center}.custom-day{text-align:center;padding:.185rem .25rem;border-radius:.25rem;display:inline-block;width:2rem;height:2rem;line-height:1.7}.weekend{color:var(--bs-danger)}.custom-day:hover,.custom-day.focused{background-color:var(--bs-gray-300)}.hidden{display:none}\n"], dependencies: [{ kind: "ngmodule", type: NgbDatepickerModule }, { kind: "directive", type: i2.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "contentTemplate", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "popperOptions", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
95
96
|
}
|
|
96
|
-
|
|
97
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: YsDatepickerPopupComponent, decorators: [{
|
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: YsDatepickerPopupComponent, decorators: [{
|
|
98
98
|
type: Component,
|
|
99
99
|
args: [{ selector: 'ys-datepicker-popup', standalone: true, imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf], providers: [
|
|
100
100
|
{
|
|
@@ -105,8 +105,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
105
105
|
I18n,
|
|
106
106
|
{ provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },
|
|
107
107
|
{ provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }
|
|
108
|
-
], template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"
|
|
109
|
-
}], ctorParameters:
|
|
108
|
+
], template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"{{calendarIconClass}}\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n {{ date.day }}\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n <span *ngIf=\"isFooter\">\r\n <hr class=\"my-0\" />\r\n <span *ngIf=\"footer\">\r\n {{footer}}\r\n </span>\r\n <span *ngIf=\"!footer\">\r\n <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n [disabled]=\"disabled\">{{todayLabel}}</button>\r\n <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n </span>\r\n </span>\r\n</ng-template>", styles: ["::ng-deep html[dir=rtl] .ngb-dp-arrow-prev .ngb-dp-navigation-chevron{transform:rotate(45deg)}::ng-deep html[dir=rtl] .ngb-dp-arrow-next .ngb-dp-navigation-chevron{transform:rotate(-135deg)}::ng-deep html[dir=rtl] .form-select{background-position:left .75rem center}::ng-deep html[dir=rtl] .ngb-dp-month:first-child .ngb-dp-week{padding-right:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month:last-child .ngb-dp-week{padding-left:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-right:1rem}::ng-deep html[dir=rtl] .input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0;border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}::ng-deep html[dir=rtl] .input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-right:calc(var(--bs-border-width) * -1);border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-top-right-radius:0;border-bottom-right-radius:0}::ng-deep .ngb-dp-day{display:flex;align-items:center}.custom-day{text-align:center;padding:.185rem .25rem;border-radius:.25rem;display:inline-block;width:2rem;height:2rem;line-height:1.7}.weekend{color:var(--bs-danger)}.custom-day:hover,.custom-day.focused{background-color:var(--bs-gray-300)}.hidden{display:none}\n"] }]
|
|
109
|
+
}], ctorParameters: () => [{ type: i1.I18n }], propDecorators: { container: [{
|
|
110
110
|
type: Input
|
|
111
111
|
}], firstDayOfWeek: [{
|
|
112
112
|
type: Input
|
|
@@ -122,7 +122,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
122
122
|
type: Input
|
|
123
123
|
}], footer: [{
|
|
124
124
|
type: Input
|
|
125
|
+
}], calendarIconClass: [{
|
|
126
|
+
type: Input
|
|
125
127
|
}], disabled: [{
|
|
126
128
|
type: Input
|
|
127
129
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ys-datepicker-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup/ys-datepicker-popup.component.ts","../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup/ys-datepicker-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { JsonPipe, NgIf } from '@angular/common';\r\nimport { Component, Input, TemplateRef, forwardRef, inject } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgbCalendar, NgbDate, NgbDateParserFormatter, NgbDateStruct, NgbDatepickerI18n, NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';\r\nimport { I18n, LanguageType, YsDateParserFormatterService, YsDatepickerI18nService } from '../services';\r\n\r\n@Component({\r\n  selector: 'ys-datepicker-popup',\r\n  standalone: true,\r\n  imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf],\r\n  templateUrl: './ys-datepicker-popup.component.html',\r\n  styleUrls: ['./ys-datepicker-popup.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => YsDatepickerPopupComponent),\r\n      multi: true\r\n    },\r\n    I18n,\r\n    { provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },\r\n    { provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }\r\n  ]\r\n})\r\nexport class YsDatepickerPopupComponent implements ControlValueAccessor {\r\n\r\n  calendar = inject(NgbCalendar);\r\n  today = inject(NgbCalendar).getToday();\r\n\r\n  _value: NgbDateStruct | null = null;\r\n  get value(): NgbDateStruct | null {\r\n    return this._value;\r\n  }\r\n  set value(val: NgbDateStruct | null) {\r\n    this._value = val;\r\n  }\r\n\r\n  @Input() container: string = '';\r\n  @Input() firstDayOfWeek: number = 1;\r\n  @Input() weekend: number[] = [6, 7];\r\n  private _language: string = LanguageType[LanguageType.en];\r\n  @Input()\r\n  get language(): string {\r\n    return this._language;\r\n  }\r\n  set language(value: string) {\r\n    this._language = value;\r\n    this.i18N.language = this._language;\r\n  }\r\n\r\n  @Input() isFooter: boolean = true;\r\n  @Input() closeLabel: string = \"Close\";\r\n  @Input() todayLabel: string = \"Today\";\r\n  @Input() footer: TemplateRef<any> | null = null;\r\n\r\n  @Input() disabled: boolean = false;\r\n  onChange: any = () => { }\r\n  onTouched: any = () => { }\r\n\r\n  constructor(private i18N: I18n) {\r\n    this.language = LanguageType[LanguageType.en];\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    if (!obj) {\r\n      this.value = null;\r\n      return;\r\n    }\r\n\r\n    var date: Date = obj;\r\n    this.value = { year: date.getFullYear(), month: (date.getMonth() + 1), day: date.getDate() };\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  markDisabled = (date: NgbDate, current?: { month: number; year: number }) => date.month !== current?.month;\r\n  isWeekend = (date: NgbDate) => this.weekend.includes(this.calendar.getWeekday(date));\r\n\r\n  valueChanged(newDate: NgbDateStruct | string | null) {\r\n    if (newDate) {\r\n      if (typeof newDate == 'string') {\r\n        let temp = newDate.split('/');\r\n        let res: Date = new Date(+temp[0], (+temp[1]) - 1, +temp[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      } else {\r\n        let res: Date = new Date(newDate.year, newDate.month - 1, newDate.day);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      }\r\n    } else {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    }\r\n  }\r\n\r\n  setToday() {\r\n    this.value = this.today;\r\n    this.valueChanged(this.value);\r\n  }\r\n\r\n}\r\n","<form class=\"row row-cols-sm-auto\">\r\n    <div class=\"col-12\">\r\n        <div class=\"input-group\">\r\n            <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n                #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n                [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n                (ngModelChange)=\"valueChanged(value)\" />\r\n            <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n                <i class=\"fa-solid fa-calendar-days\"></i>\r\n            </button>\r\n        </div>\r\n    </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n    let-focused=\"focused\">\r\n    <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n        [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n        {{ date.day }}\r\n    </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n    <span *ngIf=\"isFooter\">\r\n        <hr class=\"my-0\" />\r\n        <span *ngIf=\"footer\">\r\n            {{footer}}\r\n        </span>\r\n        <span *ngIf=\"!footer\">\r\n            <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n                [disabled]=\"disabled\">{{todayLabel}}</button>\r\n            <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n        </span>\r\n    </span>\r\n</ng-template>"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ys-datepicker-popup.component.js","sourceRoot":"","sources":["../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup/ys-datepicker-popup.component.ts","../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup/ys-datepicker-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { JsonPipe, NgIf } from '@angular/common';\r\nimport { Component, Input, TemplateRef, forwardRef, inject } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgbCalendar, NgbDate, NgbDateParserFormatter, NgbDateStruct, NgbDatepickerI18n, NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';\r\nimport { I18n, LanguageType, YsDateParserFormatterService, YsDatepickerI18nService } from '../services';\r\n\r\n@Component({\r\n  selector: 'ys-datepicker-popup',\r\n  standalone: true,\r\n  imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf],\r\n  templateUrl: './ys-datepicker-popup.component.html',\r\n  styleUrls: ['./ys-datepicker-popup.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => YsDatepickerPopupComponent),\r\n      multi: true\r\n    },\r\n    I18n,\r\n    { provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },\r\n    { provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }\r\n  ]\r\n})\r\nexport class YsDatepickerPopupComponent implements ControlValueAccessor {\r\n\r\n  calendar = inject(NgbCalendar);\r\n  today = inject(NgbCalendar).getToday();\r\n\r\n  _value: NgbDateStruct | null = null;\r\n  get value(): NgbDateStruct | null {\r\n    return this._value;\r\n  }\r\n  set value(val: NgbDateStruct | null) {\r\n    this._value = val;\r\n  }\r\n\r\n  @Input() container: \"body\" | null = null;\r\n  @Input() firstDayOfWeek: number = 1;\r\n  @Input() weekend: number[] = [6, 7];\r\n  private _language: string = LanguageType[LanguageType.en];\r\n  @Input()\r\n  get language(): string {\r\n    return this._language;\r\n  }\r\n  set language(value: string) {\r\n    this._language = value;\r\n    this.i18N.language = this._language;\r\n  }\r\n\r\n  @Input() isFooter: boolean = true;\r\n  @Input() closeLabel: string = \"Close\";\r\n  @Input() todayLabel: string = \"Today\";\r\n  @Input() footer: TemplateRef<any> | null = null;\r\n  @Input() calendarIconClass: string = \"fa-solid fa-calendar-days\";\r\n\r\n  @Input() disabled: boolean = false;\r\n  onChange: any = () => { }\r\n  onTouched: any = () => { }\r\n\r\n  constructor(private i18N: I18n) {\r\n    this.language = LanguageType[LanguageType.en];\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    if (!obj) {\r\n      this.value = null;\r\n      return;\r\n    }\r\n\r\n    var date: Date = obj;\r\n    this.value = { year: date.getFullYear(), month: (date.getMonth() + 1), day: date.getDate() };\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  markDisabled = (date: NgbDate, current?: { month: number; year: number }) => date.month !== current?.month;\r\n  isWeekend = (date: NgbDate) => this.weekend.includes(this.calendar.getWeekday(date));\r\n\r\n  valueChanged(newDate: NgbDateStruct | string | null) {\r\n    if (newDate) {\r\n      if (typeof newDate == 'string') {\r\n        let temp = newDate.split('/');\r\n        let res: Date = new Date(+temp[0], (+temp[1]) - 1, +temp[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      } else {\r\n        let res: Date = new Date(newDate.year, newDate.month - 1, newDate.day);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      }\r\n    } else {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    }\r\n  }\r\n\r\n  setToday() {\r\n    this.value = this.today;\r\n    this.valueChanged(this.value);\r\n  }\r\n\r\n}\r\n","<form class=\"row row-cols-sm-auto\">\r\n    <div class=\"col-12\">\r\n        <div class=\"input-group\">\r\n            <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n                #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n                [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n                (ngModelChange)=\"valueChanged(value)\" />\r\n            <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n                <i class=\"{{calendarIconClass}}\"></i>\r\n            </button>\r\n        </div>\r\n    </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n    let-focused=\"focused\">\r\n    <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n        [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n        {{ date.day }}\r\n    </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n    <span *ngIf=\"isFooter\">\r\n        <hr class=\"my-0\" />\r\n        <span *ngIf=\"footer\">\r\n            {{footer}}\r\n        </span>\r\n        <span *ngIf=\"!footer\">\r\n            <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n                [disabled]=\"disabled\">{{todayLabel}}</button>\r\n            <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n        </span>\r\n    </span>\r\n</ng-template>"]}
|
package/esm2022/datepicker/src/ys-datepicker-popup-persian/ys-datepicker-popup-persian.component.mjs
CHANGED
|
@@ -8,7 +8,7 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
import * as i1 from "../services";
|
|
9
9
|
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
10
10
|
import * as i3 from "@angular/forms";
|
|
11
|
-
class YsDatepickerPopupPersianComponent {
|
|
11
|
+
export class YsDatepickerPopupPersianComponent {
|
|
12
12
|
get value() {
|
|
13
13
|
return this._value;
|
|
14
14
|
}
|
|
@@ -27,7 +27,7 @@ class YsDatepickerPopupPersianComponent {
|
|
|
27
27
|
this.calendar = inject(NgbCalendar);
|
|
28
28
|
this.today = inject(NgbCalendar).getToday();
|
|
29
29
|
this._value = null;
|
|
30
|
-
this.container =
|
|
30
|
+
this.container = null;
|
|
31
31
|
this.firstDayOfWeek = 6;
|
|
32
32
|
this.weekend = [5];
|
|
33
33
|
this._language = LanguageType[LanguageType.fa];
|
|
@@ -35,6 +35,7 @@ class YsDatepickerPopupPersianComponent {
|
|
|
35
35
|
this.closeLabel = "بستن";
|
|
36
36
|
this.todayLabel = "امروز";
|
|
37
37
|
this.footer = null;
|
|
38
|
+
this.calendarIconClass = "fa-solid fa-calendar-days";
|
|
38
39
|
this.disabled = false;
|
|
39
40
|
this.onChange = () => { };
|
|
40
41
|
this.onTouched = () => { };
|
|
@@ -85,8 +86,8 @@ class YsDatepickerPopupPersianComponent {
|
|
|
85
86
|
this.value = this.today;
|
|
86
87
|
this.valueChanged(this.value);
|
|
87
88
|
}
|
|
88
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
89
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
89
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: YsDatepickerPopupPersianComponent, deps: [{ token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
90
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: YsDatepickerPopupPersianComponent, isStandalone: true, selector: "ys-datepicker-popup-persian", inputs: { container: "container", firstDayOfWeek: "firstDayOfWeek", weekend: "weekend", language: "language", isFooter: "isFooter", closeLabel: "closeLabel", todayLabel: "todayLabel", footer: "footer", calendarIconClass: "calendarIconClass", disabled: "disabled" }, providers: [
|
|
90
91
|
{
|
|
91
92
|
provide: NG_VALUE_ACCESSOR,
|
|
92
93
|
useExisting: forwardRef(() => YsDatepickerPopupPersianComponent),
|
|
@@ -96,10 +97,9 @@ class YsDatepickerPopupPersianComponent {
|
|
|
96
97
|
{ provide: NgbCalendar, useClass: NgbCalendarPersian },
|
|
97
98
|
{ provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },
|
|
98
99
|
{ provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }
|
|
99
|
-
], ngImport: i0, template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"
|
|
100
|
+
], ngImport: i0, template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"{{calendarIconClass}}\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n {{ date.day }}\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n <span *ngIf=\"isFooter\">\r\n <hr class=\"my-0\" />\r\n <span *ngIf=\"footer\">\r\n {{footer}}\r\n </span>\r\n <span *ngIf=\"!footer\">\r\n <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n [disabled]=\"disabled\">{{todayLabel}}</button>\r\n <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n </span>\r\n </span>\r\n</ng-template>", styles: ["::ng-deep html[dir=rtl] .ngb-dp-arrow-prev .ngb-dp-navigation-chevron{transform:rotate(45deg)}::ng-deep html[dir=rtl] .ngb-dp-arrow-next .ngb-dp-navigation-chevron{transform:rotate(-135deg)}::ng-deep html[dir=rtl] .form-select{background-position:left .75rem center}::ng-deep html[dir=rtl] .ngb-dp-month:first-child .ngb-dp-week{padding-right:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month:last-child .ngb-dp-week{padding-left:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-right:1rem}::ng-deep html[dir=rtl] .input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0;border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}::ng-deep html[dir=rtl] .input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-right:calc(var(--bs-border-width) * -1);border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-top-right-radius:0;border-bottom-right-radius:0}::ng-deep .ngb-dp-day{display:flex;align-items:center}.custom-day{text-align:center;padding:.185rem .25rem;border-radius:.25rem;display:inline-block;width:2rem;height:2rem;line-height:1.7}.weekend{color:var(--bs-danger)}.custom-day:hover,.custom-day.focused{background-color:var(--bs-gray-300)}.hidden{display:none}\n"], dependencies: [{ kind: "ngmodule", type: NgbDatepickerModule }, { kind: "directive", type: i2.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "contentTemplate", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "popperOptions", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
100
101
|
}
|
|
101
|
-
|
|
102
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImport: i0, type: YsDatepickerPopupPersianComponent, decorators: [{
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: YsDatepickerPopupPersianComponent, decorators: [{
|
|
103
103
|
type: Component,
|
|
104
104
|
args: [{ selector: 'ys-datepicker-popup-persian', standalone: true, imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf], providers: [
|
|
105
105
|
{
|
|
@@ -111,8 +111,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
111
111
|
{ provide: NgbCalendar, useClass: NgbCalendarPersian },
|
|
112
112
|
{ provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },
|
|
113
113
|
{ provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }
|
|
114
|
-
], template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"
|
|
115
|
-
}], ctorParameters:
|
|
114
|
+
], template: "<form class=\"row row-cols-sm-auto\">\r\n <div class=\"col-12\">\r\n <div class=\"input-group\">\r\n <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n (ngModelChange)=\"valueChanged(value)\" />\r\n <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n <i class=\"{{calendarIconClass}}\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n let-focused=\"focused\">\r\n <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n {{ date.day }}\r\n </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n <span *ngIf=\"isFooter\">\r\n <hr class=\"my-0\" />\r\n <span *ngIf=\"footer\">\r\n {{footer}}\r\n </span>\r\n <span *ngIf=\"!footer\">\r\n <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n [disabled]=\"disabled\">{{todayLabel}}</button>\r\n <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n </span>\r\n </span>\r\n</ng-template>", styles: ["::ng-deep html[dir=rtl] .ngb-dp-arrow-prev .ngb-dp-navigation-chevron{transform:rotate(45deg)}::ng-deep html[dir=rtl] .ngb-dp-arrow-next .ngb-dp-navigation-chevron{transform:rotate(-135deg)}::ng-deep html[dir=rtl] .form-select{background-position:left .75rem center}::ng-deep html[dir=rtl] .ngb-dp-month:first-child .ngb-dp-week{padding-right:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month:last-child .ngb-dp-week{padding-left:.25rem}::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,::ng-deep html[dir=rtl] .ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-right:1rem}::ng-deep html[dir=rtl] .input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,::ng-deep html[dir=rtl] .input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0;border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}::ng-deep html[dir=rtl] .input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-right:calc(var(--bs-border-width) * -1);border-top-left-radius:.375rem;border-bottom-left-radius:.375rem;border-top-right-radius:0;border-bottom-right-radius:0}::ng-deep .ngb-dp-day{display:flex;align-items:center}.custom-day{text-align:center;padding:.185rem .25rem;border-radius:.25rem;display:inline-block;width:2rem;height:2rem;line-height:1.7}.weekend{color:var(--bs-danger)}.custom-day:hover,.custom-day.focused{background-color:var(--bs-gray-300)}.hidden{display:none}\n"] }]
|
|
115
|
+
}], ctorParameters: () => [{ type: i1.I18n }], propDecorators: { container: [{
|
|
116
116
|
type: Input
|
|
117
117
|
}], firstDayOfWeek: [{
|
|
118
118
|
type: Input
|
|
@@ -128,7 +128,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.0", ngImpor
|
|
|
128
128
|
type: Input
|
|
129
129
|
}], footer: [{
|
|
130
130
|
type: Input
|
|
131
|
+
}], calendarIconClass: [{
|
|
132
|
+
type: Input
|
|
131
133
|
}], disabled: [{
|
|
132
134
|
type: Input
|
|
133
135
|
}] } });
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ys-datepicker-popup-persian.component.js","sourceRoot":"","sources":["../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup-persian/ys-datepicker-popup-persian.component.ts","../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup-persian/ys-datepicker-popup-persian.component.html"],"names":[],"mappings":"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","sourcesContent":["import { JsonPipe, NgIf } from '@angular/common';\r\nimport { Component, Input, TemplateRef, forwardRef, inject } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgbCalendar, NgbCalendarPersian, NgbDate, NgbDateParserFormatter, NgbDateStruct, NgbDatepickerI18n, NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';\r\nimport { JalaliDate } from '../models';\r\nimport { I18n, LanguageType, YsDateParserFormatterService, YsDatepickerI18nService } from '../services';\r\n\r\n@Component({\r\n  selector: 'ys-datepicker-popup-persian',\r\n  standalone: true,\r\n  imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf],\r\n  templateUrl: './ys-datepicker-popup-persian.component.html',\r\n  styleUrls: ['./ys-datepicker-popup-persian.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => YsDatepickerPopupPersianComponent),\r\n      multi: true\r\n    },\r\n    I18n,\r\n    { provide: NgbCalendar, useClass: NgbCalendarPersian },\r\n    { provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },\r\n    { provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }\r\n  ]\r\n})\r\nexport class YsDatepickerPopupPersianComponent implements ControlValueAccessor {\r\n\r\n  calendar = inject(NgbCalendar);\r\n  today = inject(NgbCalendar).getToday();\r\n\r\n  _value: NgbDateStruct | null = null;\r\n  get value(): NgbDateStruct | null {\r\n    return this._value;\r\n  }\r\n  set value(val: NgbDateStruct | null) {\r\n    this._value = val;\r\n  }\r\n\r\n  @Input() container: string = '';\r\n  @Input() firstDayOfWeek: number = 6;\r\n  @Input() weekend: number[] = [5];\r\n  private _language: string = LanguageType[LanguageType.fa];\r\n  @Input()\r\n  get language(): string {\r\n    return this._language;\r\n  }\r\n  set language(value: string) {\r\n    this._language = value;\r\n    this.i18N.language = this._language;\r\n  }\r\n\r\n  @Input() isFooter: boolean = true;\r\n  @Input() closeLabel: string = \"بستن\";\r\n  @Input() todayLabel: string = \"امروز\";\r\n  @Input() footer: TemplateRef<any> | null = null;\r\n\r\n  @Input() disabled: boolean = false;\r\n  onChange: any = () => { }\r\n  onTouched: any = () => { }\r\n\r\n  constructor(private i18N: I18n) {\r\n    this.language = LanguageType[LanguageType.fa];\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    if (!obj) {\r\n      this.value = null;\r\n      return;\r\n    }\r\n\r\n    var date: Date = obj;\r\n    let persianDate: number[] = JalaliDate.gregorianToJalali(date.getFullYear(), date.getMonth() + 1, date.getDate());\r\n    this.value = { year: persianDate[0], month: persianDate[1], day: persianDate[2] };\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  markDisabled = (date: NgbDate, current?: { month: number; year: number }) => date.month !== current?.month;\r\n  isWeekend = (date: NgbDate) => this.weekend.includes(this.calendar.getWeekday(date));\r\n\r\n  valueChanged(newDate: NgbDateStruct | string | null) {\r\n    if (newDate) {\r\n      if (typeof newDate == 'string') {\r\n        let temp = newDate.split('/');\r\n        let convertedDate: number[] = JalaliDate.jalaliToGregorian(+temp[0], (+temp[1]) - 1, +temp[2]);\r\n        let res: Date = new Date(+convertedDate[0], (+convertedDate[1]) - 1, +convertedDate[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      } else {\r\n        let convertedDate: number[] = JalaliDate.jalaliToGregorian(newDate.year, newDate.month, newDate.day);\r\n        var res: Date = new Date(+convertedDate[0], +convertedDate[1] - 1, +convertedDate[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      }\r\n    } else {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    }\r\n  }\r\n\r\n  setToday() {\r\n    this.value = this.today;\r\n    this.valueChanged(this.value);\r\n  }\r\n\r\n}","<form class=\"row row-cols-sm-auto\">\r\n    <div class=\"col-12\">\r\n        <div class=\"input-group\">\r\n            <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n                #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n                [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n                (ngModelChange)=\"valueChanged(value)\" />\r\n            <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n                <i class=\"fa-solid fa-calendar-days\"></i>\r\n            </button>\r\n        </div>\r\n    </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n    let-focused=\"focused\">\r\n    <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n        [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n        {{ date.day }}\r\n    </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n    <span *ngIf=\"isFooter\">\r\n        <hr class=\"my-0\" />\r\n        <span *ngIf=\"footer\">\r\n            {{footer}}\r\n        </span>\r\n        <span *ngIf=\"!footer\">\r\n            <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n                [disabled]=\"disabled\">{{todayLabel}}</button>\r\n            <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n        </span>\r\n    </span>\r\n</ng-template>"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ys-datepicker-popup-persian.component.js","sourceRoot":"","sources":["../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup-persian/ys-datepicker-popup-persian.component.ts","../../../../../../../projects/yoozsoft/yoozsoft-ng/datepicker/src/ys-datepicker-popup-persian/ys-datepicker-popup-persian.component.html"],"names":[],"mappings":"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","sourcesContent":["import { JsonPipe, NgIf } from '@angular/common';\r\nimport { Component, Input, TemplateRef, forwardRef, inject } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgbCalendar, NgbCalendarPersian, NgbDate, NgbDateParserFormatter, NgbDateStruct, NgbDatepickerI18n, NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';\r\nimport { JalaliDate } from '../models';\r\nimport { I18n, LanguageType, YsDateParserFormatterService, YsDatepickerI18nService } from '../services';\r\n\r\n@Component({\r\n  selector: 'ys-datepicker-popup-persian',\r\n  standalone: true,\r\n  imports: [NgbDatepickerModule, FormsModule, JsonPipe, NgIf],\r\n  templateUrl: './ys-datepicker-popup-persian.component.html',\r\n  styleUrls: ['./ys-datepicker-popup-persian.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => YsDatepickerPopupPersianComponent),\r\n      multi: true\r\n    },\r\n    I18n,\r\n    { provide: NgbCalendar, useClass: NgbCalendarPersian },\r\n    { provide: NgbDatepickerI18n, useClass: YsDatepickerI18nService },\r\n    { provide: NgbDateParserFormatter, useClass: YsDateParserFormatterService }\r\n  ]\r\n})\r\nexport class YsDatepickerPopupPersianComponent implements ControlValueAccessor {\r\n\r\n  calendar = inject(NgbCalendar);\r\n  today = inject(NgbCalendar).getToday();\r\n\r\n  _value: NgbDateStruct | null = null;\r\n  get value(): NgbDateStruct | null {\r\n    return this._value;\r\n  }\r\n  set value(val: NgbDateStruct | null) {\r\n    this._value = val;\r\n  }\r\n\r\n  @Input() container: \"body\" | null = null;\r\n  @Input() firstDayOfWeek: number = 6;\r\n  @Input() weekend: number[] = [5];\r\n  private _language: string = LanguageType[LanguageType.fa];\r\n  @Input()\r\n  get language(): string {\r\n    return this._language;\r\n  }\r\n  set language(value: string) {\r\n    this._language = value;\r\n    this.i18N.language = this._language;\r\n  }\r\n\r\n  @Input() isFooter: boolean = true;\r\n  @Input() closeLabel: string = \"بستن\";\r\n  @Input() todayLabel: string = \"امروز\";\r\n  @Input() footer: TemplateRef<any> | null = null;\r\n  @Input() calendarIconClass: string = \"fa-solid fa-calendar-days\";\r\n\r\n  @Input() disabled: boolean = false;\r\n  onChange: any = () => { }\r\n  onTouched: any = () => { }\r\n\r\n  constructor(private i18N: I18n) {\r\n    this.language = LanguageType[LanguageType.fa];\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    if (!obj) {\r\n      this.value = null;\r\n      return;\r\n    }\r\n\r\n    var date: Date = obj;\r\n    let persianDate: number[] = JalaliDate.gregorianToJalali(date.getFullYear(), date.getMonth() + 1, date.getDate());\r\n    this.value = { year: persianDate[0], month: persianDate[1], day: persianDate[2] };\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  markDisabled = (date: NgbDate, current?: { month: number; year: number }) => date.month !== current?.month;\r\n  isWeekend = (date: NgbDate) => this.weekend.includes(this.calendar.getWeekday(date));\r\n\r\n  valueChanged(newDate: NgbDateStruct | string | null) {\r\n    if (newDate) {\r\n      if (typeof newDate == 'string') {\r\n        let temp = newDate.split('/');\r\n        let convertedDate: number[] = JalaliDate.jalaliToGregorian(+temp[0], (+temp[1]) - 1, +temp[2]);\r\n        let res: Date = new Date(+convertedDate[0], (+convertedDate[1]) - 1, +convertedDate[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      } else {\r\n        let convertedDate: number[] = JalaliDate.jalaliToGregorian(newDate.year, newDate.month, newDate.day);\r\n        var res: Date = new Date(+convertedDate[0], +convertedDate[1] - 1, +convertedDate[2]);\r\n        this.onChange(res);\r\n        this.onTouched(res);\r\n      }\r\n    } else {\r\n      this.onChange(null);\r\n      this.onTouched(null);\r\n    }\r\n  }\r\n\r\n  setToday() {\r\n    this.value = this.today;\r\n    this.valueChanged(this.value);\r\n  }\r\n\r\n}","<form class=\"row row-cols-sm-auto\">\r\n    <div class=\"col-12\">\r\n        <div class=\"input-group\">\r\n            <input class=\"form-control\" placeholder=\"yyyy/mm/dd\" name=\"dp\" [(ngModel)]=\"value\" ngbDatepicker\r\n                #datepicker=\"ngbDatepicker\" [container]=\"container\" [markDisabled]=\"markDisabled\" [disabled]=\"disabled\"\r\n                [footerTemplate]=\"footerTemplate\" [firstDayOfWeek]=\"firstDayOfWeek\" [dayTemplate]=\"customDay\"\r\n                (ngModelChange)=\"valueChanged(value)\" />\r\n            <button class=\"btn btn-outline-secondary\" (click)=\"datepicker.toggle()\" type=\"button\">\r\n                <i class=\"{{calendarIconClass}}\"></i>\r\n            </button>\r\n        </div>\r\n    </div>\r\n</form>\r\n\r\n<ng-template #customDay let-date let-currentMonth=\"currentMonth\" let-selected=\"selected\" let-disabled=\"disabled\"\r\n    let-focused=\"focused\">\r\n    <span class=\"custom-day\" [class.weekend]=\"isWeekend(date)\" [class.focused]=\"focused\" [class.bg-primary]=\"selected\"\r\n        [class.hidden]=\"date.month !== currentMonth\" [class.text-muted]=\"disabled\">\r\n        {{ date.day }}\r\n    </span>\r\n</ng-template>\r\n\r\n<ng-template #footerTemplate>\r\n    <span *ngIf=\"isFooter\">\r\n        <hr class=\"my-0\" />\r\n        <span *ngIf=\"footer\">\r\n            {{footer}}\r\n        </span>\r\n        <span *ngIf=\"!footer\">\r\n            <button class=\"btn btn-primary btn-sm m-2 float-start\" (click)=\"setToday(); datepicker.close()\"\r\n                [disabled]=\"disabled\">{{todayLabel}}</button>\r\n            <button class=\"btn btn-secondary btn-sm m-2 float-end\" (click)=\"datepicker.close()\">{{closeLabel}}</button>\r\n        </span>\r\n    </span>\r\n</ng-template>"]}
|