lib-portal-angular 0.0.59 → 0.0.61

Sign up to get free protection for your applications and to get access to all the features.
@@ -3,6 +3,9 @@ import { NgModule } from '@angular/core';
3
3
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  import { NgSelectModule } from '@ng-select/ng-select';
5
5
  import { AutofocusDirective } from '../directive/autofocus-directive/autofocus.directive';
6
+ import { CepMaskDirective } from '../directive/cep-mask.directive';
7
+ import { CnpjMaskDirective } from '../directive/cnpj-mask.directive';
8
+ import { CpfMaskDirective } from '../directive/cpf-mask.directive';
6
9
  import { LucideIconsModule } from '../icons/lucide-icons.module';
7
10
  import { AlertComponent } from './alert/alert.component';
8
11
  import { AppBackgroundComponent } from './app-background/app-background.component';
@@ -14,17 +17,17 @@ import { CheckboxComponent } from './checkbox/checkbox.component';
14
17
  import { CodeHighlightComponent } from './code-highlight/code-highlight.component';
15
18
  import { ConfirmationComponent } from './confirmation/confirmation.component';
16
19
  import { CustomPaginationComponent } from './custom-pagination/custom-pagination.component';
20
+ import { CustomSwitchComponent } from './custom-switch/custom-switch.component';
17
21
  import { InputComponent } from './imput/input.component';
18
22
  import { MultiSelectComponent } from './multi-select/multi-select.component';
19
23
  import { RadioComponent } from './radio/radio.component';
24
+ import { SearchCustomerComponent } from './search-customer/search-customer.component';
20
25
  import { SearchInputComponent } from './search-input/search-input.component';
21
26
  import { SelectComponent } from './select/select.component';
27
+ import { TabComponent } from './tab/tab.component';
22
28
  import { DataTableComponent } from './tables/data-table.component';
23
29
  import { TextareaComponent } from './textarea/textarea.component';
24
30
  import { TreeNodeComponent } from './tree-node/tree-node.component';
25
- import { CustomSwitchComponent } from './custom-switch/custom-switch.component';
26
- import { SearchCustomerComponent } from './search-customer/search-customer.component';
27
- import { TabComponent } from './tab/tab.component';
28
31
  import * as i0 from "@angular/core";
29
32
  export class ComponentsModule {
30
33
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
@@ -42,6 +45,9 @@ export class ComponentsModule {
42
45
  AlertComponent,
43
46
  ConfirmationComponent,
44
47
  AutofocusDirective,
48
+ CepMaskDirective,
49
+ CnpjMaskDirective,
50
+ CpfMaskDirective,
45
51
  CustomPaginationComponent,
46
52
  TreeNodeComponent,
47
53
  SearchInputComponent,
@@ -69,6 +75,10 @@ export class ComponentsModule {
69
75
  BadgeComponent,
70
76
  AlertComponent,
71
77
  ConfirmationComponent,
78
+ AutofocusDirective,
79
+ CepMaskDirective,
80
+ CnpjMaskDirective,
81
+ CpfMaskDirective,
72
82
  CustomPaginationComponent,
73
83
  TreeNodeComponent,
74
84
  SearchInputComponent,
@@ -105,6 +115,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
105
115
  AlertComponent,
106
116
  ConfirmationComponent,
107
117
  AutofocusDirective,
118
+ CepMaskDirective,
119
+ CnpjMaskDirective,
120
+ CpfMaskDirective,
108
121
  CustomPaginationComponent,
109
122
  TreeNodeComponent,
110
123
  SearchInputComponent,
@@ -138,6 +151,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
138
151
  BadgeComponent,
139
152
  AlertComponent,
140
153
  ConfirmationComponent,
154
+ AutofocusDirective,
155
+ CepMaskDirective,
156
+ CnpjMaskDirective,
157
+ CpfMaskDirective,
141
158
  CustomPaginationComponent,
142
159
  TreeNodeComponent,
143
160
  SearchInputComponent,
@@ -150,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
150
167
  ],
151
168
  }]
152
169
  }] });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../projects/lib-portal-angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { AutofocusDirective } from '../directive/autofocus-directive/autofocus.directive';\nimport { LucideIconsModule } from '../icons/lucide-icons.module';\nimport { AlertComponent } from './alert/alert.component';\nimport { AppBackgroundComponent } from './app-background/app-background.component';\nimport { BadgeComponent } from './badge/badge.component';\nimport { BasicRegistrationComponent } from './basic-registration/basic-registration.component';\nimport { ButtonComponent } from './button/button.component';\nimport { CardComponent } from './card/card.component';\nimport { CheckboxComponent } from './checkbox/checkbox.component';\nimport { CodeHighlightComponent } from './code-highlight/code-highlight.component';\nimport { ConfirmationComponent } from './confirmation/confirmation.component';\nimport { CustomPaginationComponent } from './custom-pagination/custom-pagination.component';\nimport { InputComponent } from './imput/input.component';\nimport { MultiSelectComponent } from './multi-select/multi-select.component';\nimport { RadioComponent } from './radio/radio.component';\nimport { SearchInputComponent } from './search-input/search-input.component';\nimport { SelectComponent } from './select/select.component';\nimport { DataTableComponent } from './tables/data-table.component';\nimport { TextareaComponent } from './textarea/textarea.component';\nimport { TreeNodeComponent } from './tree-node/tree-node.component';\nimport { CustomSwitchComponent } from './custom-switch/custom-switch.component';\nimport { SearchCustomerComponent } from './search-customer/search-customer.component';\nimport { TabComponent } from './tab/tab.component';\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    AutofocusDirective,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    LucideIconsModule,\n  ],\n  exports: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    LucideIconsModule,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n  ],\n})\nexport class ComponentsModule { }\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../projects/lib-portal-angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { AutofocusDirective } from '../directive/autofocus-directive/autofocus.directive';\nimport { CepMaskDirective } from '../directive/cep-mask.directive';\nimport { CnpjMaskDirective } from '../directive/cnpj-mask.directive';\nimport { CpfMaskDirective } from '../directive/cpf-mask.directive';\nimport { LucideIconsModule } from '../icons/lucide-icons.module';\nimport { AlertComponent } from './alert/alert.component';\nimport { AppBackgroundComponent } from './app-background/app-background.component';\nimport { BadgeComponent } from './badge/badge.component';\nimport { BasicRegistrationComponent } from './basic-registration/basic-registration.component';\nimport { ButtonComponent } from './button/button.component';\nimport { CardComponent } from './card/card.component';\nimport { CheckboxComponent } from './checkbox/checkbox.component';\nimport { CodeHighlightComponent } from './code-highlight/code-highlight.component';\nimport { ConfirmationComponent } from './confirmation/confirmation.component';\nimport { CustomPaginationComponent } from './custom-pagination/custom-pagination.component';\nimport { CustomSwitchComponent } from './custom-switch/custom-switch.component';\nimport { InputComponent } from './imput/input.component';\nimport { MultiSelectComponent } from './multi-select/multi-select.component';\nimport { RadioComponent } from './radio/radio.component';\nimport { SearchCustomerComponent } from './search-customer/search-customer.component';\nimport { SearchInputComponent } from './search-input/search-input.component';\nimport { SelectComponent } from './select/select.component';\nimport { TabComponent } from './tab/tab.component';\nimport { DataTableComponent } from './tables/data-table.component';\nimport { TextareaComponent } from './textarea/textarea.component';\nimport { TreeNodeComponent } from './tree-node/tree-node.component';\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    AutofocusDirective,\n    CepMaskDirective,\n    CnpjMaskDirective,\n    CpfMaskDirective,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    LucideIconsModule,\n  ],\n  exports: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    AutofocusDirective,\n    CepMaskDirective,\n    CnpjMaskDirective,\n    CpfMaskDirective,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    LucideIconsModule,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n  ],\n})\nexport class ComponentsModule { }\n"]}
@@ -4,6 +4,9 @@ import * as i0 from "@angular/core";
4
4
  import * as i1 from "../../service/auth-service.service";
5
5
  import * as i2 from "@angular/common";
6
6
  import * as i3 from "@angular/forms";
7
+ import * as i4 from "../../directive/cep-mask.directive";
8
+ import * as i5 from "../../directive/cnpj-mask.directive";
9
+ import * as i6 from "../../directive/cpf-mask.directive";
7
10
  export class InputComponent {
8
11
  constructor(authService) {
9
12
  this.authService = authService;
@@ -18,6 +21,11 @@ export class InputComponent {
18
21
  this.required = false;
19
22
  this.pattern = null;
20
23
  this.autofocus = false;
24
+ this.useCpfMask = false;
25
+ this.useCnpjMask = false;
26
+ this.useCepMask = false;
27
+ this.onlyNumbers = false;
28
+ this.validateInput = false;
21
29
  this.labelFontWeight = 400;
22
30
  this.inputEvent = new EventEmitter();
23
31
  this.changeEvent = new EventEmitter();
@@ -29,17 +37,116 @@ export class InputComponent {
29
37
  this.onChangeCallback = () => { };
30
38
  this.onTouchedCallback = () => { };
31
39
  this.value = '';
40
+ this.showErrorModal = false;
41
+ this.errorMessage = '';
32
42
  this.subscriptions = [];
33
43
  }
44
+ getInputType() {
45
+ return this.onlyNumbers ? 'tel' : this.type;
46
+ }
34
47
  onInput(event) {
35
48
  const inputElement = event.target;
36
- this.value = inputElement.value;
49
+ let inputValue = inputElement.value;
50
+ if ((this.onlyNumbers) && !(this.useCpfMask || this.useCnpjMask || this.useCepMask)) {
51
+ inputValue = inputValue.replace(/\D/g, '');
52
+ }
53
+ this.value = inputValue;
37
54
  this.onChangeCallback(this.value);
38
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
58
+ if (this.validateInput) {
59
+ if (this.useCpfMask && numericValue.length === 11 && !this.validateCpf(numericValue)) {
60
+ this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');
61
+ }
62
+ else if (this.useCnpjMask && numericValue.length === 14 && !this.validateCnpj(numericValue)) {
63
+ this.clearAndShowValidationError('CNPJ inválido. Por favor, insira um CNPJ correto.');
64
+ }
65
+ else if (this.useCepMask && numericValue.length === 8 && !this.validateCep(numericValue)) {
66
+ this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');
67
+ }
68
+ }
69
+ }
70
+ onKeyDown(event) {
71
+ if (this.onlyNumbers && !/^\d$/.test(event.key) && event.key !== 'Backspace' && event.key !== 'ArrowLeft' && event.key !== 'ArrowRight') {
72
+ event.preventDefault();
73
+ }
39
74
  }
40
75
  onChange(event) {
76
+ const numericValue = this.value.replace(/\D/g, ''); // Remove todos os caracteres não numéricos
77
+ // Validação também ocorre no blur para casos onde o input não está completo
78
+ if (this.validateInput) {
79
+ if (this.useCpfMask && !this.validateCpf(numericValue)) {
80
+ this.clearAndShowValidationError('CPF inválido. Por favor, insira um CPF correto.');
81
+ }
82
+ else if (this.useCnpjMask && !this.validateCnpj(numericValue)) {
83
+ this.clearAndShowValidationError('CNPJ inválido. Por favor, insira um CNPJ correto.');
84
+ }
85
+ else if (this.useCepMask && !this.validateCep(numericValue)) {
86
+ this.clearAndShowValidationError('CEP inválido. Por favor, insira um CEP correto.');
87
+ }
88
+ }
41
89
  this.changeEvent.emit(event);
42
90
  }
91
+ validateCpf(cpf) {
92
+ if (cpf.length !== 11 || /^(\d)\1+$/.test(cpf))
93
+ return false;
94
+ let sum = 0, remainder;
95
+ for (let i = 1; i <= 9; i++)
96
+ sum += parseInt(cpf.substring(i - 1, i)) * (11 - i);
97
+ remainder = (sum * 10) % 11;
98
+ if (remainder === 10 || remainder === 11)
99
+ remainder = 0;
100
+ if (remainder !== parseInt(cpf.substring(9, 10)))
101
+ return false;
102
+ sum = 0;
103
+ for (let i = 1; i <= 10; i++)
104
+ sum += parseInt(cpf.substring(i - 1, i)) * (12 - i);
105
+ remainder = (sum * 10) % 11;
106
+ if (remainder === 10 || remainder === 11)
107
+ remainder = 0;
108
+ return remainder === parseInt(cpf.substring(10, 11));
109
+ }
110
+ validateCnpj(cnpj) {
111
+ if (cnpj.length !== 14)
112
+ return false;
113
+ let length = cnpj.length - 2;
114
+ let numbers = cnpj.substring(0, length);
115
+ let digits = cnpj.substring(length);
116
+ let sum = 0, pos = length - 7;
117
+ for (let i = length; i >= 1; i--) {
118
+ sum += parseInt(numbers.charAt(length - i)) * pos--;
119
+ if (pos < 2)
120
+ pos = 9;
121
+ }
122
+ let result = sum % 11 < 2 ? 0 : 11 - sum % 11;
123
+ if (result !== parseInt(digits.charAt(0)))
124
+ return false;
125
+ length = length + 1;
126
+ numbers = cnpj.substring(0, length);
127
+ sum = 0;
128
+ pos = length - 7;
129
+ for (let i = length; i >= 1; i--) {
130
+ sum += parseInt(numbers.charAt(length - i)) * pos--;
131
+ if (pos < 2)
132
+ pos = 9;
133
+ }
134
+ result = sum % 11 < 2 ? 0 : 11 - sum % 11;
135
+ return result === parseInt(digits.charAt(1));
136
+ }
137
+ validateCep(cep) {
138
+ return /^\d{8}$/.test(cep); // Valida apenas números, sem considerar a máscara
139
+ }
140
+ clearAndShowValidationError(message) {
141
+ this.value = ''; // Limpa o valor do ngModel
142
+ this.onChangeCallback(this.value); // Atualiza o ngModel com o valor limpo
143
+ this.errorMessage = message;
144
+ this.showErrorModal = true;
145
+ }
146
+ closeModal() {
147
+ this.showErrorModal = false;
148
+ this.errorMessage = '';
149
+ }
43
150
  onFocus(event) {
44
151
  this.focusEvent.emit(event);
45
152
  }
@@ -80,69 +187,23 @@ export class InputComponent {
80
187
  this.subscriptions.forEach(sub => sub.unsubscribe());
81
188
  }
82
189
  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 }); }
83
- 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", labelFontWeight: "labelFontWeight", permissions: "permissions" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
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: [
84
191
  {
85
192
  provide: NG_VALUE_ACCESSOR,
86
193
  useExisting: forwardRef(() => InputComponent),
87
194
  multi: true
88
195
  }
89
- ], ngImport: i0, template: `
90
- <div *ngIf="hasPermission()" class="form-group">
91
- <label [for]="id" [ngClass]="'label-styles'">{{ label }}</label>
92
- <input [type]="type"
93
- class="form-control custom-input"
94
- [id]="id"
95
- [placeholder]="placeholder"
96
- [(ngModel)]="value"
97
- (input)="onInput($event)"
98
- (change)="onChange($event)"
99
- (focus)="onFocus($event)"
100
- (blur)="onBlur($event)"
101
- (keyup)="keyupEvent.emit($event)"
102
- (keydown)="keydownEvent.emit($event)"
103
- (keypress)="keypressEvent.emit($event)"
104
- [disabled]="disabled"
105
- [readonly]="readonly"
106
- [attr.maxlength]="maxlength"
107
- [attr.minlength]="minlength"
108
- [required]="required"
109
- [attr.pattern]="pattern"
110
- [autofocus]="autofocus">
111
- </div>
112
- `, isInline: true, styles: ["@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.form-group{font-family:Inter,Arial,sans-serif;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:Inter,Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}\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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
196
+ ], 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\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.form-group{font-family:Inter,Arial,sans-serif;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:Inter,Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:Inter,Arial,sans-serif;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 }); }
113
197
  }
114
198
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, decorators: [{
115
199
  type: Component,
116
- args: [{ selector: 'argenta-custom-input', template: `
117
- <div *ngIf="hasPermission()" class="form-group">
118
- <label [for]="id" [ngClass]="'label-styles'">{{ label }}</label>
119
- <input [type]="type"
120
- class="form-control custom-input"
121
- [id]="id"
122
- [placeholder]="placeholder"
123
- [(ngModel)]="value"
124
- (input)="onInput($event)"
125
- (change)="onChange($event)"
126
- (focus)="onFocus($event)"
127
- (blur)="onBlur($event)"
128
- (keyup)="keyupEvent.emit($event)"
129
- (keydown)="keydownEvent.emit($event)"
130
- (keypress)="keypressEvent.emit($event)"
131
- [disabled]="disabled"
132
- [readonly]="readonly"
133
- [attr.maxlength]="maxlength"
134
- [attr.minlength]="minlength"
135
- [required]="required"
136
- [attr.pattern]="pattern"
137
- [autofocus]="autofocus">
138
- </div>
139
- `, providers: [
200
+ args: [{ selector: 'argenta-custom-input', providers: [
140
201
  {
141
202
  provide: NG_VALUE_ACCESSOR,
142
203
  useExisting: forwardRef(() => InputComponent),
143
204
  multi: true
144
205
  }
145
- ], changeDetection: ChangeDetectionStrategy.OnPush, styles: ["@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.form-group{font-family:Inter,Arial,sans-serif;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:Inter,Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}\n"] }]
206
+ ], 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\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.form-group{font-family:Inter,Arial,sans-serif;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left}.custom-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem;height:46px}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.form-label{font-family:Inter,Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}.label-styles{font-weight:400;font-family:Inter,Arial,sans-serif;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"] }]
146
207
  }], ctorParameters: function () { return [{ type: i1.AuthService }]; }, propDecorators: { label: [{
147
208
  type: Input
148
209
  }], placeholder: [{
@@ -165,6 +226,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
165
226
  type: Input
166
227
  }], autofocus: [{
167
228
  type: Input
229
+ }], useCpfMask: [{
230
+ type: Input
231
+ }], useCnpjMask: [{
232
+ type: Input
233
+ }], useCepMask: [{
234
+ type: Input
235
+ }], onlyNumbers: [{
236
+ type: Input
237
+ }], validateInput: [{
238
+ type: Input
168
239
  }], labelFontWeight: [{
169
240
  type: Input
170
241
  }], permissions: [{
@@ -184,4 +255,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
184
255
  }], keypressEvent: [{
185
256
  type: Output
186
257
  }] } });
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.ts"],"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  template: `\n    <div *ngIf=\"hasPermission()\" class=\"form-group\">\n      <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n      <input [type]=\"type\"\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)=\"keydownEvent.emit($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    </div>\n  `,\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\n  @Input() labelFontWeight: number = 400;\n\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\n  private subscriptions: Subscription[] = [];\n\n  constructor(private authService: AuthService) { }\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLInputElement;\n    this.value = inputElement.value;\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  onChange(event: Event) {\n    this.changeEvent.emit(event);\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"]}
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"]}
@@ -0,0 +1,49 @@
1
+ import { Directive, HostListener, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class CepMaskDirective {
4
+ constructor(el, renderer) {
5
+ this.el = el;
6
+ this.renderer = renderer;
7
+ this.enabled = false; // Define como opcional e padrão desabilitado
8
+ }
9
+ onInputChange(event) {
10
+ if (!this.enabled)
11
+ return; // Não aplica a máscara se não estiver habilitada
12
+ // Obtém o valor atual e remove todos os caracteres não numéricos
13
+ let initialValue = this.el.nativeElement.value.replace(/\D/g, '');
14
+ // Limita o número de caracteres a 8 para CEP
15
+ if (initialValue.length > 8) {
16
+ initialValue = initialValue.slice(0, 8);
17
+ }
18
+ // Aplica a máscara de CEP
19
+ const formattedValue = this.formatCep(initialValue);
20
+ // Atualiza o valor do input se necessário
21
+ if (formattedValue !== this.el.nativeElement.value) {
22
+ this.renderer.setProperty(this.el.nativeElement, 'value', formattedValue);
23
+ // Dispara um evento de input para atualizar o modelo
24
+ if (event.target.dispatchEvent) {
25
+ const newEvent = new Event('input', { bubbles: true });
26
+ event.target.dispatchEvent(newEvent);
27
+ }
28
+ }
29
+ }
30
+ formatCep(value) {
31
+ // Aplica a formatação de CEP: 12345-678
32
+ return value.replace(/(\d{5})(\d)/, '$1-$2');
33
+ }
34
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CepMaskDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
35
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CepMaskDirective, selector: "[cepMask]", inputs: { enabled: ["cepMask", "enabled"] }, host: { listeners: { "input": "onInputChange($event)" } }, ngImport: i0 }); }
36
+ }
37
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CepMaskDirective, decorators: [{
38
+ type: Directive,
39
+ args: [{
40
+ selector: '[cepMask]',
41
+ }]
42
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { enabled: [{
43
+ type: Input,
44
+ args: ['cepMask']
45
+ }], onInputChange: [{
46
+ type: HostListener,
47
+ args: ['input', ['$event']]
48
+ }] } });
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VwLW1hc2suZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGliLXBvcnRhbC1hbmd1bGFyL3NyYy9saWIvZGlyZWN0aXZlL2NlcC1tYXNrLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7O0FBS3RGLE1BQU0sT0FBTyxnQkFBZ0I7SUFHekIsWUFBb0IsRUFBYyxFQUFVLFFBQW1CO1FBQTNDLE9BQUUsR0FBRixFQUFFLENBQVk7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBRjdDLFlBQU8sR0FBWSxLQUFLLENBQUMsQ0FBQyw2Q0FBNkM7SUFFdEIsQ0FBQztJQUdwRSxhQUFhLENBQUMsS0FBVTtRQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU87WUFBRSxPQUFPLENBQUMsaURBQWlEO1FBRTVFLGlFQUFpRTtRQUNqRSxJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVsRSw2Q0FBNkM7UUFDN0MsSUFBSSxZQUFZLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN6QixZQUFZLEdBQUcsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7U0FDM0M7UUFFRCwwQkFBMEI7UUFDMUIsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVwRCwwQ0FBMEM7UUFDMUMsSUFBSSxjQUFjLEtBQUssSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFO1lBQ2hELElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQztZQUUxRSxxREFBcUQ7WUFDckQsSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLGFBQWEsRUFBRTtnQkFDNUIsTUFBTSxRQUFRLEdBQUcsSUFBSSxLQUFLLENBQUMsT0FBTyxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7Z0JBQ3ZELEtBQUssQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO2FBQ3hDO1NBQ0o7SUFDTCxDQUFDO0lBRUQsU0FBUyxDQUFDLEtBQWE7UUFDbkIsd0NBQXdDO1FBQ3hDLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDakQsQ0FBQzsrR0FuQ1EsZ0JBQWdCO21HQUFoQixnQkFBZ0I7OzRGQUFoQixnQkFBZ0I7a0JBSDVCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFdBQVc7aUJBQ3hCO3lIQUVxQixPQUFPO3NCQUF4QixLQUFLO3VCQUFDLFNBQVM7Z0JBS2hCLGFBQWE7c0JBRFosWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tjZXBNYXNrXScsXG59KVxuZXhwb3J0IGNsYXNzIENlcE1hc2tEaXJlY3RpdmUge1xuICAgIEBJbnB1dCgnY2VwTWFzaycpIGVuYWJsZWQ6IGJvb2xlYW4gPSBmYWxzZTsgLy8gRGVmaW5lIGNvbW8gb3BjaW9uYWwgZSBwYWRyw6NvIGRlc2FiaWxpdGFkb1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZiwgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyKSB7IH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2lucHV0JywgWyckZXZlbnQnXSlcbiAgICBvbklucHV0Q2hhbmdlKGV2ZW50OiBhbnkpIHtcbiAgICAgICAgaWYgKCF0aGlzLmVuYWJsZWQpIHJldHVybjsgLy8gTsOjbyBhcGxpY2EgYSBtw6FzY2FyYSBzZSBuw6NvIGVzdGl2ZXIgaGFiaWxpdGFkYVxuXG4gICAgICAgIC8vIE9idMOpbSBvIHZhbG9yIGF0dWFsIGUgcmVtb3ZlIHRvZG9zIG9zIGNhcmFjdGVyZXMgbsOjbyBudW3DqXJpY29zXG4gICAgICAgIGxldCBpbml0aWFsVmFsdWUgPSB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQudmFsdWUucmVwbGFjZSgvXFxEL2csICcnKTtcblxuICAgICAgICAvLyBMaW1pdGEgbyBuw7ptZXJvIGRlIGNhcmFjdGVyZXMgYSA4IHBhcmEgQ0VQXG4gICAgICAgIGlmIChpbml0aWFsVmFsdWUubGVuZ3RoID4gOCkge1xuICAgICAgICAgICAgaW5pdGlhbFZhbHVlID0gaW5pdGlhbFZhbHVlLnNsaWNlKDAsIDgpO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gQXBsaWNhIGEgbcOhc2NhcmEgZGUgQ0VQXG4gICAgICAgIGNvbnN0IGZvcm1hdHRlZFZhbHVlID0gdGhpcy5mb3JtYXRDZXAoaW5pdGlhbFZhbHVlKTtcblxuICAgICAgICAvLyBBdHVhbGl6YSBvIHZhbG9yIGRvIGlucHV0IHNlIG5lY2Vzc8OhcmlvXG4gICAgICAgIGlmIChmb3JtYXR0ZWRWYWx1ZSAhPT0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLnJlbmRlcmVyLnNldFByb3BlcnR5KHRoaXMuZWwubmF0aXZlRWxlbWVudCwgJ3ZhbHVlJywgZm9ybWF0dGVkVmFsdWUpO1xuXG4gICAgICAgICAgICAvLyBEaXNwYXJhIHVtIGV2ZW50byBkZSBpbnB1dCBwYXJhIGF0dWFsaXphciBvIG1vZGVsb1xuICAgICAgICAgICAgaWYgKGV2ZW50LnRhcmdldC5kaXNwYXRjaEV2ZW50KSB7XG4gICAgICAgICAgICAgICAgY29uc3QgbmV3RXZlbnQgPSBuZXcgRXZlbnQoJ2lucHV0JywgeyBidWJibGVzOiB0cnVlIH0pO1xuICAgICAgICAgICAgICAgIGV2ZW50LnRhcmdldC5kaXNwYXRjaEV2ZW50KG5ld0V2ZW50KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIGZvcm1hdENlcCh2YWx1ZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICAgICAgLy8gQXBsaWNhIGEgZm9ybWF0YcOnw6NvIGRlIENFUDogMTIzNDUtNjc4XG4gICAgICAgIHJldHVybiB2YWx1ZS5yZXBsYWNlKC8oXFxkezV9KShcXGQpLywgJyQxLSQyJyk7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,53 @@
1
+ import { Directive, HostListener, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class CnpjMaskDirective {
4
+ constructor(el, renderer) {
5
+ this.el = el;
6
+ this.renderer = renderer;
7
+ this.enabled = false; // Define como opcional e padrão desabilitado
8
+ }
9
+ onInputChange(event) {
10
+ if (!this.enabled)
11
+ return; // Não aplica a máscara se não estiver habilitada
12
+ // Obtém o valor atual e remove todos os caracteres não numéricos
13
+ let initialValue = this.el.nativeElement.value.replace(/\D/g, '');
14
+ // Limita o número de caracteres a 14 para CNPJ
15
+ if (initialValue.length > 14) {
16
+ initialValue = initialValue.slice(0, 14);
17
+ }
18
+ // Aplica a máscara de CNPJ
19
+ const formattedValue = this.formatCnpj(initialValue);
20
+ // Atualiza o valor do input se necessário
21
+ if (formattedValue !== this.el.nativeElement.value) {
22
+ this.renderer.setProperty(this.el.nativeElement, 'value', formattedValue);
23
+ // Dispara um evento de input para atualizar o modelo
24
+ if (event.target.dispatchEvent) {
25
+ const newEvent = new Event('input', { bubbles: true });
26
+ event.target.dispatchEvent(newEvent);
27
+ }
28
+ }
29
+ }
30
+ formatCnpj(value) {
31
+ // Aplica a formatação de CNPJ: 12.345.678/0001-00
32
+ return value
33
+ .replace(/(\d{2})(\d)/, '$1.$2')
34
+ .replace(/(\d{3})(\d)/, '$1.$2')
35
+ .replace(/(\d{3})(\d{4})(\d)/, '$1/$2-$3')
36
+ .replace(/(\d{4})(\d{2})$/, '$1-$2');
37
+ }
38
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CnpjMaskDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
39
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CnpjMaskDirective, selector: "[cnpjMask]", inputs: { enabled: ["cnpjMask", "enabled"] }, host: { listeners: { "input": "onInputChange($event)" } }, ngImport: i0 }); }
40
+ }
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CnpjMaskDirective, decorators: [{
42
+ type: Directive,
43
+ args: [{
44
+ selector: '[cnpjMask]',
45
+ }]
46
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { enabled: [{
47
+ type: Input,
48
+ args: ['cnpjMask']
49
+ }], onInputChange: [{
50
+ type: HostListener,
51
+ args: ['input', ['$event']]
52
+ }] } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY25wai1tYXNrLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpYi1wb3J0YWwtYW5ndWxhci9zcmMvbGliL2RpcmVjdGl2ZS9jbnBqLW1hc2suZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsWUFBWSxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQzs7QUFLdEYsTUFBTSxPQUFPLGlCQUFpQjtJQUcxQixZQUFvQixFQUFjLEVBQVUsUUFBbUI7UUFBM0MsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQUFVLGFBQVEsR0FBUixRQUFRLENBQVc7UUFGNUMsWUFBTyxHQUFZLEtBQUssQ0FBQyxDQUFDLDZDQUE2QztJQUV2QixDQUFDO0lBR3BFLGFBQWEsQ0FBQyxLQUFVO1FBQ3BCLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTztZQUFFLE9BQU8sQ0FBQyxpREFBaUQ7UUFFNUUsaUVBQWlFO1FBQ2pFLElBQUksWUFBWSxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWxFLCtDQUErQztRQUMvQyxJQUFJLFlBQVksQ0FBQyxNQUFNLEdBQUcsRUFBRSxFQUFFO1lBQzFCLFlBQVksR0FBRyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztTQUM1QztRQUVELDJCQUEyQjtRQUMzQixNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRXJELDBDQUEwQztRQUMxQyxJQUFJLGNBQWMsS0FBSyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUU7WUFDaEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLEVBQUUsT0FBTyxFQUFFLGNBQWMsQ0FBQyxDQUFDO1lBRTFFLHFEQUFxRDtZQUNyRCxJQUFJLEtBQUssQ0FBQyxNQUFNLENBQUMsYUFBYSxFQUFFO2dCQUM1QixNQUFNLFFBQVEsR0FBRyxJQUFJLEtBQUssQ0FBQyxPQUFPLEVBQUUsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQkFDdkQsS0FBSyxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDeEM7U0FDSjtJQUNMLENBQUM7SUFFRCxVQUFVLENBQUMsS0FBYTtRQUNwQixrREFBa0Q7UUFDbEQsT0FBTyxLQUFLO2FBQ1AsT0FBTyxDQUFDLGFBQWEsRUFBRSxPQUFPLENBQUM7YUFDL0IsT0FBTyxDQUFDLGFBQWEsRUFBRSxPQUFPLENBQUM7YUFDL0IsT0FBTyxDQUFDLG9CQUFvQixFQUFFLFVBQVUsQ0FBQzthQUN6QyxPQUFPLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDN0MsQ0FBQzsrR0F2Q1EsaUJBQWlCO21HQUFqQixpQkFBaUI7OzRGQUFqQixpQkFBaUI7a0JBSDdCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFlBQVk7aUJBQ3pCO3lIQUVzQixPQUFPO3NCQUF6QixLQUFLO3VCQUFDLFVBQVU7Z0JBS2pCLGFBQWE7c0JBRFosWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tjbnBqTWFza10nLFxufSlcbmV4cG9ydCBjbGFzcyBDbnBqTWFza0RpcmVjdGl2ZSB7XG4gICAgQElucHV0KCdjbnBqTWFzaycpIGVuYWJsZWQ6IGJvb2xlYW4gPSBmYWxzZTsgLy8gRGVmaW5lIGNvbW8gb3BjaW9uYWwgZSBwYWRyw6NvIGRlc2FiaWxpdGFkb1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZiwgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyKSB7IH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2lucHV0JywgWyckZXZlbnQnXSlcbiAgICBvbklucHV0Q2hhbmdlKGV2ZW50OiBhbnkpIHtcbiAgICAgICAgaWYgKCF0aGlzLmVuYWJsZWQpIHJldHVybjsgLy8gTsOjbyBhcGxpY2EgYSBtw6FzY2FyYSBzZSBuw6NvIGVzdGl2ZXIgaGFiaWxpdGFkYVxuXG4gICAgICAgIC8vIE9idMOpbSBvIHZhbG9yIGF0dWFsIGUgcmVtb3ZlIHRvZG9zIG9zIGNhcmFjdGVyZXMgbsOjbyBudW3DqXJpY29zXG4gICAgICAgIGxldCBpbml0aWFsVmFsdWUgPSB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQudmFsdWUucmVwbGFjZSgvXFxEL2csICcnKTtcblxuICAgICAgICAvLyBMaW1pdGEgbyBuw7ptZXJvIGRlIGNhcmFjdGVyZXMgYSAxNCBwYXJhIENOUEpcbiAgICAgICAgaWYgKGluaXRpYWxWYWx1ZS5sZW5ndGggPiAxNCkge1xuICAgICAgICAgICAgaW5pdGlhbFZhbHVlID0gaW5pdGlhbFZhbHVlLnNsaWNlKDAsIDE0KTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEFwbGljYSBhIG3DoXNjYXJhIGRlIENOUEpcbiAgICAgICAgY29uc3QgZm9ybWF0dGVkVmFsdWUgPSB0aGlzLmZvcm1hdENucGooaW5pdGlhbFZhbHVlKTtcblxuICAgICAgICAvLyBBdHVhbGl6YSBvIHZhbG9yIGRvIGlucHV0IHNlIG5lY2Vzc8OhcmlvXG4gICAgICAgIGlmIChmb3JtYXR0ZWRWYWx1ZSAhPT0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLnJlbmRlcmVyLnNldFByb3BlcnR5KHRoaXMuZWwubmF0aXZlRWxlbWVudCwgJ3ZhbHVlJywgZm9ybWF0dGVkVmFsdWUpO1xuXG4gICAgICAgICAgICAvLyBEaXNwYXJhIHVtIGV2ZW50byBkZSBpbnB1dCBwYXJhIGF0dWFsaXphciBvIG1vZGVsb1xuICAgICAgICAgICAgaWYgKGV2ZW50LnRhcmdldC5kaXNwYXRjaEV2ZW50KSB7XG4gICAgICAgICAgICAgICAgY29uc3QgbmV3RXZlbnQgPSBuZXcgRXZlbnQoJ2lucHV0JywgeyBidWJibGVzOiB0cnVlIH0pO1xuICAgICAgICAgICAgICAgIGV2ZW50LnRhcmdldC5kaXNwYXRjaEV2ZW50KG5ld0V2ZW50KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIGZvcm1hdENucGoodmFsdWU6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgICAgIC8vIEFwbGljYSBhIGZvcm1hdGHDp8OjbyBkZSBDTlBKOiAxMi4zNDUuNjc4LzAwMDEtMDBcbiAgICAgICAgcmV0dXJuIHZhbHVlXG4gICAgICAgICAgICAucmVwbGFjZSgvKFxcZHsyfSkoXFxkKS8sICckMS4kMicpXG4gICAgICAgICAgICAucmVwbGFjZSgvKFxcZHszfSkoXFxkKS8sICckMS4kMicpXG4gICAgICAgICAgICAucmVwbGFjZSgvKFxcZHszfSkoXFxkezR9KShcXGQpLywgJyQxLyQyLSQzJylcbiAgICAgICAgICAgIC5yZXBsYWNlKC8oXFxkezR9KShcXGR7Mn0pJC8sICckMS0kMicpO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,52 @@
1
+ import { Directive, HostListener, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class CpfMaskDirective {
4
+ constructor(el, renderer) {
5
+ this.el = el;
6
+ this.renderer = renderer;
7
+ this.enabled = false; // Define como opcional e padrão desabilitado
8
+ }
9
+ onInputChange(event) {
10
+ if (!this.enabled)
11
+ return;
12
+ // Obtém o valor atual e remove todos os caracteres não numéricos
13
+ let initialValue = this.el.nativeElement.value.replace(/\D/g, '');
14
+ // Limita o número de caracteres a 11 para CPF
15
+ if (initialValue.length > 11) {
16
+ initialValue = initialValue.slice(0, 11);
17
+ }
18
+ // Aplica a máscara de CPF
19
+ const formattedValue = this.formatCpf(initialValue);
20
+ // Atualiza o valor do input se necessário
21
+ if (formattedValue !== this.el.nativeElement.value) {
22
+ this.renderer.setProperty(this.el.nativeElement, 'value', formattedValue);
23
+ // Dispara um evento de input para atualizar o modelo
24
+ if (event.target.dispatchEvent) {
25
+ const newEvent = new Event('input', { bubbles: true });
26
+ event.target.dispatchEvent(newEvent);
27
+ }
28
+ }
29
+ }
30
+ formatCpf(value) {
31
+ // Aplica a formatação de CPF: 123.456.789-00
32
+ return value
33
+ .replace(/(\d{3})(\d)/, '$1.$2')
34
+ .replace(/(\d{3})(\d)/, '$1.$2')
35
+ .replace(/(\d{3})(\d{1,2})$/, '$1-$2');
36
+ }
37
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CpfMaskDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
38
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CpfMaskDirective, selector: "[cpfMask]", inputs: { enabled: ["cpfMask", "enabled"] }, host: { listeners: { "input": "onInputChange($event)" } }, ngImport: i0 }); }
39
+ }
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CpfMaskDirective, decorators: [{
41
+ type: Directive,
42
+ args: [{
43
+ selector: '[cpfMask]',
44
+ }]
45
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { enabled: [{
46
+ type: Input,
47
+ args: ['cpfMask']
48
+ }], onInputChange: [{
49
+ type: HostListener,
50
+ args: ['input', ['$event']]
51
+ }] } });
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BmLW1hc2suZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGliLXBvcnRhbC1hbmd1bGFyL3NyYy9saWIvZGlyZWN0aXZlL2NwZi1tYXNrLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7O0FBS3RGLE1BQU0sT0FBTyxnQkFBZ0I7SUFHekIsWUFBb0IsRUFBYyxFQUFVLFFBQW1CO1FBQTNDLE9BQUUsR0FBRixFQUFFLENBQVk7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBRjdDLFlBQU8sR0FBWSxLQUFLLENBQUMsQ0FBQyw2Q0FBNkM7SUFFdEIsQ0FBQztJQUdwRSxhQUFhLENBQUMsS0FBVTtRQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU87WUFBRSxPQUFPO1FBRTFCLGlFQUFpRTtRQUNqRSxJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVsRSw4Q0FBOEM7UUFDOUMsSUFBSSxZQUFZLENBQUMsTUFBTSxHQUFHLEVBQUUsRUFBRTtZQUMxQixZQUFZLEdBQUcsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7U0FDNUM7UUFFRCwwQkFBMEI7UUFDMUIsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUVwRCwwQ0FBMEM7UUFDMUMsSUFBSSxjQUFjLEtBQUssSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFO1lBQ2hELElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLE9BQU8sRUFBRSxjQUFjLENBQUMsQ0FBQztZQUUxRSxxREFBcUQ7WUFDckQsSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLGFBQWEsRUFBRTtnQkFDNUIsTUFBTSxRQUFRLEdBQUcsSUFBSSxLQUFLLENBQUMsT0FBTyxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7Z0JBQ3ZELEtBQUssQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO2FBQ3hDO1NBQ0o7SUFDTCxDQUFDO0lBRUQsU0FBUyxDQUFDLEtBQWE7UUFDbkIsNkNBQTZDO1FBQzdDLE9BQU8sS0FBSzthQUNQLE9BQU8sQ0FBQyxhQUFhLEVBQUUsT0FBTyxDQUFDO2FBQy9CLE9BQU8sQ0FBQyxhQUFhLEVBQUUsT0FBTyxDQUFDO2FBQy9CLE9BQU8sQ0FBQyxtQkFBbUIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMvQyxDQUFDOytHQXRDUSxnQkFBZ0I7bUdBQWhCLGdCQUFnQjs7NEZBQWhCLGdCQUFnQjtrQkFINUIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsV0FBVztpQkFDeEI7eUhBRXFCLE9BQU87c0JBQXhCLEtBQUs7dUJBQUMsU0FBUztnQkFLaEIsYUFBYTtzQkFEWixZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBJbnB1dCwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2NwZk1hc2tdJyxcbn0pXG5leHBvcnQgY2xhc3MgQ3BmTWFza0RpcmVjdGl2ZSB7XG4gICAgQElucHV0KCdjcGZNYXNrJykgZW5hYmxlZDogYm9vbGVhbiA9IGZhbHNlOyAvLyBEZWZpbmUgY29tbyBvcGNpb25hbCBlIHBhZHLDo28gZGVzYWJpbGl0YWRvXG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsOiBFbGVtZW50UmVmLCBwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHsgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcignaW5wdXQnLCBbJyRldmVudCddKVxuICAgIG9uSW5wdXRDaGFuZ2UoZXZlbnQ6IGFueSkge1xuICAgICAgICBpZiAoIXRoaXMuZW5hYmxlZCkgcmV0dXJuO1xuXG4gICAgICAgIC8vIE9idMOpbSBvIHZhbG9yIGF0dWFsIGUgcmVtb3ZlIHRvZG9zIG9zIGNhcmFjdGVyZXMgbsOjbyBudW3DqXJpY29zXG4gICAgICAgIGxldCBpbml0aWFsVmFsdWUgPSB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQudmFsdWUucmVwbGFjZSgvXFxEL2csICcnKTtcblxuICAgICAgICAvLyBMaW1pdGEgbyBuw7ptZXJvIGRlIGNhcmFjdGVyZXMgYSAxMSBwYXJhIENQRlxuICAgICAgICBpZiAoaW5pdGlhbFZhbHVlLmxlbmd0aCA+IDExKSB7XG4gICAgICAgICAgICBpbml0aWFsVmFsdWUgPSBpbml0aWFsVmFsdWUuc2xpY2UoMCwgMTEpO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gQXBsaWNhIGEgbcOhc2NhcmEgZGUgQ1BGXG4gICAgICAgIGNvbnN0IGZvcm1hdHRlZFZhbHVlID0gdGhpcy5mb3JtYXRDcGYoaW5pdGlhbFZhbHVlKTtcblxuICAgICAgICAvLyBBdHVhbGl6YSBvIHZhbG9yIGRvIGlucHV0IHNlIG5lY2Vzc8OhcmlvXG4gICAgICAgIGlmIChmb3JtYXR0ZWRWYWx1ZSAhPT0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLnJlbmRlcmVyLnNldFByb3BlcnR5KHRoaXMuZWwubmF0aXZlRWxlbWVudCwgJ3ZhbHVlJywgZm9ybWF0dGVkVmFsdWUpO1xuXG4gICAgICAgICAgICAvLyBEaXNwYXJhIHVtIGV2ZW50byBkZSBpbnB1dCBwYXJhIGF0dWFsaXphciBvIG1vZGVsb1xuICAgICAgICAgICAgaWYgKGV2ZW50LnRhcmdldC5kaXNwYXRjaEV2ZW50KSB7XG4gICAgICAgICAgICAgICAgY29uc3QgbmV3RXZlbnQgPSBuZXcgRXZlbnQoJ2lucHV0JywgeyBidWJibGVzOiB0cnVlIH0pO1xuICAgICAgICAgICAgICAgIGV2ZW50LnRhcmdldC5kaXNwYXRjaEV2ZW50KG5ld0V2ZW50KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIGZvcm1hdENwZih2YWx1ZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICAgICAgLy8gQXBsaWNhIGEgZm9ybWF0YcOnw6NvIGRlIENQRjogMTIzLjQ1Ni43ODktMDBcbiAgICAgICAgcmV0dXJuIHZhbHVlXG4gICAgICAgICAgICAucmVwbGFjZSgvKFxcZHszfSkoXFxkKS8sICckMS4kMicpXG4gICAgICAgICAgICAucmVwbGFjZSgvKFxcZHszfSkoXFxkKS8sICckMS4kMicpXG4gICAgICAgICAgICAucmVwbGFjZSgvKFxcZHszfSkoXFxkezEsMn0pJC8sICckMS0kMicpO1xuICAgIH1cbn1cbiJdfQ==