master-control 0.3.91 → 0.3.92

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.
@@ -53,7 +53,7 @@ export class AmountTextboxComponent {
53
53
  if (rawValue === '' || /^\d*\.?\d*$/.test(rawValue)) {
54
54
  this.inputValue = rawValue;
55
55
  if (this.isCommaAdded && rawValue && !isNaN(parseFloat(rawValue))) {
56
- const formattedValue = this.addCommasToNumber(rawValue);
56
+ const formattedValue = this.sharedService.addComasToNumberValues(rawValue);
57
57
  const newCursorPosition = this.calculateNewCursorPosition(oldValue, formattedValue, cursorPosition);
58
58
  inputElement.value = formattedValue;
59
59
  setTimeout(() => {
@@ -64,7 +64,7 @@ export class AmountTextboxComponent {
64
64
  }
65
65
  else {
66
66
  const revertValue = this.isCommaAdded && this.inputValue ?
67
- this.addCommasToNumber(this.inputValue) : this.inputValue || '';
67
+ this.sharedService.addComasToNumberValues(this.inputValue) : this.inputValue || '';
68
68
  inputElement.value = revertValue;
69
69
  setTimeout(() => {
70
70
  const safeCursorPos = Math.min(cursorPosition, revertValue.length);
@@ -87,7 +87,7 @@ export class AmountTextboxComponent {
87
87
  const rawValue = newValue.replace(/,/g, '');
88
88
  if (rawValue === '' || /^\d*\.?\d*$/.test(rawValue)) {
89
89
  this.inputValue = rawValue;
90
- const formattedValue = this.isCommaAdded && rawValue ? this.addCommasToNumber(rawValue) : rawValue;
90
+ const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;
91
91
  inputElement.value = formattedValue;
92
92
  setTimeout(() => {
93
93
  const newCursorPos = Math.max(0, cursorPosition - 2);
@@ -105,7 +105,7 @@ export class AmountTextboxComponent {
105
105
  const rawValue = newValue.replace(/,/g, '');
106
106
  if (rawValue === '' || /^\d*\.?\d*$/.test(rawValue)) {
107
107
  this.inputValue = rawValue;
108
- const formattedValue = this.isCommaAdded && rawValue ? this.addCommasToNumber(rawValue) : rawValue;
108
+ const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;
109
109
  inputElement.value = formattedValue;
110
110
  setTimeout(() => {
111
111
  inputElement.setSelectionRange(cursorPosition, cursorPosition);
@@ -116,15 +116,20 @@ export class AmountTextboxComponent {
116
116
  }
117
117
  }
118
118
  }
119
- // Add commas to number for display
120
- addCommasToNumber(value) {
121
- if (!value || value === '')
122
- return '';
123
- const stringValue = value.toString();
124
- const parts = stringValue.split('.');
125
- parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ',');
126
- return parts.join('.');
127
- }
119
+ // Add commas to number for Indian format
120
+ // addCommasToNumber(value: any | number): any {
121
+ // if (!value || value === '') return '';
122
+ // const stringValue = value.toString();
123
+ // const parts = stringValue.split('.');
124
+ // let integerPart = parts[0];
125
+ // if (integerPart.length > 3) {
126
+ // const lastThreeDigits = integerPart.slice(-3);
127
+ // const remainingDigits = integerPart.slice(0, -3);
128
+ // const formattedRemaining = remainingDigits.replace(/\B(?=(\d{2})+(?!\d))/g, ',');
129
+ // integerPart = formattedRemaining + ',' + lastThreeDigits;
130
+ // }
131
+ // return parts[1] ? integerPart + '.' + parts[1] : integerPart;
132
+ // }
128
133
  calculateNewCursorPosition(oldValue, newValue, oldCursorPosition) {
129
134
  if (oldCursorPosition === 0) {
130
135
  return 0;
@@ -161,7 +166,7 @@ export class AmountTextboxComponent {
161
166
  if (!this.inputValue)
162
167
  return '';
163
168
  if (this.isCommaAdded && !isNaN(parseFloat(this.inputValue))) {
164
- return this.addCommasToNumber(this.inputValue);
169
+ return this.sharedService.addComasToNumberValues(this.inputValue);
165
170
  }
166
171
  return this.inputValue;
167
172
  }
@@ -199,7 +204,7 @@ export class AmountTextboxComponent {
199
204
  useExisting: AmountTextboxComponent,
200
205
  multi: true
201
206
  }
202
- ], ngImport: i0, template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\r\n >{{ field().label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n <mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field()?.isVisible\"\r\n [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\">\r\n @if(reactiveFormControlobject()) {\r\n<input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n />\r\n }\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage }}\r\n </mat-error>\r\n <span matPrefix class=\"rupee-symbol px-2\">\u20B9</span>\r\n <span matSuffix class=\"me-2 right-amount-text\">{{ getFormattedAmount() }}</span>\r\n </mat-form-field>\r\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"] }] });
207
+ ], ngImport: i0, template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\r\n >{{ field().label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n <mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field()?.isVisible\"\r\n [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\">\r\n @if(reactiveFormControlobject()) {\r\n<input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n />\r\n }\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage }}\r\n </mat-error>\r\n <span matPrefix class=\"rupee-symbol px-2\">\u20B9</span>\r\n <span matSuffix class=\"me-2 right-amount-text\" *ngIf=\"inputValue\">{{ getFormattedAmount() }}</span>\r\n </mat-form-field>\r\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"] }] });
203
208
  }
204
209
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AmountTextboxComponent, decorators: [{
205
210
  type: Component,
@@ -214,8 +219,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
214
219
  useExisting: AmountTextboxComponent,
215
220
  multi: true
216
221
  }
217
- ], template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\r\n >{{ field().label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n <mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field()?.isVisible\"\r\n [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\">\r\n @if(reactiveFormControlobject()) {\r\n<input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n />\r\n }\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage }}\r\n </mat-error>\r\n <span matPrefix class=\"rupee-symbol px-2\">\u20B9</span>\r\n <span matSuffix class=\"me-2 right-amount-text\">{{ getFormattedAmount() }}</span>\r\n </mat-form-field>\r\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"] }]
222
+ ], template: "<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\r\n >{{ field().label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n <mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field()?.isVisible\"\r\n [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\">\r\n @if(reactiveFormControlobject()) {\r\n<input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n [type]=\"field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n autocomplete=\"none\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [maxLength]=\"field()?.validators?.maxLength\"\r\n [minLength]=\"field()?.validators?.minLength\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n (input)=\"onInputChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"getDisplayValue()\"\r\n />\r\n }\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage }}\r\n </mat-error>\r\n <span matPrefix class=\"rupee-symbol px-2\">\u20B9</span>\r\n <span matSuffix class=\"me-2 right-amount-text\" *ngIf=\"inputValue\">{{ getFormattedAmount() }}</span>\r\n </mat-form-field>\r\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"] }]
218
223
  }], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { blur: [{
219
224
  type: Output
220
225
  }] } });
221
- //# 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';\r\nimport { Component, input, Output, EventEmitter } from '@angular/core';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MasterControlService } from '../master-control.service';\r\n\r\n@Component({\r\n  selector: 'lib-amount-textbox',\r\n  standalone: true,\r\n  imports: [\r\n    MatFormFieldModule,\r\n    CommonModule,\r\n    MatInputModule,\r\n    ReactiveFormsModule\r\n  ],\r\n  templateUrl: './amount-textbox.component.html',\r\n  styleUrl: './amount-textbox.component.css',\r\n  providers: [\r\n      {\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: AmountTextboxComponent,\r\n        multi: true\r\n      }\r\n    ]\r\n})\r\nexport class AmountTextboxComponent implements ControlValueAccessor {\r\n  constructor(public sharedService : MasterControlService){}\r\n  field : any = input.required<any>();\r\n  inputValue: any = null;\r\n  reactiveFormControlobject : any = input<any>();\r\n  _onChange: any = (inputValue:any) => {};\r\n  _unTouched: any = () => {};\r\n  get isCommaAdded(): any {\r\n    return this.field()?.configData?.isCommaAllowed !== undefined ? \r\n      this.field()?.configData?.isCommaAllowed : true;\r\n  }\r\n\r\n   // Declare Output event emitter here (class level)\r\n  @Output() blur = new EventEmitter<any>();\r\n\r\n  // ControlValueAccessor implementation\r\n  writeValue(obj: any): void {\r\n    if (obj !== null && obj !== undefined) {\r\n      const rawValue = obj.toString();\r\n      this.inputValue = rawValue;\r\n    } else {\r\n      this.inputValue = null;\r\n    }\r\n  }\r\n  registerOnChange(fn: any): void{\r\n    this._onChange = fn;\r\n  };\r\n  registerOnTouched(fn: any): void{\r\n    this._unTouched = fn;\r\n  };\r\n  setDisabledState?(isDisabled: boolean): void{};\r\n\r\n  onInputChange(event: any): void {\r\n    const inputElement = event.target;\r\n    const cursorPosition = inputElement.selectionStart;\r\n    const oldValue = inputElement.value;\r\n    const rawValue = oldValue.replace(/,/g, '');\r\n    if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\r\n      this.inputValue = rawValue;\r\n      if (this.isCommaAdded && rawValue && !isNaN(parseFloat(rawValue))) {\r\n        const formattedValue = this.addCommasToNumber(rawValue);\r\n        const newCursorPosition = this.calculateNewCursorPosition(\r\n          oldValue, \r\n          formattedValue, \r\n          cursorPosition\r\n        );\r\n        inputElement.value = formattedValue;\r\n        setTimeout(() => {\r\n          inputElement.setSelectionRange(newCursorPosition, newCursorPosition);\r\n        }, 0);\r\n      }\r\n      this._onChange(this.inputValue);\r\n    } else {\r\n      const revertValue = this.isCommaAdded && this.inputValue ? \r\n        this.addCommasToNumber(this.inputValue) : this.inputValue || '';\r\n      inputElement.value = revertValue;\r\n      setTimeout(() => {\r\n        const safeCursorPos = Math.min(cursorPosition, revertValue.length);\r\n        inputElement.setSelectionRange(safeCursorPos, safeCursorPos);\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  onInputBlur(event?: any): void {\r\n    this._unTouched();\r\n     this.blur.emit(event);\r\n  }\r\n  onKeyDown(event: KeyboardEvent): void {\r\n    const inputElement = event.target as HTMLInputElement;\r\n    const cursorPosition = inputElement.selectionStart || 0;\r\n    const value = inputElement.value;\r\n    if (event.key === 'Backspace' && cursorPosition > 0) {\r\n      if (value[cursorPosition - 1] === ',') {\r\n        event.preventDefault();\r\n        const newValue = value.substring(0, cursorPosition - 2) + value.substring(cursorPosition);\r\n        const rawValue = newValue.replace(/,/g, '');\r\n        if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\r\n          this.inputValue = rawValue;\r\n          const formattedValue = this.isCommaAdded && rawValue ? this.addCommasToNumber(rawValue) : rawValue;\r\n          inputElement.value = formattedValue;\r\n          setTimeout(() => {\r\n            const newCursorPos = Math.max(0, cursorPosition - 2);\r\n            inputElement.setSelectionRange(newCursorPos, newCursorPos);\r\n          }, 0);\r\n          \r\n          this._onChange(this.inputValue);\r\n        }\r\n      }\r\n    }\r\n    if (event.key === 'Delete' && cursorPosition < value.length) {\r\n      if (value[cursorPosition] === ',') {\r\n        event.preventDefault();\r\n        if (cursorPosition + 1 < value.length) {\r\n          const newValue = value.substring(0, cursorPosition) + value.substring(cursorPosition + 2);\r\n          const rawValue = newValue.replace(/,/g, '');\r\n          if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\r\n            this.inputValue = rawValue;\r\n            const formattedValue = this.isCommaAdded && rawValue ? this.addCommasToNumber(rawValue) : rawValue;\r\n            inputElement.value = formattedValue;\r\n            setTimeout(() => {\r\n              inputElement.setSelectionRange(cursorPosition, cursorPosition);\r\n            }, 0);\r\n            this._onChange(this.inputValue);\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  // Add commas to number for display\r\n  addCommasToNumber(value: any | number): any {\r\n    if (!value || value === '') return '';\r\n    const stringValue = value.toString();\r\n    const parts = stringValue.split('.');\r\n    parts[0] = parts[0].replace(/\\B(?=(\\d{3})+(?!\\d))/g, ',');\r\n    return parts.join('.');\r\n  }\r\n  calculateNewCursorPosition(oldValue: string, newValue: string, oldCursorPosition: number): number {\r\n    if (oldCursorPosition === 0) {\r\n      return 0;\r\n    }\r\n    if (oldCursorPosition >= oldValue.length) {\r\n      return newValue.length;\r\n    }\r\n    let digitsBeforeCursor = 0;\r\n    for (let i = 0; i < oldCursorPosition; i++) {\r\n      const char = oldValue[i];\r\n      if (char !== ',') {\r\n        digitsBeforeCursor++;\r\n      }\r\n    }\r\n    let digitCount = 0;\r\n    let newPosition = 0;\r\n    for (let i = 0; i < newValue.length; i++) {\r\n      const char = newValue[i];\r\n      if (char !== ',') {\r\n        digitCount++;\r\n        if (digitCount === digitsBeforeCursor) {\r\n          newPosition = i + 1;\r\n          break;\r\n        }\r\n      }\r\n      if (digitCount < digitsBeforeCursor) {\r\n        newPosition = i + 1;\r\n      }\r\n    }\r\n    return Math.min(newPosition, newValue.length);\r\n  }\r\n\r\n  // Get the display value with commas if enabled\r\n  getDisplayValue(): any {\r\n    if (!this.inputValue) return '';\r\n    if (this.isCommaAdded && !isNaN(parseFloat(this.inputValue))) {\r\n      return this.addCommasToNumber(this.inputValue);\r\n    }\r\n    return this.inputValue;\r\n  }\r\n\r\n  // Format amount to Indian currency format\r\n  formatIndianCurrency(amount: number | string): string {\r\n    if (!amount || amount === '') return '';\r\n\r\n    const numAmount = typeof amount === 'string' ? parseFloat(amount.replace(/,/g, '')) : amount;\r\n    if (isNaN(numAmount) || numAmount === 0) return '₹';\r\n    if (numAmount >= 10000000) {\r\n      const crores = (numAmount / 10000000).toFixed(2);\r\n      return `₹ ${crores} Cr`;\r\n    } else if (numAmount >= 100000) {\r\n      const lakhs = (numAmount / 100000).toFixed(2);\r\n      return `₹ ${lakhs} L`;\r\n    } else if (numAmount >= 1000) {\r\n      const thousands = (numAmount / 1000).toFixed(2);\r\n      return `₹ ${thousands} K`;\r\n    } else {\r\n      return `₹ ${numAmount.toFixed(2)}`;\r\n    }\r\n  }\r\n\r\n  // Get formatted display value\r\n  getFormattedAmount(): string {\r\n    return this.formatIndianCurrency(this.sharedService.removeComasAndCurrencySymbolFromNumberValues(this.inputValue));\r\n  }\r\n}\r\n","<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\r\n  >{{ field().label\r\n  }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\r\n    >*</span\r\n  ></label\r\n>\r\n  <mat-form-field\r\n  class=\"w-100\"\r\n  appearance=\"outline\"\r\n  *ngIf=\"field() && field()?.isVisible\"\r\n  [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\">\r\n @if(reactiveFormControlobject()) {\r\n<input\r\n      matInput\r\n      [type]=\"field()?.controlType\"\r\n      [name]=\"field()?.fieldName\"\r\n      [id]=\"field()?.fieldName\"\r\n      autocomplete=\"none\"\r\n      [placeholder]=\"field()?.placeHolder\"\r\n      [maxLength]=\"field()?.validators?.maxLength\"\r\n      [minLength]=\"field()?.validators?.minLength\"\r\n      [disabled]=\"field()?.isDisable\"\r\n      [required]=\"field()?.validators?.isRequired\"\r\n      [pattern]=\"field()?.validators?.pattern\"\r\n      (input)=\"onInputChange($event)\"\r\n      (keydown)=\"onKeyDown($event)\"\r\n      (blur)=\"onInputBlur($event)\"\r\n      [value]=\"getDisplayValue()\"\r\n      [formControl]=\"reactiveFormControlobject()\"\r\n    />\r\n }@else {\r\n  <input\r\n      matInput\r\n      [type]=\"field()?.controlType\"\r\n      [name]=\"field()?.fieldName\"\r\n      [id]=\"field()?.fieldName\"\r\n      autocomplete=\"none\"\r\n      [placeholder]=\"field()?.placeHolder\"\r\n      [maxLength]=\"field()?.validators?.maxLength\"\r\n      [minLength]=\"field()?.validators?.minLength\"\r\n      [disabled]=\"field()?.isDisable\"\r\n      [required]=\"field()?.validators?.isRequired\"\r\n      [pattern]=\"field()?.validators?.pattern\"\r\n      (input)=\"onInputChange($event)\"\r\n      (keydown)=\"onKeyDown($event)\"\r\n      (blur)=\"onInputBlur($event)\"\r\n      [value]=\"getDisplayValue()\"\r\n    />\r\n }\r\n\r\n    <mat-error *ngIf=\"false\">\r\n      {{ field()?.validators?.requiredMessage }}\r\n    </mat-error>\r\n    <span matPrefix class=\"rupee-symbol px-2\">₹</span>\r\n    <span matSuffix class=\"me-2 right-amount-text\">{{ getFormattedAmount() }}</span>\r\n  </mat-form-field>\r\n"]}
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';\r\nimport { Component, input, Output, EventEmitter } from '@angular/core';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MasterControlService } from '../master-control.service';\r\n\r\n@Component({\r\n  selector: 'lib-amount-textbox',\r\n  standalone: true,\r\n  imports: [\r\n    MatFormFieldModule,\r\n    CommonModule,\r\n    MatInputModule,\r\n    ReactiveFormsModule\r\n  ],\r\n  templateUrl: './amount-textbox.component.html',\r\n  styleUrl: './amount-textbox.component.css',\r\n  providers: [\r\n      {\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: AmountTextboxComponent,\r\n        multi: true\r\n      }\r\n    ]\r\n})\r\nexport class AmountTextboxComponent implements ControlValueAccessor {\r\n  constructor(public sharedService : MasterControlService){}\r\n  field : any = input.required<any>();\r\n  inputValue: any = null;\r\n  reactiveFormControlobject : any = input<any>();\r\n  _onChange: any = (inputValue:any) => {};\r\n  _unTouched: any = () => {};\r\n  get isCommaAdded(): any {\r\n    return this.field()?.configData?.isCommaAllowed !== undefined ?\r\n      this.field()?.configData?.isCommaAllowed : true;\r\n  }\r\n\r\n   // Declare Output event emitter here (class level)\r\n  @Output() blur = new EventEmitter<any>();\r\n\r\n  // ControlValueAccessor implementation\r\n  writeValue(obj: any): void {\r\n    if (obj !== null && obj !== undefined) {\r\n      const rawValue = obj.toString();\r\n      this.inputValue = rawValue;\r\n    } else {\r\n      this.inputValue = null;\r\n    }\r\n  }\r\n  registerOnChange(fn: any): void{\r\n    this._onChange = fn;\r\n  };\r\n  registerOnTouched(fn: any): void{\r\n    this._unTouched = fn;\r\n  };\r\n  setDisabledState?(isDisabled: boolean): void{};\r\n\r\n  onInputChange(event: any): void {\r\n    const inputElement = event.target;\r\n    const cursorPosition = inputElement.selectionStart;\r\n    const oldValue = inputElement.value;\r\n    const rawValue = oldValue.replace(/,/g, '');\r\n    if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\r\n      this.inputValue = rawValue;\r\n      if (this.isCommaAdded && rawValue && !isNaN(parseFloat(rawValue))) {\r\n        const formattedValue = this.sharedService.addComasToNumberValues(rawValue);\r\n        const newCursorPosition = this.calculateNewCursorPosition(\r\n          oldValue,\r\n          formattedValue,\r\n          cursorPosition\r\n        );\r\n        inputElement.value = formattedValue;\r\n        setTimeout(() => {\r\n          inputElement.setSelectionRange(newCursorPosition, newCursorPosition);\r\n        }, 0);\r\n      }\r\n      this._onChange(this.inputValue);\r\n    } else {\r\n      const revertValue = this.isCommaAdded && this.inputValue ?\r\n        this.sharedService.addComasToNumberValues(this.inputValue) : this.inputValue || '';\r\n      inputElement.value = revertValue;\r\n      setTimeout(() => {\r\n        const safeCursorPos = Math.min(cursorPosition, revertValue.length);\r\n        inputElement.setSelectionRange(safeCursorPos, safeCursorPos);\r\n      }, 0);\r\n    }\r\n  }\r\n\r\n  onInputBlur(event?: any): void {\r\n    this._unTouched();\r\n     this.blur.emit(event);\r\n  }\r\n  onKeyDown(event: KeyboardEvent): void {\r\n    const inputElement = event.target as HTMLInputElement;\r\n    const cursorPosition = inputElement.selectionStart || 0;\r\n    const value = inputElement.value;\r\n    if (event.key === 'Backspace' && cursorPosition > 0) {\r\n      if (value[cursorPosition - 1] === ',') {\r\n        event.preventDefault();\r\n        const newValue = value.substring(0, cursorPosition - 2) + value.substring(cursorPosition);\r\n        const rawValue = newValue.replace(/,/g, '');\r\n        if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\r\n          this.inputValue = rawValue;\r\n          const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;\r\n          inputElement.value = formattedValue;\r\n          setTimeout(() => {\r\n            const newCursorPos = Math.max(0, cursorPosition - 2);\r\n            inputElement.setSelectionRange(newCursorPos, newCursorPos);\r\n          }, 0);\r\n\r\n          this._onChange(this.inputValue);\r\n        }\r\n      }\r\n    }\r\n    if (event.key === 'Delete' && cursorPosition < value.length) {\r\n      if (value[cursorPosition] === ',') {\r\n        event.preventDefault();\r\n        if (cursorPosition + 1 < value.length) {\r\n          const newValue = value.substring(0, cursorPosition) + value.substring(cursorPosition + 2);\r\n          const rawValue = newValue.replace(/,/g, '');\r\n          if (rawValue === '' || /^\\d*\\.?\\d*$/.test(rawValue)) {\r\n            this.inputValue = rawValue;\r\n            const formattedValue = this.isCommaAdded && rawValue ? this.sharedService.addComasToNumberValues(rawValue) : rawValue;\r\n            inputElement.value = formattedValue;\r\n            setTimeout(() => {\r\n              inputElement.setSelectionRange(cursorPosition, cursorPosition);\r\n            }, 0);\r\n            this._onChange(this.inputValue);\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  // Add commas to number for Indian format\r\n  // addCommasToNumber(value: any | number): any {\r\n  //   if (!value || value === '') return '';\r\n  //   const stringValue = value.toString();\r\n  //   const parts = stringValue.split('.');\r\n  //   let integerPart = parts[0];\r\n  //   if (integerPart.length > 3) {\r\n  //     const lastThreeDigits = integerPart.slice(-3);\r\n  //     const remainingDigits = integerPart.slice(0, -3);\r\n  //     const formattedRemaining = remainingDigits.replace(/\\B(?=(\\d{2})+(?!\\d))/g, ',');\r\n  //     integerPart = formattedRemaining + ',' + lastThreeDigits;\r\n  //   }\r\n\r\n  //   return parts[1] ? integerPart + '.' + parts[1] : integerPart;\r\n  // }\r\n  calculateNewCursorPosition(oldValue: string, newValue: string, oldCursorPosition: number): number {\r\n    if (oldCursorPosition === 0) {\r\n      return 0;\r\n    }\r\n    if (oldCursorPosition >= oldValue.length) {\r\n      return newValue.length;\r\n    }\r\n    let digitsBeforeCursor = 0;\r\n    for (let i = 0; i < oldCursorPosition; i++) {\r\n      const char = oldValue[i];\r\n      if (char !== ',') {\r\n        digitsBeforeCursor++;\r\n      }\r\n    }\r\n    let digitCount = 0;\r\n    let newPosition = 0;\r\n    for (let i = 0; i < newValue.length; i++) {\r\n      const char = newValue[i];\r\n      if (char !== ',') {\r\n        digitCount++;\r\n        if (digitCount === digitsBeforeCursor) {\r\n          newPosition = i + 1;\r\n          break;\r\n        }\r\n      }\r\n      if (digitCount < digitsBeforeCursor) {\r\n        newPosition = i + 1;\r\n      }\r\n    }\r\n    return Math.min(newPosition, newValue.length);\r\n  }\r\n\r\n  // Get the display value with commas if enabled\r\n  getDisplayValue(): any {\r\n    if (!this.inputValue) return '';\r\n    if (this.isCommaAdded && !isNaN(parseFloat(this.inputValue))) {\r\n      return this.sharedService.addComasToNumberValues(this.inputValue);\r\n    }\r\n    return this.inputValue;\r\n  }\r\n\r\n  // Format amount to Indian currency format\r\n  formatIndianCurrency(amount: number | string): string {\r\n    if (!amount || amount === '') return '';\r\n\r\n    const numAmount = typeof amount === 'string' ? parseFloat(amount.replace(/,/g, '')) : amount;\r\n    if (isNaN(numAmount) || numAmount === 0) return '₹';\r\n    if (numAmount >= 10000000) {\r\n      const crores = (numAmount / 10000000).toFixed(2);\r\n      return `₹ ${crores} Cr`;\r\n    } else if (numAmount >= 100000) {\r\n      const lakhs = (numAmount / 100000).toFixed(2);\r\n      return `₹ ${lakhs} L`;\r\n    } else if (numAmount >= 1000) {\r\n      const thousands = (numAmount / 1000).toFixed(2);\r\n      return `₹ ${thousands} K`;\r\n    } else {\r\n      return `₹ ${numAmount.toFixed(2)}`;\r\n    }\r\n  }\r\n\r\n  // Get formatted display value\r\n  getFormattedAmount(): string {\r\n    return this.formatIndianCurrency(this.sharedService.removeComasAndCurrencySymbolFromNumberValues(this.inputValue));\r\n  }\r\n}\r\n","<label class=\"field-lable\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\"\r\n  >{{ field().label\r\n  }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators.isRequired\"\r\n    >*</span\r\n  ></label\r\n>\r\n  <mat-form-field\r\n  class=\"w-100\"\r\n  appearance=\"outline\"\r\n  *ngIf=\"field() && field()?.isVisible\"\r\n  [ngStyle]=\"{\r\n'--custom-border-color': field()?.controlStyle?.borderColor ,\r\n'--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n'--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n'--custom-bg-color': field()?.controlStyle?.background ,\r\n'--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n'--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n'--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n'--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n'--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n'--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n'--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n'--custom-font-size': field()?.controlStyle?.fontSize ,\r\n'--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n'--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n'--custom-font-color': field()?.controlStyle?.color ,\r\n'--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n}\">\r\n @if(reactiveFormControlobject()) {\r\n<input\r\n      matInput\r\n      [type]=\"field()?.controlType\"\r\n      [name]=\"field()?.fieldName\"\r\n      [id]=\"field()?.fieldName\"\r\n      autocomplete=\"none\"\r\n      [placeholder]=\"field()?.placeHolder\"\r\n      [maxLength]=\"field()?.validators?.maxLength\"\r\n      [minLength]=\"field()?.validators?.minLength\"\r\n      [disabled]=\"field()?.isDisable\"\r\n      [required]=\"field()?.validators?.isRequired\"\r\n      [pattern]=\"field()?.validators?.pattern\"\r\n      (input)=\"onInputChange($event)\"\r\n      (keydown)=\"onKeyDown($event)\"\r\n      (blur)=\"onInputBlur($event)\"\r\n      [value]=\"getDisplayValue()\"\r\n      [formControl]=\"reactiveFormControlobject()\"\r\n    />\r\n }@else {\r\n  <input\r\n      matInput\r\n      [type]=\"field()?.controlType\"\r\n      [name]=\"field()?.fieldName\"\r\n      [id]=\"field()?.fieldName\"\r\n      autocomplete=\"none\"\r\n      [placeholder]=\"field()?.placeHolder\"\r\n      [maxLength]=\"field()?.validators?.maxLength\"\r\n      [minLength]=\"field()?.validators?.minLength\"\r\n      [disabled]=\"field()?.isDisable\"\r\n      [required]=\"field()?.validators?.isRequired\"\r\n      [pattern]=\"field()?.validators?.pattern\"\r\n      (input)=\"onInputChange($event)\"\r\n      (keydown)=\"onKeyDown($event)\"\r\n      (blur)=\"onInputBlur($event)\"\r\n      [value]=\"getDisplayValue()\"\r\n    />\r\n }\r\n\r\n    <mat-error *ngIf=\"false\">\r\n      {{ field()?.validators?.requiredMessage }}\r\n    </mat-error>\r\n    <span matPrefix class=\"rupee-symbol px-2\">₹</span>\r\n    <span matSuffix class=\"me-2 right-amount-text\" *ngIf=\"inputValue\">{{ getFormattedAmount() }}</span>\r\n  </mat-form-field>\r\n"]}
@@ -70,7 +70,7 @@ export class CheckboxComponent {
70
70
  useExisting: CheckboxComponent,
71
71
  multi: true
72
72
  }
73
- ], ngImport: i0, template: "@if(reactiveFormControlobject()) {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n [formControl]=\"reactiveFormControlobject()\" (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n <span [appTooltipTemplate]=\"HtmlContent\" arrowPosition=\"left\" tooltipPosition=\"bottom\">\r\n <img [src]=\"field().imageUrl\" class=\"toggle-img mx-1\" />\r\n </span>\r\n <ng-template #HtmlContent>\r\n <span [innerHTML]=\"field().configData?.tooltipMessage\"></span>\r\n </ng-template>\r\n</mat-checkbox>\r\n}@else {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n</mat-checkbox>\r\n}\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{field()?.validators?.isRequiredMessage}}.\r\n</div>", styles: ["*{font-family:mulish!important}.error-message{color:red}.toggle-img{width:12px;margin-left:8px!important}@media screen and (max-width: 768px){.toggle-img{width:16px}}::ng-deep .mdc-checkbox__background{border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:disabled:checked~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:disabled:indeterminate~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:enabled:indeterminate~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked:after{color:#fff!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-indeterminate{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox{border:1px solid #DADADA}::ng-deep .checkbox{padding:4px 8px 3px 0;background:#f5f5f5;border-radius:4px;margin-right:8px}::ng-deep .mat-mdc-checkbox label{font-size:var(--checkbox-font-size , 16px)!important;font-weight:var(--checkbox-font-weight , 700)!important;color:var(--checkbox-font-color , #444)!important;padding:0!important;margin-bottom:2px;font-family:Mulish!important;margin-top:8px}::ng-deep .mat-mdc-checkbox .mdc-checkbox__ripple{display:none}::ng-deep .mdc-checkbox__native-control:checked~.mdc-checkbox__background .mdc-checkbox__checkmark{color:#fff!important}::ng-deep .mat-internal-form-field{align-items:flex-start!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: CustomizedTooltipDirective, selector: "[appTooltipTemplate]", inputs: ["appTooltipTemplate"] }] });
73
+ ], ngImport: i0, template: "@if(reactiveFormControlobject()) {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\" (keydown.enter)=\"$event.preventDefault()\"\r\n [formControl]=\"reactiveFormControlobject()\" (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n <span [appTooltipTemplate]=\"HtmlContent\" arrowPosition=\"left\" tooltipPosition=\"bottom\">\r\n <img [src]=\"field().imageUrl\" class=\"toggle-img mx-1\" />\r\n </span>\r\n <ng-template #HtmlContent>\r\n <span [innerHTML]=\"field().configData?.tooltipMessage\"></span>\r\n </ng-template>\r\n</mat-checkbox>\r\n}@else {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n</mat-checkbox>\r\n}\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{field()?.validators?.isRequiredMessage}}.\r\n</div>\r\n", styles: ["*{font-family:mulish!important}.error-message{color:red}.toggle-img{width:12px;margin-left:8px!important}@media screen and (max-width: 768px){.toggle-img{width:16px}}::ng-deep .mdc-checkbox__background{border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:disabled:checked~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:disabled:indeterminate~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:enabled:indeterminate~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked:after{color:#fff!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-indeterminate{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox{border:1px solid #DADADA}::ng-deep .checkbox{padding:4px 8px 3px 0;background:#f5f5f5;border-radius:4px;margin-right:8px}::ng-deep .mat-mdc-checkbox label{font-size:var(--checkbox-font-size , 16px)!important;font-weight:var(--checkbox-font-weight , 700)!important;color:var(--checkbox-font-color , #444)!important;padding:0!important;margin-bottom:2px;font-family:Mulish!important;margin-top:8px}::ng-deep .mat-mdc-checkbox .mdc-checkbox__ripple{display:none}::ng-deep .mdc-checkbox__native-control:checked~.mdc-checkbox__background .mdc-checkbox__checkmark{color:#fff!important}::ng-deep .mat-internal-form-field{align-items:flex-start!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: CustomizedTooltipDirective, selector: "[appTooltipTemplate]", inputs: ["appTooltipTemplate"] }] });
74
74
  }
75
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CheckboxComponent, decorators: [{
76
76
  type: Component,
@@ -80,8 +80,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
80
80
  useExisting: CheckboxComponent,
81
81
  multi: true
82
82
  }
83
- ], template: "@if(reactiveFormControlobject()) {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n [formControl]=\"reactiveFormControlobject()\" (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n <span [appTooltipTemplate]=\"HtmlContent\" arrowPosition=\"left\" tooltipPosition=\"bottom\">\r\n <img [src]=\"field().imageUrl\" class=\"toggle-img mx-1\" />\r\n </span>\r\n <ng-template #HtmlContent>\r\n <span [innerHTML]=\"field().configData?.tooltipMessage\"></span>\r\n </ng-template>\r\n</mat-checkbox>\r\n}@else {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n</mat-checkbox>\r\n}\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{field()?.validators?.isRequiredMessage}}.\r\n</div>", styles: ["*{font-family:mulish!important}.error-message{color:red}.toggle-img{width:12px;margin-left:8px!important}@media screen and (max-width: 768px){.toggle-img{width:16px}}::ng-deep .mdc-checkbox__background{border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:disabled:checked~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:disabled:indeterminate~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:enabled:indeterminate~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked:after{color:#fff!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-indeterminate{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox{border:1px solid #DADADA}::ng-deep .checkbox{padding:4px 8px 3px 0;background:#f5f5f5;border-radius:4px;margin-right:8px}::ng-deep .mat-mdc-checkbox label{font-size:var(--checkbox-font-size , 16px)!important;font-weight:var(--checkbox-font-weight , 700)!important;color:var(--checkbox-font-color , #444)!important;padding:0!important;margin-bottom:2px;font-family:Mulish!important;margin-top:8px}::ng-deep .mat-mdc-checkbox .mdc-checkbox__ripple{display:none}::ng-deep .mdc-checkbox__native-control:checked~.mdc-checkbox__background .mdc-checkbox__checkmark{color:#fff!important}::ng-deep .mat-internal-form-field{align-items:flex-start!important}\n"] }]
83
+ ], template: "@if(reactiveFormControlobject()) {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\" (keydown.enter)=\"$event.preventDefault()\"\r\n [formControl]=\"reactiveFormControlobject()\" (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n <span [appTooltipTemplate]=\"HtmlContent\" arrowPosition=\"left\" tooltipPosition=\"bottom\">\r\n <img [src]=\"field().imageUrl\" class=\"toggle-img mx-1\" />\r\n </span>\r\n <ng-template #HtmlContent>\r\n <span [innerHTML]=\"field().configData?.tooltipMessage\"></span>\r\n </ng-template>\r\n</mat-checkbox>\r\n}@else {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n '--checkbox-bg-color': field()?.controlStyle?.background,\r\n '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n '--checkbox-font-color': field()?.controlStyle?.color,\r\n '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n }\">\r\n {{ field()?.label }}\r\n <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n</mat-checkbox>\r\n}\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{field()?.validators?.isRequiredMessage}}.\r\n</div>\r\n", styles: ["*{font-family:mulish!important}.error-message{color:red}.toggle-img{width:12px;margin-left:8px!important}@media screen and (max-width: 768px){.toggle-img{width:16px}}::ng-deep .mdc-checkbox__background{border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:disabled:checked~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:disabled:indeterminate~.mdc-checkbox__background{background-color:var(--checkbox-bg-color , #ffffff)!important;border-color:#0000}::ng-deep .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mdc-checkbox__native-control:enabled:indeterminate~.mdc-checkbox__background{border-color:var(--checkbox-border-color-focus, #ffbb00)!important;background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked:after{color:#fff!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-checked{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox-full.mat-pseudo-checkbox-indeterminate{background-color:var(--checkbox-bg-color-focus, #ffbb00)!important;border-radius:var(--checkbox-border-radius, 4px)!important}::ng-deep .mat-pseudo-checkbox{border:1px solid #DADADA}::ng-deep .checkbox{padding:4px 8px 3px 0;background:#f5f5f5;border-radius:4px;margin-right:8px}::ng-deep .mat-mdc-checkbox label{font-size:var(--checkbox-font-size , 16px)!important;font-weight:var(--checkbox-font-weight , 700)!important;color:var(--checkbox-font-color , #444)!important;padding:0!important;margin-bottom:2px;font-family:Mulish!important;margin-top:8px}::ng-deep .mat-mdc-checkbox .mdc-checkbox__ripple{display:none}::ng-deep .mdc-checkbox__native-control:checked~.mdc-checkbox__background .mdc-checkbox__checkmark{color:#fff!important}::ng-deep .mat-internal-form-field{align-items:flex-start!important}\n"] }]
84
84
  }], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { change: [{
85
85
  type: Output
86
86
  }] } });
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/checkbox/checkbox.component.ts","../../../../../projects/master-control/src/lib/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input, Output, EventEmitter } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { CustomizedTooltipDirective } from '../directives/customized.tooltip.directive';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-checkbox',\r\n  standalone: true,\r\n  imports: [CommonModule , MatCheckboxModule, ReactiveFormsModule, CustomizedTooltipDirective],\r\n  templateUrl: './checkbox.component.html',\r\n  styleUrl: './checkbox.component.css',\r\n    providers: [\r\n      {\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: CheckboxComponent,\r\n        multi: true\r\n      }\r\n    ]\r\n})\r\nexport class CheckboxComponent implements ControlValueAccessor {\r\n  constructor(public masterService : MasterControlService){}\r\n  field: any = input.required<any>();\r\n\r\n  inputValue: any = false;\r\n  reactiveFormControlobject : any = input<any>();\r\n  @Output() change = new EventEmitter<any>();\r\n  _onChange: any = (inputValue:any) => {};\r\n  _unTouched: any = () => {};\r\n\r\n  writeValue(obj: any): void{\r\n    this.inputValue=obj;\r\n  };\r\n  registerOnChange(fn: any): void{\r\n    this._onChange = fn;\r\n  };\r\n  registerOnTouched(fn: any): void{\r\n    this._unTouched = fn;\r\n  };\r\n  setDisabledState?(isDisabled: boolean): void{};\r\n\r\n  onInputChange(event: any): void {\r\n    this.inputValue = event.target.value;\r\n    this._onChange(this.inputValue);\r\n  }\r\n\r\n  onCheckboxChange(event: any): void {\r\n    // const target = event.target as HTMLInputElement;\r\n    this.inputValue = event.checked;\r\n    this._onChange(this.inputValue);\r\n    this._unTouched();\r\n    // this.change.emit({ event, field: this.field() });\r\n    this.change.emit(this.inputValue);\r\n    const css = this.field()?.controlStyle;\r\n  if (event.checked) {\r\n    document.body.style.setProperty('--custom-checkbox-border-focus', css?.focusBorderColor || '#ffbb00');\r\n    document.body.style.setProperty('--custom-checkbox-bg-color-focus', css?.focusBackground || '#ffbb00');\r\n    document.body.style.setProperty('--custom-checkbox-border-radius-checkbox', css?.borderRadius || '4px');\r\n    document.body.style.setProperty('--custom-font-size', css?.fontSize || '16px');\r\n    document.body.style.setProperty('--custom-font-weight', css?.fontWeight || '400');\r\n    document.body.style.setProperty('--custom-font-family', css?.fontFamily || 'Mulish');\r\n    document.body.style.setProperty('--custom-font-color', css?.color || '#444');\r\n  } else {\r\n    document.body.style.setProperty('--custom-border-color-focus', css?.focusBorderColor || '#ddd');\r\n    document.body.style.setProperty('--custom-bg-color-focus', css?.focusBackground || '#999');\r\n    document.body.style.setProperty('--custom-border-radius-checkbox', css?.borderRadius || '4px');\r\n  }\r\n  }\r\n\r\n  onInputBlur(): void {\r\n    this._unTouched();\r\n  }\r\n}\r\n","@if(reactiveFormControlobject()) {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n  [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n  [formControl]=\"reactiveFormControlobject()\" (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n      '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n      '--checkbox-bg-color': field()?.controlStyle?.background,\r\n      '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n      '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n      '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n      '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n      '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n      '--checkbox-font-color': field()?.controlStyle?.color,\r\n      '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n      '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n      '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n      '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n      '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n      '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n    }\">\r\n  {{ field()?.label }}\r\n  <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n  <span [appTooltipTemplate]=\"HtmlContent\" arrowPosition=\"left\" tooltipPosition=\"bottom\">\r\n    <img [src]=\"field().imageUrl\" class=\"toggle-img mx-1\" />\r\n  </span>\r\n  <ng-template #HtmlContent>\r\n    <span [innerHTML]=\"field().configData?.tooltipMessage\"></span>\r\n  </ng-template>\r\n</mat-checkbox>\r\n}@else {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n  [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n  (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n      '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n      '--checkbox-bg-color': field()?.controlStyle?.background,\r\n      '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n      '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n      '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n      '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n      '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n      '--checkbox-font-color': field()?.controlStyle?.color,\r\n      '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n      '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n      '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n      '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n      '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n      '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n    }\">\r\n  {{ field()?.label }}\r\n  <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n</mat-checkbox>\r\n}\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{field()?.validators?.isRequiredMessage}}.\r\n</div>"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/checkbox/checkbox.component.ts","../../../../../projects/master-control/src/lib/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input, Output, EventEmitter } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { CustomizedTooltipDirective } from '../directives/customized.tooltip.directive';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-checkbox',\r\n  standalone: true,\r\n  imports: [CommonModule , MatCheckboxModule, ReactiveFormsModule, CustomizedTooltipDirective],\r\n  templateUrl: './checkbox.component.html',\r\n  styleUrl: './checkbox.component.css',\r\n    providers: [\r\n      {\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: CheckboxComponent,\r\n        multi: true\r\n      }\r\n    ]\r\n})\r\nexport class CheckboxComponent implements ControlValueAccessor {\r\n  constructor(public masterService : MasterControlService){}\r\n  field: any = input.required<any>();\r\n\r\n  inputValue: any = false;\r\n  reactiveFormControlobject : any = input<any>();\r\n  @Output() change = new EventEmitter<any>();\r\n  _onChange: any = (inputValue:any) => {};\r\n  _unTouched: any = () => {};\r\n\r\n  writeValue(obj: any): void{\r\n    this.inputValue=obj;\r\n  };\r\n  registerOnChange(fn: any): void{\r\n    this._onChange = fn;\r\n  };\r\n  registerOnTouched(fn: any): void{\r\n    this._unTouched = fn;\r\n  };\r\n  setDisabledState?(isDisabled: boolean): void{};\r\n\r\n  onInputChange(event: any): void {\r\n    this.inputValue = event.target.value;\r\n    this._onChange(this.inputValue);\r\n  }\r\n\r\n  onCheckboxChange(event: any): void {\r\n    // const target = event.target as HTMLInputElement;\r\n    this.inputValue = event.checked;\r\n    this._onChange(this.inputValue);\r\n    this._unTouched();\r\n    // this.change.emit({ event, field: this.field() });\r\n    this.change.emit(this.inputValue);\r\n    const css = this.field()?.controlStyle;\r\n  if (event.checked) {\r\n    document.body.style.setProperty('--custom-checkbox-border-focus', css?.focusBorderColor || '#ffbb00');\r\n    document.body.style.setProperty('--custom-checkbox-bg-color-focus', css?.focusBackground || '#ffbb00');\r\n    document.body.style.setProperty('--custom-checkbox-border-radius-checkbox', css?.borderRadius || '4px');\r\n    document.body.style.setProperty('--custom-font-size', css?.fontSize || '16px');\r\n    document.body.style.setProperty('--custom-font-weight', css?.fontWeight || '400');\r\n    document.body.style.setProperty('--custom-font-family', css?.fontFamily || 'Mulish');\r\n    document.body.style.setProperty('--custom-font-color', css?.color || '#444');\r\n  } else {\r\n    document.body.style.setProperty('--custom-border-color-focus', css?.focusBorderColor || '#ddd');\r\n    document.body.style.setProperty('--custom-bg-color-focus', css?.focusBackground || '#999');\r\n    document.body.style.setProperty('--custom-border-radius-checkbox', css?.borderRadius || '4px');\r\n  }\r\n  }\r\n\r\n  onInputBlur(): void {\r\n    this._unTouched();\r\n  }\r\n}\r\n","@if(reactiveFormControlobject()) {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n  [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\" (keydown.enter)=\"$event.preventDefault()\"\r\n  [formControl]=\"reactiveFormControlobject()\" (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n      '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n      '--checkbox-bg-color': field()?.controlStyle?.background,\r\n      '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n      '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n      '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n      '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n      '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n      '--checkbox-font-color': field()?.controlStyle?.color,\r\n      '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n      '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n      '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n      '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n      '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n      '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n    }\">\r\n  {{ field()?.label }}\r\n  <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n  <span [appTooltipTemplate]=\"HtmlContent\" arrowPosition=\"left\" tooltipPosition=\"bottom\">\r\n    <img [src]=\"field().imageUrl\" class=\"toggle-img mx-1\" />\r\n  </span>\r\n  <ng-template #HtmlContent>\r\n    <span [innerHTML]=\"field().configData?.tooltipMessage\"></span>\r\n  </ng-template>\r\n</mat-checkbox>\r\n}@else {\r\n<mat-checkbox *ngIf=\"field() && field()?.isVisible\" [name]=\"field()?.fieldName\" [id]=\"field()?.fieldName\"\r\n  [disabled]=\"field()?.isDisable\" [required]=\"field()?.validators?.isRequired\" [checked]=\"inputValue\"\r\n  (change)=\"onCheckboxChange($event)\" [ngStyle]=\"{\r\n      '--checkbox-border-radius': field()?.controlStyle?.borderRadius,\r\n      '--checkbox-bg-color': field()?.controlStyle?.background,\r\n      '--checkbox-border-color': field()?.controlStyle?.borderColor,\r\n      '--checkbox-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n      '--checkbox-bg-color-focus': field()?.controlStyle?.focusBackground,\r\n      '--checkbox-font-size': field()?.controlStyle?.fontSize,\r\n      '--checkbox-font-weight': field()?.controlStyle?.fontWeight,\r\n      '--checkbox-font-color': field()?.controlStyle?.color,\r\n      '--checkbox-font-family': field()?.controlStyle?.fontFamily,\r\n      '--checkbox-border-width': field()?.controlStyle?.borderWidth,\r\n      '--checkbox-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n      '--checkbox-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n      '--checkbox-font-color-disabled': field()?.controlStyle?.disableColor,\r\n      '--checkbox-bg-color-disabled': field()?.controlStyle?.disableBackground\r\n    }\">\r\n  {{ field()?.label }}\r\n  <span [innerHTML]=\"field()?.configData?.innerHTML\"></span>\r\n</mat-checkbox>\r\n}\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{field()?.validators?.isRequiredMessage}}.\r\n</div>\r\n"]}