lib-portal-angular 0.0.78 → 0.0.79

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,5 +1,6 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
2
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, } from "@angular/core";
2
+ import { NG_VALUE_ACCESSOR } from "@angular/forms";
3
+ import { ButtonClasses } from "../../enum/ButtonClassesEnum";
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "../../service/auth-service.service";
5
6
  import * as i2 from "@angular/common";
@@ -10,10 +11,10 @@ import * as i6 from "../../directive/cpf-mask.directive";
10
11
  export class InputComponent {
11
12
  constructor(authService) {
12
13
  this.authService = authService;
13
- this.label = 'Default Label';
14
- this.placeholder = '';
15
- this.id = 'inputId';
16
- this.type = 'text';
14
+ this.label = "Default Label";
15
+ this.placeholder = "";
16
+ this.id = "inputId";
17
+ this.type = "text";
17
18
  this.disabled = false;
18
19
  this.readonly = false;
19
20
  this.maxlength = null;
@@ -28,8 +29,10 @@ export class InputComponent {
28
29
  this.validateInput = false;
29
30
  this.labelFontWeight = 400;
30
31
  this.useMoneyMask = false; // Para ativar/desativar a máscara de moeda
31
- this.currencyCode = 'BRL'; // Código da moeda
32
+ this.currencyCode = "BRL"; // Código da moeda
32
33
  this.displayCurrencySymbol = true; // Exibir ou não o símbolo da moeda
34
+ this.prependText = "";
35
+ this.buttonText = null;
33
36
  this.inputEvent = new EventEmitter();
34
37
  this.changeEvent = new EventEmitter();
35
38
  this.focusEvent = new EventEmitter();
@@ -37,39 +40,51 @@ export class InputComponent {
37
40
  this.keyupEvent = new EventEmitter();
38
41
  this.keydownEvent = new EventEmitter();
39
42
  this.keypressEvent = new EventEmitter();
43
+ this.buttonClick = new EventEmitter();
40
44
  this.onChangeCallback = () => { };
41
45
  this.onTouchedCallback = () => { };
42
- this.value = '';
46
+ this.ButtonClasses = ButtonClasses;
47
+ this.value = "";
43
48
  this.showErrorModal = false;
44
- this.errorMessage = '';
49
+ this.errorMessage = "";
45
50
  this.subscriptions = [];
46
51
  }
47
52
  getInputType() {
48
- return this.onlyNumbers ? 'tel' : this.type;
53
+ return this.onlyNumbers ? "tel" : this.type;
49
54
  }
50
55
  onInput(event) {
51
56
  const inputElement = event.target;
52
57
  let inputValue = inputElement.value;
53
58
  // Aplica máscara de números se necessário
54
- if (this.onlyNumbers && !(this.useCpfMask || this.useCnpjMask || this.useCepMask || this.useMoneyMask)) {
55
- inputValue = inputValue.replace(/\D/g, ''); // Remove todos os não numéricos
59
+ if (this.onlyNumbers &&
60
+ !(this.useCpfMask ||
61
+ this.useCnpjMask ||
62
+ this.useCepMask ||
63
+ this.useMoneyMask)) {
64
+ inputValue = inputValue.replace(/\D/g, ""); // Remove todos os não numéricos
56
65
  }
57
66
  // Validação imediata para CPF, CNPJ ou CEP
58
- const numericValue = inputValue.replace(/\D/g, ''); // Remove todos os caracteres não numéricos
67
+ const numericValue = inputValue.replace(/\D/g, ""); // Remove todos os caracteres não numéricos
59
68
  if (this.validateInput) {
60
- if (this.useCpfMask && numericValue.length === 11 && !this.validateCpf(numericValue)) {
61
- this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');
69
+ if (this.useCpfMask &&
70
+ numericValue.length === 11 &&
71
+ !this.validateCpf(numericValue)) {
72
+ this.clearAndShowValidationError("CPF inválido. Por favor, insira um CPF correto.");
62
73
  }
63
- else if (this.useCnpjMask && numericValue.length === 14 && !this.validateCnpj(numericValue)) {
64
- this.clearAndShowValidationError('CNPJ inválido. Por favor, insira um CNPJ correto.');
74
+ else if (this.useCnpjMask &&
75
+ numericValue.length === 14 &&
76
+ !this.validateCnpj(numericValue)) {
77
+ this.clearAndShowValidationError("CNPJ inválido. Por favor, insira um CNPJ correto.");
65
78
  }
66
- else if (this.useCepMask && numericValue.length === 8 && !this.validateCep(numericValue)) {
67
- this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');
79
+ else if (this.useCepMask &&
80
+ numericValue.length === 8 &&
81
+ !this.validateCep(numericValue)) {
82
+ this.clearAndShowValidationError("CEP inválido. Por favor, insira um CEP correto.");
68
83
  }
69
84
  }
70
85
  // Máscara de moeda
71
86
  if (this.useMoneyMask) {
72
- const numericValue = inputValue.replace(/\D/g, ''); // Remove todos os não numéricos
87
+ const numericValue = inputValue.replace(/\D/g, ""); // Remove todos os não numéricos
73
88
  const formattedValue = this.formatMoney(numericValue); // Formata como dinheiro ou número decimal
74
89
  inputElement.value = formattedValue;
75
90
  this.value = formattedValue;
@@ -83,42 +98,46 @@ export class InputComponent {
83
98
  }
84
99
  formatMoney(value) {
85
100
  if (!value)
86
- return ''; // Se o valor estiver vazio, retorna uma string vazia
101
+ return ""; // Se o valor estiver vazio, retorna uma string vazia
87
102
  const numericValue = parseFloat(value) / 100;
88
103
  // Verifica se deve exibir o símbolo da moeda ou não
89
104
  if (this.displayCurrencySymbol) {
90
105
  // Formata como moeda
91
- return new Intl.NumberFormat('pt-BR', {
92
- style: 'currency',
93
- currency: this.currencyCode
106
+ return new Intl.NumberFormat("pt-BR", {
107
+ style: "currency",
108
+ currency: this.currencyCode,
94
109
  }).format(numericValue);
95
110
  }
96
111
  else {
97
112
  // Formata como número decimal, sem o símbolo da moeda
98
- return new Intl.NumberFormat('pt-BR', {
99
- style: 'decimal',
113
+ return new Intl.NumberFormat("pt-BR", {
114
+ style: "decimal",
100
115
  minimumFractionDigits: 2,
101
- maximumFractionDigits: 2
116
+ maximumFractionDigits: 2,
102
117
  }).format(numericValue);
103
118
  }
104
119
  }
105
120
  onKeyDown(event) {
106
- if (this.onlyNumbers && !/^\d$/.test(event.key) && event.key !== 'Backspace' && event.key !== 'ArrowLeft' && event.key !== 'ArrowRight') {
121
+ if (this.onlyNumbers &&
122
+ !/^\d$/.test(event.key) &&
123
+ event.key !== "Backspace" &&
124
+ event.key !== "ArrowLeft" &&
125
+ event.key !== "ArrowRight") {
107
126
  event.preventDefault();
108
127
  }
109
128
  }
110
129
  onChange(event) {
111
- const numericValue = this.value.replace(/\D/g, ''); // Remove todos os caracteres não numéricos
130
+ const numericValue = this.value.replace(/\D/g, ""); // Remove todos os caracteres não numéricos
112
131
  // Validação também ocorre no blur para casos onde o input não está completo
113
132
  if (this.validateInput) {
114
133
  if (this.useCpfMask && !this.validateCpf(numericValue)) {
115
- this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');
134
+ this.clearAndShowValidationError("CPF inválido. Por favor, insira um CPF correto.");
116
135
  }
117
136
  else if (this.useCnpjMask && !this.validateCnpj(numericValue)) {
118
- this.clearAndShowValidationError('CNPJ inválido. Por favor, insira um CNPJ correto.');
137
+ this.clearAndShowValidationError("CNPJ inválido. Por favor, insira um CNPJ correto.");
119
138
  }
120
139
  else if (this.useCepMask && !this.validateCep(numericValue)) {
121
- this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');
140
+ this.clearAndShowValidationError("CEP inválido. Por favor, insira um CEP correto.");
122
141
  }
123
142
  }
124
143
  this.changeEvent.emit(event);
@@ -154,7 +173,7 @@ export class InputComponent {
154
173
  if (pos < 2)
155
174
  pos = 9;
156
175
  }
157
- let result = sum % 11 < 2 ? 0 : 11 - sum % 11;
176
+ let result = sum % 11 < 2 ? 0 : 11 - (sum % 11);
158
177
  if (result !== parseInt(digits.charAt(0)))
159
178
  return false;
160
179
  length = length + 1;
@@ -166,21 +185,21 @@ export class InputComponent {
166
185
  if (pos < 2)
167
186
  pos = 9;
168
187
  }
169
- result = sum % 11 < 2 ? 0 : 11 - sum % 11;
188
+ result = sum % 11 < 2 ? 0 : 11 - (sum % 11);
170
189
  return result === parseInt(digits.charAt(1));
171
190
  }
172
191
  validateCep(cep) {
173
192
  return /^\d{8}$/.test(cep); // Valida apenas números, sem considerar a máscara
174
193
  }
175
194
  clearAndShowValidationError(message) {
176
- this.value = ''; // Limpa o valor do ngModel
195
+ this.value = ""; // Limpa o valor do ngModel
177
196
  this.onChangeCallback(this.value); // Atualiza o ngModel com o valor limpo
178
197
  this.errorMessage = message;
179
198
  this.showErrorModal = true;
180
199
  }
181
200
  closeModal() {
182
201
  this.showErrorModal = false;
183
- this.errorMessage = '';
202
+ this.errorMessage = "";
184
203
  }
185
204
  onFocus(event) {
186
205
  this.focusEvent.emit(event);
@@ -210,35 +229,38 @@ export class InputComponent {
210
229
  }
211
230
  catch (error) {
212
231
  if (error instanceof Error) {
213
- console.error('Permission error:', error.message);
232
+ console.error("Permission error:", error.message);
214
233
  }
215
234
  else {
216
- console.error('Unknown error occurred during permission check');
235
+ console.error("Unknown error occurred during permission check");
217
236
  }
218
237
  return true;
219
238
  }
220
239
  }
240
+ onButtonClick() {
241
+ this.buttonClick.emit();
242
+ }
221
243
  ngOnDestroy() {
222
- this.subscriptions.forEach(sub => sub.unsubscribe());
244
+ this.subscriptions.forEach((sub) => sub.unsubscribe());
223
245
  }
224
246
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
225
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: InputComponent, selector: "argenta-custom-input", inputs: { label: "label", placeholder: "placeholder", id: "id", type: "type", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", autofocus: "autofocus", useCpfMask: "useCpfMask", useCnpjMask: "useCnpjMask", useCepMask: "useCepMask", onlyNumbers: "onlyNumbers", validateInput: "validateInput", labelFontWeight: "labelFontWeight", permissions: "permissions", useMoneyMask: "useMoneyMask", currencyCode: "currencyCode", displayCurrencySymbol: "displayCurrencySymbol" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
247
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: InputComponent, selector: "argenta-custom-input", inputs: { label: "label", placeholder: "placeholder", id: "id", type: "type", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", autofocus: "autofocus", useCpfMask: "useCpfMask", useCnpjMask: "useCnpjMask", useCepMask: "useCepMask", onlyNumbers: "onlyNumbers", validateInput: "validateInput", labelFontWeight: "labelFontWeight", permissions: "permissions", useMoneyMask: "useMoneyMask", currencyCode: "currencyCode", displayCurrencySymbol: "displayCurrencySymbol", prependText: "prependText", buttonText: "buttonText" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent", buttonClick: "buttonClick" }, providers: [
226
248
  {
227
249
  provide: NG_VALUE_ACCESSOR,
228
250
  useExisting: forwardRef(() => InputComponent),
229
- multi: true
230
- }
231
- ], ngImport: i0, template: "<div *ngIf=\"hasPermission()\" class=\"form-group\">\n <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n <input [type]=\"getInputType()\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"keyupEvent.emit($event)\"\n (keydown)=\"onKeyDown($event)\"\n (keypress)=\"keypressEvent.emit($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\"\n [cpfMask]=\"useCpfMask\" \n [cnpjMask]=\"useCnpjMask\" \n [cepMask]=\"useCepMask\">\n\n <!-- Modal para exibir mensagens de erro -->\n <div class=\"modal-overlay\" *ngIf=\"showErrorModal\">\n <div class=\"modal-content\">\n <span class=\"close\" (click)=\"closeModal()\">&times;</span>\n <p>{{ errorMessage }}</p>\n <button class=\"btn-ok\" (click)=\"closeModal()\">OK</button>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.form-group{font-family:var(--font-family);font-size:1rem;font-weight:700}.form-check-input{font-family:var(--font-family);color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:var(--font-family);color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:var(--font-family);color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:25px 30px;border-radius:8px;width:360px;text-align:center;position:relative;box-shadow:0 4px 12px #0003}.close{position:absolute;top:10px;right:15px;cursor:pointer;font-size:20px;color:#555;transition:color .3s}.close:hover{color:#f44336}.btn-ok{margin-top:20px;padding:8px 20px;border:none;background-color:#00444c;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s,transform .2s}.btn-ok:hover{background-color:#00363d;transform:scale(1.05)}.btn-ok:active{transform:scale(.98)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.CepMaskDirective, selector: "[cepMask]", inputs: ["cepMask"] }, { kind: "directive", type: i5.CnpjMaskDirective, selector: "[cnpjMask]", inputs: ["cnpjMask"] }, { kind: "directive", type: i6.CpfMaskDirective, selector: "[cpfMask]", inputs: ["cpfMask"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
251
+ multi: true,
252
+ },
253
+ ], ngImport: i0, template: "<div *ngIf=\"hasPermission()\" class=\"form-group\">\n <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n <div class=\"input-group\">\n <div *ngIf=\"prependText\" class=\"input-group-prepend\">\n <span\n class=\"input-group-text custom-input-group-text\"\n id=\"basic-addon3\"\n >{{ prependText }}</span\n >\n </div>\n <input\n [type]=\"getInputType()\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"keyupEvent.emit($event)\"\n (keydown)=\"onKeyDown($event)\"\n (keypress)=\"keypressEvent.emit($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\"\n [cpfMask]=\"useCpfMask\"\n [cnpjMask]=\"useCnpjMask\"\n [cepMask]=\"useCepMask\"\n />\n\n <div class=\"input-group-append\" *ngIf=\"buttonText\">\n <button type=\"button\" class=\"btn-group-append\" (click)=\"onButtonClick()\">\n {{ buttonText }}\n </button>\n </div>\n\n <!-- Modal para exibir mensagens de erro -->\n <div class=\"modal-overlay\" *ngIf=\"showErrorModal\">\n <div class=\"modal-content\">\n <span class=\"close\" (click)=\"closeModal()\">&times;</span>\n <p>{{ errorMessage }}</p>\n <button class=\"btn-ok\" (click)=\"closeModal()\">OK</button>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.form-group{font-family:var(--font-family);font-size:1rem;font-weight:700}.form-check-input{font-family:var(--font-family);color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:var(--font-family);color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:var(--font-family);color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:25px 30px;border-radius:8px;width:360px;text-align:center;position:relative;box-shadow:0 4px 12px #0003}.close{position:absolute;top:10px;right:15px;cursor:pointer;font-size:20px;color:#555;transition:color .3s}.close:hover{color:#f44336}.btn-ok{margin-top:20px;padding:8px 20px;border:none;background-color:#00444c;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s,transform .2s}.btn-ok:hover{background-color:#00363d;transform:scale(1.05)}.btn-ok:active{transform:scale(.98)}.input-group-text{padding:.64rem .75rem;font-family:var(--font-family);color:#6e6e6e;font-size:14px}.btn-group-append{padding:.69rem;font-family:var(--font-family);background-color:var(--secondary-color);border:0rem solid;color:var(--text-color);transition:border-width .2s,transform .1s;font-size:1rem;border-top-right-radius:6px;border-bottom-right-radius:6px}.btn-group-append:hover{background-color:var(--primary-color)}.custom-input-group-text{border-top-right-radius:0;border-bottom-right-radius:0;padding:.71rem .75rem;background-color:#e7e7e7;border:1px solid #dbdbdb}.btn-group-append:active{animation:blink .3s}@keyframes blink{0%{background-color:var(--primary-color);border-color:var(--primary-color)}50%{background-color:var(--secondary-color);border-color:var(--secondary-color)}to{background-color:var(--primary-color);border-color:var(--primary-color)}}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.CepMaskDirective, selector: "[cepMask]", inputs: ["cepMask"] }, { kind: "directive", type: i5.CnpjMaskDirective, selector: "[cnpjMask]", inputs: ["cnpjMask"] }, { kind: "directive", type: i6.CpfMaskDirective, selector: "[cpfMask]", inputs: ["cpfMask"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
232
254
  }
233
255
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, decorators: [{
234
256
  type: Component,
235
- args: [{ selector: 'argenta-custom-input', providers: [
257
+ args: [{ selector: "argenta-custom-input", providers: [
236
258
  {
237
259
  provide: NG_VALUE_ACCESSOR,
238
260
  useExisting: forwardRef(() => InputComponent),
239
- multi: true
240
- }
241
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"hasPermission()\" class=\"form-group\">\n <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n <input [type]=\"getInputType()\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"keyupEvent.emit($event)\"\n (keydown)=\"onKeyDown($event)\"\n (keypress)=\"keypressEvent.emit($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\"\n [cpfMask]=\"useCpfMask\" \n [cnpjMask]=\"useCnpjMask\" \n [cepMask]=\"useCepMask\">\n\n <!-- Modal para exibir mensagens de erro -->\n <div class=\"modal-overlay\" *ngIf=\"showErrorModal\">\n <div class=\"modal-content\">\n <span class=\"close\" (click)=\"closeModal()\">&times;</span>\n <p>{{ errorMessage }}</p>\n <button class=\"btn-ok\" (click)=\"closeModal()\">OK</button>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.form-group{font-family:var(--font-family);font-size:1rem;font-weight:700}.form-check-input{font-family:var(--font-family);color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:var(--font-family);color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:var(--font-family);color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:25px 30px;border-radius:8px;width:360px;text-align:center;position:relative;box-shadow:0 4px 12px #0003}.close{position:absolute;top:10px;right:15px;cursor:pointer;font-size:20px;color:#555;transition:color .3s}.close:hover{color:#f44336}.btn-ok{margin-top:20px;padding:8px 20px;border:none;background-color:#00444c;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s,transform .2s}.btn-ok:hover{background-color:#00363d;transform:scale(1.05)}.btn-ok:active{transform:scale(.98)}\n"] }]
261
+ multi: true,
262
+ },
263
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"hasPermission()\" class=\"form-group\">\n <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n <div class=\"input-group\">\n <div *ngIf=\"prependText\" class=\"input-group-prepend\">\n <span\n class=\"input-group-text custom-input-group-text\"\n id=\"basic-addon3\"\n >{{ prependText }}</span\n >\n </div>\n <input\n [type]=\"getInputType()\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"keyupEvent.emit($event)\"\n (keydown)=\"onKeyDown($event)\"\n (keypress)=\"keypressEvent.emit($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\"\n [cpfMask]=\"useCpfMask\"\n [cnpjMask]=\"useCnpjMask\"\n [cepMask]=\"useCepMask\"\n />\n\n <div class=\"input-group-append\" *ngIf=\"buttonText\">\n <button type=\"button\" class=\"btn-group-append\" (click)=\"onButtonClick()\">\n {{ buttonText }}\n </button>\n </div>\n\n <!-- Modal para exibir mensagens de erro -->\n <div class=\"modal-overlay\" *ngIf=\"showErrorModal\">\n <div class=\"modal-content\">\n <span class=\"close\" (click)=\"closeModal()\">&times;</span>\n <p>{{ errorMessage }}</p>\n <button class=\"btn-ok\" (click)=\"closeModal()\">OK</button>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.form-group{font-family:var(--font-family);font-size:1rem;font-weight:700}.form-check-input{font-family:var(--font-family);color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:var(--font-family);color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:var(--font-family);color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:var(--font-family);font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:25px 30px;border-radius:8px;width:360px;text-align:center;position:relative;box-shadow:0 4px 12px #0003}.close{position:absolute;top:10px;right:15px;cursor:pointer;font-size:20px;color:#555;transition:color .3s}.close:hover{color:#f44336}.btn-ok{margin-top:20px;padding:8px 20px;border:none;background-color:#00444c;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s,transform .2s}.btn-ok:hover{background-color:#00363d;transform:scale(1.05)}.btn-ok:active{transform:scale(.98)}.input-group-text{padding:.64rem .75rem;font-family:var(--font-family);color:#6e6e6e;font-size:14px}.btn-group-append{padding:.69rem;font-family:var(--font-family);background-color:var(--secondary-color);border:0rem solid;color:var(--text-color);transition:border-width .2s,transform .1s;font-size:1rem;border-top-right-radius:6px;border-bottom-right-radius:6px}.btn-group-append:hover{background-color:var(--primary-color)}.custom-input-group-text{border-top-right-radius:0;border-bottom-right-radius:0;padding:.71rem .75rem;background-color:#e7e7e7;border:1px solid #dbdbdb}.btn-group-append:active{animation:blink .3s}@keyframes blink{0%{background-color:var(--primary-color);border-color:var(--primary-color)}50%{background-color:var(--secondary-color);border-color:var(--secondary-color)}to{background-color:var(--primary-color);border-color:var(--primary-color)}}\n"] }]
242
264
  }], ctorParameters: function () { return [{ type: i1.AuthService }]; }, propDecorators: { label: [{
243
265
  type: Input
244
266
  }], placeholder: [{
@@ -281,6 +303,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
281
303
  type: Input
282
304
  }], displayCurrencySymbol: [{
283
305
  type: Input
306
+ }], prependText: [{
307
+ type: Input
308
+ }], buttonText: [{
309
+ type: Input
284
310
  }], inputEvent: [{
285
311
  type: Output
286
312
  }], changeEvent: [{
@@ -295,5 +321,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
295
321
  type: Output
296
322
  }], keypressEvent: [{
297
323
  type: Output
324
+ }], buttonClick: [{
325
+ type: Output
298
326
  }] } });
299
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, OnDestroy, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { AuthService } from '../../service/auth-service.service';\n\n@Component({\n  selector: 'argenta-custom-input',\n  styleUrls: ['./input.component.scss'],\n  templateUrl: './input.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class InputComponent implements ControlValueAccessor, OnDestroy {\n  @Input() label: string = 'Default Label';\n  @Input() placeholder: string = '';\n  @Input() id: string = 'inputId';\n  @Input() type: string = 'text';\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() maxlength: number | null = null;\n  @Input() minlength: number | null = null;\n  @Input() required: boolean = false;\n  @Input() pattern: string | null = null;\n  @Input() autofocus: boolean = false;\n  @Input() useCpfMask: boolean = false;\n  @Input() useCnpjMask: boolean = false;\n  @Input() useCepMask: boolean = false;\n  @Input() onlyNumbers: boolean = false;\n  @Input() validateInput: boolean = false;\n  @Input() labelFontWeight: number = 400;\n  @Input() permissions: string[] | undefined;\n  @Input() useMoneyMask: boolean = false; // Para ativar/desativar a máscara de moeda\n  @Input() currencyCode: string = 'BRL'; // Código da moeda\n  @Input() displayCurrencySymbol: boolean = true; // Exibir ou não o símbolo da moeda\n\n\n  @Output() inputEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() changeEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() focusEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() blurEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() keyupEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keydownEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keypressEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n  private onChangeCallback: (_: any) => void = () => { };\n  private onTouchedCallback: () => void = () => { };\n\n  value: string = '';\n  showErrorModal: boolean = false;\n  errorMessage: string = '';\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(private authService: AuthService) { }\n\n  getInputType(): string {\n    return this.onlyNumbers ? 'tel' : this.type;\n  }\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLInputElement;\n    let inputValue = inputElement.value;\n\n    // Aplica máscara de números se necessário\n    if (this.onlyNumbers && !(this.useCpfMask || this.useCnpjMask || this.useCepMask || this.useMoneyMask)) {\n      inputValue = inputValue.replace(/\\D/g, ''); // Remove todos os não numéricos\n    }\n\n    // Validação imediata para CPF, CNPJ ou CEP\n    const numericValue = inputValue.replace(/\\D/g, ''); // Remove todos os caracteres não numéricos\n    if (this.validateInput) {\n      if (this.useCpfMask && numericValue.length === 11 && !this.validateCpf(numericValue)) {\n        this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');\n      } else if (this.useCnpjMask && numericValue.length === 14 && !this.validateCnpj(numericValue)) {\n        this.clearAndShowValidationError('CNPJ inválido. Por favor, insira um CNPJ correto.');\n      } else if (this.useCepMask && numericValue.length === 8 && !this.validateCep(numericValue)) {\n        this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');\n      }\n    }\n\n    // Máscara de moeda\n    if (this.useMoneyMask) {\n      const numericValue = inputValue.replace(/\\D/g, ''); // Remove todos os não numéricos\n      const formattedValue = this.formatMoney(numericValue); // Formata como dinheiro ou número decimal\n      inputElement.value = formattedValue;\n      this.value = formattedValue;\n    } else {\n      this.value = inputValue;\n    }\n\n    // Atualiza o valor e emite o evento de mudança\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  private formatMoney(value: string): string {\n    if (!value) return ''; // Se o valor estiver vazio, retorna uma string vazia\n\n    const numericValue = parseFloat(value) / 100;\n\n    // Verifica se deve exibir o símbolo da moeda ou não\n    if (this.displayCurrencySymbol) {\n      // Formata como moeda\n      return new Intl.NumberFormat('pt-BR', {\n        style: 'currency',\n        currency: this.currencyCode\n      }).format(numericValue);\n    } else {\n      // Formata como número decimal, sem o símbolo da moeda\n      return new Intl.NumberFormat('pt-BR', {\n        style: 'decimal',\n        minimumFractionDigits: 2,\n        maximumFractionDigits: 2\n      }).format(numericValue);\n    }\n  }\n\n\n\n  onKeyDown(event: KeyboardEvent) {\n    if (this.onlyNumbers && !/^\\d$/.test(event.key) && event.key !== 'Backspace' && event.key !== 'ArrowLeft' && event.key !== 'ArrowRight') {\n      event.preventDefault();\n    }\n  }\n\n  onChange(event: Event) {\n    const numericValue = this.value.replace(/\\D/g, ''); // Remove todos os caracteres não numéricos\n    // Validação também ocorre no blur para casos onde o input não está completo\n    if (this.validateInput) {\n      if (this.useCpfMask && !this.validateCpf(numericValue)) {\n        this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');\n      } else if (this.useCnpjMask && !this.validateCnpj(numericValue)) {\n        this.clearAndShowValidationError('CNPJ inválido. Por favor, insira um CNPJ correto.');\n      } else if (this.useCepMask && !this.validateCep(numericValue)) {\n        this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');\n      }\n    }\n    this.changeEvent.emit(event);\n  }\n\n  validateCpf(cpf: string): boolean {\n    if (cpf.length !== 11 || /^(\\d)\\1+$/.test(cpf)) return false;\n    let sum = 0, remainder;\n    for (let i = 1; i <= 9; i++) sum += parseInt(cpf.substring(i - 1, i)) * (11 - i);\n    remainder = (sum * 10) % 11;\n    if (remainder === 10 || remainder === 11) remainder = 0;\n    if (remainder !== parseInt(cpf.substring(9, 10))) return false;\n    sum = 0;\n    for (let i = 1; i <= 10; i++) sum += parseInt(cpf.substring(i - 1, i)) * (12 - i);\n    remainder = (sum * 10) % 11;\n    if (remainder === 10 || remainder === 11) remainder = 0;\n    return remainder === parseInt(cpf.substring(10, 11));\n  }\n\n  validateCnpj(cnpj: string): boolean {\n    if (cnpj.length !== 14) return false;\n    let length = cnpj.length - 2;\n    let numbers = cnpj.substring(0, length);\n    let digits = cnpj.substring(length);\n    let sum = 0, pos = length - 7;\n    for (let i = length; i >= 1; i--) {\n      sum += parseInt(numbers.charAt(length - i)) * pos--;\n      if (pos < 2) pos = 9;\n    }\n    let result = sum % 11 < 2 ? 0 : 11 - sum % 11;\n    if (result !== parseInt(digits.charAt(0))) return false;\n    length = length + 1;\n    numbers = cnpj.substring(0, length);\n    sum = 0;\n    pos = length - 7;\n    for (let i = length; i >= 1; i--) {\n      sum += parseInt(numbers.charAt(length - i)) * pos--;\n      if (pos < 2) pos = 9;\n    }\n    result = sum % 11 < 2 ? 0 : 11 - sum % 11;\n    return result === parseInt(digits.charAt(1));\n  }\n\n  validateCep(cep: string): boolean {\n    return /^\\d{8}$/.test(cep); // Valida apenas números, sem considerar a máscara\n  }\n\n  clearAndShowValidationError(message: string) {\n    this.value = ''; // Limpa o valor do ngModel\n    this.onChangeCallback(this.value); // Atualiza o ngModel com o valor limpo\n    this.errorMessage = message;\n    this.showErrorModal = true;\n  }\n\n  closeModal() {\n    this.showErrorModal = false;\n    this.errorMessage = '';\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focusEvent.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.onTouchedCallback();\n    this.blurEvent.emit(event);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissions || this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error('Permission error:', error.message);\n      } else {\n        console.error('Unknown error occurred during permission check');\n      }\n      return true;\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n}\n","<div *ngIf=\"hasPermission()\" class=\"form-group\">\n  <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n  <input [type]=\"getInputType()\"\n         class=\"form-control custom-input\"\n         [id]=\"id\"\n         [placeholder]=\"placeholder\"\n         [(ngModel)]=\"value\"\n         (input)=\"onInput($event)\"\n         (change)=\"onChange($event)\"\n         (focus)=\"onFocus($event)\"\n         (blur)=\"onBlur($event)\"\n         (keyup)=\"keyupEvent.emit($event)\"\n         (keydown)=\"onKeyDown($event)\"\n         (keypress)=\"keypressEvent.emit($event)\"\n         [disabled]=\"disabled\"\n         [readonly]=\"readonly\"\n         [attr.maxlength]=\"maxlength\"\n         [attr.minlength]=\"minlength\"\n         [required]=\"required\"\n         [attr.pattern]=\"pattern\"\n         [autofocus]=\"autofocus\"\n         [cpfMask]=\"useCpfMask\"  \n         [cnpjMask]=\"useCnpjMask\" \n         [cepMask]=\"useCepMask\">\n\n  <!-- Modal para exibir mensagens de erro -->\n  <div class=\"modal-overlay\" *ngIf=\"showErrorModal\">\n    <div class=\"modal-content\">\n      <span class=\"close\" (click)=\"closeModal()\">&times;</span>\n      <p>{{ errorMessage }}</p>\n      <button class=\"btn-ok\" (click)=\"closeModal()\">OK</button>\n    </div>\n  </div>\n</div>\n"]}
327
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  Output,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { Subscription } from \"rxjs\";\nimport { AuthService } from \"../../service/auth-service.service\";\nimport { ButtonClasses } from \"../../enum/ButtonClassesEnum\";\n\n@Component({\n  selector: \"argenta-custom-input\",\n  styleUrls: [\"./input.component.scss\"],\n  templateUrl: \"./input.component.html\",\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class InputComponent implements ControlValueAccessor, OnDestroy {\n  @Input() label: string = \"Default Label\";\n  @Input() placeholder: string = \"\";\n  @Input() id: string = \"inputId\";\n  @Input() type: string = \"text\";\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() maxlength: number | null = null;\n  @Input() minlength: number | null = null;\n  @Input() required: boolean = false;\n  @Input() pattern: string | null = null;\n  @Input() autofocus: boolean = false;\n  @Input() useCpfMask: boolean = false;\n  @Input() useCnpjMask: boolean = false;\n  @Input() useCepMask: boolean = false;\n  @Input() onlyNumbers: boolean = false;\n  @Input() validateInput: boolean = false;\n  @Input() labelFontWeight: number = 400;\n  @Input() permissions: string[] | undefined;\n  @Input() useMoneyMask: boolean = false; // Para ativar/desativar a máscara de moeda\n  @Input() currencyCode: string = \"BRL\"; // Código da moeda\n  @Input() displayCurrencySymbol: boolean = true; // Exibir ou não o símbolo da moeda\n  @Input() prependText: string = \"\";\n  @Input() buttonText: string | null = null;\n\n  @Output() inputEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() changeEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() focusEvent: EventEmitter<FocusEvent> =\n    new EventEmitter<FocusEvent>();\n  @Output() blurEvent: EventEmitter<FocusEvent> =\n    new EventEmitter<FocusEvent>();\n  @Output() keyupEvent: EventEmitter<KeyboardEvent> =\n    new EventEmitter<KeyboardEvent>();\n  @Output() keydownEvent: EventEmitter<KeyboardEvent> =\n    new EventEmitter<KeyboardEvent>();\n  @Output() keypressEvent: EventEmitter<KeyboardEvent> =\n    new EventEmitter<KeyboardEvent>();\n  @Output() buttonClick: EventEmitter<void> = new EventEmitter<void>();\n\n  private onChangeCallback: (_: any) => void = () => {};\n  private onTouchedCallback: () => void = () => {};\n  ButtonClasses = ButtonClasses;\n\n  value: string = \"\";\n  showErrorModal: boolean = false;\n  errorMessage: string = \"\";\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(private authService: AuthService) {}\n\n  getInputType(): string {\n    return this.onlyNumbers ? \"tel\" : this.type;\n  }\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLInputElement;\n    let inputValue = inputElement.value;\n\n    // Aplica máscara de números se necessário\n    if (\n      this.onlyNumbers &&\n      !(\n        this.useCpfMask ||\n        this.useCnpjMask ||\n        this.useCepMask ||\n        this.useMoneyMask\n      )\n    ) {\n      inputValue = inputValue.replace(/\\D/g, \"\"); // Remove todos os não numéricos\n    }\n\n    // Validação imediata para CPF, CNPJ ou CEP\n    const numericValue = inputValue.replace(/\\D/g, \"\"); // Remove todos os caracteres não numéricos\n    if (this.validateInput) {\n      if (\n        this.useCpfMask &&\n        numericValue.length === 11 &&\n        !this.validateCpf(numericValue)\n      ) {\n        this.clearAndShowValidationError(\n          \"CPF inválido. Por favor, insira um CPF correto.\"\n        );\n      } else if (\n        this.useCnpjMask &&\n        numericValue.length === 14 &&\n        !this.validateCnpj(numericValue)\n      ) {\n        this.clearAndShowValidationError(\n          \"CNPJ inválido. Por favor, insira um CNPJ correto.\"\n        );\n      } else if (\n        this.useCepMask &&\n        numericValue.length === 8 &&\n        !this.validateCep(numericValue)\n      ) {\n        this.clearAndShowValidationError(\n          \"CEP inválido. Por favor, insira um CEP correto.\"\n        );\n      }\n    }\n\n    // Máscara de moeda\n    if (this.useMoneyMask) {\n      const numericValue = inputValue.replace(/\\D/g, \"\"); // Remove todos os não numéricos\n      const formattedValue = this.formatMoney(numericValue); // Formata como dinheiro ou número decimal\n      inputElement.value = formattedValue;\n      this.value = formattedValue;\n    } else {\n      this.value = inputValue;\n    }\n\n    // Atualiza o valor e emite o evento de mudança\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  private formatMoney(value: string): string {\n    if (!value) return \"\"; // Se o valor estiver vazio, retorna uma string vazia\n\n    const numericValue = parseFloat(value) / 100;\n\n    // Verifica se deve exibir o símbolo da moeda ou não\n    if (this.displayCurrencySymbol) {\n      // Formata como moeda\n      return new Intl.NumberFormat(\"pt-BR\", {\n        style: \"currency\",\n        currency: this.currencyCode,\n      }).format(numericValue);\n    } else {\n      // Formata como número decimal, sem o símbolo da moeda\n      return new Intl.NumberFormat(\"pt-BR\", {\n        style: \"decimal\",\n        minimumFractionDigits: 2,\n        maximumFractionDigits: 2,\n      }).format(numericValue);\n    }\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    if (\n      this.onlyNumbers &&\n      !/^\\d$/.test(event.key) &&\n      event.key !== \"Backspace\" &&\n      event.key !== \"ArrowLeft\" &&\n      event.key !== \"ArrowRight\"\n    ) {\n      event.preventDefault();\n    }\n  }\n\n  onChange(event: Event) {\n    const numericValue = this.value.replace(/\\D/g, \"\"); // Remove todos os caracteres não numéricos\n    // Validação também ocorre no blur para casos onde o input não está completo\n    if (this.validateInput) {\n      if (this.useCpfMask && !this.validateCpf(numericValue)) {\n        this.clearAndShowValidationError(\n          \"CPF inválido. Por favor, insira um CPF correto.\"\n        );\n      } else if (this.useCnpjMask && !this.validateCnpj(numericValue)) {\n        this.clearAndShowValidationError(\n          \"CNPJ inválido. Por favor, insira um CNPJ correto.\"\n        );\n      } else if (this.useCepMask && !this.validateCep(numericValue)) {\n        this.clearAndShowValidationError(\n          \"CEP inválido. Por favor, insira um CEP correto.\"\n        );\n      }\n    }\n    this.changeEvent.emit(event);\n  }\n\n  validateCpf(cpf: string): boolean {\n    if (cpf.length !== 11 || /^(\\d)\\1+$/.test(cpf)) return false;\n    let sum = 0,\n      remainder;\n    for (let i = 1; i <= 9; i++)\n      sum += parseInt(cpf.substring(i - 1, i)) * (11 - i);\n    remainder = (sum * 10) % 11;\n    if (remainder === 10 || remainder === 11) remainder = 0;\n    if (remainder !== parseInt(cpf.substring(9, 10))) return false;\n    sum = 0;\n    for (let i = 1; i <= 10; i++)\n      sum += parseInt(cpf.substring(i - 1, i)) * (12 - i);\n    remainder = (sum * 10) % 11;\n    if (remainder === 10 || remainder === 11) remainder = 0;\n    return remainder === parseInt(cpf.substring(10, 11));\n  }\n\n  validateCnpj(cnpj: string): boolean {\n    if (cnpj.length !== 14) return false;\n    let length = cnpj.length - 2;\n    let numbers = cnpj.substring(0, length);\n    let digits = cnpj.substring(length);\n    let sum = 0,\n      pos = length - 7;\n    for (let i = length; i >= 1; i--) {\n      sum += parseInt(numbers.charAt(length - i)) * pos--;\n      if (pos < 2) pos = 9;\n    }\n    let result = sum % 11 < 2 ? 0 : 11 - (sum % 11);\n    if (result !== parseInt(digits.charAt(0))) return false;\n    length = length + 1;\n    numbers = cnpj.substring(0, length);\n    sum = 0;\n    pos = length - 7;\n    for (let i = length; i >= 1; i--) {\n      sum += parseInt(numbers.charAt(length - i)) * pos--;\n      if (pos < 2) pos = 9;\n    }\n    result = sum % 11 < 2 ? 0 : 11 - (sum % 11);\n    return result === parseInt(digits.charAt(1));\n  }\n\n  validateCep(cep: string): boolean {\n    return /^\\d{8}$/.test(cep); // Valida apenas números, sem considerar a máscara\n  }\n\n  clearAndShowValidationError(message: string) {\n    this.value = \"\"; // Limpa o valor do ngModel\n    this.onChangeCallback(this.value); // Atualiza o ngModel com o valor limpo\n    this.errorMessage = message;\n    this.showErrorModal = true;\n  }\n\n  closeModal() {\n    this.showErrorModal = false;\n    this.errorMessage = \"\";\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focusEvent.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.onTouchedCallback();\n    this.blurEvent.emit(event);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissions || this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error(\"Permission error:\", error.message);\n      } else {\n        console.error(\"Unknown error occurred during permission check\");\n      }\n      return true;\n    }\n  }\n\n  onButtonClick() {\n    this.buttonClick.emit();\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach((sub) => sub.unsubscribe());\n  }\n}\n","<div *ngIf=\"hasPermission()\" class=\"form-group\">\n  <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n  <div class=\"input-group\">\n    <div *ngIf=\"prependText\" class=\"input-group-prepend\">\n      <span\n        class=\"input-group-text custom-input-group-text\"\n        id=\"basic-addon3\"\n        >{{ prependText }}</span\n      >\n    </div>\n    <input\n      [type]=\"getInputType()\"\n      class=\"form-control custom-input\"\n      [id]=\"id\"\n      [placeholder]=\"placeholder\"\n      [(ngModel)]=\"value\"\n      (input)=\"onInput($event)\"\n      (change)=\"onChange($event)\"\n      (focus)=\"onFocus($event)\"\n      (blur)=\"onBlur($event)\"\n      (keyup)=\"keyupEvent.emit($event)\"\n      (keydown)=\"onKeyDown($event)\"\n      (keypress)=\"keypressEvent.emit($event)\"\n      [disabled]=\"disabled\"\n      [readonly]=\"readonly\"\n      [attr.maxlength]=\"maxlength\"\n      [attr.minlength]=\"minlength\"\n      [required]=\"required\"\n      [attr.pattern]=\"pattern\"\n      [autofocus]=\"autofocus\"\n      [cpfMask]=\"useCpfMask\"\n      [cnpjMask]=\"useCnpjMask\"\n      [cepMask]=\"useCepMask\"\n    />\n\n    <div class=\"input-group-append\" *ngIf=\"buttonText\">\n      <button type=\"button\" class=\"btn-group-append\" (click)=\"onButtonClick()\">\n        {{ buttonText }}\n      </button>\n    </div>\n\n    <!-- Modal para exibir mensagens de erro -->\n    <div class=\"modal-overlay\" *ngIf=\"showErrorModal\">\n      <div class=\"modal-content\">\n        <span class=\"close\" (click)=\"closeModal()\">&times;</span>\n        <p>{{ errorMessage }}</p>\n        <button class=\"btn-ok\" (click)=\"closeModal()\">OK</button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}