master-control 0.3.32 → 0.3.34

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.
@@ -1,4 +1,4 @@
1
- import { Component, input, Output, EventEmitter } from '@angular/core';
1
+ import { Component, forwardRef, input, Output, EventEmitter, effect, } from '@angular/core';
2
2
  import { MatInputModule } from '@angular/material/input';
3
3
  import { MatFormFieldModule } from '@angular/material/form-field';
4
4
  import { CommonModule } from '@angular/common';
@@ -11,100 +11,252 @@ import * as i4 from "@angular/common";
11
11
  import * as i5 from "@angular/forms";
12
12
  export class TextboxComponent {
13
13
  masterService;
14
- constructor(masterService) {
14
+ kvDiffers;
15
+ constructor(masterService, kvDiffers) {
15
16
  this.masterService = masterService;
17
+ this.kvDiffers = kvDiffers;
18
+ effect(() => {
19
+ const f = this.field();
20
+ if (!f)
21
+ return;
22
+ if (f.isInputMasked == null)
23
+ f.isInputMasked = false;
24
+ this.syncUIFromRaw();
25
+ });
16
26
  }
17
- inputValue = null;
18
27
  field = input.required();
19
28
  reactiveFormControlobject = input();
20
- _onChange = (inputValue) => { };
21
- _unTouched = () => { };
22
- maskEnabled = true;
23
- inputValueDeepCopy = null;
24
- // Declare Output event emitter here (class level)
29
+ _onChange = () => { };
30
+ _onTouched = () => { };
31
+ inputValueDeepCopy = '';
32
+ inputValue = '';
33
+ lastBeforeInput = null;
34
+ fieldDiffer;
35
+ cfgDiffer;
36
+ styleDiffer;
37
+ validatorsDiffer;
25
38
  blur = new EventEmitter();
26
- ngOnInit() {
27
- if (!this.field().isInputMasked) {
28
- this.field().isInputMasked = false;
39
+ ngDoCheck() {
40
+ const f = this.field?.();
41
+ if (!f)
42
+ return;
43
+ if (!this.fieldDiffer)
44
+ this.fieldDiffer = this.kvDiffers.find(f).create();
45
+ let changed = !!this.fieldDiffer.diff(f);
46
+ if (f.configData) {
47
+ if (!this.cfgDiffer)
48
+ this.cfgDiffer = this.kvDiffers.find(f.configData).create();
49
+ if (this.cfgDiffer.diff(f.configData))
50
+ changed = true;
29
51
  }
30
- if (this.field()?.configData?.isTextCapitalized && this.field().isInputMasked) {
31
- this.inputValue = this.field()?.configData?.isTextCapitalized;
32
- this.checkinputMasked();
52
+ if (f.controlStyle) {
53
+ if (!this.styleDiffer)
54
+ this.styleDiffer = this.kvDiffers.find(f.controlStyle).create();
55
+ if (this.styleDiffer.diff(f.controlStyle))
56
+ changed = true;
57
+ }
58
+ if (f.validators) {
59
+ if (!this.validatorsDiffer)
60
+ this.validatorsDiffer = this.kvDiffers.find(f.validators).create();
61
+ if (this.validatorsDiffer.diff(f.validators))
62
+ changed = true;
63
+ }
64
+ if (changed) {
65
+ this.onFieldConfigChanged();
33
66
  }
34
67
  }
68
+ onFieldConfigChanged() {
69
+ const oldRaw = this.inputValueDeepCopy ?? '';
70
+ const newRaw = this.applyCapitalization(oldRaw);
71
+ if (newRaw !== oldRaw) {
72
+ this.inputValueDeepCopy = newRaw;
73
+ const maskEnabled = !!this.field?.().isInputMasked;
74
+ const hasReactive = !!this.reactiveFormControlobject?.();
75
+ if (hasReactive && !maskEnabled) {
76
+ try {
77
+ this.reactiveFormControlobject().setValue(newRaw, { emitEvent: true });
78
+ }
79
+ catch {
80
+ this._onChange(newRaw);
81
+ }
82
+ }
83
+ else {
84
+ this._onChange(newRaw);
85
+ }
86
+ }
87
+ this.syncUIFromRaw();
88
+ }
35
89
  writeValue(obj) {
36
- this.inputValue = !this.masterService.checkIfValueIsEmpty(obj) ? obj : '';
90
+ const raw = !this.masterService.checkIfValueIsEmpty(obj) ? String(obj) : '';
91
+ const capitalized = this.applyCapitalization(raw);
92
+ this.inputValueDeepCopy = capitalized;
93
+ this.syncUIFromRaw();
37
94
  }
38
- ;
39
95
  registerOnChange(fn) {
40
96
  this._onChange = fn;
41
97
  }
42
- ;
43
98
  registerOnTouched(fn) {
44
- this._unTouched = fn;
99
+ this._onTouched = fn;
100
+ }
101
+ setDisabledState(isDisabled) {
102
+ const f = this.field?.();
103
+ if (f)
104
+ f.isDisable = !!isDisabled;
105
+ }
106
+ onBeforeInput(event) {
107
+ const target = event.target;
108
+ const start = target?.selectionStart ?? 0;
109
+ const end = target?.selectionEnd ?? start;
110
+ this.lastBeforeInput = {
111
+ type: event.inputType,
112
+ data: event.data,
113
+ start,
114
+ end,
115
+ };
45
116
  }
46
- ;
47
- setDisabledState(isDisabled) { }
48
- ;
49
117
  onInputChange(event) {
50
- let min = null;
51
- let max = null;
52
- let value = event.target.value;
53
- if (!this.masterService.checkIfValueIsEmpty(this.field()?.configData) && !this.masterService.checkIfValueIsEmpty(this.field()?.configData?.minValue) && !this.masterService.checkIfValueIsEmpty(this.field()?.configData?.maxValue)) {
54
- min = parseInt(this.field()?.configData?.minValue);
55
- max = parseInt(this.field()?.configData?.maxValue);
118
+ const target = event.target;
119
+ const f = this.field?.();
120
+ const cfg = f?.configData;
121
+ const intent = this.lastBeforeInput ?? {
122
+ type: 'insertText',
123
+ data: null,
124
+ start: target.selectionStart ?? this.inputValueDeepCopy.length,
125
+ end: target.selectionEnd ?? target.selectionStart ?? this.inputValueDeepCopy.length,
126
+ };
127
+ let newVal = this.applyIntentToRaw(this.inputValueDeepCopy, intent);
128
+ newVal = this.applyCapitalization(newVal);
129
+ if (cfg?.inputType === 'number') {
130
+ const min = this.normalizeNumber(cfg?.minValue);
131
+ const max = this.normalizeNumber(cfg?.maxValue);
132
+ const num = Number(newVal);
133
+ if (!Number.isNaN(num)) {
134
+ if (min !== null && num < min)
135
+ newVal = String(min);
136
+ if (max !== null && num > max)
137
+ newVal = String(max);
138
+ }
56
139
  }
57
- if (!this.masterService.checkIfValueIsEmpty(this.field()?.configData?.inputType) && this.field()?.configData?.inputType === 'number' && !this.masterService.checkIfValueIsEmpty(max) && !this.masterService.checkIfValueIsEmpty(min)) {
58
- if (parseInt(value) < min || parseInt(value) > max) {
59
- event.target.value = parseInt(event.target.value.toString().slice(0, -1));
140
+ this.inputValueDeepCopy = newVal;
141
+ const maskEnabled = !!f?.isInputMasked;
142
+ const hasReactive = !!this.reactiveFormControlobject?.();
143
+ if (hasReactive && !maskEnabled) {
144
+ try {
145
+ this.reactiveFormControlobject().setValue(newVal, { emitEvent: true });
146
+ }
147
+ catch {
148
+ this._onChange(newVal);
149
+ }
150
+ }
151
+ else {
152
+ this._onChange(newVal);
153
+ }
154
+ const display = maskEnabled ? this.maskInput(newVal) : newVal;
155
+ this.inputValue = display;
156
+ const nextCaret = this.computeNextCaret(intent, newVal.length);
157
+ if (target.value !== display) {
158
+ target.value = display;
159
+ try {
160
+ target.setSelectionRange(nextCaret, nextCaret);
161
+ }
162
+ catch {
163
+ console.log(this.inputValue);
60
164
  }
61
165
  }
62
- this.inputValue = this.field()?.configData?.isTextCapitalized ? (event.target.value).toUpperCase() : event.target.value;
63
- this.inputValueDeepCopy = JSON.parse(JSON.stringify(this.inputValue));
64
- this._onChange(this.inputValue);
166
+ this.lastBeforeInput = null;
65
167
  }
66
168
  onInputBlur(event) {
67
- this._unTouched();
169
+ this._onTouched();
68
170
  this.blur.emit(event);
69
- if (!this.masterService.checkIfValueIsEmpty(event.target.value)) {
70
- this.checkinputMasked();
71
- }
72
171
  }
73
- checkinputMasked() {
74
- if (!this.field().isInputMasked) {
75
- this.inputValue = this.inputValueDeepCopy;
76
- }
77
- return this.field().isInputMasked ? this.maskInput(this.inputValue) : this.inputValue;
172
+ onInputFocus() {
173
+ }
174
+ syncUIFromRaw() {
175
+ const f = this.field?.();
176
+ const maskEnabled = !!f?.isInputMasked;
177
+ const raw = this.inputValueDeepCopy ?? '';
178
+ this.inputValue = maskEnabled ? this.maskInput(raw) : raw;
179
+ }
180
+ applyCapitalization(v) {
181
+ const f = this.field?.();
182
+ return f?.configData?.isTextCapitalized ? v.toUpperCase() : v;
183
+ }
184
+ normalizeNumber(v) {
185
+ if (this.masterService.checkIfValueIsEmpty(v))
186
+ return null;
187
+ const n = Number(v);
188
+ return Number.isNaN(n) ? null : n;
78
189
  }
79
190
  maskInput(value) {
80
- if (value.length > 3) {
81
- this.inputValue = value[0] + 'X'.repeat(value.length - 2) + value[value.length - 1];
191
+ if (!value || value.length < 3)
192
+ return value || '';
193
+ return value[0] + 'X'.repeat(value.length - 2) + value[value.length - 1];
194
+ }
195
+ applyIntentToRaw(raw, intent) {
196
+ const { type, data, start, end } = intent;
197
+ const s = Math.max(0, Math.min(start, raw.length));
198
+ const e = Math.max(s, Math.min(end, raw.length));
199
+ switch (type) {
200
+ case 'insertText': {
201
+ const insert = data ?? '';
202
+ return raw.slice(0, s) + insert + raw.slice(e);
203
+ }
204
+ case 'insertFromPaste': {
205
+ const paste = data ?? '';
206
+ return raw.slice(0, s) + paste + raw.slice(e);
207
+ }
208
+ case 'deleteContentBackward': {
209
+ if (s !== e)
210
+ return raw.slice(0, s) + raw.slice(e);
211
+ const idx = Math.max(0, s - 1);
212
+ return raw.slice(0, idx) + raw.slice(e);
213
+ }
214
+ case 'deleteContentForward': {
215
+ if (s !== e)
216
+ return raw.slice(0, s) + raw.slice(e);
217
+ return raw.slice(0, s) + raw.slice(Math.min(e + 1, raw.length));
218
+ }
219
+ case 'deleteByCut': {
220
+ return raw.slice(0, s) + raw.slice(e);
221
+ }
222
+ default:
223
+ return raw;
82
224
  }
83
225
  }
84
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TextboxComponent, deps: [{ token: i1.MasterControlService }], target: i0.ɵɵFactoryTarget.Component });
226
+ computeNextCaret(intent, newLen) {
227
+ const { type, data, start, end } = intent;
228
+ switch (type) {
229
+ case 'insertText':
230
+ case 'insertFromPaste':
231
+ return start + (data?.length ?? 0);
232
+ case 'deleteContentBackward':
233
+ return Math.max(0, start - (start === end ? 1 : 0));
234
+ case 'deleteContentForward':
235
+ case 'deleteByCut':
236
+ return start;
237
+ default:
238
+ return Math.max(0, Math.min(start, newLen));
239
+ }
240
+ }
241
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TextboxComponent, deps: [{ token: i1.MasterControlService }, { token: i0.KeyValueDiffers }], target: i0.ɵɵFactoryTarget.Component });
85
242
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: TextboxComponent, isStandalone: true, selector: "lib-textbox", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, reactiveFormControlobject: { classPropertyName: "reactiveFormControlobject", publicName: "reactiveFormControlobject", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { blur: "blur" }, providers: [
86
243
  {
87
244
  provide: NG_VALUE_ACCESSOR,
88
- useExisting: TextboxComponent,
89
- multi: true
90
- }
91
- ], ngImport: i0, template: "<label\r\n class=\"field-lable\"\r\n *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'--custom-width': field()?.controlStyle?.width ,\r\n}\"\r\n>\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n />\r\n }\r\n <mat-hint *ngIf=\"field()?.configData?.helperText\">{{field()?.configData?.helperText}}</mat-hint>\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}\r\n </mat-error>\r\n <!-- <mat-error *ngIf=\"field()?.configData?.isInvalidPattern && !masterService.checkIfValueIsEmpty(field()?.validators?.patternMessage)\">\r\n {{ field()?.validators?.patternMessage }}\r\n </mat-error> -->\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.patternMessage }}.\r\n</div>\r\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:5px}.error-message{color:red}*{font-family:mulish!important}::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:12px!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}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{font-size:14px!important}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: 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"] }] });
245
+ useExisting: forwardRef(() => TextboxComponent),
246
+ multi: true,
247
+ },
248
+ ], ngImport: i0, template: "<label\r\n class=\"field-lable\"\r\n *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n>\r\n {{ field()?.label }}\r\n <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</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 '--custom-width': field()?.controlStyle?.width\r\n }\"\r\n>\r\n\r\n @if (reactiveFormControlobject() && !field()?.isInputMasked) {\r\n <input\r\n matInput\r\n autocomplete=\"off\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (beforeinput)=\"onBeforeInput($event)\"\r\n (input)=\"onInputChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n (focus)=\"onInputFocus()\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n } @else {\r\n\r\n <input\r\n matInput\r\n autocomplete=\"off\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (beforeinput)=\"onBeforeInput($event)\"\r\n (input)=\"onInputChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n (focus)=\"onInputFocus()\"\r\n [value]=\"inputValue\"\r\n />\r\n }\r\n\r\n <mat-hint *ngIf=\"field()?.configData?.helperText\">{{ field()?.configData?.helperText }}</mat-hint>\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage || 'This field cannot be empty' }}\r\n </mat-error>\r\n\r\n</mat-form-field>\r\n\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.patternMessage }}.\r\n</div>", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:5px}.error-message{color:red}*{font-family:mulish!important}::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:12px!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}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{font-size:14px!important}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: 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"] }] });
92
249
  }
93
250
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TextboxComponent, decorators: [{
94
251
  type: Component,
95
- args: [{ selector: 'lib-textbox', standalone: true, imports: [
96
- MatInputModule,
97
- MatFormFieldModule,
98
- CommonModule,
99
- ReactiveFormsModule
100
- ], providers: [
252
+ args: [{ selector: 'lib-textbox', standalone: true, imports: [MatInputModule, MatFormFieldModule, CommonModule, ReactiveFormsModule], providers: [
101
253
  {
102
254
  provide: NG_VALUE_ACCESSOR,
103
- useExisting: TextboxComponent,
104
- multi: true
105
- }
106
- ], template: "<label\r\n class=\"field-lable\"\r\n *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'--custom-width': field()?.controlStyle?.width ,\r\n}\"\r\n>\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n />\r\n }\r\n <mat-hint *ngIf=\"field()?.configData?.helperText\">{{field()?.configData?.helperText}}</mat-hint>\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}\r\n </mat-error>\r\n <!-- <mat-error *ngIf=\"field()?.configData?.isInvalidPattern && !masterService.checkIfValueIsEmpty(field()?.validators?.patternMessage)\">\r\n {{ field()?.validators?.patternMessage }}\r\n </mat-error> -->\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.patternMessage }}.\r\n</div>\r\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:5px}.error-message{color:red}*{font-family:mulish!important}::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:12px!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}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{font-size:14px!important}\n"] }]
107
- }], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { blur: [{
255
+ useExisting: forwardRef(() => TextboxComponent),
256
+ multi: true,
257
+ },
258
+ ], template: "<label\r\n class=\"field-lable\"\r\n *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n>\r\n {{ field()?.label }}\r\n <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</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 '--custom-width': field()?.controlStyle?.width\r\n }\"\r\n>\r\n\r\n @if (reactiveFormControlobject() && !field()?.isInputMasked) {\r\n <input\r\n matInput\r\n autocomplete=\"off\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (beforeinput)=\"onBeforeInput($event)\"\r\n (input)=\"onInputChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n (focus)=\"onInputFocus()\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n } @else {\r\n\r\n <input\r\n matInput\r\n autocomplete=\"off\"\r\n [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\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 (beforeinput)=\"onBeforeInput($event)\"\r\n (input)=\"onInputChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n (focus)=\"onInputFocus()\"\r\n [value]=\"inputValue\"\r\n />\r\n }\r\n\r\n <mat-hint *ngIf=\"field()?.configData?.helperText\">{{ field()?.configData?.helperText }}</mat-hint>\r\n\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage || 'This field cannot be empty' }}\r\n </mat-error>\r\n\r\n</mat-form-field>\r\n\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.requiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.patternMessage }}.\r\n</div>", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:5px}.error-message{color:red}*{font-family:mulish!important}::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:12px!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}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{font-size:14px!important}\n"] }]
259
+ }], ctorParameters: () => [{ type: i1.MasterControlService }, { type: i0.KeyValueDiffers }], propDecorators: { blur: [{
108
260
  type: Output
109
261
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textbox.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/textbox/textbox.component.ts","../../../../../projects/master-control/src/lib/textbox/textbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, input, Output, EventEmitter  } from '@angular/core';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'lib-textbox',\r\n  standalone: true,\r\n  imports: [\r\n    MatInputModule,\r\n    MatFormFieldModule ,\r\n    CommonModule,\r\n    ReactiveFormsModule\r\n  ],\r\n  templateUrl: './textbox.component.html',\r\n  styleUrl: './textbox.component.css',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: TextboxComponent,\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class TextboxComponent implements ControlValueAccessor {\r\n  constructor(public masterService : MasterControlService){}\r\n  inputValue: any = null;\r\n  field : any = input.required<any>();\r\n  reactiveFormControlobject : any = input<any>();\r\n\r\n  _onChange: any = (inputValue:any) => {};\r\n  _unTouched: any = () => {};\r\n  maskEnabled: any = true;\r\n  inputValueDeepCopy:any = null;\r\n\r\n   // Declare Output event emitter here (class level)\r\n  @Output() blur = new EventEmitter<any>();\r\n\r\n   ngOnInit() {\r\n    if(!this.field().isInputMasked){\r\n      this.field().isInputMasked = false;\r\n    }\r\n    if(this.field()?.configData?.isTextCapitalized && this.field().isInputMasked){\r\n      this.inputValue = this.field()?.configData?.isTextCapitalized;\r\n      this.checkinputMasked();\r\n    }\r\n  }\r\n\r\n  writeValue(obj: any): void{\r\n    this.inputValue=!this.masterService.checkIfValueIsEmpty(obj) ? 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    let min : any = null;\r\n    let max : any= null;\r\n    let value = event.target.value;\r\n    if(!this.masterService.checkIfValueIsEmpty(this.field()?.configData) && !this.masterService.checkIfValueIsEmpty(this.field()?.configData?.minValue) && !this.masterService.checkIfValueIsEmpty(this.field()?.configData?.maxValue)) {\r\n      min = parseInt(this.field()?.configData?.minValue);\r\n      max = parseInt(this.field()?.configData?.maxValue);\r\n    }\r\n\r\n    if (!this.masterService.checkIfValueIsEmpty(this.field()?.configData?.inputType) && this.field()?.configData?.inputType === 'number' && !this.masterService.checkIfValueIsEmpty(max) && !this.masterService.checkIfValueIsEmpty(min)) {\r\n      if(parseInt(value) < min || parseInt(value) > max) {\r\n        event.target.value = parseInt(event.target.value.toString().slice(0, -1));\r\n      }\r\n    }\r\n    this.inputValue = this.field()?.configData?.isTextCapitalized ? (event.target.value).toUpperCase() : event.target.value;\r\n    this.inputValueDeepCopy = JSON.parse(JSON.stringify(this.inputValue));\r\n    this._onChange(this.inputValue);\r\n  }\r\n\r\n  onInputBlur(event?: any): void {\r\n    this._unTouched();\r\n    this.blur.emit(event);\r\n    if(!this.masterService.checkIfValueIsEmpty(event.target.value)) {\r\n      this.checkinputMasked();\r\n    }\r\n  }\r\n\r\n  checkinputMasked() {\r\n    if(!this.field().isInputMasked){\r\n      this.inputValue = this.inputValueDeepCopy;\r\n    }\r\n    return this.field().isInputMasked ? this.maskInput(this.inputValue) : this.inputValue;\r\n  }\r\n\r\n  maskInput(value: any) {\r\n    if (value.length > 3){\r\n      this.inputValue =  value[0] + 'X'.repeat(value.length - 2) + value[value.length - 1];\r\n    }\r\n  }\r\n}\r\n","<label\r\n  class=\"field-lable\"\r\n  *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'--custom-width': field()?.controlStyle?.width ,\r\n}\"\r\n>\r\n  @if(reactiveFormControlobject()) {\r\n  <input\r\n    matInput\r\n    autocomplete=\"none\"\r\n    [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n    [name]=\"field()?.fieldName\"\r\n    [id]=\"field()?.fieldName\"\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    (blur)=\"onInputBlur($event)\"\r\n    [value]=\"inputValue\"\r\n    [formControl]=\"reactiveFormControlobject()\"\r\n  />\r\n  }@else {\r\n  <input\r\n    matInput\r\n    autocomplete=\"none\"\r\n    [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n    [name]=\"field()?.fieldName\"\r\n    [id]=\"field()?.fieldName\"\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    (blur)=\"onInputBlur($event)\"\r\n    [value]=\"inputValue\"\r\n  />\r\n  }\r\n    <mat-hint *ngIf=\"field()?.configData?.helperText\">{{field()?.configData?.helperText}}</mat-hint>\r\n\r\n  <mat-error *ngIf=\"false\">\r\n    {{ field()?.validators?.isRequiredMessage }}\r\n  </mat-error>\r\n  <!-- <mat-error *ngIf=\"field()?.configData?.isInvalidPattern && !masterService.checkIfValueIsEmpty(field()?.validators?.patternMessage)\">\r\n    {{ field()?.validators?.patternMessage }}\r\n  </mat-error> -->\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field()?.validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field()?.validators?.patternMessage }}.\r\n</div>\r\n"]}
262
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textbox.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/textbox/textbox.component.ts","../../../../../projects/master-control/src/lib/textbox/textbox.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,KAAK,EACL,MAAM,EACN,YAAY,EACZ,MAAM,GAIP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAwB,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;;;;;;;AAuB9F,MAAM,OAAO,gBAAgB;IAElB;IACC;IAFV,YACS,aAAmC,EAClC,SAA0B;QAD3B,kBAAa,GAAb,aAAa,CAAsB;QAClC,cAAS,GAAT,SAAS,CAAiB;QAElC,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YACvB,IAAI,CAAC,CAAC;gBAAE,OAAO;YAEf,IAAI,CAAC,CAAC,aAAa,IAAI,IAAI;gBAAE,CAAC,CAAC,aAAa,GAAG,KAAK,CAAC;YAErD,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,GAAQ,KAAK,CAAC,QAAQ,EAAO,CAAC;IACnC,yBAAyB,GAAQ,KAAK,EAAO,CAAC;IAEtC,SAAS,GAAuB,GAAG,EAAE,GAAE,CAAC,CAAC;IACzC,UAAU,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;IAE1C,kBAAkB,GAAW,EAAE,CAAC;IAChC,UAAU,GAAW,EAAE,CAAC;IAChB,eAAe,GAA2B,IAAI,CAAC;IAE/C,WAAW,CAA+B;IAC1C,SAAS,CAA+B;IACxC,WAAW,CAA+B;IAC1C,gBAAgB,CAA+B;IAE7C,IAAI,GAAG,IAAI,YAAY,EAAO,CAAC;IAEzC,SAAS;QACP,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QACzB,IAAI,CAAC,CAAC;YAAE,OAAO;QAEf,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;QAC1E,IAAI,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEzC,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC;YACjB,IAAI,CAAC,IAAI,CAAC,SAAS;gBAAE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,CAAC;YACjF,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC;gBAAE,OAAO,GAAG,IAAI,CAAC;QACxD,CAAC;QAED,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC;YACnB,IAAI,CAAC,IAAI,CAAC,WAAW;gBAAE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE,CAAC;YACvF,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC;gBAAE,OAAO,GAAG,IAAI,CAAC;QAC5D,CAAC;QAED,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC;YACjB,IAAI,CAAC,IAAI,CAAC,gBAAgB;gBAAE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,CAAC;YAC/F,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC;gBAAE,OAAO,GAAG,IAAI,CAAC;QAC/D,CAAC;QAED,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC;IACH,CAAC;IAEO,oBAAoB;QAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,IAAI,EAAE,CAAC;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAEhD,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;YACtB,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC;YAEjC,MAAM,WAAW,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,aAAa,CAAC;YACnD,MAAM,WAAW,GAAG,CAAC,CAAC,IAAI,CAAC,yBAAyB,EAAE,EAAE,CAAC;YACzD,IAAI,WAAW,IAAI,CAAC,WAAW,EAAE,CAAC;gBAChC,IAAI,CAAC;oBACH,IAAI,CAAC,yBAAyB,EAAE,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;gBACzE,CAAC;gBAAC,MAAM,CAAC;oBACP,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBACzB,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;QACD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,UAAU,CAAC,GAAQ;QACjB,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5E,MAAM,WAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAClD,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;QACtC,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QACzB,IAAI,CAAC;YAAE,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,UAAU,CAAC;IACpC,CAAC;IAGD,aAAa,CAAC,KAAiB;QAC7B,MAAM,MAAM,GAAG,KAAK,CAAC,MAAiC,CAAC;QACvD,MAAM,KAAK,GAAG,MAAM,EAAE,cAAc,IAAI,CAAC,CAAC;QAC1C,MAAM,GAAG,GAAG,MAAM,EAAE,YAAY,IAAI,KAAK,CAAC;QAC1C,IAAI,CAAC,eAAe,GAAG;YACrB,IAAI,EAAE,KAAK,CAAC,SAAS;YACrB,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,KAAK;YACL,GAAG;SACJ,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,KAAY;QACxB,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAC;QAChD,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QACzB,MAAM,GAAG,GAAG,CAAC,EAAE,UAAU,CAAC;QAE1B,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,IAAI;YACrC,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,MAAM,CAAC,cAAc,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM;YAC9D,GAAG,EAAE,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,cAAc,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM;SACpF,CAAC;QAEF,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC;QAEpE,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAE1C,IAAI,GAAG,EAAE,SAAS,KAAK,QAAQ,EAAE,CAAC;YAChC,MAAM,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;YAChD,MAAM,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;YAChD,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;gBACvB,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,GAAG,GAAG;oBAAE,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;gBACpD,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,GAAG,GAAG;oBAAE,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;YACtD,CAAC;QACH,CAAC;QAED,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC;QAEjC,MAAM,WAAW,GAAG,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC;QACvC,MAAM,WAAW,GAAG,CAAC,CAAC,IAAI,CAAC,yBAAyB,EAAE,EAAE,CAAC;QAEzD,IAAI,WAAW,IAAI,CAAC,WAAW,EAAE,CAAC;YAChC,IAAI,CAAC;gBACH,IAAI,CAAC,yBAAyB,EAAE,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACzE,CAAC;YAAC,MAAM,CAAC;gBACP,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACzB,CAAC;QAED,MAAM,OAAO,GAAG,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QAC9D,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;QAE1B,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QAC/D,IAAI,MAAM,CAAC,KAAK,KAAK,OAAO,EAAE,CAAC;YAC7B,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC;gBAAC,MAAM,CAAC,iBAAiB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;YAAC,CAAC;YAAC,MAAM,CAAC;gBAC7D,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC/B,CAAC;QACH,CAAC;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAED,YAAY;IACZ,CAAC;IAEO,aAAa;QACnB,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QACzB,MAAM,WAAW,GAAG,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC;QACvC,MAAM,GAAG,GAAG,IAAI,CAAC,kBAAkB,IAAI,EAAE,CAAC;QAC1C,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IAC5D,CAAC;IAEO,mBAAmB,CAAC,CAAS;QACnC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;QACzB,OAAO,CAAC,EAAE,UAAU,EAAE,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAChE,CAAC;IAEO,eAAe,CAAC,CAAM;QAC5B,IAAI,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC,CAAC;YAAE,OAAO,IAAI,CAAC;QAC3D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACpB,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACpC,CAAC;IAEO,SAAS,CAAC,KAAa;QAC7B,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;YAAE,OAAO,KAAK,IAAI,EAAE,CAAC;QACnD,OAAO,KAAK,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC3E,CAAC;IAEO,gBAAgB,CAAC,GAAW,EAAE,MAAuB;QAC3D,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,MAAM,CAAC;QAC1C,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;QACnD,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;QAEjD,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,YAAY,CAAC,CAAC,CAAC;gBAClB,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;gBAC1B,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACjD,CAAC;YACD,KAAK,iBAAiB,CAAC,CAAC,CAAC;gBACvB,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;gBACzB,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAChD,CAAC;YACD,KAAK,uBAAuB,CAAC,CAAC,CAAC;gBAC7B,IAAI,CAAC,KAAK,CAAC;oBAAE,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACnD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/B,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAC1C,CAAC;YACD,KAAK,sBAAsB,CAAC,CAAC,CAAC;gBAC5B,IAAI,CAAC,KAAK,CAAC;oBAAE,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACnD,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YAClE,CAAC;YACD,KAAK,aAAa,CAAC,CAAC,CAAC;gBACnB,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACxC,CAAC;YACD;gBACE,OAAO,GAAG,CAAC;QACf,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,MAAuB,EAAE,MAAc;QAC9D,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,MAAM,CAAC;QAC1C,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,YAAY,CAAC;YAClB,KAAK,iBAAiB;gBACpB,OAAO,KAAK,GAAG,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC,CAAC;YACrC,KAAK,uBAAuB;gBAC1B,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACtD,KAAK,sBAAsB,CAAC;YAC5B,KAAK,aAAa;gBAChB,OAAO,KAAK,CAAC;YACf;gBACE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;wGArPU,gBAAgB;4FAAhB,gBAAgB,4YARhB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC;gBAC/C,KAAK,EAAE,IAAI;aACZ;SACF,0BCpCH,4zHAyFM,67GD9DM,cAAc,0uBAAE,kBAAkB,8BAAE,YAAY,uNAAE,mBAAmB;;4FAWpE,gBAAgB;kBAd5B,SAAS;+BACE,aAAa,cACX,IAAI,WACP,CAAC,cAAc,EAAE,kBAAkB,EAAE,YAAY,EAAE,mBAAmB,CAAC,aAGrE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,iBAAiB,CAAC;4BAC/C,KAAK,EAAE,IAAI;yBACZ;qBACF;uHAgCS,IAAI;sBAAb,MAAM","sourcesContent":["import {\r\n  Component,\r\n  forwardRef,\r\n  input,\r\n  Output,\r\n  EventEmitter,\r\n  effect,\r\n  DoCheck,\r\n  KeyValueDiffers,\r\n  KeyValueDiffer,\r\n} from '@angular/core';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\n\r\ntype BeforeInputInfo = {\r\n  type: string;\r\n  data: string | null;\r\n  start: number;\r\n  end: number;\r\n};\r\n\r\n@Component({\r\n  selector: 'lib-textbox',\r\n  standalone: true,\r\n  imports: [MatInputModule, MatFormFieldModule, CommonModule, ReactiveFormsModule],\r\n  templateUrl: './textbox.component.html',\r\n  styleUrls: ['./textbox.component.css'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => TextboxComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class TextboxComponent implements ControlValueAccessor, DoCheck {\r\n  constructor(\r\n    public masterService: MasterControlService,\r\n    private kvDiffers: KeyValueDiffers\r\n  ) {\r\n    effect(() => {\r\n      const f = this.field();\r\n      if (!f) return;\r\n\r\n      if (f.isInputMasked == null) f.isInputMasked = false;\r\n\r\n      this.syncUIFromRaw();\r\n    });\r\n  }\r\n\r\n  field: any = input.required<any>();\r\n  reactiveFormControlobject: any = input<any>();\r\n\r\n  private _onChange: (val: any) => void = () => {};\r\n  private _onTouched: () => void = () => {};\r\n\r\n  inputValueDeepCopy: string = ''; \r\n  inputValue: string = '';        \r\n  private lastBeforeInput: BeforeInputInfo | null = null;\r\n\r\n  private fieldDiffer?: KeyValueDiffer<string, any>;\r\n  private cfgDiffer?: KeyValueDiffer<string, any>;\r\n  private styleDiffer?: KeyValueDiffer<string, any>;\r\n  private validatorsDiffer?: KeyValueDiffer<string, any>;\r\n\r\n  @Output() blur = new EventEmitter<any>();\r\n\r\n  ngDoCheck(): void {\r\n    const f = this.field?.();\r\n    if (!f) return;\r\n\r\n    if (!this.fieldDiffer) this.fieldDiffer = this.kvDiffers.find(f).create();\r\n    let changed = !!this.fieldDiffer.diff(f);\r\n\r\n    if (f.configData) {\r\n      if (!this.cfgDiffer) this.cfgDiffer = this.kvDiffers.find(f.configData).create();\r\n      if (this.cfgDiffer.diff(f.configData)) changed = true;\r\n    }\r\n\r\n    if (f.controlStyle) {\r\n      if (!this.styleDiffer) this.styleDiffer = this.kvDiffers.find(f.controlStyle).create();\r\n      if (this.styleDiffer.diff(f.controlStyle)) changed = true;\r\n    }\r\n\r\n    if (f.validators) {\r\n      if (!this.validatorsDiffer) this.validatorsDiffer = this.kvDiffers.find(f.validators).create();\r\n      if (this.validatorsDiffer.diff(f.validators)) changed = true;\r\n    }\r\n\r\n    if (changed) {\r\n      this.onFieldConfigChanged();\r\n    }\r\n  }\r\n\r\n  private onFieldConfigChanged(): void {\r\n    const oldRaw = this.inputValueDeepCopy ?? '';\r\n    const newRaw = this.applyCapitalization(oldRaw);\r\n\r\n    if (newRaw !== oldRaw) {\r\n      this.inputValueDeepCopy = newRaw;\r\n\r\n      const maskEnabled = !!this.field?.().isInputMasked;\r\n      const hasReactive = !!this.reactiveFormControlobject?.();\r\n      if (hasReactive && !maskEnabled) {\r\n        try {\r\n          this.reactiveFormControlobject().setValue(newRaw, { emitEvent: true });\r\n        } catch {\r\n          this._onChange(newRaw);\r\n        }\r\n      } else {\r\n        this._onChange(newRaw);\r\n      }\r\n    }\r\n    this.syncUIFromRaw();\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    const raw = !this.masterService.checkIfValueIsEmpty(obj) ? String(obj) : '';\r\n    const capitalized = this.applyCapitalization(raw);\r\n    this.inputValueDeepCopy = capitalized;\r\n    this.syncUIFromRaw();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this._onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouched = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    const f = this.field?.();\r\n    if (f) f.isDisable = !!isDisabled;\r\n  }\r\n\r\n\r\n  onBeforeInput(event: InputEvent): void {\r\n    const target = event.target as HTMLInputElement | null;\r\n    const start = target?.selectionStart ?? 0;\r\n    const end = target?.selectionEnd ?? start;\r\n    this.lastBeforeInput = {\r\n      type: event.inputType,\r\n      data: event.data,\r\n      start,\r\n      end,\r\n    };\r\n  }\r\n\r\n  onInputChange(event: Event): void {\r\n    const target = event.target as HTMLInputElement;\r\n    const f = this.field?.();\r\n    const cfg = f?.configData;\r\n\r\n    const intent = this.lastBeforeInput ?? {\r\n      type: 'insertText',\r\n      data: null,\r\n      start: target.selectionStart ?? this.inputValueDeepCopy.length,\r\n      end: target.selectionEnd ?? target.selectionStart ?? this.inputValueDeepCopy.length,\r\n    };\r\n\r\n    let newVal = this.applyIntentToRaw(this.inputValueDeepCopy, intent);\r\n\r\n    newVal = this.applyCapitalization(newVal);\r\n\r\n    if (cfg?.inputType === 'number') {\r\n      const min = this.normalizeNumber(cfg?.minValue);\r\n      const max = this.normalizeNumber(cfg?.maxValue);\r\n      const num = Number(newVal);\r\n      if (!Number.isNaN(num)) {\r\n        if (min !== null && num < min) newVal = String(min);\r\n        if (max !== null && num > max) newVal = String(max);\r\n      }\r\n    }\r\n\r\n    this.inputValueDeepCopy = newVal;\r\n\r\n    const maskEnabled = !!f?.isInputMasked;\r\n    const hasReactive = !!this.reactiveFormControlobject?.();\r\n\r\n    if (hasReactive && !maskEnabled) {\r\n      try {\r\n        this.reactiveFormControlobject().setValue(newVal, { emitEvent: true });\r\n      } catch {\r\n        this._onChange(newVal);\r\n      }\r\n    } else {\r\n      this._onChange(newVal);\r\n    }\r\n\r\n    const display = maskEnabled ? this.maskInput(newVal) : newVal;\r\n    this.inputValue = display;\r\n\r\n    const nextCaret = this.computeNextCaret(intent, newVal.length);\r\n    if (target.value !== display) {\r\n      target.value = display;\r\n      try { target.setSelectionRange(nextCaret, nextCaret); } catch {\r\n        console.log(this.inputValue);\r\n      }\r\n    }\r\n\r\n    this.lastBeforeInput = null;\r\n  }\r\n\r\n  onInputBlur(event?: Event): void {\r\n    this._onTouched();\r\n    this.blur.emit(event);\r\n  }\r\n\r\n  onInputFocus(): void {\r\n  }\r\n\r\n  private syncUIFromRaw(): void {\r\n    const f = this.field?.();\r\n    const maskEnabled = !!f?.isInputMasked;\r\n    const raw = this.inputValueDeepCopy ?? '';\r\n    this.inputValue = maskEnabled ? this.maskInput(raw) : raw;\r\n  }\r\n\r\n  private applyCapitalization(v: string): string {\r\n    const f = this.field?.();\r\n    return f?.configData?.isTextCapitalized ? v.toUpperCase() : v;\r\n  }\r\n\r\n  private normalizeNumber(v: any): number | null {\r\n    if (this.masterService.checkIfValueIsEmpty(v)) return null;\r\n    const n = Number(v);\r\n    return Number.isNaN(n) ? null : n;\r\n  }\r\n\r\n  private maskInput(value: string): string {\r\n    if (!value || value.length < 3) return value || '';\r\n    return value[0] + 'X'.repeat(value.length - 2) + value[value.length - 1];\r\n  }\r\n\r\n  private applyIntentToRaw(raw: string, intent: BeforeInputInfo): string {\r\n    const { type, data, start, end } = intent;\r\n    const s = Math.max(0, Math.min(start, raw.length));\r\n    const e = Math.max(s, Math.min(end, raw.length));\r\n\r\n    switch (type) {\r\n      case 'insertText': {\r\n        const insert = data ?? '';\r\n        return raw.slice(0, s) + insert + raw.slice(e);\r\n      }\r\n      case 'insertFromPaste': {\r\n        const paste = data ?? '';\r\n        return raw.slice(0, s) + paste + raw.slice(e);\r\n      }\r\n      case 'deleteContentBackward': {\r\n        if (s !== e) return raw.slice(0, s) + raw.slice(e);\r\n        const idx = Math.max(0, s - 1);\r\n        return raw.slice(0, idx) + raw.slice(e);\r\n      }\r\n      case 'deleteContentForward': {\r\n        if (s !== e) return raw.slice(0, s) + raw.slice(e);\r\n        return raw.slice(0, s) + raw.slice(Math.min(e + 1, raw.length));\r\n      }\r\n      case 'deleteByCut': {\r\n        return raw.slice(0, s) + raw.slice(e);\r\n      }\r\n      default:\r\n        return raw;\r\n    }\r\n  }\r\n\r\n  private computeNextCaret(intent: BeforeInputInfo, newLen: number): number {\r\n    const { type, data, start, end } = intent;\r\n    switch (type) {\r\n      case 'insertText':\r\n      case 'insertFromPaste':\r\n        return start + (data?.length ?? 0);\r\n      case 'deleteContentBackward':\r\n        return Math.max(0, start - (start === end ? 1 : 0));\r\n      case 'deleteContentForward':\r\n      case 'deleteByCut':\r\n        return start;\r\n      default:\r\n        return Math.max(0, Math.min(start, newLen));\r\n    }\r\n  }\r\n}","<label\r\n  class=\"field-lable\"\r\n  *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n>\r\n  {{ field()?.label }}\r\n  <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</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    '--custom-width': field()?.controlStyle?.width\r\n  }\"\r\n>\r\n\r\n  @if (reactiveFormControlobject() && !field()?.isInputMasked) {\r\n    <input\r\n      matInput\r\n      autocomplete=\"off\"\r\n       [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n      [name]=\"field()?.fieldName\"\r\n      [id]=\"field()?.fieldName\"\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      (beforeinput)=\"onBeforeInput($event)\"\r\n      (input)=\"onInputChange($event)\"\r\n      (blur)=\"onInputBlur($event)\"\r\n      (focus)=\"onInputFocus()\"\r\n      [formControl]=\"reactiveFormControlobject()\"\r\n    />\r\n  } @else {\r\n\r\n    <input\r\n      matInput\r\n      autocomplete=\"off\"\r\n     [type]=\"field()?.configData?.inputType ? field()?.configData?.inputType : field()?.controlType\"\r\n      [name]=\"field()?.fieldName\"\r\n      [id]=\"field()?.fieldName\"\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      (beforeinput)=\"onBeforeInput($event)\"\r\n      (input)=\"onInputChange($event)\"\r\n      (blur)=\"onInputBlur($event)\"\r\n      (focus)=\"onInputFocus()\"\r\n      [value]=\"inputValue\"\r\n    />\r\n  }\r\n\r\n  <mat-hint *ngIf=\"field()?.configData?.helperText\">{{ field()?.configData?.helperText }}</mat-hint>\r\n\r\n  <mat-error *ngIf=\"false\">\r\n    {{ field()?.validators?.requiredMessage || 'This field cannot be empty' }}\r\n  </mat-error>\r\n\r\n</mat-form-field>\r\n\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field()?.validators?.requiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field()?.validators?.patternMessage }}.\r\n</div>"]}
@@ -0,0 +1,34 @@
1
+ import { Component, input } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ export class TopHeaderComponent {
6
+ field = input.required();
7
+ showProfileMenu = false;
8
+ configData = {
9
+ options: [
10
+ { label: "",
11
+ value: ""
12
+ }
13
+ ],
14
+ configData: {
15
+ logoUrl: "",
16
+ notificationBellVisible: "",
17
+ notificationCount: "",
18
+ notificationImageUrl: "",
19
+ UserProfileVisible: "",
20
+ imageUrl: "",
21
+ userProfileText: "",
22
+ }
23
+ };
24
+ ngOnInit() {
25
+ this.configData = this.field();
26
+ }
27
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TopHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
28
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: TopHeaderComponent, isStandalone: true, selector: "lib-top-header", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<header class=\"sticky-top bg-white shadow-sm\">\r\n <div class=\"container-fluid mx-auto p-0\">\r\n <div class=\"header row align-items-center\">\r\n <div class=\"col-11\">\r\n <a href=\"/\" class=\"d-flex align-items-center gap-3 fixMargin\">\r\n <img\r\n [src]=\"configData.configData.logoUrl\"\r\n class=\"logo\"\r\n height=\"32\"\r\n alt=\"Logo\"\r\n />\r\n </a>\r\n </div>\r\n <div class=\"col-1 d-flex justify-content-end align-items-center p-1 position-relative\">\r\n <div class=\"me-3 position-relative notification-icon\" role=\"button\" *ngIf=\"configData.configData.notificationBellVisible=='true'\">\r\n <img\r\n [src]=\"configData.configData.notificationImageUrl\"\r\n alt=\"Notifications\"\r\n width=\"28\"\r\n height=\"28\"\r\n />\r\n <span \r\n class=\"position-absolute top-0 start-100 translate-middle badge rounded-pill bg-danger\"\r\n >\r\n {{configData.configData.notificationCount}}\r\n </span>\r\n </div>\r\n <div\r\n (mouseenter)=\"showProfileMenu=true\"\r\n class=\"profile-icon d-flex align-items-center rounded-pill bg-light\"\r\n role=\"button\" *ngIf=\"configData.configData.UserProfileVisible=='true'\"\r\n >\r\n <img\r\n [src]=\"configData.configData.imageUrl\"\r\n alt=\"Profile\"\r\n class=\"rounded-circle me-2\"\r\n width=\"36\"\r\n height=\"36\"\r\n />\r\n <span class=\"fw-medium\">{{configData.configData.userProfileText}}</span>\r\n </div>\r\n <div\r\n *ngIf=\"showProfileMenu\"\r\n class=\"profile-menu position-absolute top-100 end-0 bg-white border border-warning rounded-3 shadow-sm mt-2\" (mouseenter)=\"showProfileMenu=true\" (mouseleave)=\"showProfileMenu=false\"\r\n >\r\n <div class=\"profile-menu-caret\"></div>\r\n \r\n <ul class=\"list-unstyled m-0 py-2\">\r\n <li class=\"px-3 py-2 text-nowrap\" *ngFor=\"let item of configData.options || []\">\r\n {{ item.label || 'No label' }}\r\n </li>\r\n </ul>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n </div>\r\n</header>", styles: [".header{background:#fff;box-shadow:0 2px 4px #00000014;height:59px;margin:0;padding:0 40px}.logo{width:64px;height:32px}.profile-menu-caret{position:absolute;top:-11px;right:16px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:11px solid #fa0;z-index:1}.profile-menu-caret:after{content:\"\";position:absolute;left:-9.8px;top:1.7px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:10px solid #fff;z-index:2}.my_templates{white-space:nowrap}ul li{cursor:pointer}.fixMargin{width:68px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
29
+ }
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TopHeaderComponent, decorators: [{
31
+ type: Component,
32
+ args: [{ selector: 'lib-top-header', standalone: true, imports: [CommonModule], template: "<header class=\"sticky-top bg-white shadow-sm\">\r\n <div class=\"container-fluid mx-auto p-0\">\r\n <div class=\"header row align-items-center\">\r\n <div class=\"col-11\">\r\n <a href=\"/\" class=\"d-flex align-items-center gap-3 fixMargin\">\r\n <img\r\n [src]=\"configData.configData.logoUrl\"\r\n class=\"logo\"\r\n height=\"32\"\r\n alt=\"Logo\"\r\n />\r\n </a>\r\n </div>\r\n <div class=\"col-1 d-flex justify-content-end align-items-center p-1 position-relative\">\r\n <div class=\"me-3 position-relative notification-icon\" role=\"button\" *ngIf=\"configData.configData.notificationBellVisible=='true'\">\r\n <img\r\n [src]=\"configData.configData.notificationImageUrl\"\r\n alt=\"Notifications\"\r\n width=\"28\"\r\n height=\"28\"\r\n />\r\n <span \r\n class=\"position-absolute top-0 start-100 translate-middle badge rounded-pill bg-danger\"\r\n >\r\n {{configData.configData.notificationCount}}\r\n </span>\r\n </div>\r\n <div\r\n (mouseenter)=\"showProfileMenu=true\"\r\n class=\"profile-icon d-flex align-items-center rounded-pill bg-light\"\r\n role=\"button\" *ngIf=\"configData.configData.UserProfileVisible=='true'\"\r\n >\r\n <img\r\n [src]=\"configData.configData.imageUrl\"\r\n alt=\"Profile\"\r\n class=\"rounded-circle me-2\"\r\n width=\"36\"\r\n height=\"36\"\r\n />\r\n <span class=\"fw-medium\">{{configData.configData.userProfileText}}</span>\r\n </div>\r\n <div\r\n *ngIf=\"showProfileMenu\"\r\n class=\"profile-menu position-absolute top-100 end-0 bg-white border border-warning rounded-3 shadow-sm mt-2\" (mouseenter)=\"showProfileMenu=true\" (mouseleave)=\"showProfileMenu=false\"\r\n >\r\n <div class=\"profile-menu-caret\"></div>\r\n \r\n <ul class=\"list-unstyled m-0 py-2\">\r\n <li class=\"px-3 py-2 text-nowrap\" *ngFor=\"let item of configData.options || []\">\r\n {{ item.label || 'No label' }}\r\n </li>\r\n </ul>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n </div>\r\n</header>", styles: [".header{background:#fff;box-shadow:0 2px 4px #00000014;height:59px;margin:0;padding:0 40px}.logo{width:64px;height:32px}.profile-menu-caret{position:absolute;top:-11px;right:16px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:11px solid #fa0;z-index:1}.profile-menu-caret:after{content:\"\";position:absolute;left:-9.8px;top:1.7px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:10px solid #fff;z-index:2}.my_templates{white-space:nowrap}ul li{cursor:pointer}.fixMargin{width:68px}\n"] }]
33
+ }] });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9wLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL3RvcC1oZWFkZXIvdG9wLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL3RvcC1oZWFkZXIvdG9wLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUE0QixLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFTL0MsTUFBTSxPQUFPLGtCQUFrQjtJQUMvQixLQUFLLEdBQVMsS0FBSyxDQUFDLFFBQVEsRUFBTyxDQUFDO0lBRXBDLGVBQWUsR0FBRyxLQUFLLENBQUM7SUFDeEIsVUFBVSxHQUFDO1FBQ1QsT0FBTyxFQUFDO1lBQ04sRUFBQyxLQUFLLEVBQUMsRUFBRTtnQkFDUCxLQUFLLEVBQUMsRUFBRTthQUNUO1NBQ0Y7UUFDSCxVQUFVLEVBQUM7WUFDVCxPQUFPLEVBQUUsRUFBRTtZQUNYLHVCQUF1QixFQUFDLEVBQUU7WUFDMUIsaUJBQWlCLEVBQUMsRUFBRTtZQUNwQixvQkFBb0IsRUFBQyxFQUFFO1lBQ3ZCLGtCQUFrQixFQUFDLEVBQUU7WUFDckIsUUFBUSxFQUFDLEVBQUU7WUFDWixlQUFlLEVBQUMsRUFBRTtTQUNsQjtLQUFDLENBQUM7SUFFSCxRQUFRO1FBRU4sSUFBSSxDQUFDLFVBQVUsR0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDL0IsQ0FBQzt3R0F2Qlksa0JBQWtCOzRGQUFsQixrQkFBa0IsNk1DVi9CLHV3RUF5RFMseW9CRGpERyxZQUFZOzs0RkFFWCxrQkFBa0I7a0JBUDlCLFNBQVM7K0JBQ0UsZ0JBQWdCLGNBQ2QsSUFBSSxXQUdQLENBQUMsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBIb3N0TGlzdGVuZXIsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi10b3AtaGVhZGVyJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi90b3AtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vdG9wLWhlYWRlci5jb21wb25lbnQuY3NzJyxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVG9wSGVhZGVyQ29tcG9uZW50IHtcclxuZmllbGQgOiBhbnkgPSBpbnB1dC5yZXF1aXJlZDxhbnk+KCk7XHJcblxyXG5zaG93UHJvZmlsZU1lbnUgPSBmYWxzZTtcclxuY29uZmlnRGF0YT17XHJcbiAgb3B0aW9uczpbXHJcbiAgICB7bGFiZWw6XCJcIixcclxuICAgICAgdmFsdWU6XCJcIlxyXG4gICAgfVxyXG4gIF0sXHJcbmNvbmZpZ0RhdGE6e1xyXG4gIGxvZ29Vcmw6IFwiXCIsXHJcbiAgbm90aWZpY2F0aW9uQmVsbFZpc2libGU6XCJcIixcclxuICBub3RpZmljYXRpb25Db3VudDpcIlwiLFxyXG4gIG5vdGlmaWNhdGlvbkltYWdlVXJsOlwiXCIsXHJcbiAgVXNlclByb2ZpbGVWaXNpYmxlOlwiXCIsXHJcbiAgaW1hZ2VVcmw6XCJcIixcclxuIHVzZXJQcm9maWxlVGV4dDpcIlwiLFxyXG59fTtcclxuXHJcbm5nT25Jbml0KClcclxue1xyXG4gIHRoaXMuY29uZmlnRGF0YT10aGlzLmZpZWxkKCk7XHJcbn1cclxufVxyXG4iLCI8aGVhZGVyIGNsYXNzPVwic3RpY2t5LXRvcCBiZy13aGl0ZSBzaGFkb3ctc21cIj5cclxuICA8ZGl2IGNsYXNzPVwiY29udGFpbmVyLWZsdWlkIG14LWF1dG8gcC0wXCI+XHJcbiAgPGRpdiBjbGFzcz1cImhlYWRlciByb3cgYWxpZ24taXRlbXMtY2VudGVyXCI+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTFcIj5cclxuICAgICAgICA8YSBocmVmPVwiL1wiIGNsYXNzPVwiZC1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlciBnYXAtMyBmaXhNYXJnaW5cIj5cclxuICAgICAgICAgIDxpbWdcclxuICAgICAgICAgICAgW3NyY109XCJjb25maWdEYXRhLmNvbmZpZ0RhdGEubG9nb1VybFwiXHJcbiAgICAgICAgICAgIGNsYXNzPVwibG9nb1wiXHJcbiAgICAgICAgICAgIGhlaWdodD1cIjMyXCJcclxuICAgICAgICAgICAgYWx0PVwiTG9nb1wiXHJcbiAgICAgICAgICAvPlxyXG4gICAgICAgIDwvYT5cclxuICAgICAgPC9kaXY+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMSBkLWZsZXgganVzdGlmeS1jb250ZW50LWVuZCBhbGlnbi1pdGVtcy1jZW50ZXIgcC0xIHBvc2l0aW9uLXJlbGF0aXZlXCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cIm1lLTMgcG9zaXRpb24tcmVsYXRpdmUgbm90aWZpY2F0aW9uLWljb25cIiByb2xlPVwiYnV0dG9uXCIgKm5nSWY9XCJjb25maWdEYXRhLmNvbmZpZ0RhdGEubm90aWZpY2F0aW9uQmVsbFZpc2libGU9PSd0cnVlJ1wiPlxyXG4gICAgPGltZ1xyXG4gICAgICBbc3JjXT1cImNvbmZpZ0RhdGEuY29uZmlnRGF0YS5ub3RpZmljYXRpb25JbWFnZVVybFwiXHJcbiAgICAgIGFsdD1cIk5vdGlmaWNhdGlvbnNcIlxyXG4gICAgICB3aWR0aD1cIjI4XCJcclxuICAgICAgaGVpZ2h0PVwiMjhcIlxyXG4gICAgLz5cclxuICAgIDxzcGFuIFxyXG4gICAgICBjbGFzcz1cInBvc2l0aW9uLWFic29sdXRlIHRvcC0wIHN0YXJ0LTEwMCB0cmFuc2xhdGUtbWlkZGxlIGJhZGdlIHJvdW5kZWQtcGlsbCBiZy1kYW5nZXJcIlxyXG4gICAgPlxyXG4gICAgIHt7Y29uZmlnRGF0YS5jb25maWdEYXRhLm5vdGlmaWNhdGlvbkNvdW50fX1cclxuICAgIDwvc3Bhbj5cclxuICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXZcclxuICAgICAgICAgICAobW91c2VlbnRlcik9XCJzaG93UHJvZmlsZU1lbnU9dHJ1ZVwiXHJcbiAgICAgICAgICBjbGFzcz1cInByb2ZpbGUtaWNvbiBkLWZsZXggYWxpZ24taXRlbXMtY2VudGVyIHJvdW5kZWQtcGlsbCBiZy1saWdodFwiXHJcbiAgICAgICAgICByb2xlPVwiYnV0dG9uXCIgKm5nSWY9XCJjb25maWdEYXRhLmNvbmZpZ0RhdGEuVXNlclByb2ZpbGVWaXNpYmxlPT0ndHJ1ZSdcIlxyXG4gICAgICAgID5cclxuICAgICAgICAgIDxpbWdcclxuICAgICAgICAgICAgW3NyY109XCJjb25maWdEYXRhLmNvbmZpZ0RhdGEuaW1hZ2VVcmxcIlxyXG4gICAgICAgICAgICBhbHQ9XCJQcm9maWxlXCJcclxuICAgICAgICAgICAgY2xhc3M9XCJyb3VuZGVkLWNpcmNsZSBtZS0yXCJcclxuICAgICAgICAgICAgd2lkdGg9XCIzNlwiXHJcbiAgICAgICAgICAgIGhlaWdodD1cIjM2XCJcclxuICAgICAgICAgIC8+XHJcbiAgICAgICAgICA8c3BhbiBjbGFzcz1cImZ3LW1lZGl1bVwiPnt7Y29uZmlnRGF0YS5jb25maWdEYXRhLnVzZXJQcm9maWxlVGV4dH19PC9zcGFuPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXZcclxuICAgICAgICAgICpuZ0lmPVwic2hvd1Byb2ZpbGVNZW51XCJcclxuICAgICAgICAgIGNsYXNzPVwicHJvZmlsZS1tZW51IHBvc2l0aW9uLWFic29sdXRlIHRvcC0xMDAgZW5kLTAgYmctd2hpdGUgYm9yZGVyIGJvcmRlci13YXJuaW5nIHJvdW5kZWQtMyBzaGFkb3ctc20gbXQtMlwiICAobW91c2VlbnRlcik9XCJzaG93UHJvZmlsZU1lbnU9dHJ1ZVwiICAobW91c2VsZWF2ZSk9XCJzaG93UHJvZmlsZU1lbnU9ZmFsc2VcIlxyXG4gICAgICAgID5cclxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJwcm9maWxlLW1lbnUtY2FyZXRcIj48L2Rpdj5cclxuICAgICAgICAgIFxyXG4gICAgICAgPHVsIGNsYXNzPVwibGlzdC11bnN0eWxlZCBtLTAgcHktMlwiPlxyXG4gICAgICAgICAgPGxpIGNsYXNzPVwicHgtMyBweS0yIHRleHQtbm93cmFwXCIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgY29uZmlnRGF0YS5vcHRpb25zIHx8IFtdXCI+XHJcbiAgICAgICAgICB7eyBpdGVtLmxhYmVsIHx8ICdObyBsYWJlbCcgfX1cclxuICAgICAgICAgIDwvbGk+XHJcbiAgICAgICA8L3VsPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgXHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbjwvaGVhZGVyPiJdfQ==