ecabs-components 1.0.64 → 1.0.66
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/lib/base/element-base.mjs +6 -2
- package/esm2022/lib/base/element-wrapper/element-wrapper.component.mjs +3 -3
- package/esm2022/lib/base/models/ecabs-date-picker-translations.models.mjs +1 -1
- package/esm2022/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.mjs +2 -2
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +46 -5
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.module.mjs +1 -1
- package/esm2022/lib/ecabs-increment/ecabs-increment.component.mjs +2 -2
- package/esm2022/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.component.mjs +179 -0
- package/esm2022/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.module.mjs +59 -0
- package/esm2022/lib/ecabs-picker-header/ecabs-picker-header.component.mjs +2 -2
- package/esm2022/lib/ecabs-place-autocomplete/ecabs-place-autocomplete.component.mjs +3 -3
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ecabs-components.mjs +272 -21
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/base/element-base.d.ts +2 -1
- package/lib/base/models/ecabs-date-picker-translations.models.d.ts +4 -0
- package/lib/ecabs-date-picker/ecabs-date-picker.component.d.ts +8 -2
- package/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.component.d.ts +49 -0
- package/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.module.d.ts +17 -0
- package/package.json +2 -1
- package/public-api.d.ts +2 -0
- package/src/assets/styles/scss/modules/_map.scss +28 -0
- package/src/assets/styles/tailwind/index.scss +1 -1
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
|
|
3
|
+
import { takeUntil } from 'rxjs';
|
|
4
|
+
import { format, isValid } from 'date-fns';
|
|
5
|
+
import Holidays from 'date-holidays';
|
|
6
|
+
import ElementBaseComponent from '../base/element-base';
|
|
7
|
+
import { UnsubscribeService } from '../base/services/unsubscribe.service';
|
|
8
|
+
import { EcabsDatePickerHeaderComponent } from '../../public-api';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "../base/services/ecabs-date-picker-translations.service";
|
|
11
|
+
import * as i2 from "../base/services/unsubscribe.service";
|
|
12
|
+
import * as i3 from "@angular/common";
|
|
13
|
+
import * as i4 from "../base/element-wrapper/element-wrapper.component";
|
|
14
|
+
import * as i5 from "@angular/material/icon";
|
|
15
|
+
import * as i6 from "@angular/material/datepicker";
|
|
16
|
+
import * as i7 from "@angular/material/legacy-chips";
|
|
17
|
+
import * as i8 from "@angular/material/legacy-form-field";
|
|
18
|
+
import * as i9 from "@angular/forms";
|
|
19
|
+
import * as i10 from "../ecabs-date-picker-actions/ecabs-date-picker-actions.component";
|
|
20
|
+
export class EcabsMultipleDatesPickerComponent extends ElementBaseComponent {
|
|
21
|
+
injector;
|
|
22
|
+
ecabsDatePickerHeaderService;
|
|
23
|
+
unsubscribeService;
|
|
24
|
+
_picker;
|
|
25
|
+
minDate;
|
|
26
|
+
maxDate;
|
|
27
|
+
touchUi = false;
|
|
28
|
+
cancelLabel;
|
|
29
|
+
applyLabel;
|
|
30
|
+
excludeHolidays;
|
|
31
|
+
excludeWeekends;
|
|
32
|
+
holidayOptions;
|
|
33
|
+
modelChange = new EventEmitter();
|
|
34
|
+
val;
|
|
35
|
+
header = EcabsDatePickerHeaderComponent;
|
|
36
|
+
translationConfig;
|
|
37
|
+
CLOSE_ON_SELECTED = false;
|
|
38
|
+
init = new Date();
|
|
39
|
+
resetModel = new Date();
|
|
40
|
+
model = [];
|
|
41
|
+
get value() {
|
|
42
|
+
return this.val;
|
|
43
|
+
}
|
|
44
|
+
set value(val) {
|
|
45
|
+
if (val && this.val !== val) {
|
|
46
|
+
this.val = val;
|
|
47
|
+
this.onChange(val);
|
|
48
|
+
this.onTouch(val);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
constructor(injector, ecabsDatePickerHeaderService, unsubscribeService) {
|
|
52
|
+
super();
|
|
53
|
+
this.injector = injector;
|
|
54
|
+
this.ecabsDatePickerHeaderService = ecabsDatePickerHeaderService;
|
|
55
|
+
this.unsubscribeService = unsubscribeService;
|
|
56
|
+
}
|
|
57
|
+
ngOnInit() {
|
|
58
|
+
this.ecabsDatePickerHeaderService.getConfig()
|
|
59
|
+
.pipe(takeUntil(this.unsubscribeService.subscription()))
|
|
60
|
+
.subscribe(config => this.translationConfig = config);
|
|
61
|
+
}
|
|
62
|
+
ngAfterViewInit() {
|
|
63
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
64
|
+
if (ngControl) {
|
|
65
|
+
this.control = ngControl.control;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
dateClass = (date) => {
|
|
69
|
+
if (this._findDate(date) !== -1) {
|
|
70
|
+
return ['selected'];
|
|
71
|
+
}
|
|
72
|
+
return [];
|
|
73
|
+
};
|
|
74
|
+
dateChanged(event) {
|
|
75
|
+
if (event.value) {
|
|
76
|
+
const date = event.value;
|
|
77
|
+
const index = this._findDate(date);
|
|
78
|
+
if (index === -1) {
|
|
79
|
+
this.model.push(date);
|
|
80
|
+
this.modelChange.emit(this.model);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
this.model.splice(index, 1);
|
|
84
|
+
this.modelChange.emit(this.model);
|
|
85
|
+
}
|
|
86
|
+
this.resetModel = new Date();
|
|
87
|
+
if (!this.CLOSE_ON_SELECTED) {
|
|
88
|
+
const closeFn = this._picker.close;
|
|
89
|
+
this._picker.close = () => { };
|
|
90
|
+
this._picker['_popupComponentRef']?.instance._calendar.monthView._createWeekCells();
|
|
91
|
+
setTimeout(() => {
|
|
92
|
+
this._picker.close = closeFn;
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
remove(date) {
|
|
98
|
+
const index = this._findDate(date);
|
|
99
|
+
this.model.splice(index, 1);
|
|
100
|
+
this.modelChange.emit(this.model);
|
|
101
|
+
}
|
|
102
|
+
onChange = () => { };
|
|
103
|
+
onTouch = () => { };
|
|
104
|
+
writeValue(value) {
|
|
105
|
+
this.value = value;
|
|
106
|
+
}
|
|
107
|
+
registerOnChange(fn) {
|
|
108
|
+
this.onChange = fn;
|
|
109
|
+
}
|
|
110
|
+
registerOnTouched(fn) {
|
|
111
|
+
this.onTouch = fn;
|
|
112
|
+
}
|
|
113
|
+
isDateNotHoliday(date) {
|
|
114
|
+
const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};
|
|
115
|
+
if (countryCode && timeZoneOffset) {
|
|
116
|
+
const holiday = new Holidays(countryCode.toUpperCase());
|
|
117
|
+
return !holiday.isHoliday(`${format(date, 'yyyy-MM-dd')}T00:00:00${timeZoneOffset}`);
|
|
118
|
+
}
|
|
119
|
+
return true;
|
|
120
|
+
}
|
|
121
|
+
filterDateRange = (date) => {
|
|
122
|
+
let result = true;
|
|
123
|
+
if (isValid(new Date(date))) {
|
|
124
|
+
const day = date?.getDay();
|
|
125
|
+
if (this.excludeWeekends) {
|
|
126
|
+
result = result && day !== 0 && day !== 6;
|
|
127
|
+
}
|
|
128
|
+
if (this.excludeHolidays) {
|
|
129
|
+
result = result && this.isDateNotHoliday(date);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
return result;
|
|
133
|
+
};
|
|
134
|
+
_findDate(date) {
|
|
135
|
+
return this.model.map((m) => +m).indexOf(+date);
|
|
136
|
+
}
|
|
137
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsMultipleDatesPickerComponent, deps: [{ token: i0.Injector }, { token: i1.EcabsDatePickerHeaderService }, { token: i2.UnsubscribeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
138
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsMultipleDatesPickerComponent, selector: "ecabs-multiple-dates-picker", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", cancelLabel: "cancelLabel", applyLabel: "applyLabel", excludeHolidays: "excludeHolidays", excludeWeekends: "excludeWeekends", holidayOptions: "holidayOptions" }, outputs: { modelChange: "modelChange" }, providers: [
|
|
139
|
+
{
|
|
140
|
+
provide: NG_VALUE_ACCESSOR,
|
|
141
|
+
useExisting: EcabsMultipleDatesPickerComponent,
|
|
142
|
+
multi: true,
|
|
143
|
+
},
|
|
144
|
+
UnsubscribeService
|
|
145
|
+
], viewQueries: [{ propertyName: "_picker", first: true, predicate: ["picker"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper w-full\">\r\n <mat-chip-list \r\n #chipList aria-label=\"Choose a date\" \r\n (click)=\"picker.open()\"\r\n class=\"w-full\"\r\n >\r\n <mat-chip \r\n class=\"form-field__input\" \r\n *ngFor=\"let value of model\" \r\n [selectable]=\"false\" [removable]=\"true\"\r\n (removed)=\"remove(value)\"\r\n >\r\n {{ value | date: 'dd/MM/yyyy' }}\r\n <mat-icon matChipRemove *ngIf=\"true\">cancel</mat-icon>\r\n </mat-chip>\r\n <input \r\n class=\"form-field__input fake-input\" \r\n [value]=\"resetModel\"\r\n [(ngModel)]=\"value\" \r\n [matDatepicker]=\"picker\" \r\n placeholder=\"Select dates\" \r\n (dateChange)=\"dateChanged($event)\"\r\n [matChipInputFor]=\"chipList\" \r\n [min]=\"minDate\" \r\n [max]=\"maxDate\" \r\n [matDatepickerFilter]=\"filterDateRange\"\r\n />\r\n </mat-chip-list>\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n </mat-datepicker-toggle>\r\n <mat-datepicker\r\n #picker \r\n [calendarHeaderComponent]=\"header\" \r\n [touchUi]=\"touchUi\" \r\n [dateClass]=\"dateClass\"\r\n >\r\n <mat-datepicker-actions>\r\n <ecabs-date-picker-actions \r\n [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n >\r\n </ecabs-date-picker-actions>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n </div>\r\n</app-element-wrapper>", styles: [":root{--color-black: #07080d;--color-white: #ffffff;--color-white-opacity-05: rgba(0, 0, 0, .05);--color-gray-100: #f5f6f9;--color-gray-200: #f8f9f9;--color-gray-300: #d9d9d9;--color-gray-400: #a6a6a6;--color-gray-500: #6b6d73;--color-brand-dark: #193273;--color-brand-dark-rgb: 25, 50, 115;--color-brand-light: #325FDA;--color-brand-light2: #e7efff;--color-brand-light-rgb: 50, 95, 218;--color-brand-300: #e7efff;--color-brand-300-rgb: 231, 239, 255;--color-error: #df3838;--color-error-opacity: #fbe4e4;--color-error-rgb: 223, 56, 56;--color-notification: #f4d04f;--color-notification-rgb: 244, 208, 79;--color-warn: #f2994a;--color-warn-rgb: 242, 153, 74;--color-info: #325fda;--color-info-rgb: 50, 95, 218;--color-warning: #f2994a;--color-warning-opacity: #fdf0e4;--color-success: #25bd3d;--color-success--opacity: #e8f8e5;--color-success-rgb: 37, 189, 61;--color-allocation-started: #E8F8E5;--color-allocation-scheduled: #FDF0E4;--color-allocation-ended: #FBE4E4;--color-allocation-sick: #E7EFFF;--color-allocation-no-show: #EAE5FF;--color-allocation-unavailable: #F2F2F2;--cropper-outline-color: rgba(0, 0, 0, .5)}:host ::ng-deep .mat-chip-list-wrapper{padding:5px}:host ::ng-deep .mat-chip-list-wrapper .mat-standard-chip{margin:0 5px 0 0}:host ::ng-deep .fake-input{visibility:hidden;width:0;padding:0;margin:0}:host ::ng-deep .form-field__input--wrapper{border:1px solid var(--color-gray-500);padding:5px;align-items:center;background:#fff;border-radius:.25rem}::ng-deep .mat-calendar-body-cell.selected>.mat-calendar-body-cell-content,::ng-deep .mat-calendar-body-cell.selected:hover>.mat-calendar-body-cell-content,::ng-deep .mat-calendar-body-cell.selected>.mat-calendar-body-cell-content:hover{background-color:#673ab7!important;color:#fff!important}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i6.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "component", type: i6.MatDatepickerActions, selector: "mat-datepicker-actions, mat-date-range-picker-actions" }, { kind: "component", type: i7.MatLegacyChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i7.MatLegacyChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i7.MatLegacyChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i7.MatLegacyChipRemove, selector: "[matChipRemove]" }, { kind: "directive", type: i8.MatLegacySuffix, selector: "[matSuffix]" }, { kind: "directive", type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i10.EcabsDatePickerActionsComponent, selector: "ecabs-date-picker-actions", inputs: ["cancelLabel", "applyLabel"], outputs: ["apply"] }, { kind: "pipe", type: i3.DatePipe, name: "date" }] });
|
|
146
|
+
}
|
|
147
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsMultipleDatesPickerComponent, decorators: [{
|
|
148
|
+
type: Component,
|
|
149
|
+
args: [{ selector: 'ecabs-multiple-dates-picker', providers: [
|
|
150
|
+
{
|
|
151
|
+
provide: NG_VALUE_ACCESSOR,
|
|
152
|
+
useExisting: EcabsMultipleDatesPickerComponent,
|
|
153
|
+
multi: true,
|
|
154
|
+
},
|
|
155
|
+
UnsubscribeService
|
|
156
|
+
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper w-full\">\r\n <mat-chip-list \r\n #chipList aria-label=\"Choose a date\" \r\n (click)=\"picker.open()\"\r\n class=\"w-full\"\r\n >\r\n <mat-chip \r\n class=\"form-field__input\" \r\n *ngFor=\"let value of model\" \r\n [selectable]=\"false\" [removable]=\"true\"\r\n (removed)=\"remove(value)\"\r\n >\r\n {{ value | date: 'dd/MM/yyyy' }}\r\n <mat-icon matChipRemove *ngIf=\"true\">cancel</mat-icon>\r\n </mat-chip>\r\n <input \r\n class=\"form-field__input fake-input\" \r\n [value]=\"resetModel\"\r\n [(ngModel)]=\"value\" \r\n [matDatepicker]=\"picker\" \r\n placeholder=\"Select dates\" \r\n (dateChange)=\"dateChanged($event)\"\r\n [matChipInputFor]=\"chipList\" \r\n [min]=\"minDate\" \r\n [max]=\"maxDate\" \r\n [matDatepickerFilter]=\"filterDateRange\"\r\n />\r\n </mat-chip-list>\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n </mat-datepicker-toggle>\r\n <mat-datepicker\r\n #picker \r\n [calendarHeaderComponent]=\"header\" \r\n [touchUi]=\"touchUi\" \r\n [dateClass]=\"dateClass\"\r\n >\r\n <mat-datepicker-actions>\r\n <ecabs-date-picker-actions \r\n [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n >\r\n </ecabs-date-picker-actions>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n </div>\r\n</app-element-wrapper>", styles: [":root{--color-black: #07080d;--color-white: #ffffff;--color-white-opacity-05: rgba(0, 0, 0, .05);--color-gray-100: #f5f6f9;--color-gray-200: #f8f9f9;--color-gray-300: #d9d9d9;--color-gray-400: #a6a6a6;--color-gray-500: #6b6d73;--color-brand-dark: #193273;--color-brand-dark-rgb: 25, 50, 115;--color-brand-light: #325FDA;--color-brand-light2: #e7efff;--color-brand-light-rgb: 50, 95, 218;--color-brand-300: #e7efff;--color-brand-300-rgb: 231, 239, 255;--color-error: #df3838;--color-error-opacity: #fbe4e4;--color-error-rgb: 223, 56, 56;--color-notification: #f4d04f;--color-notification-rgb: 244, 208, 79;--color-warn: #f2994a;--color-warn-rgb: 242, 153, 74;--color-info: #325fda;--color-info-rgb: 50, 95, 218;--color-warning: #f2994a;--color-warning-opacity: #fdf0e4;--color-success: #25bd3d;--color-success--opacity: #e8f8e5;--color-success-rgb: 37, 189, 61;--color-allocation-started: #E8F8E5;--color-allocation-scheduled: #FDF0E4;--color-allocation-ended: #FBE4E4;--color-allocation-sick: #E7EFFF;--color-allocation-no-show: #EAE5FF;--color-allocation-unavailable: #F2F2F2;--cropper-outline-color: rgba(0, 0, 0, .5)}:host ::ng-deep .mat-chip-list-wrapper{padding:5px}:host ::ng-deep .mat-chip-list-wrapper .mat-standard-chip{margin:0 5px 0 0}:host ::ng-deep .fake-input{visibility:hidden;width:0;padding:0;margin:0}:host ::ng-deep .form-field__input--wrapper{border:1px solid var(--color-gray-500);padding:5px;align-items:center;background:#fff;border-radius:.25rem}::ng-deep .mat-calendar-body-cell.selected>.mat-calendar-body-cell-content,::ng-deep .mat-calendar-body-cell.selected:hover>.mat-calendar-body-cell-content,::ng-deep .mat-calendar-body-cell.selected>.mat-calendar-body-cell-content:hover{background-color:#673ab7!important;color:#fff!important}\n"] }]
|
|
157
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.EcabsDatePickerHeaderService }, { type: i2.UnsubscribeService }]; }, propDecorators: { _picker: [{
|
|
158
|
+
type: ViewChild,
|
|
159
|
+
args: ['picker', { static: true }]
|
|
160
|
+
}], minDate: [{
|
|
161
|
+
type: Input
|
|
162
|
+
}], maxDate: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], touchUi: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], cancelLabel: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], applyLabel: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], excludeHolidays: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], excludeWeekends: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], holidayOptions: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], modelChange: [{
|
|
177
|
+
type: Output
|
|
178
|
+
}] } });
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-multiple-dates-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Injector, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\n\r\nimport { takeUntil } from 'rxjs';\r\n\r\nimport { format, isValid } from 'date-fns';\r\nimport Holidays from 'date-holidays';\r\n\r\nimport { MatDatepicker, MatDatepickerInputEvent } from '@angular/material/datepicker';\r\n\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport { EcabsDatePickerHolidayOptions, EcabsDatePickerTranslations } from '../base/models/ecabs-date-picker-translations.models';\r\n\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\n\r\nimport { EcabsDatePickerHeaderComponent } from '../../public-api';\r\n\r\n@Component({\r\n  selector: 'ecabs-multiple-dates-picker',\r\n  templateUrl: './ecabs-multiple-dates-picker.component.html',\r\n  styleUrls: ['./ecabs-multiple-dates-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsMultipleDatesPickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService\r\n  ],\r\n})\r\nexport class EcabsMultipleDatesPickerComponent extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit {\r\n  @ViewChild('picker', { static: true }) _picker: MatDatepicker<Date>;\r\n\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() cancelLabel: string;\r\n  @Input() applyLabel: string;\r\n  @Input() excludeHolidays: boolean;\r\n  @Input() excludeWeekends: boolean;\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n\r\n  @Output() modelChange = new EventEmitter<Date[]>();\r\n\r\n  val: string | number;\r\n  header = EcabsDatePickerHeaderComponent;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n\r\n  public CLOSE_ON_SELECTED = false;\r\n  public init = new Date();\r\n  public resetModel = new Date();\r\n  public model = [];\r\n\r\n  get value(): string | number {\r\n    return this.val;\r\n  }\r\n\r\n  set value(val: string | number) {\r\n    if (val && this.val !== val) {\r\n      this.val = val;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly ecabsDatePickerHeaderService: EcabsDatePickerHeaderService,\r\n    private readonly unsubscribeService: UnsubscribeService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.ecabsDatePickerHeaderService.getConfig()\r\n      .pipe(takeUntil(this.unsubscribeService.subscription()),)\r\n      .subscribe(config => this.translationConfig = config);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(NgControl, null);\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n  }\r\n\r\n  public dateClass = (date: Date): string[] => {\r\n    if (this._findDate(date) !== -1) {\r\n      return ['selected'];\r\n    }\r\n\r\n    return [];\r\n  };\r\n\r\n  public dateChanged(event: MatDatepickerInputEvent<Date>): void {\r\n    if (event.value) {\r\n      const date = event.value;\r\n      const index = this._findDate(date);\r\n      if (index === -1) {\r\n        this.model.push(date);\r\n        this.modelChange.emit(this.model);\r\n      } else {\r\n        this.model.splice(index, 1);\r\n        this.modelChange.emit(this.model);\r\n      }\r\n      this.resetModel = new Date();\r\n      if (!this.CLOSE_ON_SELECTED) {\r\n        const closeFn = this._picker.close;\r\n        this._picker.close = (): any => { };\r\n        this._picker['_popupComponentRef']?.instance._calendar.monthView._createWeekCells();\r\n        setTimeout(() => {\r\n          this._picker.close = closeFn;\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  public remove(date: Date): void {\r\n    const index = this._findDate(date);\r\n    this.model.splice(index, 1);\r\n    this.modelChange.emit(this.model);\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  isDateNotHoliday(date: Date): boolean {\r\n    const { countryCode, timeZoneOffset } = this.holidayOptions ?? {};\r\n\r\n    if (countryCode && timeZoneOffset) {\r\n      const holiday = new Holidays(countryCode.toUpperCase());\r\n\r\n      return !holiday.isHoliday(`${format(date, 'yyyy-MM-dd')}T00:00:00${timeZoneOffset}`);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  filterDateRange = (date: Date): boolean => {\r\n    let result = true;\r\n\r\n    if (isValid(new Date(date))) {\r\n      const day = date?.getDay();\r\n\r\n      if (this.excludeWeekends) {\r\n        result = result && day !== 0 && day !== 6;\r\n      }\r\n\r\n      if (this.excludeHolidays) {\r\n        result = result && this.isDateNotHoliday(date);\r\n      }\r\n    }\r\n\r\n    return result;\r\n  };\r\n\r\n  private _findDate(date: Date): number {\r\n    return this.model.map((m) => +m).indexOf(+date);\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <mat-chip-list \r\n      #chipList aria-label=\"Choose a date\" \r\n      (click)=\"picker.open()\"\r\n      class=\"w-full\"\r\n    >\r\n      <mat-chip \r\n        class=\"form-field__input\" \r\n        *ngFor=\"let value of model\" \r\n        [selectable]=\"false\" [removable]=\"true\"\r\n        (removed)=\"remove(value)\"\r\n      >\r\n        {{ value | date: 'dd/MM/yyyy' }}\r\n        <mat-icon matChipRemove *ngIf=\"true\">cancel</mat-icon>\r\n      </mat-chip>\r\n      <input \r\n        class=\"form-field__input fake-input\"  \r\n        [value]=\"resetModel\"\r\n        [(ngModel)]=\"value\" \r\n        [matDatepicker]=\"picker\" \r\n        placeholder=\"Select dates\" \r\n        (dateChange)=\"dateChanged($event)\"\r\n        [matChipInputFor]=\"chipList\" \r\n        [min]=\"minDate\" \r\n        [max]=\"maxDate\" \r\n        [matDatepickerFilter]=\"filterDateRange\"\r\n      />\r\n    </mat-chip-list>\r\n    <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n      <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-datepicker\r\n      #picker \r\n      [calendarHeaderComponent]=\"header\" \r\n      [touchUi]=\"touchUi\" \r\n      [dateClass]=\"dateClass\"\r\n    >\r\n      <mat-datepicker-actions>\r\n        <ecabs-date-picker-actions \r\n          [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n          [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n        >\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n  </div>\r\n</app-element-wrapper>"]}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
5
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
6
|
+
import { MatLegacyButtonModule as MatButtonModule } from '@angular/material/legacy-button';
|
|
7
|
+
import { MatLegacyInputModule } from "@angular/material/legacy-input";
|
|
8
|
+
import { MatLegacyChipsModule as MatChipModule } from '@angular/material/legacy-chips';
|
|
9
|
+
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
10
|
+
import { EcabsPickerHeaderModule } from '../ecabs-picker-header/ecabs-picker-header.module';
|
|
11
|
+
import { EcabsDatePickerActionsModule } from "../ecabs-date-picker-actions/ecabs-date-picker-actions.module";
|
|
12
|
+
import { EcabsMultipleDatesPickerComponent } from './ecabs-multiple-dates-picker.component';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
export class EcabsMultipleDatesPickerModule {
|
|
15
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsMultipleDatesPickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
16
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: EcabsMultipleDatesPickerModule, declarations: [EcabsMultipleDatesPickerComponent], imports: [CommonModule,
|
|
17
|
+
ElementWrapperModule,
|
|
18
|
+
MatIconModule,
|
|
19
|
+
MatDatepickerModule,
|
|
20
|
+
MatChipModule,
|
|
21
|
+
MatButtonModule,
|
|
22
|
+
MatLegacyInputModule,
|
|
23
|
+
FormsModule,
|
|
24
|
+
ReactiveFormsModule,
|
|
25
|
+
EcabsPickerHeaderModule,
|
|
26
|
+
EcabsDatePickerActionsModule], exports: [EcabsMultipleDatesPickerComponent] });
|
|
27
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsMultipleDatesPickerModule, imports: [CommonModule,
|
|
28
|
+
ElementWrapperModule,
|
|
29
|
+
MatIconModule,
|
|
30
|
+
MatDatepickerModule,
|
|
31
|
+
MatChipModule,
|
|
32
|
+
MatButtonModule,
|
|
33
|
+
MatLegacyInputModule,
|
|
34
|
+
FormsModule,
|
|
35
|
+
ReactiveFormsModule,
|
|
36
|
+
EcabsPickerHeaderModule,
|
|
37
|
+
EcabsDatePickerActionsModule] });
|
|
38
|
+
}
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsMultipleDatesPickerModule, decorators: [{
|
|
40
|
+
type: NgModule,
|
|
41
|
+
args: [{
|
|
42
|
+
declarations: [EcabsMultipleDatesPickerComponent,],
|
|
43
|
+
imports: [
|
|
44
|
+
CommonModule,
|
|
45
|
+
ElementWrapperModule,
|
|
46
|
+
MatIconModule,
|
|
47
|
+
MatDatepickerModule,
|
|
48
|
+
MatChipModule,
|
|
49
|
+
MatButtonModule,
|
|
50
|
+
MatLegacyInputModule,
|
|
51
|
+
FormsModule,
|
|
52
|
+
ReactiveFormsModule,
|
|
53
|
+
EcabsPickerHeaderModule,
|
|
54
|
+
EcabsDatePickerActionsModule
|
|
55
|
+
],
|
|
56
|
+
exports: [EcabsMultipleDatesPickerComponent,],
|
|
57
|
+
}]
|
|
58
|
+
}] });
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtbXVsdGlwbGUtZGF0ZXMtcGlja2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1tdWx0aXBsZS1kYXRlcy1waWNrZXIvZWNhYnMtbXVsdGlwbGUtZGF0ZXMtcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxxQkFBcUIsSUFBSSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUMzRixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsb0JBQW9CLElBQUksYUFBYSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFFdkYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDdEYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDNUYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sK0RBQStELENBQUM7QUFFN0csT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0seUNBQXlDLENBQUM7O0FBbUI1RixNQUFNLE9BQU8sOEJBQThCO3dHQUE5Qiw4QkFBOEI7eUdBQTlCLDhCQUE4QixpQkFoQjFCLGlDQUFpQyxhQUU5QyxZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIsYUFBYTtZQUNiLGVBQWU7WUFDZixvQkFBb0I7WUFDcEIsV0FBVztZQUNYLG1CQUFtQjtZQUNuQix1QkFBdUI7WUFDdkIsNEJBQTRCLGFBRXBCLGlDQUFpQzt5R0FFaEMsOEJBQThCLFlBZHZDLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixhQUFhO1lBQ2IsZUFBZTtZQUNmLG9CQUFvQjtZQUNwQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLHVCQUF1QjtZQUN2Qiw0QkFBNEI7OzRGQUluQiw4QkFBOEI7a0JBakIxQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGlDQUFpQyxFQUFFO29CQUNsRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixvQkFBb0I7d0JBQ3BCLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixhQUFhO3dCQUNiLGVBQWU7d0JBQ2Ysb0JBQW9CO3dCQUNwQixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsdUJBQXVCO3dCQUN2Qiw0QkFBNEI7cUJBQzdCO29CQUNELE9BQU8sRUFBRSxDQUFDLGlDQUFpQyxFQUFFO2lCQUM5QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBNYXREYXRlcGlja2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGF0ZXBpY2tlcic7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgTWF0TGVnYWN5QnV0dG9uTW9kdWxlIGFzIE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xlZ2FjeS1idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRMZWdhY3lJbnB1dE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9sZWdhY3ktaW5wdXRcIjtcclxuaW1wb3J0IHsgTWF0TGVnYWN5Q2hpcHNNb2R1bGUgYXMgTWF0Q2hpcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xlZ2FjeS1jaGlwcyc7XHJcblxyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic1BpY2tlckhlYWRlck1vZHVsZSB9IGZyb20gJy4uL2VjYWJzLXBpY2tlci1oZWFkZXIvZWNhYnMtcGlja2VyLWhlYWRlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic0RhdGVQaWNrZXJBY3Rpb25zTW9kdWxlIH0gZnJvbSBcIi4uL2VjYWJzLWRhdGUtcGlja2VyLWFjdGlvbnMvZWNhYnMtZGF0ZS1waWNrZXItYWN0aW9ucy5tb2R1bGVcIjtcclxuXHJcbmltcG9ydCB7IEVjYWJzTXVsdGlwbGVEYXRlc1BpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtbXVsdGlwbGUtZGF0ZXMtcGlja2VyLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0VjYWJzTXVsdGlwbGVEYXRlc1BpY2tlckNvbXBvbmVudCxdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEVsZW1lbnRXcmFwcGVyTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIE1hdERhdGVwaWNrZXJNb2R1bGUsXHJcbiAgICBNYXRDaGlwTW9kdWxlLFxyXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxyXG4gICAgTWF0TGVnYWN5SW5wdXRNb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBFY2Fic1BpY2tlckhlYWRlck1vZHVsZSxcclxuICAgIEVjYWJzRGF0ZVBpY2tlckFjdGlvbnNNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtFY2Fic011bHRpcGxlRGF0ZXNQaWNrZXJDb21wb25lbnQsXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEVjYWJzTXVsdGlwbGVEYXRlc1BpY2tlck1vZHVsZSB7IH1cclxuIl19
|