@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.
- package/bundles/colijnit-corecomponents_v12.umd.js +98 -31
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12-257.1.18.tgz +0 -0
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/filter-item/filter-item.component.js +14 -3
- package/esm2015/lib/components/input-date-picker/input-date-picker.component.js +24 -2
- package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +69 -30
- package/fesm2015/colijnit-corecomponents_v12.js +103 -31
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/calendar/style/_layout.scss +14 -14
- package/lib/components/calendar/style/_material-definition.scss +3 -3
- package/lib/components/filter-item/filter-item.component.d.ts +2 -0
- package/lib/components/input-date-picker/input-date-picker.component.d.ts +3 -0
- package/lib/components/input-date-range-picker/input-date-range-picker.component.d.ts +6 -0
- package/package.json +1 -1
|
@@ -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
|
-
|
|
48
|
-
|
|
49
|
-
|
|
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
|
-
|
|
52
|
-
}
|
|
61
|
+
});
|
|
53
62
|
}
|
|
54
63
|
handleSecondDateChanged(value) {
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
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
|
-
|
|
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
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
|
|
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
|
-
(
|
|
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
|
-
(
|
|
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
|
-
(
|
|
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
|
-
|
|
6963
|
-
|
|
6964
|
-
|
|
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
|
-
|
|
6967
|
-
}
|
|
6998
|
+
});
|
|
6968
6999
|
}
|
|
6969
7000
|
handleSecondDateChanged(value) {
|
|
6970
|
-
|
|
6971
|
-
|
|
6972
|
-
|
|
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
|
-
|
|
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
|
-
|
|
6982
|
-
|
|
6983
|
-
|
|
6984
|
-
|
|
6985
|
-
|
|
6986
|
-
|
|
6987
|
-
|
|
6988
|
-
|
|
6989
|
-
}
|
|
6990
|
-
|
|
6991
|
-
|
|
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
|
-
(
|
|
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
|
-
(
|
|
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]="'
|
|
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
|
|