lib-portal-angular 0.0.65 → 0.0.66
Sign up to get free protection for your applications and to get access to all the features.
@@ -27,6 +27,9 @@ export class InputComponent {
|
|
27
27
|
this.onlyNumbers = false;
|
28
28
|
this.validateInput = false;
|
29
29
|
this.labelFontWeight = 400;
|
30
|
+
this.useMoneyMask = false; // Para ativar/desativar a máscara de moeda
|
31
|
+
this.currencyCode = 'BRL'; // Código da moeda
|
32
|
+
this.displayCurrencySymbol = true; // Exibir ou não o símbolo da moeda
|
30
33
|
this.inputEvent = new EventEmitter();
|
31
34
|
this.changeEvent = new EventEmitter();
|
32
35
|
this.focusEvent = new EventEmitter();
|
@@ -47,14 +50,12 @@ export class InputComponent {
|
|
47
50
|
onInput(event) {
|
48
51
|
const inputElement = event.target;
|
49
52
|
let inputValue = inputElement.value;
|
50
|
-
|
51
|
-
|
53
|
+
// 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
|
52
56
|
}
|
53
|
-
|
54
|
-
|
55
|
-
this.inputEvent.emit(event);
|
56
|
-
// Validar imediatamente após o último caractere numérico para CPF, CNPJ ou CEP
|
57
|
-
const numericValue = this.value.replace(/\D/g, ''); // Remove todos os caracteres não numéricos
|
57
|
+
// Validação imediata para CPF, CNPJ ou CEP
|
58
|
+
const numericValue = inputValue.replace(/\D/g, ''); // Remove todos os caracteres não numéricos
|
58
59
|
if (this.validateInput) {
|
59
60
|
if (this.useCpfMask && numericValue.length === 11 && !this.validateCpf(numericValue)) {
|
60
61
|
this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');
|
@@ -66,6 +67,40 @@ export class InputComponent {
|
|
66
67
|
this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');
|
67
68
|
}
|
68
69
|
}
|
70
|
+
// Máscara de moeda
|
71
|
+
if (this.useMoneyMask) {
|
72
|
+
const numericValue = inputValue.replace(/\D/g, ''); // Remove todos os não numéricos
|
73
|
+
const formattedValue = this.formatMoney(numericValue); // Formata como dinheiro ou número decimal
|
74
|
+
inputElement.value = formattedValue;
|
75
|
+
this.value = formattedValue;
|
76
|
+
}
|
77
|
+
else {
|
78
|
+
this.value = inputValue;
|
79
|
+
}
|
80
|
+
// Atualiza o valor e emite o evento de mudança
|
81
|
+
this.onChangeCallback(this.value);
|
82
|
+
this.inputEvent.emit(event);
|
83
|
+
}
|
84
|
+
formatMoney(value) {
|
85
|
+
if (!value)
|
86
|
+
return ''; // Se o valor estiver vazio, retorna uma string vazia
|
87
|
+
const numericValue = parseFloat(value) / 100;
|
88
|
+
// Verifica se deve exibir o símbolo da moeda ou não
|
89
|
+
if (this.displayCurrencySymbol) {
|
90
|
+
// Formata como moeda
|
91
|
+
return new Intl.NumberFormat('pt-BR', {
|
92
|
+
style: 'currency',
|
93
|
+
currency: this.currencyCode
|
94
|
+
}).format(numericValue);
|
95
|
+
}
|
96
|
+
else {
|
97
|
+
// Formata como número decimal, sem o símbolo da moeda
|
98
|
+
return new Intl.NumberFormat('pt-BR', {
|
99
|
+
style: 'decimal',
|
100
|
+
minimumFractionDigits: 2,
|
101
|
+
maximumFractionDigits: 2
|
102
|
+
}).format(numericValue);
|
103
|
+
}
|
69
104
|
}
|
70
105
|
onKeyDown(event) {
|
71
106
|
if (this.onlyNumbers && !/^\d$/.test(event.key) && event.key !== 'Backspace' && event.key !== 'ArrowLeft' && event.key !== 'ArrowRight') {
|
@@ -187,7 +222,7 @@ export class InputComponent {
|
|
187
222
|
this.subscriptions.forEach(sub => sub.unsubscribe());
|
188
223
|
}
|
189
224
|
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 }); }
|
190
|
-
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" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
|
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: [
|
191
226
|
{
|
192
227
|
provide: NG_VALUE_ACCESSOR,
|
193
228
|
useExisting: forwardRef(() => InputComponent),
|
@@ -240,6 +275,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
240
275
|
type: Input
|
241
276
|
}], permissions: [{
|
242
277
|
type: Input
|
278
|
+
}], useMoneyMask: [{
|
279
|
+
type: Input
|
280
|
+
}], currencyCode: [{
|
281
|
+
type: Input
|
282
|
+
}], displayCurrencySymbol: [{
|
283
|
+
type: Input
|
243
284
|
}], inputEvent: [{
|
244
285
|
type: Output
|
245
286
|
}], changeEvent: [{
|
@@ -255,4 +296,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
255
296
|
}], keypressEvent: [{
|
256
297
|
type: Output
|
257
298
|
}] } });
|
258
|
-
//# 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\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    if ((this.onlyNumbers) && !(this.useCpfMask || this.useCnpjMask || this.useCepMask)) {\n      inputValue = inputValue.replace(/\\D/g, '');\n    }\n\n    this.value = inputValue;\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n\n    // Validar imediatamente após o último caractere numérico para CPF, CNPJ ou CEP\n    const numericValue = this.value.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\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"]}
|
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"]}
|
@@ -1429,6 +1429,9 @@ class InputComponent {
|
|
1429
1429
|
this.onlyNumbers = false;
|
1430
1430
|
this.validateInput = false;
|
1431
1431
|
this.labelFontWeight = 400;
|
1432
|
+
this.useMoneyMask = false; // Para ativar/desativar a máscara de moeda
|
1433
|
+
this.currencyCode = 'BRL'; // Código da moeda
|
1434
|
+
this.displayCurrencySymbol = true; // Exibir ou não o símbolo da moeda
|
1432
1435
|
this.inputEvent = new EventEmitter();
|
1433
1436
|
this.changeEvent = new EventEmitter();
|
1434
1437
|
this.focusEvent = new EventEmitter();
|
@@ -1449,14 +1452,12 @@ class InputComponent {
|
|
1449
1452
|
onInput(event) {
|
1450
1453
|
const inputElement = event.target;
|
1451
1454
|
let inputValue = inputElement.value;
|
1452
|
-
|
1453
|
-
|
1455
|
+
// Aplica máscara de números se necessário
|
1456
|
+
if (this.onlyNumbers && !(this.useCpfMask || this.useCnpjMask || this.useCepMask || this.useMoneyMask)) {
|
1457
|
+
inputValue = inputValue.replace(/\D/g, ''); // Remove todos os não numéricos
|
1454
1458
|
}
|
1455
|
-
|
1456
|
-
|
1457
|
-
this.inputEvent.emit(event);
|
1458
|
-
// Validar imediatamente após o último caractere numérico para CPF, CNPJ ou CEP
|
1459
|
-
const numericValue = this.value.replace(/\D/g, ''); // Remove todos os caracteres não numéricos
|
1459
|
+
// Validação imediata para CPF, CNPJ ou CEP
|
1460
|
+
const numericValue = inputValue.replace(/\D/g, ''); // Remove todos os caracteres não numéricos
|
1460
1461
|
if (this.validateInput) {
|
1461
1462
|
if (this.useCpfMask && numericValue.length === 11 && !this.validateCpf(numericValue)) {
|
1462
1463
|
this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');
|
@@ -1468,6 +1469,40 @@ class InputComponent {
|
|
1468
1469
|
this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');
|
1469
1470
|
}
|
1470
1471
|
}
|
1472
|
+
// Máscara de moeda
|
1473
|
+
if (this.useMoneyMask) {
|
1474
|
+
const numericValue = inputValue.replace(/\D/g, ''); // Remove todos os não numéricos
|
1475
|
+
const formattedValue = this.formatMoney(numericValue); // Formata como dinheiro ou número decimal
|
1476
|
+
inputElement.value = formattedValue;
|
1477
|
+
this.value = formattedValue;
|
1478
|
+
}
|
1479
|
+
else {
|
1480
|
+
this.value = inputValue;
|
1481
|
+
}
|
1482
|
+
// Atualiza o valor e emite o evento de mudança
|
1483
|
+
this.onChangeCallback(this.value);
|
1484
|
+
this.inputEvent.emit(event);
|
1485
|
+
}
|
1486
|
+
formatMoney(value) {
|
1487
|
+
if (!value)
|
1488
|
+
return ''; // Se o valor estiver vazio, retorna uma string vazia
|
1489
|
+
const numericValue = parseFloat(value) / 100;
|
1490
|
+
// Verifica se deve exibir o símbolo da moeda ou não
|
1491
|
+
if (this.displayCurrencySymbol) {
|
1492
|
+
// Formata como moeda
|
1493
|
+
return new Intl.NumberFormat('pt-BR', {
|
1494
|
+
style: 'currency',
|
1495
|
+
currency: this.currencyCode
|
1496
|
+
}).format(numericValue);
|
1497
|
+
}
|
1498
|
+
else {
|
1499
|
+
// Formata como número decimal, sem o símbolo da moeda
|
1500
|
+
return new Intl.NumberFormat('pt-BR', {
|
1501
|
+
style: 'decimal',
|
1502
|
+
minimumFractionDigits: 2,
|
1503
|
+
maximumFractionDigits: 2
|
1504
|
+
}).format(numericValue);
|
1505
|
+
}
|
1471
1506
|
}
|
1472
1507
|
onKeyDown(event) {
|
1473
1508
|
if (this.onlyNumbers && !/^\d$/.test(event.key) && event.key !== 'Backspace' && event.key !== 'ArrowLeft' && event.key !== 'ArrowRight') {
|
@@ -1589,7 +1624,7 @@ class InputComponent {
|
|
1589
1624
|
this.subscriptions.forEach(sub => sub.unsubscribe());
|
1590
1625
|
}
|
1591
1626
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, deps: [{ token: AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
|
1592
|
-
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" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
|
1627
|
+
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: [
|
1593
1628
|
{
|
1594
1629
|
provide: NG_VALUE_ACCESSOR,
|
1595
1630
|
useExisting: forwardRef(() => InputComponent),
|
@@ -1642,6 +1677,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
1642
1677
|
type: Input
|
1643
1678
|
}], permissions: [{
|
1644
1679
|
type: Input
|
1680
|
+
}], useMoneyMask: [{
|
1681
|
+
type: Input
|
1682
|
+
}], currencyCode: [{
|
1683
|
+
type: Input
|
1684
|
+
}], displayCurrencySymbol: [{
|
1685
|
+
type: Input
|
1645
1686
|
}], inputEvent: [{
|
1646
1687
|
type: Output
|
1647
1688
|
}], changeEvent: [{
|