adb-shared 6.0.2 → 6.0.3
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/esm2022/adb-shared.mjs +4 -4
- package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-footer.component.mjs +48 -48
- package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-nav.component.mjs +112 -112
- package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-nav.module.mjs +58 -66
- package/esm2022/lib/components/adb-artportalen-nav/environment.service.mjs +16 -16
- package/esm2022/lib/components/adb-artportalen-nav/navigation.model.mjs +1 -1
- package/esm2022/lib/components/adb-buttons/adb-buttons.module.mjs +19 -19
- package/esm2022/lib/components/adb-buttons/help-button.component.mjs +35 -35
- package/esm2022/lib/components/adb-confirm-modal/adb-confirm-modal.mjs +29 -29
- package/esm2022/lib/components/adb-confirm-modal/adb-modal.module.mjs +23 -23
- package/esm2022/lib/components/adb-confirm-modal/adb-modal.service.mjs +46 -46
- package/esm2022/lib/components/adb-dropdown/adb-dropdown.directive.mjs +100 -100
- package/esm2022/lib/components/adb-dropdown/adb-dropdown.module.mjs +24 -24
- package/esm2022/lib/components/adb-dropdown/adb-dropdown.service.mjs +10 -10
- package/esm2022/lib/components/adb-dropdown/adb-dropdown2.directive.mjs +119 -119
- package/esm2022/lib/components/adb-header/adb-header.module.mjs +49 -57
- package/esm2022/lib/components/adb-header/adb-nav.component.mjs +115 -115
- package/esm2022/lib/components/adb-header/environment.service.mjs +16 -16
- package/esm2022/lib/components/adb-header/navigation.model.mjs +1 -1
- package/esm2022/lib/components/adb-rich-editor/adb-rich-editor.component.mjs +84 -65
- package/esm2022/lib/components/adb-rich-editor/adb-rich-editor.module.mjs +19 -19
- package/esm2022/lib/components/adb-toast/adb-toast.mjs +25 -25
- package/esm2022/lib/components/adb-toast/adb-toast.module.mjs +23 -23
- package/esm2022/lib/components/adb-toast/adb-toast.service.mjs +55 -55
- package/esm2022/lib/components/date-picker/adb-date-picker.component.mjs +177 -177
- package/esm2022/lib/components/date-picker/adb-date-picker.directive.mjs +220 -220
- package/esm2022/lib/components/date-picker/adb-date-picker.module.mjs +25 -25
- package/esm2022/lib/components/date-picker/adb-date-picker.service.mjs +10 -10
- package/esm2022/lib/components/pagers/infinite-scroll.component.mjs +47 -47
- package/esm2022/lib/components/pagers/pager-base.directive.mjs +57 -57
- package/esm2022/lib/components/pagers/pager-inline.mjs +49 -49
- package/esm2022/lib/components/pagers/pager.mjs +53 -53
- package/esm2022/lib/components/pagers/pagers.module.mjs +26 -26
- package/esm2022/lib/directives/click-outside.directive.mjs +28 -28
- package/esm2022/lib/directives/directives.module.mjs +21 -21
- package/esm2022/lib/directives/file-upload.directive.mjs +36 -36
- package/esm2022/lib/directives/focus.directive.mjs +34 -34
- package/esm2022/lib/directives/redlist-badge-class.directive.mjs +44 -44
- package/esm2022/lib/directives/risk-class.directive.mjs +37 -37
- package/esm2022/lib/pipes/date.pipe.mjs +22 -22
- package/esm2022/lib/pipes/emptyValue.pipe.mjs +22 -22
- package/esm2022/lib/pipes/highlight-html.pipe.mjs +46 -46
- package/esm2022/lib/pipes/highlight.pipe.mjs +46 -46
- package/esm2022/lib/pipes/number-spacing.pipe.mjs +21 -21
- package/esm2022/lib/pipes/pipes.module.mjs +22 -22
- package/esm2022/lib/pipes/rich.pipe.mjs +36 -36
- package/esm2022/public-api.mjs +41 -41
- package/fesm2022/adb-shared.mjs +1817 -1815
- package/fesm2022/adb-shared.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/components/adb-artportalen-nav/adb-artportalen-footer.component.d.ts +23 -23
- package/lib/components/adb-artportalen-nav/adb-artportalen-nav.component.d.ts +41 -41
- package/lib/components/adb-artportalen-nav/adb-artportalen-nav.module.d.ts +16 -17
- package/lib/components/adb-artportalen-nav/environment.service.d.ts +7 -7
- package/lib/components/adb-artportalen-nav/navigation.model.d.ts +18 -18
- package/lib/components/adb-buttons/adb-buttons.module.d.ts +9 -9
- package/lib/components/adb-buttons/help-button.component.d.ts +13 -13
- package/lib/components/adb-confirm-modal/adb-confirm-modal.d.ts +20 -20
- package/lib/components/adb-confirm-modal/adb-modal.module.d.ts +10 -10
- package/lib/components/adb-confirm-modal/adb-modal.service.d.ts +18 -18
- package/lib/components/adb-dropdown/adb-dropdown.directive.d.ts +21 -21
- package/lib/components/adb-dropdown/adb-dropdown.module.d.ts +11 -11
- package/lib/components/adb-dropdown/adb-dropdown.service.d.ts +7 -7
- package/lib/components/adb-dropdown/adb-dropdown2.directive.d.ts +23 -23
- package/lib/components/adb-header/adb-header.module.d.ts +15 -16
- package/lib/components/adb-header/adb-nav.component.d.ts +41 -41
- package/lib/components/adb-header/environment.service.d.ts +7 -7
- package/lib/components/adb-header/navigation.model.d.ts +29 -29
- package/lib/components/adb-rich-editor/adb-rich-editor.component.d.ts +24 -22
- package/lib/components/adb-rich-editor/adb-rich-editor.module.d.ts +9 -9
- package/lib/components/adb-toast/adb-toast.d.ts +11 -11
- package/lib/components/adb-toast/adb-toast.module.d.ts +10 -10
- package/lib/components/adb-toast/adb-toast.service.d.ts +36 -36
- package/lib/components/date-picker/adb-date-picker.component.d.ts +64 -64
- package/lib/components/date-picker/adb-date-picker.directive.d.ts +47 -47
- package/lib/components/date-picker/adb-date-picker.module.d.ts +12 -12
- package/lib/components/date-picker/adb-date-picker.service.d.ts +8 -8
- package/lib/components/pagers/infinite-scroll.component.d.ts +15 -15
- package/lib/components/pagers/pager-base.directive.d.ts +16 -16
- package/lib/components/pagers/pager-inline.d.ts +16 -16
- package/lib/components/pagers/pager.d.ts +22 -22
- package/lib/components/pagers/pagers.module.d.ts +11 -11
- package/lib/directives/click-outside.directive.d.ts +10 -10
- package/lib/directives/directives.module.d.ts +11 -11
- package/lib/directives/file-upload.directive.d.ts +12 -12
- package/lib/directives/focus.directive.d.ts +11 -11
- package/lib/directives/redlist-badge-class.directive.d.ts +7 -7
- package/lib/directives/risk-class.directive.d.ts +7 -7
- package/lib/pipes/date.pipe.d.ts +10 -10
- package/lib/pipes/emptyValue.pipe.d.ts +7 -7
- package/lib/pipes/highlight-html.pipe.d.ts +10 -10
- package/lib/pipes/highlight.pipe.d.ts +9 -9
- package/lib/pipes/number-spacing.pipe.d.ts +7 -7
- package/lib/pipes/pipes.module.d.ts +12 -12
- package/lib/pipes/rich.pipe.d.ts +11 -11
- package/package.json +5 -5
- package/public-api.d.ts +38 -38
|
@@ -1,177 +1,177 @@
|
|
|
1
|
-
import { Component, EventEmitter, HostBinding, Input, Output } from "@angular/core";
|
|
2
|
-
import { addDays, addMonths, addYears, eachDayOfInterval, eachWeekOfInterval, endOfDay, endOfMonth, getHours, getISOWeek, getMinutes, getMonth, isSameDay, isSameMonth, isSameYear, isValid, isWithinInterval, parseISO, startOfDay, startOfMonth, subMonths, subYears } from "date-fns";
|
|
3
|
-
import { Subscription } from "rxjs";
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@ngx-translate/core";
|
|
6
|
-
import * as i2 from "@angular/common";
|
|
7
|
-
import * as i3 from "../../pipes/date.pipe";
|
|
8
|
-
export class AdbDatePickerComponent {
|
|
9
|
-
static { this.MONTHS = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]; }
|
|
10
|
-
static { this.WEEK_DAYS = ['1', '2', '3', '4', '5', '6', '7']; }
|
|
11
|
-
static { this.YEAR_INTERVALL = 8; }
|
|
12
|
-
;
|
|
13
|
-
constructor(elementRef, translate) {
|
|
14
|
-
this.elementRef = elementRef;
|
|
15
|
-
this.translate = translate;
|
|
16
|
-
this.subscriptions = new Subscription();
|
|
17
|
-
this.currentdDate = new Date();
|
|
18
|
-
this.selectedDate = new Date();
|
|
19
|
-
this.weekDays = AdbDatePickerComponent.WEEK_DAYS;
|
|
20
|
-
this.noYearMode = false;
|
|
21
|
-
this.selectDate = new EventEmitter();
|
|
22
|
-
}
|
|
23
|
-
ngOnInit() {
|
|
24
|
-
if (this.settings) {
|
|
25
|
-
if (this.settings?.minDate || this.settings?.maxDate) {
|
|
26
|
-
const minDate = AdbDatePickerComponent.parseDate(this.settings.minDate);
|
|
27
|
-
const maxDate = AdbDatePickerComponent.parseDate(this.settings.maxDate);
|
|
28
|
-
this.range = {
|
|
29
|
-
start: minDate ? startOfDay(minDate) : subYears(new Date(), 1000),
|
|
30
|
-
end: maxDate ? endOfDay(maxDate) : addYears(new Date(), 1000)
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
if (this.settings.noYear) {
|
|
34
|
-
this.noYearMode = this.settings.noYear;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
this.selectedDate = this.currentdDate = this.initialDate ?? new Date();
|
|
38
|
-
this.currentMonth = getMonth(this.selectedDate);
|
|
39
|
-
this.createCalendar();
|
|
40
|
-
}
|
|
41
|
-
onShowYear() {
|
|
42
|
-
this.months = null;
|
|
43
|
-
this.loadYearsInterval();
|
|
44
|
-
}
|
|
45
|
-
onShowMonth() {
|
|
46
|
-
this.years = null;
|
|
47
|
-
this.loadMonths();
|
|
48
|
-
}
|
|
49
|
-
onSelectYear(inYear) {
|
|
50
|
-
this.selectedDate.setFullYear(inYear.getFullYear());
|
|
51
|
-
this.loadMonths();
|
|
52
|
-
this.years = null;
|
|
53
|
-
}
|
|
54
|
-
onSelectMonth(inMonth) {
|
|
55
|
-
this.selectedDate.setMonth(inMonth);
|
|
56
|
-
this.currentMonth = getMonth(this.selectedDate);
|
|
57
|
-
this.createCalendar();
|
|
58
|
-
this.years = null;
|
|
59
|
-
this.months = null;
|
|
60
|
-
}
|
|
61
|
-
onPrev() {
|
|
62
|
-
if (this.years) {
|
|
63
|
-
this.selectedDate = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);
|
|
64
|
-
this.loadYearsInterval();
|
|
65
|
-
}
|
|
66
|
-
else if (this.months) {
|
|
67
|
-
this.selectedDate = subYears(this.selectedDate, 1);
|
|
68
|
-
this.loadMonths();
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
this.selectedDate = subMonths(this.selectedDate, 1);
|
|
72
|
-
this.createCalendar();
|
|
73
|
-
}
|
|
74
|
-
this.currentMonth = getMonth(this.selectedDate);
|
|
75
|
-
}
|
|
76
|
-
onNext() {
|
|
77
|
-
if (this.years) {
|
|
78
|
-
this.selectedDate = addYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);
|
|
79
|
-
this.loadYearsInterval();
|
|
80
|
-
}
|
|
81
|
-
else if (this.months) {
|
|
82
|
-
this.selectedDate = addYears(this.selectedDate, 1);
|
|
83
|
-
this.loadMonths();
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
this.selectedDate = addMonths(this.selectedDate, 1);
|
|
87
|
-
this.createCalendar();
|
|
88
|
-
}
|
|
89
|
-
this.currentMonth = getMonth(this.selectedDate);
|
|
90
|
-
}
|
|
91
|
-
ngOnDestroy() {
|
|
92
|
-
this.subscriptions.unsubscribe();
|
|
93
|
-
}
|
|
94
|
-
loadMonths() {
|
|
95
|
-
this.months = AdbDatePickerComponent.MONTHS.map(x => {
|
|
96
|
-
return {
|
|
97
|
-
value: x,
|
|
98
|
-
isThisMonth: getMonth(this.selectedDate) === x && isSameYear(this.currentdDate, this.selectedDate)
|
|
99
|
-
};
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
loadYearsInterval() {
|
|
103
|
-
let year = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);
|
|
104
|
-
const years = [];
|
|
105
|
-
for (let i = 0; i < 16; i++) {
|
|
106
|
-
years.push({
|
|
107
|
-
value: year,
|
|
108
|
-
title: year.getFullYear(),
|
|
109
|
-
isThisYear: isSameYear(year, this.currentdDate)
|
|
110
|
-
});
|
|
111
|
-
year = addYears(year, 1);
|
|
112
|
-
}
|
|
113
|
-
this.years = years;
|
|
114
|
-
}
|
|
115
|
-
onSelectDate(day) {
|
|
116
|
-
this.selectDate.emit(day.value);
|
|
117
|
-
}
|
|
118
|
-
createCalendar() {
|
|
119
|
-
const weeks = [];
|
|
120
|
-
const monthInterval = { start: startOfMonth(this.selectedDate), end: endOfMonth(this.selectedDate) };
|
|
121
|
-
var fnsWweeks = eachWeekOfInterval(monthInterval, { weekStartsOn: this.translate.currentLang === 'sv' || this.translate.currentLang === 'sv-SE' ? 1 : 0 });
|
|
122
|
-
for (const fnsWeek of fnsWweeks) {
|
|
123
|
-
const week = { weekNumber: 0, days: [] };
|
|
124
|
-
week.weekNumber = getISOWeek(new Date(fnsWeek));
|
|
125
|
-
const weekInterval = { start: new Date(fnsWeek), end: addDays(new Date(fnsWeek), 6) };
|
|
126
|
-
week.days = eachDayOfInterval(weekInterval).map(day => {
|
|
127
|
-
day.setHours(getHours(new Date()));
|
|
128
|
-
day.setMinutes(getMinutes(new Date()));
|
|
129
|
-
return {
|
|
130
|
-
value: day,
|
|
131
|
-
isSelected: isSameYear(day, this.initialDate) && isSameDay(day, this.initialDate) && isSameMonth(day, this.initialDate),
|
|
132
|
-
isInRange: this.range ? isWithinInterval(day, this.range) : true,
|
|
133
|
-
isToday: isSameDay(day, new Date()),
|
|
134
|
-
inMonth: monthInterval.start.getMonth() === day.getMonth()
|
|
135
|
-
};
|
|
136
|
-
});
|
|
137
|
-
weeks.push(week);
|
|
138
|
-
}
|
|
139
|
-
this.weeks = weeks;
|
|
140
|
-
}
|
|
141
|
-
static parseDate(value) {
|
|
142
|
-
if (typeof value === 'string') {
|
|
143
|
-
if (isValid(parseISO(value))) {
|
|
144
|
-
return parseISO(value);
|
|
145
|
-
}
|
|
146
|
-
else {
|
|
147
|
-
return null;
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
else if (value instanceof Date) {
|
|
151
|
-
return value;
|
|
152
|
-
}
|
|
153
|
-
else {
|
|
154
|
-
return null;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
158
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
159
|
-
}
|
|
160
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
161
|
-
type: Component,
|
|
162
|
-
args: [{ selector: 'adb-date-picker', template: "<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&¤tMonth===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&¤tMonth===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" }]
|
|
163
|
-
}], ctorParameters:
|
|
164
|
-
type: Input
|
|
165
|
-
}], settings: [{
|
|
166
|
-
type: Input
|
|
167
|
-
}], toLeft: [{
|
|
168
|
-
type: Input
|
|
169
|
-
}], id: [{
|
|
170
|
-
type: HostBinding,
|
|
171
|
-
args: ['id']
|
|
172
|
-
}, {
|
|
173
|
-
type: Input
|
|
174
|
-
}], selectDate: [{
|
|
175
|
-
type: Output
|
|
176
|
-
}] } });
|
|
177
|
-
//# 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\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"]}
|
|
1
|
+
import { Component, EventEmitter, HostBinding, Input, Output } from "@angular/core";
|
|
2
|
+
import { addDays, addMonths, addYears, eachDayOfInterval, eachWeekOfInterval, endOfDay, endOfMonth, getHours, getISOWeek, getMinutes, getMonth, isSameDay, isSameMonth, isSameYear, isValid, isWithinInterval, parseISO, startOfDay, startOfMonth, subMonths, subYears } from "date-fns";
|
|
3
|
+
import { Subscription } from "rxjs";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@ngx-translate/core";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "../../pipes/date.pipe";
|
|
8
|
+
export class AdbDatePickerComponent {
|
|
9
|
+
static { this.MONTHS = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11]; }
|
|
10
|
+
static { this.WEEK_DAYS = ['1', '2', '3', '4', '5', '6', '7']; }
|
|
11
|
+
static { this.YEAR_INTERVALL = 8; }
|
|
12
|
+
;
|
|
13
|
+
constructor(elementRef, translate) {
|
|
14
|
+
this.elementRef = elementRef;
|
|
15
|
+
this.translate = translate;
|
|
16
|
+
this.subscriptions = new Subscription();
|
|
17
|
+
this.currentdDate = new Date();
|
|
18
|
+
this.selectedDate = new Date();
|
|
19
|
+
this.weekDays = AdbDatePickerComponent.WEEK_DAYS;
|
|
20
|
+
this.noYearMode = false;
|
|
21
|
+
this.selectDate = new EventEmitter();
|
|
22
|
+
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
if (this.settings) {
|
|
25
|
+
if (this.settings?.minDate || this.settings?.maxDate) {
|
|
26
|
+
const minDate = AdbDatePickerComponent.parseDate(this.settings.minDate);
|
|
27
|
+
const maxDate = AdbDatePickerComponent.parseDate(this.settings.maxDate);
|
|
28
|
+
this.range = {
|
|
29
|
+
start: minDate ? startOfDay(minDate) : subYears(new Date(), 1000),
|
|
30
|
+
end: maxDate ? endOfDay(maxDate) : addYears(new Date(), 1000)
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
if (this.settings.noYear) {
|
|
34
|
+
this.noYearMode = this.settings.noYear;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
this.selectedDate = this.currentdDate = this.initialDate ?? new Date();
|
|
38
|
+
this.currentMonth = getMonth(this.selectedDate);
|
|
39
|
+
this.createCalendar();
|
|
40
|
+
}
|
|
41
|
+
onShowYear() {
|
|
42
|
+
this.months = null;
|
|
43
|
+
this.loadYearsInterval();
|
|
44
|
+
}
|
|
45
|
+
onShowMonth() {
|
|
46
|
+
this.years = null;
|
|
47
|
+
this.loadMonths();
|
|
48
|
+
}
|
|
49
|
+
onSelectYear(inYear) {
|
|
50
|
+
this.selectedDate.setFullYear(inYear.getFullYear());
|
|
51
|
+
this.loadMonths();
|
|
52
|
+
this.years = null;
|
|
53
|
+
}
|
|
54
|
+
onSelectMonth(inMonth) {
|
|
55
|
+
this.selectedDate.setMonth(inMonth);
|
|
56
|
+
this.currentMonth = getMonth(this.selectedDate);
|
|
57
|
+
this.createCalendar();
|
|
58
|
+
this.years = null;
|
|
59
|
+
this.months = null;
|
|
60
|
+
}
|
|
61
|
+
onPrev() {
|
|
62
|
+
if (this.years) {
|
|
63
|
+
this.selectedDate = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);
|
|
64
|
+
this.loadYearsInterval();
|
|
65
|
+
}
|
|
66
|
+
else if (this.months) {
|
|
67
|
+
this.selectedDate = subYears(this.selectedDate, 1);
|
|
68
|
+
this.loadMonths();
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
this.selectedDate = subMonths(this.selectedDate, 1);
|
|
72
|
+
this.createCalendar();
|
|
73
|
+
}
|
|
74
|
+
this.currentMonth = getMonth(this.selectedDate);
|
|
75
|
+
}
|
|
76
|
+
onNext() {
|
|
77
|
+
if (this.years) {
|
|
78
|
+
this.selectedDate = addYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);
|
|
79
|
+
this.loadYearsInterval();
|
|
80
|
+
}
|
|
81
|
+
else if (this.months) {
|
|
82
|
+
this.selectedDate = addYears(this.selectedDate, 1);
|
|
83
|
+
this.loadMonths();
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
this.selectedDate = addMonths(this.selectedDate, 1);
|
|
87
|
+
this.createCalendar();
|
|
88
|
+
}
|
|
89
|
+
this.currentMonth = getMonth(this.selectedDate);
|
|
90
|
+
}
|
|
91
|
+
ngOnDestroy() {
|
|
92
|
+
this.subscriptions.unsubscribe();
|
|
93
|
+
}
|
|
94
|
+
loadMonths() {
|
|
95
|
+
this.months = AdbDatePickerComponent.MONTHS.map(x => {
|
|
96
|
+
return {
|
|
97
|
+
value: x,
|
|
98
|
+
isThisMonth: getMonth(this.selectedDate) === x && isSameYear(this.currentdDate, this.selectedDate)
|
|
99
|
+
};
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
loadYearsInterval() {
|
|
103
|
+
let year = subYears(this.selectedDate, AdbDatePickerComponent.YEAR_INTERVALL);
|
|
104
|
+
const years = [];
|
|
105
|
+
for (let i = 0; i < 16; i++) {
|
|
106
|
+
years.push({
|
|
107
|
+
value: year,
|
|
108
|
+
title: year.getFullYear(),
|
|
109
|
+
isThisYear: isSameYear(year, this.currentdDate)
|
|
110
|
+
});
|
|
111
|
+
year = addYears(year, 1);
|
|
112
|
+
}
|
|
113
|
+
this.years = years;
|
|
114
|
+
}
|
|
115
|
+
onSelectDate(day) {
|
|
116
|
+
this.selectDate.emit(day.value);
|
|
117
|
+
}
|
|
118
|
+
createCalendar() {
|
|
119
|
+
const weeks = [];
|
|
120
|
+
const monthInterval = { start: startOfMonth(this.selectedDate), end: endOfMonth(this.selectedDate) };
|
|
121
|
+
var fnsWweeks = eachWeekOfInterval(monthInterval, { weekStartsOn: this.translate.currentLang === 'sv' || this.translate.currentLang === 'sv-SE' ? 1 : 0 });
|
|
122
|
+
for (const fnsWeek of fnsWweeks) {
|
|
123
|
+
const week = { weekNumber: 0, days: [] };
|
|
124
|
+
week.weekNumber = getISOWeek(new Date(fnsWeek));
|
|
125
|
+
const weekInterval = { start: new Date(fnsWeek), end: addDays(new Date(fnsWeek), 6) };
|
|
126
|
+
week.days = eachDayOfInterval(weekInterval).map(day => {
|
|
127
|
+
day.setHours(getHours(new Date()));
|
|
128
|
+
day.setMinutes(getMinutes(new Date()));
|
|
129
|
+
return {
|
|
130
|
+
value: day,
|
|
131
|
+
isSelected: isSameYear(day, this.initialDate) && isSameDay(day, this.initialDate) && isSameMonth(day, this.initialDate),
|
|
132
|
+
isInRange: this.range ? isWithinInterval(day, this.range) : true,
|
|
133
|
+
isToday: isSameDay(day, new Date()),
|
|
134
|
+
inMonth: monthInterval.start.getMonth() === day.getMonth()
|
|
135
|
+
};
|
|
136
|
+
});
|
|
137
|
+
weeks.push(week);
|
|
138
|
+
}
|
|
139
|
+
this.weeks = weeks;
|
|
140
|
+
}
|
|
141
|
+
static parseDate(value) {
|
|
142
|
+
if (typeof value === 'string') {
|
|
143
|
+
if (isValid(parseISO(value))) {
|
|
144
|
+
return parseISO(value);
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
return null;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
else if (value instanceof Date) {
|
|
151
|
+
return value;
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
return null;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDatePickerComponent, deps: [{ token: i0.ElementRef }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
158
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: AdbDatePickerComponent, selector: "adb-date-picker", inputs: { initialDate: "initialDate", settings: "settings", toLeft: "toLeft", id: "id" }, outputs: { selectDate: "selectDate" }, host: { properties: { "id": "this.id" } }, ngImport: i0, template: "<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&¤tMonth===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&¤tMonth===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", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.DatePipe, name: "date" }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: i3.LocaleDatePipe, name: "adbLocaleDate" }] }); }
|
|
159
|
+
}
|
|
160
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDatePickerComponent, decorators: [{
|
|
161
|
+
type: Component,
|
|
162
|
+
args: [{ selector: 'adb-date-picker', template: "<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&¤tMonth===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&¤tMonth===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" }]
|
|
163
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.TranslateService }], propDecorators: { initialDate: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], settings: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], toLeft: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], id: [{
|
|
170
|
+
type: HostBinding,
|
|
171
|
+
args: ['id']
|
|
172
|
+
}, {
|
|
173
|
+
type: Input
|
|
174
|
+
}], selectDate: [{
|
|
175
|
+
type: Output
|
|
176
|
+
}] } });
|
|
177
|
+
//# 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\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"]}
|