master-control 0.4.99 → 0.5.2
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/age-date/age-date.component.mjs +7 -3
- package/esm2022/lib/amount-textbox/amount-textbox.component.mjs +7 -3
- package/esm2022/lib/annuity-calculator-radio/annuity-calculator-radio.component.mjs +8 -4
- package/esm2022/lib/autocomplete/autocomplete.component.mjs +5 -3
- package/esm2022/lib/button/button.component.mjs +7 -3
- package/esm2022/lib/checkbox/checkbox.component.mjs +7 -3
- package/esm2022/lib/dob/dob.component.mjs +7 -3
- package/esm2022/lib/email-with-domain/email-with-domain.component.mjs +7 -3
- package/esm2022/lib/field-name-attribute.util.mjs +11 -0
- package/esm2022/lib/info-textbox/info-textbox.component.mjs +7 -3
- package/esm2022/lib/master-control.component.mjs +8 -3
- package/esm2022/lib/medial-questions/medial-questions.component.mjs +3 -3
- package/esm2022/lib/mob-number/mob-number.component.mjs +5 -3
- package/esm2022/lib/multiple-select/multiple-select.component.mjs +5 -3
- package/esm2022/lib/otp-mob-number/otp-mob-number.component.mjs +7 -3
- package/esm2022/lib/otp-textbox/otp-textbox.component.mjs +7 -3
- package/esm2022/lib/radio/radio.component.mjs +5 -3
- package/esm2022/lib/search-multi-select/search-multi-select.component.mjs +5 -3
- package/esm2022/lib/select/select.component.mjs +7 -6
- package/esm2022/lib/select-textbox/select-textbox.component.mjs +7 -3
- package/esm2022/lib/subscript-textbox/subscript-textbox.component.mjs +7 -3
- package/esm2022/lib/suffix-textbox/suffix-textbox.component.mjs +7 -3
- package/esm2022/lib/tag-mob-number/tag-mob-number.component.mjs +7 -3
- package/esm2022/lib/textarea/textarea.component.mjs +7 -3
- package/esm2022/lib/textbox/textbox.component.mjs +5 -3
- package/esm2022/lib/textbox-with-image/textbox-with-image.component.mjs +7 -3
- package/esm2022/lib/textbox-with-text/textbox-with-text.component.mjs +7 -3
- package/esm2022/lib/textbox-with-underscore/textbox-with-underscore.component.mjs +7 -3
- package/esm2022/lib/toggle/toggle.component.mjs +7 -3
- package/esm2022/lib/toggle-button/toggle-button.component.mjs +7 -3
- package/esm2022/lib/upload/upload.component.mjs +7 -3
- package/fesm2022/master-control.mjs +146 -62
- package/fesm2022/master-control.mjs.map +1 -1
- package/lib/age-date/age-date.component.d.ts +1 -0
- package/lib/amount-textbox/amount-textbox.component.d.ts +1 -0
- package/lib/button/button.component.d.ts +3 -1
- package/lib/checkbox/checkbox.component.d.ts +1 -0
- package/lib/dob/dob.component.d.ts +1 -0
- package/lib/email-with-domain/email-with-domain.component.d.ts +1 -0
- package/lib/field-name-attribute.util.d.ts +1 -0
- package/lib/info-textbox/info-textbox.component.d.ts +1 -0
- package/lib/otp-mob-number/otp-mob-number.component.d.ts +1 -0
- package/lib/otp-textbox/otp-textbox.component.d.ts +1 -0
- package/lib/select/select.component.d.ts +1 -0
- package/lib/select-textbox/select-textbox.component.d.ts +1 -0
- package/lib/subscript-textbox/subscript-textbox.component.d.ts +1 -0
- package/lib/suffix-textbox/suffix-textbox.component.d.ts +1 -0
- package/lib/tag-mob-number/tag-mob-number.component.d.ts +1 -0
- package/lib/textarea/textarea.component.d.ts +1 -0
- package/lib/textbox-with-image/textbox-with-image.component.d.ts +1 -0
- package/lib/textbox-with-text/textbox-with-text.component.d.ts +1 -0
- package/lib/textbox-with-underscore/textbox-with-underscore.component.d.ts +1 -0
- package/lib/toggle/toggle.component.d.ts +1 -0
- package/lib/toggle-button/toggle-button.component.d.ts +3 -2
- package/lib/upload/upload.component.d.ts +1 -0
- package/master-control-0.5.02.tgz +0 -0
- package/package.json +1 -1
- package/master-control-0.4.99.tgz +0 -0
|
@@ -6,6 +6,7 @@ import { MAT_DATE_FORMATS } from '@angular/material/core';
|
|
|
6
6
|
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
7
7
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
8
8
|
import { MatInputModule } from '@angular/material/input';
|
|
9
|
+
import { initializeFieldNameAttribute } from '../field-name-attribute.util';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "../master-control.service";
|
|
11
12
|
import * as i2 from "@angular/material/input";
|
|
@@ -26,6 +27,9 @@ export class AgeDateComponent {
|
|
|
26
27
|
constructor(service) {
|
|
27
28
|
this.service = service;
|
|
28
29
|
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
initializeFieldNameAttribute(this.field());
|
|
32
|
+
}
|
|
29
33
|
ngAfterViewChecked() {
|
|
30
34
|
if (this.inputValue) {
|
|
31
35
|
this.calculateAge(this.inputValue);
|
|
@@ -194,7 +198,7 @@ export class AgeDateComponent {
|
|
|
194
198
|
useExisting: AgeDateComponent,
|
|
195
199
|
multi: true
|
|
196
200
|
},
|
|
197
|
-
], ngImport: i0, template: "<label *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n <input\n matInput\n autocomplete=\"off\"\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [placeholder]=\"field()?.placeHolder\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n [matDatepicker]=\"picker\"\n (input)=\"dateDivisionFormat($event)\"\n [disabled]=\"field()?.isDisable\"\n [min]=\"field()?.configData?.min\"\n [max]=\"field()?.configData?.max\"\n (dateChange)=\"onInputChange($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"inputValue\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else{\n <input\n matInput\n autocomplete=\"off\"\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [placeholder]=\"field()?.placeHolder\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n [matDatepicker]=\"picker\"\n [min]=\"field()?.configData?.min\"\n [max]=\"field()?.configData?.max\"\n (input)=\"dateDivisionFormat($event)\"\n [disabled]=\"field()?.isDisable\"\n (dateChange)=\"onInputChange($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"inputValue\"\n />\n }\n <span matSuffix class=\"right-date-text\" *ngIf=\"!this.service.checkIfValueIsEmpty(age) && !this.service.checkIfValueIsEmpty(inputValue) && age >= 0\">\n ({{ age }}) yrs\n </span>\n <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"!field()?.isDisable\">\n <img\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\n style=\"width: 16px\"\n matDatepickerToggleIcon\n />\n </mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error *ngIf=\"false\">\n {{ field()?.validators?.isRequiredMessage }}\n </mat-error>\n</mat-form-field>\n<div class=\"error-message\" *ngIf=\"false\">\n {{ field()?.validators?.isRequiredMessage }}.\n</div>\n<div class=\"error-message\" *ngIf=\"false\">\n {{ field()?.validators?.patternMessage }}.\n</div>\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0}.right-date-text{padding:4px 8px;border-radius:4px;font-weight:600;font-size:12px;color:#444;background:#f5f5f5;margin-right:8px;display:inline-flex;align-items:center;vertical-align:middle;height:20px;white-space:nowrap!important}::ng-deep .mat-mdc-form-field-icon-suffix{display:inline-flex!important;align-items:center!important;gap:0px!important}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important;font-size:12px!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}*{font-family:mulish!important}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.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: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i5.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "ngmodule", type: MomentDateModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
201
|
+
], ngImport: i0, template: "<label *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n <input\n matInput\n autocomplete=\"off\"\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n [placeholder]=\"field()?.placeHolder\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n [matDatepicker]=\"picker\"\n (input)=\"dateDivisionFormat($event)\"\n [disabled]=\"field()?.isDisable\"\n [min]=\"field()?.configData?.min\"\n [max]=\"field()?.configData?.max\"\n (dateChange)=\"onInputChange($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"inputValue\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else{\n <input\n matInput\n autocomplete=\"off\"\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n [placeholder]=\"field()?.placeHolder\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n [matDatepicker]=\"picker\"\n [min]=\"field()?.configData?.min\"\n [max]=\"field()?.configData?.max\"\n (input)=\"dateDivisionFormat($event)\"\n [disabled]=\"field()?.isDisable\"\n (dateChange)=\"onInputChange($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"inputValue\"\n />\n }\n <span matSuffix class=\"right-date-text\" *ngIf=\"!this.service.checkIfValueIsEmpty(age) && !this.service.checkIfValueIsEmpty(inputValue) && age >= 0\">\n ({{ age }}) yrs\n </span>\n <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"!field()?.isDisable\">\n <img\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\n style=\"width: 16px\"\n matDatepickerToggleIcon\n />\n </mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error *ngIf=\"false\">\n {{ field()?.validators?.isRequiredMessage }}\n </mat-error>\n</mat-form-field>\n<div class=\"error-message\" *ngIf=\"false\">\n {{ field()?.validators?.isRequiredMessage }}.\n</div>\n<div class=\"error-message\" *ngIf=\"false\">\n {{ field()?.validators?.patternMessage }}.\n</div>\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0}.right-date-text{padding:4px 8px;border-radius:4px;font-weight:600;font-size:12px;color:#444;background:#f5f5f5;margin-right:8px;display:inline-flex;align-items:center;vertical-align:middle;height:20px;white-space:nowrap!important}::ng-deep .mat-mdc-form-field-icon-suffix{display:inline-flex!important;align-items:center!important;gap:0px!important}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important;font-size:12px!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}*{font-family:mulish!important}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.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: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i5.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "ngmodule", type: MomentDateModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
198
202
|
}
|
|
199
203
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AgeDateComponent, decorators: [{
|
|
200
204
|
type: Component,
|
|
@@ -230,7 +234,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
230
234
|
useExisting: AgeDateComponent,
|
|
231
235
|
multi: true
|
|
232
236
|
},
|
|
233
|
-
], template: "<label *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n <input\n matInput\n autocomplete=\"off\"\n [type]=\"field()?.controlType\"\n [name]=\"field()?.
|
|
237
|
+
], template: "<label *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n <input\n matInput\n autocomplete=\"off\"\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n [placeholder]=\"field()?.placeHolder\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n [matDatepicker]=\"picker\"\n (input)=\"dateDivisionFormat($event)\"\n [disabled]=\"field()?.isDisable\"\n [min]=\"field()?.configData?.min\"\n [max]=\"field()?.configData?.max\"\n (dateChange)=\"onInputChange($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"inputValue\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else{\n <input\n matInput\n autocomplete=\"off\"\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n [placeholder]=\"field()?.placeHolder\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n [matDatepicker]=\"picker\"\n [min]=\"field()?.configData?.min\"\n [max]=\"field()?.configData?.max\"\n (input)=\"dateDivisionFormat($event)\"\n [disabled]=\"field()?.isDisable\"\n (dateChange)=\"onInputChange($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"inputValue\"\n />\n }\n <span matSuffix class=\"right-date-text\" *ngIf=\"!this.service.checkIfValueIsEmpty(age) && !this.service.checkIfValueIsEmpty(inputValue) && age >= 0\">\n ({{ age }}) yrs\n </span>\n <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"!field()?.isDisable\">\n <img\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\n style=\"width: 16px\"\n matDatepickerToggleIcon\n />\n </mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error *ngIf=\"false\">\n {{ field()?.validators?.isRequiredMessage }}\n </mat-error>\n</mat-form-field>\n<div class=\"error-message\" *ngIf=\"false\">\n {{ field()?.validators?.isRequiredMessage }}.\n</div>\n<div class=\"error-message\" *ngIf=\"false\">\n {{ field()?.validators?.patternMessage }}.\n</div>\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0}.right-date-text{padding:4px 8px;border-radius:4px;font-weight:600;font-size:12px;color:#444;background:#f5f5f5;margin-right:8px;display:inline-flex;align-items:center;vertical-align:middle;height:20px;white-space:nowrap!important}::ng-deep .mat-mdc-form-field-icon-suffix{display:inline-flex!important;align-items:center!important;gap:0px!important}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important;font-size:12px!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}*{font-family:mulish!important}\n"] }]
|
|
234
238
|
}], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { blur: [{
|
|
235
239
|
type: Output
|
|
236
240
|
}], valueChange: [{
|
|
@@ -240,4 +244,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
240
244
|
}], invalidDate: [{
|
|
241
245
|
type: Output
|
|
242
246
|
}] } });
|
|
243
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"age-date.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/age-date/age-date.component.ts","../../../../../projects/master-control/src/lib/age-date/age-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, input, AfterViewChecked, Output, EventEmitter } from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MomentDateModule } from '@angular/material-moment-adapter';\nimport { MAT_DATE_FORMATS } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MasterControlService } from '../master-control.service';\n\n@Component({\n  selector: 'lib-age-date',\n  standalone: true,\n  imports: [\n    MatInputModule,\n    MatFormFieldModule,\n    CommonModule,\n    MatDatepickerModule,\n    MomentDateModule,\n    ReactiveFormsModule\n  ],\n  providers: [{ provide: MAT_DATE_FORMATS, useValue: {\n  parse: {\n    dateInput: [\n      'DD-MM-YYYY',\n      'DD/MM/YYYY',\n      'YYYY/MM/DD',\n      'MM/DD/YYYY',\n      'DD MMM YYYY',\n      'DD MMMM YYYY',\n      'DD-MMM-YYYY',\n    ],\n  },\n  display: {\n    dateInput: 'DD/MMM/YYYY',\n    monthYearLabel: 'MMM YYYY',\n    dateA11yLabel: 'DD/MMM/YYYY',\n    monthYearA11yLabel: 'MMMM YYYY',\n  },\n  }\n  },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: AgeDateComponent,\n      multi: true\n    },\n],\n  templateUrl: './age-date.component.html',\n  styleUrl: './age-date.component.css',\n})\nexport class AgeDateComponent implements AfterViewChecked {\n  field: any = input.required<any>();\n  inputValue: any = null;\n  reactiveFormControlobject : any = input<any>();\n  age : any = null;\n  @Output() blur = new EventEmitter<any>();\n  @Output() valueChange = new EventEmitter<any>();\n  @Output() dateSelected = new EventEmitter<any>();\n  @Output() invalidDate = new EventEmitter<any>();\n  constructor(public service : MasterControlService) {}\n\n  ngAfterViewChecked(): void {\n    if (this.inputValue) {\n      this.calculateAge(this.inputValue);\n    }\n  }\n\n  dateDivisionFormat(event: any) {\n    let evt = event.target;\n\n    // Check if user is deleting (backspace/delete)\n    const isDeleting = event.inputType === 'deleteContentBackward' ||\n                       event.inputType === 'deleteContentForward' ||\n                       !event.data;\n\n    // If deleting, allow normal deletion without auto-adding slashes\n    if (isDeleting) {\n      return;\n    }\n\n    let value = evt.value;\n\n    // Handle case where we have existing slashes but need to reformat\n    // Split by slash to understand current structure\n    const parts = value.split('/');\n\n    // If we have exactly 3 parts (date/month/year), don't add more slashes\n    if (parts.length < 3) {\n       // For first slash after date (2 digits)\n    if (value.length > 2 && !value.includes('/')) {\n      evt.value = [value.slice(0, 2), '/', value.slice(2)].join('');\n    }\n    // For second slash after month\n    else if (parts.length === 2) {\n      const datePart = parts[0];\n      const monthPart = parts[1];\n\n\n\n      // Add slash after numeric month (exactly 2 digits) or alphabetic month (exactly 3 letters)\n      if ((monthPart.length === 2 && /^\\d{2}$/.test(monthPart)) ||\n          (monthPart.length === 3 && /^[a-zA-Z]{3}$/.test(monthPart))) {\n        evt.value = datePart + '/' + monthPart + '/';\n      }\n    }\n\n\n    }\n     const datePart = parts[0] || '';\n      const monthPart = parts[1] || '';\n      const yearPart = parts[2] || '';\n\n     // Prevent further input if limits are reached and restore previous value\n      if ((datePart.length >= 2) ||\n          (monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n          (monthPart.length >= 3 && /^[a-zA-Z]+$/.test(monthPart)) ||\n          (yearPart.length >= 4)) {\n\n        // Get cursor position to determine which part is being edited\n        const cursorPos = evt.selectionStart;\n        const isEditingDate = cursorPos <= 3;\n        const isEditingMonth = cursorPos > 3 && cursorPos <= (3 + monthPart.length);\n        const isEditingYear = cursorPos > (3 + monthPart.length + 1);\n\n        // Reconstruct the previous valid value by trimming excess characters\n        let previousValidValue='';\n        if (isEditingDate && datePart.length >= 2) {\n          // Trim date part to 2 characters max\n          const validDatePart = datePart.substring(0, 2);\n          previousValidValue = validDatePart + (parts[1] ? '/' + parts[1] : '') + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) {\n          // Trim numeric month to 2 characters max\n          const validMonthPart = monthPart.substring(0, 2);\n          previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 3 ) {\n          // Trim alphabetic month to 3 characters max\n          const validMonthPart = monthPart.substring(0, 3);\n          previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingYear && yearPart.length >= 4) {\n          // Trim year part to 4 characters max\n          const validYearPart = yearPart.substring(0, 4);\n          previousValidValue = parts[0] + '/' + parts[1] + '/' + validYearPart;\n        }\n\n        // Prevent input if trying to exceed limits by restoring previous value\n        if ((isEditingDate && datePart.length >= 2) ||\n            (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n            (isEditingMonth && monthPart.length >= 3 ) ||\n            (isEditingYear && yearPart.length >= 4)) {\n\n          // Restore the previous valid value\n          setTimeout(() => {\n            evt.value = previousValidValue;\n          }, 0);\n          event.preventDefault();\n          return;\n        }\n      }\n\n\n  }\n   _onChange: any = (inputValue:any) => {};\n  _unTouched: any = () => {};\n\n  writeValue(obj: any): void{\n    this.inputValue=obj;\n  };\n  registerOnChange(fn: any): void{\n    this._onChange = fn;\n  };\n  registerOnTouched(fn: any): void{\n    this._unTouched = fn;\n  };\n  setDisabledState?(isDisabled: boolean): void{};\n\n  onInputChange(event: any): void {\n    if (event.value) {\n      this.inputValue = event.value;\n      this._onChange(this.inputValue);\n      this.calculateAge(event.value);\n    } else {\n      this.inputValue = event.target.value;\n      this._onChange(this.inputValue);\n    }\n    this.dateSelected.emit({\n        formattedValue: this.inputValue,\n        dateObject: this.inputValue,\n        isValid: true,\n        source: 'datepicker'\n      });\n    this.valueChange.emit(this.inputValue);\n  }\n\n  onInputBlur(event : any): void {\n    if (!this.service.checkIfValueIsEmpty(event.target.value)) {\n      if (isNaN(Date.parse(event.target.value))) {\n        event.target.value = '';\n      } else {\n        this.calculateAge(event.target.value);\n      }\n    }\n    this._unTouched();\n    this.blur.emit(event);\n  }\n\n  calculateAge(birthDate: Date) {\n    const today = new Date();\n    const birthdate = new Date(birthDate);\n    let age = today.getFullYear() - birthdate.getFullYear();\n    const monthDiff = today.getMonth() - birthdate.getMonth();\n    const days_difference = today.getDate() - birthdate.getDate();\n    if (monthDiff < 0 || (monthDiff === 0 && days_difference < 0)) {\n      age = age - 1;\n    }\n    this.age = age;\n  }\n\n\n}\n","<label *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field\n  class=\"w-100\"\n  appearance=\"outline\"\n  *ngIf=\"field() && field()?.isVisible\"\n  [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n <input\n    matInput\n    autocomplete=\"off\"\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldName\"\n    [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder\"\n    [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\"\n    [matDatepicker]=\"picker\"\n    (input)=\"dateDivisionFormat($event)\"\n    [disabled]=\"field()?.isDisable\"\n    [min]=\"field()?.configData?.min\"\n    [max]=\"field()?.configData?.max\"\n    (dateChange)=\"onInputChange($event)\"\n    (blur)=\"onInputBlur($event)\"\n    [value]=\"inputValue\"\n    [formControl]=\"reactiveFormControlobject()\"\n  />\n }@else{\n    <input\n    matInput\n    autocomplete=\"off\"\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldName\"\n    [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder\"\n    [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\"\n    [matDatepicker]=\"picker\"\n    [min]=\"field()?.configData?.min\"\n    [max]=\"field()?.configData?.max\"\n    (input)=\"dateDivisionFormat($event)\"\n    [disabled]=\"field()?.isDisable\"\n    (dateChange)=\"onInputChange($event)\"\n    (blur)=\"onInputBlur($event)\"\n    [value]=\"inputValue\"\n  />\n }\n  <span matSuffix class=\"right-date-text\" *ngIf=\"!this.service.checkIfValueIsEmpty(age) && !this.service.checkIfValueIsEmpty(inputValue) && age >= 0\">\n    ({{ age }}) yrs\n  </span>\n  <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"!field()?.isDisable\">\n    <img\n      src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\n      style=\"width: 16px\"\n      matDatepickerToggleIcon\n    />\n  </mat-datepicker-toggle>\n  <mat-datepicker #picker></mat-datepicker>\n   <mat-error *ngIf=\"false\">\n    {{ field()?.validators?.isRequiredMessage }}\n  </mat-error>\n</mat-form-field>\n<div class=\"error-message\" *ngIf=\"false\">\n  {{ field()?.validators?.isRequiredMessage }}.\n</div>\n<div class=\"error-message\" *ngIf=\"false\">\n  {{ field()?.validators?.patternMessage }}.\n</div>\n"]}
|
|
247
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"age-date.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/age-date/age-date.component.ts","../../../../../projects/master-control/src/lib/age-date/age-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, input, AfterViewChecked, Output, EventEmitter } from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MomentDateModule } from '@angular/material-moment-adapter';\nimport { MAT_DATE_FORMATS } from '@angular/material/core';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MasterControlService } from '../master-control.service';\nimport { initializeFieldNameAttribute } from '../field-name-attribute.util';\n\n@Component({\n  selector: 'lib-age-date',\n  standalone: true,\n  imports: [\n    MatInputModule,\n    MatFormFieldModule,\n    CommonModule,\n    MatDatepickerModule,\n    MomentDateModule,\n    ReactiveFormsModule\n  ],\n  providers: [{ provide: MAT_DATE_FORMATS, useValue: {\n  parse: {\n    dateInput: [\n      'DD-MM-YYYY',\n      'DD/MM/YYYY',\n      'YYYY/MM/DD',\n      'MM/DD/YYYY',\n      'DD MMM YYYY',\n      'DD MMMM YYYY',\n      'DD-MMM-YYYY',\n    ],\n  },\n  display: {\n    dateInput: 'DD/MMM/YYYY',\n    monthYearLabel: 'MMM YYYY',\n    dateA11yLabel: 'DD/MMM/YYYY',\n    monthYearA11yLabel: 'MMMM YYYY',\n  },\n  }\n  },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: AgeDateComponent,\n      multi: true\n    },\n],\n  templateUrl: './age-date.component.html',\n  styleUrl: './age-date.component.css',\n})\nexport class AgeDateComponent implements AfterViewChecked {\n  field: any = input.required<any>();\n  inputValue: any = null;\n  reactiveFormControlobject : any = input<any>();\n  age : any = null;\n  @Output() blur = new EventEmitter<any>();\n  @Output() valueChange = new EventEmitter<any>();\n  @Output() dateSelected = new EventEmitter<any>();\n  @Output() invalidDate = new EventEmitter<any>();\n  constructor(public service : MasterControlService) {}\n\n  ngOnInit(): void {\n    initializeFieldNameAttribute(this.field());\n  }\n\n  ngAfterViewChecked(): void {\n    if (this.inputValue) {\n      this.calculateAge(this.inputValue);\n    }\n  }\n\n  dateDivisionFormat(event: any) {\n    let evt = event.target;\n\n    // Check if user is deleting (backspace/delete)\n    const isDeleting = event.inputType === 'deleteContentBackward' ||\n                       event.inputType === 'deleteContentForward' ||\n                       !event.data;\n\n    // If deleting, allow normal deletion without auto-adding slashes\n    if (isDeleting) {\n      return;\n    }\n\n    let value = evt.value;\n\n    // Handle case where we have existing slashes but need to reformat\n    // Split by slash to understand current structure\n    const parts = value.split('/');\n\n    // If we have exactly 3 parts (date/month/year), don't add more slashes\n    if (parts.length < 3) {\n       // For first slash after date (2 digits)\n    if (value.length > 2 && !value.includes('/')) {\n      evt.value = [value.slice(0, 2), '/', value.slice(2)].join('');\n    }\n    // For second slash after month\n    else if (parts.length === 2) {\n      const datePart = parts[0];\n      const monthPart = parts[1];\n\n\n\n      // Add slash after numeric month (exactly 2 digits) or alphabetic month (exactly 3 letters)\n      if ((monthPart.length === 2 && /^\\d{2}$/.test(monthPart)) ||\n          (monthPart.length === 3 && /^[a-zA-Z]{3}$/.test(monthPart))) {\n        evt.value = datePart + '/' + monthPart + '/';\n      }\n    }\n\n\n    }\n     const datePart = parts[0] || '';\n      const monthPart = parts[1] || '';\n      const yearPart = parts[2] || '';\n\n     // Prevent further input if limits are reached and restore previous value\n      if ((datePart.length >= 2) ||\n          (monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n          (monthPart.length >= 3 && /^[a-zA-Z]+$/.test(monthPart)) ||\n          (yearPart.length >= 4)) {\n\n        // Get cursor position to determine which part is being edited\n        const cursorPos = evt.selectionStart;\n        const isEditingDate = cursorPos <= 3;\n        const isEditingMonth = cursorPos > 3 && cursorPos <= (3 + monthPart.length);\n        const isEditingYear = cursorPos > (3 + monthPart.length + 1);\n\n        // Reconstruct the previous valid value by trimming excess characters\n        let previousValidValue='';\n        if (isEditingDate && datePart.length >= 2) {\n          // Trim date part to 2 characters max\n          const validDatePart = datePart.substring(0, 2);\n          previousValidValue = validDatePart + (parts[1] ? '/' + parts[1] : '') + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) {\n          // Trim numeric month to 2 characters max\n          const validMonthPart = monthPart.substring(0, 2);\n          previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingMonth && monthPart.length >= 3 ) {\n          // Trim alphabetic month to 3 characters max\n          const validMonthPart = monthPart.substring(0, 3);\n          previousValidValue = parts[0] + '/' + validMonthPart + (parts[2] ? '/' + parts[2] : '');\n        } else if (isEditingYear && yearPart.length >= 4) {\n          // Trim year part to 4 characters max\n          const validYearPart = yearPart.substring(0, 4);\n          previousValidValue = parts[0] + '/' + parts[1] + '/' + validYearPart;\n        }\n\n        // Prevent input if trying to exceed limits by restoring previous value\n        if ((isEditingDate && datePart.length >= 2) ||\n            (isEditingMonth && monthPart.length >= 2 && /^\\d+$/.test(monthPart)) ||\n            (isEditingMonth && monthPart.length >= 3 ) ||\n            (isEditingYear && yearPart.length >= 4)) {\n\n          // Restore the previous valid value\n          setTimeout(() => {\n            evt.value = previousValidValue;\n          }, 0);\n          event.preventDefault();\n          return;\n        }\n      }\n\n\n  }\n   _onChange: any = (inputValue:any) => {};\n  _unTouched: any = () => {};\n\n  writeValue(obj: any): void{\n    this.inputValue=obj;\n  };\n  registerOnChange(fn: any): void{\n    this._onChange = fn;\n  };\n  registerOnTouched(fn: any): void{\n    this._unTouched = fn;\n  };\n  setDisabledState?(isDisabled: boolean): void{};\n\n  onInputChange(event: any): void {\n    if (event.value) {\n      this.inputValue = event.value;\n      this._onChange(this.inputValue);\n      this.calculateAge(event.value);\n    } else {\n      this.inputValue = event.target.value;\n      this._onChange(this.inputValue);\n    }\n    this.dateSelected.emit({\n        formattedValue: this.inputValue,\n        dateObject: this.inputValue,\n        isValid: true,\n        source: 'datepicker'\n      });\n    this.valueChange.emit(this.inputValue);\n  }\n\n  onInputBlur(event : any): void {\n    if (!this.service.checkIfValueIsEmpty(event.target.value)) {\n      if (isNaN(Date.parse(event.target.value))) {\n        event.target.value = '';\n      } else {\n        this.calculateAge(event.target.value);\n      }\n    }\n    this._unTouched();\n    this.blur.emit(event);\n  }\n\n  calculateAge(birthDate: Date) {\n    const today = new Date();\n    const birthdate = new Date(birthDate);\n    let age = today.getFullYear() - birthdate.getFullYear();\n    const monthDiff = today.getMonth() - birthdate.getMonth();\n    const days_difference = today.getDate() - birthdate.getDate();\n    if (monthDiff < 0 || (monthDiff === 0 && days_difference < 0)) {\n      age = age - 1;\n    }\n    this.age = age;\n  }\n\n\n}\n","<label *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n<mat-form-field\n  class=\"w-100\"\n  appearance=\"outline\"\n  *ngIf=\"field() && field()?.isVisible\"\n  [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n <input\n    matInput\n    autocomplete=\"off\"\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldNameAttribute\"\n    [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder\"\n    [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\"\n    [matDatepicker]=\"picker\"\n    (input)=\"dateDivisionFormat($event)\"\n    [disabled]=\"field()?.isDisable\"\n    [min]=\"field()?.configData?.min\"\n    [max]=\"field()?.configData?.max\"\n    (dateChange)=\"onInputChange($event)\"\n    (blur)=\"onInputBlur($event)\"\n    [value]=\"inputValue\"\n    [formControl]=\"reactiveFormControlobject()\"\n  />\n }@else{\n    <input\n    matInput\n    autocomplete=\"off\"\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldNameAttribute\"\n    [id]=\"field()?.fieldName\"\n    [placeholder]=\"field()?.placeHolder\"\n    [required]=\"field()?.validators?.isRequired\"\n    [pattern]=\"field()?.validators?.pattern\"\n    [matDatepicker]=\"picker\"\n    [min]=\"field()?.configData?.min\"\n    [max]=\"field()?.configData?.max\"\n    (input)=\"dateDivisionFormat($event)\"\n    [disabled]=\"field()?.isDisable\"\n    (dateChange)=\"onInputChange($event)\"\n    (blur)=\"onInputBlur($event)\"\n    [value]=\"inputValue\"\n  />\n }\n  <span matSuffix class=\"right-date-text\" *ngIf=\"!this.service.checkIfValueIsEmpty(age) && !this.service.checkIfValueIsEmpty(inputValue) && age >= 0\">\n    ({{ age }}) yrs\n  </span>\n  <mat-datepicker-toggle matSuffix [for]=\"picker\" *ngIf=\"!field()?.isDisable\">\n    <img\n      src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\n      style=\"width: 16px\"\n      matDatepickerToggleIcon\n    />\n  </mat-datepicker-toggle>\n  <mat-datepicker #picker></mat-datepicker>\n   <mat-error *ngIf=\"false\">\n    {{ field()?.validators?.isRequiredMessage }}\n  </mat-error>\n</mat-form-field>\n<div class=\"error-message\" *ngIf=\"false\">\n  {{ field()?.validators?.isRequiredMessage }}.\n</div>\n<div class=\"error-message\" *ngIf=\"false\">\n  {{ field()?.validators?.patternMessage }}.\n</div>\n"]}
|
|
@@ -3,6 +3,7 @@ import { Component, input, Output, EventEmitter } from '@angular/core';
|
|
|
3
3
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
4
4
|
import { MatInputModule } from '@angular/material/input';
|
|
5
5
|
import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
6
|
+
import { initializeFieldNameAttribute } from '../field-name-attribute.util';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../master-control.service";
|
|
8
9
|
import * as i2 from "@angular/material/form-field";
|
|
@@ -25,6 +26,9 @@ export class AmountTextboxComponent {
|
|
|
25
26
|
}
|
|
26
27
|
// Declare Output event emitter here (class level)
|
|
27
28
|
blur = new EventEmitter();
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
initializeFieldNameAttribute(this.field());
|
|
31
|
+
}
|
|
28
32
|
// ControlValueAccessor implementation
|
|
29
33
|
writeValue(obj) {
|
|
30
34
|
if (obj !== null && obj !== undefined) {
|
|
@@ -204,7 +208,7 @@ export class AmountTextboxComponent {
|
|
|
204
208
|
useExisting: AmountTextboxComponent,
|
|
205
209
|
multi: true
|
|
206
210
|
}
|
|
207
|
-
], ngImport: i0, template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\n >{{ field().label\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\n >*</span\n ></label\n>\n <mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n<input\n matInput\n [type]=\"field()?.controlType\"\n [name]=\"field()?.
|
|
211
|
+
], ngImport: i0, template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\n >{{ field().label\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\n >*</span\n ></label\n>\n <mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n<input\n matInput\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n autocomplete=\"off\"\n [placeholder]=\"field()?.placeHolder\"\n [maxLength]=\"field()?.validators?.maxLength\"\n [minLength]=\"field()?.validators?.minLength\"\n [disabled]=\"field()?.isDisable\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n (input)=\"onInputChange($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"getDisplayValue()\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else {\n <input\n matInput\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n autocomplete=\"off\"\n [placeholder]=\"field()?.placeHolder\"\n [maxLength]=\"field()?.validators?.maxLength\"\n [minLength]=\"field()?.validators?.minLength\"\n [disabled]=\"field()?.isDisable\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n (input)=\"onInputChange($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"getDisplayValue()\"\n />\n }\n\n <mat-error *ngIf=\"false\">\n {{ field()?.validators?.requiredMessage }}\n </mat-error>\n <span matPrefix class=\"rupee-symbol px-2\">\u20B9</span>\n <span matSuffix class=\"me-2 right-amount-text\" *ngIf=\"inputValue\">{{ getFormattedAmount() }}</span>\n </mat-form-field>\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0!important}*{font-family:mulish!important}.right-amount-text{font-weight:600;font-size:10px;color:#444;background:#f5f5f5;border-radius:2px;padding:5.5px 6px 4px}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-size:.75rem!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}.rupee-symbol{color:#444;font-size:12px;font-weight:400}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i2.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.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: "ngmodule", type: ReactiveFormsModule }, { 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.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
208
212
|
}
|
|
209
213
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AmountTextboxComponent, decorators: [{
|
|
210
214
|
type: Component,
|
|
@@ -219,8 +223,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
219
223
|
useExisting: AmountTextboxComponent,
|
|
220
224
|
multi: true
|
|
221
225
|
}
|
|
222
|
-
], template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\n >{{ field().label\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\n >*</span\n ></label\n>\n <mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n<input\n matInput\n [type]=\"field()?.controlType\"\n [name]=\"field()?.
|
|
226
|
+
], template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\n >{{ field().label\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\n >*</span\n ></label\n>\n <mat-form-field\n class=\"w-100\"\n appearance=\"outline\"\n *ngIf=\"field() && field()?.isVisible\"\n [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n<input\n matInput\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n autocomplete=\"off\"\n [placeholder]=\"field()?.placeHolder\"\n [maxLength]=\"field()?.validators?.maxLength\"\n [minLength]=\"field()?.validators?.minLength\"\n [disabled]=\"field()?.isDisable\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n (input)=\"onInputChange($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"getDisplayValue()\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else {\n <input\n matInput\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldNameAttribute\"\n [id]=\"field()?.fieldName\"\n autocomplete=\"off\"\n [placeholder]=\"field()?.placeHolder\"\n [maxLength]=\"field()?.validators?.maxLength\"\n [minLength]=\"field()?.validators?.minLength\"\n [disabled]=\"field()?.isDisable\"\n [required]=\"field()?.validators?.isRequired\"\n [pattern]=\"field()?.validators?.pattern\"\n (input)=\"onInputChange($event)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onInputBlur($event)\"\n [value]=\"getDisplayValue()\"\n />\n }\n\n <mat-error *ngIf=\"false\">\n {{ field()?.validators?.requiredMessage }}\n </mat-error>\n <span matPrefix class=\"rupee-symbol px-2\">\u20B9</span>\n <span matSuffix class=\"me-2 right-amount-text\" *ngIf=\"inputValue\">{{ getFormattedAmount() }}</span>\n </mat-form-field>\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0!important}*{font-family:mulish!important}.right-amount-text{font-weight:600;font-size:10px;color:#444;background:#f5f5f5;border-radius:2px;padding:5.5px 6px 4px}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-size:.75rem!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}.rupee-symbol{color:#444;font-size:12px;font-weight:400}\n"] }]
|
|
223
227
|
}], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { blur: [{
|
|
224
228
|
type: Output
|
|
225
229
|
}] } });
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amount-textbox.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/amount-textbox/amount-textbox.component.ts","../../../../../projects/master-control/src/lib/amount-textbox/amount-textbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, input, Output, EventEmitter } from '@angular/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MasterControlService } from '../master-control.service';\n\n@Component({\n  selector: 'lib-amount-textbox',\n  standalone: true,\n  imports: [\n    MatFormFieldModule,\n    CommonModule,\n    MatInputModule,\n    ReactiveFormsModule\n  ],\n  templateUrl: './amount-textbox.component.html',\n  styleUrl: './amount-textbox.component.css',\n  providers: [\n      {\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: AmountTextboxComponent,\n        multi: true\n      }\n    ]\n})\nexport class AmountTextboxComponent implements ControlValueAccessor {\n  constructor(public sharedService : MasterControlService){}\n  field : any = input.required<any>();\n  inputValue: any = null;\n  reactiveFormControlobject : any = input<any>();\n  _onChange: any = (inputValue:any) => {};\n  _unTouched: any = () => {};\n  get isCommaAdded(): any {\n    return this.field()?.configData?.isCommaAllowed !== undefined ?\n      this.field()?.configData?.isCommaAllowed : true;\n  }\n\n   // Declare Output event emitter here (class level)\n  @Output() blur = new EventEmitter<any>();\n\n  // ControlValueAccessor implementation\n  writeValue(obj: any): void {\n    if (obj !== null && obj !== undefined) {\n      const rawValue = obj.toString();\n      this.inputValue = rawValue;\n    } else {\n      this.inputValue = null;\n    }\n  }\n  registerOnChange(fn: any): void{\n    this._onChange = fn;\n  };\n  registerOnTouched(fn: any): void{\n    this._unTouched = fn;\n  };\n  setDisabledState?(isDisabled: boolean): void{};\n\n  onInputChange(event: any): void {\n    const inputElement = event.target;\n    const cursorPosition = inputElement.selectionStart;\n    const oldValue = inputElement.value;\n    const rawValue = oldValue.replace(/,/g, '');\n    if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\n      this.inputValue = rawValue;\n      if (this.isCommaAdded && rawValue && !isNaN(parseFloat(rawValue))) {\n        const formattedValue = this.sharedService.addComasToNumberValues(rawValue);\n        const newCursorPosition = this.calculateNewCursorPosition(\n          oldValue,\n          formattedValue,\n          cursorPosition\n        );\n        inputElement.value = formattedValue;\n        setTimeout(() => {\n          inputElement.setSelectionRange(newCursorPosition, newCursorPosition);\n        }, 0);\n      }\n      this._onChange(this.inputValue);\n    } else {\n      const revertValue = this.isCommaAdded && this.inputValue ?\n        this.sharedService.addComasToNumberValues(this.inputValue) : this.inputValue || '';\n      inputElement.value = revertValue;\n      setTimeout(() => {\n        const safeCursorPos = Math.min(cursorPosition, revertValue.length);\n        inputElement.setSelectionRange(safeCursorPos, safeCursorPos);\n      }, 0);\n    }\n  }\n\n  onInputBlur(event?: any): void {\n    this._unTouched();\n     this.blur.emit(event);\n  }\n  onKeyDown(event: KeyboardEvent): void {\n    const inputElement = event.target as HTMLInputElement;\n    const cursorPosition = inputElement.selectionStart || 0;\n    const value = inputElement.value;\n    if (event.key === 'Backspace' && cursorPosition > 0) {\n      if (value[cursorPosition - 1] === ',') {\n        event.preventDefault();\n        const newValue = value.substring(0, cursorPosition - 2) + value.substring(cursorPosition);\n        const rawValue = newValue.replace(/,/g, '');\n        if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\n          this.inputValue = rawValue;\n          const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;\n          inputElement.value = formattedValue;\n          setTimeout(() => {\n            const newCursorPos = Math.max(0, cursorPosition - 2);\n            inputElement.setSelectionRange(newCursorPos, newCursorPos);\n          }, 0);\n\n          this._onChange(this.inputValue);\n        }\n      }\n    }\n    if (event.key === 'Delete' && cursorPosition < value.length) {\n      if (value[cursorPosition] === ',') {\n        event.preventDefault();\n        if (cursorPosition + 1 < value.length) {\n          const newValue = value.substring(0, cursorPosition) + value.substring(cursorPosition + 2);\n          const rawValue = newValue.replace(/,/g, '');\n          if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\n            this.inputValue = rawValue;\n            const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;\n            inputElement.value = formattedValue;\n            setTimeout(() => {\n              inputElement.setSelectionRange(cursorPosition, cursorPosition);\n            }, 0);\n            this._onChange(this.inputValue);\n          }\n        }\n      }\n    }\n  }\n\n  // Add commas to number for Indian format\n  // addCommasToNumber(value: any | number): any {\n  //   if (!value || value === '') return '';\n  //   const stringValue = value.toString();\n  //   const parts = stringValue.split('.');\n  //   let integerPart = parts[0];\n  //   if (integerPart.length > 3) {\n  //     const lastThreeDigits = integerPart.slice(-3);\n  //     const remainingDigits = integerPart.slice(0, -3);\n  //     const formattedRemaining = remainingDigits.replace(/\\B(?=(\\d{2})+(?!\\d))/g, ',');\n  //     integerPart = formattedRemaining + ',' + lastThreeDigits;\n  //   }\n\n  //   return parts[1] ? integerPart + '.' + parts[1] : integerPart;\n  // }\n  calculateNewCursorPosition(oldValue: string, newValue: string, oldCursorPosition: number): number {\n    if (oldCursorPosition === 0) {\n      return 0;\n    }\n    if (oldCursorPosition >= oldValue.length) {\n      return newValue.length;\n    }\n    let digitsBeforeCursor = 0;\n    for (let i = 0; i < oldCursorPosition; i++) {\n      const char = oldValue[i];\n      if (char !== ',') {\n        digitsBeforeCursor++;\n      }\n    }\n    let digitCount = 0;\n    let newPosition = 0;\n    for (let i = 0; i < newValue.length; i++) {\n      const char = newValue[i];\n      if (char !== ',') {\n        digitCount++;\n        if (digitCount === digitsBeforeCursor) {\n          newPosition = i + 1;\n          break;\n        }\n      }\n      if (digitCount < digitsBeforeCursor) {\n        newPosition = i + 1;\n      }\n    }\n    return Math.min(newPosition, newValue.length);\n  }\n\n  // Get the display value with commas if enabled\n  getDisplayValue(): any {\n    if (!this.inputValue) return '';\n    if (this.isCommaAdded && !isNaN(parseFloat(this.inputValue))) {\n      return this.sharedService.addComasToNumberValues(this.inputValue);\n    }\n    return this.inputValue;\n  }\n\n  // Format amount to Indian currency format\n  formatIndianCurrency(amount: number | string): string {\n    if (!amount || amount === '') return '';\n\n    const numAmount = typeof amount === 'string' ? parseFloat(amount.replace(/,/g, '')) : amount;\n    if (isNaN(numAmount) || numAmount === 0) return '₹';\n    if (numAmount >= 10000000) {\n      const crores = (numAmount / 10000000).toFixed(2);\n      return `₹ ${crores} Cr`;\n    } else if (numAmount >= 100000) {\n      const lakhs = (numAmount / 100000).toFixed(2);\n      return `₹ ${lakhs} L`;\n    } else if (numAmount >= 1000) {\n      const thousands = (numAmount / 1000).toFixed(2);\n      return `₹ ${thousands} K`;\n    } else {\n      return `₹ ${numAmount.toFixed(2)}`;\n    }\n  }\n\n  // Get formatted display value\n  getFormattedAmount(): string {\n    return this.formatIndianCurrency(this.sharedService.removeComasAndCurrencySymbolFromNumberValues(this.inputValue));\n  }\n}\n","<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\n  >{{ field().label\n  }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\n    >*</span\n  ></label\n>\n  <mat-form-field\n  class=\"w-100\"\n  appearance=\"outline\"\n  *ngIf=\"field() && field()?.isVisible\"\n  [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n<input\n      matInput\n      [type]=\"field()?.controlType\"\n      [name]=\"field()?.fieldName\"\n      [id]=\"field()?.fieldName\"\n      autocomplete=\"off\"\n      [placeholder]=\"field()?.placeHolder\"\n      [maxLength]=\"field()?.validators?.maxLength\"\n      [minLength]=\"field()?.validators?.minLength\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [pattern]=\"field()?.validators?.pattern\"\n      (input)=\"onInputChange($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onInputBlur($event)\"\n      [value]=\"getDisplayValue()\"\n      [formControl]=\"reactiveFormControlobject()\"\n    />\n }@else {\n  <input\n      matInput\n      [type]=\"field()?.controlType\"\n      [name]=\"field()?.fieldName\"\n      [id]=\"field()?.fieldName\"\n      autocomplete=\"off\"\n      [placeholder]=\"field()?.placeHolder\"\n      [maxLength]=\"field()?.validators?.maxLength\"\n      [minLength]=\"field()?.validators?.minLength\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [pattern]=\"field()?.validators?.pattern\"\n      (input)=\"onInputChange($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onInputBlur($event)\"\n      [value]=\"getDisplayValue()\"\n    />\n }\n\n    <mat-error *ngIf=\"false\">\n      {{ field()?.validators?.requiredMessage }}\n    </mat-error>\n    <span matPrefix class=\"rupee-symbol px-2\">₹</span>\n    <span matSuffix class=\"me-2 right-amount-text\" *ngIf=\"inputValue\">{{ getFormattedAmount() }}</span>\n  </mat-form-field>\n"]}
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amount-textbox.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/amount-textbox/amount-textbox.component.ts","../../../../../projects/master-control/src/lib/amount-textbox/amount-textbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, input, Output, EventEmitter } from '@angular/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MasterControlService } from '../master-control.service';\nimport { initializeFieldNameAttribute } from '../field-name-attribute.util';\n\n@Component({\n  selector: 'lib-amount-textbox',\n  standalone: true,\n  imports: [\n    MatFormFieldModule,\n    CommonModule,\n    MatInputModule,\n    ReactiveFormsModule\n  ],\n  templateUrl: './amount-textbox.component.html',\n  styleUrl: './amount-textbox.component.css',\n  providers: [\n      {\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: AmountTextboxComponent,\n        multi: true\n      }\n    ]\n})\nexport class AmountTextboxComponent implements ControlValueAccessor {\n  constructor(public sharedService : MasterControlService){}\n  field : any = input.required<any>();\n  inputValue: any = null;\n  reactiveFormControlobject : any = input<any>();\n  _onChange: any = (inputValue:any) => {};\n  _unTouched: any = () => {};\n  get isCommaAdded(): any {\n    return this.field()?.configData?.isCommaAllowed !== undefined ?\n      this.field()?.configData?.isCommaAllowed : true;\n  }\n\n   // Declare Output event emitter here (class level)\n  @Output() blur = new EventEmitter<any>();\n\n  ngOnInit(): void {\n    initializeFieldNameAttribute(this.field());\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(obj: any): void {\n    if (obj !== null && obj !== undefined) {\n      const rawValue = obj.toString();\n      this.inputValue = rawValue;\n    } else {\n      this.inputValue = null;\n    }\n  }\n  registerOnChange(fn: any): void{\n    this._onChange = fn;\n  };\n  registerOnTouched(fn: any): void{\n    this._unTouched = fn;\n  };\n  setDisabledState?(isDisabled: boolean): void{};\n\n  onInputChange(event: any): void {\n    const inputElement = event.target;\n    const cursorPosition = inputElement.selectionStart;\n    const oldValue = inputElement.value;\n    const rawValue = oldValue.replace(/,/g, '');\n    if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\n      this.inputValue = rawValue;\n      if (this.isCommaAdded && rawValue && !isNaN(parseFloat(rawValue))) {\n        const formattedValue = this.sharedService.addComasToNumberValues(rawValue);\n        const newCursorPosition = this.calculateNewCursorPosition(\n          oldValue,\n          formattedValue,\n          cursorPosition\n        );\n        inputElement.value = formattedValue;\n        setTimeout(() => {\n          inputElement.setSelectionRange(newCursorPosition, newCursorPosition);\n        }, 0);\n      }\n      this._onChange(this.inputValue);\n    } else {\n      const revertValue = this.isCommaAdded && this.inputValue ?\n        this.sharedService.addComasToNumberValues(this.inputValue) : this.inputValue || '';\n      inputElement.value = revertValue;\n      setTimeout(() => {\n        const safeCursorPos = Math.min(cursorPosition, revertValue.length);\n        inputElement.setSelectionRange(safeCursorPos, safeCursorPos);\n      }, 0);\n    }\n  }\n\n  onInputBlur(event?: any): void {\n    this._unTouched();\n     this.blur.emit(event);\n  }\n  onKeyDown(event: KeyboardEvent): void {\n    const inputElement = event.target as HTMLInputElement;\n    const cursorPosition = inputElement.selectionStart || 0;\n    const value = inputElement.value;\n    if (event.key === 'Backspace' && cursorPosition > 0) {\n      if (value[cursorPosition - 1] === ',') {\n        event.preventDefault();\n        const newValue = value.substring(0, cursorPosition - 2) + value.substring(cursorPosition);\n        const rawValue = newValue.replace(/,/g, '');\n        if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\n          this.inputValue = rawValue;\n          const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;\n          inputElement.value = formattedValue;\n          setTimeout(() => {\n            const newCursorPos = Math.max(0, cursorPosition - 2);\n            inputElement.setSelectionRange(newCursorPos, newCursorPos);\n          }, 0);\n\n          this._onChange(this.inputValue);\n        }\n      }\n    }\n    if (event.key === 'Delete' && cursorPosition < value.length) {\n      if (value[cursorPosition] === ',') {\n        event.preventDefault();\n        if (cursorPosition + 1 < value.length) {\n          const newValue = value.substring(0, cursorPosition) + value.substring(cursorPosition + 2);\n          const rawValue = newValue.replace(/,/g, '');\n          if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\n            this.inputValue = rawValue;\n            const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;\n            inputElement.value = formattedValue;\n            setTimeout(() => {\n              inputElement.setSelectionRange(cursorPosition, cursorPosition);\n            }, 0);\n            this._onChange(this.inputValue);\n          }\n        }\n      }\n    }\n  }\n\n  // Add commas to number for Indian format\n  // addCommasToNumber(value: any | number): any {\n  //   if (!value || value === '') return '';\n  //   const stringValue = value.toString();\n  //   const parts = stringValue.split('.');\n  //   let integerPart = parts[0];\n  //   if (integerPart.length > 3) {\n  //     const lastThreeDigits = integerPart.slice(-3);\n  //     const remainingDigits = integerPart.slice(0, -3);\n  //     const formattedRemaining = remainingDigits.replace(/\\B(?=(\\d{2})+(?!\\d))/g, ',');\n  //     integerPart = formattedRemaining + ',' + lastThreeDigits;\n  //   }\n\n  //   return parts[1] ? integerPart + '.' + parts[1] : integerPart;\n  // }\n  calculateNewCursorPosition(oldValue: string, newValue: string, oldCursorPosition: number): number {\n    if (oldCursorPosition === 0) {\n      return 0;\n    }\n    if (oldCursorPosition >= oldValue.length) {\n      return newValue.length;\n    }\n    let digitsBeforeCursor = 0;\n    for (let i = 0; i < oldCursorPosition; i++) {\n      const char = oldValue[i];\n      if (char !== ',') {\n        digitsBeforeCursor++;\n      }\n    }\n    let digitCount = 0;\n    let newPosition = 0;\n    for (let i = 0; i < newValue.length; i++) {\n      const char = newValue[i];\n      if (char !== ',') {\n        digitCount++;\n        if (digitCount === digitsBeforeCursor) {\n          newPosition = i + 1;\n          break;\n        }\n      }\n      if (digitCount < digitsBeforeCursor) {\n        newPosition = i + 1;\n      }\n    }\n    return Math.min(newPosition, newValue.length);\n  }\n\n  // Get the display value with commas if enabled\n  getDisplayValue(): any {\n    if (!this.inputValue) return '';\n    if (this.isCommaAdded && !isNaN(parseFloat(this.inputValue))) {\n      return this.sharedService.addComasToNumberValues(this.inputValue);\n    }\n    return this.inputValue;\n  }\n\n  // Format amount to Indian currency format\n  formatIndianCurrency(amount: number | string): string {\n    if (!amount || amount === '') return '';\n\n    const numAmount = typeof amount === 'string' ? parseFloat(amount.replace(/,/g, '')) : amount;\n    if (isNaN(numAmount) || numAmount === 0) return '₹';\n    if (numAmount >= 10000000) {\n      const crores = (numAmount / 10000000).toFixed(2);\n      return `₹ ${crores} Cr`;\n    } else if (numAmount >= 100000) {\n      const lakhs = (numAmount / 100000).toFixed(2);\n      return `₹ ${lakhs} L`;\n    } else if (numAmount >= 1000) {\n      const thousands = (numAmount / 1000).toFixed(2);\n      return `₹ ${thousands} K`;\n    } else {\n      return `₹ ${numAmount.toFixed(2)}`;\n    }\n  }\n\n  // Get formatted display value\n  getFormattedAmount(): string {\n    return this.formatIndianCurrency(this.sharedService.removeComasAndCurrencySymbolFromNumberValues(this.inputValue));\n  }\n}\n","<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\n  >{{ field().label\n  }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\n    >*</span\n  ></label\n>\n  <mat-form-field\n  class=\"w-100\"\n  appearance=\"outline\"\n  *ngIf=\"field() && field()?.isVisible\"\n  [ngStyle]=\"{\n'--custom-border-color': field()?.controlStyle?.borderColor ,\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\n'--custom-bg-color': field()?.controlStyle?.background ,\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-size': field()?.controlStyle?.fontSize ,\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\n'--custom-font-color': field()?.controlStyle?.color ,\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n}\">\n @if(reactiveFormControlobject()) {\n<input\n      matInput\n      [type]=\"field()?.controlType\"\n      [name]=\"field()?.fieldNameAttribute\"\n      [id]=\"field()?.fieldName\"\n      autocomplete=\"off\"\n      [placeholder]=\"field()?.placeHolder\"\n      [maxLength]=\"field()?.validators?.maxLength\"\n      [minLength]=\"field()?.validators?.minLength\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [pattern]=\"field()?.validators?.pattern\"\n      (input)=\"onInputChange($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onInputBlur($event)\"\n      [value]=\"getDisplayValue()\"\n      [formControl]=\"reactiveFormControlobject()\"\n    />\n }@else {\n  <input\n      matInput\n      [type]=\"field()?.controlType\"\n      [name]=\"field()?.fieldNameAttribute\"\n      [id]=\"field()?.fieldName\"\n      autocomplete=\"off\"\n      [placeholder]=\"field()?.placeHolder\"\n      [maxLength]=\"field()?.validators?.maxLength\"\n      [minLength]=\"field()?.validators?.minLength\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [pattern]=\"field()?.validators?.pattern\"\n      (input)=\"onInputChange($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onInputBlur($event)\"\n      [value]=\"getDisplayValue()\"\n    />\n }\n\n    <mat-error *ngIf=\"false\">\n      {{ field()?.validators?.requiredMessage }}\n    </mat-error>\n    <span matPrefix class=\"rupee-symbol px-2\">₹</span>\n    <span matSuffix class=\"me-2 right-amount-text\" *ngIf=\"inputValue\">{{ getFormattedAmount() }}</span>\n  </mat-form-field>\n"]}
|