ecabs-components 1.1.44 → 1.1.46
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -1
- package/esm2022/lib/base/validators/date-range.validator.mjs +17 -0
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +9 -4
- package/esm2022/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.mjs +22 -6
- package/esm2022/lib/ecabs-date-range-picker/ecabs-date-range-picker.module.mjs +1 -1
- package/esm2022/lib/ecabs-dialog-confirm-deletion/ecabs-dialog-confirm-deletion.component.mjs +4 -4
- package/esm2022/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.mjs +11 -6
- package/fesm2022/ecabs-components.mjs +53 -12
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/lib/base/validators/date-range.validator.d.ts +14 -0
- package/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.d.ts +3 -1
- package/package.json +1 -1
- package/src/assets/styles/tailwind/index.scss +1 -1
package/README.md
CHANGED
|
@@ -103,4 +103,6 @@ To get more help on the Angular CLI use `ng help` or go check out the [Angular C
|
|
|
103
103
|
- **v1.1.41** — Added EcabsDialogConfirmationDeletionComponent.
|
|
104
104
|
- **v1.1.42** — Apply `width` and `height` properties directly to root `MatDialog` of `EcabsDialogConfirmComponent`.
|
|
105
105
|
- **v1.1.43** — Added disabling of Apply button for date range picker
|
|
106
|
-
- **v1.1.44** — Fixed issue Apply button is still active when only the DateFrom is selected
|
|
106
|
+
- **v1.1.44** — Fixed issue Apply button is still active when only the DateFrom is selected
|
|
107
|
+
- **v1.1.45** — Added default validation of date range
|
|
108
|
+
- **v1.1.46** — Add `ViewChild` reference for `MatRadioGroup` and update event type in `EcabsRadioButtonListComponent`.
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export const dateRangeValidator = (control) => {
|
|
2
|
+
if (control.value) {
|
|
3
|
+
const { dateFrom, dateTo } = control.value;
|
|
4
|
+
control.setErrors(null);
|
|
5
|
+
if (!dateFrom && dateTo) {
|
|
6
|
+
return { dateFromRangeRequired: true };
|
|
7
|
+
}
|
|
8
|
+
if (dateFrom && !dateTo) {
|
|
9
|
+
return { dateToRangeRequired: true };
|
|
10
|
+
}
|
|
11
|
+
if (dateFrom > dateTo) {
|
|
12
|
+
return { dateFromMoreThanDateTo: true };
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return null;
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS52YWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvYmFzZS92YWxpZGF0b3JzL2RhdGUtcmFuZ2UudmFsaWRhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLENBQUMsT0FBMkIsRUFBRSxFQUFFO0lBQ2hFLElBQUksT0FBTyxDQUFDLEtBQUssRUFBRTtRQUNqQixNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7UUFDM0MsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV4QixJQUFJLENBQUMsUUFBUSxJQUFJLE1BQU0sRUFBRTtZQUN2QixPQUFPLEVBQUUscUJBQXFCLEVBQUUsSUFBSSxFQUFFLENBQUM7U0FDeEM7UUFFRCxJQUFJLFFBQVEsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUN2QixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsSUFBSSxFQUFFLENBQUM7U0FDdEM7UUFFRCxJQUFJLFFBQVEsR0FBRyxNQUFNLEVBQUU7WUFDckIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLElBQUksRUFBRSxDQUFDO1NBQ3pDO0tBQ0Y7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVudHlwZWRGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuXHJcbmV4cG9ydCBjb25zdCBkYXRlUmFuZ2VWYWxpZGF0b3IgPSAoY29udHJvbDogVW50eXBlZEZvcm1Db250cm9sKSA9PiB7XHJcbiAgaWYgKGNvbnRyb2wudmFsdWUpIHtcclxuICAgIGNvbnN0IHsgZGF0ZUZyb20sIGRhdGVUbyB9ID0gY29udHJvbC52YWx1ZTtcclxuICAgIGNvbnRyb2wuc2V0RXJyb3JzKG51bGwpO1xyXG5cclxuICAgIGlmICghZGF0ZUZyb20gJiYgZGF0ZVRvKSB7XHJcbiAgICAgIHJldHVybiB7IGRhdGVGcm9tUmFuZ2VSZXF1aXJlZDogdHJ1ZSB9O1xyXG4gICAgfVxyXG5cclxuICAgIGlmIChkYXRlRnJvbSAmJiAhZGF0ZVRvKSB7XHJcbiAgICAgIHJldHVybiB7IGRhdGVUb1JhbmdlUmVxdWlyZWQ6IHRydWUgfTtcclxuICAgIH1cclxuXHJcbiAgICBpZiAoZGF0ZUZyb20gPiBkYXRlVG8pIHtcclxuICAgICAgcmV0dXJuIHsgZGF0ZUZyb21Nb3JlVGhhbkRhdGVUbzogdHJ1ZSB9O1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcmV0dXJuIG51bGw7XHJcbn07XHJcbiJdfQ==
|
|
@@ -61,11 +61,16 @@ export class EcabsDatePickerComponent extends EcabsElementBaseComponent {
|
|
|
61
61
|
if (ngControl) {
|
|
62
62
|
this.control = ngControl.control;
|
|
63
63
|
}
|
|
64
|
-
this.datepicker?.openedStream
|
|
64
|
+
this.datepicker?.openedStream
|
|
65
|
+
.asObservable()
|
|
66
|
+
.pipe(takeUntil(this.unsubscribeService.subscription()))
|
|
65
67
|
.subscribe(() => {
|
|
66
68
|
setTimeout(() => {
|
|
67
|
-
const calendar = this.datepicker._componentRef?.instance
|
|
68
|
-
|
|
69
|
+
const calendar = this.datepicker._componentRef?.instance
|
|
70
|
+
._calendar;
|
|
71
|
+
calendar?._userSelection
|
|
72
|
+
.asObservable()
|
|
73
|
+
.pipe(takeUntil(this.unsubscribeService.subscription()))
|
|
69
74
|
.subscribe((lastChosenDate) => {
|
|
70
75
|
this.disabledApplyButton = !lastChosenDate.value;
|
|
71
76
|
});
|
|
@@ -158,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
158
163
|
type: ViewChild,
|
|
159
164
|
args: ['picker']
|
|
160
165
|
}] } });
|
|
161
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { format, isEqual, isValid } from 'date-fns';\r\nimport { takeUntil } from 'rxjs';\r\nimport Holidays from 'date-holidays';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} 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 './components/ecabs-date-picker-header/ecabs-date-picker-header.component';\r\nimport { MatDatepicker } from '@angular/material/datepicker';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-picker',\r\n  templateUrl: './ecabs-date-picker.component.html',\r\n  styleUrls: ['./ecabs-date-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDatePickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDatePickerComponent\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit\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() specificDates: Date[];\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  @ViewChild('picker') datepicker: MatDatepicker<any> | undefined;\r\n\r\n  val: string | number;\r\n  header = EcabsDatePickerHeaderComponent;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n  disabledApplyButton = true;\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 (this.val !== val && (!val || isValid(new Date(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\r\n      .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    this.datepicker?.openedStream.asObservable().pipe(takeUntil(this.unsubscribeService.subscription()))\r\n    .subscribe(() => {\r\n      setTimeout(()=>{\r\n        const calendar = (this.datepicker as any)._componentRef?.instance._calendar;\r\n         calendar?._userSelection.asObservable().pipe(takeUntil(this.unsubscribeService.subscription()))\r\n         .subscribe((lastChosenDate)=>{\r\n             this.disabledApplyButton = !lastChosenDate.value; \r\n        })\r\n      }, 100);\r\n    });\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  blurChange(e: any): void {\r\n    this.onblur.emit(e);\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(\r\n        `${format(date, 'yyyy-MM-dd')}T00:00:00${timeZoneOffset}`,\r\n      );\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      if (this.specificDates?.length > 0) {\r\n        const specificDates = this.specificDates;\r\n        if (specificDates && specificDates.length > 0) {\r\n          const index = specificDates.findIndex((specificDate) =>\r\n            isEqual(date, specificDate),\r\n          );\r\n          result = result && index === -1;\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  };\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper\">\r\n    <input\r\n      class=\"form-field__input date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"value\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      [matDatepickerFilter]=\"filterDateRange\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker-toggle\r\n      matSuffix [for]=\"picker\"\r\n      class=\"text-gray-500\"\r\n    >\r\n      <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-datepicker #picker\r\n      [calendarHeaderComponent]=\"header\"\r\n      [touchUi]=\"touchUi\"\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          [disabledApplyButton]=\"disabledApplyButton\"\r\n        >\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n  </div>\r\n</ecabs-element-wrapper>\r\n"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-picker/ecabs-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { format, isEqual, isValid } from 'date-fns';\r\nimport { takeUntil } from 'rxjs';\r\nimport Holidays from 'date-holidays';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport {\r\n  EcabsDatePickerHolidayOptions,\r\n  EcabsDatePickerTranslations,\r\n} 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 './components/ecabs-date-picker-header/ecabs-date-picker-header.component';\r\nimport { MatDatepicker } from '@angular/material/datepicker';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-picker',\r\n  templateUrl: './ecabs-date-picker.component.html',\r\n  styleUrls: ['./ecabs-date-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDatePickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDatePickerComponent\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit\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() specificDates: Date[];\r\n  @Input() holidayOptions: EcabsDatePickerHolidayOptions;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  @ViewChild('picker') datepicker: MatDatepicker<any> | undefined;\r\n\r\n  val: string | number;\r\n  header = EcabsDatePickerHeaderComponent;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n  disabledApplyButton = true;\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 (this.val !== val && (!val || isValid(new Date(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\r\n      .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    this.datepicker?.openedStream\r\n      .asObservable()\r\n      .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n      .subscribe(() => {\r\n        setTimeout(() => {\r\n          const calendar = (this.datepicker as any)._componentRef?.instance\r\n            ._calendar;\r\n          calendar?._userSelection\r\n            .asObservable()\r\n            .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n            .subscribe((lastChosenDate) => {\r\n              this.disabledApplyButton = !lastChosenDate.value;\r\n            });\r\n        }, 100);\r\n      });\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  blurChange(e: any): void {\r\n    this.onblur.emit(e);\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(\r\n        `${format(date, 'yyyy-MM-dd')}T00:00:00${timeZoneOffset}`,\r\n      );\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      if (this.specificDates?.length > 0) {\r\n        const specificDates = this.specificDates;\r\n        if (specificDates && specificDates.length > 0) {\r\n          const index = specificDates.findIndex((specificDate) =>\r\n            isEqual(date, specificDate),\r\n          );\r\n          result = result && index === -1;\r\n        }\r\n      }\r\n    }\r\n\r\n    return result;\r\n  };\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper\">\r\n    <input\r\n      class=\"form-field__input date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"value\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      [matDatepickerFilter]=\"filterDateRange\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker-toggle\r\n      matSuffix [for]=\"picker\"\r\n      class=\"text-gray-500\"\r\n    >\r\n      <mat-icon matDatepickerToggleIcon>calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-datepicker #picker\r\n      [calendarHeaderComponent]=\"header\"\r\n      [touchUi]=\"touchUi\"\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          [disabledApplyButton]=\"disabledApplyButton\"\r\n        >\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n  </div>\r\n</ecabs-element-wrapper>\r\n"]}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { takeUntil } from 'rxjs';
|
|
2
2
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
3
|
-
import { NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';
|
|
3
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';
|
|
4
4
|
import EcabsElementBaseComponent from '../base/element-base';
|
|
5
5
|
import { UnsubscribeService } from '../base/services/unsubscribe.service';
|
|
6
6
|
import { EcabsDateRangePickerHeaderComponent } from './components/ecabs-date-range-picker-header/ecabs-date-range-picker-header.component';
|
|
7
7
|
import { isValid } from 'date-fns';
|
|
8
|
+
import { dateRangeValidator } from '../base/validators/date-range.validator';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "../base/services/ecabs-date-picker-translations.service";
|
|
10
11
|
import * as i2 from "../base/services/unsubscribe.service";
|
|
@@ -87,11 +88,16 @@ export class EcabsDateRangePickerComponent extends EcabsElementBaseComponent {
|
|
|
87
88
|
this.dateTo = this.value.dateTo;
|
|
88
89
|
});
|
|
89
90
|
}
|
|
90
|
-
this.datepicker?.openedStream
|
|
91
|
+
this.datepicker?.openedStream
|
|
92
|
+
.asObservable()
|
|
93
|
+
.pipe(takeUntil(this.unsubscribeService.subscription()))
|
|
91
94
|
.subscribe(() => {
|
|
92
95
|
setTimeout(() => {
|
|
93
|
-
const calendar = this.datepicker._componentRef?.instance
|
|
94
|
-
|
|
96
|
+
const calendar = this.datepicker._componentRef?.instance
|
|
97
|
+
._calendar;
|
|
98
|
+
calendar?._userSelection
|
|
99
|
+
.asObservable()
|
|
100
|
+
.pipe(takeUntil(this.unsubscribeService.subscription()))
|
|
95
101
|
.subscribe((lastChosenDate) => {
|
|
96
102
|
let startRange;
|
|
97
103
|
let endRange;
|
|
@@ -105,7 +111,7 @@ export class EcabsDateRangePickerComponent extends EcabsElementBaseComponent {
|
|
|
105
111
|
if (start > lastChosenDate.value) {
|
|
106
112
|
startRange = lastChosenDate.value;
|
|
107
113
|
}
|
|
108
|
-
else if (lastChosenDate.value &&
|
|
114
|
+
else if (lastChosenDate.value && start && !end) {
|
|
109
115
|
endRange = lastChosenDate.value;
|
|
110
116
|
}
|
|
111
117
|
this.disabledApplyButton = !(startRange && endRange);
|
|
@@ -140,6 +146,11 @@ export class EcabsDateRangePickerComponent extends EcabsElementBaseComponent {
|
|
|
140
146
|
useExisting: EcabsDateRangePickerComponent,
|
|
141
147
|
multi: true,
|
|
142
148
|
},
|
|
149
|
+
{
|
|
150
|
+
provide: NG_VALIDATORS,
|
|
151
|
+
useValue: dateRangeValidator,
|
|
152
|
+
multi: true,
|
|
153
|
+
},
|
|
143
154
|
UnsubscribeService,
|
|
144
155
|
], viewQueries: [{ propertyName: "datepicker", first: true, predicate: ["picker"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper\">\r\n <mat-date-range-input \r\n [rangePicker]=\"picker\" \r\n [min]=\"minDate\"\r\n [max]=\"maxDate\" \r\n (blur)=\"onTouch()\">\r\n <input matStartDate class=\"form-field__input\" [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\" [value]=\"dateFrom\" [(ngModel)]=\"dateFrom\" />\r\n <input matEndDate class=\"form-field__input\" [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\" [value]=\"dateTo\" [(ngModel)]=\"dateTo\" />\r\n </mat-date-range-input>\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n <mat-icon matDatepickerToggleIcon class=\"text-gray-500\">calendar_today</mat-icon>\r\n </mat-datepicker-toggle>\r\n <mat-date-range-picker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\">\r\n <mat-datepicker-actions>\r\n <ecabs-date-picker-actions [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n [isDateRange]=\"true\"\r\n [disabledApplyButton]=\"disabledApplyButton\"\r\n (apply)=\"onApply()\">\r\n </ecabs-date-picker-actions>\r\n </mat-datepicker-actions>\r\n </mat-date-range-picker>\r\n </div>\r\n</ecabs-element-wrapper>\r\n", styles: [".header{display:flex;align-items:center;padding:.5em}.datepicker-ui__toggle.mat-mdc-icon-button.mat-mdc-button-base,.mat-mdc-icon-button.mat-mdc-button-base.mat-datepicker-toggle{padding:0;width:2.5rem;height:2.5rem;line-height:2}.header-label{flex:1;height:1em;font-weight:500;text-align:center}.select-date-label{color:var(--color-brand-dark);padding-top:1.6rem;padding-left:1.6rem}.mat-calendar-table .mat-calendar-body tr:first-child[aria-hidden=true]{display:none}.mat-calendar-body-label{visibility:hidden}.mat-calendar-body-cell-content{border-radius:.25rem!important}.mat-calendar-body-active .mat-calendar-body-today{color:var(--color-brand-light)!important;background-color:var(--color-brand-light2)!important}.mat-calendar{align-self:center}.mat-calendar .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:var(--color-brand-light2);color:var(--color-black)}.mat-calendar .mat-calendar-body-cell.mat-calendar-body-active .mat-calendar-body-cell-content.mat-calendar-body-selected,.mat-calendar .mat-calendar-body-cell.mat-calendar-body-active:hover .mat-calendar-body-cell-content.mat-calendar-body-selected{background-color:var(--color-brand-light)!important;color:var(--color-white)!important}.mat-calendar .mat-calendar-body-selected{background-color:var(--color-brand-light);color:var(--color-white)!important}.mat-calendar .mat-calendar-body-selected .mat-calendar-body-today{color:var(--color-white)!important}.mat-calendar .mat-calendar-table-header,.mat-calendar .mat-calendar-body-label{color:var(--color-gray-500)}.mat-calendar .mat-calendar-body-cell>.mat-calendar-body-today{opacity:1}.mat-calendar .mat-calendar-body-cell-content,.mat-calendar .mat-date-range-input-separator{color:var(--color-black)}.mat-calendar .mat-calendar-content{padding:0 1.6rem}.mat-calendar .mat-calendar-table-header th{font-size:16px;font-size:1rem}.mat-calendar .mat-calendar-table-header-divider:after{display:none}.mat-calendar .mat-calendar-body{font-size:16px;font-size:1rem}.mat-calendar .mat-calendar-body-in-range:before{background-color:var(--color-brand-light2)}.mat-calendar .mat-calendar-body-in-range .mat-calendar-body-cell-content{color:var(--color-black)!important}.mat-calendar .mat-calendar-body-range-start .mat-calendar-body-cell-content,.mat-calendar .mat-calendar-body-range-end .mat-calendar-body-cell-content{color:var(--color-white)!important}.mat-datepicker-popup .mat-datepicker-content{color:var(--color-black);box-shadow:0 0 25px #0003}.mat-datepicker-popup .mat-datepicker-actions{display:unset;margin-top:1rem;padding:0 1.6rem 1.6rem}.mat-datepicker-popup .mat-datepicker-actions .mat-button-base+.mat-button-base{margin-left:unset}.mat-datepicker-popup .mat-datepicker-actions button.mat-button-base{min-width:100%}.mat-datepicker-popup .mat-calendar-body-disabled>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){color:var(--color-gray-300)}.datepicker-ui__toggle,.mat-datepicker-toggle{position:absolute!important;right:0;line-height:1.25;padding:0}.datepicker-ui__toggle mat-icon,.mat-datepicker-toggle mat-icon{color:var(--color-gray-500)}ecabs-date-picker .dateTimeWrapper{position:relative;display:flex;width:100%}ecabs-date-picker .dateTimeWrapper .datePart{flex:2}ecabs-date-picker .dateTimeWrapper .timePart{flex:1;padding-left:10px;vertical-align:top;max-width:10rem}ecabs-date-picker .dateTimeWrapper .timePart ecabs-timepicker .timeInputWrapper{display:block}ecabs-date-picker .dateTimeWrapper .timePart ecabs-timepicker{width:100%}ecabs-date-picker .dateTimeWrapper .timePart ecabs-timepicker .inputWrapper{display:block}ecabs-date-picker .dateTimeWrapper .dateInputWrapper{position:relative}ecabs-date-picker .dateTimeWrapper input{min-height:42px;width:100%;display:block;box-sizing:border-box;font-size:14px;font-weight:500;padding-left:10px;border-radius:4px;border:1px solid rgb(107,109,115);outline:none;transition:all .3s ease-in-out}ecabs-date-picker .dateTimeWrapper input:disabled{border-bottom-width:1px;background-color:var(--color-white-opacity-05)}ecabs-date-picker .dateTimeWrapper input[type=date]::-webkit-calendar-picker-indicator,ecabs-date-picker .dateTimeWrapper input[type=date]::-webkit-inner-spin-button{display:none}ecabs-date-picker .dateTimeWrapper input[type=date]::-webkit-clear-button{display:none}ecabs-date-picker .dateTimeWrapper .calendar-icon{float:right;margin-top:-38px;padding:5px 10px 5px 5px;display:block;font-size:13px;line-height:20px;color:var(--color-gray-500);position:relative;width:40px;height:30px;cursor:pointer;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI1LjQuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCA0OCA0OCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgNDggNDg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDojNkI2RDczO30KPC9zdHlsZT4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTksNDRjLTAuOCwwLTEuNS0wLjMtMi4xLTAuOUM2LjMsNDIuNSw2LDQxLjgsNiw0MVYxMGMwLTAuOCwwLjMtMS41LDAuOS0yLjFTOC4yLDcsOSw3aDMuMlY0aDMuMnYzaDE3VjRoMy4ydjMKCUgzOWMwLjgsMCwxLjUsMC4zLDIuMSwwLjlDNDEuNyw4LjUsNDIsOS4yLDQyLDEwdjMxYzAsMC44LTAuMywxLjUtMC45LDIuMUM0MC41LDQzLjcsMzkuOCw0NCwzOSw0NEg5eiBNOSw0MWgzMGwwLDBsMCwwVjE5LjVIOVY0MQoJTDksNDFMOSw0MXogTTksMTYuNWgzMFYxMGwwLDBsMCwwSDlsMCwwbDAsMFYxNi41eiBNOSwxNi41VjEwbDAsMGwwLDBsMCwwbDAsMFYxNi41eiIvPgo8L3N2Zz4K);background-position:center center;background-repeat:no-repeat;background-size:1.375rem}ecabs-date-picker .dateTimeWrapper .calendar-icon.disabled{cursor:not-allowed}ecabs-date-picker .ecabs-element-wrapper.focused label{color:#376bfb}ecabs-date-picker .ecabs-element-wrapper.focused input{border-bottom-width:2px;border-bottom-color:#376bfb}ecabs-date-picker .ecabs-element-wrapper.validationError label{color:#ff4c4c}ecabs-date-picker .ecabs-element-wrapper.validationError input{border-bottom-color:#ff4c4c;border-bottom-width:2px}.ng-mydp .myDpSelector{border:0;padding:0;box-shadow:0 4px 6px #162a4c14,0 2px 16px #162a4c0f,0 8px 12px #162a4c0a;border-radius:0 0 4px 4px;background:#fff}.ng-mydp .myDpSelector:focus{box-shadow:0 4px 6px #162a4c14,0 2px 16px #162a4c0f,0 8px 12px #162a4c0a}.ng-mydp .myDpSelector .myDpWeekDayTitle{background-color:#fff;font-weight:500;font-size:11px;color:#162a4cb3}.ng-mydp .myDpSelector .myDpNextBtn{margin-left:auto;margin-right:16px}.ng-mydp .myDpSelector .myDpNextBtn .myDpIconRightArrow{line-height:26px;height:25px}.ng-mydp .myDpSelector .myDpNextBtn .myDpIconRightArrow:before{color:#376bfb;font-size:13px}.ng-mydp .myDpSelector .myDpPrevBtn{margin-left:16px}.ng-mydp .myDpSelector .myDpPrevBtn .myDpIconLeftArrow{line-height:26px;height:25px}.ng-mydp .myDpSelector .myDpPrevBtn .myDpIconLeftArrow:before{color:#376bfb;font-size:13px}.ng-mydp .myDpSelector .myDpMonthYearSelBar{height:52px;padding-top:10px;border:0}.ng-mydp .myDpSelector .myDpMonthYearText button{font-weight:500;font-size:13px;line-height:20px;color:#376bfb}.ng-mydp .myDpSelector .myDpMonthYearText .myDpMonthBtn{padding-right:7px;position:relative;margin-right:15px}.ng-mydp .myDpSelector .myDpMonthYearText .myDpMonthBtn:after{position:absolute;content:\"\";height:14px;width:1px;right:-7px;top:6px;background:#162a4c80}.ng-mydp .myDpSelector .myDpMonthYearText .myDpYearBtn{padding-left:6px}.ng-mydp .myDpSelector .myDpCalTable{height:calc(100% - 54px);width:calc(100% - 20px);margin:0 10px}.ng-mydp .myDpSelector table.myDpCalTable td .myDpDayValue{border-radius:4px;background:#f0f2f5;display:inline-block;box-sizing:border-box;width:32px;height:28px;font-size:13px;line-height:28px;text-align:center;color:#162a4ce6}.ng-mydp .myDpSelector table.myDpCalTable td .myDpDayValue.myDpMarkCurrDay{border-bottom:0;color:#376bfb}.ng-mydp .myDpSelector table.myDpCalTable td.myDpSelectedDay .myDpDayValue{color:#fff!important;background:#6ab72a!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDisabled{background:unset}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDisabled .myDpDayValue{background:unset!important;color:#162a4c80;cursor:not-allowed}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDisabled .myDpDayValue:hover{background:unset!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpRangeColor{background-color:#fff}.ng-mydp .myDpSelector table.myDpCalTable td.myDpRangeColor .myDpDayValue{background:#bee39d!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpRangeColor.myDpSelectedDay .myDpDayValue{color:#fff!important;background:#6ab72a!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDaycell:focus{box-shadow:unset;outline:unset}.ng-mydp .myDpSelector table.myDpCalTable td.myDpPrevMonth .myDpDayValue,.ng-mydp .myDpSelector table.myDpCalTable td.myDpNextMonth .myDpDayValue{background:#f6f7f9;color:#162a4c80}.ng-mydp .myDpSelector table.myDpCalTable td .myDpDimDay{opacity:1}.ng-mydp .myDpSelector table.myDpCalTable .myDpTableSingleDay:hover{background-color:#fff}.ng-mydp .myDpSelector table.myDpCalTable .myDpTableSingleDay:hover .myDpDayValue{background:#bee39d;color:#162a4ce6}.ng-mydp .myDpSelector table.myDpCalTable .myDpSelectedDay,.ng-mydp .myDpSelector table.myDpCalTable .myDpSelectedMonth,.ng-mydp .myDpSelector table.myDpCalTable .myDpSelectedYear{background-color:#fff;border-radius:0}.ng-mydp .myDpSelector .myDpMonthTable{height:128px;width:calc(100% - 20px);margin:0 10px}.ng-mydp .myDpSelector .myDpMonthTable td .myDpMonthValue{display:inline-block;height:28px;width:80px;background:#f0f2f5;vertical-align:middle;text-align:center;line-height:28px;font-weight:400;font-size:13px;color:#162a4ce6;border-radius:4px}.ng-mydp .myDpSelector .myDpMonthTable td .myDpMonthValue.myDpMarkCurrMonth{border:0;color:#376bfb}.ng-mydp .myDpSelector .myDpMonthTable td .myDpMonthValue:hover{background:#bee39d}.ng-mydp .myDpSelector .myDpMonthTable td.myDpDisabled{background:unset}.ng-mydp .myDpSelector .myDpMonthTable td.myDpDisabled .myDpMonthValue{background:unset!important;color:#162a4c80!important;cursor:not-allowed}.ng-mydp .myDpSelector .myDpMonthTable td.myDpSelectedMonth{background-color:#fff}.ng-mydp .myDpSelector .myDpMonthTable td.myDpSelectedMonth .myDpMonthValue{background:#6ab72a!important;color:#fff!important}.ng-mydp .myDpSelector .myDpMonthTable td.myDpTableSingleMonth:hover{background-color:#fff}.ng-mydp .myDpSelector .myDpYearTable{height:160px;width:calc(100% - 20px);margin:0 10px}.ng-mydp .myDpSelector .myDpYearTable td .myDpYearValue{display:inline-block;height:28px;width:46px;background:#f0f2f5;vertical-align:middle;text-align:center;line-height:28px;font-weight:400;font-size:13px;color:#162a4ce6;border-radius:4px}.ng-mydp .myDpSelector .myDpYearTable td .myDpYearValue.myDpMarkCurrYear{border:0;color:#376bfb}.ng-mydp .myDpSelector .myDpYearTable td .myDpYearValue:hover{background:#bee39d}.ng-mydp .myDpSelector .myDpYearTable td.myDpDisabled{background:unset}.ng-mydp .myDpSelector .myDpYearTable td.myDpDisabled .myDpYearValue{background:unset!important;color:#162a4c80!important;cursor:not-allowed}.ng-mydp .myDpSelector .myDpYearTable td.myDpSelectedYear{background-color:#fff}.ng-mydp .myDpSelector .myDpYearTable td.myDpSelectedYear .myDpYearValue{background:#6ab72a!important;color:#fff!important}.ng-mydp .myDpSelector .myDpYearTable td.myDpTableSingleYear:hover{background-color:#fff}.ng-mydp .myDpSelectorArrow{height:272px!important;width:268px!important;margin-top:-12px}.ng-mydp .myDpSelectorArrow:after{display:none}.ng-mydp .myDpSelectorArrow:before{display:none}: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)}.mat-date-range-input{display:block;width:100%;padding:.5rem 1rem;border-radius:.25rem;border:1px solid var(--color-gray-500);color:var(--color-black);line-height:1.5}:host ::ng-deep .mat-mdc-icon-button{max-width:2.5rem;max-height:2.5rem}\n"], dependencies: [{ kind: "component", type: i3.EcabsElementWrapperComponent, selector: "ecabs-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i5.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "component", type: i5.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i5.MatStartDate, selector: "input[matStartDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i5.MatEndDate, selector: "input[matEndDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i5.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "component", type: i5.MatDatepickerActions, selector: "mat-datepicker-actions, mat-date-range-picker-actions" }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i7.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i8.EcabsDatePickerActionsComponent, selector: "ecabs-date-picker-actions", inputs: ["cancelLabel", "applyLabel", "isDateRange", "disabledApplyButton"], outputs: ["apply"] }] });
|
|
145
156
|
}
|
|
@@ -151,6 +162,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
151
162
|
useExisting: EcabsDateRangePickerComponent,
|
|
152
163
|
multi: true,
|
|
153
164
|
},
|
|
165
|
+
{
|
|
166
|
+
provide: NG_VALIDATORS,
|
|
167
|
+
useValue: dateRangeValidator,
|
|
168
|
+
multi: true,
|
|
169
|
+
},
|
|
154
170
|
UnsubscribeService,
|
|
155
171
|
], template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper\">\r\n <mat-date-range-input \r\n [rangePicker]=\"picker\" \r\n [min]=\"minDate\"\r\n [max]=\"maxDate\" \r\n (blur)=\"onTouch()\">\r\n <input matStartDate class=\"form-field__input\" [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\" [value]=\"dateFrom\" [(ngModel)]=\"dateFrom\" />\r\n <input matEndDate class=\"form-field__input\" [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\" [value]=\"dateTo\" [(ngModel)]=\"dateTo\" />\r\n </mat-date-range-input>\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n <mat-icon matDatepickerToggleIcon class=\"text-gray-500\">calendar_today</mat-icon>\r\n </mat-datepicker-toggle>\r\n <mat-date-range-picker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\">\r\n <mat-datepicker-actions>\r\n <ecabs-date-picker-actions [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n [isDateRange]=\"true\"\r\n [disabledApplyButton]=\"disabledApplyButton\"\r\n (apply)=\"onApply()\">\r\n </ecabs-date-picker-actions>\r\n </mat-datepicker-actions>\r\n </mat-date-range-picker>\r\n </div>\r\n</ecabs-element-wrapper>\r\n", styles: [".header{display:flex;align-items:center;padding:.5em}.datepicker-ui__toggle.mat-mdc-icon-button.mat-mdc-button-base,.mat-mdc-icon-button.mat-mdc-button-base.mat-datepicker-toggle{padding:0;width:2.5rem;height:2.5rem;line-height:2}.header-label{flex:1;height:1em;font-weight:500;text-align:center}.select-date-label{color:var(--color-brand-dark);padding-top:1.6rem;padding-left:1.6rem}.mat-calendar-table .mat-calendar-body tr:first-child[aria-hidden=true]{display:none}.mat-calendar-body-label{visibility:hidden}.mat-calendar-body-cell-content{border-radius:.25rem!important}.mat-calendar-body-active .mat-calendar-body-today{color:var(--color-brand-light)!important;background-color:var(--color-brand-light2)!important}.mat-calendar{align-self:center}.mat-calendar .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:var(--color-brand-light2);color:var(--color-black)}.mat-calendar .mat-calendar-body-cell.mat-calendar-body-active .mat-calendar-body-cell-content.mat-calendar-body-selected,.mat-calendar .mat-calendar-body-cell.mat-calendar-body-active:hover .mat-calendar-body-cell-content.mat-calendar-body-selected{background-color:var(--color-brand-light)!important;color:var(--color-white)!important}.mat-calendar .mat-calendar-body-selected{background-color:var(--color-brand-light);color:var(--color-white)!important}.mat-calendar .mat-calendar-body-selected .mat-calendar-body-today{color:var(--color-white)!important}.mat-calendar .mat-calendar-table-header,.mat-calendar .mat-calendar-body-label{color:var(--color-gray-500)}.mat-calendar .mat-calendar-body-cell>.mat-calendar-body-today{opacity:1}.mat-calendar .mat-calendar-body-cell-content,.mat-calendar .mat-date-range-input-separator{color:var(--color-black)}.mat-calendar .mat-calendar-content{padding:0 1.6rem}.mat-calendar .mat-calendar-table-header th{font-size:16px;font-size:1rem}.mat-calendar .mat-calendar-table-header-divider:after{display:none}.mat-calendar .mat-calendar-body{font-size:16px;font-size:1rem}.mat-calendar .mat-calendar-body-in-range:before{background-color:var(--color-brand-light2)}.mat-calendar .mat-calendar-body-in-range .mat-calendar-body-cell-content{color:var(--color-black)!important}.mat-calendar .mat-calendar-body-range-start .mat-calendar-body-cell-content,.mat-calendar .mat-calendar-body-range-end .mat-calendar-body-cell-content{color:var(--color-white)!important}.mat-datepicker-popup .mat-datepicker-content{color:var(--color-black);box-shadow:0 0 25px #0003}.mat-datepicker-popup .mat-datepicker-actions{display:unset;margin-top:1rem;padding:0 1.6rem 1.6rem}.mat-datepicker-popup .mat-datepicker-actions .mat-button-base+.mat-button-base{margin-left:unset}.mat-datepicker-popup .mat-datepicker-actions button.mat-button-base{min-width:100%}.mat-datepicker-popup .mat-calendar-body-disabled>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){color:var(--color-gray-300)}.datepicker-ui__toggle,.mat-datepicker-toggle{position:absolute!important;right:0;line-height:1.25;padding:0}.datepicker-ui__toggle mat-icon,.mat-datepicker-toggle mat-icon{color:var(--color-gray-500)}ecabs-date-picker .dateTimeWrapper{position:relative;display:flex;width:100%}ecabs-date-picker .dateTimeWrapper .datePart{flex:2}ecabs-date-picker .dateTimeWrapper .timePart{flex:1;padding-left:10px;vertical-align:top;max-width:10rem}ecabs-date-picker .dateTimeWrapper .timePart ecabs-timepicker .timeInputWrapper{display:block}ecabs-date-picker .dateTimeWrapper .timePart ecabs-timepicker{width:100%}ecabs-date-picker .dateTimeWrapper .timePart ecabs-timepicker .inputWrapper{display:block}ecabs-date-picker .dateTimeWrapper .dateInputWrapper{position:relative}ecabs-date-picker .dateTimeWrapper input{min-height:42px;width:100%;display:block;box-sizing:border-box;font-size:14px;font-weight:500;padding-left:10px;border-radius:4px;border:1px solid rgb(107,109,115);outline:none;transition:all .3s ease-in-out}ecabs-date-picker .dateTimeWrapper input:disabled{border-bottom-width:1px;background-color:var(--color-white-opacity-05)}ecabs-date-picker .dateTimeWrapper input[type=date]::-webkit-calendar-picker-indicator,ecabs-date-picker .dateTimeWrapper input[type=date]::-webkit-inner-spin-button{display:none}ecabs-date-picker .dateTimeWrapper input[type=date]::-webkit-clear-button{display:none}ecabs-date-picker .dateTimeWrapper .calendar-icon{float:right;margin-top:-38px;padding:5px 10px 5px 5px;display:block;font-size:13px;line-height:20px;color:var(--color-gray-500);position:relative;width:40px;height:30px;cursor:pointer;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI1LjQuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCA0OCA0OCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgNDggNDg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDojNkI2RDczO30KPC9zdHlsZT4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTksNDRjLTAuOCwwLTEuNS0wLjMtMi4xLTAuOUM2LjMsNDIuNSw2LDQxLjgsNiw0MVYxMGMwLTAuOCwwLjMtMS41LDAuOS0yLjFTOC4yLDcsOSw3aDMuMlY0aDMuMnYzaDE3VjRoMy4ydjMKCUgzOWMwLjgsMCwxLjUsMC4zLDIuMSwwLjlDNDEuNyw4LjUsNDIsOS4yLDQyLDEwdjMxYzAsMC44LTAuMywxLjUtMC45LDIuMUM0MC41LDQzLjcsMzkuOCw0NCwzOSw0NEg5eiBNOSw0MWgzMGwwLDBsMCwwVjE5LjVIOVY0MQoJTDksNDFMOSw0MXogTTksMTYuNWgzMFYxMGwwLDBsMCwwSDlsMCwwbDAsMFYxNi41eiBNOSwxNi41VjEwbDAsMGwwLDBsMCwwbDAsMFYxNi41eiIvPgo8L3N2Zz4K);background-position:center center;background-repeat:no-repeat;background-size:1.375rem}ecabs-date-picker .dateTimeWrapper .calendar-icon.disabled{cursor:not-allowed}ecabs-date-picker .ecabs-element-wrapper.focused label{color:#376bfb}ecabs-date-picker .ecabs-element-wrapper.focused input{border-bottom-width:2px;border-bottom-color:#376bfb}ecabs-date-picker .ecabs-element-wrapper.validationError label{color:#ff4c4c}ecabs-date-picker .ecabs-element-wrapper.validationError input{border-bottom-color:#ff4c4c;border-bottom-width:2px}.ng-mydp .myDpSelector{border:0;padding:0;box-shadow:0 4px 6px #162a4c14,0 2px 16px #162a4c0f,0 8px 12px #162a4c0a;border-radius:0 0 4px 4px;background:#fff}.ng-mydp .myDpSelector:focus{box-shadow:0 4px 6px #162a4c14,0 2px 16px #162a4c0f,0 8px 12px #162a4c0a}.ng-mydp .myDpSelector .myDpWeekDayTitle{background-color:#fff;font-weight:500;font-size:11px;color:#162a4cb3}.ng-mydp .myDpSelector .myDpNextBtn{margin-left:auto;margin-right:16px}.ng-mydp .myDpSelector .myDpNextBtn .myDpIconRightArrow{line-height:26px;height:25px}.ng-mydp .myDpSelector .myDpNextBtn .myDpIconRightArrow:before{color:#376bfb;font-size:13px}.ng-mydp .myDpSelector .myDpPrevBtn{margin-left:16px}.ng-mydp .myDpSelector .myDpPrevBtn .myDpIconLeftArrow{line-height:26px;height:25px}.ng-mydp .myDpSelector .myDpPrevBtn .myDpIconLeftArrow:before{color:#376bfb;font-size:13px}.ng-mydp .myDpSelector .myDpMonthYearSelBar{height:52px;padding-top:10px;border:0}.ng-mydp .myDpSelector .myDpMonthYearText button{font-weight:500;font-size:13px;line-height:20px;color:#376bfb}.ng-mydp .myDpSelector .myDpMonthYearText .myDpMonthBtn{padding-right:7px;position:relative;margin-right:15px}.ng-mydp .myDpSelector .myDpMonthYearText .myDpMonthBtn:after{position:absolute;content:\"\";height:14px;width:1px;right:-7px;top:6px;background:#162a4c80}.ng-mydp .myDpSelector .myDpMonthYearText .myDpYearBtn{padding-left:6px}.ng-mydp .myDpSelector .myDpCalTable{height:calc(100% - 54px);width:calc(100% - 20px);margin:0 10px}.ng-mydp .myDpSelector table.myDpCalTable td .myDpDayValue{border-radius:4px;background:#f0f2f5;display:inline-block;box-sizing:border-box;width:32px;height:28px;font-size:13px;line-height:28px;text-align:center;color:#162a4ce6}.ng-mydp .myDpSelector table.myDpCalTable td .myDpDayValue.myDpMarkCurrDay{border-bottom:0;color:#376bfb}.ng-mydp .myDpSelector table.myDpCalTable td.myDpSelectedDay .myDpDayValue{color:#fff!important;background:#6ab72a!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDisabled{background:unset}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDisabled .myDpDayValue{background:unset!important;color:#162a4c80;cursor:not-allowed}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDisabled .myDpDayValue:hover{background:unset!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpRangeColor{background-color:#fff}.ng-mydp .myDpSelector table.myDpCalTable td.myDpRangeColor .myDpDayValue{background:#bee39d!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpRangeColor.myDpSelectedDay .myDpDayValue{color:#fff!important;background:#6ab72a!important}.ng-mydp .myDpSelector table.myDpCalTable td.myDpDaycell:focus{box-shadow:unset;outline:unset}.ng-mydp .myDpSelector table.myDpCalTable td.myDpPrevMonth .myDpDayValue,.ng-mydp .myDpSelector table.myDpCalTable td.myDpNextMonth .myDpDayValue{background:#f6f7f9;color:#162a4c80}.ng-mydp .myDpSelector table.myDpCalTable td .myDpDimDay{opacity:1}.ng-mydp .myDpSelector table.myDpCalTable .myDpTableSingleDay:hover{background-color:#fff}.ng-mydp .myDpSelector table.myDpCalTable .myDpTableSingleDay:hover .myDpDayValue{background:#bee39d;color:#162a4ce6}.ng-mydp .myDpSelector table.myDpCalTable .myDpSelectedDay,.ng-mydp .myDpSelector table.myDpCalTable .myDpSelectedMonth,.ng-mydp .myDpSelector table.myDpCalTable .myDpSelectedYear{background-color:#fff;border-radius:0}.ng-mydp .myDpSelector .myDpMonthTable{height:128px;width:calc(100% - 20px);margin:0 10px}.ng-mydp .myDpSelector .myDpMonthTable td .myDpMonthValue{display:inline-block;height:28px;width:80px;background:#f0f2f5;vertical-align:middle;text-align:center;line-height:28px;font-weight:400;font-size:13px;color:#162a4ce6;border-radius:4px}.ng-mydp .myDpSelector .myDpMonthTable td .myDpMonthValue.myDpMarkCurrMonth{border:0;color:#376bfb}.ng-mydp .myDpSelector .myDpMonthTable td .myDpMonthValue:hover{background:#bee39d}.ng-mydp .myDpSelector .myDpMonthTable td.myDpDisabled{background:unset}.ng-mydp .myDpSelector .myDpMonthTable td.myDpDisabled .myDpMonthValue{background:unset!important;color:#162a4c80!important;cursor:not-allowed}.ng-mydp .myDpSelector .myDpMonthTable td.myDpSelectedMonth{background-color:#fff}.ng-mydp .myDpSelector .myDpMonthTable td.myDpSelectedMonth .myDpMonthValue{background:#6ab72a!important;color:#fff!important}.ng-mydp .myDpSelector .myDpMonthTable td.myDpTableSingleMonth:hover{background-color:#fff}.ng-mydp .myDpSelector .myDpYearTable{height:160px;width:calc(100% - 20px);margin:0 10px}.ng-mydp .myDpSelector .myDpYearTable td .myDpYearValue{display:inline-block;height:28px;width:46px;background:#f0f2f5;vertical-align:middle;text-align:center;line-height:28px;font-weight:400;font-size:13px;color:#162a4ce6;border-radius:4px}.ng-mydp .myDpSelector .myDpYearTable td .myDpYearValue.myDpMarkCurrYear{border:0;color:#376bfb}.ng-mydp .myDpSelector .myDpYearTable td .myDpYearValue:hover{background:#bee39d}.ng-mydp .myDpSelector .myDpYearTable td.myDpDisabled{background:unset}.ng-mydp .myDpSelector .myDpYearTable td.myDpDisabled .myDpYearValue{background:unset!important;color:#162a4c80!important;cursor:not-allowed}.ng-mydp .myDpSelector .myDpYearTable td.myDpSelectedYear{background-color:#fff}.ng-mydp .myDpSelector .myDpYearTable td.myDpSelectedYear .myDpYearValue{background:#6ab72a!important;color:#fff!important}.ng-mydp .myDpSelector .myDpYearTable td.myDpTableSingleYear:hover{background-color:#fff}.ng-mydp .myDpSelectorArrow{height:272px!important;width:268px!important;margin-top:-12px}.ng-mydp .myDpSelectorArrow:after{display:none}.ng-mydp .myDpSelectorArrow:before{display:none}: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)}.mat-date-range-input{display:block;width:100%;padding:.5rem 1rem;border-radius:.25rem;border:1px solid var(--color-gray-500);color:var(--color-black);line-height:1.5}:host ::ng-deep .mat-mdc-icon-button{max-width:2.5rem;max-height:2.5rem}\n"] }]
|
|
156
172
|
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.EcabsDatePickerHeaderService }, { type: i2.UnsubscribeService }]; }, propDecorators: { minDate: [{
|
|
@@ -173,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
173
189
|
type: ViewChild,
|
|
174
190
|
args: ['picker']
|
|
175
191
|
}] } });
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-range-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { takeUntil } from 'rxjs';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport { EcabsDatePickerTranslations } from '../base/models/ecabs-date-picker-translations.models';\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\nimport { EcabsDateRangePickerHeaderComponent } from './components/ecabs-date-range-picker-header/ecabs-date-range-picker-header.component';\r\nimport { MatDateRangePicker } from '@angular/material/datepicker';\r\nimport { isValid } from 'date-fns';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-range-picker',\r\n  templateUrl: './ecabs-date-range-picker.component.html',\r\n  styleUrls: ['./ecabs-date-range-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateRangePickerComponent,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDateRangePickerComponent\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit\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() startDatePlaceholder: string;\r\n  @Input() endDatePlaceholder: string;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n  val: {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  };\r\n\r\n  @ViewChild('picker') datepicker: MatDateRangePicker<any> | undefined;\r\n\r\n  header = EcabsDateRangePickerHeaderComponent;\r\n  _dateFrom: string;\r\n  _dateTo: string;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n  disabledApplyButton = true;\r\n\r\n  get value(): {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  } {\r\n    return this.val;\r\n  }\r\n\r\n  get dateFrom(): string {\r\n    return this._dateFrom;\r\n  }\r\n\r\n  get dateTo(): string {\r\n    return this._dateTo;\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set value(val: { dateFrom: string; dateTo: string }) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.dateFrom = val.dateFrom;\r\n      this.dateTo = val.dateTo;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateFrom(val: string) {\r\n    if (this._dateFrom !== val && isValid(new Date(val))) {\r\n      this._dateFrom = val;\r\n      this.onApply();\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateTo(val: string) {\r\n    if (this._dateTo !== val && isValid(new Date(val))) {\r\n      this._dateTo = val;\r\n      this.onApply();\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\r\n      .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      setTimeout(() => {\r\n        this.dateFrom = this.value.dateFrom;\r\n        this.dateTo = this.value.dateTo;\r\n      });\r\n    }\r\n\r\n    this.datepicker?.openedStream.asObservable().pipe(takeUntil(this.unsubscribeService.subscription()))\r\n    .subscribe(() => {\r\n      setTimeout(()=>{\r\n        const calendar = (this.datepicker as any)._componentRef?.instance._calendar;\r\n         calendar?._userSelection.asObservable().pipe(takeUntil(this.unsubscribeService.subscription()))\r\n         .subscribe((lastChosenDate)=>{\r\n            let startRange: Date;\r\n            let endRange: Date;\r\n            const {start, end} = calendar.selected ?? {};\r\n\r\n            if (lastChosenDate.value && (!start || (start && end))) {\r\n              startRange = lastChosenDate.value;\r\n            }\r\n\r\n            if (lastChosenDate.value && start && !end) {\r\n              startRange = start;\r\n            }\r\n\r\n            if (start > lastChosenDate.value) {\r\n              startRange = lastChosenDate.value;\r\n            } else if (lastChosenDate.value && (start && !end)) {\r\n              endRange = lastChosenDate.value;\r\n            }\r\n            \r\n            this.disabledApplyButton = !(startRange && endRange); \r\n        })\r\n      }, 100);\r\n    });\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  blurChange(e): void {\r\n    this.onblur.emit(e);\r\n  }\r\n\r\n  onApply(): void {\r\n    this.value = {\r\n      dateFrom: this.dateFrom,\r\n      dateTo: this.dateTo,\r\n    };\r\n  }\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper\">\r\n    <mat-date-range-input \r\n      [rangePicker]=\"picker\" \r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\" \r\n      (blur)=\"onTouch()\">\r\n      <input matStartDate class=\"form-field__input\" [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\" [value]=\"dateFrom\" [(ngModel)]=\"dateFrom\" />\r\n      <input matEndDate class=\"form-field__input\" [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\" [value]=\"dateTo\" [(ngModel)]=\"dateTo\" />\r\n    </mat-date-range-input>\r\n    <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n      <mat-icon matDatepickerToggleIcon class=\"text-gray-500\">calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-date-range-picker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\">\r\n      <mat-datepicker-actions>\r\n        <ecabs-date-picker-actions [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n                                   [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n                                   [isDateRange]=\"true\"\r\n                                   [disabledApplyButton]=\"disabledApplyButton\"\r\n                                   (apply)=\"onApply()\">\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-date-range-picker>\r\n  </div>\r\n</ecabs-element-wrapper>\r\n"]}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-range-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAEjC,OAAO,EAEL,SAAS,EACT,YAAY,EAEZ,KAAK,EAEL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,aAAa,EACb,iBAAiB,EACjB,SAAS,GAEV,MAAM,gBAAgB,CAAC;AAExB,OAAO,yBAAyB,MAAM,sBAAsB,CAAC;AAG7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,mCAAmC,EAAE,MAAM,sFAAsF,CAAC;AAE3I,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;;;;;;;;;;AAoB7E,MAAM,OAAO,6BACX,SAAQ,yBAAyB;IAoEd;IACA;IACA;IAnEV,OAAO,CAAO;IACd,OAAO,CAAO;IACd,OAAO,GAAG,KAAK,CAAC;IAChB,WAAW,CAAS;IACpB,UAAU,CAAS;IACnB,oBAAoB,CAAS;IAC7B,kBAAkB,CAAS;IAE1B,MAAM,GAAG,IAAI,YAAY,EAAO,CAAC;IAC3C,GAAG,CAGD;IAEmB,UAAU,CAAsC;IAErE,MAAM,GAAG,mCAAmC,CAAC;IAC7C,SAAS,CAAS;IAClB,OAAO,CAAS;IAChB,iBAAiB,CAA8B;IAC/C,mBAAmB,GAAG,IAAI,CAAC;IAE3B,IAAI,KAAK;QAIP,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,0BAA0B;IAC1B,IAAI,KAAK,CAAC,GAAyC;QACjD,IAAI,IAAI,CAAC,GAAG,KAAK,GAAG,EAAE;YACpB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;YACf,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;YAC7B,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;YACzB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YACnB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;SACnB;IACH,CAAC;IAED,0BAA0B;IAC1B,IAAI,QAAQ,CAAC,GAAW;QACtB,IAAI,IAAI,CAAC,SAAS,KAAK,GAAG,IAAI,OAAO,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE;YACpD,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;YACrB,IAAI,CAAC,OAAO,EAAE,CAAC;SAChB;IACH,CAAC;IAED,0BAA0B;IAC1B,IAAI,MAAM,CAAC,GAAW;QACpB,IAAI,IAAI,CAAC,OAAO,KAAK,GAAG,IAAI,OAAO,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE;YAClD,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YACnB,IAAI,CAAC,OAAO,EAAE,CAAC;SAChB;IACH,CAAC;IAED,YACmB,QAAkB,EAClB,4BAA0D,EAC1D,kBAAsC;QAEvD,KAAK,EAAE,CAAC;QAJS,aAAQ,GAAR,QAAQ,CAAU;QAClB,iCAA4B,GAA5B,4BAA4B,CAA8B;QAC1D,uBAAkB,GAAlB,kBAAkB,CAAoB;IAGzD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,4BAA4B;aAC9B,SAAS,EAAE;aACX,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC,CAAC;aACvD,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,eAAe;QACb,MAAM,SAAS,GAAc,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAChE,IAAI,SAAS,EAAE;YACb,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAA6B,CAAC;YACvD,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBACpC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;YAClC,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,UAAU,EAAE,YAAY;aAC1B,YAAY,EAAE;aACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC,CAAC;aACvD,SAAS,CAAC,GAAG,EAAE;YACd,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,QAAQ,GAAI,IAAI,CAAC,UAAkB,CAAC,aAAa,EAAE,QAAQ;qBAC9D,SAAS,CAAC;gBACb,QAAQ,EAAE,cAAc;qBACrB,YAAY,EAAE;qBACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC,CAAC;qBACvD,SAAS,CAAC,CAAC,cAAc,EAAE,EAAE;oBAC5B,IAAI,UAAgB,CAAC;oBACrB,IAAI,QAAc,CAAC;oBACnB,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,QAAQ,CAAC,QAAQ,IAAI,EAAE,CAAC;oBAE/C,IAAI,cAAc,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,KAAK,IAAI,GAAG,CAAC,CAAC,EAAE;wBACtD,UAAU,GAAG,cAAc,CAAC,KAAK,CAAC;qBACnC;oBAED,IAAI,cAAc,CAAC,KAAK,IAAI,KAAK,IAAI,CAAC,GAAG,EAAE;wBACzC,UAAU,GAAG,KAAK,CAAC;qBACpB;oBAED,IAAI,KAAK,GAAG,cAAc,CAAC,KAAK,EAAE;wBAChC,UAAU,GAAG,cAAc,CAAC,KAAK,CAAC;qBACnC;yBAAM,IAAI,cAAc,CAAC,KAAK,IAAI,KAAK,IAAI,CAAC,GAAG,EAAE;wBAChD,QAAQ,GAAG,cAAc,CAAC,KAAK,CAAC;qBACjC;oBAED,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC,UAAU,IAAI,QAAQ,CAAC,CAAC;gBACvD,CAAC,CAAC,CAAC;YACP,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IACzB,OAAO,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAExB,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,UAAU,CAAC,CAAC;QACV,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,CAAC;IACJ,CAAC;wGAxJU,6BAA6B;4FAA7B,6BAA6B,uSAd7B;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,6BAA6B;gBAC1C,KAAK,EAAE,IAAI;aACZ;YACD;gBACE,OAAO,EAAE,aAAa;gBACtB,QAAQ,EAAE,kBAAkB;gBAC5B,KAAK,EAAE,IAAI;aACZ;YACD,kBAAkB;SACnB,uJC7CH,2+CAyBA;;4FDsBa,6BAA6B;kBAlBzC,SAAS;+BACE,yBAAyB,aAGxB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,+BAA+B;4BAC1C,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,aAAa;4BACtB,QAAQ,EAAE,kBAAkB;4BAC5B,KAAK,EAAE,IAAI;yBACZ;wBACD,kBAAkB;qBACnB;2KAMQ,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBAEI,MAAM;sBAAf,MAAM;gBAMc,UAAU;sBAA9B,SAAS;uBAAC,QAAQ","sourcesContent":["import { takeUntil } from 'rxjs';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALIDATORS,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n} from '@angular/forms';\r\n\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport { EcabsDatePickerTranslations } from '../base/models/ecabs-date-picker-translations.models';\r\nimport { EcabsDatePickerHeaderService } from '../base/services/ecabs-date-picker-translations.service';\r\nimport { UnsubscribeService } from '../base/services/unsubscribe.service';\r\nimport { EcabsDateRangePickerHeaderComponent } from './components/ecabs-date-range-picker-header/ecabs-date-range-picker-header.component';\r\nimport { MatDateRangePicker } from '@angular/material/datepicker';\r\nimport { isValid } from 'date-fns';\r\nimport { dateRangeValidator } from '../base/validators/date-range.validator';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-range-picker',\r\n  templateUrl: './ecabs-date-range-picker.component.html',\r\n  styleUrls: ['./ecabs-date-range-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateRangePickerComponent,\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useValue: dateRangeValidator,\r\n      multi: true,\r\n    },\r\n    UnsubscribeService,\r\n  ],\r\n})\r\nexport class EcabsDateRangePickerComponent\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnInit\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() startDatePlaceholder: string;\r\n  @Input() endDatePlaceholder: string;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n  val: {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  };\r\n\r\n  @ViewChild('picker') datepicker: MatDateRangePicker<any> | undefined;\r\n\r\n  header = EcabsDateRangePickerHeaderComponent;\r\n  _dateFrom: string;\r\n  _dateTo: string;\r\n  translationConfig: EcabsDatePickerTranslations;\r\n  disabledApplyButton = true;\r\n\r\n  get value(): {\r\n    dateFrom: string;\r\n    dateTo: string;\r\n  } {\r\n    return this.val;\r\n  }\r\n\r\n  get dateFrom(): string {\r\n    return this._dateFrom;\r\n  }\r\n\r\n  get dateTo(): string {\r\n    return this._dateTo;\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set value(val: { dateFrom: string; dateTo: string }) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.dateFrom = val.dateFrom;\r\n      this.dateTo = val.dateTo;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateFrom(val: string) {\r\n    if (this._dateFrom !== val && isValid(new Date(val))) {\r\n      this._dateFrom = val;\r\n      this.onApply();\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set dateTo(val: string) {\r\n    if (this._dateTo !== val && isValid(new Date(val))) {\r\n      this._dateTo = val;\r\n      this.onApply();\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\r\n      .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      setTimeout(() => {\r\n        this.dateFrom = this.value.dateFrom;\r\n        this.dateTo = this.value.dateTo;\r\n      });\r\n    }\r\n\r\n    this.datepicker?.openedStream\r\n      .asObservable()\r\n      .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n      .subscribe(() => {\r\n        setTimeout(() => {\r\n          const calendar = (this.datepicker as any)._componentRef?.instance\r\n            ._calendar;\r\n          calendar?._userSelection\r\n            .asObservable()\r\n            .pipe(takeUntil(this.unsubscribeService.subscription()))\r\n            .subscribe((lastChosenDate) => {\r\n              let startRange: Date;\r\n              let endRange: Date;\r\n              const { start, end } = calendar.selected ?? {};\r\n\r\n              if (lastChosenDate.value && (!start || (start && end))) {\r\n                startRange = lastChosenDate.value;\r\n              }\r\n\r\n              if (lastChosenDate.value && start && !end) {\r\n                startRange = start;\r\n              }\r\n\r\n              if (start > lastChosenDate.value) {\r\n                startRange = lastChosenDate.value;\r\n              } else if (lastChosenDate.value && start && !end) {\r\n                endRange = lastChosenDate.value;\r\n              }\r\n\r\n              this.disabledApplyButton = !(startRange && endRange);\r\n            });\r\n        }, 100);\r\n      });\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  blurChange(e): void {\r\n    this.onblur.emit(e);\r\n  }\r\n\r\n  onApply(): void {\r\n    this.value = {\r\n      dateFrom: this.dateFrom,\r\n      dateTo: this.dateTo,\r\n    };\r\n  }\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper\">\r\n    <mat-date-range-input \r\n      [rangePicker]=\"picker\" \r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\" \r\n      (blur)=\"onTouch()\">\r\n      <input matStartDate class=\"form-field__input\" [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\" [value]=\"dateFrom\" [(ngModel)]=\"dateFrom\" />\r\n      <input matEndDate class=\"form-field__input\" [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\" [value]=\"dateTo\" [(ngModel)]=\"dateTo\" />\r\n    </mat-date-range-input>\r\n    <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n      <mat-icon matDatepickerToggleIcon class=\"text-gray-500\">calendar_today</mat-icon>\r\n    </mat-datepicker-toggle>\r\n    <mat-date-range-picker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\">\r\n      <mat-datepicker-actions>\r\n        <ecabs-date-picker-actions [applyLabel]=\"applyLabel ?? translationConfig?.applyLabel\"\r\n                                   [cancelLabel]=\"cancelLabel ?? translationConfig?.cancelLabel\"\r\n                                   [isDateRange]=\"true\"\r\n                                   [disabledApplyButton]=\"disabledApplyButton\"\r\n                                   (apply)=\"onApply()\">\r\n        </ecabs-date-picker-actions>\r\n      </mat-datepicker-actions>\r\n    </mat-date-range-picker>\r\n  </div>\r\n</ecabs-element-wrapper>\r\n"]}
|
|
@@ -84,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
84
84
|
exports: [EcabsDateRangePickerComponent, EcabsDateRangePickerHeaderComponent],
|
|
85
85
|
}]
|
|
86
86
|
}] });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtZGF0ZS1yYW5nZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWRhdGUtcmFuZ2UtcGlja2VyL2VjYWJzLWRhdGUtcmFuZ2UtcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQzdGLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQ2xHLE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ3JHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQzVGLE9BQU8sRUFBRSxtQ0FBbUMsRUFBRSxNQUFNLHNGQUFzRixDQUFDO0FBQzNJLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBQzdHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBRXpELE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHO0lBQzdDLEtBQUssRUFBRTtRQUNMLFNBQVMsRUFBRSxzQkFBc0I7S0FDbEM7SUFDRCxPQUFPLEVBQUU7UUFDUCxTQUFTLEVBQUUsc0JBQXNCO1FBQ2pDLGNBQWMsRUFBRSxVQUFVO1FBQzFCLGFBQWEsRUFBRSxzQkFBc0I7UUFDckMsa0JBQWtCLEVBQUUsV0FBVztLQUNoQztDQUNGLENBQUM7QUF5QkYsTUFBTSxPQUFPLG9CQUFvQjt3R0FBcEIsb0JBQW9CO3lHQUFwQixvQkFBb0IsaUJBckI3Qiw2QkFBNkI7WUFDN0IsbUNBQW1DLGFBR25DLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixlQUFlO1lBQ2YsV0FBVztZQUNYLG1CQUFtQjtZQUNuQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLCtCQUErQjtZQUMvQixnQ0FBZ0M7WUFDaEMsNEJBQTRCO1lBQzVCLGNBQWM7WUFDZCw0QkFBNEIsYUFFcEIsNkJBQTZCLEVBQUUsbUNBQW1DO3lHQUVqRSxvQkFBb0IsWUFqQjdCLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixlQUFlO1lBQ2YsV0FBVztZQUNYLG1CQUFtQjtZQUNuQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLCtCQUErQjtZQUMvQixnQ0FBZ0M7WUFDaEMsNEJBQTRCO1lBQzVCLGNBQWM7WUFDZCw0QkFBNEI7OzRGQUluQixvQkFBb0I7a0JBdkJoQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWiw2QkFBNkI7d0JBQzdCLG1DQUFtQztxQkFDcEM7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixhQUFhO3dCQUNiLG1CQUFtQjt3QkFDbkIsZUFBZTt3QkFDZixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsdUJBQXVCO3dCQUN2QixrQkFBa0I7d0JBQ2xCLCtCQUErQjt3QkFDL0IsZ0NBQWdDO3dCQUNoQyw0QkFBNEI7d0JBQzVCLGNBQWM7d0JBQ2QsNEJBQTRCO3FCQUM3QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyw2QkFBNkIsRUFBRSxtQ0FBbUMsQ0FBQztpQkFDOUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0RGF0ZXBpY2tlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXInO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IEVjYWJzTWFza0RhdGVEaXJlY3RpdmVNb2R1bGUgfSBmcm9tICcuLi9iYXNlL2RpcmVjdGl2ZXMvZGF0ZS1tYXNrLmRpcmVjdGl2ZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic0RpZ2l0c09ubHlEaXJlY3RpdmVzTW9kdWxlIH0gZnJvbSAnLi4vYmFzZS9kaXJlY3RpdmVzL2RpZ2l0cy1vbmx5LmRpcmVjdGl2ZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic051bWJlckJvcmRlckRpcmVjdGl2ZU1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZGlyZWN0aXZlcy9udW1iZXItYm9yZGVyLmRpcmVjdGl2ZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic0J1dHRvbnNNb2R1bGUgfSBmcm9tICcuLi9lY2Ficy1idXR0b25zL2VjYWJzLWJ1dHRvbnMubW9kdWxlJztcclxuaW1wb3J0IHsgRWNhYnNQaWNrZXJIZWFkZXJNb2R1bGUgfSBmcm9tICcuLi9lY2Ficy1waWNrZXItaGVhZGVyL2VjYWJzLXBpY2tlci1oZWFkZXIubW9kdWxlJztcclxuaW1wb3J0IHsgRWNhYnNEYXRlUmFuZ2VQaWNrZXJIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZWNhYnMtZGF0ZS1yYW5nZS1waWNrZXItaGVhZGVyL2VjYWJzLWRhdGUtcmFuZ2UtcGlja2VyLWhlYWRlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBFY2Fic0RhdGVSYW5nZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRWNhYnNEYXRlUGlja2VyQWN0aW9uc01vZHVsZSB9IGZyb20gJy4uL2VjYWJzLWRhdGUtcGlja2VyLWFjdGlvbnMvZWNhYnMtZGF0ZS1waWNrZXItYWN0aW9ucy5tb2R1bGUnO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuXHJcbmV4cG9ydCBjb25zdCBNQVRFUklBTF9EQVRFVElNRVBJQ0tFUl9GT1JNQVRTID0ge1xyXG4gIHBhcnNlOiB7XHJcbiAgICBkYXRlSW5wdXQ6ICdERC9NTU0vWVlZWSBISDptbTpTUycsXHJcbiAgfSxcclxuICBkaXNwbGF5OiB7XHJcbiAgICBkYXRlSW5wdXQ6ICdERC9NTU0vWVlZWSBISDptbTpTUycsXHJcbiAgICBtb250aFllYXJMYWJlbDogJ01NTSBZWVlZJyxcclxuICAgIGRhdGVBMTF5TGFiZWw6ICdERC9NTU0vWVlZWSBISDptbTpTUycsXHJcbiAgICBtb250aFllYXJBMTF5TGFiZWw6ICdNTU1NIFlZWVknLFxyXG4gIH0sXHJcbn07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRWNhYnNEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQsXHJcbiAgICBFY2Fic0RhdGVSYW5nZVBpY2tlckhlYWRlckNvbXBvbmVudCxcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEVsZW1lbnRXcmFwcGVyTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIE1hdERhdGVwaWNrZXJNb2R1bGUsXHJcbiAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBFY2Fic1BpY2tlckhlYWRlck1vZHVsZSxcclxuICAgIEVjYWJzQnV0dG9uc01vZHVsZSxcclxuICAgIEVjYWJzRGlnaXRzT25seURpcmVjdGl2ZXNNb2R1bGUsXHJcbiAgICBFY2Fic051bWJlckJvcmRlckRpcmVjdGl2ZU1vZHVsZSxcclxuICAgIEVjYWJzTWFza0RhdGVEaXJlY3RpdmVNb2R1bGUsXHJcbiAgICBNYXRJbnB1dE1vZHVsZSxcclxuICAgIEVjYWJzRGF0ZVBpY2tlckFjdGlvbnNNb2R1bGUsXHJcbiAgXSxcclxuICBleHBvcnRzOiBbRWNhYnNEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQsIEVjYWJzRGF0ZVJhbmdlUGlja2VySGVhZGVyQ29tcG9uZW50XSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEVjYWJzRGF0ZVJhbmdlTW9kdWxlIHt9XHJcbiJdfQ==
|
package/esm2022/lib/ecabs-dialog-confirm-deletion/ecabs-dialog-confirm-deletion.component.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';
|
|
2
|
-
import { Validators } from '@angular/forms';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Inject, } from '@angular/core';
|
|
2
|
+
import { Validators, } from '@angular/forms';
|
|
3
3
|
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
4
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -33,7 +33,7 @@ export class EcabsDialogConfirmationDeletionComponent {
|
|
|
33
33
|
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
34
34
|
.subscribe((config) => {
|
|
35
35
|
const { i18n } = config ?? {};
|
|
36
|
-
const { confirmLabel, cancelLabel
|
|
36
|
+
const { confirmLabel, cancelLabel } = this.data ?? {};
|
|
37
37
|
if (i18n) {
|
|
38
38
|
this.data.confirmLabel = confirmLabel || i18n?.confirmLabel;
|
|
39
39
|
this.data.cancelLabel = cancelLabel || i18n?.cancelLabel;
|
|
@@ -56,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
56
56
|
type: Inject,
|
|
57
57
|
args: [MAT_DIALOG_DATA]
|
|
58
58
|
}] }, { type: i2.UntypedFormBuilder }, { type: i3.EcabsComponentsService }, { type: i0.DestroyRef }]; } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtZGlhbG9nLWNvbmZpcm0tZGVsZXRpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWRpYWxvZy1jb25maXJtLWRlbGV0aW9uL2VjYWJzLWRpYWxvZy1jb25maXJtLWRlbGV0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1kaWFsb2ctY29uZmlybS1kZWxldGlvbi9lY2Ficy1kaWFsb2ctY29uZmlybS1kZWxldGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFFVCxNQUFNLEdBRVAsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUdMLFVBQVUsR0FDWCxNQUFNLGdCQUFnQixDQUFDO0FBRXhCLE9BQU8sRUFBRSxlQUFlLEVBQWdCLE1BQU0sMEJBQTBCLENBQUM7QUFFekUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7Ozs7O0FBUWhFLE1BQU0sT0FBTyx3Q0FBd0M7SUFLMUM7SUFDeUI7SUFDZjtJQUNBO0lBQ0E7SUFSbkIsSUFBSSxDQUFtQjtJQUN2QixLQUFLLEdBQWlCLE1BQU0sQ0FBQztJQUU3QixZQUNTLFNBQWlFLEVBQ3hDLElBQWtDLEVBQ2pELEVBQXNCLEVBQ3RCLGlCQUF5QyxFQUN6QyxVQUFzQjtRQUpoQyxjQUFTLEdBQVQsU0FBUyxDQUF3RDtRQUN4QyxTQUFJLEdBQUosSUFBSSxDQUE4QjtRQUNqRCxPQUFFLEdBQUYsRUFBRSxDQUFvQjtRQUN0QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQXdCO1FBQ3pDLGVBQVUsR0FBVixVQUFVLENBQVk7SUFDdEMsQ0FBQztJQUVKLFFBQVE7UUFDTixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDO1lBQ3hCLElBQUksRUFBRSxDQUFDLElBQUksRUFBRSxVQUFVLENBQUMsUUFBUSxDQUFDO1NBQ2xDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxpQkFBaUI7YUFDbkIsU0FBUyxFQUFFO2FBQ1gsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQzthQUN6QyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUNwQixNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsTUFBTSxJQUFJLEVBQUUsQ0FBQztZQUM5QixNQUFNLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxHQUFHLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDO1lBRXRELElBQUksSUFBSSxFQUFFO2dCQUNSLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxHQUFHLFlBQVksSUFBSSxJQUFJLEVBQUUsWUFBWSxDQUFDO2dCQUM1RCxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLElBQUksSUFBSSxFQUFFLFdBQVcsQ0FBQzthQUMxRDtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlCLENBQUM7d0dBckNVLHdDQUF3Qyw4Q0FNekMsZUFBZTs0RkFOZCx3Q0FBd0MscUVDdkJyRCw2dENBb0NBOzs0RkRiYSx3Q0FBd0M7a0JBTnBELFNBQVM7K0JBQ0UsK0JBQStCLG1CQUd4Qix1QkFBdUIsQ0FBQyxNQUFNOzswQkFRNUMsTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBDb21wb25lbnQsXHJcbiAgRGVzdHJveVJlZixcclxuICBJbmplY3QsXHJcbiAgT25Jbml0LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1xyXG4gIFVudHlwZWRGb3JtQnVpbGRlcixcclxuICBVbnR5cGVkRm9ybUdyb3VwLFxyXG4gIFZhbGlkYXRvcnMsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBUaGVtZVBhbGV0dGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcclxuaW1wb3J0IHsgTUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWYgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBFY2Fic0NvbXBvbmVudHNTZXJ2aWNlIH0gZnJvbSAnLi4vYmFzZS9zZXJ2aWNlcy9lY2Ficy1jb21wb25lbnRzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2VjYWJzLWRpYWxvZy1jb25maXJtLWRlbGV0aW9uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZWNhYnMtZGlhbG9nLWNvbmZpcm0tZGVsZXRpb24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2VjYWJzLWRpYWxvZy1jb25maXJtLWRlbGV0aW9uLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFY2Fic0RpYWxvZ0NvbmZpcm1hdGlvbkRlbGV0aW9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICBmb3JtOiBVbnR5cGVkRm9ybUdyb3VwO1xyXG4gIGNvbG9yOiBUaGVtZVBhbGV0dGUgPSAnd2Fybic7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPEVjYWJzRGlhbG9nQ29uZmlybWF0aW9uRGVsZXRpb25Db21wb25lbnQ+LFxyXG4gICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBFY2Fic0RlbGV0ZUNvbmZpcm1hdGlvbk1vZGFsLFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBmYjogVW50eXBlZEZvcm1CdWlsZGVyLFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb21wb25lbnRzU2VydmljZTogRWNhYnNDb21wb25lbnRzU2VydmljZSxcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgZGVzdHJveVJlZjogRGVzdHJveVJlZixcclxuICApIHt9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5mb3JtID0gdGhpcy5mYi5ncm91cCh7XHJcbiAgICAgIG5hbWU6IFtudWxsLCBWYWxpZGF0b3JzLnJlcXVpcmVkXSxcclxuICAgIH0pO1xyXG5cclxuICAgIHRoaXMuY29tcG9uZW50c1NlcnZpY2VcclxuICAgICAgLmdldENvbmZpZygpXHJcbiAgICAgIC5waXBlKHRha2VVbnRpbERlc3Ryb3llZCh0aGlzLmRlc3Ryb3lSZWYpKVxyXG4gICAgICAuc3Vic2NyaWJlKChjb25maWcpID0+IHtcclxuICAgICAgICBjb25zdCB7IGkxOG4gfSA9IGNvbmZpZyA/PyB7fTtcclxuICAgICAgICBjb25zdCB7IGNvbmZpcm1MYWJlbCwgY2FuY2VsTGFiZWwgfSA9IHRoaXMuZGF0YSA/PyB7fTtcclxuXHJcbiAgICAgICAgaWYgKGkxOG4pIHtcclxuICAgICAgICAgIHRoaXMuZGF0YS5jb25maXJtTGFiZWwgPSBjb25maXJtTGFiZWwgfHwgaTE4bj8uY29uZmlybUxhYmVsO1xyXG4gICAgICAgICAgdGhpcy5kYXRhLmNhbmNlbExhYmVsID0gY2FuY2VsTGFiZWwgfHwgaTE4bj8uY2FuY2VsTGFiZWw7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KTtcclxuICB9XHJcblxyXG4gIG9uQ29uZmlybSgpOiB2b2lkIHtcclxuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKHRydWUpO1xyXG4gIH1cclxuXHJcbiAgb25DYW5jZWwoKTogdm9pZCB7XHJcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZShmYWxzZSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEVjYWJzRGVsZXRlQ29uZmlybWF0aW9uTW9kYWwge1xyXG4gIGFjdGlvbk5hbWU/OiBzdHJpbmc7XHJcbiAgYWxlcnRUZXh0Pzogc3RyaW5nO1xyXG4gIGNvbG9yPzogVGhlbWVQYWxldHRlO1xyXG4gIGNvbXBhcmlzb25UZXh0Pzogc3RyaW5nO1xyXG4gIGNvbmZpcm1MYWJlbD86IHN0cmluZztcclxuICBjYW5jZWxMYWJlbD86IHN0cmluZztcclxuICBlbnRpdHlOYW1lPzogc3RyaW5nO1xyXG4gIGVudGl0eU5hbWVMYWJlbD86IHN0cmluZztcclxuICBlbnRpdHlOYW1lUGxhY2Vob2xkZXI/OiBzdHJpbmc7XHJcbiAgc2hvd0VudGl0eU5hbWVJbkhlYWRlcj86IGJvb2xlYW47XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cInAtNlwiPlxyXG4gIDxoMyBjbGFzcz1cIm1vZGFsLXRpdGxlIGZvbnQtc2VtaWJvbGRcIiBbbmdDbGFzc109XCIoZGF0YT8uY29sb3IgfHwgY29sb3IpID09PSAncHJpbWFyeScgPyAncHJpbWFyeScgOiAnd2FybidcIj5cclxuICAgIHt7IGRhdGEuYWN0aW9uTmFtZSB9fSB7eyBkYXRhLnNob3dFbnRpdHlOYW1lSW5IZWFkZXIgPyAoZGF0YS5lbnRpdHlOYW1lIHwgbG93ZXJjYXNlKSA6ICcnIH19XHJcbiAgPC9oMz5cclxuICA8ZGl2IGNsYXNzPVwibXQtMVwiPlxyXG4gICAgPGRpdiBjbGFzcz1cImFsZXJ0LWl0ZW1cIiAqbmdJZj1cImRhdGEuYWxlcnRUZXh0ICYmIGRhdGEuYWxlcnRUZXh0Lmxlbmd0aCA+IDBcIj5cclxuICAgICAgPHNwYW4gY2xhc3M9XCJhbGVydC10ZXh0XCI+XHJcbiAgICAgICAge3sgZGF0YS5hbGVydFRleHQgfX1cclxuICAgICAgPC9zcGFuPlxyXG4gICAgPC9kaXY+XHJcblxyXG4gICAgPGZvcm0gW2Zvcm1Hcm91cF09XCJmb3JtXCIgY2xhc3M9XCJtdC0xXCI+XHJcbiAgICAgIDxlY2Ficy1pbnB1dFxyXG4gICAgICAgIFtwbGFjZWhvbGRlcl09XCJkYXRhLmVudGl0eU5hbWVQbGFjZWhvbGRlclwiXHJcbiAgICAgICAgW2xhYmVsXT1cImRhdGEuZW50aXR5TmFtZUxhYmVsXCJcclxuICAgICAgICBuYW1lPVwibmFtZVwiXHJcbiAgICAgICAgZm9ybUNvbnRyb2xOYW1lPVwibmFtZVwiXHJcbiAgICAgID48L2VjYWJzLWlucHV0PlxyXG4gICAgPC9mb3JtPlxyXG4gIDwvZGl2PlxyXG5cclxuICA8ZGl2IGNsYXNzPVwiYnRuX19ncm91cCBmbGV4IGZsZXgtcm93IGdhcC14LTQganVzdGlmeS1lbmRcIj5cclxuICAgIDxlY2Ficy1idXR0b25zIGNsYXNzPVwiZ3Jvd1wiIFtzdHlsZV09XCInc3Ryb2tlZCdcIiAoY2xpY2spPVwib25DYW5jZWwoKVwiPlxyXG4gICAgICB7eyBkYXRhPy5jYW5jZWxMYWJlbCB9fVxyXG4gICAgPC9lY2Ficy1idXR0b25zPlxyXG5cclxuICAgIDxlY2Ficy1idXR0b25zXHJcbiAgICAgIGNsYXNzPVwiZ3Jvd1wiXHJcbiAgICAgIFtjb2xvcl09XCJkYXRhPy5jb2xvciB8fCBjb2xvclwiXHJcbiAgICAgIChjbGljayk9XCJvbkNvbmZpcm0oKVwiXHJcbiAgICAgIFtkaXNhYmxlZF09XCJmb3JtLnZhbHVlLm5hbWUgIT09IGRhdGEuY29tcGFyaXNvblRleHRcIlxyXG4gICAgPlxyXG4gICAgICB7eyBkYXRhPy5jb25maXJtTGFiZWwgfX1cclxuICAgIDwvZWNhYnMtYnV0dG9ucz5cclxuICA8L2Rpdj5cclxuPC9kaXY+XHJcbiJdfQ==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';
|
|
3
3
|
import EcabsElementBaseComponent from '../base/element-base';
|
|
4
|
+
import { MatRadioGroup } from '@angular/material/radio';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/common";
|
|
6
7
|
import * as i2 from "../base/element-wrapper/element-wrapper.component";
|
|
@@ -8,6 +9,7 @@ import * as i3 from "@angular/material/radio";
|
|
|
8
9
|
import * as i4 from "@angular/forms";
|
|
9
10
|
export class EcabsRadioButtonListComponent extends EcabsElementBaseComponent {
|
|
10
11
|
injector;
|
|
12
|
+
matRadioGroup;
|
|
11
13
|
items;
|
|
12
14
|
direction = 'horizontal';
|
|
13
15
|
changed = new EventEmitter();
|
|
@@ -50,7 +52,7 @@ export class EcabsRadioButtonListComponent extends EcabsElementBaseComponent {
|
|
|
50
52
|
useExisting: EcabsRadioButtonListComponent,
|
|
51
53
|
multi: true,
|
|
52
54
|
},
|
|
53
|
-
], usesInheritance: true, ngImport: i0, template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <mat-radio-group\r\n [ngClass]=\"{ 'flex flex-col my-1': direction === 'vertical' }\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [id]=\"name\"\r\n (change)=\"changed.emit($event
|
|
55
|
+
], viewQueries: [{ propertyName: "matRadioGroup", first: true, predicate: MatRadioGroup, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <mat-radio-group\r\n [ngClass]=\"{ 'flex flex-col my-1': direction === 'vertical' }\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [id]=\"name\"\r\n [name]=\"name\"\r\n (change)=\"changed.emit($event)\"\r\n >\r\n <mat-radio-button\r\n [disabled]=\"item.disabled\"\r\n [ngClass]=\"{ 'my-1': direction === 'vertical' }\"\r\n class=\"mr-4\"\r\n *ngFor=\"let item of items\"\r\n [value]=\"item.value\"\r\n >\r\n {{ item.label }}\r\n </mat-radio-button>\r\n </mat-radio-group>\r\n</ecabs-element-wrapper>\r\n", styles: [".mr-4{margin-right:1rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.flex{display:flex}.flex-col{flex-direction:column}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.EcabsElementWrapperComponent, selector: "ecabs-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "directive", type: i3.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i3.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
54
56
|
}
|
|
55
57
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsRadioButtonListComponent, decorators: [{
|
|
56
58
|
type: Component,
|
|
@@ -60,12 +62,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
60
62
|
useExisting: EcabsRadioButtonListComponent,
|
|
61
63
|
multi: true,
|
|
62
64
|
},
|
|
63
|
-
], template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <mat-radio-group\r\n [ngClass]=\"{ 'flex flex-col my-1': direction === 'vertical' }\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [id]=\"name\"\r\n (change)=\"changed.emit($event
|
|
64
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: {
|
|
65
|
+
], template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <mat-radio-group\r\n [ngClass]=\"{ 'flex flex-col my-1': direction === 'vertical' }\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [id]=\"name\"\r\n [name]=\"name\"\r\n (change)=\"changed.emit($event)\"\r\n >\r\n <mat-radio-button\r\n [disabled]=\"item.disabled\"\r\n [ngClass]=\"{ 'my-1': direction === 'vertical' }\"\r\n class=\"mr-4\"\r\n *ngFor=\"let item of items\"\r\n [value]=\"item.value\"\r\n >\r\n {{ item.label }}\r\n </mat-radio-button>\r\n </mat-radio-group>\r\n</ecabs-element-wrapper>\r\n", styles: [".mr-4{margin-right:1rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.flex{display:flex}.flex-col{flex-direction:column}\n"] }]
|
|
66
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { matRadioGroup: [{
|
|
67
|
+
type: ViewChild,
|
|
68
|
+
args: [MatRadioGroup, { static: false }]
|
|
69
|
+
}], items: [{
|
|
65
70
|
type: Input
|
|
66
71
|
}], direction: [{
|
|
67
72
|
type: Input
|
|
68
73
|
}], changed: [{
|
|
69
74
|
type: Output
|
|
70
75
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtcmFkaW8tYnV0dG9uLWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLXJhZGlvLWJ1dHRvbi1saXN0L2VjYWJzLXJhZGlvLWJ1dHRvbi1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1yYWRpby1idXR0b24tbGlzdC9lY2Ficy1yYWRpby1idXR0b24tbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFFWixLQUFLLEVBQ0wsTUFBTSxFQUNOLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBRUwsaUJBQWlCLEVBQ2pCLFNBQVMsR0FFVixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8seUJBQXlCLE1BQU0sc0JBQXNCLENBQUM7QUFFN0QsT0FBTyxFQUFrQixhQUFhLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7Ozs7O0FBY3hFLE1BQU0sT0FBTyw2QkFDWCxTQUFRLHlCQUF5QjtJQTZCYjtJQXpCcEIsYUFBYSxDQUFnQjtJQUc3QixLQUFLLENBQWlCO0lBR3RCLFNBQVMsR0FBOEIsWUFBWSxDQUFDO0lBRzNDLE9BQU8sR0FBRyxJQUFJLFlBQVksRUFBa0IsQ0FBQztJQUV0RCxHQUFHLENBQVM7SUFFWixJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUM7SUFDbEIsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLEdBQUc7UUFDWCxJQUFJLEdBQUcsS0FBSyxTQUFTLElBQUksSUFBSSxDQUFDLEdBQUcsS0FBSyxHQUFHLEVBQUU7WUFDekMsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7WUFDZixJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ25CLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDbkI7SUFDSCxDQUFDO0lBRUQsWUFBb0IsUUFBa0I7UUFDcEMsS0FBSyxFQUFFLENBQUM7UUFEVSxhQUFRLEdBQVIsUUFBUSxDQUFVO0lBRXRDLENBQUM7SUFFRCxRQUFRLEdBQVEsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO0lBQ3pCLE9BQU8sR0FBUSxHQUFHLEVBQUUsR0FBRSxDQUFDLENBQUM7SUFFeEIsZUFBZTtRQUNiLE1BQU0sU0FBUyxHQUFjLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNoRSxJQUFJLFNBQVMsRUFBRTtZQUNiLElBQUksQ0FBQyxPQUFPLEdBQUcsU0FBUyxDQUFDLE9BQTZCLENBQUM7U0FDeEQ7SUFDSCxDQUFDO0lBRUQsVUFBVSxDQUFDLEtBQVU7UUFDbkIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQzt3R0F0RFUsNkJBQTZCOzRGQUE3Qiw2QkFBNkIsdUlBUjdCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLDZCQUE2QjtnQkFDMUMsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLHlFQU1VLGFBQWEsdUVDbkMxQixtbkJBb0JBOzs0RkRXYSw2QkFBNkI7a0JBWnpDLFNBQVM7K0JBQ0UseUJBQXlCLGFBR3hCO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsK0JBQStCOzRCQUMxQyxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRjsrRkFPRCxhQUFhO3NCQURaLFNBQVM7dUJBQUMsYUFBYSxFQUFFLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRTtnQkFJM0MsS0FBSztzQkFESixLQUFLO2dCQUlOLFNBQVM7c0JBRFIsS0FBSztnQkFJRyxPQUFPO3NCQURmLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIEFmdGVyVmlld0luaXQsXHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBJbmplY3RvcixcclxuICBJbnB1dCxcclxuICBPdXRwdXQsXHJcbiAgVmlld0NoaWxkLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1xyXG4gIENvbnRyb2xWYWx1ZUFjY2Vzc29yLFxyXG4gIE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gIE5nQ29udHJvbCxcclxuICBVbnR5cGVkRm9ybUNvbnRyb2wsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgRWNhYnNFbGVtZW50QmFzZUNvbXBvbmVudCBmcm9tICcuLi9iYXNlL2VsZW1lbnQtYmFzZSc7XHJcbmltcG9ydCB7IFNlbGVjdE9wdGlvbiB9IGZyb20gJy4uL2Jhc2UvbW9kZWxzL3NlbGVjdC5tb2RlbHMnO1xyXG5pbXBvcnQgeyBNYXRSYWRpb0NoYW5nZSwgTWF0UmFkaW9Hcm91cCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3JhZGlvJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZWNhYnMtcmFkaW8tYnV0dG9uLWxpc3QnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9lY2Ficy1yYWRpby1idXR0b24tbGlzdC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJ2VjYWJzLXJhZGlvLWJ1dHRvbi1saXN0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICB1c2VFeGlzdGluZzogRWNhYnNSYWRpb0J1dHRvbkxpc3RDb21wb25lbnQsXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgfSxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNSYWRpb0J1dHRvbkxpc3RDb21wb25lbnRcclxuICBleHRlbmRzIEVjYWJzRWxlbWVudEJhc2VDb21wb25lbnRcclxuICBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBBZnRlclZpZXdJbml0XHJcbntcclxuICBAVmlld0NoaWxkKE1hdFJhZGlvR3JvdXAsIHsgc3RhdGljOiBmYWxzZSB9KVxyXG4gIG1hdFJhZGlvR3JvdXA6IE1hdFJhZGlvR3JvdXA7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgaXRlbXM6IFNlbGVjdE9wdGlvbltdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIGRpcmVjdGlvbjogJ2hvcml6b250YWwnIHwgJ3ZlcnRpY2FsJyA9ICdob3Jpem9udGFsJztcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcmVhZG9ubHkgY2hhbmdlZCA9IG5ldyBFdmVudEVtaXR0ZXI8TWF0UmFkaW9DaGFuZ2U+KCk7XHJcblxyXG4gIHZhbDogc3RyaW5nO1xyXG5cclxuICBnZXQgdmFsdWUoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLnZhbDtcclxuICB9XHJcblxyXG4gIHNldCB2YWx1ZSh2YWwpIHtcclxuICAgIGlmICh2YWwgIT09IHVuZGVmaW5lZCAmJiB0aGlzLnZhbCAhPT0gdmFsKSB7XHJcbiAgICAgIHRoaXMudmFsID0gdmFsO1xyXG4gICAgICB0aGlzLm9uQ2hhbmdlKHZhbCk7XHJcbiAgICAgIHRoaXMub25Ub3VjaCh2YWwpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBpbmplY3RvcjogSW5qZWN0b3IpIHtcclxuICAgIHN1cGVyKCk7XHJcbiAgfVxyXG5cclxuICBvbkNoYW5nZTogYW55ID0gKCkgPT4ge307XHJcbiAgb25Ub3VjaDogYW55ID0gKCkgPT4ge307XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcclxuICAgIGNvbnN0IG5nQ29udHJvbDogTmdDb250cm9sID0gdGhpcy5pbmplY3Rvci5nZXQoTmdDb250cm9sLCBudWxsKTtcclxuICAgIGlmIChuZ0NvbnRyb2wpIHtcclxuICAgICAgdGhpcy5jb250cm9sID0gbmdDb250cm9sLmNvbnRyb2wgYXMgVW50eXBlZEZvcm1Db250cm9sO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgd3JpdGVWYWx1ZSh2YWx1ZTogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XHJcbiAgfVxyXG5cclxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcclxuICB9XHJcblxyXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMub25Ub3VjaCA9IGZuO1xyXG4gIH1cclxufVxyXG4iLCI8ZWNhYnMtZWxlbWVudC13cmFwcGVyIFtkYXRhXT1cImdldERhdGEoKVwiPlxyXG4gIDxtYXQtcmFkaW8tZ3JvdXBcclxuICAgIFtuZ0NsYXNzXT1cInsgJ2ZsZXggZmxleC1jb2wgbXktMSc6IGRpcmVjdGlvbiA9PT0gJ3ZlcnRpY2FsJyB9XCJcclxuICAgIFsobmdNb2RlbCldPVwidmFsdWVcIlxyXG4gICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgIFtpZF09XCJuYW1lXCJcclxuICAgIFtuYW1lXT1cIm5hbWVcIlxyXG4gICAgKGNoYW5nZSk9XCJjaGFuZ2VkLmVtaXQoJGV2ZW50KVwiXHJcbiAgPlxyXG4gICAgPG1hdC1yYWRpby1idXR0b25cclxuICAgICAgW2Rpc2FibGVkXT1cIml0ZW0uZGlzYWJsZWRcIlxyXG4gICAgICBbbmdDbGFzc109XCJ7ICdteS0xJzogZGlyZWN0aW9uID09PSAndmVydGljYWwnIH1cIlxyXG4gICAgICBjbGFzcz1cIm1yLTRcIlxyXG4gICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiBpdGVtc1wiXHJcbiAgICAgIFt2YWx1ZV09XCJpdGVtLnZhbHVlXCJcclxuICAgID5cclxuICAgICAge3sgaXRlbS5sYWJlbCB9fVxyXG4gICAgPC9tYXQtcmFkaW8tYnV0dG9uPlxyXG4gIDwvbWF0LXJhZGlvLWdyb3VwPlxyXG48L2VjYWJzLWVsZW1lbnQtd3JhcHBlcj5cclxuIl19
|