i-tech-shared-components 1.0.7 → 1.0.9

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.
@@ -0,0 +1,97 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { ReactiveFormsModule } from "@angular/forms";
3
+ import { NgClass, NgIf } from "@angular/common";
4
+ import { TranslateModule } from "@ngx-translate/core";
5
+ import { MatFormFieldModule } from "@angular/material/form-field";
6
+ import { MatDatepickerModule } from "@angular/material/datepicker";
7
+ import { MatInput } from "@angular/material/input";
8
+ import { MatTooltip } from "@angular/material/tooltip";
9
+ import { MatIconModule } from "@angular/material/icon";
10
+ import { DateMaskDirective } from "../../directives/date-mask.directive";
11
+ import { GenerateErrorMessagesPipe } from "../../pipes/generate-error-messages.pipe";
12
+ import { IconButtonComponent } from "../icon-button/icon-button.component";
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "../../services/input.service";
15
+ import * as i2 from "@ngx-translate/core";
16
+ import * as i3 from "@angular/forms";
17
+ import * as i4 from "@angular/material/form-field";
18
+ import * as i5 from "@angular/material/datepicker";
19
+ import * as i6 from "@angular/material/icon";
20
+ export class DatePickerComponent {
21
+ constructor(inputService) {
22
+ this.inputService = inputService;
23
+ this.label = '';
24
+ this.required = false;
25
+ this.hintText = '';
26
+ this.placeholder = 'MM/DD/YYYY';
27
+ this.submit = false;
28
+ this.valueChangeEmitter = new EventEmitter();
29
+ this.isOpen = false;
30
+ this.focused = false;
31
+ this.customErrorStateMatcher = {
32
+ isErrorState: (control, form) => {
33
+ return !!(control && control.invalid && this.submit);
34
+ }
35
+ };
36
+ this.ngControl = this.inputService.injectNgControl();
37
+ }
38
+ emitChange() {
39
+ if (!this.valueChangeEmit) {
40
+ return;
41
+ }
42
+ this.valueChangeEmitter.emit();
43
+ }
44
+ clickForFocusOut() {
45
+ setTimeout(() => {
46
+ this.inputElement.nativeElement.focus();
47
+ this.inputElement.nativeElement.blur();
48
+ }, 120);
49
+ }
50
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, deps: [{ token: i1.InputService }], target: i0.ɵɵFactoryTarget.Component }); }
51
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DatePickerComponent, isStandalone: true, selector: "i-tech-date-picker", inputs: { label: "label", defaultPatternKey: "defaultPatternKey", required: "required", hintText: "hintText", placeholder: "placeholder", iconPrefix: "iconPrefix", iconPrefixSvg: "iconPrefixSvg", iconPrefixTooltip: "iconPrefixTooltip", iconPrefixColor: "iconPrefixColor", iconPrefixVariant: "iconPrefixVariant", valueChangeEmit: "valueChangeEmit", submit: "submit" }, outputs: { valueChangeEmitter: "valueChangeEmitter" }, viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"flex_column relative mat-date-range-input\" *ngIf=\"ngControl\" [ngClass]=\"{'check_requirements': submit}\">\r\n <div class=\"w-100\">\r\n <mat-label [ngClass]=\"{\r\n 'readonly-color' : ngControl.control.disabled,\r\n 'invalid-label-color': !!(ngControl.control.errors && submit)\r\n }\">\r\n {{ label | translate }}\r\n </mat-label>\r\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\r\n </div>\r\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\"\r\n [class.readonly-field]=\"ngControl.control.disabled\">\r\n <input matInput #inputElement\r\n type=\"text\"\r\n [formControl]=\"ngControl.control\"\r\n [placeholder]=\"placeholder | translate\"\r\n dateMask\r\n [matDatepicker]=\"datePicker\"\r\n [errorStateMatcher]=\"customErrorStateMatcher\"\r\n (focus)=\"focused = true\"\r\n (click)=\"datePicker.open();\"\r\n (dateChange)=\"emitChange()\"\r\n >\r\n\r\n <mat-icon *ngIf=\"iconPrefix\"\r\n matPrefix\r\n [matTooltip]=\"((iconPrefixTooltip || '') | translate)\"\r\n [style.color]=\"iconPrefixColor\"\r\n >{{ iconPrefix }}\r\n </mat-icon>\r\n\r\n <mat-icon *ngIf=\"iconPrefixSvg\"\r\n matPrefix\r\n [matTooltip]=\"((iconPrefixTooltip || '') | translate)\"\r\n [svgIcon]=\"iconPrefixSvg\"\r\n ></mat-icon>\r\n\r\n <i-tech-icon-button matSuffix\r\n [iconName]=\"'date_range'\"\r\n [disabled]=\"ngControl.control.disabled\"\r\n (click)=\"datePicker.open()\"\r\n [ngClass]=\"ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\r\n ></i-tech-icon-button>\r\n\r\n <mat-datepicker #datePicker (closed)=\"isOpen = false;clickForFocusOut()\"\r\n (opened)=\"isOpen = true;focused = true\"></mat-datepicker>\r\n\r\n <!-- Error Messages -->\r\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\r\n {{ ngControl.control | generateErrorMessages : label : defaultPatternKey }}\r\n </mat-error>\r\n\r\n <!-- Helper Text -->\r\n <mat-hint *ngIf=\"!(!!(ngControl.control.errors && submit)) && hintText\"\r\n [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\"\r\n >\r\n {{ hintText | translate }}\r\n </mat-hint>\r\n\r\n </mat-form-field>\r\n</div>\r\n", dependencies: [{ 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: i2.TranslatePipe, name: "translate" }, { 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.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { 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.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: DateMaskDirective, selector: "[dateMask]", inputs: ["maskType", "matDatepicker", "rangeFormControl"] }, { kind: "pipe", type: GenerateErrorMessagesPipe, name: "generateErrorMessages" }, { kind: "component", type: IconButtonComponent, selector: "i-tech-icon-button", inputs: ["size", "type", "iconSvg", "iconName", "tooltip", "disabled"], outputs: ["buttonClick"] }] }); }
52
+ }
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, decorators: [{
54
+ type: Component,
55
+ args: [{ selector: 'i-tech-date-picker', imports: [
56
+ NgClass, NgIf,
57
+ TranslateModule,
58
+ ReactiveFormsModule,
59
+ MatFormFieldModule,
60
+ MatDatepickerModule,
61
+ MatInput,
62
+ MatTooltip,
63
+ MatIconModule,
64
+ DateMaskDirective,
65
+ GenerateErrorMessagesPipe, IconButtonComponent
66
+ ], standalone: true, template: "<div class=\"flex_column relative mat-date-range-input\" *ngIf=\"ngControl\" [ngClass]=\"{'check_requirements': submit}\">\r\n <div class=\"w-100\">\r\n <mat-label [ngClass]=\"{\r\n 'readonly-color' : ngControl.control.disabled,\r\n 'invalid-label-color': !!(ngControl.control.errors && submit)\r\n }\">\r\n {{ label | translate }}\r\n </mat-label>\r\n <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\r\n </div>\r\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\"\r\n [class.readonly-field]=\"ngControl.control.disabled\">\r\n <input matInput #inputElement\r\n type=\"text\"\r\n [formControl]=\"ngControl.control\"\r\n [placeholder]=\"placeholder | translate\"\r\n dateMask\r\n [matDatepicker]=\"datePicker\"\r\n [errorStateMatcher]=\"customErrorStateMatcher\"\r\n (focus)=\"focused = true\"\r\n (click)=\"datePicker.open();\"\r\n (dateChange)=\"emitChange()\"\r\n >\r\n\r\n <mat-icon *ngIf=\"iconPrefix\"\r\n matPrefix\r\n [matTooltip]=\"((iconPrefixTooltip || '') | translate)\"\r\n [style.color]=\"iconPrefixColor\"\r\n >{{ iconPrefix }}\r\n </mat-icon>\r\n\r\n <mat-icon *ngIf=\"iconPrefixSvg\"\r\n matPrefix\r\n [matTooltip]=\"((iconPrefixTooltip || '') | translate)\"\r\n [svgIcon]=\"iconPrefixSvg\"\r\n ></mat-icon>\r\n\r\n <i-tech-icon-button matSuffix\r\n [iconName]=\"'date_range'\"\r\n [disabled]=\"ngControl.control.disabled\"\r\n (click)=\"datePicker.open()\"\r\n [ngClass]=\"ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\r\n ></i-tech-icon-button>\r\n\r\n <mat-datepicker #datePicker (closed)=\"isOpen = false;clickForFocusOut()\"\r\n (opened)=\"isOpen = true;focused = true\"></mat-datepicker>\r\n\r\n <!-- Error Messages -->\r\n <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\r\n {{ ngControl.control | generateErrorMessages : label : defaultPatternKey }}\r\n </mat-error>\r\n\r\n <!-- Helper Text -->\r\n <mat-hint *ngIf=\"!(!!(ngControl.control.errors && submit)) && hintText\"\r\n [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\"\r\n >\r\n {{ hintText | translate }}\r\n </mat-hint>\r\n\r\n </mat-form-field>\r\n</div>\r\n" }]
67
+ }], ctorParameters: () => [{ type: i1.InputService }], propDecorators: { label: [{
68
+ type: Input
69
+ }], defaultPatternKey: [{
70
+ type: Input
71
+ }], required: [{
72
+ type: Input
73
+ }], hintText: [{
74
+ type: Input
75
+ }], placeholder: [{
76
+ type: Input
77
+ }], iconPrefix: [{
78
+ type: Input
79
+ }], iconPrefixSvg: [{
80
+ type: Input
81
+ }], iconPrefixTooltip: [{
82
+ type: Input
83
+ }], iconPrefixColor: [{
84
+ type: Input
85
+ }], iconPrefixVariant: [{
86
+ type: Input
87
+ }], valueChangeEmit: [{
88
+ type: Input
89
+ }], submit: [{
90
+ type: Input
91
+ }], inputElement: [{
92
+ type: ViewChild,
93
+ args: ['inputElement']
94
+ }], valueChangeEmitter: [{
95
+ type: Output
96
+ }] } });
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/shared-components/src/lib/components/date-picker/date-picker.component.ts","../../../../../../projects/shared-components/src/lib/components/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, Input, Output, ViewChild} from '@angular/core';\r\nimport {FormControlName, ReactiveFormsModule} from \"@angular/forms\";\r\nimport { InputService } from '../../services/input.service';\r\nimport {NgClass, NgIf} from \"@angular/common\";\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\nimport {MatFormFieldModule} from \"@angular/material/form-field\";\r\nimport {MatDatepickerModule} from \"@angular/material/datepicker\";\r\nimport {MatInput} from \"@angular/material/input\";\r\nimport {MatTooltip} from \"@angular/material/tooltip\";\r\nimport {MatIconModule} from \"@angular/material/icon\";\r\nimport {DateMaskDirective} from \"../../directives/date-mask.directive\";\r\nimport {GenerateErrorMessagesPipe} from \"../../pipes/generate-error-messages.pipe\";\r\nimport {IconButtonComponent} from \"../icon-button/icon-button.component\";\r\n\r\n@Component({\r\n    selector: 'i-tech-date-picker',\r\n    templateUrl: './date-picker.component.html',\r\n  imports: [\r\n    NgClass, NgIf,\r\n    TranslateModule,\r\n    ReactiveFormsModule,\r\n    MatFormFieldModule,\r\n    MatDatepickerModule,\r\n    MatInput,\r\n    MatTooltip,\r\n    MatIconModule,\r\n    DateMaskDirective,\r\n    GenerateErrorMessagesPipe, IconButtonComponent\r\n  ],\r\n    standalone: true\r\n})\r\nexport class DatePickerComponent {\r\n    @Input() label: string = '';\r\n    @Input() defaultPatternKey!: string ;\r\n    @Input() required: boolean = false;\r\n    @Input() hintText: string = '';\r\n    @Input() placeholder: string = 'MM/DD/YYYY';\r\n    @Input() iconPrefix?: string;\r\n    @Input() iconPrefixSvg?: string;\r\n    @Input() iconPrefixTooltip?: string;\r\n    @Input() iconPrefixColor?: string;\r\n    @Input() iconPrefixVariant?: string;\r\n    @Input() valueChangeEmit?: boolean;\r\n\r\n    @Input() submit: boolean = false;\r\n    @ViewChild('inputElement') inputElement!: ElementRef;\r\n    @Output() valueChangeEmitter = new EventEmitter<void>();\r\n\r\n    isOpen = false;\r\n    focused = false;\r\n\r\n    ngControl: FormControlName;\r\n\r\n    constructor(private inputService: InputService) {\r\n        this.ngControl = this.inputService.injectNgControl() as FormControlName;\r\n    }\r\n\r\n    emitChange(): void {\r\n        if (!this.valueChangeEmit) { return; }\r\n        this.valueChangeEmitter.emit();\r\n    }\r\n\r\n    clickForFocusOut(): void {\r\n        setTimeout(() => {\r\n            this.inputElement.nativeElement.focus();\r\n            this.inputElement.nativeElement.blur();\r\n        },120)\r\n    }\r\n\r\n    customErrorStateMatcher = {\r\n        isErrorState: (control: any, form: any): boolean => {\r\n            return !!(control && control.invalid && this.submit);\r\n        }\r\n    };\r\n}\r\n","<div class=\"flex_column relative mat-date-range-input\" *ngIf=\"ngControl\" [ngClass]=\"{'check_requirements': submit}\">\r\n  <div class=\"w-100\">\r\n    <mat-label [ngClass]=\"{\r\n        'readonly-color' : ngControl.control.disabled,\r\n        'invalid-label-color': !!(ngControl.control.errors && submit)\r\n        }\">\r\n      {{ label | translate }}\r\n    </mat-label>\r\n    <span *ngIf=\"required\" class=\"required-input\" [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\">*</span>\r\n  </div>\r\n  <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\"\r\n                  [class.readonly-field]=\"ngControl.control.disabled\">\r\n    <input matInput #inputElement\r\n           type=\"text\"\r\n           [formControl]=\"ngControl.control\"\r\n           [placeholder]=\"placeholder | translate\"\r\n           dateMask\r\n           [matDatepicker]=\"datePicker\"\r\n           [errorStateMatcher]=\"customErrorStateMatcher\"\r\n           (focus)=\"focused = true\"\r\n           (click)=\"datePicker.open();\"\r\n           (dateChange)=\"emitChange()\"\r\n    >\r\n\r\n    <mat-icon *ngIf=\"iconPrefix\"\r\n              matPrefix\r\n              [matTooltip]=\"((iconPrefixTooltip || '') | translate)\"\r\n              [style.color]=\"iconPrefixColor\"\r\n    >{{ iconPrefix }}\r\n    </mat-icon>\r\n\r\n    <mat-icon *ngIf=\"iconPrefixSvg\"\r\n              matPrefix\r\n              [matTooltip]=\"((iconPrefixTooltip || '') | translate)\"\r\n              [svgIcon]=\"iconPrefixSvg\"\r\n    ></mat-icon>\r\n\r\n    <i-tech-icon-button matSuffix\r\n                        [iconName]=\"'date_range'\"\r\n                        [disabled]=\"ngControl.control.disabled\"\r\n                        (click)=\"datePicker.open()\"\r\n                        [ngClass]=\"ngControl.control.disabled ? 'readonly-color' : 'default-form-icon-color'\"\r\n    ></i-tech-icon-button>\r\n\r\n    <mat-datepicker #datePicker (closed)=\"isOpen = false;clickForFocusOut()\"\r\n                    (opened)=\"isOpen = true;focused = true\"></mat-datepicker>\r\n\r\n    <!-- Error Messages -->\r\n    <mat-error *ngIf=\"!!(ngControl.control.errors && submit)\">\r\n      {{ ngControl.control | generateErrorMessages : label : defaultPatternKey }}\r\n    </mat-error>\r\n\r\n    <!-- Helper Text -->\r\n    <mat-hint *ngIf=\"!(!!(ngControl.control.errors && submit)) && hintText\"\r\n              [ngClass]=\"{'readonly-color' : ngControl.control.disabled}\"\r\n    >\r\n      {{ hintText | translate }}\r\n    </mat-hint>\r\n\r\n  </mat-form-field>\r\n</div>\r\n"]}
@@ -0,0 +1,118 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { MatDatepickerModule } from "@angular/material/datepicker";
3
+ import { ReactiveFormsModule, UntypedFormControl, UntypedFormGroup, Validators } from "@angular/forms";
4
+ import { MatFormFieldModule } from "@angular/material/form-field";
5
+ import { NgClass, NgIf } from "@angular/common";
6
+ import { TranslateModule } from "@ngx-translate/core";
7
+ import { IconButtonComponent } from "../icon-button/icon-button.component";
8
+ import { DateMaskDirective } from "../../directives/date-mask.directive";
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/material/form-field";
11
+ import * as i2 from "@angular/forms";
12
+ import * as i3 from "@angular/material/datepicker";
13
+ import * as i4 from "@ngx-translate/core";
14
+ export class DateRangeDatepickerComponent {
15
+ constructor() {
16
+ this.submit = false;
17
+ this.clearValue = true;
18
+ this.errorMessage = '';
19
+ this.hintText = 'MM/DD/YYYY - MM/DD/YYYY';
20
+ this.resetForm = new EventEmitter();
21
+ this.selectionChange = new EventEmitter();
22
+ this.isOpen = false;
23
+ this.dateRangeForm = new UntypedFormGroup({
24
+ startDate: new UntypedFormControl('', [Validators.maxLength(10)]),
25
+ endDate: new UntypedFormControl('', [Validators.maxLength(10)]),
26
+ });
27
+ this.customErrorStateMatcher = {
28
+ isErrorState: (control, form) => {
29
+ return !!(control && control.invalid && this.submit);
30
+ }
31
+ };
32
+ }
33
+ ngAfterViewInit() {
34
+ setTimeout(() => {
35
+ if (this.defaultValue?.length) {
36
+ this.dateRangeForm.patchValue({
37
+ startDate: this.defaultValue[0],
38
+ endDate: this.defaultValue[1]
39
+ });
40
+ }
41
+ });
42
+ }
43
+ ngOnChanges(changes) {
44
+ setTimeout(() => {
45
+ if (changes['value']?.currentValue && !(changes['value'].currentValue[0])) {
46
+ if (this.picker) {
47
+ this.dateRangeForm.reset();
48
+ this.picker.select(null);
49
+ }
50
+ }
51
+ else if (changes['value'] && this.value?.length) {
52
+ this.dateRangeForm.setValue({
53
+ startDate: new Date(this.value[0] || ''),
54
+ endDate: new Date(this.value[1] || '')
55
+ });
56
+ }
57
+ }, 10);
58
+ }
59
+ clickForFocusOut() {
60
+ setTimeout(() => {
61
+ this.min.nativeElement.focus();
62
+ this.min.nativeElement.blur();
63
+ }, 120);
64
+ }
65
+ setDate(value, element) {
66
+ this.selectionChange.emit(value);
67
+ element.blur();
68
+ }
69
+ keyEventHandler(event, value, element) {
70
+ if (event.code === 'Enter') {
71
+ this.setDate(value, element);
72
+ }
73
+ }
74
+ 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: "app-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\"\r\n [formGroup]=\"dateRangeForm\"\r\n>\r\n <div class=\"w-100\">\r\n <mat-label>\r\n {{(label || '') | translate}}\r\n </mat-label>\r\n </div>\r\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\r\n <mat-date-range-input [rangePicker]=\"picker\">\r\n <input formControlName=\"startDate\"\r\n [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\r\n [title]=\"key ? key.title : 'Date'\"\r\n [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\r\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\r\n matStartDate #min\r\n dateMask\r\n [errorStateMatcher]=\"customErrorStateMatcher\"\r\n [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\r\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\r\n (dateChange)=\"setDate([min.value, max.value || null],min)\">\r\n <input formControlName=\"endDate\"\r\n [placeholder]=\"(placeholder ? placeholder[1] : 'End Date')\"\r\n [title]=\"key ? key.title : 'Date'\"\r\n [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\r\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\r\n matEndDate #max\r\n dateMask\r\n [errorStateMatcher]=\"customErrorStateMatcher\"\r\n [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\r\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\r\n (dateChange)=\"setDate([min.value, max.value || null],max)\">\r\n </mat-date-range-input>\r\n <i-tech-icon-button matSuffix\r\n [iconName]=\"'cancel'\"\r\n (buttonClick)=\"selectionChange.emit([null, null])\"\r\n class=\"default-form-icon-color\"\r\n *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\r\n ></i-tech-icon-button>\r\n <i-tech-icon-button matSuffix [iconName]=\"'date_range'\" (buttonClick)=\"picker.open()\" class=\"default-form-icon-color\"></i-tech-icon-button>\r\n <mat-date-range-picker #picker (closed)=\"isOpen = false;clickForFocusOut()\" (opened)=\"isOpen = true\"></mat-date-range-picker>\r\n <mat-hint *ngIf=\"hintText && !errorMessage\">{{hintText}}</mat-hint>\r\n </mat-form-field>\r\n</div>\r\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
+ }
77
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateRangeDatepickerComponent, decorators: [{
78
+ type: Component,
79
+ args: [{ selector: 'app-mat-range-datepicker', imports: [
80
+ MatFormFieldModule,
81
+ ReactiveFormsModule,
82
+ MatDatepickerModule,
83
+ NgClass, NgIf,
84
+ TranslateModule,
85
+ IconButtonComponent, DateMaskDirective
86
+ ], standalone: true, template: "<div class=\"flex_column relative mat-date-range-input\"\r\n [formGroup]=\"dateRangeForm\"\r\n>\r\n <div class=\"w-100\">\r\n <mat-label>\r\n {{(label || '') | translate}}\r\n </mat-label>\r\n </div>\r\n <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\r\n <mat-date-range-input [rangePicker]=\"picker\">\r\n <input formControlName=\"startDate\"\r\n [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\r\n [title]=\"key ? key.title : 'Date'\"\r\n [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\r\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\r\n matStartDate #min\r\n dateMask\r\n [errorStateMatcher]=\"customErrorStateMatcher\"\r\n [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\r\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\r\n (dateChange)=\"setDate([min.value, max.value || null],min)\">\r\n <input formControlName=\"endDate\"\r\n [placeholder]=\"(placeholder ? placeholder[1] : 'End Date')\"\r\n [title]=\"key ? key.title : 'Date'\"\r\n [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\r\n [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\r\n matEndDate #max\r\n dateMask\r\n [errorStateMatcher]=\"customErrorStateMatcher\"\r\n [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\r\n (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\r\n (dateChange)=\"setDate([min.value, max.value || null],max)\">\r\n </mat-date-range-input>\r\n <i-tech-icon-button matSuffix\r\n [iconName]=\"'cancel'\"\r\n (buttonClick)=\"selectionChange.emit([null, null])\"\r\n class=\"default-form-icon-color\"\r\n *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\r\n ></i-tech-icon-button>\r\n <i-tech-icon-button matSuffix [iconName]=\"'date_range'\" (buttonClick)=\"picker.open()\" class=\"default-form-icon-color\"></i-tech-icon-button>\r\n <mat-date-range-picker #picker (closed)=\"isOpen = false;clickForFocusOut()\" (opened)=\"isOpen = true\"></mat-date-range-picker>\r\n <mat-hint *ngIf=\"hintText && !errorMessage\">{{hintText}}</mat-hint>\r\n </mat-form-field>\r\n</div>\r\n" }]
87
+ }], propDecorators: { label: [{
88
+ type: Input
89
+ }], placeholder: [{
90
+ type: Input
91
+ }], value: [{
92
+ type: Input
93
+ }], defaultValue: [{
94
+ type: Input
95
+ }], key: [{
96
+ type: Input
97
+ }], submit: [{
98
+ type: Input
99
+ }], clearValue: [{
100
+ type: Input
101
+ }], errorMessage: [{
102
+ type: Input
103
+ }], onePlaceholder: [{
104
+ type: Input
105
+ }], hintText: [{
106
+ type: Input
107
+ }], resetForm: [{
108
+ type: Output
109
+ }], selectionChange: [{
110
+ type: Output
111
+ }], picker: [{
112
+ type: ViewChild,
113
+ args: ['picker']
114
+ }], min: [{
115
+ type: ViewChild,
116
+ args: ['min']
117
+ }] } });
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 {\r\n  AfterViewInit,\r\n  Component, ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {MatDatepickerModule, MatDateRangePicker} from \"@angular/material/datepicker\";\r\nimport {ReactiveFormsModule, UntypedFormControl, UntypedFormGroup, Validators} from \"@angular/forms\";\r\nimport {MatFormFieldModule} from \"@angular/material/form-field\";\r\nimport {NgClass, NgIf} from \"@angular/common\";\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\nimport {IconButtonComponent} from \"../icon-button/icon-button.component\";\r\nimport {DateMaskDirective} from \"../../directives/date-mask.directive\";\r\n\r\n@Component({\r\n  selector: 'app-mat-range-datepicker',\r\n  templateUrl: './date-range-datepicker.component.html',\r\n  imports: [\r\n    MatFormFieldModule,\r\n    ReactiveFormsModule,\r\n    MatDatepickerModule,\r\n    NgClass, NgIf,\r\n    TranslateModule,\r\n    IconButtonComponent, DateMaskDirective\r\n  ],\r\n  standalone: true\r\n})\r\nexport class DateRangeDatepickerComponent implements OnChanges, AfterViewInit {\r\n  @Input() label?: string;\r\n  @Input() placeholder?: Array<string>;\r\n  @Input() value?: Array<string | null>;\r\n  @Input() defaultValue?: Array<Date>;\r\n  @Input() key?: {start: string, end: string, title: string};\r\n  @Input() submit = false;\r\n  @Input() clearValue = true;\r\n  @Input() errorMessage = '';\r\n  @Input() onePlaceholder?: string;\r\n  @Input() hintText: string = 'MM/DD/YYYY - MM/DD/YYYY';\r\n  @Output() resetForm = new EventEmitter<any>();\r\n  @Output() selectionChange = new EventEmitter<any>();\r\n  @ViewChild('picker') picker!: MatDateRangePicker<any>;\r\n  @ViewChild('min') min!: ElementRef;\r\n  isOpen = false;\r\n\r\n  dateRangeForm = new UntypedFormGroup({\r\n    startDate: new UntypedFormControl('', [Validators.maxLength(10)]),\r\n    endDate: new UntypedFormControl('', [Validators.maxLength(10)]),\r\n  });\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      if (this.defaultValue?.length) {\r\n        this.dateRangeForm.patchValue({\r\n          startDate: this.defaultValue[0],\r\n          endDate: this.defaultValue[1]\r\n        })\r\n      }\r\n    })\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    setTimeout(() => {\r\n      if (changes['value']?.currentValue && !(changes['value'].currentValue[0])) {\r\n        if (this.picker) {\r\n          this.dateRangeForm.reset();\r\n          this.picker.select(null)\r\n        }\r\n      } else if (changes['value'] && this.value?.length) {\r\n        this.dateRangeForm.setValue({\r\n          startDate: new Date(this.value[0] || ''),\r\n          endDate: new Date(this.value[1] || '')\r\n        })\r\n      }\r\n    }, 10)\r\n  }\r\n\r\n  clickForFocusOut(): void {\r\n    setTimeout(() => {\r\n      this.min.nativeElement.focus();\r\n      this.min.nativeElement.blur();\r\n    },120)\r\n  }\r\n\r\n  customErrorStateMatcher = {\r\n    isErrorState: (control: any, form: any): boolean => {\r\n      return !!(control && control.invalid && this.submit);\r\n    }\r\n  };\r\n\r\n  setDate(value: Array<string | null>, element: any): void {\r\n    this.selectionChange.emit(value);\r\n    element.blur();\r\n  }\r\n\r\n  keyEventHandler(event: KeyboardEvent,value: Array<string | null>, element: any): void {\r\n    if (event.code === 'Enter') {\r\n      this.setDate(value,element)\r\n    }\r\n  }\r\n\r\n}\r\n","<div class=\"flex_column relative mat-date-range-input\"\r\n     [formGroup]=\"dateRangeForm\"\r\n>\r\n    <div class=\"w-100\">\r\n        <mat-label>\r\n            {{(label || '') | translate}}\r\n        </mat-label>\r\n    </div>\r\n    <mat-form-field appearance=\"outline\" [ngClass]=\"{'opened_calendar': isOpen}\">\r\n        <mat-date-range-input [rangePicker]=\"picker\">\r\n            <input formControlName=\"startDate\"\r\n                   [placeholder]=\" (placeholder ? placeholder[0] : 'Start Date')\"\r\n                   [title]=\"key ? key.title :  'Date'\"\r\n                   [attr.data-accessKey]=\"key ? key.start : 'minStartDate'\"\r\n                   [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\r\n                   matStartDate #min\r\n                   dateMask\r\n                   [errorStateMatcher]=\"customErrorStateMatcher\"\r\n                   [rangeFormControl]=\"dateRangeForm.controls['startDate']\"\r\n                   (keydown)=\"keyEventHandler($event,[min.value, max.value || null],min)\"\r\n                   (dateChange)=\"setDate([min.value, max.value || null],min)\">\r\n            <input formControlName=\"endDate\"\r\n                   [placeholder]=\"(placeholder  ? placeholder[1] : 'End Date')\"\r\n                   [title]=\"key ? key.title :  'Date'\"\r\n                   [attr.data-accessKey]=\"key ? key.end : 'maxEndDate'\"\r\n                   [attr.data-parentKey]=\"key ? (key.start + '_' + key.end) : 'minStartDate_maxEndDate'\"\r\n                   matEndDate #max\r\n                   dateMask\r\n                   [errorStateMatcher]=\"customErrorStateMatcher\"\r\n                   [rangeFormControl]=\"dateRangeForm.controls['endDate']\"\r\n                   (keydown)=\"keyEventHandler($event,[min.value, max.value || null],max)\"\r\n                   (dateChange)=\"setDate([min.value, max.value || null],max)\">\r\n        </mat-date-range-input>\r\n        <i-tech-icon-button matSuffix\r\n             [iconName]=\"'cancel'\"\r\n             (buttonClick)=\"selectionChange.emit([null, null])\"\r\n             class=\"default-form-icon-color\"\r\n             *ngIf=\"dateRangeForm.get('startDate')?.value && this.dateRangeForm.get('endDate')?.value\"\r\n        ></i-tech-icon-button>\r\n        <i-tech-icon-button matSuffix [iconName]=\"'date_range'\" (buttonClick)=\"picker.open()\" class=\"default-form-icon-color\"></i-tech-icon-button>\r\n        <mat-date-range-picker #picker (closed)=\"isOpen = false;clickForFocusOut()\" (opened)=\"isOpen = true\"></mat-date-range-picker>\r\n        <mat-hint *ngIf=\"hintText && !errorMessage\">{{hintText}}</mat-hint>\r\n    </mat-form-field>\r\n</div>\r\n"]}
@@ -0,0 +1,92 @@
1
+ import { Directive, HostListener, Input } from '@angular/core';
2
+ import { NgxMaskDirective, NgxMaskService } from 'ngx-mask';
3
+ import * as i0 from "@angular/core";
4
+ export class DateMaskDirective {
5
+ constructor(elementRef, injector) {
6
+ this.elementRef = elementRef;
7
+ this.injector = injector;
8
+ this.expressions = {
9
+ DMY: 'M0/d0/0000',
10
+ DM: 'M0/d0'
11
+ };
12
+ this.dateRegex = new RegExp(/^\s*(1[012]|0?[1-9])\/(3[01]|[12][0-9]|0?[1-9])\/((?:19|20)\d{2})\s*$/);
13
+ this.dayMonthRegex = new RegExp(/^\s*(1[012]|0?[1-9])\/(3[01]|[12][0-9]|0?[1-9])$/);
14
+ this.previousValue = '';
15
+ this.maskService = this.injector.get(NgxMaskService);
16
+ }
17
+ onInput() {
18
+ let value = this.elementRef.nativeElement.value;
19
+ if (this.existsZerosInString(value)) {
20
+ value = this.previousValue;
21
+ }
22
+ const maskedValue = this.maskService.applyMask(value, this.maskType === 'DAY_MONTH' ? this.expressions.DM : this.expressions.DMY);
23
+ if (this.maskType !== 'DAY_MONTH' && !isNaN(new Date(maskedValue).getTime())) {
24
+ if (this.matDatepicker) {
25
+ this.matDatepicker.select(new Date(maskedValue));
26
+ }
27
+ else if (this.rangeFormControl) {
28
+ this.rangeFormControl.setValue(new Date(maskedValue));
29
+ }
30
+ }
31
+ if (isNaN(new Date(maskedValue).getTime())) {
32
+ this.matDatepicker.select(null);
33
+ }
34
+ this.elementRef.nativeElement.value = maskedValue || null;
35
+ this.previousValue = maskedValue || null;
36
+ }
37
+ onPaste(event) {
38
+ const pastedValue = event.clipboardData?.getData('text/plain');
39
+ if (!pastedValue) {
40
+ return;
41
+ }
42
+ if (this.maskType === 'DAY_MONTH') {
43
+ if (!this.dayMonthRegex.test(pastedValue)) {
44
+ event?.preventDefault();
45
+ }
46
+ }
47
+ else {
48
+ if (!this.dateRegex.test(pastedValue)) {
49
+ event?.preventDefault();
50
+ }
51
+ }
52
+ }
53
+ existsZerosInString(date) {
54
+ const dateToArray = date.split('/');
55
+ let isValid;
56
+ if (this.maskType === 'DAY_MONTH') {
57
+ isValid = !!dateToArray.find((part) => part.includes('00'));
58
+ }
59
+ else {
60
+ if (dateToArray.length < 3) {
61
+ isValid = !!dateToArray.find((part) => part.includes('00'));
62
+ }
63
+ else {
64
+ isValid = (dateToArray[2][0] == '0') || (+dateToArray[2][0] > 2);
65
+ }
66
+ }
67
+ return isValid;
68
+ }
69
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateMaskDirective, deps: [{ token: i0.ElementRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
70
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DateMaskDirective, isStandalone: true, selector: "[dateMask]", inputs: { maskType: "maskType", matDatepicker: "matDatepicker", rangeFormControl: "rangeFormControl" }, host: { listeners: { "input": "onInput()", "paste": "onPaste($event)" } }, providers: [NgxMaskDirective], ngImport: i0 }); }
71
+ }
72
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateMaskDirective, decorators: [{
73
+ type: Directive,
74
+ args: [{
75
+ selector: '[dateMask]',
76
+ providers: [NgxMaskDirective],
77
+ standalone: true
78
+ }]
79
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Injector }], propDecorators: { maskType: [{
80
+ type: Input
81
+ }], matDatepicker: [{
82
+ type: Input
83
+ }], rangeFormControl: [{
84
+ type: Input
85
+ }], onInput: [{
86
+ type: HostListener,
87
+ args: ['input']
88
+ }], onPaste: [{
89
+ type: HostListener,
90
+ args: ['paste', ['$event']]
91
+ }] } });
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-mask.directive.js","sourceRoot":"","sources":["../../../../../projects/shared-components/src/lib/directives/date-mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Injector, Input\r\n} from '@angular/core';\r\nimport { NgxMaskDirective, NgxMaskService} from 'ngx-mask';\r\nimport {MatDatepicker} from \"@angular/material/datepicker\";\r\nimport {AbstractControl} from \"@angular/forms\";\r\n\r\n@Directive({\r\n  selector: '[dateMask]',\r\n  providers:[NgxMaskDirective],\r\n  standalone: true\r\n})\r\nexport class DateMaskDirective {\r\n  @Input() maskType!: string;\r\n  @Input() matDatepicker!: MatDatepicker<any>;\r\n  @Input() rangeFormControl!: AbstractControl;\r\n\r\n  expressions = {\r\n    DMY: 'M0/d0/0000',\r\n    DM: 'M0/d0'\r\n  }\r\n  maskService: any;\r\n  dateRegex = new RegExp(/^\\s*(1[012]|0?[1-9])\\/(3[01]|[12][0-9]|0?[1-9])\\/((?:19|20)\\d{2})\\s*$/);\r\n  dayMonthRegex = new RegExp(/^\\s*(1[012]|0?[1-9])\\/(3[01]|[12][0-9]|0?[1-9])$/);\r\n  previousValue = '';\r\n\r\n  constructor(\r\n      private elementRef: ElementRef,\r\n      private injector: Injector,\r\n  ) {\r\n    this.maskService = this.injector.get(NgxMaskService);\r\n  }\r\n\r\n  @HostListener('input')\r\n  onInput() {\r\n    let value = this.elementRef.nativeElement.value;\r\n\r\n    if (this.existsZerosInString(value)) {\r\n      value = this.previousValue;\r\n    }\r\n\r\n    const maskedValue = this.maskService.applyMask(\r\n        value,\r\n        this.maskType === 'DAY_MONTH' ? this.expressions.DM : this.expressions.DMY\r\n    );\r\n\r\n    if (this.maskType !== 'DAY_MONTH' && !isNaN(new Date(maskedValue).getTime())) {\r\n      if (this.matDatepicker) {\r\n        this.matDatepicker.select(new Date(maskedValue));\r\n      } else if (this.rangeFormControl) {\r\n        this.rangeFormControl.setValue(new Date(maskedValue));\r\n     }\r\n    }\r\n\r\n    if (isNaN(new Date(maskedValue).getTime())) {\r\n      this.matDatepicker.select(null)\r\n    }\r\n\r\n    this.elementRef.nativeElement.value = maskedValue || null;\r\n    this.previousValue = maskedValue || null;\r\n  }\r\n\r\n  @HostListener('paste', ['$event'])\r\n  onPaste(event: ClipboardEvent) {\r\n    const pastedValue = event.clipboardData?.getData('text/plain');\r\n    if (!pastedValue) { return; }\r\n    if (this.maskType === 'DAY_MONTH') {\r\n      if (!this.dayMonthRegex.test(pastedValue)) {\r\n        event?.preventDefault();\r\n      }\r\n    } else {\r\n      if (!this.dateRegex.test(pastedValue)) {\r\n        event?.preventDefault();\r\n      }\r\n    }\r\n  }\r\n\r\n  existsZerosInString(date: string): boolean {\r\n    const dateToArray = date.split('/');\r\n    let isValid;\r\n    if (this.maskType === 'DAY_MONTH') {\r\n      isValid = !!dateToArray.find((part: string) => part.includes('00'));\r\n    } else {\r\n      if (dateToArray.length < 3) {\r\n        isValid = !!dateToArray.find((part: string) => part.includes('00'));\r\n      } else {\r\n        isValid = (dateToArray[2][0] == '0') || (+dateToArray[2][0] > 2);\r\n      }\r\n\r\n    }\r\n    return isValid;\r\n  }\r\n\r\n}\r\n"]}
@@ -13,4 +13,7 @@ export * from './lib/components/icon-button/icon-button.component';
13
13
  export * from './lib/components/text/text-input.component';
14
14
  export * from './lib/components/button/button.component';
15
15
  export * from './lib/components/autocomplete-select/autocomplete-select.component';
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsb0VBQW9FLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygc2hhcmVkLWNvbXBvbmVudHNcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9nZW5lcmF0ZS1lcnJvci1tZXNzYWdlcy5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvYXJyYXktdG8tc3RyaW5nLnBpcGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9nZXQtdmFsdWUtYnkta2V5LWZyb20tb2JqZWN0LnBpcGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9pbnB1dC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlcy9hcHAtaW5wdXQuaW50ZXJmYWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlcy9idXR0b24tdHlwZXMuZW51bSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZXMvYXV0b2NvbXBsZXRlLWNvbmZpZ3MuaW50ZXJmYWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9pbnB1dC1tYXNrLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvaWNvbi1idXR0b24vaWNvbi1idXR0b24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90ZXh0L3RleHQtaW5wdXQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvYXV0b2NvbXBsZXRlLXNlbGVjdC9hdXRvY29tcGxldGUtc2VsZWN0LmNvbXBvbmVudCc7XHJcblxyXG4iXX0=
16
+ export * from './lib/components/date-picker/date-picker.component';
17
+ export * from './lib/components/clear-value/clear-value.component';
18
+ export * from './lib/components/date-range-datepicker/date-range-datepicker.component';
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYyxvREFBb0QsQ0FBQztBQUNuRSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsd0VBQXdFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygc2hhcmVkLWNvbXBvbmVudHNcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9nZW5lcmF0ZS1lcnJvci1tZXNzYWdlcy5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvYXJyYXktdG8tc3RyaW5nLnBpcGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9nZXQtdmFsdWUtYnkta2V5LWZyb20tb2JqZWN0LnBpcGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9pbnB1dC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlcy9hcHAtaW5wdXQuaW50ZXJmYWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlcy9idXR0b24tdHlwZXMuZW51bSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZXMvYXV0b2NvbXBsZXRlLWNvbmZpZ3MuaW50ZXJmYWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9pbnB1dC1tYXNrLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvaWNvbi1idXR0b24vaWNvbi1idXR0b24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90ZXh0L3RleHQtaW5wdXQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvYXV0b2NvbXBsZXRlLXNlbGVjdC9hdXRvY29tcGxldGUtc2VsZWN0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZGF0ZS1waWNrZXIvZGF0ZS1waWNrZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jbGVhci12YWx1ZS9jbGVhci12YWx1ZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2RhdGUtcmFuZ2UtZGF0ZXBpY2tlci9kYXRlLXJhbmdlLWRhdGVwaWNrZXIuY29tcG9uZW50JztcclxuXHJcbiJdfQ==