@huntsman-cancer-institute/input 16.0.0 → 17.0.0
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/date/date-base.d.ts +65 -65
- package/date/date-date-range.component.d.ts +32 -32
- package/date/date-date.component.d.ts +53 -53
- package/date/date-validator.d.ts +17 -17
- package/date/date.module.d.ts +16 -16
- package/dropdown/dropdown-index.d.ts +6 -6
- package/dropdown/dropdown-select-result.component.d.ts +23 -23
- package/dropdown/dropdown-select.component.d.ts +76 -76
- package/dropdown/dropdown.component.d.ts +40 -40
- package/dropdown/dropdown.module.d.ts +13 -13
- package/dropdown/dropdown.service.d.ts +51 -51
- package/dropdown/messages.d.ts +11 -11
- package/dropdown/select-item.d.ts +16 -16
- package/dropdown/template-dropdown.directive.d.ts +12 -12
- package/esm2022/date/date-base.mjs +114 -114
- package/esm2022/date/date-date-range.component.mjs +92 -92
- package/esm2022/date/date-date.component.mjs +189 -189
- package/esm2022/date/date-validator.mjs +40 -40
- package/esm2022/date/date.module.mjs +60 -60
- package/esm2022/dropdown/dropdown-index.mjs +5 -5
- package/esm2022/dropdown/dropdown-select-result.component.mjs +85 -85
- package/esm2022/dropdown/dropdown-select.component.mjs +360 -360
- package/esm2022/dropdown/dropdown.component.mjs +170 -170
- package/esm2022/dropdown/dropdown.module.mjs +50 -50
- package/esm2022/dropdown/dropdown.service.mjs +133 -133
- package/esm2022/dropdown/messages.mjs +9 -9
- package/esm2022/dropdown/select-item.mjs +11 -11
- package/esm2022/dropdown/template-dropdown.directive.mjs +26 -26
- package/esm2022/huntsman-cancer-institute-input.mjs +4 -4
- package/esm2022/index.mjs +19 -19
- package/esm2022/inline/inline.component.mjs +179 -179
- package/esm2022/inline/inline.module.mjs +28 -28
- package/esm2022/search/search.component.mjs +157 -157
- package/esm2022/search/search.module.mjs +32 -32
- package/esm2022/select/custom-combobox.component.mjs +531 -531
- package/esm2022/select/custom-multi-combobox.component.mjs +232 -232
- package/esm2022/select/md-multi-select.component.mjs +127 -127
- package/esm2022/select/md-select.component.mjs +107 -107
- package/esm2022/select/native-select.component.mjs +188 -188
- package/esm2022/select/select.module.mjs +83 -83
- package/fesm2022/huntsman-cancer-institute-input.mjs +2797 -2797
- package/fesm2022/huntsman-cancer-institute-input.mjs.map +1 -1
- package/index.d.ts +20 -20
- package/inline/inline.component.d.ts +66 -66
- package/inline/inline.module.d.ts +9 -9
- package/package.json +16 -8
- package/search/search.component.d.ts +42 -42
- package/search/search.module.d.ts +10 -10
- package/select/custom-combobox.component.d.ts +98 -98
- package/select/custom-multi-combobox.component.d.ts +50 -50
- package/select/md-multi-select.component.d.ts +32 -32
- package/select/md-select.component.d.ts +30 -30
- package/select/native-select.component.d.ts +37 -37
- package/select/select.module.d.ts +21 -21
|
@@ -1,166 +1,166 @@
|
|
|
1
|
-
import { Component, ElementRef, EventEmitter, Input, ViewChild, Output, ChangeDetectorRef } from "@angular/core";
|
|
2
|
-
import { DatePipe } from "@angular/common";
|
|
3
|
-
import { UntypedFormBuilder, UntypedFormControl } from "@angular/forms";
|
|
4
|
-
import { DateValidator } from "./date-validator";
|
|
5
|
-
import { DateBase } from "./date-base";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/forms";
|
|
8
|
-
import * as i2 from "@angular/common";
|
|
9
|
-
import * as i3 from "@ng-bootstrap/ng-bootstrap";
|
|
10
|
-
/**
|
|
11
|
-
* TODO: Confirm timezone behavior.
|
|
12
|
-
*
|
|
13
|
-
* @since 4.0.0
|
|
14
|
-
*/
|
|
15
|
-
export class DateComponent extends DateBase {
|
|
16
|
-
constructor(elementRef, formBuilder, datePipe, changeDetectorRef) {
|
|
17
|
-
super(elementRef);
|
|
18
|
-
this.formBuilder = formBuilder;
|
|
19
|
-
this.datePipe = datePipe;
|
|
20
|
-
this.changeDetectorRef = changeDetectorRef;
|
|
21
|
-
// Binded data from the parent component.
|
|
22
|
-
this.dateFormat = "shortDate";
|
|
23
|
-
this.inputDataChange = new EventEmitter();
|
|
24
|
-
// only validate if user is typing
|
|
25
|
-
this.validate = false;
|
|
26
|
-
this.focused = false;
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
*
|
|
30
|
-
*/
|
|
31
|
-
ngOnInit() {
|
|
32
|
-
this.dateForm = this.formBuilder.group({
|
|
33
|
-
dateInput: new UntypedFormControl("", [DateValidator.dateFormatValidator, DateValidator.dateRangeValidator])
|
|
34
|
-
});
|
|
35
|
-
this.onChanges();
|
|
36
|
-
this.updateInternalDataFromModel();
|
|
37
|
-
// set the minDate to 20 years in the past by default
|
|
38
|
-
let today = new Date();
|
|
39
|
-
if (!this.minDate) {
|
|
40
|
-
this.minDate = { year: today.getFullYear() - 20, month: today.getMonth() + 1, day: today.getDate() };
|
|
41
|
-
}
|
|
42
|
-
// set max date to today by default
|
|
43
|
-
if (!this.maxDate) {
|
|
44
|
-
this.maxDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
ngAfterViewInit() {
|
|
48
|
-
// Fill the input with the bound data set in the parent component.
|
|
49
|
-
if (this.inputData) {
|
|
50
|
-
let formattedDate = this.datePipe.transform(this.inputData, this.dateFormat);
|
|
51
|
-
this.dateForm.controls["dateInput"].setValue(formattedDate);
|
|
52
|
-
}
|
|
53
|
-
this.changeDetectorRef.detectChanges();
|
|
54
|
-
}
|
|
55
|
-
onChanges() { }
|
|
56
|
-
ngDoCheck() {
|
|
57
|
-
// this is the only way I found to have the focus on the startDate day when the user opens
|
|
58
|
-
// the popup. We only want to focus once otherwise user can not click anywhere else in the popup
|
|
59
|
-
if (this.dp && !this.focused) {
|
|
60
|
-
this.dp.focus();
|
|
61
|
-
this.focused = true;
|
|
62
|
-
}
|
|
63
|
-
// mark picker for focusing next time it is open
|
|
64
|
-
if (this.state === 0) {
|
|
65
|
-
this.focused = false;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
updateInternalDataFromModel() {
|
|
69
|
-
if (this.inputData) {
|
|
70
|
-
this.modifiedData = new Date(this.inputData);
|
|
71
|
-
let md = new Date(this.inputData);
|
|
72
|
-
this.startDate = { year: md.getFullYear(), month: md.getMonth() + 1, day: md.getDate() };
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
let today = new Date();
|
|
76
|
-
this.startDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* Updates the bound data with the working data.
|
|
81
|
-
*/
|
|
82
|
-
updateModelFromInternalData() {
|
|
83
|
-
if (this.modifiedData) {
|
|
84
|
-
let dsDate = this.ngbDateToString(this.modifiedData);
|
|
85
|
-
if (dsDate) {
|
|
86
|
-
this.inputData = dsDate;
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
this.inputData = this.modifiedData;
|
|
90
|
-
}
|
|
91
|
-
const formattedModifiedDate = this.datePipe.transform(this.inputData, this.dateFormat);
|
|
92
|
-
this.dateForm.controls["dateInput"].setValue(formattedModifiedDate, { emitEvent: false });
|
|
93
|
-
}
|
|
94
|
-
this.inputDataChange.emit(this.inputData);
|
|
95
|
-
this.updateInternalDataFromModel();
|
|
96
|
-
}
|
|
97
|
-
clear() {
|
|
98
|
-
this.modifiedData = null;
|
|
99
|
-
this.inputData = null;
|
|
100
|
-
this.dateForm.controls["dateInput"].setValue("");
|
|
101
|
-
this.validate = false;
|
|
102
|
-
let today = new Date();
|
|
103
|
-
this.startDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
104
|
-
this.state = 0;
|
|
105
|
-
this.dateForm.controls["dateInput"].setValue("");
|
|
106
|
-
this.inputDataChange.emit(this.inputData);
|
|
107
|
-
}
|
|
108
|
-
onKeyUpInput(event) {
|
|
109
|
-
// Check for when the input is deleted before being saved
|
|
110
|
-
if (event.key === "Delete" || event.key === "Backspace") {
|
|
111
|
-
if (this.dateForm.controls["dataInput"].value.length === 0) {
|
|
112
|
-
this.clear();
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
// update range so that the date range validator can run accurately
|
|
116
|
-
DateValidator.minValue = this.minDate;
|
|
117
|
-
DateValidator.maxValue = this.maxDate;
|
|
118
|
-
// Get the updated dateForm value
|
|
119
|
-
let eventTarget = event.target;
|
|
120
|
-
let inputValue = eventTarget.value;
|
|
121
|
-
this.dateForm.controls["dateInput"].patchValue(inputValue);
|
|
122
|
-
// if we have a good date and is within the range update the picker
|
|
123
|
-
if (DateValidator.inRange(this.dateForm.controls["dateInput"])) {
|
|
124
|
-
this.validate = false;
|
|
125
|
-
this.inputData = this.datePipe.transform(this.dateForm.controls["dateInput"].value, this.dateFormat);
|
|
126
|
-
this.updateInternalDataFromModel();
|
|
127
|
-
this.dateForm.controls["dateInput"].setValue(this.inputData);
|
|
128
|
-
this.inputDataChange.emit(this.inputData);
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
this.validate = true;
|
|
132
|
-
}
|
|
133
|
-
// // only validate if user is typing
|
|
134
|
-
// if (!this.validate) {
|
|
135
|
-
// this.validate = true;
|
|
136
|
-
// this.dateForm.controls["dateInput"].setValue("");
|
|
137
|
-
//
|
|
138
|
-
// // clear the date picker
|
|
139
|
-
// this.modifiedData = null;
|
|
140
|
-
// this.inputData = null;
|
|
141
|
-
// let today: Date = new Date();
|
|
142
|
-
// this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};
|
|
143
|
-
// this.state = 0;
|
|
144
|
-
// this.inputDataChange.emit(this.inputData);
|
|
145
|
-
// }
|
|
146
|
-
}
|
|
147
|
-
/**
|
|
148
|
-
* NgbDateStruct stores day, month and year. Convert this to ISO8601.
|
|
149
|
-
*
|
|
150
|
-
* @param date
|
|
151
|
-
* @returns {any}
|
|
152
|
-
*/
|
|
153
|
-
ngbDateToString(date) {
|
|
154
|
-
if (date === undefined || date === null) {
|
|
155
|
-
return null;
|
|
156
|
-
}
|
|
157
|
-
else if (date.year === undefined || date.month === undefined || date.day === undefined) {
|
|
158
|
-
return null;
|
|
159
|
-
}
|
|
160
|
-
return date.year + "-" + ((date.month < 10) ? "0" : "") + date.month + "-" + ((date.day < 10) ? "0" : "") + date.day + "T12:00-06:00";
|
|
161
|
-
}
|
|
162
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
163
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Input, ViewChild, Output, ChangeDetectorRef } from "@angular/core";
|
|
2
|
+
import { DatePipe } from "@angular/common";
|
|
3
|
+
import { UntypedFormBuilder, UntypedFormControl } from "@angular/forms";
|
|
4
|
+
import { DateValidator } from "./date-validator";
|
|
5
|
+
import { DateBase } from "./date-base";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/forms";
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "@ng-bootstrap/ng-bootstrap";
|
|
10
|
+
/**
|
|
11
|
+
* TODO: Confirm timezone behavior.
|
|
12
|
+
*
|
|
13
|
+
* @since 4.0.0
|
|
14
|
+
*/
|
|
15
|
+
export class DateComponent extends DateBase {
|
|
16
|
+
constructor(elementRef, formBuilder, datePipe, changeDetectorRef) {
|
|
17
|
+
super(elementRef);
|
|
18
|
+
this.formBuilder = formBuilder;
|
|
19
|
+
this.datePipe = datePipe;
|
|
20
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
21
|
+
// Binded data from the parent component.
|
|
22
|
+
this.dateFormat = "shortDate";
|
|
23
|
+
this.inputDataChange = new EventEmitter();
|
|
24
|
+
// only validate if user is typing
|
|
25
|
+
this.validate = false;
|
|
26
|
+
this.focused = false;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
*
|
|
30
|
+
*/
|
|
31
|
+
ngOnInit() {
|
|
32
|
+
this.dateForm = this.formBuilder.group({
|
|
33
|
+
dateInput: new UntypedFormControl("", [DateValidator.dateFormatValidator, DateValidator.dateRangeValidator])
|
|
34
|
+
});
|
|
35
|
+
this.onChanges();
|
|
36
|
+
this.updateInternalDataFromModel();
|
|
37
|
+
// set the minDate to 20 years in the past by default
|
|
38
|
+
let today = new Date();
|
|
39
|
+
if (!this.minDate) {
|
|
40
|
+
this.minDate = { year: today.getFullYear() - 20, month: today.getMonth() + 1, day: today.getDate() };
|
|
41
|
+
}
|
|
42
|
+
// set max date to today by default
|
|
43
|
+
if (!this.maxDate) {
|
|
44
|
+
this.maxDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
ngAfterViewInit() {
|
|
48
|
+
// Fill the input with the bound data set in the parent component.
|
|
49
|
+
if (this.inputData) {
|
|
50
|
+
let formattedDate = this.datePipe.transform(this.inputData, this.dateFormat);
|
|
51
|
+
this.dateForm.controls["dateInput"].setValue(formattedDate);
|
|
52
|
+
}
|
|
53
|
+
this.changeDetectorRef.detectChanges();
|
|
54
|
+
}
|
|
55
|
+
onChanges() { }
|
|
56
|
+
ngDoCheck() {
|
|
57
|
+
// this is the only way I found to have the focus on the startDate day when the user opens
|
|
58
|
+
// the popup. We only want to focus once otherwise user can not click anywhere else in the popup
|
|
59
|
+
if (this.dp && !this.focused) {
|
|
60
|
+
this.dp.focus();
|
|
61
|
+
this.focused = true;
|
|
62
|
+
}
|
|
63
|
+
// mark picker for focusing next time it is open
|
|
64
|
+
if (this.state === 0) {
|
|
65
|
+
this.focused = false;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
updateInternalDataFromModel() {
|
|
69
|
+
if (this.inputData) {
|
|
70
|
+
this.modifiedData = new Date(this.inputData);
|
|
71
|
+
let md = new Date(this.inputData);
|
|
72
|
+
this.startDate = { year: md.getFullYear(), month: md.getMonth() + 1, day: md.getDate() };
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
let today = new Date();
|
|
76
|
+
this.startDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Updates the bound data with the working data.
|
|
81
|
+
*/
|
|
82
|
+
updateModelFromInternalData() {
|
|
83
|
+
if (this.modifiedData) {
|
|
84
|
+
let dsDate = this.ngbDateToString(this.modifiedData);
|
|
85
|
+
if (dsDate) {
|
|
86
|
+
this.inputData = dsDate;
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
this.inputData = this.modifiedData;
|
|
90
|
+
}
|
|
91
|
+
const formattedModifiedDate = this.datePipe.transform(this.inputData, this.dateFormat);
|
|
92
|
+
this.dateForm.controls["dateInput"].setValue(formattedModifiedDate, { emitEvent: false });
|
|
93
|
+
}
|
|
94
|
+
this.inputDataChange.emit(this.inputData);
|
|
95
|
+
this.updateInternalDataFromModel();
|
|
96
|
+
}
|
|
97
|
+
clear() {
|
|
98
|
+
this.modifiedData = null;
|
|
99
|
+
this.inputData = null;
|
|
100
|
+
this.dateForm.controls["dateInput"].setValue("");
|
|
101
|
+
this.validate = false;
|
|
102
|
+
let today = new Date();
|
|
103
|
+
this.startDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
104
|
+
this.state = 0;
|
|
105
|
+
this.dateForm.controls["dateInput"].setValue("");
|
|
106
|
+
this.inputDataChange.emit(this.inputData);
|
|
107
|
+
}
|
|
108
|
+
onKeyUpInput(event) {
|
|
109
|
+
// Check for when the input is deleted before being saved
|
|
110
|
+
if (event.key === "Delete" || event.key === "Backspace") {
|
|
111
|
+
if (this.dateForm.controls["dataInput"].value.length === 0) {
|
|
112
|
+
this.clear();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// update range so that the date range validator can run accurately
|
|
116
|
+
DateValidator.minValue = this.minDate;
|
|
117
|
+
DateValidator.maxValue = this.maxDate;
|
|
118
|
+
// Get the updated dateForm value
|
|
119
|
+
let eventTarget = event.target;
|
|
120
|
+
let inputValue = eventTarget.value;
|
|
121
|
+
this.dateForm.controls["dateInput"].patchValue(inputValue);
|
|
122
|
+
// if we have a good date and is within the range update the picker
|
|
123
|
+
if (DateValidator.inRange(this.dateForm.controls["dateInput"])) {
|
|
124
|
+
this.validate = false;
|
|
125
|
+
this.inputData = this.datePipe.transform(this.dateForm.controls["dateInput"].value, this.dateFormat);
|
|
126
|
+
this.updateInternalDataFromModel();
|
|
127
|
+
this.dateForm.controls["dateInput"].setValue(this.inputData);
|
|
128
|
+
this.inputDataChange.emit(this.inputData);
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
this.validate = true;
|
|
132
|
+
}
|
|
133
|
+
// // only validate if user is typing
|
|
134
|
+
// if (!this.validate) {
|
|
135
|
+
// this.validate = true;
|
|
136
|
+
// this.dateForm.controls["dateInput"].setValue("");
|
|
137
|
+
//
|
|
138
|
+
// // clear the date picker
|
|
139
|
+
// this.modifiedData = null;
|
|
140
|
+
// this.inputData = null;
|
|
141
|
+
// let today: Date = new Date();
|
|
142
|
+
// this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};
|
|
143
|
+
// this.state = 0;
|
|
144
|
+
// this.inputDataChange.emit(this.inputData);
|
|
145
|
+
// }
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* NgbDateStruct stores day, month and year. Convert this to ISO8601.
|
|
149
|
+
*
|
|
150
|
+
* @param date
|
|
151
|
+
* @returns {any}
|
|
152
|
+
*/
|
|
153
|
+
ngbDateToString(date) {
|
|
154
|
+
if (date === undefined || date === null) {
|
|
155
|
+
return null;
|
|
156
|
+
}
|
|
157
|
+
else if (date.year === undefined || date.month === undefined || date.day === undefined) {
|
|
158
|
+
return null;
|
|
159
|
+
}
|
|
160
|
+
return date.year + "-" + ((date.month < 10) ? "0" : "") + date.month + "-" + ((date.day < 10) ? "0" : "") + date.day + "T12:00-06:00";
|
|
161
|
+
}
|
|
162
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DateComponent, deps: [{ token: i0.ElementRef }, { token: i1.UntypedFormBuilder }, { token: i2.DatePipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
163
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: DateComponent, selector: "hci-date", inputs: { dateFormat: "dateFormat", minDate: "minDate", maxDate: "maxDate", label: "label", inputData: "inputData", modifiedData: "modifiedData" }, outputs: { inputDataChange: "inputDataChange" }, host: { listeners: { "document:click": "handleOutsideEvent($event)" } }, providers: [DatePipe, DateValidator], viewQueries: [{ propertyName: "dp", first: true, predicate: ["dp"], descendants: true }], usesInheritance: true, ngImport: i0, template: `
|
|
164
164
|
<div class="form-group">
|
|
165
165
|
<div class="input-group d-flex">
|
|
166
166
|
<form [formGroup]="dateForm" class="flex-grow-1">
|
|
@@ -221,10 +221,10 @@ export class DateComponent extends DateBase {
|
|
|
221
221
|
</div>
|
|
222
222
|
</div>
|
|
223
223
|
|
|
224
|
-
`, isInline: true, styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.NgbDatepicker, selector: "ngb-datepicker", inputs: ["contentTemplate", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "maxDate", "minDate", "navigation", "outsideDays", "showWeekNumbers", "startDate", "weekdays"], outputs: ["navigate", "dateSelect"], exportAs: ["ngbDatepicker"] }] }); }
|
|
225
|
-
}
|
|
226
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
227
|
-
type: Component,
|
|
224
|
+
`, isInline: true, styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.NgbDatepicker, selector: "ngb-datepicker", inputs: ["contentTemplate", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "maxDate", "minDate", "navigation", "outsideDays", "showWeekNumbers", "startDate", "weekdays"], outputs: ["navigate", "dateSelect"], exportAs: ["ngbDatepicker"] }] }); }
|
|
225
|
+
}
|
|
226
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DateComponent, decorators: [{
|
|
227
|
+
type: Component,
|
|
228
228
|
args: [{ selector: "hci-date", providers: [DatePipe, DateValidator], template: `
|
|
229
229
|
<div class="form-group">
|
|
230
230
|
<div class="input-group d-flex">
|
|
@@ -286,25 +286,25 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
286
286
|
</div>
|
|
287
287
|
</div>
|
|
288
288
|
|
|
289
|
-
`, host: {
|
|
290
|
-
"(document:click)": "handleOutsideEvent($event)"
|
|
291
|
-
} }]
|
|
292
|
-
}], ctorParameters:
|
|
293
|
-
type: ViewChild,
|
|
294
|
-
args: ["dp", { static: false }]
|
|
295
|
-
}], dateFormat: [{
|
|
296
|
-
type: Input
|
|
297
|
-
}], minDate: [{
|
|
298
|
-
type: Input
|
|
299
|
-
}], maxDate: [{
|
|
300
|
-
type: Input
|
|
301
|
-
}], label: [{
|
|
302
|
-
type: Input
|
|
303
|
-
}], inputData: [{
|
|
304
|
-
type: Input
|
|
305
|
-
}], modifiedData: [{
|
|
306
|
-
type: Input
|
|
307
|
-
}], inputDataChange: [{
|
|
308
|
-
type: Output
|
|
309
|
-
}] } });
|
|
310
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-date.component.js","sourceRoot":"","sources":["../../../../projects/input/src/date/date-date.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, ElementRef, EventEmitter, Input, OnInit, DoCheck, AfterViewInit, ViewChild, Output,\r\n  ChangeDetectorRef\r\n} from \"@angular/core\";\r\nimport {DatePipe} from \"@angular/common\";\r\nimport {UntypedFormBuilder, UntypedFormGroup, UntypedFormControl} from \"@angular/forms\";\r\n\r\nimport {NgbDateStruct} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport {DateValidator} from \"./date-validator\";\r\nimport {DateBase} from \"./date-base\";\r\n\r\nimport * as moment from \"moment\";\r\n\r\n/**\r\n * TODO: Confirm timezone behavior.\r\n *\r\n * @since 4.0.0\r\n */\r\n@Component({\r\n  selector: \"hci-date\",\r\n  providers: [DatePipe, DateValidator],\r\n  template: `\r\n      <div class=\"form-group\">\r\n         <div class=\"input-group d-flex\">\r\n           <form [formGroup]=\"dateForm\" class=\"flex-grow-1\">\r\n             <div class=\"date-wrapper\">\r\n               <div class=\"input-group-append\">\r\n                 <input type=\"text\" (keyup)=\"onKeyUpInput($event)\"\r\n                        (ngModelChange)=\"onChange($event)\" class=\"form-control\"\r\n                        formControlName=\"dateInput\" placeholder=\"{{label}}\"\r\n                        aria-label=\"date\" aria-describedby=\"basic-addon2\" />\r\n                 <span class=\"input-group-text\" id=\"basic-addon2\" (click)=\"clear()\">\r\n                   <i class=\"fas fa-times\"></i>\r\n                 </span>\r\n                 <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"startEdit();\">\r\n                   <i class=\"fas fa-calendar-alt\"></i>\r\n                 </button>\r\n               </div>\r\n               <div *ngIf=\"validate && dateForm.get('dateInput').hasError('dateFormatValidator')\"\r\n                    class=\"invalid-date\">Enter date as M/D/YYYY or MM/DD/YYYY</div>\r\n               <div *ngIf=\"validate && dateForm.get('dateInput').hasError('dateRangeValidator')\"\r\n                    class=\"invalid-date\">Invalid Date Range</div>\r\n             </div>\r\n           </form>\r\n           <!--\r\n             We will replace the nbg date picker with material date picker\r\n           -->\r\n<!--           <form [formGroup]=\"dateForm\" class=\"flex-grow-1\">-->\r\n<!--             <div class=\"date-wrapper\">-->\r\n<!--               <div class=\"input-group-append\">-->\r\n<!--                  <mat-form-field appearance=\"outline\" [style.padding-top.em]=\"0.5\"-->\r\n<!--                                  [style.padding-bottom.em]=\"0.5\">-->\r\n<!--                    <input matInput (keypress)=\"onKeyPressInput($event)\"-->\r\n<!--                           [min]=\"minDate\" [max]=\"maxDate\" [matDatepicker]=\"datePicker\"-->\r\n<!--                           formControlName=\"dateInput\" placeholder=\"{{label}}\" aria-label=\"date\"-->\r\n<!--                           aria-describedby=\"basic-addon2\">-->\r\n<!--                    <mat-datepicker-toggle matSuffix [for]=\"datePicker\"></mat-datepicker-toggle>-->\r\n<!--                    <mat-datepicker #datePicker></mat-datepicker>-->\r\n<!--                    <mat-error *ngIf=\"validate && dateForm.get('dateInput').hasError('dateFormatValidator')\"-->\r\n<!--                               class=\"invalid-date\">-->\r\n<!--                      Enter date as M/D/YYYY or MM/DD/YYYY-->\r\n<!--                    </mat-error>-->\r\n<!--                    <mat-error *ngIf=\"validate && dateForm.get('dateInput').hasError('dateRangeValidator')\"-->\r\n<!--                               class=\"invalid-date\">-->\r\n<!--                      Invalid Date Range-->\r\n<!--                    </mat-error>-->\r\n<!--                  </mat-form-field>-->\r\n<!--               </div>-->\r\n<!--             </div>-->\r\n<!--          </form>-->\r\n         </div>\r\n      </div>\r\n      <div *ngIf=\"state === 1\" class=\"inline-editing\">\r\n        <ngb-datepicker [ngModel]=\"modifiedData\" #dp [startDate]=\"startDate\" [minDate]=\"minDate\"\r\n                        [maxDate]=\"maxDate\" (keydown)=\"onKeyDown($event)\"\r\n                        (ngModelChange)=\"onChange($event)\" (select)=\"save()\"></ngb-datepicker>\r\n        <div class=\"inline-hover-save-options\">\r\n<!--          <a class=\"btn ii-so-btn save\" (click)=\"save()\"><i class=\"fas fa-check\"></i></a>-->\r\n<!--          <a class=\"btn ii-so-btn cancel\" (click)=\"cancel()\"><i class=\"fas fa-times\"></i></a>-->\r\n        </div>\r\n      </div>\r\n\r\n  `,\r\n  styles: [`\r\n    /*::ng-deep mat-form-field .mat-form-field-flex > .mat-form-field-infix{*/\r\n    /*  padding: 0.25em 0 0.5em 0;*/\r\n    /*}*/\r\n  `],\r\n  host: {\r\n    \"(document:click)\": \"handleOutsideEvent($event)\"\r\n  }\r\n})\r\n\r\nexport class DateComponent extends DateBase implements OnInit, DoCheck, AfterViewInit {\r\n\r\n  @ViewChild(\"dp\", {static: false}) dp: any;\r\n\r\n  // Binded data from the parent component.\r\n  @Input() dateFormat: string = \"shortDate\";\r\n  // @Input() dateFormat: string = \"MM/d/yyyy\"; //For testing only\r\n  startDate;\r\n  @Input() minDate;\r\n  @Input() maxDate;\r\n  @Input() label: string;\r\n  labelDate: string;\r\n  @Input() inputData: Object;\r\n  // The data used in our input.  We stored this as well as the inputData so we can cancel the edit and preserve the original data.\r\n  @Input() modifiedData: Object;\r\n\r\n  @Output() inputDataChange = new EventEmitter<any>();\r\n\r\n  dateForm: UntypedFormGroup;\r\n  dateInput: UntypedFormControl;\r\n  // only validate if user is typing\r\n  validate: boolean = false;\r\n\r\n  private focused: boolean = false;\r\n\r\n  constructor(elementRef: ElementRef, private formBuilder: UntypedFormBuilder, private datePipe: DatePipe, private changeDetectorRef: ChangeDetectorRef) {\r\n    super(elementRef);\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  ngOnInit() {\r\n    this.dateForm = this.formBuilder.group({\r\n       dateInput : new UntypedFormControl(\"\", [DateValidator.dateFormatValidator, DateValidator.dateRangeValidator])\r\n    });\r\n    this.onChanges();\r\n\r\n    this.updateInternalDataFromModel();\r\n    // set the minDate to 20 years in the past by default\r\n    let today = new Date();\r\n    if (!this.minDate) {\r\n        this.minDate = {year: today.getFullYear() - 20, month: today.getMonth() + 1, day: today.getDate()};\r\n    }\r\n    // set max date to today by default\r\n    if (!this.maxDate) {\r\n        this.maxDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // Fill the input with the bound data set in the parent component.\r\n    if (this.inputData) {\r\n      let formattedDate = this.datePipe.transform(<string>this.inputData, this.dateFormat);\r\n      this.dateForm.controls[\"dateInput\"].setValue(formattedDate);\r\n    }\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  onChanges(): void {}\r\n\r\n\r\n  ngDoCheck() {\r\n    // this is the only way I found to have the focus on the startDate day when the user opens\r\n    // the popup. We only want to focus once otherwise user can not click anywhere else in the popup\r\n    if (this.dp && !this.focused) {\r\n        this.dp.focus();\r\n        this.focused = true;\r\n    }\r\n    // mark picker for focusing next time it is open\r\n    if (this.state === 0) {\r\n        this.focused = false;\r\n    }\r\n  }\r\n\r\n  public updateInternalDataFromModel() {\r\n     if (this.inputData) {\r\n         this.modifiedData = new Date(<string>this.inputData);\r\n         let md: Date = new Date(<string>this.inputData);\r\n         this.startDate = {year: md.getFullYear(), month: md.getMonth() + 1, day: md.getDate()};\r\n     } else {\r\n         let today: Date = new Date();\r\n         this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n     }\r\n  }\r\n\r\n  /**\r\n   * Updates the bound data with the working data.\r\n   */\r\n  public updateModelFromInternalData() {\r\n     if (this.modifiedData) {\r\n         let dsDate = this.ngbDateToString(<NgbDateStruct>this.modifiedData);\r\n         if (dsDate) {\r\n            this.inputData = dsDate;\r\n         } else {\r\n            this.inputData = this.modifiedData;\r\n         }\r\n\r\n         const formattedModifiedDate = this.datePipe.transform(<string>this.inputData, this.dateFormat);\r\n         this.dateForm.controls[\"dateInput\"].setValue(formattedModifiedDate, { emitEvent: false});\r\n\r\n     }\r\n     this.inputDataChange.emit(this.inputData);\r\n     this.updateInternalDataFromModel();\r\n  }\r\n\r\n  public clear() {\r\n      this.modifiedData = null;\r\n      this.inputData = null;\r\n      this.dateForm.controls[\"dateInput\"].setValue(\"\");\r\n      this.validate = false;\r\n      let today: Date = new Date();\r\n      this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n      this.state = 0;\r\n      this.dateForm.controls[\"dateInput\"].setValue(\"\");\r\n      this.inputDataChange.emit(this.inputData);\r\n  }\r\n\r\n  public onKeyUpInput(event: KeyboardEvent) {\r\n    // Check for when the input is deleted before being saved\r\n    if(event.key === \"Delete\" || event.key === \"Backspace\") {\r\n      if(this.dateForm.controls[\"dataInput\"].value.length === 0) {\r\n        this.clear();\r\n      }\r\n    }\r\n\r\n     // update range so that the date range validator can run accurately\r\n     DateValidator.minValue = this.minDate;\r\n     DateValidator.maxValue = this.maxDate;\r\n\r\n    // Get the updated dateForm value\r\n     let eventTarget = event.target as HTMLInputElement;\r\n     let inputValue = eventTarget.value;\r\n     this.dateForm.controls[\"dateInput\"].patchValue(inputValue);\r\n\r\n     // if we have a good date and is within the range update the picker\r\n     if (DateValidator.inRange(this.dateForm.controls[\"dateInput\"])) {\r\n         this.validate = false;\r\n         this.inputData = this.datePipe.transform(this.dateForm.controls[\"dateInput\"].value, this.dateFormat);\r\n         this.updateInternalDataFromModel();\r\n         this.dateForm.controls[\"dateInput\"].setValue(this.inputData);\r\n         this.inputDataChange.emit(this.inputData);\r\n     } else {\r\n       this.validate = true;\r\n     }\r\n\r\n      // // only validate if user is typing\r\n      // if (!this.validate) {\r\n      //   this.validate = true;\r\n      //   this.dateForm.controls[\"dateInput\"].setValue(\"\");\r\n      //\r\n      //   // clear the date picker\r\n      //   this.modifiedData = null;\r\n      //   this.inputData = null;\r\n      //   let today: Date = new Date();\r\n      //   this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n      //   this.state = 0;\r\n      //   this.inputDataChange.emit(this.inputData);\r\n      // }\r\n  }\r\n\r\n  /**\r\n   * NgbDateStruct stores day, month and year.  Convert this to ISO8601.\r\n   *\r\n   * @param date\r\n   * @returns {any}\r\n   */\r\n  private ngbDateToString(date: NgbDateStruct): string {\r\n    if (date === undefined || date === null) {\r\n      return null;\r\n    } else if (date.year === undefined || date.month === undefined || date.day === undefined) {\r\n      return null;\r\n    }\r\n\r\n    return date.year + \"-\" + ((date.month < 10) ? \"0\" : \"\") + date.month + \"-\" + ((date.day < 10) ? \"0\" : \"\") + date.day + \"T12:00-06:00\";\r\n  }\r\n\r\n}\r\n"]}
|
|
289
|
+
`, host: {
|
|
290
|
+
"(document:click)": "handleOutsideEvent($event)"
|
|
291
|
+
} }]
|
|
292
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.UntypedFormBuilder }, { type: i2.DatePipe }, { type: i0.ChangeDetectorRef }], propDecorators: { dp: [{
|
|
293
|
+
type: ViewChild,
|
|
294
|
+
args: ["dp", { static: false }]
|
|
295
|
+
}], dateFormat: [{
|
|
296
|
+
type: Input
|
|
297
|
+
}], minDate: [{
|
|
298
|
+
type: Input
|
|
299
|
+
}], maxDate: [{
|
|
300
|
+
type: Input
|
|
301
|
+
}], label: [{
|
|
302
|
+
type: Input
|
|
303
|
+
}], inputData: [{
|
|
304
|
+
type: Input
|
|
305
|
+
}], modifiedData: [{
|
|
306
|
+
type: Input
|
|
307
|
+
}], inputDataChange: [{
|
|
308
|
+
type: Output
|
|
309
|
+
}] } });
|
|
310
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-date.component.js","sourceRoot":"","sources":["../../../../projects/input/src/date/date-date.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,KAAK,EAAkC,SAAS,EAAE,MAAM,EAC7F,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAC,kBAAkB,EAAoB,kBAAkB,EAAC,MAAM,gBAAgB,CAAC;AAIxF,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,QAAQ,EAAC,MAAM,aAAa,CAAC;;;;;AAIrC;;;;GAIG;AA4EH,MAAM,OAAO,aAAc,SAAQ,QAAQ;IAyBzC,YAAY,UAAsB,EAAU,WAA+B,EAAU,QAAkB,EAAU,iBAAoC;QACnJ,KAAK,CAAC,UAAU,CAAC,CAAC;QADwB,gBAAW,GAAX,WAAW,CAAoB;QAAU,aAAQ,GAAR,QAAQ,CAAU;QAAU,sBAAiB,GAAjB,iBAAiB,CAAmB;QArBrJ,yCAAyC;QAChC,eAAU,GAAW,WAAW,CAAC;QAWhC,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAIpD,kCAAkC;QAClC,aAAQ,GAAY,KAAK,CAAC;QAElB,YAAO,GAAY,KAAK,CAAC;IAIjC,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACpC,SAAS,EAAG,IAAI,kBAAkB,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,mBAAmB,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;SAC/G,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjB,IAAI,CAAC,2BAA2B,EAAE,CAAC;QACnC,qDAAqD;QACrD,IAAI,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAChB,IAAI,CAAC,OAAO,GAAG,EAAC,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,OAAO,EAAE,EAAC,CAAC;QACvG,CAAC;QACD,mCAAmC;QACnC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAChB,IAAI,CAAC,OAAO,GAAG,EAAC,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,OAAO,EAAE,EAAC,CAAC;QAClG,CAAC;IACH,CAAC;IAED,eAAe;QACb,kEAAkE;QAClE,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAS,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACrF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC9D,CAAC;QACD,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC;IAED,SAAS,KAAU,CAAC;IAGpB,SAAS;QACP,0FAA0F;QAC1F,gGAAgG;QAChG,IAAI,IAAI,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAC3B,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;QACD,gDAAgD;QAChD,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACzB,CAAC;IACH,CAAC;IAEM,2BAA2B;QAC/B,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,YAAY,GAAG,IAAI,IAAI,CAAS,IAAI,CAAC,SAAS,CAAC,CAAC;YACrD,IAAI,EAAE,GAAS,IAAI,IAAI,CAAS,IAAI,CAAC,SAAS,CAAC,CAAC;YAChD,IAAI,CAAC,SAAS,GAAG,EAAC,IAAI,EAAE,EAAE,CAAC,WAAW,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC,OAAO,EAAE,EAAC,CAAC;QAC3F,CAAC;aAAM,CAAC;YACJ,IAAI,KAAK,GAAS,IAAI,IAAI,EAAE,CAAC;YAC7B,IAAI,CAAC,SAAS,GAAG,EAAC,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,OAAO,EAAE,EAAC,CAAC;QACpG,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,2BAA2B;QAC/B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,MAAM,GAAG,IAAI,CAAC,eAAe,CAAgB,IAAI,CAAC,YAAY,CAAC,CAAC;YACpE,IAAI,MAAM,EAAE,CAAC;gBACV,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACL,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC;YACtC,CAAC;YAED,MAAM,qBAAqB,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAS,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAC/F,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,qBAAqB,EAAE,EAAE,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;QAE7F,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1C,IAAI,CAAC,2BAA2B,EAAE,CAAC;IACtC,CAAC;IAEM,KAAK;QACR,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,KAAK,GAAS,IAAI,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,SAAS,GAAG,EAAC,IAAI,EAAE,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,OAAO,EAAE,EAAC,CAAC;QAChG,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC;IAEM,YAAY,CAAC,KAAoB;QACtC,yDAAyD;QACzD,IAAG,KAAK,CAAC,GAAG,KAAK,QAAQ,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;YACvD,IAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC1D,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,CAAC;QACH,CAAC;QAEA,mEAAmE;QACnE,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC;QACtC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC;QAEvC,iCAAiC;QAChC,IAAI,WAAW,GAAG,KAAK,CAAC,MAA0B,CAAC;QACnD,IAAI,UAAU,GAAG,WAAW,CAAC,KAAK,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QAE3D,mEAAmE;QACnE,IAAI,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC;YAC7D,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACrG,IAAI,CAAC,2BAA2B,EAAE,CAAC;YACnC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC7D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACvB,CAAC;QAEA,qCAAqC;QACrC,wBAAwB;QACxB,0BAA0B;QAC1B,sDAAsD;QACtD,EAAE;QACF,6BAA6B;QAC7B,8BAA8B;QAC9B,2BAA2B;QAC3B,kCAAkC;QAClC,qGAAqG;QACrG,oBAAoB;QACpB,+CAA+C;QAC/C,IAAI;IACR,CAAC;IAED;;;;;OAKG;IACK,eAAe,CAAC,IAAmB;QACzC,IAAI,IAAI,KAAK,SAAS,IAAI,IAAI,KAAK,IAAI,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC;QACd,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YACzF,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,IAAI,CAAC,IAAI,GAAG,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,GAAG,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,GAAG,cAAc,CAAC;IACxI,CAAC;8GA/KU,aAAa;kGAAb,aAAa,iTAzEb,CAAC,QAAQ,EAAE,aAAa,CAAC,2IAC1B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6DT;;2FAWU,aAAa;kBA3EzB,SAAS;+BACE,UAAU,aACT,CAAC,QAAQ,EAAE,aAAa,CAAC,YAC1B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6DT,QAMK;wBACJ,kBAAkB,EAAE,4BAA4B;qBACjD;uKAKiC,EAAE;sBAAnC,SAAS;uBAAC,IAAI,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;gBAGvB,UAAU;sBAAlB,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEI,eAAe;sBAAxB,MAAM","sourcesContent":["import {\r\n  Component, ElementRef, EventEmitter, Input, OnInit, DoCheck, AfterViewInit, ViewChild, Output,\r\n  ChangeDetectorRef\r\n} from \"@angular/core\";\r\nimport {DatePipe} from \"@angular/common\";\r\nimport {UntypedFormBuilder, UntypedFormGroup, UntypedFormControl} from \"@angular/forms\";\r\n\r\nimport {NgbDateStruct} from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport {DateValidator} from \"./date-validator\";\r\nimport {DateBase} from \"./date-base\";\r\n\r\nimport * as moment from \"moment\";\r\n\r\n/**\r\n * TODO: Confirm timezone behavior.\r\n *\r\n * @since 4.0.0\r\n */\r\n@Component({\r\n  selector: \"hci-date\",\r\n  providers: [DatePipe, DateValidator],\r\n  template: `\r\n      <div class=\"form-group\">\r\n         <div class=\"input-group d-flex\">\r\n           <form [formGroup]=\"dateForm\" class=\"flex-grow-1\">\r\n             <div class=\"date-wrapper\">\r\n               <div class=\"input-group-append\">\r\n                 <input type=\"text\" (keyup)=\"onKeyUpInput($event)\"\r\n                        (ngModelChange)=\"onChange($event)\" class=\"form-control\"\r\n                        formControlName=\"dateInput\" placeholder=\"{{label}}\"\r\n                        aria-label=\"date\" aria-describedby=\"basic-addon2\" />\r\n                 <span class=\"input-group-text\" id=\"basic-addon2\" (click)=\"clear()\">\r\n                   <i class=\"fas fa-times\"></i>\r\n                 </span>\r\n                 <button class=\"btn btn-outline-secondary\" type=\"button\" (click)=\"startEdit();\">\r\n                   <i class=\"fas fa-calendar-alt\"></i>\r\n                 </button>\r\n               </div>\r\n               <div *ngIf=\"validate && dateForm.get('dateInput').hasError('dateFormatValidator')\"\r\n                    class=\"invalid-date\">Enter date as M/D/YYYY or MM/DD/YYYY</div>\r\n               <div *ngIf=\"validate && dateForm.get('dateInput').hasError('dateRangeValidator')\"\r\n                    class=\"invalid-date\">Invalid Date Range</div>\r\n             </div>\r\n           </form>\r\n           <!--\r\n             We will replace the nbg date picker with material date picker\r\n           -->\r\n<!--           <form [formGroup]=\"dateForm\" class=\"flex-grow-1\">-->\r\n<!--             <div class=\"date-wrapper\">-->\r\n<!--               <div class=\"input-group-append\">-->\r\n<!--                  <mat-form-field appearance=\"outline\" [style.padding-top.em]=\"0.5\"-->\r\n<!--                                  [style.padding-bottom.em]=\"0.5\">-->\r\n<!--                    <input matInput (keypress)=\"onKeyPressInput($event)\"-->\r\n<!--                           [min]=\"minDate\" [max]=\"maxDate\" [matDatepicker]=\"datePicker\"-->\r\n<!--                           formControlName=\"dateInput\" placeholder=\"{{label}}\" aria-label=\"date\"-->\r\n<!--                           aria-describedby=\"basic-addon2\">-->\r\n<!--                    <mat-datepicker-toggle matSuffix [for]=\"datePicker\"></mat-datepicker-toggle>-->\r\n<!--                    <mat-datepicker #datePicker></mat-datepicker>-->\r\n<!--                    <mat-error *ngIf=\"validate && dateForm.get('dateInput').hasError('dateFormatValidator')\"-->\r\n<!--                               class=\"invalid-date\">-->\r\n<!--                      Enter date as M/D/YYYY or MM/DD/YYYY-->\r\n<!--                    </mat-error>-->\r\n<!--                    <mat-error *ngIf=\"validate && dateForm.get('dateInput').hasError('dateRangeValidator')\"-->\r\n<!--                               class=\"invalid-date\">-->\r\n<!--                      Invalid Date Range-->\r\n<!--                    </mat-error>-->\r\n<!--                  </mat-form-field>-->\r\n<!--               </div>-->\r\n<!--             </div>-->\r\n<!--          </form>-->\r\n         </div>\r\n      </div>\r\n      <div *ngIf=\"state === 1\" class=\"inline-editing\">\r\n        <ngb-datepicker [ngModel]=\"modifiedData\" #dp [startDate]=\"startDate\" [minDate]=\"minDate\"\r\n                        [maxDate]=\"maxDate\" (keydown)=\"onKeyDown($event)\"\r\n                        (ngModelChange)=\"onChange($event)\" (select)=\"save()\"></ngb-datepicker>\r\n        <div class=\"inline-hover-save-options\">\r\n<!--          <a class=\"btn ii-so-btn save\" (click)=\"save()\"><i class=\"fas fa-check\"></i></a>-->\r\n<!--          <a class=\"btn ii-so-btn cancel\" (click)=\"cancel()\"><i class=\"fas fa-times\"></i></a>-->\r\n        </div>\r\n      </div>\r\n\r\n  `,\r\n  styles: [`\r\n    /*::ng-deep mat-form-field .mat-form-field-flex > .mat-form-field-infix{*/\r\n    /*  padding: 0.25em 0 0.5em 0;*/\r\n    /*}*/\r\n  `],\r\n  host: {\r\n    \"(document:click)\": \"handleOutsideEvent($event)\"\r\n  }\r\n})\r\n\r\nexport class DateComponent extends DateBase implements OnInit, DoCheck, AfterViewInit {\r\n\r\n  @ViewChild(\"dp\", {static: false}) dp: any;\r\n\r\n  // Binded data from the parent component.\r\n  @Input() dateFormat: string = \"shortDate\";\r\n  // @Input() dateFormat: string = \"MM/d/yyyy\"; //For testing only\r\n  startDate;\r\n  @Input() minDate;\r\n  @Input() maxDate;\r\n  @Input() label: string;\r\n  labelDate: string;\r\n  @Input() inputData: Object;\r\n  // The data used in our input.  We stored this as well as the inputData so we can cancel the edit and preserve the original data.\r\n  @Input() modifiedData: Object;\r\n\r\n  @Output() inputDataChange = new EventEmitter<any>();\r\n\r\n  dateForm: UntypedFormGroup;\r\n  dateInput: UntypedFormControl;\r\n  // only validate if user is typing\r\n  validate: boolean = false;\r\n\r\n  private focused: boolean = false;\r\n\r\n  constructor(elementRef: ElementRef, private formBuilder: UntypedFormBuilder, private datePipe: DatePipe, private changeDetectorRef: ChangeDetectorRef) {\r\n    super(elementRef);\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  ngOnInit() {\r\n    this.dateForm = this.formBuilder.group({\r\n       dateInput : new UntypedFormControl(\"\", [DateValidator.dateFormatValidator, DateValidator.dateRangeValidator])\r\n    });\r\n    this.onChanges();\r\n\r\n    this.updateInternalDataFromModel();\r\n    // set the minDate to 20 years in the past by default\r\n    let today = new Date();\r\n    if (!this.minDate) {\r\n        this.minDate = {year: today.getFullYear() - 20, month: today.getMonth() + 1, day: today.getDate()};\r\n    }\r\n    // set max date to today by default\r\n    if (!this.maxDate) {\r\n        this.maxDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // Fill the input with the bound data set in the parent component.\r\n    if (this.inputData) {\r\n      let formattedDate = this.datePipe.transform(<string>this.inputData, this.dateFormat);\r\n      this.dateForm.controls[\"dateInput\"].setValue(formattedDate);\r\n    }\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  onChanges(): void {}\r\n\r\n\r\n  ngDoCheck() {\r\n    // this is the only way I found to have the focus on the startDate day when the user opens\r\n    // the popup. We only want to focus once otherwise user can not click anywhere else in the popup\r\n    if (this.dp && !this.focused) {\r\n        this.dp.focus();\r\n        this.focused = true;\r\n    }\r\n    // mark picker for focusing next time it is open\r\n    if (this.state === 0) {\r\n        this.focused = false;\r\n    }\r\n  }\r\n\r\n  public updateInternalDataFromModel() {\r\n     if (this.inputData) {\r\n         this.modifiedData = new Date(<string>this.inputData);\r\n         let md: Date = new Date(<string>this.inputData);\r\n         this.startDate = {year: md.getFullYear(), month: md.getMonth() + 1, day: md.getDate()};\r\n     } else {\r\n         let today: Date = new Date();\r\n         this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n     }\r\n  }\r\n\r\n  /**\r\n   * Updates the bound data with the working data.\r\n   */\r\n  public updateModelFromInternalData() {\r\n     if (this.modifiedData) {\r\n         let dsDate = this.ngbDateToString(<NgbDateStruct>this.modifiedData);\r\n         if (dsDate) {\r\n            this.inputData = dsDate;\r\n         } else {\r\n            this.inputData = this.modifiedData;\r\n         }\r\n\r\n         const formattedModifiedDate = this.datePipe.transform(<string>this.inputData, this.dateFormat);\r\n         this.dateForm.controls[\"dateInput\"].setValue(formattedModifiedDate, { emitEvent: false});\r\n\r\n     }\r\n     this.inputDataChange.emit(this.inputData);\r\n     this.updateInternalDataFromModel();\r\n  }\r\n\r\n  public clear() {\r\n      this.modifiedData = null;\r\n      this.inputData = null;\r\n      this.dateForm.controls[\"dateInput\"].setValue(\"\");\r\n      this.validate = false;\r\n      let today: Date = new Date();\r\n      this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n      this.state = 0;\r\n      this.dateForm.controls[\"dateInput\"].setValue(\"\");\r\n      this.inputDataChange.emit(this.inputData);\r\n  }\r\n\r\n  public onKeyUpInput(event: KeyboardEvent) {\r\n    // Check for when the input is deleted before being saved\r\n    if(event.key === \"Delete\" || event.key === \"Backspace\") {\r\n      if(this.dateForm.controls[\"dataInput\"].value.length === 0) {\r\n        this.clear();\r\n      }\r\n    }\r\n\r\n     // update range so that the date range validator can run accurately\r\n     DateValidator.minValue = this.minDate;\r\n     DateValidator.maxValue = this.maxDate;\r\n\r\n    // Get the updated dateForm value\r\n     let eventTarget = event.target as HTMLInputElement;\r\n     let inputValue = eventTarget.value;\r\n     this.dateForm.controls[\"dateInput\"].patchValue(inputValue);\r\n\r\n     // if we have a good date and is within the range update the picker\r\n     if (DateValidator.inRange(this.dateForm.controls[\"dateInput\"])) {\r\n         this.validate = false;\r\n         this.inputData = this.datePipe.transform(this.dateForm.controls[\"dateInput\"].value, this.dateFormat);\r\n         this.updateInternalDataFromModel();\r\n         this.dateForm.controls[\"dateInput\"].setValue(this.inputData);\r\n         this.inputDataChange.emit(this.inputData);\r\n     } else {\r\n       this.validate = true;\r\n     }\r\n\r\n      // // only validate if user is typing\r\n      // if (!this.validate) {\r\n      //   this.validate = true;\r\n      //   this.dateForm.controls[\"dateInput\"].setValue(\"\");\r\n      //\r\n      //   // clear the date picker\r\n      //   this.modifiedData = null;\r\n      //   this.inputData = null;\r\n      //   let today: Date = new Date();\r\n      //   this.startDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n      //   this.state = 0;\r\n      //   this.inputDataChange.emit(this.inputData);\r\n      // }\r\n  }\r\n\r\n  /**\r\n   * NgbDateStruct stores day, month and year.  Convert this to ISO8601.\r\n   *\r\n   * @param date\r\n   * @returns {any}\r\n   */\r\n  private ngbDateToString(date: NgbDateStruct): string {\r\n    if (date === undefined || date === null) {\r\n      return null;\r\n    } else if (date.year === undefined || date.month === undefined || date.day === undefined) {\r\n      return null;\r\n    }\r\n\r\n    return date.year + \"-\" + ((date.month < 10) ? \"0\" : \"\") + date.month + \"-\" + ((date.day < 10) ? \"0\" : \"\") + date.day + \"T12:00-06:00\";\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
import * as moment from "moment";
|
|
2
|
-
export class DateValidator {
|
|
3
|
-
static { this.minValue = undefined; }
|
|
4
|
-
static { this.maxValue = undefined; }
|
|
5
|
-
static dateFormatValidator(ac) {
|
|
6
|
-
if (ac && ac.value && !moment(ac.value, "M/D/YYYY", true).isValid()) {
|
|
7
|
-
return { "dateFormatValidator": true };
|
|
8
|
-
}
|
|
9
|
-
return null;
|
|
10
|
-
}
|
|
11
|
-
static dateRangeValidator(ac) {
|
|
12
|
-
if (ac && ac.value && DateValidator.minValue && DateValidator.maxValue && moment(ac.value, "M/D/YYYY", true).isValid()) {
|
|
13
|
-
let dateValue = moment(ac.value);
|
|
14
|
-
let minDate = moment(DateValidator.convertNgbStructToDate(DateValidator.minValue));
|
|
15
|
-
let maxDate = moment(DateValidator.convertNgbStructToDate(DateValidator.maxValue));
|
|
16
|
-
if (dateValue.isBefore(minDate, "day") || dateValue.isAfter(maxDate, "day")) {
|
|
17
|
-
return { "dateRangeValidator": true };
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
return null;
|
|
21
|
-
}
|
|
22
|
-
static convertNgbStructToDate(struct) {
|
|
23
|
-
return { year: struct.year, month: struct.month - 1, day: struct.day };
|
|
24
|
-
}
|
|
25
|
-
static inRange(ac) {
|
|
26
|
-
if (ac && ac.value && DateValidator.minValue && DateValidator.maxValue && moment(ac.value, "M/D/YYYY", true).isValid()) {
|
|
27
|
-
let dateValue = moment(ac.value);
|
|
28
|
-
let minDate = moment(DateValidator.convertNgbStructToDate(DateValidator.minValue));
|
|
29
|
-
let maxDate = moment(DateValidator.convertNgbStructToDate(DateValidator.maxValue));
|
|
30
|
-
if (dateValue.isBefore(minDate, "day") || dateValue.isAfter(maxDate, "day")) {
|
|
31
|
-
return false;
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
return true;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
return false;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import * as moment from "moment";
|
|
2
|
+
export class DateValidator {
|
|
3
|
+
static { this.minValue = undefined; }
|
|
4
|
+
static { this.maxValue = undefined; }
|
|
5
|
+
static dateFormatValidator(ac) {
|
|
6
|
+
if (ac && ac.value && !moment(ac.value, "M/D/YYYY", true).isValid()) {
|
|
7
|
+
return { "dateFormatValidator": true };
|
|
8
|
+
}
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
static dateRangeValidator(ac) {
|
|
12
|
+
if (ac && ac.value && DateValidator.minValue && DateValidator.maxValue && moment(ac.value, "M/D/YYYY", true).isValid()) {
|
|
13
|
+
let dateValue = moment(ac.value);
|
|
14
|
+
let minDate = moment(DateValidator.convertNgbStructToDate(DateValidator.minValue));
|
|
15
|
+
let maxDate = moment(DateValidator.convertNgbStructToDate(DateValidator.maxValue));
|
|
16
|
+
if (dateValue.isBefore(minDate, "day") || dateValue.isAfter(maxDate, "day")) {
|
|
17
|
+
return { "dateRangeValidator": true };
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
static convertNgbStructToDate(struct) {
|
|
23
|
+
return { year: struct.year, month: struct.month - 1, day: struct.day };
|
|
24
|
+
}
|
|
25
|
+
static inRange(ac) {
|
|
26
|
+
if (ac && ac.value && DateValidator.minValue && DateValidator.maxValue && moment(ac.value, "M/D/YYYY", true).isValid()) {
|
|
27
|
+
let dateValue = moment(ac.value);
|
|
28
|
+
let minDate = moment(DateValidator.convertNgbStructToDate(DateValidator.minValue));
|
|
29
|
+
let maxDate = moment(DateValidator.convertNgbStructToDate(DateValidator.maxValue));
|
|
30
|
+
if (dateValue.isBefore(minDate, "day") || dateValue.isAfter(maxDate, "day")) {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
return false;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS12YWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dC9zcmMvZGF0ZS9kYXRlLXZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEtBQUssTUFBTSxNQUFNLFFBQVEsQ0FBQztBQUVqQyxNQUFNLE9BQU8sYUFBYTthQUNqQixhQUFRLEdBQUcsU0FBUyxDQUFDO2FBQ3JCLGFBQVEsR0FBRyxTQUFTLENBQUM7SUFFNUIsTUFBTSxDQUFDLG1CQUFtQixDQUFDLEVBQW1CO1FBQzVDLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxLQUFLLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQztZQUNwRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDekMsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxFQUFtQjtRQUMzQyxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsS0FBSyxJQUFJLGFBQWEsQ0FBQyxRQUFRLElBQUksYUFBYSxDQUFDLFFBQVEsSUFBSSxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQztZQUN2SCxJQUFJLFNBQVMsR0FBRyxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2pDLElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsc0JBQXNCLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDbkYsSUFBSSxPQUFPLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztZQUVuRixJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxJQUFJLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQzVFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxJQUFJLEVBQUUsQ0FBQztZQUN4QyxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVBLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxNQUFNO1FBQ2xDLE9BQU8sRUFBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUssR0FBRyxDQUFDLEVBQUUsR0FBRyxFQUFFLE1BQU0sQ0FBQyxHQUFHLEVBQUMsQ0FBQztJQUN2RSxDQUFDO0lBRUQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFtQjtRQUNoQyxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsS0FBSyxJQUFJLGFBQWEsQ0FBQyxRQUFRLElBQUksYUFBYSxDQUFDLFFBQVEsSUFBSSxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQztZQUN2SCxJQUFJLFNBQVMsR0FBRyxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2pDLElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsc0JBQXNCLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDbkYsSUFBSSxPQUFPLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztZQUVuRixJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxJQUFJLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQzNFLE9BQU8sS0FBSyxDQUFDO1lBQ2hCLENBQUM7aUJBQU0sQ0FBQztnQkFDTCxPQUFPLElBQUksQ0FBQztZQUNmLENBQUM7UUFDSCxDQUFDO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBYnN0cmFjdENvbnRyb2x9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5cclxuaW1wb3J0ICogYXMgbW9tZW50IGZyb20gXCJtb21lbnRcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBEYXRlVmFsaWRhdG9yIHtcclxuICBzdGF0aWMgbWluVmFsdWUgPSB1bmRlZmluZWQ7XHJcbiAgc3RhdGljIG1heFZhbHVlID0gdW5kZWZpbmVkO1xyXG5cclxuICBzdGF0aWMgZGF0ZUZvcm1hdFZhbGlkYXRvcihhYzogQWJzdHJhY3RDb250cm9sKSB7XHJcbiAgICBpZiAoYWMgJiYgYWMudmFsdWUgJiYgIW1vbWVudChhYy52YWx1ZSwgXCJNL0QvWVlZWVwiLCB0cnVlKS5pc1ZhbGlkKCkpIHtcclxuICAgICAgcmV0dXJuIHsgXCJkYXRlRm9ybWF0VmFsaWRhdG9yXCI6IHRydWUgfTtcclxuICAgIH1cclxuICAgIHJldHVybiBudWxsO1xyXG4gIH1cclxuXHJcbiAgc3RhdGljIGRhdGVSYW5nZVZhbGlkYXRvcihhYzogQWJzdHJhY3RDb250cm9sKSB7XHJcbiAgICBpZiAoYWMgJiYgYWMudmFsdWUgJiYgRGF0ZVZhbGlkYXRvci5taW5WYWx1ZSAmJiBEYXRlVmFsaWRhdG9yLm1heFZhbHVlICYmIG1vbWVudChhYy52YWx1ZSwgXCJNL0QvWVlZWVwiLCB0cnVlKS5pc1ZhbGlkKCkpIHtcclxuICAgICAgbGV0IGRhdGVWYWx1ZSA9IG1vbWVudChhYy52YWx1ZSk7XHJcbiAgICAgIGxldCBtaW5EYXRlID0gbW9tZW50KERhdGVWYWxpZGF0b3IuY29udmVydE5nYlN0cnVjdFRvRGF0ZShEYXRlVmFsaWRhdG9yLm1pblZhbHVlKSk7XHJcbiAgICAgIGxldCBtYXhEYXRlID0gbW9tZW50KERhdGVWYWxpZGF0b3IuY29udmVydE5nYlN0cnVjdFRvRGF0ZShEYXRlVmFsaWRhdG9yLm1heFZhbHVlKSk7XHJcblxyXG4gICAgICBpZiAoZGF0ZVZhbHVlLmlzQmVmb3JlKG1pbkRhdGUsIFwiZGF5XCIpIHx8IGRhdGVWYWx1ZS5pc0FmdGVyKG1heERhdGUsIFwiZGF5XCIpKSB7XHJcbiAgICAgICAgcmV0dXJuIHsgXCJkYXRlUmFuZ2VWYWxpZGF0b3JcIjogdHJ1ZSB9O1xyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIG51bGw7XHJcbiAgfVxyXG5cclxuICAgc3RhdGljIGNvbnZlcnROZ2JTdHJ1Y3RUb0RhdGUoc3RydWN0KSB7XHJcbiAgICAgcmV0dXJuIHt5ZWFyOiBzdHJ1Y3QueWVhciwgbW9udGg6IHN0cnVjdC5tb250aCAtIDEsIGRheTogc3RydWN0LmRheX07XHJcbiAgIH1cclxuXHJcbiAgIHN0YXRpYyBpblJhbmdlKGFjOiBBYnN0cmFjdENvbnRyb2wpIHtcclxuICAgICBpZiAoYWMgJiYgYWMudmFsdWUgJiYgRGF0ZVZhbGlkYXRvci5taW5WYWx1ZSAmJiBEYXRlVmFsaWRhdG9yLm1heFZhbHVlICYmIG1vbWVudChhYy52YWx1ZSwgXCJNL0QvWVlZWVwiLCB0cnVlKS5pc1ZhbGlkKCkpIHtcclxuICAgICAgIGxldCBkYXRlVmFsdWUgPSBtb21lbnQoYWMudmFsdWUpO1xyXG4gICAgICAgbGV0IG1pbkRhdGUgPSBtb21lbnQoRGF0ZVZhbGlkYXRvci5jb252ZXJ0TmdiU3RydWN0VG9EYXRlKERhdGVWYWxpZGF0b3IubWluVmFsdWUpKTtcclxuICAgICAgIGxldCBtYXhEYXRlID0gbW9tZW50KERhdGVWYWxpZGF0b3IuY29udmVydE5nYlN0cnVjdFRvRGF0ZShEYXRlVmFsaWRhdG9yLm1heFZhbHVlKSk7XHJcblxyXG4gICAgICAgaWYgKGRhdGVWYWx1ZS5pc0JlZm9yZShtaW5EYXRlLCBcImRheVwiKSB8fCBkYXRlVmFsdWUuaXNBZnRlcihtYXhEYXRlLCBcImRheVwiKSkge1xyXG4gICAgICAgICAgcmV0dXJuIGZhbHNlO1xyXG4gICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgICAgfVxyXG4gICAgIH1cclxuICAgICByZXR1cm4gZmFsc2U7XHJcbiAgIH1cclxufVxyXG4iXX0=
|