@colijnit/corecomponents_v12 257.1.17 → 257.1.19

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.
@@ -4,6 +4,11 @@ import { OverlayService } from '../../service/overlay.service';
4
4
  import { BaseInputDatePickerDirective } from "../base-input-date-picker/base-input-date-picker.directive";
5
5
  import { DoubleCalendarComponent } from "../double-calendar/double-calendar.component";
6
6
  export class InputDateRangePickerComponent extends BaseInputDatePickerDirective {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.EARLIEST_DATE = new Date(1900, 0, 1); // 1900-01-01
10
+ this.LATEST_DATE = new Date(2100, 11, 31); // 2100-12-31
11
+ }
7
12
  showClass() {
8
13
  return true;
9
14
  }
@@ -44,43 +49,75 @@ export class InputDateRangePickerComponent extends BaseInputDatePickerDirective
44
49
  }
45
50
  }
46
51
  handleFirstDateChanged(value) {
47
- if (value) {
48
- if (!this.model) {
49
- this.setModel([]);
52
+ setTimeout(() => {
53
+ var _a, _b;
54
+ if (this.isValidDateString(value)) {
55
+ const [year, month, day] = value.split('-').map(Number);
56
+ const date = new Date(year, month - 1, day);
57
+ if (!this.model)
58
+ this.setModel([]);
59
+ this.setModel([date, (_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a[1]) !== null && _b !== void 0 ? _b : null]);
50
60
  }
51
- this.setModel([new Date(value), this.model[1] ? this.model[1] : null]);
52
- }
61
+ });
53
62
  }
54
63
  handleSecondDateChanged(value) {
55
- if (value) {
56
- if (!this.model) {
57
- this.setModel([]);
64
+ setTimeout(() => {
65
+ var _a, _b;
66
+ if (this.isValidDateString(value)) {
67
+ const [year, month, day] = value.split('-').map(Number);
68
+ const date = new Date(year, month - 1, day);
69
+ if (!this.model)
70
+ this.setModel([]);
71
+ this.setModel([(_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a[0]) !== null && _b !== void 0 ? _b : null, date]);
58
72
  }
59
- this.setModel([this.model[0] ? this.model[0] : null, new Date(value)]);
73
+ });
74
+ }
75
+ finalizeDates() {
76
+ let startDate = this.EARLIEST_DATE;
77
+ let endDate = this.LATEST_DATE;
78
+ if (this.isValidDateString(this.firstDateAsString)) {
79
+ const [y, m, d] = this.firstDateAsString.split('-').map(Number);
80
+ startDate = new Date(y, m - 1, d);
81
+ }
82
+ if (this.isValidDateString(this.secondDateAsString)) {
83
+ const [y, m, d] = this.secondDateAsString.split('-').map(Number);
84
+ endDate = new Date(y, m - 1, d);
60
85
  }
86
+ this.setModel([startDate, endDate]);
87
+ }
88
+ finalize() {
89
+ var _a;
90
+ (_a = this.finalizeDates) === null || _a === void 0 ? void 0 : _a.call(this);
91
+ }
92
+ isValidDateString(value) {
93
+ const regex = /^\d{4}-\d{2}-\d{2}$/;
94
+ if (!regex.test(value))
95
+ return false;
96
+ const [yearStr, monthStr, dayStr] = value.split('-');
97
+ const [year, month, day] = [Number(yearStr), Number(monthStr), Number(dayStr)];
98
+ // Prevent ancient years or too-far future
99
+ if (year < 1900 || year > 2100)
100
+ return false;
101
+ const date = new Date(year, month - 1, day);
102
+ return (date.getFullYear() === year &&
103
+ date.getMonth() === month - 1 &&
104
+ date.getDate() === day);
61
105
  }
62
106
  modelSet() {
63
107
  this.setModelAsString();
64
108
  }
65
109
  setModelAsString() {
66
- if (this.model[0]) {
67
- const year = this.model[0].toLocaleString("default", { year: "numeric" });
68
- const month = this.model[0].toLocaleString("default", { month: "2-digit" });
69
- const day = this.model[0].toLocaleString("default", { day: "2-digit" });
70
- this.firstDateAsString = `${year}-${month}-${day}`;
71
- }
72
- else {
73
- this.firstDateAsString = ``;
74
- }
75
- if (this.model[1]) {
76
- const year = this.model[1].toLocaleString("default", { year: "numeric" });
77
- const month = this.model[1].toLocaleString("default", { month: "2-digit" });
78
- const day = this.model[1].toLocaleString("default", { day: "2-digit" });
79
- this.secondDateAsString = `${year}-${month}-${day}`;
80
- }
81
- else {
82
- this.secondDateAsString = ``;
83
- }
110
+ var _a, _b;
111
+ const isStartDefault = ((_a = this.model[0]) === null || _a === void 0 ? void 0 : _a.getTime()) === this.EARLIEST_DATE.getTime();
112
+ const isEndDefault = ((_b = this.model[1]) === null || _b === void 0 ? void 0 : _b.getTime()) === this.LATEST_DATE.getTime();
113
+ this.firstDateAsString = (!this.model[0] || isStartDefault) ? '' : this.formatDate(this.model[0]);
114
+ this.secondDateAsString = (!this.model[1] || isEndDefault) ? '' : this.formatDate(this.model[1]);
115
+ }
116
+ formatDate(date) {
117
+ const year = date.toLocaleString("default", { year: "numeric" });
118
+ const month = date.toLocaleString("default", { month: "2-digit" });
119
+ const day = date.toLocaleString("default", { day: "2-digit" });
120
+ return `${year}-${month}-${day}`;
84
121
  }
85
122
  }
86
123
  InputDateRangePickerComponent.decorators = [
@@ -96,10 +133,11 @@ InputDateRangePickerComponent.decorators = [
96
133
  [leftIcon]="leftIcon"
97
134
  [leftIconData]="leftIconData"
98
135
  [placeholder]="placeholder"
99
- (blur)="handleFirstDateChanged(firstDateAsString)"
136
+ (modelChange)="handleFirstDateChanged(firstDateAsString)"
100
137
  (clearIconClick)="clearDate(0)"
101
138
  (click)="handleFirstInputClick($event)"
102
139
  [emptyPlace]="true"
140
+ (keyup.enter)="finalizeDates()"
103
141
  ></co-input-text>
104
142
  <co-input-text #secondInput class="no-focus-line custom-height"
105
143
  [(model)]= "secondDateAsString"
@@ -108,10 +146,11 @@ InputDateRangePickerComponent.decorators = [
108
146
  [type]="'date'"
109
147
  [rightIcon]="rightIcon"
110
148
  (rightIconClick)="toggleCalendar()"
111
- (blur)="handleSecondDateChanged(secondDateAsString)"
149
+ (modelChange)="handleSecondDateChanged(secondDateAsString)"
112
150
  (clearIconClick)="clearDate(1)"
113
151
  (click)="handleSecondInputClick($event)"
114
152
  [emptyPlace]="true"
153
+ (keyup.enter)="finalizeDates()"
115
154
  ></co-input-text>
116
155
  </div>
117
156
  `,
@@ -133,4 +172,4 @@ InputDateRangePickerComponent.propDecorators = {
133
172
  secondInput: [{ type: ViewChild, args: ['secondInput',] }],
134
173
  showClass: [{ type: HostBinding, args: ['class.co-input-date-range',] }]
135
174
  };
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-date-range-picker/input-date-range-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentRef, ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {\r\n    SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME\r\n} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\nimport {DoubleCalendarComponent} from \"../double-calendar/double-calendar.component\";\r\n\r\n@Component({\r\n    selector: 'co-input-date-range',\r\n    template: `\r\n      <div class=\"inputs-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n        <co-input-text #firstInput class=\"no-focus-line custom-height\"\r\n                       [(model)]=\"firstDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [leftIcon]=\"leftIcon\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [placeholder]=\"placeholder\"\r\n                       (blur)=\"handleFirstDateChanged(firstDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(0)\"\r\n                       (click)=\"handleFirstInputClick($event)\"\r\n                       [emptyPlace]=\"true\"\r\n        ></co-input-text>\r\n        <co-input-text #secondInput class=\"no-focus-line custom-height\"\r\n                       [(model)]= \"secondDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [rightIcon]=\"rightIcon\"\r\n                       (rightIconClick)=\"toggleCalendar()\"\r\n                       (blur)=\"handleSecondDateChanged(secondDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(1)\"\r\n                       (click)=\"handleSecondInputClick($event)\"\r\n                       [emptyPlace]=\"true\"\r\n        ></co-input-text>\r\n      </div>\r\n    `,\r\n    providers: [\r\n        OverlayService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => InputDateRangePickerComponent)\r\n        }, {\r\n            provide: BaseInputDatePickerDirective,\r\n            useExisting: InputDateRangePickerComponent\r\n        }],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputDateRangePickerComponent extends BaseInputDatePickerDirective {\r\n\r\n  public firstDateAsString;\r\n  public secondDateAsString;\r\n\r\n  private _doubleCalendarComponentRef: ComponentRef<DoubleCalendarComponent>;\r\n\r\n  @ViewChild('firstInput') firstInput: ElementRef;\r\n  @ViewChild('secondInput') secondInput: ElementRef;\r\n    @HostBinding('class.co-input-date-range')\r\n    public showClass(): boolean {\r\n        return true;\r\n    }\r\n  handleFirstInputClick(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  handleSecondInputClick(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n  public handleDatesSelected(dates: Date[]): void {\r\n    this.setModel(dates);\r\n  }\r\n\r\n  public handleSecondDateSelected(): void {\r\n    if (this.closeAfterDateSelection) {\r\n      this.toggleCalendar();\r\n    }\r\n  }\r\n\r\n  public clearDate(index: number): void {\r\n      this.model[index] = undefined;\r\n  }\r\n\r\n  public toggleCalendar(): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n\r\n    this.showCalendar = !this.showCalendar;\r\n\r\n    if (this.showCalendar) {\r\n      this._doubleCalendarComponentRef = this.overlayService.createComponent(DoubleCalendarComponent, {\r\n        parentForOverlay: this.parentForOverlay,\r\n        selectedDates: this.model\r\n      }, {\r\n        datesSelected: (event) => this.handleDatesSelected(event),\r\n        secondDateSelected: () => this.handleSecondDateSelected(),\r\n        clickedOutside: () => this.toggleCalendar()\r\n      });\r\n    } else {\r\n      this.overlayService.removeComponent(this._doubleCalendarComponentRef);\r\n    }\r\n  }\r\n\r\n  public handleFirstDateChanged(value: string): void {\r\n    if (value) {\r\n      if (!this.model) {\r\n        this.setModel([]);\r\n      }\r\n      this.setModel([new Date(value), this.model[1] ? this.model[1] : null]);\r\n    }\r\n  }\r\n\r\n  public handleSecondDateChanged(value: string): void {\r\n    if (value) {\r\n      if (!this.model) {\r\n        this.setModel([]);\r\n      }\r\n      this.setModel([this.model[0] ? this.model[0] : null, new Date(value)]);\r\n    }\r\n  }\r\n\r\n  protected modelSet(): void {\r\n    this.setModelAsString();\r\n  }\r\n\r\n  private setModelAsString(): void {\r\n    if (this.model[0]) {\r\n      const year = this.model[0].toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model[0].toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model[0].toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.firstDateAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.firstDateAsString = ``;\r\n    }\r\n    if (this.model[1]) {\r\n      const year = this.model[1].toLocaleString(\"default\", { year: \"numeric\" });\r\n      const month = this.model[1].toLocaleString(\"default\", { month: \"2-digit\" });\r\n      const day = this.model[1].toLocaleString(\"default\", { day: \"2-digit\" });\r\n      this.secondDateAsString = `${year}-${month}-${day}`;\r\n    } else {\r\n      this.secondDateAsString = ``;\r\n    }\r\n  }\r\n}\r\n"]}
175
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-date-range-picker/input-date-range-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentRef, ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {\r\n    SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME\r\n} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\nimport {DoubleCalendarComponent} from \"../double-calendar/double-calendar.component\";\r\n\r\n@Component({\r\n    selector: 'co-input-date-range',\r\n    template: `\r\n      <div class=\"inputs-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n        <co-input-text #firstInput class=\"no-focus-line custom-height\"\r\n                       [(model)]=\"firstDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [leftIcon]=\"leftIcon\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [placeholder]=\"placeholder\"\r\n                       (modelChange)=\"handleFirstDateChanged(firstDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(0)\"\r\n                       (click)=\"handleFirstInputClick($event)\"\r\n                       [emptyPlace]=\"true\"\r\n                       (keyup.enter)=\"finalizeDates()\"\r\n        ></co-input-text>\r\n        <co-input-text #secondInput class=\"no-focus-line custom-height\"\r\n                       [(model)]= \"secondDateAsString\"\r\n                       [noClickFocus]=\"true\"\r\n                       [pattern]=\"'yyyy-MM-dd'\"\r\n                       [type]=\"'date'\"\r\n                       [rightIcon]=\"rightIcon\"\r\n                       (rightIconClick)=\"toggleCalendar()\"\r\n                       (modelChange)=\"handleSecondDateChanged(secondDateAsString)\"\r\n                       (clearIconClick)=\"clearDate(1)\"\r\n                       (click)=\"handleSecondInputClick($event)\"\r\n                       [emptyPlace]=\"true\"\r\n                       (keyup.enter)=\"finalizeDates()\"\r\n        ></co-input-text>\r\n      </div>\r\n    `,\r\n    providers: [\r\n        OverlayService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => InputDateRangePickerComponent)\r\n        }, {\r\n            provide: BaseInputDatePickerDirective,\r\n            useExisting: InputDateRangePickerComponent\r\n        }],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputDateRangePickerComponent extends BaseInputDatePickerDirective {\r\n\r\n  public firstDateAsString;\r\n  public secondDateAsString;\r\n\r\n  private readonly EARLIEST_DATE = new Date(1900, 0, 1);  // 1900-01-01\r\n  private readonly LATEST_DATE = new Date(2100, 11, 31);  // 2100-12-31\r\n\r\n  private _doubleCalendarComponentRef: ComponentRef<DoubleCalendarComponent>;\r\n\r\n  @ViewChild('firstInput') firstInput: ElementRef;\r\n  @ViewChild('secondInput') secondInput: ElementRef;\r\n    @HostBinding('class.co-input-date-range')\r\n    public showClass(): boolean {\r\n        return true;\r\n    }\r\n  handleFirstInputClick(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  handleSecondInputClick(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n  public handleDatesSelected(dates: Date[]): void {\r\n    this.setModel(dates);\r\n  }\r\n\r\n  public handleSecondDateSelected(): void {\r\n    if (this.closeAfterDateSelection) {\r\n      this.toggleCalendar();\r\n    }\r\n  }\r\n\r\n  public clearDate(index: number): void {\r\n      this.model[index] = undefined;\r\n  }\r\n\r\n  public toggleCalendar(): void {\r\n    if (this.readonly) {\r\n      return;\r\n    }\r\n\r\n    this.showCalendar = !this.showCalendar;\r\n\r\n    if (this.showCalendar) {\r\n      this._doubleCalendarComponentRef = this.overlayService.createComponent(DoubleCalendarComponent, {\r\n        parentForOverlay: this.parentForOverlay,\r\n        selectedDates: this.model\r\n      }, {\r\n        datesSelected: (event) => this.handleDatesSelected(event),\r\n        secondDateSelected: () => this.handleSecondDateSelected(),\r\n        clickedOutside: () => this.toggleCalendar()\r\n      });\r\n    } else {\r\n      this.overlayService.removeComponent(this._doubleCalendarComponentRef);\r\n    }\r\n  }\r\n\r\n  public handleFirstDateChanged(value: string): void {\r\n    setTimeout(() => {\r\n      if (this.isValidDateString(value)) {\r\n        const [year, month, day] = value.split('-').map(Number);\r\n        const date = new Date(year, month - 1, day);\r\n\r\n        if (!this.model) this.setModel([]);\r\n        this.setModel([date, this.model?.[1] ?? null]);\r\n      }\r\n    });\r\n  }\r\n\r\n  public handleSecondDateChanged(value: string): void {\r\n    setTimeout(() => {\r\n      if (this.isValidDateString(value)) {\r\n        const [year, month, day] = value.split('-').map(Number);\r\n        const date = new Date(year, month - 1, day);\r\n\r\n        if (!this.model) this.setModel([]);\r\n        this.setModel([this.model?.[0] ?? null, date]);\r\n      }\r\n    });\r\n  }\r\n\r\n  public finalizeDates(): void {\r\n    let startDate = this.EARLIEST_DATE;\r\n    let endDate = this.LATEST_DATE;\r\n\r\n    if (this.isValidDateString(this.firstDateAsString)) {\r\n      const [y, m, d] = this.firstDateAsString.split('-').map(Number);\r\n      startDate = new Date(y, m - 1, d);\r\n    }\r\n\r\n    if (this.isValidDateString(this.secondDateAsString)) {\r\n      const [y, m, d] = this.secondDateAsString.split('-').map(Number);\r\n      endDate = new Date(y, m - 1, d);\r\n    }\r\n\r\n    this.setModel([startDate, endDate]);\r\n  }\r\n\r\n  public finalize(): void {\r\n    this.finalizeDates?.();\r\n  }\r\n\r\n  private isValidDateString(value: string): boolean {\r\n    const regex = /^\\d{4}-\\d{2}-\\d{2}$/;\r\n    if (!regex.test(value)) return false;\r\n\r\n    const [yearStr, monthStr, dayStr] = value.split('-');\r\n    const [year, month, day] = [Number(yearStr), Number(monthStr), Number(dayStr)];\r\n\r\n    // Prevent ancient years or too-far future\r\n    if (year < 1900 || year > 2100) return false;\r\n\r\n    const date = new Date(year, month - 1, day);\r\n    return (\r\n      date.getFullYear() === year &&\r\n      date.getMonth() === month - 1 &&\r\n      date.getDate() === day\r\n    );\r\n  }\r\n\r\n  protected modelSet(): void {\r\n    this.setModelAsString();\r\n  }\r\n\r\n  private setModelAsString(): void {\r\n    const isStartDefault = this.model[0]?.getTime() === this.EARLIEST_DATE.getTime();\r\n    const isEndDefault = this.model[1]?.getTime() === this.LATEST_DATE.getTime();\r\n\r\n    this.firstDateAsString = (!this.model[0] || isStartDefault) ? '' : this.formatDate(this.model[0]);\r\n    this.secondDateAsString = (!this.model[1] || isEndDefault) ? '' : this.formatDate(this.model[1]);\r\n  }\r\n\r\n  private formatDate(date: Date): string {\r\n    const year = date.toLocaleString(\"default\", { year: \"numeric\" });\r\n    const month = date.toLocaleString(\"default\", { month: \"2-digit\" });\r\n    const day = date.toLocaleString(\"default\", { day: \"2-digit\" });\r\n    return `${year}-${month}-${day}`;\r\n  }\r\n}\r\n"]}
@@ -5446,6 +5446,27 @@ class InputDatePickerComponent extends BaseInputDatePickerDirective {
5446
5446
  this.overlayService.removeComponent(this._calendarComponentRef);
5447
5447
  }
5448
5448
  }
5449
+ finalizeDate() {
5450
+ if (this.isValidDateString(this.modelAsString)) {
5451
+ const [year, month, day] = this.modelAsString.split('-').map(Number);
5452
+ const date = new Date(year, month - 1, day);
5453
+ this.setModel(date);
5454
+ }
5455
+ }
5456
+ finalize() {
5457
+ var _a;
5458
+ (_a = this.finalizeDate) === null || _a === void 0 ? void 0 : _a.call(this); // re-use the same logic from (keyup.enter)
5459
+ }
5460
+ isValidDateString(value) {
5461
+ const regex = /^\d{4}-\d{2}-\d{2}$/;
5462
+ if (!regex.test(value))
5463
+ return false;
5464
+ const [year, month, day] = value.split('-').map(Number);
5465
+ const date = new Date(year, month - 1, day);
5466
+ return (date.getFullYear() === year &&
5467
+ date.getMonth() === month - 1 &&
5468
+ date.getDate() === day);
5469
+ }
5449
5470
  handleDateChange(value) {
5450
5471
  if (value) {
5451
5472
  this.setModel(new Date(value));
@@ -5485,9 +5506,10 @@ InputDatePickerComponent.decorators = [
5485
5506
  [placeholder]="placeholder"
5486
5507
  (leftIconClick)="leftIconClick.emit($event)"
5487
5508
  (rightIconClick)="toggleCalendar(true)"
5488
- (blur)="handleDateChange(modelAsString)"
5509
+ (modelChange)="modelAsString = $event"
5489
5510
  (clearIconClick)="handleClearIconClicked()"
5490
5511
  [emptyPlace]="true"
5512
+ (keyup.enter)="finalizeDate()"
5491
5513
  ></co-input-text>
5492
5514
  `,
5493
5515
  providers: [
@@ -6919,6 +6941,11 @@ DoubleCalendarModule.decorators = [
6919
6941
  ];
6920
6942
 
6921
6943
  class InputDateRangePickerComponent extends BaseInputDatePickerDirective {
6944
+ constructor() {
6945
+ super(...arguments);
6946
+ this.EARLIEST_DATE = new Date(1900, 0, 1); // 1900-01-01
6947
+ this.LATEST_DATE = new Date(2100, 11, 31); // 2100-12-31
6948
+ }
6922
6949
  showClass() {
6923
6950
  return true;
6924
6951
  }
@@ -6959,43 +6986,75 @@ class InputDateRangePickerComponent extends BaseInputDatePickerDirective {
6959
6986
  }
6960
6987
  }
6961
6988
  handleFirstDateChanged(value) {
6962
- if (value) {
6963
- if (!this.model) {
6964
- this.setModel([]);
6989
+ setTimeout(() => {
6990
+ var _a, _b;
6991
+ if (this.isValidDateString(value)) {
6992
+ const [year, month, day] = value.split('-').map(Number);
6993
+ const date = new Date(year, month - 1, day);
6994
+ if (!this.model)
6995
+ this.setModel([]);
6996
+ this.setModel([date, (_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a[1]) !== null && _b !== void 0 ? _b : null]);
6965
6997
  }
6966
- this.setModel([new Date(value), this.model[1] ? this.model[1] : null]);
6967
- }
6998
+ });
6968
6999
  }
6969
7000
  handleSecondDateChanged(value) {
6970
- if (value) {
6971
- if (!this.model) {
6972
- this.setModel([]);
7001
+ setTimeout(() => {
7002
+ var _a, _b;
7003
+ if (this.isValidDateString(value)) {
7004
+ const [year, month, day] = value.split('-').map(Number);
7005
+ const date = new Date(year, month - 1, day);
7006
+ if (!this.model)
7007
+ this.setModel([]);
7008
+ this.setModel([(_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a[0]) !== null && _b !== void 0 ? _b : null, date]);
6973
7009
  }
6974
- this.setModel([this.model[0] ? this.model[0] : null, new Date(value)]);
7010
+ });
7011
+ }
7012
+ finalizeDates() {
7013
+ let startDate = this.EARLIEST_DATE;
7014
+ let endDate = this.LATEST_DATE;
7015
+ if (this.isValidDateString(this.firstDateAsString)) {
7016
+ const [y, m, d] = this.firstDateAsString.split('-').map(Number);
7017
+ startDate = new Date(y, m - 1, d);
6975
7018
  }
7019
+ if (this.isValidDateString(this.secondDateAsString)) {
7020
+ const [y, m, d] = this.secondDateAsString.split('-').map(Number);
7021
+ endDate = new Date(y, m - 1, d);
7022
+ }
7023
+ this.setModel([startDate, endDate]);
7024
+ }
7025
+ finalize() {
7026
+ var _a;
7027
+ (_a = this.finalizeDates) === null || _a === void 0 ? void 0 : _a.call(this);
7028
+ }
7029
+ isValidDateString(value) {
7030
+ const regex = /^\d{4}-\d{2}-\d{2}$/;
7031
+ if (!regex.test(value))
7032
+ return false;
7033
+ const [yearStr, monthStr, dayStr] = value.split('-');
7034
+ const [year, month, day] = [Number(yearStr), Number(monthStr), Number(dayStr)];
7035
+ // Prevent ancient years or too-far future
7036
+ if (year < 1900 || year > 2100)
7037
+ return false;
7038
+ const date = new Date(year, month - 1, day);
7039
+ return (date.getFullYear() === year &&
7040
+ date.getMonth() === month - 1 &&
7041
+ date.getDate() === day);
6976
7042
  }
6977
7043
  modelSet() {
6978
7044
  this.setModelAsString();
6979
7045
  }
6980
7046
  setModelAsString() {
6981
- if (this.model[0]) {
6982
- const year = this.model[0].toLocaleString("default", { year: "numeric" });
6983
- const month = this.model[0].toLocaleString("default", { month: "2-digit" });
6984
- const day = this.model[0].toLocaleString("default", { day: "2-digit" });
6985
- this.firstDateAsString = `${year}-${month}-${day}`;
6986
- }
6987
- else {
6988
- this.firstDateAsString = ``;
6989
- }
6990
- if (this.model[1]) {
6991
- const year = this.model[1].toLocaleString("default", { year: "numeric" });
6992
- const month = this.model[1].toLocaleString("default", { month: "2-digit" });
6993
- const day = this.model[1].toLocaleString("default", { day: "2-digit" });
6994
- this.secondDateAsString = `${year}-${month}-${day}`;
6995
- }
6996
- else {
6997
- this.secondDateAsString = ``;
6998
- }
7047
+ var _a, _b;
7048
+ const isStartDefault = ((_a = this.model[0]) === null || _a === void 0 ? void 0 : _a.getTime()) === this.EARLIEST_DATE.getTime();
7049
+ const isEndDefault = ((_b = this.model[1]) === null || _b === void 0 ? void 0 : _b.getTime()) === this.LATEST_DATE.getTime();
7050
+ this.firstDateAsString = (!this.model[0] || isStartDefault) ? '' : this.formatDate(this.model[0]);
7051
+ this.secondDateAsString = (!this.model[1] || isEndDefault) ? '' : this.formatDate(this.model[1]);
7052
+ }
7053
+ formatDate(date) {
7054
+ const year = date.toLocaleString("default", { year: "numeric" });
7055
+ const month = date.toLocaleString("default", { month: "2-digit" });
7056
+ const day = date.toLocaleString("default", { day: "2-digit" });
7057
+ return `${year}-${month}-${day}`;
6999
7058
  }
7000
7059
  }
7001
7060
  InputDateRangePickerComponent.decorators = [
@@ -7011,10 +7070,11 @@ InputDateRangePickerComponent.decorators = [
7011
7070
  [leftIcon]="leftIcon"
7012
7071
  [leftIconData]="leftIconData"
7013
7072
  [placeholder]="placeholder"
7014
- (blur)="handleFirstDateChanged(firstDateAsString)"
7073
+ (modelChange)="handleFirstDateChanged(firstDateAsString)"
7015
7074
  (clearIconClick)="clearDate(0)"
7016
7075
  (click)="handleFirstInputClick($event)"
7017
7076
  [emptyPlace]="true"
7077
+ (keyup.enter)="finalizeDates()"
7018
7078
  ></co-input-text>
7019
7079
  <co-input-text #secondInput class="no-focus-line custom-height"
7020
7080
  [(model)]= "secondDateAsString"
@@ -7023,10 +7083,11 @@ InputDateRangePickerComponent.decorators = [
7023
7083
  [type]="'date'"
7024
7084
  [rightIcon]="rightIcon"
7025
7085
  (rightIconClick)="toggleCalendar()"
7026
- (blur)="handleSecondDateChanged(secondDateAsString)"
7086
+ (modelChange)="handleSecondDateChanged(secondDateAsString)"
7027
7087
  (clearIconClick)="clearDate(1)"
7028
7088
  (click)="handleSecondInputClick($event)"
7029
7089
  [emptyPlace]="true"
7090
+ (keyup.enter)="finalizeDates()"
7030
7091
  ></co-input-text>
7031
7092
  </div>
7032
7093
  `,
@@ -12139,6 +12200,13 @@ class FilterItemComponent {
12139
12200
  });
12140
12201
  }
12141
12202
  onButtonClicked() {
12203
+ var _a, _b;
12204
+ if ((_a = this.dateInput) === null || _a === void 0 ? void 0 : _a.finalize) {
12205
+ this.dateInput.finalize();
12206
+ }
12207
+ if ((_b = this.dateRangeInput) === null || _b === void 0 ? void 0 : _b.finalize) {
12208
+ this.dateRangeInput.finalize();
12209
+ }
12142
12210
  this.filterButtonClicked.emit();
12143
12211
  }
12144
12212
  uncheckForSingleSelect(model) {
@@ -12566,15 +12634,17 @@ FilterItemComponent.decorators = [
12566
12634
  </div>
12567
12635
  <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateField">
12568
12636
  <co-input-date
12637
+ #dateInput
12569
12638
  [(model)]="model" [readonly]="readonly"
12570
12639
  (modelChange)="handleModelChange($event)"
12571
12640
  ></co-input-date>
12572
12641
  </div>
12573
12642
  <div class="co-filter-item-dateField-content" *ngIf="mode === modes.DateRangeField">
12574
12643
  <co-input-date-range [readonly]="readonly"
12644
+ #dateRangeInput
12575
12645
  [model]="[dateRangeStart, dateRangeEnd]"
12576
12646
  (modelChange)="handleModelChange($event)"
12577
- [placeholder]="'SELECT_DATE' | coreLocalize">
12647
+ [placeholder]="'Kies datum' | coreLocalize">
12578
12648
  </co-input-date-range>
12579
12649
  </div>
12580
12650
  </ng-template>
@@ -12618,6 +12688,8 @@ FilterItemComponent.propDecorators = {
12618
12688
  collectionChange: [{ type: Output }],
12619
12689
  filterButtonClicked: [{ type: Output }],
12620
12690
  hasClass: [{ type: HostBinding, args: ["class.co-filter-item",] }],
12691
+ dateInput: [{ type: ViewChild, args: ['dateInput',] }],
12692
+ dateRangeInput: [{ type: ViewChild, args: ['dateRangeInput',] }],
12621
12693
  hidden: [{ type: HostBinding, args: ['class.co-hidden',] }]
12622
12694
  };
12623
12695