ecabs-components 1.1.43 → 1.1.44
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
CHANGED
|
@@ -103,3 +103,4 @@ 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
|
|
@@ -102,7 +102,10 @@ export class EcabsDateRangePickerComponent extends EcabsElementBaseComponent {
|
|
|
102
102
|
if (lastChosenDate.value && start && !end) {
|
|
103
103
|
startRange = start;
|
|
104
104
|
}
|
|
105
|
-
if (lastChosenDate.value
|
|
105
|
+
if (start > lastChosenDate.value) {
|
|
106
|
+
startRange = lastChosenDate.value;
|
|
107
|
+
}
|
|
108
|
+
else if (lastChosenDate.value && (start && !end)) {
|
|
106
109
|
endRange = lastChosenDate.value;
|
|
107
110
|
}
|
|
108
111
|
this.disabledApplyButton = !(startRange && endRange);
|
|
@@ -170,4 +173,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
170
173
|
type: ViewChild,
|
|
171
174
|
args: ['picker']
|
|
172
175
|
}] } });
|
|
173
|
-
//# 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 (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"]}
|
|
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"]}
|
|
@@ -3028,7 +3028,10 @@ class EcabsDateRangePickerComponent extends EcabsElementBaseComponent {
|
|
|
3028
3028
|
if (lastChosenDate.value && start && !end) {
|
|
3029
3029
|
startRange = start;
|
|
3030
3030
|
}
|
|
3031
|
-
if (lastChosenDate.value
|
|
3031
|
+
if (start > lastChosenDate.value) {
|
|
3032
|
+
startRange = lastChosenDate.value;
|
|
3033
|
+
}
|
|
3034
|
+
else if (lastChosenDate.value && (start && !end)) {
|
|
3032
3035
|
endRange = lastChosenDate.value;
|
|
3033
3036
|
}
|
|
3034
3037
|
this.disabledApplyButton = !(startRange && endRange);
|