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.
Files changed (23) hide show
  1. package/esm2022/lib/base/element-base.mjs +6 -2
  2. package/esm2022/lib/base/element-wrapper/element-wrapper.component.mjs +3 -3
  3. package/esm2022/lib/base/models/ecabs-date-picker-translations.models.mjs +1 -1
  4. package/esm2022/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.mjs +2 -2
  5. package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +46 -5
  6. package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.module.mjs +1 -1
  7. package/esm2022/lib/ecabs-increment/ecabs-increment.component.mjs +2 -2
  8. package/esm2022/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.component.mjs +179 -0
  9. package/esm2022/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.module.mjs +59 -0
  10. package/esm2022/lib/ecabs-picker-header/ecabs-picker-header.component.mjs +2 -2
  11. package/esm2022/lib/ecabs-place-autocomplete/ecabs-place-autocomplete.component.mjs +3 -3
  12. package/esm2022/public-api.mjs +3 -1
  13. package/fesm2022/ecabs-components.mjs +272 -21
  14. package/fesm2022/ecabs-components.mjs.map +1 -1
  15. package/lib/base/element-base.d.ts +2 -1
  16. package/lib/base/models/ecabs-date-picker-translations.models.d.ts +4 -0
  17. package/lib/ecabs-date-picker/ecabs-date-picker.component.d.ts +8 -2
  18. package/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.component.d.ts +49 -0
  19. package/lib/ecabs-multiple-dates-picker/ecabs-multiple-dates-picker.module.d.ts +17 -0
  20. package/package.json +2 -1
  21. package/public-api.d.ts +2 -0
  22. package/src/assets/styles/scss/modules/_map.scss +28 -0
  23. 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