@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.
Files changed (54) hide show
  1. package/date/date-base.d.ts +65 -65
  2. package/date/date-date-range.component.d.ts +32 -32
  3. package/date/date-date.component.d.ts +53 -53
  4. package/date/date-validator.d.ts +17 -17
  5. package/date/date.module.d.ts +16 -16
  6. package/dropdown/dropdown-index.d.ts +6 -6
  7. package/dropdown/dropdown-select-result.component.d.ts +23 -23
  8. package/dropdown/dropdown-select.component.d.ts +76 -76
  9. package/dropdown/dropdown.component.d.ts +40 -40
  10. package/dropdown/dropdown.module.d.ts +13 -13
  11. package/dropdown/dropdown.service.d.ts +51 -51
  12. package/dropdown/messages.d.ts +11 -11
  13. package/dropdown/select-item.d.ts +16 -16
  14. package/dropdown/template-dropdown.directive.d.ts +12 -12
  15. package/esm2022/date/date-base.mjs +114 -114
  16. package/esm2022/date/date-date-range.component.mjs +92 -92
  17. package/esm2022/date/date-date.component.mjs +189 -189
  18. package/esm2022/date/date-validator.mjs +40 -40
  19. package/esm2022/date/date.module.mjs +60 -60
  20. package/esm2022/dropdown/dropdown-index.mjs +5 -5
  21. package/esm2022/dropdown/dropdown-select-result.component.mjs +85 -85
  22. package/esm2022/dropdown/dropdown-select.component.mjs +360 -360
  23. package/esm2022/dropdown/dropdown.component.mjs +170 -170
  24. package/esm2022/dropdown/dropdown.module.mjs +50 -50
  25. package/esm2022/dropdown/dropdown.service.mjs +133 -133
  26. package/esm2022/dropdown/messages.mjs +9 -9
  27. package/esm2022/dropdown/select-item.mjs +11 -11
  28. package/esm2022/dropdown/template-dropdown.directive.mjs +26 -26
  29. package/esm2022/huntsman-cancer-institute-input.mjs +4 -4
  30. package/esm2022/index.mjs +19 -19
  31. package/esm2022/inline/inline.component.mjs +179 -179
  32. package/esm2022/inline/inline.module.mjs +28 -28
  33. package/esm2022/search/search.component.mjs +157 -157
  34. package/esm2022/search/search.module.mjs +32 -32
  35. package/esm2022/select/custom-combobox.component.mjs +531 -531
  36. package/esm2022/select/custom-multi-combobox.component.mjs +232 -232
  37. package/esm2022/select/md-multi-select.component.mjs +127 -127
  38. package/esm2022/select/md-select.component.mjs +107 -107
  39. package/esm2022/select/native-select.component.mjs +188 -188
  40. package/esm2022/select/select.module.mjs +83 -83
  41. package/fesm2022/huntsman-cancer-institute-input.mjs +2797 -2797
  42. package/fesm2022/huntsman-cancer-institute-input.mjs.map +1 -1
  43. package/index.d.ts +20 -20
  44. package/inline/inline.component.d.ts +66 -66
  45. package/inline/inline.module.d.ts +9 -9
  46. package/package.json +16 -8
  47. package/search/search.component.d.ts +42 -42
  48. package/search/search.module.d.ts +10 -10
  49. package/select/custom-combobox.component.d.ts +98 -98
  50. package/select/custom-multi-combobox.component.d.ts +50 -50
  51. package/select/md-multi-select.component.d.ts +32 -32
  52. package/select/md-select.component.d.ts +30 -30
  53. package/select/native-select.component.d.ts +37 -37
  54. 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: "16.2.12", 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: "16.2.12", 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: `
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: "16.2.12", ngImport: i0, type: DateComponent, decorators: [{
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: function () { return [{ 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":"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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":"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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"]}
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS12YWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dC9zcmMvZGF0ZS9kYXRlLXZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEtBQUssTUFBTSxNQUFNLFFBQVEsQ0FBQztBQUVqQyxNQUFNLE9BQU8sYUFBYTthQUNqQixhQUFRLEdBQUcsU0FBUyxDQUFDO2FBQ3JCLGFBQVEsR0FBRyxTQUFTLENBQUM7SUFFNUIsTUFBTSxDQUFDLG1CQUFtQixDQUFDLEVBQW1CO1FBQzVDLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxLQUFLLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDbkUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLElBQUksRUFBRSxDQUFDO1NBQ3hDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsTUFBTSxDQUFDLGtCQUFrQixDQUFDLEVBQW1CO1FBQzNDLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxLQUFLLElBQUksYUFBYSxDQUFDLFFBQVEsSUFBSSxhQUFhLENBQUMsUUFBUSxJQUFJLE1BQU0sQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtZQUN0SCxJQUFJLFNBQVMsR0FBRyxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2pDLElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsc0JBQXNCLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDbkYsSUFBSSxPQUFPLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztZQUVuRixJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxJQUFJLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFO2dCQUMzRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsSUFBSSxFQUFFLENBQUM7YUFDdkM7U0FDRjtRQUVELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVBLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxNQUFNO1FBQ2xDLE9BQU8sRUFBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUssR0FBRyxDQUFDLEVBQUUsR0FBRyxFQUFFLE1BQU0sQ0FBQyxHQUFHLEVBQUMsQ0FBQztJQUN2RSxDQUFDO0lBRUQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFtQjtRQUNoQyxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsS0FBSyxJQUFJLGFBQWEsQ0FBQyxRQUFRLElBQUksYUFBYSxDQUFDLFFBQVEsSUFBSSxNQUFNLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDdEgsSUFBSSxTQUFTLEdBQUcsTUFBTSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNqQyxJQUFJLE9BQU8sR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLHNCQUFzQixDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1lBQ25GLElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsc0JBQXNCLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFFbkYsSUFBSSxTQUFTLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsSUFBSSxTQUFTLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsRUFBRTtnQkFDMUUsT0FBTyxLQUFLLENBQUM7YUFDZjtpQkFBTTtnQkFDSixPQUFPLElBQUksQ0FBQzthQUNkO1NBQ0Y7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0Fic3RyYWN0Q29udHJvbH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcblxyXG5pbXBvcnQgKiBhcyBtb21lbnQgZnJvbSBcIm1vbWVudFwiO1xyXG5cclxuZXhwb3J0IGNsYXNzIERhdGVWYWxpZGF0b3Ige1xyXG4gIHN0YXRpYyBtaW5WYWx1ZSA9IHVuZGVmaW5lZDtcclxuICBzdGF0aWMgbWF4VmFsdWUgPSB1bmRlZmluZWQ7XHJcblxyXG4gIHN0YXRpYyBkYXRlRm9ybWF0VmFsaWRhdG9yKGFjOiBBYnN0cmFjdENvbnRyb2wpIHtcclxuICAgIGlmIChhYyAmJiBhYy52YWx1ZSAmJiAhbW9tZW50KGFjLnZhbHVlLCBcIk0vRC9ZWVlZXCIsIHRydWUpLmlzVmFsaWQoKSkge1xyXG4gICAgICByZXR1cm4geyBcImRhdGVGb3JtYXRWYWxpZGF0b3JcIjogdHJ1ZSB9O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIG51bGw7XHJcbiAgfVxyXG5cclxuICBzdGF0aWMgZGF0ZVJhbmdlVmFsaWRhdG9yKGFjOiBBYnN0cmFjdENvbnRyb2wpIHtcclxuICAgIGlmIChhYyAmJiBhYy52YWx1ZSAmJiBEYXRlVmFsaWRhdG9yLm1pblZhbHVlICYmIERhdGVWYWxpZGF0b3IubWF4VmFsdWUgJiYgbW9tZW50KGFjLnZhbHVlLCBcIk0vRC9ZWVlZXCIsIHRydWUpLmlzVmFsaWQoKSkge1xyXG4gICAgICBsZXQgZGF0ZVZhbHVlID0gbW9tZW50KGFjLnZhbHVlKTtcclxuICAgICAgbGV0IG1pbkRhdGUgPSBtb21lbnQoRGF0ZVZhbGlkYXRvci5jb252ZXJ0TmdiU3RydWN0VG9EYXRlKERhdGVWYWxpZGF0b3IubWluVmFsdWUpKTtcclxuICAgICAgbGV0IG1heERhdGUgPSBtb21lbnQoRGF0ZVZhbGlkYXRvci5jb252ZXJ0TmdiU3RydWN0VG9EYXRlKERhdGVWYWxpZGF0b3IubWF4VmFsdWUpKTtcclxuXHJcbiAgICAgIGlmIChkYXRlVmFsdWUuaXNCZWZvcmUobWluRGF0ZSwgXCJkYXlcIikgfHwgZGF0ZVZhbHVlLmlzQWZ0ZXIobWF4RGF0ZSwgXCJkYXlcIikpIHtcclxuICAgICAgICByZXR1cm4geyBcImRhdGVSYW5nZVZhbGlkYXRvclwiOiB0cnVlIH07XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gbnVsbDtcclxuICB9XHJcblxyXG4gICBzdGF0aWMgY29udmVydE5nYlN0cnVjdFRvRGF0ZShzdHJ1Y3QpIHtcclxuICAgICByZXR1cm4ge3llYXI6IHN0cnVjdC55ZWFyLCBtb250aDogc3RydWN0Lm1vbnRoIC0gMSwgZGF5OiBzdHJ1Y3QuZGF5fTtcclxuICAgfVxyXG5cclxuICAgc3RhdGljIGluUmFuZ2UoYWM6IEFic3RyYWN0Q29udHJvbCkge1xyXG4gICAgIGlmIChhYyAmJiBhYy52YWx1ZSAmJiBEYXRlVmFsaWRhdG9yLm1pblZhbHVlICYmIERhdGVWYWxpZGF0b3IubWF4VmFsdWUgJiYgbW9tZW50KGFjLnZhbHVlLCBcIk0vRC9ZWVlZXCIsIHRydWUpLmlzVmFsaWQoKSkge1xyXG4gICAgICAgbGV0IGRhdGVWYWx1ZSA9IG1vbWVudChhYy52YWx1ZSk7XHJcbiAgICAgICBsZXQgbWluRGF0ZSA9IG1vbWVudChEYXRlVmFsaWRhdG9yLmNvbnZlcnROZ2JTdHJ1Y3RUb0RhdGUoRGF0ZVZhbGlkYXRvci5taW5WYWx1ZSkpO1xyXG4gICAgICAgbGV0IG1heERhdGUgPSBtb21lbnQoRGF0ZVZhbGlkYXRvci5jb252ZXJ0TmdiU3RydWN0VG9EYXRlKERhdGVWYWxpZGF0b3IubWF4VmFsdWUpKTtcclxuXHJcbiAgICAgICBpZiAoZGF0ZVZhbHVlLmlzQmVmb3JlKG1pbkRhdGUsIFwiZGF5XCIpIHx8IGRhdGVWYWx1ZS5pc0FmdGVyKG1heERhdGUsIFwiZGF5XCIpKSB7XHJcbiAgICAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICB9XHJcbiAgICAgfVxyXG4gICAgIHJldHVybiBmYWxzZTtcclxuICAgfVxyXG59XHJcbiJdfQ==
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=