ecabs-components 1.1.66 → 1.1.68

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.
@@ -23,6 +23,7 @@ export class EcabsTimeRangeInputV2Component extends EcabsElementBaseComponent {
23
23
  separatorLabel = 'to';
24
24
  startTimePlaceholder;
25
25
  endTimePlaceholder;
26
+ allowCrossMidnight = false;
26
27
  val;
27
28
  _timeFrom;
28
29
  _timeTo;
@@ -71,6 +72,9 @@ export class EcabsTimeRangeInputV2Component extends EcabsElementBaseComponent {
71
72
  this.control.valueChanges
72
73
  .pipe(takeUntilDestroyed(this.destroyRef))
73
74
  .subscribe(() => this.timeRangeValidator(this.control));
75
+ setTimeout(() => {
76
+ this.timeRangeValidator(this.control);
77
+ });
74
78
  }
75
79
  }
76
80
  onChange = () => { };
@@ -98,31 +102,35 @@ export class EcabsTimeRangeInputV2Component extends EcabsElementBaseComponent {
98
102
  }
99
103
  timeRangeValidator(control) {
100
104
  const required = control.hasValidator(Validators.required);
101
- if (control.value) {
102
- const { timeFrom, timeTo } = control.value;
103
- control.setErrors(null);
104
- if (required &&
105
- (!timeFrom || timeFrom?.length === 0) &&
106
- (!timeTo || timeTo?.length === 0)) {
107
- control.setErrors({ required: true });
108
- return;
109
- }
110
- if (!timeFrom && timeTo) {
111
- control.setErrors({ timeFromRangeRequired: true });
112
- return;
113
- }
114
- if (timeFrom && !timeTo) {
115
- control.setErrors({ timeToRangeRequired: true });
116
- return;
117
- }
118
- if (timeFrom > timeTo) {
119
- control.setErrors({ timeFromMoreThanTimeTo: true });
120
- return;
121
- }
105
+ if (!control.value && !required) {
106
+ return;
107
+ }
108
+ if (!control.value) {
109
+ control.setErrors({ required: true });
110
+ return;
111
+ }
112
+ const { timeFrom, timeTo } = control.value;
113
+ control.setErrors(null);
114
+ if (required &&
115
+ (!timeFrom || timeFrom?.length === 0) &&
116
+ (!timeTo || timeTo?.length === 0)) {
117
+ control.setErrors({ required: true });
118
+ }
119
+ else if (!timeFrom && timeTo) {
120
+ control.setErrors({ rangeFrom: true });
121
+ }
122
+ else if (timeFrom && !timeTo) {
123
+ control.setErrors({ rangeTo: true });
124
+ }
125
+ else if (timeFrom &&
126
+ timeTo &&
127
+ timeFrom > timeTo &&
128
+ !this.allowCrossMidnight) {
129
+ control.setErrors({ rangeOrder: true });
122
130
  }
123
131
  }
124
132
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsTimeRangeInputV2Component, deps: [{ token: i0.Injector }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Component });
125
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsTimeRangeInputV2Component, selector: "ecabs-time-range-input-v2", inputs: { showCloseIcon: "showCloseIcon", listPlacement: "listPlacement", appendTo: "appendTo", min: "min", max: "max", showDayStart: "showDayStart", showDayEnd: "showDayEnd", addSecond: "addSecond", dayStartLabel: "dayStartLabel", dayEndLabel: "dayEndLabel", separatorLabel: "separatorLabel", startTimePlaceholder: "startTimePlaceholder", endTimePlaceholder: "endTimePlaceholder" }, providers: [
133
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsTimeRangeInputV2Component, selector: "ecabs-time-range-input-v2", inputs: { showCloseIcon: "showCloseIcon", listPlacement: "listPlacement", appendTo: "appendTo", min: "min", max: "max", showDayStart: "showDayStart", showDayEnd: "showDayEnd", addSecond: "addSecond", dayStartLabel: "dayStartLabel", dayEndLabel: "dayEndLabel", separatorLabel: "separatorLabel", startTimePlaceholder: "startTimePlaceholder", endTimePlaceholder: "endTimePlaceholder", allowCrossMidnight: "allowCrossMidnight" }, providers: [
126
134
  {
127
135
  provide: NG_VALUE_ACCESSOR,
128
136
  useExisting: forwardRef(() => EcabsTimeRangeInputV2Component),
@@ -165,5 +173,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
165
173
  type: Input
166
174
  }], endTimePlaceholder: [{
167
175
  type: Input
176
+ }], allowCrossMidnight: [{
177
+ type: Input
168
178
  }] } });
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-time-range-input-v2.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-time-range-input-v2/ecabs-time-range-input-v2.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-time-range-input-v2/ecabs-time-range-input-v2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  DestroyRef,\r\n  forwardRef,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport { ListPlacement } from '../base/models/timepicker.models';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { isEqual as lodashIsEqual } from 'lodash';\r\n\r\n@Component({\r\n  selector: 'ecabs-time-range-input-v2',\r\n  templateUrl: './ecabs-time-range-input-v2.component.html',\r\n  styleUrls: ['ecabs-time-range-input-v2.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => EcabsTimeRangeInputV2Component),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class EcabsTimeRangeInputV2Component\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit\r\n{\r\n  @Input()\r\n  showCloseIcon = false;\r\n\r\n  @Input()\r\n  listPlacement: ListPlacement = 'auto';\r\n\r\n  @Input()\r\n  appendTo!: string;\r\n\r\n  @Input()\r\n  min!: string;\r\n\r\n  @Input()\r\n  max!: string;\r\n\r\n  @Input()\r\n  showDayStart = true;\r\n\r\n  @Input()\r\n  showDayEnd = false;\r\n\r\n  @Input()\r\n  addSecond = true;\r\n\r\n  @Input()\r\n  dayStartLabel: string;\r\n\r\n  @Input()\r\n  dayEndLabel: string;\r\n\r\n  @Input()\r\n  separatorLabel = 'to';\r\n\r\n  @Input()\r\n  startTimePlaceholder: string;\r\n\r\n  @Input()\r\n  endTimePlaceholder: string;\r\n\r\n  val: {\r\n    timeFrom: string;\r\n    timeTo: string;\r\n  };\r\n\r\n  _timeFrom: string;\r\n  _timeTo: string;\r\n\r\n  get value(): {\r\n    timeFrom: string;\r\n    timeTo: string;\r\n  } {\r\n    return this.val;\r\n  }\r\n\r\n  get timeFrom(): string {\r\n    return this._timeFrom;\r\n  }\r\n\r\n  get timeTo(): string {\r\n    return this._timeTo;\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set value(val: { timeFrom: string; timeTo: string }) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.timeFrom = val.timeFrom;\r\n      this.timeTo = val.timeTo;\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 timeFrom(val: string) {\r\n    if (this._timeFrom !== val) {\r\n      this._timeFrom = val;\r\n      this.onApply();\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set timeTo(val: string) {\r\n    if (this._timeTo !== val) {\r\n      this._timeTo = val;\r\n      this.onApply();\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly destroyRef: DestroyRef,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(NgControl, null);\r\n\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n      this.control.valueChanges\r\n        .pipe(takeUntilDestroyed(this.destroyRef))\r\n        .subscribe(() => this.timeRangeValidator(this.control));\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  onApply(): void {\r\n    const newValue = {\r\n      timeFrom: this.timeFrom,\r\n      timeTo: this.timeTo,\r\n    };\r\n\r\n    if (!lodashIsEqual(this.value, newValue)) {\r\n      this.value = {\r\n        timeFrom: this.timeFrom,\r\n        timeTo: this.timeTo,\r\n      };\r\n    }\r\n  }\r\n\r\n  timeRangeValidator(control: UntypedFormControl) {\r\n    const required = control.hasValidator(Validators.required);\r\n\r\n    if (control.value) {\r\n      const { timeFrom, timeTo } = control.value;\r\n      control.setErrors(null);\r\n\r\n      if (\r\n        required &&\r\n        (!timeFrom || timeFrom?.length === 0) &&\r\n        (!timeTo || timeTo?.length === 0)\r\n      ) {\r\n        control.setErrors({ required: true });\r\n\r\n        return;\r\n      }\r\n\r\n      if (!timeFrom && timeTo) {\r\n        control.setErrors({ timeFromRangeRequired: true });\r\n\r\n        return;\r\n      }\r\n\r\n      if (timeFrom && !timeTo) {\r\n        control.setErrors({ timeToRangeRequired: true });\r\n\r\n        return;\r\n      }\r\n\r\n      if (timeFrom > timeTo) {\r\n        control.setErrors({ timeFromMoreThanTimeTo: true });\r\n\r\n        return;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__range--wrapper\">\r\n    <div class=\"form-field__range\">\r\n      <ecabs-timepicker \r\n      [label]=\"startTimePlaceholder\" \r\n      [(ngModel)]=\"timeFrom\" \r\n      [dayStartLabel]=\"dayStartLabel\" \r\n      [dayEndLabel]=\"dayEndLabel\">\r\n      </ecabs-timepicker>\r\n    </div>\r\n\r\n    <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n    <div class=\"form-field__range\">\r\n      <ecabs-timepicker \r\n      [label]=\"endTimePlaceholder\" \r\n      [(ngModel)]=\"timeTo\" \r\n      [dayStartLabel]=\"dayStartLabel\"\r\n       [dayEndLabel]=\"dayEndLabel\">\r\n      </ecabs-timepicker>\r\n    </div>\r\n  </div>\r\n</ecabs-element-wrapper>"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-time-range-input-v2.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-time-range-input-v2/ecabs-time-range-input-v2.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-time-range-input-v2/ecabs-time-range-input-v2.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  DestroyRef,\r\n  forwardRef,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  UntypedFormControl,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport EcabsElementBaseComponent from '../base/element-base';\r\nimport { ListPlacement } from '../base/models/timepicker.models';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { isEqual as lodashIsEqual } from 'lodash';\r\n\r\n@Component({\r\n  selector: 'ecabs-time-range-input-v2',\r\n  templateUrl: './ecabs-time-range-input-v2.component.html',\r\n  styleUrls: ['ecabs-time-range-input-v2.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => EcabsTimeRangeInputV2Component),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class EcabsTimeRangeInputV2Component\r\n  extends EcabsElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit\r\n{\r\n  @Input()\r\n  showCloseIcon = false;\r\n\r\n  @Input()\r\n  listPlacement: ListPlacement = 'auto';\r\n\r\n  @Input()\r\n  appendTo!: string;\r\n\r\n  @Input()\r\n  min!: string;\r\n\r\n  @Input()\r\n  max!: string;\r\n\r\n  @Input()\r\n  showDayStart = true;\r\n\r\n  @Input()\r\n  showDayEnd = false;\r\n\r\n  @Input()\r\n  addSecond = true;\r\n\r\n  @Input()\r\n  dayStartLabel: string;\r\n\r\n  @Input()\r\n  dayEndLabel: string;\r\n\r\n  @Input()\r\n  separatorLabel = 'to';\r\n\r\n  @Input()\r\n  startTimePlaceholder: string;\r\n\r\n  @Input()\r\n  endTimePlaceholder: string;\r\n\r\n  @Input()\r\n  allowCrossMidnight = false;\r\n\r\n  val: {\r\n    timeFrom: string;\r\n    timeTo: string;\r\n  };\r\n\r\n  _timeFrom: string;\r\n  _timeTo: string;\r\n\r\n  get value(): {\r\n    timeFrom: string;\r\n    timeTo: string;\r\n  } {\r\n    return this.val;\r\n  }\r\n\r\n  get timeFrom(): string {\r\n    return this._timeFrom;\r\n  }\r\n\r\n  get timeTo(): string {\r\n    return this._timeTo;\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set value(val: { timeFrom: string; timeTo: string }) {\r\n    if (this.val !== val) {\r\n      this.val = val;\r\n      this.timeFrom = val.timeFrom;\r\n      this.timeTo = val.timeTo;\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 timeFrom(val: string) {\r\n    if (this._timeFrom !== val) {\r\n      this._timeFrom = val;\r\n      this.onApply();\r\n    }\r\n  }\r\n\r\n  //eslint-disable-next-line\r\n  set timeTo(val: string) {\r\n    if (this._timeTo !== val) {\r\n      this._timeTo = val;\r\n      this.onApply();\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly destroyRef: DestroyRef,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(NgControl, null);\r\n\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n      this.control.valueChanges\r\n        .pipe(takeUntilDestroyed(this.destroyRef))\r\n        .subscribe(() => this.timeRangeValidator(this.control));\r\n      setTimeout(() => {\r\n        this.timeRangeValidator(this.control);\r\n      });\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  onApply(): void {\r\n    const newValue = {\r\n      timeFrom: this.timeFrom,\r\n      timeTo: this.timeTo,\r\n    };\r\n\r\n    if (!lodashIsEqual(this.value, newValue)) {\r\n      this.value = {\r\n        timeFrom: this.timeFrom,\r\n        timeTo: this.timeTo,\r\n      };\r\n    }\r\n  }\r\n\r\n  timeRangeValidator(control: UntypedFormControl) {\r\n    const required = control.hasValidator(Validators.required);\r\n\r\n    if (!control.value && !required) {\r\n      return;\r\n    }\r\n\r\n    if (!control.value) {\r\n      control.setErrors({ required: true });\r\n\r\n      return;\r\n    }\r\n\r\n    const { timeFrom, timeTo } = control.value;\r\n    control.setErrors(null);\r\n\r\n    if (\r\n      required &&\r\n      (!timeFrom || timeFrom?.length === 0) &&\r\n      (!timeTo || timeTo?.length === 0)\r\n    ) {\r\n      control.setErrors({ required: true });\r\n    } else if (!timeFrom && timeTo) {\r\n      control.setErrors({ rangeFrom: true });\r\n    } else if (timeFrom && !timeTo) {\r\n      control.setErrors({ rangeTo: true });\r\n    } else if (\r\n      timeFrom &&\r\n      timeTo &&\r\n      timeFrom > timeTo &&\r\n      !this.allowCrossMidnight\r\n    ) {\r\n      control.setErrors({ rangeOrder: true });\r\n    }\r\n  }\r\n}\r\n","<ecabs-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__range--wrapper\">\r\n    <div class=\"form-field__range\">\r\n      <ecabs-timepicker \r\n      [label]=\"startTimePlaceholder\" \r\n      [(ngModel)]=\"timeFrom\" \r\n      [dayStartLabel]=\"dayStartLabel\" \r\n      [dayEndLabel]=\"dayEndLabel\">\r\n      </ecabs-timepicker>\r\n    </div>\r\n\r\n    <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n    <div class=\"form-field__range\">\r\n      <ecabs-timepicker \r\n      [label]=\"endTimePlaceholder\" \r\n      [(ngModel)]=\"timeTo\" \r\n      [dayStartLabel]=\"dayStartLabel\"\r\n       [dayEndLabel]=\"dayEndLabel\">\r\n      </ecabs-timepicker>\r\n    </div>\r\n  </div>\r\n</ecabs-element-wrapper>"]}
@@ -8688,6 +8688,7 @@ class EcabsTimeRangeInputV2Component extends EcabsElementBaseComponent {
8688
8688
  separatorLabel = 'to';
8689
8689
  startTimePlaceholder;
8690
8690
  endTimePlaceholder;
8691
+ allowCrossMidnight = false;
8691
8692
  val;
8692
8693
  _timeFrom;
8693
8694
  _timeTo;
@@ -8736,6 +8737,9 @@ class EcabsTimeRangeInputV2Component extends EcabsElementBaseComponent {
8736
8737
  this.control.valueChanges
8737
8738
  .pipe(takeUntilDestroyed(this.destroyRef))
8738
8739
  .subscribe(() => this.timeRangeValidator(this.control));
8740
+ setTimeout(() => {
8741
+ this.timeRangeValidator(this.control);
8742
+ });
8739
8743
  }
8740
8744
  }
8741
8745
  onChange = () => { };
@@ -8763,31 +8767,35 @@ class EcabsTimeRangeInputV2Component extends EcabsElementBaseComponent {
8763
8767
  }
8764
8768
  timeRangeValidator(control) {
8765
8769
  const required = control.hasValidator(Validators.required);
8766
- if (control.value) {
8767
- const { timeFrom, timeTo } = control.value;
8768
- control.setErrors(null);
8769
- if (required &&
8770
- (!timeFrom || timeFrom?.length === 0) &&
8771
- (!timeTo || timeTo?.length === 0)) {
8772
- control.setErrors({ required: true });
8773
- return;
8774
- }
8775
- if (!timeFrom && timeTo) {
8776
- control.setErrors({ timeFromRangeRequired: true });
8777
- return;
8778
- }
8779
- if (timeFrom && !timeTo) {
8780
- control.setErrors({ timeToRangeRequired: true });
8781
- return;
8782
- }
8783
- if (timeFrom > timeTo) {
8784
- control.setErrors({ timeFromMoreThanTimeTo: true });
8785
- return;
8786
- }
8770
+ if (!control.value && !required) {
8771
+ return;
8772
+ }
8773
+ if (!control.value) {
8774
+ control.setErrors({ required: true });
8775
+ return;
8776
+ }
8777
+ const { timeFrom, timeTo } = control.value;
8778
+ control.setErrors(null);
8779
+ if (required &&
8780
+ (!timeFrom || timeFrom?.length === 0) &&
8781
+ (!timeTo || timeTo?.length === 0)) {
8782
+ control.setErrors({ required: true });
8783
+ }
8784
+ else if (!timeFrom && timeTo) {
8785
+ control.setErrors({ rangeFrom: true });
8786
+ }
8787
+ else if (timeFrom && !timeTo) {
8788
+ control.setErrors({ rangeTo: true });
8789
+ }
8790
+ else if (timeFrom &&
8791
+ timeTo &&
8792
+ timeFrom > timeTo &&
8793
+ !this.allowCrossMidnight) {
8794
+ control.setErrors({ rangeOrder: true });
8787
8795
  }
8788
8796
  }
8789
8797
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsTimeRangeInputV2Component, deps: [{ token: i0.Injector }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Component });
8790
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsTimeRangeInputV2Component, selector: "ecabs-time-range-input-v2", inputs: { showCloseIcon: "showCloseIcon", listPlacement: "listPlacement", appendTo: "appendTo", min: "min", max: "max", showDayStart: "showDayStart", showDayEnd: "showDayEnd", addSecond: "addSecond", dayStartLabel: "dayStartLabel", dayEndLabel: "dayEndLabel", separatorLabel: "separatorLabel", startTimePlaceholder: "startTimePlaceholder", endTimePlaceholder: "endTimePlaceholder" }, providers: [
8798
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsTimeRangeInputV2Component, selector: "ecabs-time-range-input-v2", inputs: { showCloseIcon: "showCloseIcon", listPlacement: "listPlacement", appendTo: "appendTo", min: "min", max: "max", showDayStart: "showDayStart", showDayEnd: "showDayEnd", addSecond: "addSecond", dayStartLabel: "dayStartLabel", dayEndLabel: "dayEndLabel", separatorLabel: "separatorLabel", startTimePlaceholder: "startTimePlaceholder", endTimePlaceholder: "endTimePlaceholder", allowCrossMidnight: "allowCrossMidnight" }, providers: [
8791
8799
  {
8792
8800
  provide: NG_VALUE_ACCESSOR,
8793
8801
  useExisting: forwardRef(() => EcabsTimeRangeInputV2Component),
@@ -8830,6 +8838,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
8830
8838
  type: Input
8831
8839
  }], endTimePlaceholder: [{
8832
8840
  type: Input
8841
+ }], allowCrossMidnight: [{
8842
+ type: Input
8833
8843
  }] } });
8834
8844
 
8835
8845
  class EcabsTimeRangeInputV2Module {
@@ -9147,7 +9157,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
9147
9157
  class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
9148
9158
  injector;
9149
9159
  ecabsDatePickerHeaderService;
9150
- unsubscribeService;
9160
+ destroyRef;
9151
9161
  minDate;
9152
9162
  maxDate;
9153
9163
  touchUi = false;
@@ -9160,6 +9170,7 @@ class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
9160
9170
  excludeWeekends;
9161
9171
  specificDates;
9162
9172
  holidayOptions;
9173
+ dateToOptional = false;
9163
9174
  onblur = new EventEmitter();
9164
9175
  val;
9165
9176
  pickerTo;
@@ -9194,28 +9205,42 @@ class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
9194
9205
  }
9195
9206
  //eslint-disable-next-line
9196
9207
  set dateFrom(val) {
9197
- if (this._dateFrom !== val && isValid(new Date(val))) {
9208
+ if (this._dateFrom === val) {
9209
+ return;
9210
+ }
9211
+ if (val && isValid(new Date(val))) {
9198
9212
  this._dateFrom = val;
9199
9213
  this.minDateTo = new Date(val);
9200
- if (!this.dateTo) {
9214
+ if (!this.dateTo && !this.dateToOptional) {
9201
9215
  this.pickerTo?.open();
9202
9216
  }
9203
- this.onApply();
9204
9217
  }
9218
+ else if (!val) {
9219
+ this._dateFrom = val;
9220
+ this.minDateTo = this.minDate;
9221
+ }
9222
+ this.onApply();
9205
9223
  }
9206
9224
  //eslint-disable-next-line
9207
9225
  set dateTo(val) {
9208
- if (this._dateTo !== val && isValid(new Date(val))) {
9226
+ if (this._dateTo === val) {
9227
+ return;
9228
+ }
9229
+ if (val && isValid(new Date(val))) {
9209
9230
  this._dateTo = val;
9210
9231
  this.maxDateFrom = new Date(val);
9211
- this.onApply();
9212
9232
  }
9233
+ else if (!val) {
9234
+ this._dateTo = val;
9235
+ this.maxDateFrom = this.maxDate;
9236
+ }
9237
+ this.onApply();
9213
9238
  }
9214
- constructor(injector, ecabsDatePickerHeaderService, unsubscribeService) {
9239
+ constructor(injector, ecabsDatePickerHeaderService, destroyRef) {
9215
9240
  super();
9216
9241
  this.injector = injector;
9217
9242
  this.ecabsDatePickerHeaderService = ecabsDatePickerHeaderService;
9218
- this.unsubscribeService = unsubscribeService;
9243
+ this.destroyRef = destroyRef;
9219
9244
  }
9220
9245
  ngOnChanges(changes) {
9221
9246
  const { minDate, maxDate } = changes;
@@ -9231,7 +9256,7 @@ class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
9231
9256
  ngOnInit() {
9232
9257
  this.ecabsDatePickerHeaderService
9233
9258
  .getConfig()
9234
- .pipe(takeUntil(this.unsubscribeService.subscription()))
9259
+ .pipe(takeUntilDestroyed(this.destroyRef))
9235
9260
  .subscribe((config) => (this.translationConfig = config));
9236
9261
  if (this.holidayOptions?.countryCode) {
9237
9262
  this.holidayInstance = new Holidays(this.holidayOptions.countryCode.toUpperCase());
@@ -9242,17 +9267,15 @@ class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
9242
9267
  if (ngControl) {
9243
9268
  this.control = ngControl.control;
9244
9269
  this.control.valueChanges
9245
- .pipe(takeUntil(this.unsubscribeService.subscription()))
9270
+ .pipe(takeUntilDestroyed(this.destroyRef))
9246
9271
  .subscribe(() => this.dateRangeValidator(this.control));
9247
9272
  setTimeout(() => {
9248
9273
  this.dateFrom = this.value.dateFrom;
9249
9274
  this.dateTo = this.value.dateTo;
9275
+ this.dateRangeValidator(this.control);
9250
9276
  });
9251
9277
  }
9252
9278
  }
9253
- ngOnDestroy() {
9254
- this.unsubscribeService.destroy();
9255
- }
9256
9279
  onChange = () => { };
9257
9280
  onTouch = () => { };
9258
9281
  writeValue(value) {
@@ -9311,37 +9334,36 @@ class EcabsDateRangePickerComponentV2 extends EcabsElementBaseComponent {
9311
9334
  }
9312
9335
  dateRangeValidator(control) {
9313
9336
  const required = control?.hasValidator(Validators.required);
9314
- if (control.value) {
9315
- const { dateFrom, dateTo } = control.value;
9316
- control.setErrors(null);
9317
- if (required &&
9318
- (!dateFrom || dateFrom?.length === 0) &&
9319
- (!dateTo || dateTo?.length === 0)) {
9337
+ if (!control.value) {
9338
+ if (required) {
9320
9339
  control.setErrors({ required: true });
9321
- return;
9322
- }
9323
- if (!dateFrom && dateTo) {
9324
- control.setErrors({ dateFromRangeRequired: true });
9325
- return;
9326
- }
9327
- if (dateFrom && !dateTo) {
9328
- control.setErrors({ dateToRangeRequired: true });
9329
- return;
9330
- }
9331
- if (new Date(dateFrom) > new Date(dateTo)) {
9332
- control.setErrors({ dateFromMoreThanDateTo: true });
9333
- return;
9334
9340
  }
9341
+ return;
9342
+ }
9343
+ const { dateFrom, dateTo } = control.value;
9344
+ control.setErrors(null);
9345
+ if (required &&
9346
+ (!dateFrom || dateFrom?.length === 0) &&
9347
+ (!dateTo || dateTo?.length === 0)) {
9348
+ control.setErrors({ required: true });
9349
+ }
9350
+ else if (!dateFrom && dateTo) {
9351
+ control.setErrors({ rangeFrom: true });
9352
+ }
9353
+ else if (dateFrom && !dateTo && !this.dateToOptional) {
9354
+ control.setErrors({ rangeTo: true });
9355
+ }
9356
+ else if (dateFrom && dateTo && new Date(dateFrom) > new Date(dateTo)) {
9357
+ control.setErrors({ rangeOrder: true });
9335
9358
  }
9336
9359
  }
9337
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateRangePickerComponentV2, deps: [{ token: i0.Injector }, { token: EcabsDatePickerHeaderService }, { token: UnsubscribeService }], target: i0.ɵɵFactoryTarget.Component });
9338
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDateRangePickerComponentV2, selector: "ecabs-date-range-picker-v2", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", cancelLabel: "cancelLabel", applyLabel: "applyLabel", startDatePlaceholder: "startDatePlaceholder", endDatePlaceholder: "endDatePlaceholder", separatorLabel: "separatorLabel", excludeHolidays: "excludeHolidays", excludeWeekends: "excludeWeekends", specificDates: "specificDates", holidayOptions: "holidayOptions" }, outputs: { onblur: "onblur" }, providers: [
9360
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateRangePickerComponentV2, deps: [{ token: i0.Injector }, { token: EcabsDatePickerHeaderService }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Component });
9361
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDateRangePickerComponentV2, selector: "ecabs-date-range-picker-v2", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", cancelLabel: "cancelLabel", applyLabel: "applyLabel", startDatePlaceholder: "startDatePlaceholder", endDatePlaceholder: "endDatePlaceholder", separatorLabel: "separatorLabel", excludeHolidays: "excludeHolidays", excludeWeekends: "excludeWeekends", specificDates: "specificDates", holidayOptions: "holidayOptions", dateToOptional: "dateToOptional" }, outputs: { onblur: "onblur" }, providers: [
9339
9362
  {
9340
9363
  provide: NG_VALUE_ACCESSOR,
9341
9364
  useExisting: EcabsDateRangePickerComponentV2,
9342
9365
  multi: true,
9343
9366
  },
9344
- UnsubscribeService,
9345
9367
  ], viewQueries: [{ propertyName: "pickerTo", first: true, predicate: ["pickerTo"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__range--wrapper\">\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateFrom' }}\"\r\n [(ngModel)]=\"dateFrom\"\r\n [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerFrom\"\r\n [min]=\"minDateFrom\"\r\n [max]=\"maxDateFrom\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerFrom.open()\"\r\n />\r\n <mat-datepicker #pickerFrom\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n\r\n <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateTo' }}\"\r\n [(ngModel)]=\"dateTo\"\r\n [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerTo\"\r\n [min]=\"minDateTo\"\r\n [max]=\"maxDateTo\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerTo.open()\"\r\n />\r\n <mat-datepicker #pickerTo\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n </div>\r\n</ecabs-element-wrapper>\r\n", styles: [""], dependencies: [{ kind: "component", type: EcabsElementWrapperComponent, selector: "ecabs-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: EcabsMaskDateDirective, selector: "[ecabsMaskDate]", inputs: ["isDateTimeMask", "considerSeconds"] }] });
9346
9368
  }
9347
9369
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateRangePickerComponentV2, decorators: [{
@@ -9352,9 +9374,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
9352
9374
  useExisting: EcabsDateRangePickerComponentV2,
9353
9375
  multi: true,
9354
9376
  },
9355
- UnsubscribeService,
9356
9377
  ], template: "<ecabs-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__range--wrapper\">\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateFrom' }}\"\r\n [(ngModel)]=\"dateFrom\"\r\n [placeholder]=\"startDatePlaceholder ?? translationConfig?.startDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerFrom\"\r\n [min]=\"minDateFrom\"\r\n [max]=\"maxDateFrom\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerFrom.open()\"\r\n />\r\n <mat-datepicker #pickerFrom\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n\r\n <span class=\"text-gray-400 px-3 text-sm\">{{ separatorLabel }}</span>\r\n <div class=\"form-field__range\">\r\n <input\r\n class=\"border-none w-full\"\r\n id=\"{{ name + 'dateTo' }}\"\r\n [(ngModel)]=\"dateTo\"\r\n [placeholder]=\"endDatePlaceholder ?? translationConfig?.endDatePlaceholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"pickerTo\"\r\n [min]=\"minDateTo\"\r\n [max]=\"maxDateTo\"\r\n [matDatepickerFilter]=\"filterDateRange\"\r\n ecabsMaskDate\r\n (blur)=\"onTouch()\"\r\n (click)=\"pickerTo.open()\"\r\n />\r\n <mat-datepicker #pickerTo\r\n [panelClass]=\"panelClass\"\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\">\r\n </mat-datepicker>\r\n </div>\r\n </div>\r\n</ecabs-element-wrapper>\r\n" }]
9357
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: EcabsDatePickerHeaderService }, { type: UnsubscribeService }]; }, propDecorators: { minDate: [{
9378
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: EcabsDatePickerHeaderService }, { type: i0.DestroyRef }]; }, propDecorators: { minDate: [{
9358
9379
  type: Input
9359
9380
  }], maxDate: [{
9360
9381
  type: Input
@@ -9378,6 +9399,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
9378
9399
  type: Input
9379
9400
  }], holidayOptions: [{
9380
9401
  type: Input
9402
+ }], dateToOptional: [{
9403
+ type: Input
9381
9404
  }], onblur: [{
9382
9405
  type: Output
9383
9406
  }], pickerTo: [{