i-tech-shared-components 1.1.44 → 1.1.46
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/esm2022/lib/components/date-range-datepicker/date-range-datepicker.component.mjs +28 -3
- package/esm2022/lib/components/date-time-picker/date-time-picker.component.mjs +68 -12
- package/fesm2022/i-tech-shared-components.mjs +94 -13
- package/fesm2022/i-tech-shared-components.mjs.map +1 -1
- package/lib/components/date-range-datepicker/date-range-datepicker.component.d.ts +2 -0
- package/lib/components/date-time-picker/date-time-picker.component.d.ts +10 -6
- package/package.json +1 -1
|
@@ -20,6 +20,7 @@ export class DateRangeDatepickerComponent {
|
|
|
20
20
|
this.resetForm = new EventEmitter();
|
|
21
21
|
this.selectionChange = new EventEmitter();
|
|
22
22
|
this.isOpen = false;
|
|
23
|
+
this.isSelectingRange = false;
|
|
23
24
|
this.dateRangeForm = new UntypedFormGroup({
|
|
24
25
|
startDate: new UntypedFormControl('', [Validators.maxLength(10)]),
|
|
25
26
|
endDate: new UntypedFormControl('', [Validators.maxLength(10)]),
|
|
@@ -63,7 +64,28 @@ export class DateRangeDatepickerComponent {
|
|
|
63
64
|
}, 120);
|
|
64
65
|
}
|
|
65
66
|
setDate(value, element) {
|
|
66
|
-
|
|
67
|
+
const startDate = value[0];
|
|
68
|
+
const endDate = value[1];
|
|
69
|
+
// If this is the start date being selected (matStartDate input)
|
|
70
|
+
if (element === this.min?.nativeElement) {
|
|
71
|
+
// We're starting a new selection process
|
|
72
|
+
this.isSelectingRange = true;
|
|
73
|
+
// Don't emit any event yet
|
|
74
|
+
}
|
|
75
|
+
// If this is the end date being selected (matEndDate input)
|
|
76
|
+
else if (element === this.max?.nativeElement) {
|
|
77
|
+
// We're completing a selection
|
|
78
|
+
this.isSelectingRange = false;
|
|
79
|
+
// Only emit when we have both dates
|
|
80
|
+
if (startDate && endDate) {
|
|
81
|
+
this.selectionChange.emit(value);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
// Handle clear operation (both null)
|
|
85
|
+
else if (startDate === null && endDate === null) {
|
|
86
|
+
this.isSelectingRange = false;
|
|
87
|
+
this.selectionChange.emit(value);
|
|
88
|
+
}
|
|
67
89
|
element.blur();
|
|
68
90
|
}
|
|
69
91
|
keyEventHandler(event, value, element) {
|
|
@@ -72,7 +94,7 @@ export class DateRangeDatepickerComponent {
|
|
|
72
94
|
}
|
|
73
95
|
}
|
|
74
96
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateRangeDatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
75
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateRangeDatepickerComponent, isStandalone: true, selector: "i-tech-mat-range-datepicker", inputs: { label: "label", placeholder: "placeholder", value: "value", defaultValue: "defaultValue", key: "key", submit: "submit", clearValue: "clearValue", errorMessage: "errorMessage", onePlaceholder: "onePlaceholder", hintText: "hintText" }, outputs: { resetForm: "resetForm", selectionChange: "selectionChange" }, viewQueries: [{ propertyName: "picker", first: true, predicate: ["picker"], descendants: true }, { propertyName: "min", first: true, predicate: ["min"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex_column relative mat-date-range-input\"\n [formGroup]=\"dateRangeForm\"\n>\n <div class=\"w-100\" *ngIf=\"label\">\n <mat-label>\n {{ (label || '') | translate }}\n </mat-label>\n </div>\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\n <mat-date-range-input [rangePicker]=\"picker\">\n <input formControlName=\"startDate\"\n [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matStartDate #min\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\n (dateChange)=\"setDate([min.value, max.value || null],min)\">\n <input formControlName=\"endDate\"\n [placeholder]=\"(placeholder ? placeholder[1] : 'End Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matEndDate #max\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\n (dateChange)=\"setDate([min.value, max.value || null],max)\">\n </mat-date-range-input>\n <i-tech-icon-button matSuffix\n [iconName]=\"'cancel'\"\n (buttonClick)=\"selectionChange.emit([null, null])\"\n class=\"default-form-icon-color\"\n *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\n ></i-tech-icon-button>\n <i-tech-icon-button\n matSuffix\n [iconName]=\"'date_range'\"\n (buttonClick)=\"picker.open()\"\n class=\"default-form-icon-color\"\n ></i-tech-icon-button>\n <mat-date-range-picker\n #picker\n (closed)=\"isOpen = false;clickForFocusOut()\"\n (opened)=\"isOpen = true\"\n ></mat-date-range-picker>\n <mat-hint *ngIf=\"hintText && !errorMessage\">{{ hintText }}</mat-hint>\n </mat-form-field>\n</div>\n", dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i3.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i3.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i3.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "component", type: IconButtonComponent, selector: "i-tech-icon-button", inputs: ["size", "type", "iconSvg", "iconName", "tooltip", "disabled"], outputs: ["buttonClick"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }] }); }
|
|
97
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateRangeDatepickerComponent, isStandalone: true, selector: "i-tech-mat-range-datepicker", inputs: { label: "label", placeholder: "placeholder", value: "value", defaultValue: "defaultValue", key: "key", submit: "submit", clearValue: "clearValue", errorMessage: "errorMessage", onePlaceholder: "onePlaceholder", hintText: "hintText" }, outputs: { resetForm: "resetForm", selectionChange: "selectionChange" }, viewQueries: [{ propertyName: "picker", first: true, predicate: ["picker"], descendants: true }, { propertyName: "min", first: true, predicate: ["min"], descendants: true }, { propertyName: "max", first: true, predicate: ["max"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex_column relative mat-date-range-input\"\n [formGroup]=\"dateRangeForm\"\n>\n <div class=\"w-100\" *ngIf=\"label\">\n <mat-label>\n {{ (label || '') | translate }}\n </mat-label>\n </div>\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\n <mat-date-range-input [rangePicker]=\"picker\">\n <input formControlName=\"startDate\"\n [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matStartDate #min\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\n (dateChange)=\"setDate([min.value, max.value || null],min)\">\n <input formControlName=\"endDate\"\n [placeholder]=\"(placeholder ? placeholder[1] : 'End Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matEndDate #max\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\n (dateChange)=\"setDate([min.value, max.value || null],max)\">\n </mat-date-range-input>\n <i-tech-icon-button matSuffix\n [iconName]=\"'cancel'\"\n (buttonClick)=\"selectionChange.emit([null, null])\"\n class=\"default-form-icon-color\"\n *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\n ></i-tech-icon-button>\n <i-tech-icon-button\n matSuffix\n [iconName]=\"'date_range'\"\n (buttonClick)=\"picker.open()\"\n class=\"default-form-icon-color\"\n ></i-tech-icon-button>\n <mat-date-range-picker\n #picker\n (closed)=\"isOpen = false;clickForFocusOut()\"\n (opened)=\"isOpen = true\"\n ></mat-date-range-picker>\n <mat-hint *ngIf=\"hintText && !errorMessage\">{{ hintText }}</mat-hint>\n </mat-form-field>\n</div>\n", dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i3.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i3.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i3.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "component", type: IconButtonComponent, selector: "i-tech-icon-button", inputs: ["size", "type", "iconSvg", "iconName", "tooltip", "disabled"], outputs: ["buttonClick"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }] }); }
|
|
76
98
|
}
|
|
77
99
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateRangeDatepickerComponent, decorators: [{
|
|
78
100
|
type: Component,
|
|
@@ -114,5 +136,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
114
136
|
}], min: [{
|
|
115
137
|
type: ViewChild,
|
|
116
138
|
args: ['min']
|
|
139
|
+
}], max: [{
|
|
140
|
+
type: ViewChild,
|
|
141
|
+
args: ['max']
|
|
117
142
|
}] } });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/date-range-datepicker/date-range-datepicker.component.ts","../../../../../../projects/shared-components/src/lib/components/date-range-datepicker/date-range-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component, ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { MatDatepickerModule, MatDateRangePicker } from \"@angular/material/datepicker\";\nimport { ReactiveFormsModule, UntypedFormControl, UntypedFormGroup, Validators } from \"@angular/forms\";\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\nimport { NgClass, NgIf } from \"@angular/common\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { IconButtonComponent } from \"../icon-button/icon-button.component\";\nimport { DateMaskDirective } from \"../../directives/date-mask.directive\";\n\n@Component({\n  selector: 'i-tech-mat-range-datepicker',\n  templateUrl: './date-range-datepicker.component.html',\n  imports: [\n    MatFormFieldModule,\n    ReactiveFormsModule,\n    MatDatepickerModule,\n    NgClass, NgIf,\n    TranslateModule,\n    IconButtonComponent, DateMaskDirective\n  ],\n  standalone: true\n})\nexport class DateRangeDatepickerComponent implements OnChanges, AfterViewInit {\n  @Input() label?: string;\n  @Input() placeholder?: Array<string>;\n  @Input() value?: Array<string | null>;\n  @Input() defaultValue?: Array<Date>;\n  @Input() key?: {start: string, end: string, title: string};\n  @Input() submit = false;\n  @Input() clearValue = true;\n  @Input() errorMessage = '';\n  @Input() onePlaceholder?: string;\n  @Input() hintText = 'MM/DD/YYYY - MM/DD/YYYY';\n  @Output() resetForm = new EventEmitter<any>();\n  @Output() selectionChange = new EventEmitter<any>();\n  @ViewChild('picker') picker!: MatDateRangePicker<any>;\n  @ViewChild('min') min!: ElementRef;\n  isOpen = false;\n\n  dateRangeForm = new UntypedFormGroup({\n    startDate: new UntypedFormControl('', [Validators.maxLength(10)]),\n    endDate: new UntypedFormControl('', [Validators.maxLength(10)]),\n  });\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      if (this.defaultValue?.length) {\n        this.dateRangeForm.patchValue({\n          startDate: this.defaultValue[0],\n          endDate: this.defaultValue[1]\n        })\n      }\n    })\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    setTimeout(() => {\n      if (changes['value']?.currentValue && !(changes['value'].currentValue[0])) {\n        if (this.picker) {\n          this.dateRangeForm.reset();\n          this.picker.select(null)\n        }\n      } else if (changes['value'] && this.value?.length) {\n        this.dateRangeForm.setValue({\n          startDate: new Date(this.value[0] || ''),\n          endDate: new Date(this.value[1] || '')\n        })\n      }\n    }, 10)\n  }\n\n  clickForFocusOut(): void {\n    setTimeout(() => {\n      this.min.nativeElement.focus();\n      this.min.nativeElement.blur();\n    },120)\n  }\n\n  customErrorStateMatcher = {\n    isErrorState: (control: any, form: any): boolean => {\n      return !!(control && control.invalid && this.submit);\n    }\n  };\n\n  setDate(value: Array<string | null>, element: any): void {\n    this.selectionChange.emit(value);\n    element.blur();\n  }\n\n  keyEventHandler(event: KeyboardEvent,value: Array<string | null>, element: any): void {\n    if (event.code === 'Enter') {\n      this.setDate(value,element)\n    }\n  }\n\n}\n","<div class=\"flex_column relative mat-date-range-input\"\n     [formGroup]=\"dateRangeForm\"\n>\n  <div class=\"w-100\" *ngIf=\"label\">\n    <mat-label>\n      {{ (label || '') | translate }}\n    </mat-label>\n  </div>\n  <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\n    <mat-date-range-input [rangePicker]=\"picker\">\n      <input formControlName=\"startDate\"\n             [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\n             [title]=\"key ? key.title :  'Date'\"\n             [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\n             [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n             matStartDate #min\n             dateMask\n             [errorStateMatcher]=\"customErrorStateMatcher\"\n             [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\n             (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\n             (dateChange)=\"setDate([min.value, max.value || null],min)\">\n      <input formControlName=\"endDate\"\n             [placeholder]=\"(placeholder  ? placeholder[1] : 'End Date')\"\n             [title]=\"key ? key.title :  'Date'\"\n             [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\n             [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n             matEndDate #max\n             dateMask\n             [errorStateMatcher]=\"customErrorStateMatcher\"\n             [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\n             (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\n             (dateChange)=\"setDate([min.value, max.value || null],max)\">\n    </mat-date-range-input>\n    <i-tech-icon-button matSuffix\n                        [iconName]=\"'cancel'\"\n                        (buttonClick)=\"selectionChange.emit([null, null])\"\n                        class=\"default-form-icon-color\"\n                        *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\n    ></i-tech-icon-button>\n    <i-tech-icon-button\n      matSuffix\n      [iconName]=\"'date_range'\"\n      (buttonClick)=\"picker.open()\"\n      class=\"default-form-icon-color\"\n    ></i-tech-icon-button>\n    <mat-date-range-picker\n      #picker\n      (closed)=\"isOpen = false;clickForFocusOut()\"\n      (opened)=\"isOpen = true\"\n    ></mat-date-range-picker>\n    <mat-hint *ngIf=\"hintText && !errorMessage\">{{ hintText }}</mat-hint>\n  </mat-form-field>\n</div>\n"]}
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/date-range-datepicker/date-range-datepicker.component.ts","../../../../../../projects/shared-components/src/lib/components/date-range-datepicker/date-range-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component, ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { MatDatepickerModule, MatDateRangePicker } from \"@angular/material/datepicker\";\nimport { ReactiveFormsModule, UntypedFormControl, UntypedFormGroup, Validators } from \"@angular/forms\";\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\nimport { NgClass, NgIf } from \"@angular/common\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { IconButtonComponent } from \"../icon-button/icon-button.component\";\nimport { DateMaskDirective } from \"../../directives/date-mask.directive\";\n\n@Component({\n  selector: 'i-tech-mat-range-datepicker',\n  templateUrl: './date-range-datepicker.component.html',\n  imports: [\n    MatFormFieldModule,\n    ReactiveFormsModule,\n    MatDatepickerModule,\n    NgClass, NgIf,\n    TranslateModule,\n    IconButtonComponent, DateMaskDirective\n  ],\n  standalone: true\n})\nexport class DateRangeDatepickerComponent implements OnChanges, AfterViewInit {\n  @Input() label?: string;\n  @Input() placeholder?: Array<string>;\n  @Input() value?: Array<string | null>;\n  @Input() defaultValue?: Array<Date>;\n  @Input() key?: {start: string, end: string, title: string};\n  @Input() submit = false;\n  @Input() clearValue = true;\n  @Input() errorMessage = '';\n  @Input() onePlaceholder?: string;\n  @Input() hintText = 'MM/DD/YYYY - MM/DD/YYYY';\n  @Output() resetForm = new EventEmitter<any>();\n  @Output() selectionChange = new EventEmitter<any>();\n  @ViewChild('picker') picker!: MatDateRangePicker<any>;\n  @ViewChild('min') min!: ElementRef;\n  @ViewChild('max') max!: ElementRef;\n  isOpen = false;\n  isSelectingRange = false;\n\n  dateRangeForm = new UntypedFormGroup({\n    startDate: new UntypedFormControl('', [Validators.maxLength(10)]),\n    endDate: new UntypedFormControl('', [Validators.maxLength(10)]),\n  });\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      if (this.defaultValue?.length) {\n        this.dateRangeForm.patchValue({\n          startDate: this.defaultValue[0],\n          endDate: this.defaultValue[1]\n        })\n      }\n    })\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    setTimeout(() => {\n      if (changes['value']?.currentValue && !(changes['value'].currentValue[0])) {\n        if (this.picker) {\n          this.dateRangeForm.reset();\n          this.picker.select(null)\n        }\n      } else if (changes['value'] && this.value?.length) {\n        this.dateRangeForm.setValue({\n          startDate: new Date(this.value[0] || ''),\n          endDate: new Date(this.value[1] || '')\n        })\n      }\n    }, 10)\n  }\n\n  clickForFocusOut(): void {\n    setTimeout(() => {\n      this.min.nativeElement.focus();\n      this.min.nativeElement.blur();\n    },120)\n  }\n\n  customErrorStateMatcher = {\n    isErrorState: (control: any, form: any): boolean => {\n      return !!(control && control.invalid && this.submit);\n    }\n  };\n\n  setDate(value: Array<string | null>, element: any): void {\n    const startDate = value[0];\n    const endDate = value[1];\n\n    // If this is the start date being selected (matStartDate input)\n    if (element === this.min?.nativeElement) {\n      // We're starting a new selection process\n      this.isSelectingRange = true;\n      // Don't emit any event yet\n    }\n    // If this is the end date being selected (matEndDate input)\n    else if (element === this.max?.nativeElement) {\n      // We're completing a selection\n      this.isSelectingRange = false;\n      // Only emit when we have both dates\n      if (startDate && endDate) {\n        this.selectionChange.emit(value);\n      }\n    }\n    // Handle clear operation (both null)\n    else if (startDate === null && endDate === null) {\n      this.isSelectingRange = false;\n      this.selectionChange.emit(value);\n    }\n\n    element.blur();\n  }\n\n  keyEventHandler(event: KeyboardEvent,value: Array<string | null>, element: any): void {\n    if (event.code === 'Enter') {\n      this.setDate(value,element)\n    }\n  }\n\n}\n","<div class=\"flex_column relative mat-date-range-input\"\n     [formGroup]=\"dateRangeForm\"\n>\n  <div class=\"w-100\" *ngIf=\"label\">\n    <mat-label>\n      {{ (label || '') | translate }}\n    </mat-label>\n  </div>\n  <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\n    <mat-date-range-input [rangePicker]=\"picker\">\n      <input formControlName=\"startDate\"\n             [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\n             [title]=\"key ? key.title :  'Date'\"\n             [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\n             [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n             matStartDate #min\n             dateMask\n             [errorStateMatcher]=\"customErrorStateMatcher\"\n             [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\n             (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\n             (dateChange)=\"setDate([min.value, max.value || null],min)\">\n      <input formControlName=\"endDate\"\n             [placeholder]=\"(placeholder  ? placeholder[1] : 'End Date')\"\n             [title]=\"key ? key.title :  'Date'\"\n             [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\n             [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n             matEndDate #max\n             dateMask\n             [errorStateMatcher]=\"customErrorStateMatcher\"\n             [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\n             (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\n             (dateChange)=\"setDate([min.value, max.value || null],max)\">\n    </mat-date-range-input>\n    <i-tech-icon-button matSuffix\n                        [iconName]=\"'cancel'\"\n                        (buttonClick)=\"selectionChange.emit([null, null])\"\n                        class=\"default-form-icon-color\"\n                        *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\n    ></i-tech-icon-button>\n    <i-tech-icon-button\n      matSuffix\n      [iconName]=\"'date_range'\"\n      (buttonClick)=\"picker.open()\"\n      class=\"default-form-icon-color\"\n    ></i-tech-icon-button>\n    <mat-date-range-picker\n      #picker\n      (closed)=\"isOpen = false;clickForFocusOut()\"\n      (opened)=\"isOpen = true\"\n    ></mat-date-range-picker>\n    <mat-hint *ngIf=\"hintText && !errorMessage\">{{ hintText }}</mat-hint>\n  </mat-form-field>\n</div>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import { MatDatepickerModule } from "@angular/material/datepicker";
|
|
3
3
|
import { NgxMaskDirective } from "ngx-mask";
|
|
4
4
|
import { FormsModule, ReactiveFormsModule, UntypedFormControl, UntypedFormGroup } from "@angular/forms";
|
|
@@ -42,6 +42,9 @@ export class DateTimePickerComponent {
|
|
|
42
42
|
time: new UntypedFormControl(),
|
|
43
43
|
date: new UntypedFormControl(),
|
|
44
44
|
});
|
|
45
|
+
// Track datepicker state
|
|
46
|
+
this.focusTimeoutId = null;
|
|
47
|
+
this.datePickerJustClosed = false;
|
|
45
48
|
this.ngControl = this.inputService.injectNgControl();
|
|
46
49
|
}
|
|
47
50
|
ngAfterViewInit() {
|
|
@@ -50,6 +53,11 @@ export class DateTimePickerComponent {
|
|
|
50
53
|
this.setValue();
|
|
51
54
|
});
|
|
52
55
|
}
|
|
56
|
+
ngOnDestroy() {
|
|
57
|
+
if (this.focusTimeoutId) {
|
|
58
|
+
clearTimeout(this.focusTimeoutId);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
53
61
|
setValue() {
|
|
54
62
|
if (!this.ngControl?.control) {
|
|
55
63
|
return;
|
|
@@ -67,13 +75,28 @@ export class DateTimePickerComponent {
|
|
|
67
75
|
time: this.parseDateService.changeFormat(dateTime, 'HH:mm')
|
|
68
76
|
}, { emitEvent: false });
|
|
69
77
|
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
78
|
+
onDatePickerClosed() {
|
|
79
|
+
// Update form value first
|
|
80
|
+
this.setDateTimeValue();
|
|
81
|
+
// Mark that the datepicker just closed
|
|
82
|
+
this.datePickerJustClosed = true;
|
|
83
|
+
// Clear any existing timeout
|
|
84
|
+
if (this.focusTimeoutId) {
|
|
85
|
+
clearTimeout(this.focusTimeoutId);
|
|
73
86
|
}
|
|
74
|
-
|
|
87
|
+
// Use a callback that runs outside Angular's change detection
|
|
88
|
+
this.focusTimeoutId = setTimeout(() => {
|
|
89
|
+
// Focus time input
|
|
90
|
+
if (this.timeInput?.nativeElement) {
|
|
91
|
+
this.timeInput.nativeElement.focus();
|
|
92
|
+
}
|
|
93
|
+
// Reset flag after enough time
|
|
94
|
+
setTimeout(() => {
|
|
95
|
+
this.datePickerJustClosed = false;
|
|
96
|
+
}, 200);
|
|
97
|
+
}, 100); // Longer delay to let Angular Material finish its work
|
|
75
98
|
}
|
|
76
|
-
|
|
99
|
+
setDateTimeValue() {
|
|
77
100
|
if (this.form.value.date && this.form.value.time) {
|
|
78
101
|
const date = this.parseDateService.changeFormat(this.form.value.date, 'YYYY-MM-DD');
|
|
79
102
|
const time = this.form.value.time;
|
|
@@ -84,20 +107,50 @@ export class DateTimePickerComponent {
|
|
|
84
107
|
}
|
|
85
108
|
this.dateChangeEvent.emit();
|
|
86
109
|
}
|
|
87
|
-
onFocus() {
|
|
110
|
+
onFocus(event) {
|
|
111
|
+
// If datepicker just closed and focus is going to date input, move it to time input
|
|
112
|
+
if (this.datePickerJustClosed) {
|
|
113
|
+
const target = event.target;
|
|
114
|
+
const dateInput = document.querySelector('input[formControlName="date"]');
|
|
115
|
+
if (target === dateInput) {
|
|
116
|
+
// Cancel any existing focus timeout
|
|
117
|
+
if (this.focusTimeoutId) {
|
|
118
|
+
clearTimeout(this.focusTimeoutId);
|
|
119
|
+
}
|
|
120
|
+
// Set new timeout to focus time input
|
|
121
|
+
this.focusTimeoutId = setTimeout(() => {
|
|
122
|
+
if (this.timeInput?.nativeElement) {
|
|
123
|
+
this.timeInput.nativeElement.focus();
|
|
124
|
+
}
|
|
125
|
+
}, 10);
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
88
129
|
this.isFocused = true;
|
|
89
130
|
}
|
|
90
|
-
onBlur() {
|
|
91
|
-
|
|
131
|
+
onBlur(event) {
|
|
132
|
+
// Don't handle blur during datepicker transitions
|
|
133
|
+
if (this.datePickerJustClosed) {
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
// Check if focus is moving to another element within our component
|
|
137
|
+
setTimeout(() => {
|
|
138
|
+
const dateInput = document.querySelector('input[formControlName="date"]');
|
|
139
|
+
const timeInput = this.timeInput?.nativeElement;
|
|
140
|
+
const activeElement = document.activeElement;
|
|
141
|
+
if (activeElement !== dateInput && activeElement !== timeInput) {
|
|
142
|
+
this.isFocused = false;
|
|
143
|
+
}
|
|
144
|
+
}, 50);
|
|
92
145
|
}
|
|
93
146
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: i1.InputService }, { token: i2.ParseDateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
94
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required", disabled: "disabled" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n
|
|
147
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required", disabled: "disabled" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], viewQueries: [{ propertyName: "timeInput", first: true, predicate: ["dateElement"], descendants: true }], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n >\n <mat-datepicker #DatePicker\n (closed)=\"onDatePickerClosed()\">\n </mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (change)=\"setDateTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "pipe", type: GenerateErrorMessagesPipe, name: "generateErrorMessages" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }] }); }
|
|
95
148
|
}
|
|
96
149
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, decorators: [{
|
|
97
150
|
type: Component,
|
|
98
151
|
args: [{ selector: 'i-tech-date-time-picker', imports: [MatDatepickerModule, NgxMaskDirective, DateMaskDirective, TranslateModule,
|
|
99
152
|
FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError
|
|
100
|
-
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n
|
|
153
|
+
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n >\n <mat-datepicker #DatePicker\n (closed)=\"onDatePickerClosed()\">\n </mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (change)=\"setDateTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n" }]
|
|
101
154
|
}], ctorParameters: () => [{ type: i1.InputService }, { type: i2.ParseDateService }], propDecorators: { dateChangeEvent: [{
|
|
102
155
|
type: Output
|
|
103
156
|
}], label: [{
|
|
@@ -108,5 +161,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
108
161
|
type: Input
|
|
109
162
|
}], disabled: [{
|
|
110
163
|
type: Input
|
|
164
|
+
}], timeInput: [{
|
|
165
|
+
type: ViewChild,
|
|
166
|
+
args: ['dateElement']
|
|
111
167
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.ts","../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { MatDatepickerModule } from \"@angular/material/datepicker\";\nimport { NgxMaskDirective } from \"ngx-mask\";\nimport {\n  FormControlName,\n  FormsModule,\n  ReactiveFormsModule,\n  UntypedFormControl,\n  UntypedFormGroup\n} from \"@angular/forms\";\nimport { NgClass, NgIf } from \"@angular/common\";\nimport { MatError, MatLabel } from \"@angular/material/form-field\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { DateMaskDirective } from \"../../directives/date-mask.directive\";\nimport { ParseDateService } from \"../../services/parse-date.service\";\nimport { InputService } from \"../../services/input.service\";\nimport { GenerateErrorMessagesPipe } from \"../../pipes/generate-error-messages.pipe\";\n\n@Component({\n  selector: 'i-tech-date-time-picker',\n  imports: [MatDatepickerModule, NgxMaskDirective,DateMaskDirective, TranslateModule,\n    FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError\n  ],\n  standalone: true,\n  providers: [ParseDateService],\n  templateUrl: './date-time-picker.component.html',\n  styleUrl: './date-time-picker.component.scss'\n})\nexport class DateTimePickerComponent implements AfterViewInit {\n  @Output() dateChangeEvent = new EventEmitter<void>();\n  @Input() label!: string;\n  @Input() submit = false;\n  @Input() required = false;\n  @Input() set disabled(disabled: boolean) {\n    this._disabled = disabled;\n    if (disabled) {\n      this.form.get('time')?.disable();\n      this.form.get('date')?.disable();\n    } else {\n      this.form.get('time')?.enable();\n      this.form.get('date')?.enable();\n    }\n  };\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  private _disabled = false;\n\n  isFocused = false;\n  form = new UntypedFormGroup({\n    time: new UntypedFormControl(),\n    date: new UntypedFormControl(),\n  })\n  ngControl: FormControlName;\n\n  constructor(\n      private inputService: InputService,\n      private parseDateService: ParseDateService\n  ) {\n    this.ngControl = this.inputService.injectNgControl();\n  }\n\n  ngAfterViewInit(): void {\n    this.setValue();\n    this.ngControl.control.valueChanges.subscribe(() => {\n      this.setValue()\n    })\n  }\n\n  private setValue(): void {\n    if (!this.ngControl?.control) {\n      return;\n    }\n    const dateTime = this.ngControl.control.value;\n    if (!dateTime) {\n      this.form.patchValue({\n        date: null,\n        time: null\n      }, { emitEvent: false });\n      return;\n    }\n\n    this.form.patchValue({\n      date: new Date(this.parseDateService.changeFormat(dateTime,'YYYY-MM-DD') + 'T' + '00:00:00'),\n      time: this.parseDateService.changeFormat(dateTime,'HH:mm')\n    }, { emitEvent: false })\n  }\n\n  public dateChange(timeInput: HTMLInputElement): void {\n    if (!timeInput.value) {\n      timeInput.focus();\n    }\n    this.setDatTimeValue()\n  }\n\n  public setDatTimeValue(): void {\n    if (this.form.value.date && this.form.value.time) {\n      const date = this.parseDateService.changeFormat(this.form.value.date , 'YYYY-MM-DD');\n      const time = this.form.value.time;\n      this.ngControl.control.patchValue(date + 'T' + time, { emitEvent: false });\n    } else {\n      this.ngControl.control.patchValue(null, { emitEvent: false });\n    }\n    this.dateChangeEvent.emit()\n  }\n\n  public onFocus(): void {\n    this.isFocused = true;\n  }\n\n  public onBlur(): void {\n    this.isFocused = false;\n  }\n}\n","<div class=\"date_time_picker_container\"\n     *ngIf=\"ngControl?.control\"\n     [class.readonly_field]=\"disabled\"\n>\n    <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n    <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n    <div class=\"date_time_picker\"\n         [formGroup]=\"form\"\n         [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n    >\n        <input type=\"text\" dateMask class=\"date\"\n               placeholder=\"mm/dd/yy\"\n               formControlName=\"date\"\n               [matDatepicker]=\"DatePicker\"\n               [disabled]=\"disabled\"\n               (click)=\"!disabled && DatePicker.open()\"\n               (focus)=\"onFocus()\"\n               (blur)=\"onBlur()\"\n               (selectionchange)=\"dateChange(dateElement)\"\n        >\n        <mat-datepicker #DatePicker></mat-datepicker>\n        <input type=\"time\"\n               #dateElement\n               class=\"time\"\n               formControlName=\"time\"\n               [disabled]=\"disabled\"\n               (focus)=\"onFocus()\"\n               (blur)=\"onBlur()\"\n               (change)=\"setDatTimeValue()\"\n        />\n    </div>\n    <!-- Error Messages -->\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n        {{ngControl.control | generateErrorMessages : (label || '')}}\n    </mat-error>\n</div>\n"]}
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.ts","../../../../../../projects/shared-components/src/lib/components/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, Output, ViewChild, ElementRef, OnDestroy } from '@angular/core';\nimport { MatDatepickerModule } from \"@angular/material/datepicker\";\nimport { NgxMaskDirective } from \"ngx-mask\";\nimport {\n  FormControlName,\n  FormsModule,\n  ReactiveFormsModule,\n  UntypedFormControl,\n  UntypedFormGroup\n} from \"@angular/forms\";\nimport { NgClass, NgIf } from \"@angular/common\";\nimport { MatError, MatLabel } from \"@angular/material/form-field\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { DateMaskDirective } from \"../../directives/date-mask.directive\";\nimport { ParseDateService } from \"../../services/parse-date.service\";\nimport { InputService } from \"../../services/input.service\";\nimport { GenerateErrorMessagesPipe } from \"../../pipes/generate-error-messages.pipe\";\n\n@Component({\n  selector: 'i-tech-date-time-picker',\n  imports: [MatDatepickerModule, NgxMaskDirective, DateMaskDirective, TranslateModule,\n    FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError\n  ],\n  standalone: true,\n  providers: [ParseDateService],\n  templateUrl: './date-time-picker.component.html',\n  styleUrl: './date-time-picker.component.scss'\n})\nexport class DateTimePickerComponent implements AfterViewInit, OnDestroy {\n  @Output() dateChangeEvent = new EventEmitter<void>();\n  @Input() label!: string;\n  @Input() submit = false;\n  @Input() required = false;\n  @Input() set disabled(disabled: boolean) {\n    this._disabled = disabled;\n    if (disabled) {\n      this.form.get('time')?.disable();\n      this.form.get('date')?.disable();\n    } else {\n      this.form.get('time')?.enable();\n      this.form.get('date')?.enable();\n    }\n  };\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  private _disabled = false;\n\n  @ViewChild('dateElement') timeInput!: ElementRef;\n\n  isFocused = false;\n  form = new UntypedFormGroup({\n    time: new UntypedFormControl(),\n    date: new UntypedFormControl(),\n  })\n  ngControl: FormControlName;\n\n  // Track datepicker state\n  private focusTimeoutId: any = null;\n  private datePickerJustClosed = false;\n\n  constructor(\n      private inputService: InputService,\n      private parseDateService: ParseDateService\n  ) {\n    this.ngControl = this.inputService.injectNgControl();\n  }\n\n  ngAfterViewInit(): void {\n    this.setValue();\n    this.ngControl.control.valueChanges.subscribe(() => {\n      this.setValue()\n    })\n  }\n\n  ngOnDestroy(): void {\n    if (this.focusTimeoutId) {\n      clearTimeout(this.focusTimeoutId);\n    }\n  }\n\n  private setValue(): void {\n    if (!this.ngControl?.control) {\n      return;\n    }\n    const dateTime = this.ngControl.control.value;\n    if (!dateTime) {\n      this.form.patchValue({\n        date: null,\n        time: null\n      }, { emitEvent: false });\n      return;\n    }\n\n    this.form.patchValue({\n      date: new Date(this.parseDateService.changeFormat(dateTime, 'YYYY-MM-DD') + 'T' + '00:00:00'),\n      time: this.parseDateService.changeFormat(dateTime, 'HH:mm')\n    }, { emitEvent: false })\n  }\n\n  public onDatePickerClosed(): void {\n    // Update form value first\n    this.setDateTimeValue();\n\n    // Mark that the datepicker just closed\n    this.datePickerJustClosed = true;\n\n    // Clear any existing timeout\n    if (this.focusTimeoutId) {\n      clearTimeout(this.focusTimeoutId);\n    }\n\n    // Use a callback that runs outside Angular's change detection\n    this.focusTimeoutId = setTimeout(() => {\n      // Focus time input\n      if (this.timeInput?.nativeElement) {\n        this.timeInput.nativeElement.focus();\n      }\n\n      // Reset flag after enough time\n      setTimeout(() => {\n        this.datePickerJustClosed = false;\n      }, 200);\n    }, 100); // Longer delay to let Angular Material finish its work\n  }\n\n  public setDateTimeValue(): void {\n    if (this.form.value.date && this.form.value.time) {\n      const date = this.parseDateService.changeFormat(this.form.value.date, 'YYYY-MM-DD');\n      const time = this.form.value.time;\n      this.ngControl.control.patchValue(date + 'T' + time, { emitEvent: false });\n    } else {\n      this.ngControl.control.patchValue(null, { emitEvent: false });\n    }\n    this.dateChangeEvent.emit();\n  }\n\n  public onFocus(event: FocusEvent): void {\n    // If datepicker just closed and focus is going to date input, move it to time input\n    if (this.datePickerJustClosed) {\n      const target = event.target as HTMLElement;\n      const dateInput = document.querySelector('input[formControlName=\"date\"]');\n\n      if (target === dateInput) {\n        // Cancel any existing focus timeout\n        if (this.focusTimeoutId) {\n          clearTimeout(this.focusTimeoutId);\n        }\n\n        // Set new timeout to focus time input\n        this.focusTimeoutId = setTimeout(() => {\n          if (this.timeInput?.nativeElement) {\n            this.timeInput.nativeElement.focus();\n          }\n        }, 10);\n\n        return;\n      }\n    }\n\n    this.isFocused = true;\n  }\n\n  public onBlur(event?: FocusEvent): void {\n    // Don't handle blur during datepicker transitions\n    if (this.datePickerJustClosed) {\n      return;\n    }\n\n    // Check if focus is moving to another element within our component\n    setTimeout(() => {\n      const dateInput = document.querySelector('input[formControlName=\"date\"]');\n      const timeInput = this.timeInput?.nativeElement;\n      const activeElement = document.activeElement;\n\n      if (activeElement !== dateInput && activeElement !== timeInput) {\n        this.isFocused = false;\n      }\n    }, 50);\n  }\n}\n","<div class=\"date_time_picker_container\"\n     *ngIf=\"ngControl?.control\"\n     [class.readonly_field]=\"disabled\"\n>\n    <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n    <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n    <div class=\"date_time_picker\"\n         [formGroup]=\"form\"\n         [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n    >\n        <input type=\"text\" dateMask class=\"date\"\n               placeholder=\"mm/dd/yy\"\n               formControlName=\"date\"\n               [matDatepicker]=\"DatePicker\"\n               [disabled]=\"disabled\"\n               (click)=\"!disabled && DatePicker.open()\"\n               (focus)=\"onFocus($event)\"\n               (blur)=\"onBlur($event)\"\n        >\n        <mat-datepicker #DatePicker\n                        (closed)=\"onDatePickerClosed()\">\n        </mat-datepicker>\n        <input type=\"time\"\n               #dateElement\n               class=\"time\"\n               formControlName=\"time\"\n               [disabled]=\"disabled\"\n               (focus)=\"onFocus($event)\"\n               (blur)=\"onBlur($event)\"\n               (change)=\"setDateTimeValue()\"\n        />\n    </div>\n    <!-- Error Messages -->\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n        {{ngControl.control | generateErrorMessages : (label || '')}}\n    </mat-error>\n</div>\n"]}
|
|
@@ -1201,6 +1201,7 @@ class DateRangeDatepickerComponent {
|
|
|
1201
1201
|
this.resetForm = new EventEmitter();
|
|
1202
1202
|
this.selectionChange = new EventEmitter();
|
|
1203
1203
|
this.isOpen = false;
|
|
1204
|
+
this.isSelectingRange = false;
|
|
1204
1205
|
this.dateRangeForm = new UntypedFormGroup({
|
|
1205
1206
|
startDate: new UntypedFormControl('', [Validators.maxLength(10)]),
|
|
1206
1207
|
endDate: new UntypedFormControl('', [Validators.maxLength(10)]),
|
|
@@ -1244,7 +1245,28 @@ class DateRangeDatepickerComponent {
|
|
|
1244
1245
|
}, 120);
|
|
1245
1246
|
}
|
|
1246
1247
|
setDate(value, element) {
|
|
1247
|
-
|
|
1248
|
+
const startDate = value[0];
|
|
1249
|
+
const endDate = value[1];
|
|
1250
|
+
// If this is the start date being selected (matStartDate input)
|
|
1251
|
+
if (element === this.min?.nativeElement) {
|
|
1252
|
+
// We're starting a new selection process
|
|
1253
|
+
this.isSelectingRange = true;
|
|
1254
|
+
// Don't emit any event yet
|
|
1255
|
+
}
|
|
1256
|
+
// If this is the end date being selected (matEndDate input)
|
|
1257
|
+
else if (element === this.max?.nativeElement) {
|
|
1258
|
+
// We're completing a selection
|
|
1259
|
+
this.isSelectingRange = false;
|
|
1260
|
+
// Only emit when we have both dates
|
|
1261
|
+
if (startDate && endDate) {
|
|
1262
|
+
this.selectionChange.emit(value);
|
|
1263
|
+
}
|
|
1264
|
+
}
|
|
1265
|
+
// Handle clear operation (both null)
|
|
1266
|
+
else if (startDate === null && endDate === null) {
|
|
1267
|
+
this.isSelectingRange = false;
|
|
1268
|
+
this.selectionChange.emit(value);
|
|
1269
|
+
}
|
|
1248
1270
|
element.blur();
|
|
1249
1271
|
}
|
|
1250
1272
|
keyEventHandler(event, value, element) {
|
|
@@ -1253,7 +1275,7 @@ class DateRangeDatepickerComponent {
|
|
|
1253
1275
|
}
|
|
1254
1276
|
}
|
|
1255
1277
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateRangeDatepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1256
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateRangeDatepickerComponent, isStandalone: true, selector: "i-tech-mat-range-datepicker", inputs: { label: "label", placeholder: "placeholder", value: "value", defaultValue: "defaultValue", key: "key", submit: "submit", clearValue: "clearValue", errorMessage: "errorMessage", onePlaceholder: "onePlaceholder", hintText: "hintText" }, outputs: { resetForm: "resetForm", selectionChange: "selectionChange" }, viewQueries: [{ propertyName: "picker", first: true, predicate: ["picker"], descendants: true }, { propertyName: "min", first: true, predicate: ["min"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex_column relative mat-date-range-input\"\n [formGroup]=\"dateRangeForm\"\n>\n <div class=\"w-100\" *ngIf=\"label\">\n <mat-label>\n {{ (label || '') | translate }}\n </mat-label>\n </div>\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\n <mat-date-range-input [rangePicker]=\"picker\">\n <input formControlName=\"startDate\"\n [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matStartDate #min\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\n (dateChange)=\"setDate([min.value, max.value || null],min)\">\n <input formControlName=\"endDate\"\n [placeholder]=\"(placeholder ? placeholder[1] : 'End Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matEndDate #max\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\n (dateChange)=\"setDate([min.value, max.value || null],max)\">\n </mat-date-range-input>\n <i-tech-icon-button matSuffix\n [iconName]=\"'cancel'\"\n (buttonClick)=\"selectionChange.emit([null, null])\"\n class=\"default-form-icon-color\"\n *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\n ></i-tech-icon-button>\n <i-tech-icon-button\n matSuffix\n [iconName]=\"'date_range'\"\n (buttonClick)=\"picker.open()\"\n class=\"default-form-icon-color\"\n ></i-tech-icon-button>\n <mat-date-range-picker\n #picker\n (closed)=\"isOpen = false;clickForFocusOut()\"\n (opened)=\"isOpen = true\"\n ></mat-date-range-picker>\n <mat-hint *ngIf=\"hintText && !errorMessage\">{{ hintText }}</mat-hint>\n </mat-form-field>\n</div>\n", dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3$1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i3$1.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i3$1.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i3$1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: IconButtonComponent, selector: "i-tech-icon-button", inputs: ["size", "type", "iconSvg", "iconName", "tooltip", "disabled"], outputs: ["buttonClick"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }] }); }
|
|
1278
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateRangeDatepickerComponent, isStandalone: true, selector: "i-tech-mat-range-datepicker", inputs: { label: "label", placeholder: "placeholder", value: "value", defaultValue: "defaultValue", key: "key", submit: "submit", clearValue: "clearValue", errorMessage: "errorMessage", onePlaceholder: "onePlaceholder", hintText: "hintText" }, outputs: { resetForm: "resetForm", selectionChange: "selectionChange" }, viewQueries: [{ propertyName: "picker", first: true, predicate: ["picker"], descendants: true }, { propertyName: "min", first: true, predicate: ["min"], descendants: true }, { propertyName: "max", first: true, predicate: ["max"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex_column relative mat-date-range-input\"\n [formGroup]=\"dateRangeForm\"\n>\n <div class=\"w-100\" *ngIf=\"label\">\n <mat-label>\n {{ (label || '') | translate }}\n </mat-label>\n </div>\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\n <mat-date-range-input [rangePicker]=\"picker\">\n <input formControlName=\"startDate\"\n [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matStartDate #min\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\n (dateChange)=\"setDate([min.value, max.value || null],min)\">\n <input formControlName=\"endDate\"\n [placeholder]=\"(placeholder ? placeholder[1] : 'End Date')\"\n [title]=\"key ? key.title : 'Date'\"\n [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\n matEndDate #max\n dateMask\n [errorStateMatcher]=\"customErrorStateMatcher\"\n [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\n (dateChange)=\"setDate([min.value, max.value || null],max)\">\n </mat-date-range-input>\n <i-tech-icon-button matSuffix\n [iconName]=\"'cancel'\"\n (buttonClick)=\"selectionChange.emit([null, null])\"\n class=\"default-form-icon-color\"\n *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\n ></i-tech-icon-button>\n <i-tech-icon-button\n matSuffix\n [iconName]=\"'date_range'\"\n (buttonClick)=\"picker.open()\"\n class=\"default-form-icon-color\"\n ></i-tech-icon-button>\n <mat-date-range-picker\n #picker\n (closed)=\"isOpen = false;clickForFocusOut()\"\n (opened)=\"isOpen = true\"\n ></mat-date-range-picker>\n <mat-hint *ngIf=\"hintText && !errorMessage\">{{ hintText }}</mat-hint>\n </mat-form-field>\n</div>\n", dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3$1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i3$1.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i3$1.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i3$1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: IconButtonComponent, selector: "i-tech-icon-button", inputs: ["size", "type", "iconSvg", "iconName", "tooltip", "disabled"], outputs: ["buttonClick"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }] }); }
|
|
1257
1279
|
}
|
|
1258
1280
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateRangeDatepickerComponent, decorators: [{
|
|
1259
1281
|
type: Component,
|
|
@@ -1295,6 +1317,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
1295
1317
|
}], min: [{
|
|
1296
1318
|
type: ViewChild,
|
|
1297
1319
|
args: ['min']
|
|
1320
|
+
}], max: [{
|
|
1321
|
+
type: ViewChild,
|
|
1322
|
+
args: ['max']
|
|
1298
1323
|
}] } });
|
|
1299
1324
|
|
|
1300
1325
|
var DropdownSelectionType;
|
|
@@ -1424,6 +1449,9 @@ class DateTimePickerComponent {
|
|
|
1424
1449
|
time: new UntypedFormControl(),
|
|
1425
1450
|
date: new UntypedFormControl(),
|
|
1426
1451
|
});
|
|
1452
|
+
// Track datepicker state
|
|
1453
|
+
this.focusTimeoutId = null;
|
|
1454
|
+
this.datePickerJustClosed = false;
|
|
1427
1455
|
this.ngControl = this.inputService.injectNgControl();
|
|
1428
1456
|
}
|
|
1429
1457
|
ngAfterViewInit() {
|
|
@@ -1432,6 +1460,11 @@ class DateTimePickerComponent {
|
|
|
1432
1460
|
this.setValue();
|
|
1433
1461
|
});
|
|
1434
1462
|
}
|
|
1463
|
+
ngOnDestroy() {
|
|
1464
|
+
if (this.focusTimeoutId) {
|
|
1465
|
+
clearTimeout(this.focusTimeoutId);
|
|
1466
|
+
}
|
|
1467
|
+
}
|
|
1435
1468
|
setValue() {
|
|
1436
1469
|
if (!this.ngControl?.control) {
|
|
1437
1470
|
return;
|
|
@@ -1449,13 +1482,28 @@ class DateTimePickerComponent {
|
|
|
1449
1482
|
time: this.parseDateService.changeFormat(dateTime, 'HH:mm')
|
|
1450
1483
|
}, { emitEvent: false });
|
|
1451
1484
|
}
|
|
1452
|
-
|
|
1453
|
-
|
|
1454
|
-
|
|
1455
|
-
|
|
1456
|
-
this.
|
|
1485
|
+
onDatePickerClosed() {
|
|
1486
|
+
// Update form value first
|
|
1487
|
+
this.setDateTimeValue();
|
|
1488
|
+
// Mark that the datepicker just closed
|
|
1489
|
+
this.datePickerJustClosed = true;
|
|
1490
|
+
// Clear any existing timeout
|
|
1491
|
+
if (this.focusTimeoutId) {
|
|
1492
|
+
clearTimeout(this.focusTimeoutId);
|
|
1493
|
+
}
|
|
1494
|
+
// Use a callback that runs outside Angular's change detection
|
|
1495
|
+
this.focusTimeoutId = setTimeout(() => {
|
|
1496
|
+
// Focus time input
|
|
1497
|
+
if (this.timeInput?.nativeElement) {
|
|
1498
|
+
this.timeInput.nativeElement.focus();
|
|
1499
|
+
}
|
|
1500
|
+
// Reset flag after enough time
|
|
1501
|
+
setTimeout(() => {
|
|
1502
|
+
this.datePickerJustClosed = false;
|
|
1503
|
+
}, 200);
|
|
1504
|
+
}, 100); // Longer delay to let Angular Material finish its work
|
|
1457
1505
|
}
|
|
1458
|
-
|
|
1506
|
+
setDateTimeValue() {
|
|
1459
1507
|
if (this.form.value.date && this.form.value.time) {
|
|
1460
1508
|
const date = this.parseDateService.changeFormat(this.form.value.date, 'YYYY-MM-DD');
|
|
1461
1509
|
const time = this.form.value.time;
|
|
@@ -1466,20 +1514,50 @@ class DateTimePickerComponent {
|
|
|
1466
1514
|
}
|
|
1467
1515
|
this.dateChangeEvent.emit();
|
|
1468
1516
|
}
|
|
1469
|
-
onFocus() {
|
|
1517
|
+
onFocus(event) {
|
|
1518
|
+
// If datepicker just closed and focus is going to date input, move it to time input
|
|
1519
|
+
if (this.datePickerJustClosed) {
|
|
1520
|
+
const target = event.target;
|
|
1521
|
+
const dateInput = document.querySelector('input[formControlName="date"]');
|
|
1522
|
+
if (target === dateInput) {
|
|
1523
|
+
// Cancel any existing focus timeout
|
|
1524
|
+
if (this.focusTimeoutId) {
|
|
1525
|
+
clearTimeout(this.focusTimeoutId);
|
|
1526
|
+
}
|
|
1527
|
+
// Set new timeout to focus time input
|
|
1528
|
+
this.focusTimeoutId = setTimeout(() => {
|
|
1529
|
+
if (this.timeInput?.nativeElement) {
|
|
1530
|
+
this.timeInput.nativeElement.focus();
|
|
1531
|
+
}
|
|
1532
|
+
}, 10);
|
|
1533
|
+
return;
|
|
1534
|
+
}
|
|
1535
|
+
}
|
|
1470
1536
|
this.isFocused = true;
|
|
1471
1537
|
}
|
|
1472
|
-
onBlur() {
|
|
1473
|
-
|
|
1538
|
+
onBlur(event) {
|
|
1539
|
+
// Don't handle blur during datepicker transitions
|
|
1540
|
+
if (this.datePickerJustClosed) {
|
|
1541
|
+
return;
|
|
1542
|
+
}
|
|
1543
|
+
// Check if focus is moving to another element within our component
|
|
1544
|
+
setTimeout(() => {
|
|
1545
|
+
const dateInput = document.querySelector('input[formControlName="date"]');
|
|
1546
|
+
const timeInput = this.timeInput?.nativeElement;
|
|
1547
|
+
const activeElement = document.activeElement;
|
|
1548
|
+
if (activeElement !== dateInput && activeElement !== timeInput) {
|
|
1549
|
+
this.isFocused = false;
|
|
1550
|
+
}
|
|
1551
|
+
}, 50);
|
|
1474
1552
|
}
|
|
1475
1553
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: InputService }, { token: ParseDateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1476
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required", disabled: "disabled" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n
|
|
1554
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DateTimePickerComponent, isStandalone: true, selector: "i-tech-date-time-picker", inputs: { label: "label", submit: "submit", required: "required", disabled: "disabled" }, outputs: { dateChangeEvent: "dateChangeEvent" }, providers: [ParseDateService], viewQueries: [{ propertyName: "timeInput", first: true, predicate: ["dateElement"], descendants: true }], ngImport: i0, template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n >\n <mat-datepicker #DatePicker\n (closed)=\"onDatePickerClosed()\">\n </mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (change)=\"setDateTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3$1.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3$1.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: MatLabel, selector: "mat-label" }, { kind: "pipe", type: GenerateErrorMessagesPipe, name: "generateErrorMessages" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MatError, selector: "mat-error, [matError]", inputs: ["id"] }] }); }
|
|
1477
1555
|
}
|
|
1478
1556
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, decorators: [{
|
|
1479
1557
|
type: Component,
|
|
1480
1558
|
args: [{ selector: 'i-tech-date-time-picker', imports: [MatDatepickerModule, NgxMaskDirective, DateMaskDirective, TranslateModule,
|
|
1481
1559
|
FormsModule, NgClass, ReactiveFormsModule, MatLabel, GenerateErrorMessagesPipe, NgIf, MatError
|
|
1482
|
-
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n
|
|
1560
|
+
], standalone: true, providers: [ParseDateService], template: "<div class=\"date_time_picker_container\"\n *ngIf=\"ngControl?.control\"\n [class.readonly_field]=\"disabled\"\n>\n <mat-label [ngClass]=\"{'readonly-color': disabled}\">{{label | translate}}</mat-label>\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color': disabled}\"> *</span>\n\n <div class=\"date_time_picker\"\n [formGroup]=\"form\"\n [ngClass]=\"{'focused': isFocused, 'disabled': disabled}\"\n >\n <input type=\"text\" dateMask class=\"date\"\n placeholder=\"mm/dd/yy\"\n formControlName=\"date\"\n [matDatepicker]=\"DatePicker\"\n [disabled]=\"disabled\"\n (click)=\"!disabled && DatePicker.open()\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n >\n <mat-datepicker #DatePicker\n (closed)=\"onDatePickerClosed()\">\n </mat-datepicker>\n <input type=\"time\"\n #dateElement\n class=\"time\"\n formControlName=\"time\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (change)=\"setDateTimeValue()\"\n />\n </div>\n <!-- Error Messages -->\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\n {{ngControl.control | generateErrorMessages : (label || '')}}\n </mat-error>\n</div>\n" }]
|
|
1483
1561
|
}], ctorParameters: () => [{ type: InputService }, { type: ParseDateService }], propDecorators: { dateChangeEvent: [{
|
|
1484
1562
|
type: Output
|
|
1485
1563
|
}], label: [{
|
|
@@ -1490,6 +1568,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
1490
1568
|
type: Input
|
|
1491
1569
|
}], disabled: [{
|
|
1492
1570
|
type: Input
|
|
1571
|
+
}], timeInput: [{
|
|
1572
|
+
type: ViewChild,
|
|
1573
|
+
args: ['dateElement']
|
|
1493
1574
|
}] } });
|
|
1494
1575
|
|
|
1495
1576
|
/*
|