adb-shared 5.0.47 → 5.0.49

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.
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
177
177
  }], hide: [{
178
178
  type: Output
179
179
  }] } });
180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.component.ts","../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output } from \"@angular/core\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { addDays, addMonths, addYears, eachDayOfInterval, eachWeekOfInterval, endOfDay, endOfMonth, getHours, getISOWeek, getMinutes, getMonth, isSameDay, isSameMonth, isSameYear, isValid, isWithinInterval, parseISO, startOfDay, startOfMonth, subMonths, subYears } from \"date-fns\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { AdbDatePickerDirective } from \"./adb-date-picker.directive\";\r\n\r\n@Component({\r\n    selector: 'adb-date-picker',\r\n    templateUrl: './adb-date-picker.component.html'\r\n})\r\nexport class AdbDatePickerComponent implements OnInit, OnDestroy {\r\n    private subscriptions = new Subscription();\r\n    static MONTHS = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];\r\n    static WEEK_DAYS = ['1', '2', '3', '4', '5', '6', '7'];\r\n    static YEAR_INTERVALL = 8;\r\n    currentdDate: Date = new Date();\r\n    currentMonth: number;\r\n\r\n    selectedDate: Date = new Date();\r\n    years: { value: Date, title: string, isThisYear: boolean }[];\r\n    months: { value: number, isThisMonth: boolean }[];\r\n    weekDays = AdbDatePickerComponent.WEEK_DAYS;\r\n    weeks: PickerWeek[];\r\n    range: { start: any; end: any; };\r\n    noYearMode = false;;\r\n\r\n    @Input() initialDate: Date;\r\n    @Input() settings: any;\r\n    @Input() toLeft: boolean;\r\n\r\n    @HostBinding('id')\r\n    @Input() id: string;\r\n\r\n    @Output() selectDate = new EventEmitter<Date>();\r\n    @Output() hide = new EventEmitter<void>();\r\n\r\n    constructor(public elementRef: ElementRef, private translate: TranslateService) {\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.settings) {\r\n            if (this.settings?.minDate || this.settings?.maxDate) {\r\n                const minDate = AdbDatePickerComponent.parseDate(this.settings.minDate);\r\n                const maxDate = AdbDatePickerComponent.parseDate(this.settings.maxDate);\r\n                this.range = {\r\n                    start: minDate ? startOfDay(minDate) : subYears(new Date(), 1000),\r\n                    end: maxDate ? endOfDay(maxDate) : addYears(new Date(), 1000)\r\n                };\r\n            }\r\n            if(this.settings.noYear){\r\n                this.noYearMode = this.settings.noYear;\r\n            }\r\n        }\r\n        this.selectedDate = this.currentdDate = this.initialDate ?? new Date();\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n        this.createCalendar()\r\n    }\r\n\r\n    onShowYear(): void {\r\n        this.months = null;\r\n        this.loadYearsInterval();\r\n    }\r\n\r\n    onShowMonth(): void {\r\n        this.years = null;\r\n        this.loadMonths();\r\n    }\r\n\r\n    onSelectYear(inYear?: Date): void {\r\n        this.selectedDate.setFullYear(inYear.getFullYear());\r\n        this.loadMonths();\r\n        this.years = null;\r\n    }\r\n\r\n    onSelectMonth(inMonth?: number): void {\r\n        this.selectedDate.setMonth(inMonth);\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n        this.createCalendar();\r\n        this.years = null;\r\n        this.months = null;\r\n    }\r\n\r\n    onPrev(): void {\r\n        if (this.years) {\r\n            this.selectedDate = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);\r\n            this.loadYearsInterval();\r\n        } else if (this.months) {\r\n            this.selectedDate = subYears(this.selectedDate, 1);\r\n            this.loadMonths();\r\n        } else {\r\n            this.selectedDate = subMonths(this.selectedDate, 1);\r\n            this.createCalendar();\r\n        }\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n    }\r\n\r\n    onNext(): void {\r\n        if (this.years) {\r\n            this.selectedDate = addYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);\r\n            this.loadYearsInterval();\r\n        } else if (this.months) {\r\n            this.selectedDate = addYears(this.selectedDate, 1);\r\n            this.loadMonths();\r\n        } else {\r\n            this.selectedDate = addMonths(this.selectedDate, 1);\r\n            this.createCalendar();\r\n        }\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n    }\r\n\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscriptions.unsubscribe();\r\n    }\r\n\r\n    private loadMonths(): void {\r\n        this.months = AdbDatePickerComponent.MONTHS.map(x => {\r\n            return {\r\n                value: x,\r\n                isThisMonth: getMonth(this.selectedDate) === x && isSameYear(this.currentdDate, this.selectedDate)\r\n            }\r\n        });\r\n    }\r\n\r\n    private loadYearsInterval() {\r\n        let year = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);\r\n        const years = [];\r\n        for (let i = 0; i < 16; i++) {\r\n            years.push({\r\n                value: year,\r\n                title: year.getFullYear(),\r\n                isThisYear: isSameYear(year, this.currentdDate)\r\n            });\r\n            year = addYears(year, 1);\r\n        }\r\n        this.years = years;\r\n    }\r\n\r\n    onSelectDate(day: PickerDay): void {\r\n        this.selectDate.emit(day.value);\r\n    }\r\n\r\n    private createCalendar() {\r\n        const weeks = [];\r\n        const monthInterval = { start: startOfMonth(this.selectedDate), end: endOfMonth(this.selectedDate) };\r\n        var fnsWweeks = eachWeekOfInterval(monthInterval, { weekStartsOn: this.translate.currentLang === 'sv' || this.translate.currentLang === 'sv-SE' ? 1 : 0 });\r\n        for (const fnsWeek of fnsWweeks) {\r\n            const week = { weekNumber: 0, days: [] };\r\n            week.weekNumber = getISOWeek(new Date(fnsWeek));\r\n            const weekInterval = { start: new Date(fnsWeek), end: addDays(new Date(fnsWeek), 6) };\r\n            week.days = eachDayOfInterval(weekInterval).map(day => {\r\n                day.setHours(getHours(new Date()));\r\n                day.setMinutes(getMinutes(new Date()));\r\n                return {\r\n                    value: day,\r\n                    isSelected: isSameYear(day, this.initialDate) && isSameDay(day, this.initialDate) && isSameMonth(day, this.initialDate),\r\n                    isInRange: this.range ? isWithinInterval(day, this.range) : true,\r\n                    isToday: isSameDay(day, new Date()),\r\n                    inMonth: monthInterval.start.getMonth() === day.getMonth()\r\n                };\r\n            });\r\n            weeks.push(week);\r\n        }\r\n        this.weeks = weeks;\r\n    }\r\n\r\n    static parseDate(value: Date | string): Date {\r\n        if (typeof value === 'string') {\r\n            if (isValid(parseISO(value))) {\r\n                return parseISO(value);\r\n            } else {\r\n                return null;\r\n            }\r\n        } else if (value instanceof Date) {\r\n            return value;\r\n        } else {\r\n            return null;\r\n        }\r\n    }\r\n}\r\n\r\nexport interface PickerWeek {\r\n    weeks: {\r\n        weekNumber: number;\r\n        days: PickerDay[]\r\n    }[];\r\n}\r\n\r\nexport interface PickerDay {\r\n    value: Date,\r\n    isToday: boolean,\r\n    isInRange: boolean,\r\n    inMonth: boolean,\r\n    isSelected: boolean\r\n}","<div class=\"position-relative\" [class.to-left]=\"toLeft\">\r\n    <nav class=\"bg-white shadow rounded position-absolute\" style=\"width:350px\">\r\n        <header class=\"bg-primary p-2 rounded-top d-flex justify-content-between align-items-center gap-1\">\r\n            <button tabIndex=\"-1\" class=\"btn btn-primary text-white  rounded-pill\" type=\"button\" (click)=\"onPrev()\" [disabled]=\"noYearMode&&currentMonth===0\"><span class=\"fa fa-chevron-left\"></span></button>\r\n            <ng-container *ngIf=\"!years&&!months\">\r\n                <button tabIndex=\"-1\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onShowMonth();$event.stopPropagation()\">{{selectedDate|adbLocaleDate:'MMM'}}</button>\r\n                <button *ngIf=\"!noYearMode\" tabIndex=\"-1\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onShowYear();$event.stopPropagation()\">{{selectedDate|date:'yyyy'}}</button>\r\n            </ng-container>\r\n            <button tabIndex=\"-1\" *ngIf=\"years\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"years=null;$event.stopPropagation()\">{{years[0].title}} - {{years[years.length-1].title}}</button>\r\n            <button tabIndex=\"-1\" *ngIf=\"months\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onShowYear();$event.stopPropagation()\">{{selectedDate|date:'yyyy'}}</button>\r\n            <button tabIndex=\"-1\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onNext()\" [disabled]=\"noYearMode&&currentMonth===11\"><span class=\"fa fa-chevron-right\"></span></button>\r\n        </header>\r\n        <div class=\"p-0 border calendar\">\r\n            <ul class=\"list-unstyled row\" *ngIf=\"years\">\r\n                <li class=\"col-3 text-center px-2 py-3\" *ngFor=\"let year of years\">\r\n                    <button type=\"button\" tabIndex=\"-1\" class=\"btn btn-sm btn-outline-secondary rounded-pill\" (click)=\"onSelectYear(year.value);$event.stopPropagation()\" [class.active]=\"year.hasObservation\" [ngClass]=\"{'border border-secondary':year.isThisYear}\">{{year.title}}</button>\r\n                </li>\r\n            </ul>\r\n            <ul class=\"list-unstyled row\" *ngIf=\"months\">\r\n                <li class=\"col-4 text-center px-2 py-3\" *ngFor=\"let month of months\">\r\n                    <button type=\"button\" tabIndex=\"-1\" class=\"btn btn-sm btn-outline-secondary rounded-pill\" (click)=\"onSelectMonth(month.value);$event.stopPropagation()\" [class.active]=\"month.observation\" [ngClass]=\"{'border border-secondary':month.isThisMonth}\">\r\n                        {{'MONTHS.'+(month.value+1)|translate}}\r\n                    </button>\r\n                </li>\r\n            </ul>\r\n            <div class=\"days\" *ngIf=\"!years&&!months\">\r\n                <div class=\"text-center border-bottom py-2 text-muted\" *ngFor=\"let weekDay of weekDays\">{{'WEEK_DAYS.'+weekDay|translate}}</div>\r\n                <ng-container *ngFor=\"let week of weeks\">\r\n                    <button tabIndex=\"-1\" class=\"btn rounded-circle p-0 m-2\" *ngFor=\"let day of week.days\" (click)=\"onSelectDate(day)\" type=\"button\" \r\n                        [class.border]=\"day.isToday\" [class.bg-primary]=\"day.isSelected\" [class.text-white]=\"day.isSelected\" [ngClass]=\"{'pe-none text-muted opacity-50':!day.inMonth||!day.isInRange}\">\r\n                        <small>{{day.value|date:'d'}}</small>\r\n                    </button>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n    </nav>\r\n</div>\r\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.component.ts","../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output } from \"@angular/core\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { addDays, addMonths, addYears, eachDayOfInterval, eachWeekOfInterval, endOfDay, endOfMonth, getHours, getISOWeek, getMinutes, getMonth, isSameDay, isSameMonth, isSameYear, isValid, isWithinInterval, parseISO, startOfDay, startOfMonth, subMonths, subYears } from \"date-fns\";\r\nimport { Subscription } from \"rxjs\";\r\n\r\n@Component({\r\n    selector: 'adb-date-picker',\r\n    templateUrl: './adb-date-picker.component.html'\r\n})\r\nexport class AdbDatePickerComponent implements OnInit, OnDestroy {\r\n    private subscriptions = new Subscription();\r\n    static MONTHS = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];\r\n    static WEEK_DAYS = ['1', '2', '3', '4', '5', '6', '7'];\r\n    static YEAR_INTERVALL = 8;\r\n    currentdDate: Date = new Date();\r\n    currentMonth: number;\r\n\r\n    selectedDate: Date = new Date();\r\n    years: { value: Date, title: string, isThisYear: boolean }[];\r\n    months: { value: number, isThisMonth: boolean }[];\r\n    weekDays = AdbDatePickerComponent.WEEK_DAYS;\r\n    weeks: PickerWeek[];\r\n    range: { start: any; end: any; };\r\n    noYearMode = false;;\r\n\r\n    @Input() initialDate: Date;\r\n    @Input() settings: any;\r\n    @Input() toLeft: boolean;\r\n\r\n    @HostBinding('id')\r\n    @Input() id: string;\r\n\r\n    @Output() selectDate = new EventEmitter<Date>();\r\n    @Output() hide = new EventEmitter<void>();\r\n\r\n    constructor(public elementRef: ElementRef, private translate: TranslateService) {\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.settings) {\r\n            if (this.settings?.minDate || this.settings?.maxDate) {\r\n                const minDate = AdbDatePickerComponent.parseDate(this.settings.minDate);\r\n                const maxDate = AdbDatePickerComponent.parseDate(this.settings.maxDate);\r\n                this.range = {\r\n                    start: minDate ? startOfDay(minDate) : subYears(new Date(), 1000),\r\n                    end: maxDate ? endOfDay(maxDate) : addYears(new Date(), 1000)\r\n                };\r\n            }\r\n            if(this.settings.noYear){\r\n                this.noYearMode = this.settings.noYear;\r\n            }\r\n        }\r\n        this.selectedDate = this.currentdDate = this.initialDate ?? new Date();\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n        this.createCalendar()\r\n    }\r\n\r\n    onShowYear(): void {\r\n        this.months = null;\r\n        this.loadYearsInterval();\r\n    }\r\n\r\n    onShowMonth(): void {\r\n        this.years = null;\r\n        this.loadMonths();\r\n    }\r\n\r\n    onSelectYear(inYear?: Date): void {\r\n        this.selectedDate.setFullYear(inYear.getFullYear());\r\n        this.loadMonths();\r\n        this.years = null;\r\n    }\r\n\r\n    onSelectMonth(inMonth?: number): void {\r\n        this.selectedDate.setMonth(inMonth);\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n        this.createCalendar();\r\n        this.years = null;\r\n        this.months = null;\r\n    }\r\n\r\n    onPrev(): void {\r\n        if (this.years) {\r\n            this.selectedDate = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);\r\n            this.loadYearsInterval();\r\n        } else if (this.months) {\r\n            this.selectedDate = subYears(this.selectedDate, 1);\r\n            this.loadMonths();\r\n        } else {\r\n            this.selectedDate = subMonths(this.selectedDate, 1);\r\n            this.createCalendar();\r\n        }\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n    }\r\n\r\n    onNext(): void {\r\n        if (this.years) {\r\n            this.selectedDate = addYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);\r\n            this.loadYearsInterval();\r\n        } else if (this.months) {\r\n            this.selectedDate = addYears(this.selectedDate, 1);\r\n            this.loadMonths();\r\n        } else {\r\n            this.selectedDate = addMonths(this.selectedDate, 1);\r\n            this.createCalendar();\r\n        }\r\n        this.currentMonth = getMonth(this.selectedDate);\r\n    }\r\n\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscriptions.unsubscribe();\r\n    }\r\n\r\n    private loadMonths(): void {\r\n        this.months = AdbDatePickerComponent.MONTHS.map(x => {\r\n            return {\r\n                value: x,\r\n                isThisMonth: getMonth(this.selectedDate) === x && isSameYear(this.currentdDate, this.selectedDate)\r\n            }\r\n        });\r\n    }\r\n\r\n    private loadYearsInterval() {\r\n        let year = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);\r\n        const years = [];\r\n        for (let i = 0; i < 16; i++) {\r\n            years.push({\r\n                value: year,\r\n                title: year.getFullYear(),\r\n                isThisYear: isSameYear(year, this.currentdDate)\r\n            });\r\n            year = addYears(year, 1);\r\n        }\r\n        this.years = years;\r\n    }\r\n\r\n    onSelectDate(day: PickerDay): void {\r\n        this.selectDate.emit(day.value);\r\n    }\r\n\r\n    private createCalendar() {\r\n        const weeks = [];\r\n        const monthInterval = { start: startOfMonth(this.selectedDate), end: endOfMonth(this.selectedDate) };\r\n        var fnsWweeks = eachWeekOfInterval(monthInterval, { weekStartsOn: this.translate.currentLang === 'sv' || this.translate.currentLang === 'sv-SE' ? 1 : 0 });\r\n        for (const fnsWeek of fnsWweeks) {\r\n            const week = { weekNumber: 0, days: [] };\r\n            week.weekNumber = getISOWeek(new Date(fnsWeek));\r\n            const weekInterval = { start: new Date(fnsWeek), end: addDays(new Date(fnsWeek), 6) };\r\n            week.days = eachDayOfInterval(weekInterval).map(day => {\r\n                day.setHours(getHours(new Date()));\r\n                day.setMinutes(getMinutes(new Date()));\r\n                return {\r\n                    value: day,\r\n                    isSelected: isSameYear(day, this.initialDate) && isSameDay(day, this.initialDate) && isSameMonth(day, this.initialDate),\r\n                    isInRange: this.range ? isWithinInterval(day, this.range) : true,\r\n                    isToday: isSameDay(day, new Date()),\r\n                    inMonth: monthInterval.start.getMonth() === day.getMonth()\r\n                };\r\n            });\r\n            weeks.push(week);\r\n        }\r\n        this.weeks = weeks;\r\n    }\r\n\r\n    static parseDate(value: Date | string): Date {\r\n        if (typeof value === 'string') {\r\n            if (isValid(parseISO(value))) {\r\n                return parseISO(value);\r\n            } else {\r\n                return null;\r\n            }\r\n        } else if (value instanceof Date) {\r\n            return value;\r\n        } else {\r\n            return null;\r\n        }\r\n    }\r\n}\r\n\r\nexport interface PickerWeek {\r\n    weeks: {\r\n        weekNumber: number;\r\n        days: PickerDay[]\r\n    }[];\r\n}\r\n\r\nexport interface PickerDay {\r\n    value: Date,\r\n    isToday: boolean,\r\n    isInRange: boolean,\r\n    inMonth: boolean,\r\n    isSelected: boolean\r\n}","<div class=\"position-relative\" [class.to-left]=\"toLeft\">\r\n    <nav class=\"bg-white shadow rounded position-absolute\" style=\"width:350px\">\r\n        <header class=\"bg-primary p-2 rounded-top d-flex justify-content-between align-items-center gap-1\">\r\n            <button tabIndex=\"-1\" class=\"btn btn-primary text-white  rounded-pill\" type=\"button\" (click)=\"onPrev()\" [disabled]=\"noYearMode&&currentMonth===0\"><span class=\"fa fa-chevron-left\"></span></button>\r\n            <ng-container *ngIf=\"!years&&!months\">\r\n                <button tabIndex=\"-1\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onShowMonth();$event.stopPropagation()\">{{selectedDate|adbLocaleDate:'MMM'}}</button>\r\n                <button *ngIf=\"!noYearMode\" tabIndex=\"-1\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onShowYear();$event.stopPropagation()\">{{selectedDate|date:'yyyy'}}</button>\r\n            </ng-container>\r\n            <button tabIndex=\"-1\" *ngIf=\"years\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"years=null;$event.stopPropagation()\">{{years[0].title}} - {{years[years.length-1].title}}</button>\r\n            <button tabIndex=\"-1\" *ngIf=\"months\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onShowYear();$event.stopPropagation()\">{{selectedDate|date:'yyyy'}}</button>\r\n            <button tabIndex=\"-1\" class=\"btn btn-primary text-white rounded-pill\" type=\"button\" (click)=\"onNext()\" [disabled]=\"noYearMode&&currentMonth===11\"><span class=\"fa fa-chevron-right\"></span></button>\r\n        </header>\r\n        <div class=\"p-0 border calendar\">\r\n            <ul class=\"list-unstyled row\" *ngIf=\"years\">\r\n                <li class=\"col-3 text-center px-2 py-3\" *ngFor=\"let year of years\">\r\n                    <button type=\"button\" tabIndex=\"-1\" class=\"btn btn-sm btn-outline-secondary rounded-pill\" (click)=\"onSelectYear(year.value);$event.stopPropagation()\" [class.active]=\"year.hasObservation\" [ngClass]=\"{'border border-secondary':year.isThisYear}\">{{year.title}}</button>\r\n                </li>\r\n            </ul>\r\n            <ul class=\"list-unstyled row\" *ngIf=\"months\">\r\n                <li class=\"col-4 text-center px-2 py-3\" *ngFor=\"let month of months\">\r\n                    <button type=\"button\" tabIndex=\"-1\" class=\"btn btn-sm btn-outline-secondary rounded-pill\" (click)=\"onSelectMonth(month.value);$event.stopPropagation()\" [class.active]=\"month.observation\" [ngClass]=\"{'border border-secondary':month.isThisMonth}\">\r\n                        {{'MONTHS.'+(month.value+1)|translate}}\r\n                    </button>\r\n                </li>\r\n            </ul>\r\n            <div class=\"days\" *ngIf=\"!years&&!months\">\r\n                <div class=\"text-center border-bottom py-2 text-muted\" *ngFor=\"let weekDay of weekDays\">{{'WEEK_DAYS.'+weekDay|translate}}</div>\r\n                <ng-container *ngFor=\"let week of weeks\">\r\n                    <button tabIndex=\"-1\" class=\"btn rounded-circle p-0 m-2\" *ngFor=\"let day of week.days\" (click)=\"onSelectDate(day)\" type=\"button\" \r\n                        [class.border]=\"day.isToday\" [class.bg-primary]=\"day.isSelected\" [class.text-white]=\"day.isSelected\" [ngClass]=\"{'pe-none text-muted opacity-50':!day.inMonth||!day.isInRange}\">\r\n                        <small>{{day.value|date:'d'}}</small>\r\n                    </button>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n    </nav>\r\n</div>\r\n"]}
@@ -18,16 +18,13 @@ export class AdbDatePickerDirective {
18
18
  this.subscriptions = new Subscription();
19
19
  this.format = 'yyyy-MM-dd';
20
20
  this.settings = null;
21
- this.pickOnly = true;
22
21
  this.onValidationChange = () => { };
23
22
  //ControlValueAccessor
24
23
  this.onChange = () => { };
25
24
  this.onTouched = () => { };
26
25
  }
27
26
  ngOnInit() {
28
- if (!this.pickOnly) {
29
- this.elementRef.nativeElement.setAttribute("placeholder", this.format);
30
- }
27
+ this.elementRef.nativeElement.setAttribute("placeholder", this.format);
31
28
  }
32
29
  onClick() {
33
30
  if (this.adbDatePickerService.viewRef) {
@@ -51,33 +48,32 @@ export class AdbDatePickerDirective {
51
48
  this.adbDatePickerService.viewRef = viewRef;
52
49
  }
53
50
  onKeyup(event) {
54
- if (!this.pickOnly) {
55
- const date = AdbDatePickerDirective.tryParse(event.target.value);
56
- if (date) {
57
- const now = new Date();
58
- date.setHours(now.getHours());
59
- date.setMinutes(now.getMinutes());
60
- date.setSeconds(now.getSeconds());
61
- this.onChange(date);
62
- }
63
- else {
64
- this.onChange(event.target.value); //send inccorect values to form
65
- }
51
+ const date = AdbDatePickerDirective.tryParse(event.target.value);
52
+ if (date) {
53
+ const now = new Date();
54
+ date.setHours(now.getHours());
55
+ date.setMinutes(now.getMinutes());
56
+ date.setSeconds(now.getSeconds());
57
+ this.onChange(date);
58
+ }
59
+ else {
60
+ this.onChange(event.target.value); //send inccorect values to form
66
61
  }
67
62
  }
63
+ onTabDown() {
64
+ this.updateValueOnLeave();
65
+ this.onHide();
66
+ }
67
+ onEscUp() {
68
+ this.updateValueOnLeave();
69
+ this.onHide();
70
+ this.elementRef.nativeElement.blur();
71
+ }
68
72
  onHide() {
69
73
  this.adbDatePickerService.viewRef = null;
70
74
  this.viewContainerRef.detach();
71
75
  this.viewContainerRef.clear();
72
76
  }
73
- handleKeyboardEvent(event) {
74
- if (event.key === 'Tab') {
75
- this.onHide();
76
- }
77
- else if (this.pickOnly) {
78
- event.preventDefault();
79
- }
80
- }
81
77
  onCheckOutSideClick(target) {
82
78
  const nativeElement = this.adbDatePickerService.viewRef?.instance.elementRef.nativeElement ?? null;
83
79
  if (nativeElement) {
@@ -85,12 +81,23 @@ export class AdbDatePickerDirective {
85
81
  if (!target.hasAttribute('adbdatepicker')) {
86
82
  const clickedInside = nativeElement.contains(target);
87
83
  if (!clickedInside) {
84
+ this.updateValueOnLeave();
88
85
  this.onHide();
89
86
  }
90
87
  }
91
88
  }
92
89
  }
93
90
  }
91
+ updateValueOnLeave() {
92
+ if (this.isValid) {
93
+ if (this.initialDate) {
94
+ this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(this.initialDate, this.format, this.translate.currentLang));
95
+ }
96
+ else {
97
+ this.renderer.setProperty(this.elementRef.nativeElement, 'value', '');
98
+ }
99
+ }
100
+ }
94
101
  ngOnDestroy() {
95
102
  this.subscriptions.unsubscribe();
96
103
  }
@@ -98,17 +105,23 @@ export class AdbDatePickerDirective {
98
105
  validate(control) {
99
106
  const value = control.value;
100
107
  if (!value) {
108
+ this.initialDate = null;
109
+ this.isValid = true;
101
110
  return null;
102
111
  }
103
112
  if (value instanceof Date) {
113
+ this.initialDate = value;
114
+ this.isValid = true;
104
115
  return null;
105
116
  }
106
117
  if (typeof value === 'string' || value instanceof String) {
107
118
  const date = AdbDatePickerDirective.tryParse(value);
108
119
  if (!date) {
120
+ this.isValid = false;
109
121
  return { date: true };
110
122
  }
111
123
  }
124
+ this.isValid = true;
112
125
  return null;
113
126
  }
114
127
  registerOnValidatorChange(fn) {
@@ -150,7 +163,7 @@ export class AdbDatePickerDirective {
150
163
  return '' + Math.floor(Math.random() * Date.now());
151
164
  }
152
165
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdbDatePickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.AdbDatePickerService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Directive }); }
153
- /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings", pickOnly: "pickOnly" }, host: { listeners: { "click": "onClick()", "keyup": "onKeyup($event)", "keyup.esc": "onHide()", "keydown": "handleKeyboardEvent($event)", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
166
+ /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings" }, host: { listeners: { "click": "onClick()", "keyup": "onKeyup($event)", "keydown.shift.tab": "onTabDown()", "keydown.tab": "onTabDown()", "down.esc": "onEscUp()", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
154
167
  provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => AdbDatePickerDirective)),
155
168
  multi: true
156
169
  },
@@ -183,22 +196,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
183
196
  type: Input
184
197
  }], settings: [{
185
198
  type: Input
186
- }], pickOnly: [{
187
- type: Input
188
199
  }], onClick: [{
189
200
  type: HostListener,
190
201
  args: ['click']
191
202
  }], onKeyup: [{
192
203
  type: HostListener,
193
204
  args: ['keyup', ['$event']]
194
- }], onHide: [{
205
+ }], onTabDown: [{
206
+ type: HostListener,
207
+ args: ['keydown.shift.tab']
208
+ }, {
195
209
  type: HostListener,
196
- args: ['keyup.esc']
197
- }], handleKeyboardEvent: [{
210
+ args: ['keydown.tab']
211
+ }], onEscUp: [{
198
212
  type: HostListener,
199
- args: ['keydown', ['$event']]
213
+ args: ['down.esc']
200
214
  }], onCheckOutSideClick: [{
201
215
  type: HostListener,
202
216
  args: ['document:click', ['$event.target']]
203
217
  }] } });
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-date-picker.directive.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatDate } from \"@angular/common\";\r\nimport { Directive, ElementRef, forwardRef, HostBinding, HostListener, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewContainerRef } from \"@angular/core\";\r\nimport { AbstractControl, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from \"@angular/forms\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { isValid, parse, parseISO, setHours, setMinutes } from \"date-fns\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { AdbDatePickerComponent } from \"./adb-date-picker.component\";\r\nimport { AdbDatePickerService } from \"./adb-date-picker.service\";\r\n\r\n@Directive({\r\n    selector: `input[adbDatepicker]`,\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AdbDatePickerDirective),\r\n        multi: true\r\n    },\r\n    {\r\n        provide: NG_VALIDATORS,\r\n        useExisting: AdbDatePickerDirective,\r\n        multi: true,\r\n    },]\r\n})\r\nexport class AdbDatePickerDirective implements ControlValueAccessor, Validator, OnInit, OnDestroy {\r\n    @HostBinding('autocomplete') autocomplete = 'off';\r\n    private subscriptions = new Subscription();\r\n    @Input() format = 'yyyy-MM-dd';\r\n    @Input() toLeft: boolean;\r\n    @Input() settings: { maxDate?: Date | string, minDate?: Date | string } = null;\r\n    @Input() pickOnly = true;\r\n    id: string;\r\n    initialDate: Date;\r\n\r\n    constructor(\r\n        private viewContainerRef: ViewContainerRef,\r\n        private renderer: Renderer2,\r\n        private elementRef: ElementRef,\r\n        private adbDatePickerService: AdbDatePickerService,\r\n        public translate: TranslateService) {\r\n\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (!this.pickOnly) {\r\n            this.elementRef.nativeElement.setAttribute(\"placeholder\", this.format);\r\n        }\r\n    }\r\n\r\n    @HostListener('click')\r\n    onClick(): void {\r\n        if (this.adbDatePickerService.viewRef) {\r\n            this.adbDatePickerService.viewRef.destroy();\r\n        }\r\n        const viewRef = this.viewContainerRef.createComponent<AdbDatePickerComponent>(AdbDatePickerComponent);\r\n        viewRef.instance.settings = this.settings;\r\n        viewRef.instance.toLeft = this.toLeft;\r\n        viewRef.instance.initialDate = this.initialDate;\r\n        this.id = this.getId();\r\n        viewRef.instance.id = this.id;\r\n        viewRef.instance.selectDate.subscribe((date) => {\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(date, this.format, this.translate.currentLang));\r\n            this.onChange(date);\r\n            this.initialDate = date;\r\n            this.onHide();\r\n        });\r\n        viewRef.instance.hide.subscribe(() => {\r\n            this.onHide();\r\n        });\r\n        this.adbDatePickerService.viewRef = viewRef;\r\n    }\r\n\r\n    @HostListener('keyup', ['$event']) public onKeyup(event: KeyboardEvent): void {\r\n        if (!this.pickOnly) {\r\n            const date = AdbDatePickerDirective.tryParse((event.target as HTMLInputElement).value);\r\n            if (date) {\r\n                const now = new Date();\r\n                date.setHours(now.getHours()); date.setMinutes(now.getMinutes()); date.setSeconds(now.getSeconds());\r\n                this.onChange(date);\r\n            } else {\r\n                this.onChange((event.target as HTMLInputElement).value); //send inccorect values to form\r\n            }\r\n        }\r\n    }\r\n\r\n    @HostListener('keyup.esc')\r\n    onHide(): void {\r\n        this.adbDatePickerService.viewRef = null;\r\n        this.viewContainerRef.detach();\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    @HostListener('keydown', ['$event'])\r\n    handleKeyboardEvent(event: KeyboardEvent) {\r\n        if (event.key === 'Tab') {\r\n            this.onHide();\r\n        }\r\n        else if (this.pickOnly) {\r\n            event.preventDefault();\r\n        }\r\n    }\r\n\r\n    @HostListener('document:click', ['$event.target'])\r\n    onCheckOutSideClick(target: any): void {\r\n        const nativeElement = this.adbDatePickerService.viewRef?.instance.elementRef.nativeElement ?? null;\r\n        if (nativeElement) {\r\n            if (nativeElement.id === this.id) {\r\n                if (!target.hasAttribute('adbdatepicker')) {\r\n                    const clickedInside = nativeElement.contains(target);\r\n                    if (!clickedInside) {\r\n                        this.onHide();\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscriptions.unsubscribe();\r\n    }\r\n\r\n    //Validator\r\n    validate(control: AbstractControl): ValidationErrors {\r\n        const value = control.value;\r\n        if (!value) {\r\n            return null;\r\n        }\r\n        if (value instanceof Date) {\r\n            return null;\r\n        }\r\n        if (typeof value === 'string' || value instanceof String) {\r\n            const date = AdbDatePickerDirective.tryParse(value as string);\r\n            if (!date) {\r\n                return { date: true }\r\n            }\r\n        }\r\n        return null;\r\n    }\r\n\r\n    onValidationChange: any = () => { };\r\n    registerOnValidatorChange?(fn: () => void): void {\r\n        this.onValidationChange = fn;\r\n    }\r\n\r\n    //ControlValueAccessor\r\n    onChange: any = () => { };\r\n    onTouched: any = () => { };\r\n\r\n    writeValue(value: Date | string): void {\r\n        if (!value) {\r\n            this.initialDate = null;\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', '');\r\n            return;\r\n        }\r\n        if (typeof value === 'string' || value instanceof String) {\r\n            const date = AdbDatePickerDirective.tryParse(value as string);\r\n            if (!date) {\r\n                this.renderer.setProperty(this.elementRef.nativeElement, 'value', value);\r\n                return;\r\n            }\r\n            value = date;\r\n        }\r\n        if (value instanceof Date) {\r\n            this.initialDate = value;\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(this.initialDate, this.format, this.translate.currentLang));\r\n        }\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    setDisabledState?(isDisabled: boolean): void {\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    static tryParse(dateString: string): Date {\r\n        const parsed = parseISO(dateString);\r\n        return isValid(parsed) ? parsed : null;\r\n    }\r\n\r\n    private getId(): string {\r\n        return '' + Math.floor(Math.random() * Date.now())\r\n    }\r\n}"]}
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-date-picker.directive.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/date-picker/adb-date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatDate } from \"@angular/common\";\r\nimport { Directive, ElementRef, forwardRef, HostBinding, HostListener, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewContainerRef } from \"@angular/core\";\r\nimport { AbstractControl, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from \"@angular/forms\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { isValid, parseISO } from \"date-fns\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { AdbDatePickerComponent } from \"./adb-date-picker.component\";\r\nimport { AdbDatePickerService } from \"./adb-date-picker.service\";\r\n\r\n@Directive({\r\n    selector: `input[adbDatepicker]`,\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AdbDatePickerDirective),\r\n        multi: true\r\n    },\r\n    {\r\n        provide: NG_VALIDATORS,\r\n        useExisting: AdbDatePickerDirective,\r\n        multi: true,\r\n    },]\r\n})\r\nexport class AdbDatePickerDirective implements ControlValueAccessor, Validator, OnInit, OnDestroy {\r\n    @HostBinding('autocomplete') autocomplete = 'off';\r\n    private subscriptions = new Subscription();\r\n    @Input() format = 'yyyy-MM-dd';\r\n    @Input() toLeft: boolean;\r\n    @Input() settings: { maxDate?: Date | string, minDate?: Date | string } = null;\r\n    id: string;\r\n    initialDate: Date;\r\n    isValid: boolean;\r\n\r\n    constructor(\r\n        private viewContainerRef: ViewContainerRef,\r\n        private renderer: Renderer2,\r\n        private elementRef: ElementRef,\r\n        private adbDatePickerService: AdbDatePickerService,\r\n        public translate: TranslateService) {\r\n\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.elementRef.nativeElement.setAttribute(\"placeholder\", this.format);\r\n    }\r\n\r\n    @HostListener('click')\r\n    onClick(): void {\r\n        if (this.adbDatePickerService.viewRef) {\r\n            this.adbDatePickerService.viewRef.destroy();\r\n        }\r\n        const viewRef = this.viewContainerRef.createComponent<AdbDatePickerComponent>(AdbDatePickerComponent);\r\n        viewRef.instance.settings = this.settings;\r\n        viewRef.instance.toLeft = this.toLeft;\r\n        viewRef.instance.initialDate = this.initialDate;\r\n        this.id = this.getId();\r\n        viewRef.instance.id = this.id;\r\n        viewRef.instance.selectDate.subscribe((date) => {\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(date, this.format, this.translate.currentLang));\r\n            this.onChange(date);\r\n            this.initialDate = date;\r\n            this.onHide();\r\n        });\r\n        viewRef.instance.hide.subscribe(() => {\r\n            this.onHide();\r\n        });\r\n        this.adbDatePickerService.viewRef = viewRef;\r\n    }\r\n\r\n    @HostListener('keyup', ['$event']) public onKeyup(event: KeyboardEvent): void {\r\n        const date = AdbDatePickerDirective.tryParse((event.target as HTMLInputElement).value);\r\n        if (date) {\r\n            const now = new Date();\r\n            date.setHours(now.getHours()); date.setMinutes(now.getMinutes()); date.setSeconds(now.getSeconds());\r\n            this.onChange(date);\r\n        } else {\r\n            this.onChange((event.target as HTMLInputElement).value); //send inccorect values to form\r\n        }\r\n    }\r\n\r\n    @HostListener('keydown.shift.tab')\r\n    @HostListener('keydown.tab')\r\n    onTabDown(): void {\r\n        this.updateValueOnLeave();\r\n        this.onHide();\r\n    }\r\n\r\n    @HostListener('down.esc')\r\n    onEscUp():void{\r\n        this.updateValueOnLeave();\r\n        this.onHide();\r\n        this.elementRef.nativeElement.blur();\r\n    }\r\n\r\n\r\n    onHide(): void {\r\n        this.adbDatePickerService.viewRef = null;\r\n        this.viewContainerRef.detach();\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    @HostListener('document:click', ['$event.target'])\r\n    onCheckOutSideClick(target: any): void {\r\n        const nativeElement = this.adbDatePickerService.viewRef?.instance.elementRef.nativeElement ?? null;\r\n        if (nativeElement) {\r\n            if (nativeElement.id === this.id) {\r\n                if (!target.hasAttribute('adbdatepicker')) {\r\n                    const clickedInside = nativeElement.contains(target);\r\n                    if (!clickedInside) {\r\n                        this.updateValueOnLeave();\r\n                        this.onHide();\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    private updateValueOnLeave(): void {\r\n        if (this.isValid) {\r\n            if (this.initialDate) {\r\n                this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(this.initialDate, this.format, this.translate.currentLang));\r\n            } else {\r\n                this.renderer.setProperty(this.elementRef.nativeElement, 'value', '');\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscriptions.unsubscribe();\r\n    }\r\n\r\n    //Validator\r\n    validate(control: AbstractControl): ValidationErrors {\r\n        const value = control.value;\r\n        if (!value) {\r\n            this.initialDate = null;\r\n            this.isValid = true;\r\n            return null;\r\n        }\r\n        if (value instanceof Date) {\r\n            this.initialDate = value;\r\n            this.isValid = true;\r\n            return null;\r\n        }\r\n        if (typeof value === 'string' || value instanceof String) {\r\n            const date = AdbDatePickerDirective.tryParse(value as string);\r\n            if (!date) {\r\n                this.isValid = false;\r\n                return { date: true }\r\n            }\r\n        }\r\n        this.isValid = true;\r\n        return null;\r\n    }\r\n\r\n    onValidationChange: any = () => { };\r\n    registerOnValidatorChange?(fn: () => void): void {\r\n        this.onValidationChange = fn;\r\n    }\r\n\r\n    //ControlValueAccessor\r\n    onChange: any = () => { };\r\n    onTouched: any = () => { };\r\n\r\n    writeValue(value: Date | string): void {\r\n        if (!value) {\r\n            this.initialDate = null;\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', '');\r\n            return;\r\n        }\r\n        if (typeof value === 'string' || value instanceof String) {\r\n            const date = AdbDatePickerDirective.tryParse(value as string);\r\n            if (!date) {\r\n                this.renderer.setProperty(this.elementRef.nativeElement, 'value', value);\r\n                return;\r\n            }\r\n            value = date;\r\n        }\r\n        if (value instanceof Date) {\r\n            this.initialDate = value;\r\n            this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(this.initialDate, this.format, this.translate.currentLang));\r\n        }\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    setDisabledState?(isDisabled: boolean): void {\r\n        this.viewContainerRef.clear();\r\n    }\r\n\r\n    static tryParse(dateString: string): Date {\r\n        const parsed = parseISO(dateString);\r\n        return isValid(parsed) ? parsed : null;\r\n    }\r\n\r\n    private getId(): string {\r\n        return '' + Math.floor(Math.random() * Date.now())\r\n    }\r\n}"]}
@@ -1254,16 +1254,13 @@ class AdbDatePickerDirective {
1254
1254
  this.subscriptions = new Subscription();
1255
1255
  this.format = 'yyyy-MM-dd';
1256
1256
  this.settings = null;
1257
- this.pickOnly = true;
1258
1257
  this.onValidationChange = () => { };
1259
1258
  //ControlValueAccessor
1260
1259
  this.onChange = () => { };
1261
1260
  this.onTouched = () => { };
1262
1261
  }
1263
1262
  ngOnInit() {
1264
- if (!this.pickOnly) {
1265
- this.elementRef.nativeElement.setAttribute("placeholder", this.format);
1266
- }
1263
+ this.elementRef.nativeElement.setAttribute("placeholder", this.format);
1267
1264
  }
1268
1265
  onClick() {
1269
1266
  if (this.adbDatePickerService.viewRef) {
@@ -1287,33 +1284,32 @@ class AdbDatePickerDirective {
1287
1284
  this.adbDatePickerService.viewRef = viewRef;
1288
1285
  }
1289
1286
  onKeyup(event) {
1290
- if (!this.pickOnly) {
1291
- const date = AdbDatePickerDirective.tryParse(event.target.value);
1292
- if (date) {
1293
- const now = new Date();
1294
- date.setHours(now.getHours());
1295
- date.setMinutes(now.getMinutes());
1296
- date.setSeconds(now.getSeconds());
1297
- this.onChange(date);
1298
- }
1299
- else {
1300
- this.onChange(event.target.value); //send inccorect values to form
1301
- }
1287
+ const date = AdbDatePickerDirective.tryParse(event.target.value);
1288
+ if (date) {
1289
+ const now = new Date();
1290
+ date.setHours(now.getHours());
1291
+ date.setMinutes(now.getMinutes());
1292
+ date.setSeconds(now.getSeconds());
1293
+ this.onChange(date);
1294
+ }
1295
+ else {
1296
+ this.onChange(event.target.value); //send inccorect values to form
1302
1297
  }
1303
1298
  }
1299
+ onTabDown() {
1300
+ this.updateValueOnLeave();
1301
+ this.onHide();
1302
+ }
1303
+ onEscUp() {
1304
+ this.updateValueOnLeave();
1305
+ this.onHide();
1306
+ this.elementRef.nativeElement.blur();
1307
+ }
1304
1308
  onHide() {
1305
1309
  this.adbDatePickerService.viewRef = null;
1306
1310
  this.viewContainerRef.detach();
1307
1311
  this.viewContainerRef.clear();
1308
1312
  }
1309
- handleKeyboardEvent(event) {
1310
- if (event.key === 'Tab') {
1311
- this.onHide();
1312
- }
1313
- else if (this.pickOnly) {
1314
- event.preventDefault();
1315
- }
1316
- }
1317
1313
  onCheckOutSideClick(target) {
1318
1314
  const nativeElement = this.adbDatePickerService.viewRef?.instance.elementRef.nativeElement ?? null;
1319
1315
  if (nativeElement) {
@@ -1321,12 +1317,23 @@ class AdbDatePickerDirective {
1321
1317
  if (!target.hasAttribute('adbdatepicker')) {
1322
1318
  const clickedInside = nativeElement.contains(target);
1323
1319
  if (!clickedInside) {
1320
+ this.updateValueOnLeave();
1324
1321
  this.onHide();
1325
1322
  }
1326
1323
  }
1327
1324
  }
1328
1325
  }
1329
1326
  }
1327
+ updateValueOnLeave() {
1328
+ if (this.isValid) {
1329
+ if (this.initialDate) {
1330
+ this.renderer.setProperty(this.elementRef.nativeElement, 'value', formatDate(this.initialDate, this.format, this.translate.currentLang));
1331
+ }
1332
+ else {
1333
+ this.renderer.setProperty(this.elementRef.nativeElement, 'value', '');
1334
+ }
1335
+ }
1336
+ }
1330
1337
  ngOnDestroy() {
1331
1338
  this.subscriptions.unsubscribe();
1332
1339
  }
@@ -1334,17 +1341,23 @@ class AdbDatePickerDirective {
1334
1341
  validate(control) {
1335
1342
  const value = control.value;
1336
1343
  if (!value) {
1344
+ this.initialDate = null;
1345
+ this.isValid = true;
1337
1346
  return null;
1338
1347
  }
1339
1348
  if (value instanceof Date) {
1349
+ this.initialDate = value;
1350
+ this.isValid = true;
1340
1351
  return null;
1341
1352
  }
1342
1353
  if (typeof value === 'string' || value instanceof String) {
1343
1354
  const date = AdbDatePickerDirective.tryParse(value);
1344
1355
  if (!date) {
1356
+ this.isValid = false;
1345
1357
  return { date: true };
1346
1358
  }
1347
1359
  }
1360
+ this.isValid = true;
1348
1361
  return null;
1349
1362
  }
1350
1363
  registerOnValidatorChange(fn) {
@@ -1386,7 +1399,7 @@ class AdbDatePickerDirective {
1386
1399
  return '' + Math.floor(Math.random() * Date.now());
1387
1400
  }
1388
1401
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdbDatePickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: AdbDatePickerService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Directive }); }
1389
- /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings", pickOnly: "pickOnly" }, host: { listeners: { "click": "onClick()", "keyup": "onKeyup($event)", "keyup.esc": "onHide()", "keydown": "handleKeyboardEvent($event)", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
1402
+ /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: AdbDatePickerDirective, selector: "input[adbDatepicker]", inputs: { format: "format", toLeft: "toLeft", settings: "settings" }, host: { listeners: { "click": "onClick()", "keyup": "onKeyup($event)", "keydown.shift.tab": "onTabDown()", "keydown.tab": "onTabDown()", "down.esc": "onEscUp()", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "autocomplete": "this.autocomplete" } }, providers: [{
1390
1403
  provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => AdbDatePickerDirective)),
1391
1404
  multi: true
1392
1405
  },
@@ -1419,20 +1432,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1419
1432
  type: Input
1420
1433
  }], settings: [{
1421
1434
  type: Input
1422
- }], pickOnly: [{
1423
- type: Input
1424
1435
  }], onClick: [{
1425
1436
  type: HostListener,
1426
1437
  args: ['click']
1427
1438
  }], onKeyup: [{
1428
1439
  type: HostListener,
1429
1440
  args: ['keyup', ['$event']]
1430
- }], onHide: [{
1441
+ }], onTabDown: [{
1442
+ type: HostListener,
1443
+ args: ['keydown.shift.tab']
1444
+ }, {
1431
1445
  type: HostListener,
1432
- args: ['keyup.esc']
1433
- }], handleKeyboardEvent: [{
1446
+ args: ['keydown.tab']
1447
+ }], onEscUp: [{
1434
1448
  type: HostListener,
1435
- args: ['keydown', ['$event']]
1449
+ args: ['down.esc']
1436
1450
  }], onCheckOutSideClick: [{
1437
1451
  type: HostListener,
1438
1452
  args: ['document:click', ['$event.target']]