@stiunb/unb-lib-components 18.0.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +18 -0
- package/esm2022/lib/services/unb-auth.service.mjs +57 -0
- package/esm2022/lib/unb-mensagem/unb-mensagem.component.mjs +82 -0
- package/esm2022/lib/unb-mensagem/unb-mensagem.module.mjs +26 -0
- package/esm2022/lib/unb-mensagem/unb-mensagem.service.mjs +61 -0
- package/esm2022/lib/unb-mensagem/unb-message.model.mjs +3 -0
- package/esm2022/lib/unb-nav-bar/unb-nav-bar.component.mjs +53 -0
- package/esm2022/lib/unb-nav-bar/unb-nav-bar.module.mjs +52 -0
- package/esm2022/lib/unb-pessoa/pessoa-tabelas-apoio.mjs +30 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.mjs +122 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.mjs +140 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.mjs +144 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-list.mjs +139 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-form/unb-pessoa-form.component.mjs +166 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-email.model.mjs +5 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-endereco.model.mjs +5 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-escolaridade.model.mjs +6 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-estado-civil.model.mjs +6 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-municipio.mjs +3 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-pais.mjs +3 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-raca-cor.mjs +3 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-telefone.model.mjs +9 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa.model.mjs +6 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-pesquisar/unb-pessoa-pesquisar.component.mjs +229 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.mjs +102 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.mjs +140 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa.module.mjs +128 -0
- package/esm2022/lib/unb-pessoa/unb-pessoa.service.mjs +157 -0
- package/esm2022/lib/unb-pessoa/unb-tipo-pessoa.enum.mjs +7 -0
- package/esm2022/lib/unb-usuario/oidc-decoded-token.mjs +2 -0
- package/esm2022/lib/unb-usuario/oidc-user-data.mjs +2 -0
- package/esm2022/lib/unb-usuario/unb-usuario.component.mjs +38 -0
- package/esm2022/lib/unb-usuario/unb-usuario.model.mjs +9 -0
- package/esm2022/lib/unb-usuario/unb-usuario.module.mjs +65 -0
- package/esm2022/lib/utils/unb-utils.mjs +76 -0
- package/esm2022/public-api.mjs +34 -0
- package/esm2022/unb-lib-components.mjs +5 -0
- package/fesm2022/unb-lib-components.mjs +1923 -0
- package/fesm2022/unb-lib-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/services/unb-auth.service.d.ts +17 -0
- package/lib/unb-mensagem/unb-mensagem.component.d.ts +35 -0
- package/lib/unb-mensagem/unb-mensagem.module.d.ts +10 -0
- package/lib/unb-mensagem/unb-mensagem.service.d.ts +36 -0
- package/lib/unb-mensagem/unb-message.model.d.ts +6 -0
- package/lib/unb-nav-bar/unb-nav-bar.component.d.ts +19 -0
- package/lib/unb-nav-bar/unb-nav-bar.module.d.ts +16 -0
- package/lib/unb-pessoa/pessoa-tabelas-apoio.d.ts +5 -0
- package/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.d.ts +34 -0
- package/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.d.ts +31 -0
- package/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.d.ts +36 -0
- package/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-list.d.ts +29 -0
- package/lib/unb-pessoa/unb-pessoa-form/unb-pessoa-form.component.d.ts +56 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-email.model.d.ts +13 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-endereco.model.d.ts +22 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-escolaridade.model.d.ts +6 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-estado-civil.model.d.ts +6 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-municipio.d.ts +8 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-pais.d.ts +7 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-raca-cor.d.ts +4 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-telefone.model.d.ts +17 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa.model.d.ts +69 -0
- package/lib/unb-pessoa/unb-pessoa-pesquisar/unb-pessoa-pesquisar.component.d.ts +39 -0
- package/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.d.ts +34 -0
- package/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.d.ts +31 -0
- package/lib/unb-pessoa/unb-pessoa.module.d.ts +35 -0
- package/lib/unb-pessoa/unb-pessoa.service.d.ts +59 -0
- package/lib/unb-pessoa/unb-tipo-pessoa.enum.d.ts +5 -0
- package/lib/unb-usuario/oidc-decoded-token.d.ts +29 -0
- package/lib/unb-usuario/oidc-user-data.d.ts +9 -0
- package/lib/unb-usuario/unb-usuario.component.d.ts +17 -0
- package/lib/unb-usuario/unb-usuario.model.d.ts +6 -0
- package/lib/unb-usuario/unb-usuario.module.d.ts +18 -0
- package/lib/utils/unb-utils.d.ts +7 -0
- package/package.json +28 -0
- package/public-api.d.ts +28 -0
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { UnbPessoaEmail } from '../unb-pessoa-models/unb-pessoa-email.model';
|
|
3
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/material/snack-bar";
|
|
6
|
+
import * as i2 from "../unb-pessoa.service";
|
|
7
|
+
import * as i3 from "@angular/material/dialog";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "@angular/forms";
|
|
10
|
+
import * as i6 from "@angular/material/button";
|
|
11
|
+
import * as i7 from "@angular/material/form-field";
|
|
12
|
+
import * as i8 from "@angular/material/input";
|
|
13
|
+
import * as i9 from "@angular/material/select";
|
|
14
|
+
import * as i10 from "@angular/material/core";
|
|
15
|
+
export class UnbPessoaEmailFormComponent {
|
|
16
|
+
constructor(snackBar, service, dialogRef, data) {
|
|
17
|
+
this.snackBar = snackBar;
|
|
18
|
+
this.service = service;
|
|
19
|
+
this.dialogRef = dialogRef;
|
|
20
|
+
this.data = data;
|
|
21
|
+
this.email = new UnbPessoaEmail();
|
|
22
|
+
this.listaTipoEmail = [];
|
|
23
|
+
this.email = JSON.parse(JSON.stringify(data.email)); // O e-mail específico para edição
|
|
24
|
+
// Verifique se a lista de e-mails foi passada e atribua-a
|
|
25
|
+
if (data.emailsList) {
|
|
26
|
+
this.emailsList = JSON.parse(JSON.stringify(data.emailsList)); // Faça uma cópia profunda se for manipular
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
this.emailsList = []; // Inicialize como vazio se não for passada
|
|
30
|
+
}
|
|
31
|
+
if (!this.email) {
|
|
32
|
+
this.email = new UnbPessoaEmail();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.tipoEmail = this.service.getTipoEmail();
|
|
37
|
+
// Inscreve para guardar a lista em uma variável comum
|
|
38
|
+
this.tipoEmail.subscribe(lista => {
|
|
39
|
+
this.listaTipoEmail = lista;
|
|
40
|
+
// Se já tiver tipoEmailCodigo, preenche o nome correspondente
|
|
41
|
+
if (this.email.tipoEmailCodigo != null) {
|
|
42
|
+
const tipoEncontrado = lista.find(t => t.codigo === this.email.tipoEmailCodigo);
|
|
43
|
+
if (tipoEncontrado) {
|
|
44
|
+
this.email.tipo = tipoEncontrado.denominacao;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else if (this.email.tipo) {
|
|
48
|
+
const tipoEncontrado = lista.find(t => t.denominacao?.toLowerCase() === this.email.tipo?.toLowerCase());
|
|
49
|
+
if (tipoEncontrado) {
|
|
50
|
+
this.email.tipoEmailCodigo = tipoEncontrado.codigo;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
salvar(form) {
|
|
56
|
+
if (form.invalid) {
|
|
57
|
+
this.openSnackBar('Existem erros no formulário, por favor, verificar.');
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
if (this.validar(this.email) == false)
|
|
61
|
+
return;
|
|
62
|
+
this.emailSalvo = this.email;
|
|
63
|
+
this.salvarclose();
|
|
64
|
+
}
|
|
65
|
+
compararTipos(t1, t2) {
|
|
66
|
+
return t1 && t2 && t1 === t2;
|
|
67
|
+
}
|
|
68
|
+
onTipoSelecionado(codigoSelecionado) {
|
|
69
|
+
const tipoSelecionado = this.listaTipoEmail.find(t => t.codigo === codigoSelecionado);
|
|
70
|
+
if (tipoSelecionado) {
|
|
71
|
+
this.email.tipo = tipoSelecionado.denominacao;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Valida o objeto de e-mail.
|
|
76
|
+
* Retorna true se o e-mail for válido, false caso contrário.
|
|
77
|
+
*/
|
|
78
|
+
validar(emailToValidate) {
|
|
79
|
+
// 1. Validação de campo obrigatório
|
|
80
|
+
if (!emailToValidate.email || emailToValidate.email.trim() === '') {
|
|
81
|
+
this.openSnackBar("E-mail é um campo obrigatório.");
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
// 2. Validação de formato de e-mail
|
|
85
|
+
const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/;
|
|
86
|
+
if (!emailRegex.test(emailToValidate.email)) {
|
|
87
|
+
this.openSnackBar("Digite um E-mail válido.");
|
|
88
|
+
return false;
|
|
89
|
+
}
|
|
90
|
+
// 3. Validação de e-mail duplicado na lista existente
|
|
91
|
+
// Filtra a lista para excluir o próprio e-mail que está sendo editado (se ele tiver um 'codigo')
|
|
92
|
+
const isDuplicate = this.emailsList.some(existingEmail => existingEmail.email?.toLowerCase() === emailToValidate.email?.toLowerCase() &&
|
|
93
|
+
existingEmail.codigo !== emailToValidate.codigo // Ignora o próprio e-mail se estiver sendo editado
|
|
94
|
+
);
|
|
95
|
+
if (isDuplicate) {
|
|
96
|
+
this.openSnackBar("Este e-mail já existe na lista.");
|
|
97
|
+
return false;
|
|
98
|
+
}
|
|
99
|
+
return true;
|
|
100
|
+
}
|
|
101
|
+
close() {
|
|
102
|
+
this.dialogRef.close(null);
|
|
103
|
+
}
|
|
104
|
+
salvarclose() {
|
|
105
|
+
this.dialogRef.close(this.emailSalvo);
|
|
106
|
+
}
|
|
107
|
+
openSnackBar(message) {
|
|
108
|
+
this.snackBar.open(message, 'x', {
|
|
109
|
+
duration: 5000,
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEmailFormComponent, deps: [{ token: i1.MatSnackBar }, { token: i2.UnBPessoaService }, { token: i3.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
113
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbPessoaEmailFormComponent, selector: "lib-unb-pessoa-email-form", ngImport: i0, template: "<h1 mat-dialog-title>Cadastro de E-mail</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n <mat-dialog-content>\r\n <div class=\"form-container\">\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>E-mail</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"email.email\" name=\"emailValue\" #emailValue=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Tipo</mat-label>\r\n <mat-select [(ngModel)]=\"email.tipoEmailCodigo\" [compareWith]=\"compararTipos\" name=\"tipoEmailCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of tipoEmail | async\" [value]=\"tipo.codigo\">\r\n {{tipo.denominacao}}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n </div>\r\n </mat-dialog-content>\r\n\r\n <mat-dialog-actions align=\"end\">\r\n <button mat-stroked-button type=\"button\" color=\"warn\" (click)=\"close()\">Fechar</button>\r\n <button mat-flat-button type=\"submit\" color=\"primary\">Salvar</button>\r\n </mat-dialog-actions>\r\n</form>", styles: [".card-actions-buttons{display:flex;gap:5px;flex-wrap:wrap}.form-container{display:flex;flex-wrap:wrap;column-gap:10px;margin:10px}@media (max-width: 1000px){.form-container{flex-direction:column;gap:5px}}.break{flex-basis:100%;height:0}.form-5{flex:1 1 5%}.inline-table-container{display:flex;align-items:center;justify-content:space-between;padding:5px}@media (max-width: 600px){.form-5,.form-10,.form-15{flex:1 1 100%}}.form-10{flex:1 1 10%}.form-15{flex:1 1 15%}.form-20{flex:1 1 20%}.form-25{flex:1 1 25%}.form-30{flex:1 1 30%}.form-35{flex:1 1 35%}.form-40{flex:1 1 40%}.form-45{flex:1 1 45%}.form-50{flex:1 1 50%}.form-60{flex:1 1 60%}.form-70{flex:1 1 70%}.form-80{flex:1 1 80%}.form-100{flex:1 1 100%;min-width:250px}.botoes-container{display:flex;gap:5px}@media (max-width: 600px){.botoes-container{margin-bottom:10px}.botoes-container button{flex:1;max-width:50%}}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "directive", type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i3.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i3.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i3.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i9.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i10.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] }); }
|
|
114
|
+
}
|
|
115
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEmailFormComponent, decorators: [{
|
|
116
|
+
type: Component,
|
|
117
|
+
args: [{ standalone: false, selector: 'lib-unb-pessoa-email-form', template: "<h1 mat-dialog-title>Cadastro de E-mail</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n <mat-dialog-content>\r\n <div class=\"form-container\">\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>E-mail</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"email.email\" name=\"emailValue\" #emailValue=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Tipo</mat-label>\r\n <mat-select [(ngModel)]=\"email.tipoEmailCodigo\" [compareWith]=\"compararTipos\" name=\"tipoEmailCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of tipoEmail | async\" [value]=\"tipo.codigo\">\r\n {{tipo.denominacao}}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n </div>\r\n </mat-dialog-content>\r\n\r\n <mat-dialog-actions align=\"end\">\r\n <button mat-stroked-button type=\"button\" color=\"warn\" (click)=\"close()\">Fechar</button>\r\n <button mat-flat-button type=\"submit\" color=\"primary\">Salvar</button>\r\n </mat-dialog-actions>\r\n</form>", styles: [".card-actions-buttons{display:flex;gap:5px;flex-wrap:wrap}.form-container{display:flex;flex-wrap:wrap;column-gap:10px;margin:10px}@media (max-width: 1000px){.form-container{flex-direction:column;gap:5px}}.break{flex-basis:100%;height:0}.form-5{flex:1 1 5%}.inline-table-container{display:flex;align-items:center;justify-content:space-between;padding:5px}@media (max-width: 600px){.form-5,.form-10,.form-15{flex:1 1 100%}}.form-10{flex:1 1 10%}.form-15{flex:1 1 15%}.form-20{flex:1 1 20%}.form-25{flex:1 1 25%}.form-30{flex:1 1 30%}.form-35{flex:1 1 35%}.form-40{flex:1 1 40%}.form-45{flex:1 1 45%}.form-50{flex:1 1 50%}.form-60{flex:1 1 60%}.form-70{flex:1 1 70%}.form-80{flex:1 1 80%}.form-100{flex:1 1 100%;min-width:250px}.botoes-container{display:flex;gap:5px}@media (max-width: 600px){.botoes-container{margin-bottom:10px}.botoes-container button{flex:1;max-width:50%}}\n"] }]
|
|
118
|
+
}], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.MatDialogRef }, { type: undefined, decorators: [{
|
|
119
|
+
type: Inject,
|
|
120
|
+
args: [MAT_DIALOG_DATA]
|
|
121
|
+
}] }] });
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unb-pessoa-email-form.js","sourceRoot":"","sources":["../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.ts","../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject } from '@angular/core';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { Observable } from 'rxjs';\r\nimport { UnbPessoaEmail, UnbPessoaEmailTipo } from '../unb-pessoa-models/unb-pessoa-email.model';\r\nimport { UnBPessoaService } from '../unb-pessoa.service';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { NgForm } from '@angular/forms';\r\n\r\n\r\n@Component({\r\n  standalone: false,\r\n  selector: 'lib-unb-pessoa-email-form',\r\n  templateUrl: './unb-pessoa-email-form.html',\r\n  styleUrl: './unb-pessoa-email-form.css'\r\n})\r\nexport class UnbPessoaEmailFormComponent implements OnInit {\r\n  emailSalvo!: UnbPessoaEmail;\r\n  email = new UnbPessoaEmail();\r\n  emailsList: UnbPessoaEmail[];\r\n  tipoEmail!: Observable<UnbPessoaEmailTipo[]>;\r\n  listaTipoEmail: UnbPessoaEmailTipo[] = [];\r\n\r\n  constructor(private snackBar: MatSnackBar, private service: UnBPessoaService, public dialogRef: MatDialogRef<UnbPessoaEmailFormComponent>, @Inject(MAT_DIALOG_DATA) public data: any) {\r\n    this.email = JSON.parse(JSON.stringify(data.email)); // O e-mail específico para edição\r\n\r\n    // Verifique se a lista de e-mails foi passada e atribua-a\r\n    if (data.emailsList) {\r\n      this.emailsList = JSON.parse(JSON.stringify(data.emailsList)); // Faça uma cópia profunda se for manipular\r\n    } else {\r\n      this.emailsList = []; // Inicialize como vazio se não for passada\r\n    }\r\n\r\n    if (!this.email) {\r\n      this.email = new UnbPessoaEmail();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.tipoEmail = this.service.getTipoEmail();\r\n    // Inscreve para guardar a lista em uma variável comum\r\n    this.tipoEmail.subscribe(lista => {\r\n      this.listaTipoEmail = lista;\r\n\r\n      // Se já tiver tipoEmailCodigo, preenche o nome correspondente\r\n      if (this.email.tipoEmailCodigo != null) {\r\n        const tipoEncontrado = lista.find(t => t.codigo === this.email.tipoEmailCodigo);\r\n        if (tipoEncontrado) {\r\n          this.email.tipo = tipoEncontrado.denominacao;\r\n        }\r\n      } else if (this.email.tipo) {\r\n        const tipoEncontrado = lista.find(\r\n          t => t.denominacao?.toLowerCase() === this.email.tipo?.toLowerCase()\r\n        );\r\n        if (tipoEncontrado) {\r\n          this.email.tipoEmailCodigo = tipoEncontrado.codigo!;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  salvar(form: NgForm) {\r\n    if (form.invalid) {\r\n      this.openSnackBar('Existem erros no formulário, por favor, verificar.');\r\n      return;\r\n    }\r\n    if (this.validar(this.email) == false) return;\r\n\r\n    this.emailSalvo = this.email;\r\n    this.salvarclose()\r\n  }\r\n\r\n  compararTipos(t1: any, t2: any): boolean {\r\n    return t1 && t2 && t1 === t2;\r\n  }\r\n\r\n  onTipoSelecionado(codigoSelecionado: number) {\r\n    const tipoSelecionado = this.listaTipoEmail.find(t => t.codigo === codigoSelecionado);\r\n    if (tipoSelecionado) {\r\n      this.email.tipo = tipoSelecionado.denominacao;\r\n    }\r\n  }\r\n  \r\n\r\n /**\r\n   * Valida o objeto de e-mail.\r\n   * Retorna true se o e-mail for válido, false caso contrário.\r\n   */\r\n  validar(emailToValidate: UnbPessoaEmail): boolean {\r\n    // 1. Validação de campo obrigatório\r\n    if (!emailToValidate.email || emailToValidate.email.trim() === '') {\r\n      this.openSnackBar(\"E-mail é um campo obrigatório.\");\r\n      return false;\r\n    }\r\n\r\n    // 2. Validação de formato de e-mail\r\n    const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n    if (!emailRegex.test(emailToValidate.email)) {\r\n      this.openSnackBar(\"Digite um E-mail válido.\");\r\n      return false;\r\n    }\r\n\r\n    // 3. Validação de e-mail duplicado na lista existente\r\n    // Filtra a lista para excluir o próprio e-mail que está sendo editado (se ele tiver um 'codigo')\r\n    const isDuplicate = this.emailsList.some(existingEmail =>\r\n      existingEmail.email?.toLowerCase() === emailToValidate.email?.toLowerCase() &&\r\n      existingEmail.codigo !== emailToValidate.codigo // Ignora o próprio e-mail se estiver sendo editado\r\n    );\r\n\r\n    if (isDuplicate) {\r\n      this.openSnackBar(\"Este e-mail já existe na lista.\");\r\n      return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  close() {\r\n    this.dialogRef.close(null);\r\n  }\r\n\r\n  salvarclose() {\r\n    this.dialogRef.close(this.emailSalvo);\r\n  }\r\n\r\n  openSnackBar(message: string) {\r\n    this.snackBar.open(message, 'x', {\r\n      duration: 5000,\r\n    });\r\n  }\r\n\r\n}","<h1 mat-dialog-title>Cadastro de E-mail</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n  <mat-dialog-content>\r\n    <div class=\"form-container\">\r\n       <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>E-mail</mat-label>\r\n        <input type=\"text\" matInput [(ngModel)]=\"email.email\" name=\"emailValue\" #emailValue=\"ngModel\" />\r\n      </mat-form-field>\r\n\r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>Tipo</mat-label>\r\n        <mat-select [(ngModel)]=\"email.tipoEmailCodigo\" [compareWith]=\"compararTipos\" name=\"tipoEmailCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n          <mat-option *ngFor=\"let tipo of tipoEmail | async\" [value]=\"tipo.codigo\">\r\n            {{tipo.denominacao}}\r\n          </mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n\r\n    </div>\r\n  </mat-dialog-content>\r\n\r\n  <mat-dialog-actions align=\"end\">\r\n    <button mat-stroked-button type=\"button\" color=\"warn\" (click)=\"close()\">Fechar</button>\r\n    <button mat-flat-button type=\"submit\" color=\"primary\">Salvar</button>\r\n  </mat-dialog-actions>\r\n</form>"]}
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { UnbPessoaEmailFormComponent } from './unb-pessoa-email-form';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/material/snack-bar";
|
|
5
|
+
import * as i2 from "../unb-pessoa.service";
|
|
6
|
+
import * as i3 from "@angular/material/dialog";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
import * as i5 from "@angular/material/icon";
|
|
9
|
+
import * as i6 from "@angular/material/button";
|
|
10
|
+
export class UnbPessoaEmailListComponent {
|
|
11
|
+
constructor(snackBar, service, dialog) {
|
|
12
|
+
this.snackBar = snackBar;
|
|
13
|
+
this.service = service;
|
|
14
|
+
this.dialog = dialog;
|
|
15
|
+
this.podeEditar = true;
|
|
16
|
+
this.emails = [];
|
|
17
|
+
this.apiPessoaConfig = { url: '', token: '' };
|
|
18
|
+
this.emailsEmitted = new EventEmitter();
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
this.tipoEmail = this.service.getTipoEmail();
|
|
22
|
+
this.sortAndAssignOrder(); // organiza a lista de emails. As vezes tem ordem duplicada ou faltando.
|
|
23
|
+
}
|
|
24
|
+
excluir(email) {
|
|
25
|
+
}
|
|
26
|
+
editar(email) {
|
|
27
|
+
this.openFormDialog(email);
|
|
28
|
+
}
|
|
29
|
+
moverParaCima(index) {
|
|
30
|
+
if (index <= 0)
|
|
31
|
+
return;
|
|
32
|
+
[this.emails[index - 1], this.emails[index]] = [this.emails[index], this.emails[index - 1]];
|
|
33
|
+
this.atualizarOrdem();
|
|
34
|
+
}
|
|
35
|
+
moverParaBaixo(index) {
|
|
36
|
+
if (index >= this.emails.length - 1)
|
|
37
|
+
return;
|
|
38
|
+
[this.emails[index], this.emails[index + 1]] = [this.emails[index + 1], this.emails[index]];
|
|
39
|
+
this.atualizarOrdem();
|
|
40
|
+
}
|
|
41
|
+
atualizarOrdem() {
|
|
42
|
+
this.emails.forEach((email, idx) => {
|
|
43
|
+
email.ordem = idx + 1;
|
|
44
|
+
});
|
|
45
|
+
this.emailsEmitted.emit(this.emails);
|
|
46
|
+
}
|
|
47
|
+
openFormDialog(emailToEdit) {
|
|
48
|
+
const dialogRef = this.dialog.open(UnbPessoaEmailFormComponent, {
|
|
49
|
+
width: '900px',
|
|
50
|
+
data: {
|
|
51
|
+
email: emailToEdit, // E-mail a ser editado ou vazio para novo
|
|
52
|
+
emailsList: this.emails // A sua lista COMPLETA de e-mails
|
|
53
|
+
},
|
|
54
|
+
});
|
|
55
|
+
dialogRef.afterClosed().subscribe(result => {
|
|
56
|
+
if (result) {
|
|
57
|
+
const index = this.emails.findIndex(e => e.codigo === result.codigo);
|
|
58
|
+
if (result.codigo && index > -1) {
|
|
59
|
+
// Atualiza e-mail existente
|
|
60
|
+
this.emails[index] = result;
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
// Adiciona novo e-mail (gera ordem automaticamente se quiser)
|
|
64
|
+
result.ordem = this.emails.length + 1;
|
|
65
|
+
this.emails.push(result);
|
|
66
|
+
}
|
|
67
|
+
// Emite lista atualizada
|
|
68
|
+
this.emailsEmitted.emit(this.emails);
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
sortAndAssignOrder() {
|
|
73
|
+
// 1. Crie uma cópia da lista para não modificar a original durante a iteração inicial
|
|
74
|
+
const tempEmails = [...this.emails];
|
|
75
|
+
// 2. Mapeie as ordens existentes para identificar duplicatas e ausentes
|
|
76
|
+
const orderMap = new Map();
|
|
77
|
+
const emailsWithoutOrder = [];
|
|
78
|
+
tempEmails.forEach(email => {
|
|
79
|
+
if (email.ordem !== undefined && email.ordem !== null) {
|
|
80
|
+
if (!orderMap.has(email.ordem)) {
|
|
81
|
+
orderMap.set(email.ordem, []);
|
|
82
|
+
}
|
|
83
|
+
orderMap.get(email.ordem)?.push(email);
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
emailsWithoutOrder.push(email);
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
// 3. Inicialize um Set para rastrear todas as ordens que serão usadas no final
|
|
90
|
+
const finalUsedOrders = new Set();
|
|
91
|
+
// Inicialize o próximo valor de ordem disponível
|
|
92
|
+
let nextAvailableOrder = 0;
|
|
93
|
+
// Função auxiliar para encontrar a próxima ordem disponível
|
|
94
|
+
const getNextAvailableOrder = () => {
|
|
95
|
+
while (finalUsedOrders.has(nextAvailableOrder)) {
|
|
96
|
+
nextAvailableOrder++;
|
|
97
|
+
}
|
|
98
|
+
return nextAvailableOrder++;
|
|
99
|
+
};
|
|
100
|
+
// 4. Processe emails com ordem definida:
|
|
101
|
+
// - A primeira ocorrência de uma ordem a mantém.
|
|
102
|
+
// - Duplicatas recebem uma nova ordem.
|
|
103
|
+
// - Adicione as ordens válidas ao finalUsedOrders.
|
|
104
|
+
this.emails.forEach(email => {
|
|
105
|
+
if (email.ordem !== undefined && email.ordem !== null) {
|
|
106
|
+
if (!finalUsedOrders.has(email.ordem)) {
|
|
107
|
+
// Se a ordem ainda não foi usada, use-a e adicione ao set
|
|
108
|
+
finalUsedOrders.add(email.ordem);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
// Se a ordem já foi usada (é uma duplicata), atribua uma nova
|
|
112
|
+
email.ordem = getNextAvailableOrder();
|
|
113
|
+
finalUsedOrders.add(email.ordem); // Adiciona a nova ordem ao set
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
// 5. Atribua ordens para emails que não tinham ordem definida
|
|
118
|
+
emailsWithoutOrder.forEach(email => {
|
|
119
|
+
email.ordem = getNextAvailableOrder();
|
|
120
|
+
finalUsedOrders.add(email.ordem); // Adiciona a nova ordem ao set
|
|
121
|
+
});
|
|
122
|
+
// 6. Finalmente, ordene a lista completa com as ordens agora únicas
|
|
123
|
+
this.emails.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));
|
|
124
|
+
}
|
|
125
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEmailListComponent, deps: [{ token: i1.MatSnackBar }, { token: i2.UnBPessoaService }, { token: i3.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
126
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbPessoaEmailListComponent, selector: "lib-unb-pessoa-email-list", inputs: { podeEditar: "podeEditar", emails: "emails", apiPessoaConfig: "apiPessoaConfig" }, outputs: { emailsEmitted: "emailsEmitted" }, ngImport: i0, template: "<div class=\"mes-container\">\r\n <div class=\"header-container\">\r\n <div class=\"mes-header\">\r\n <span class=\"titulo\">\r\n {{ emails?.length === 1 ? 'Email Cadastrado' : 'E-mails Cadastrados' }}\r\n </span>\r\n <span class=\"titulo\">({{ emails?.length || 0 }})</span>\r\n </div>\r\n\r\n <button matTooltip=\"Novo Email\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n Cadastrar Novo Email\r\n </button>\r\n </div>\r\n\r\n <!-- Exibe a tabela de despesas somente se houver despesas -->\r\n <table class=\"my-table\" *ngIf=\"emails && emails.length > 0\">\r\n <tr style=\"background-color: #e4e3e3cc;\">\r\n <th style=\"text-align: center;\" >Ordem</th>\r\n <th>E-mail</th>\r\n <th>Tipo</th>\r\n <th style=\"text-align: center;\">A\u00E7\u00F5es</th>\r\n </tr>\r\n\r\n <tr *ngFor=\"let valor of emails; let i = index\" class=\"my-tr\">\r\n <td style=\"width: 5%; text-align: center;\"> \r\n <button *ngIf=\"emails.length > 1 && i > 0\" mat-icon-button aria-label=\"Mover para cima\"\r\n (click)=\"moverParaCima(i)\">\r\n <mat-icon>arrow_upward</mat-icon>\r\n </button>\r\n <button *ngIf=\"emails.length > 1 && i < emails.length - 1\" mat-icon-button aria-label=\"Mover para baixo\"\r\n (click)=\"moverParaBaixo(i)\">\r\n <mat-icon>arrow_downward</mat-icon>\r\n </button>\r\n </td>\r\n <td style=\"width: 50%;\">{{ valor.email }}</td>\r\n <td style=\"width: 20%;\">{{ valor.tipo?.toUpperCase() }}</td>\r\n <td style=\"width: 20%; text-align: center;\">\r\n <button mat-icon-button aria-label=\"Salvar\" color=\"primary\" (click)=\"editar(valor)\">\r\n <mat-icon>edit</mat-icon>\r\n </button>\r\n <button mat-icon-button aria-label=\"Deletar\" color=\"warn\" (click)=\"excluir(valor)\">\r\n <mat-icon>delete</mat-icon>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".mes-container{padding:12px;margin-bottom:2px;border-radius:8px;box-shadow:0 2px 6px #0000001a;transition:background-color .3s ease,box-shadow .3s ease}.mes-container:nth-child(2n){background-color:#f9f9fc}.mes-container:nth-child(odd){background-color:#fff}.mes-container:hover{background-color:#f0f0f5;box-shadow:0 4px 8px #00000026}.header-container{display:flex;align-items:center;margin-bottom:2px}.header-container button{margin-left:auto}.mes-header{display:flex;align-items:center;gap:6px;font-size:1.2rem;font-weight:700;color:#333}.my-table{width:100%;border-collapse:collapse;border-radius:8px;overflow:hidden;box-shadow:0 4px 8px #0000001a;font-family:Arial,sans-serif}.my-table th,.my-table td{padding:5px;text-align:left;border-bottom:1px solid #ddd}.my-table th{background-color:#005dbb7b;color:#fff;font-weight:700}.my-table tr{transition:background-color .3s ease}.my-table tr:hover{background-color:#f1f1f1}.my-table td{background-color:#fff}.my-table td button{transition:transform .2s ease}.my-table td button:hover{transform:scale(1.1)}.my-table td:last-child{text-align:center}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }] }); }
|
|
127
|
+
}
|
|
128
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEmailListComponent, decorators: [{
|
|
129
|
+
type: Component,
|
|
130
|
+
args: [{ standalone: false, selector: 'lib-unb-pessoa-email-list', template: "<div class=\"mes-container\">\r\n <div class=\"header-container\">\r\n <div class=\"mes-header\">\r\n <span class=\"titulo\">\r\n {{ emails?.length === 1 ? 'Email Cadastrado' : 'E-mails Cadastrados' }}\r\n </span>\r\n <span class=\"titulo\">({{ emails?.length || 0 }})</span>\r\n </div>\r\n\r\n <button matTooltip=\"Novo Email\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n Cadastrar Novo Email\r\n </button>\r\n </div>\r\n\r\n <!-- Exibe a tabela de despesas somente se houver despesas -->\r\n <table class=\"my-table\" *ngIf=\"emails && emails.length > 0\">\r\n <tr style=\"background-color: #e4e3e3cc;\">\r\n <th style=\"text-align: center;\" >Ordem</th>\r\n <th>E-mail</th>\r\n <th>Tipo</th>\r\n <th style=\"text-align: center;\">A\u00E7\u00F5es</th>\r\n </tr>\r\n\r\n <tr *ngFor=\"let valor of emails; let i = index\" class=\"my-tr\">\r\n <td style=\"width: 5%; text-align: center;\"> \r\n <button *ngIf=\"emails.length > 1 && i > 0\" mat-icon-button aria-label=\"Mover para cima\"\r\n (click)=\"moverParaCima(i)\">\r\n <mat-icon>arrow_upward</mat-icon>\r\n </button>\r\n <button *ngIf=\"emails.length > 1 && i < emails.length - 1\" mat-icon-button aria-label=\"Mover para baixo\"\r\n (click)=\"moverParaBaixo(i)\">\r\n <mat-icon>arrow_downward</mat-icon>\r\n </button>\r\n </td>\r\n <td style=\"width: 50%;\">{{ valor.email }}</td>\r\n <td style=\"width: 20%;\">{{ valor.tipo?.toUpperCase() }}</td>\r\n <td style=\"width: 20%; text-align: center;\">\r\n <button mat-icon-button aria-label=\"Salvar\" color=\"primary\" (click)=\"editar(valor)\">\r\n <mat-icon>edit</mat-icon>\r\n </button>\r\n <button mat-icon-button aria-label=\"Deletar\" color=\"warn\" (click)=\"excluir(valor)\">\r\n <mat-icon>delete</mat-icon>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".mes-container{padding:12px;margin-bottom:2px;border-radius:8px;box-shadow:0 2px 6px #0000001a;transition:background-color .3s ease,box-shadow .3s ease}.mes-container:nth-child(2n){background-color:#f9f9fc}.mes-container:nth-child(odd){background-color:#fff}.mes-container:hover{background-color:#f0f0f5;box-shadow:0 4px 8px #00000026}.header-container{display:flex;align-items:center;margin-bottom:2px}.header-container button{margin-left:auto}.mes-header{display:flex;align-items:center;gap:6px;font-size:1.2rem;font-weight:700;color:#333}.my-table{width:100%;border-collapse:collapse;border-radius:8px;overflow:hidden;box-shadow:0 4px 8px #0000001a;font-family:Arial,sans-serif}.my-table th,.my-table td{padding:5px;text-align:left;border-bottom:1px solid #ddd}.my-table th{background-color:#005dbb7b;color:#fff;font-weight:700}.my-table tr{transition:background-color .3s ease}.my-table tr:hover{background-color:#f1f1f1}.my-table td{background-color:#fff}.my-table td button{transition:transform .2s ease}.my-table td button:hover{transform:scale(1.1)}.my-table td:last-child{text-align:center}\n"] }]
|
|
131
|
+
}], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.MatDialog }], propDecorators: { podeEditar: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], emails: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], apiPessoaConfig: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], emailsEmitted: [{
|
|
138
|
+
type: Output
|
|
139
|
+
}] } });
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unb-pessoa-email-list.js","sourceRoot":"","sources":["../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.ts","../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { Observable } from 'rxjs';\r\nimport { UnbPessoaEmail, UnbPessoaEmailTipo } from '../unb-pessoa-models/unb-pessoa-email.model';\r\nimport { UnBPessoaService } from '../unb-pessoa.service';\r\nimport { UnbPessoaEmailFormComponent } from './unb-pessoa-email-form';\r\nimport { TipoPessoaEnum } from '../unb-tipo-pessoa.enum';\r\n\r\n@Component({\r\n  standalone: false,\r\n  selector: 'lib-unb-pessoa-email-list',\r\n  templateUrl: './unb-pessoa-email-list.html',\r\n  styleUrl: './unb-pessoa-email-list.css'\r\n})\r\nexport class UnbPessoaEmailListComponent implements OnInit {\r\n  @Input() podeEditar = true;\r\n  @Input() emails: any = [];\r\n  @Input() apiPessoaConfig: { url: string; token: string } = { url: '', token: '' };\r\n  @Output() emailsEmitted = new EventEmitter<UnbPessoaEmail[]>();\r\n\r\n  tipoEmail!: Observable<UnbPessoaEmailTipo[]>;\r\n\r\n  constructor(private snackBar: MatSnackBar, private service: UnBPessoaService, public dialog: MatDialog) {\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.tipoEmail = this.service.getTipoEmail();\r\n\r\n    this.sortAndAssignOrder(); // organiza a lista de emails. As vezes tem ordem duplicada ou faltando.\r\n  }\r\n\r\n  excluir(email: UnbPessoaEmailTipo) {\r\n\r\n  }\r\n\r\n  editar(email: UnbPessoaEmailTipo) {\r\n    this.openFormDialog(email);\r\n  }\r\n\r\n  moverParaCima(index: number) {\r\n    if (index <= 0) return;\r\n\r\n    [this.emails[index - 1], this.emails[index]] = [this.emails[index], this.emails[index - 1]];\r\n    this.atualizarOrdem();\r\n  }\r\n\r\n  moverParaBaixo(index: number) {\r\n    if (index >= this.emails.length - 1) return;\r\n\r\n    [this.emails[index], this.emails[index + 1]] = [this.emails[index + 1], this.emails[index]];\r\n    this.atualizarOrdem();\r\n  }\r\n\r\n  atualizarOrdem() {\r\n    this.emails.forEach((email, idx) => {\r\n      email.ordem = idx + 1;\r\n    });\r\n\r\n    this.emailsEmitted.emit(this.emails);\r\n  }\r\n\r\n  openFormDialog(emailToEdit: any) {\r\n    const dialogRef = this.dialog.open(UnbPessoaEmailFormComponent, {\r\n      width: '900px',\r\n      data: {\r\n        email: emailToEdit, // E-mail a ser editado ou vazio para novo\r\n        emailsList: this.emails // A sua lista COMPLETA de e-mails\r\n      },\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe(result => {\r\n      if (result) {\r\n        const index = this.emails.findIndex(e => e.codigo === result.codigo);\r\n\r\n        if (result.codigo && index > -1) {\r\n          // Atualiza e-mail existente\r\n          this.emails[index] = result;\r\n        } else {\r\n          // Adiciona novo e-mail (gera ordem automaticamente se quiser)\r\n          result.ordem = this.emails.length + 1;\r\n          this.emails.push(result);\r\n        }\r\n        // Emite lista atualizada\r\n        this.emailsEmitted.emit(this.emails);\r\n      }\r\n    });\r\n  }\r\n\r\n  private sortAndAssignOrder(): void {\r\n    // 1. Crie uma cópia da lista para não modificar a original durante a iteração inicial\r\n    const tempEmails = [...this.emails];\r\n\r\n    // 2. Mapeie as ordens existentes para identificar duplicatas e ausentes\r\n    const orderMap = new Map<number, UnbPessoaEmail[]>();\r\n    const emailsWithoutOrder: UnbPessoaEmail[] = [];\r\n\r\n    tempEmails.forEach(email => {\r\n      if (email.ordem !== undefined && email.ordem !== null) {\r\n        if (!orderMap.has(email.ordem)) {\r\n          orderMap.set(email.ordem, []);\r\n        }\r\n        orderMap.get(email.ordem)?.push(email);\r\n      } else {\r\n        emailsWithoutOrder.push(email);\r\n      }\r\n    });\r\n\r\n    // 3. Inicialize um Set para rastrear todas as ordens que serão usadas no final\r\n    const finalUsedOrders = new Set<number>();\r\n    // Inicialize o próximo valor de ordem disponível\r\n    let nextAvailableOrder = 0;\r\n\r\n    // Função auxiliar para encontrar a próxima ordem disponível\r\n    const getNextAvailableOrder = () => {\r\n      while (finalUsedOrders.has(nextAvailableOrder)) {\r\n        nextAvailableOrder++;\r\n      }\r\n      return nextAvailableOrder++;\r\n    };\r\n\r\n    // 4. Processe emails com ordem definida:\r\n    //    - A primeira ocorrência de uma ordem a mantém.\r\n    //    - Duplicatas recebem uma nova ordem.\r\n    //    - Adicione as ordens válidas ao finalUsedOrders.\r\n    this.emails.forEach(email => { // Iterar sobre a lista original para modificar in-place\r\n      if (email.ordem !== undefined && email.ordem !== null) {\r\n        if (!finalUsedOrders.has(email.ordem)) {\r\n          // Se a ordem ainda não foi usada, use-a e adicione ao set\r\n          finalUsedOrders.add(email.ordem);\r\n        } else {\r\n          // Se a ordem já foi usada (é uma duplicata), atribua uma nova\r\n          email.ordem = getNextAvailableOrder();\r\n          finalUsedOrders.add(email.ordem); // Adiciona a nova ordem ao set\r\n        }\r\n      }\r\n    });\r\n\r\n    // 5. Atribua ordens para emails que não tinham ordem definida\r\n    emailsWithoutOrder.forEach(email => {\r\n      email.ordem = getNextAvailableOrder();\r\n      finalUsedOrders.add(email.ordem); // Adiciona a nova ordem ao set\r\n    });\r\n\r\n    // 6. Finalmente, ordene a lista completa com as ordens agora únicas\r\n    this.emails.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));\r\n  }\r\n\r\n\r\n}","<div class=\"mes-container\">\r\n    <div class=\"header-container\">\r\n        <div class=\"mes-header\">\r\n            <span class=\"titulo\">\r\n                {{ emails?.length === 1 ? 'Email Cadastrado' : 'E-mails Cadastrados' }}\r\n            </span>\r\n            <span class=\"titulo\">({{ emails?.length || 0 }})</span>\r\n        </div>\r\n\r\n        <button matTooltip=\"Novo Email\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n            Cadastrar Novo Email\r\n        </button>\r\n    </div>\r\n\r\n    <!-- Exibe a tabela de despesas somente se houver despesas -->\r\n    <table class=\"my-table\" *ngIf=\"emails && emails.length > 0\">\r\n        <tr style=\"background-color: #e4e3e3cc;\">\r\n            <th style=\"text-align: center;\" >Ordem</th>\r\n            <th>E-mail</th>\r\n            <th>Tipo</th>\r\n            <th style=\"text-align: center;\">Ações</th>\r\n        </tr>\r\n\r\n        <tr *ngFor=\"let valor of emails; let i = index\" class=\"my-tr\">\r\n            <td style=\"width: 5%; text-align: center;\">                \r\n                <button *ngIf=\"emails.length > 1 && i > 0\" mat-icon-button aria-label=\"Mover para cima\"\r\n                    (click)=\"moverParaCima(i)\">\r\n                    <mat-icon>arrow_upward</mat-icon>\r\n                </button>\r\n                <button *ngIf=\"emails.length > 1 && i < emails.length - 1\" mat-icon-button aria-label=\"Mover para baixo\"\r\n                    (click)=\"moverParaBaixo(i)\">\r\n                    <mat-icon>arrow_downward</mat-icon>\r\n                </button>\r\n            </td>\r\n            <td style=\"width: 50%;\">{{ valor.email }}</td>\r\n            <td style=\"width: 20%;\">{{ valor.tipo?.toUpperCase() }}</td>\r\n            <td style=\"width: 20%; text-align: center;\">\r\n                <button mat-icon-button aria-label=\"Salvar\" color=\"primary\" (click)=\"editar(valor)\">\r\n                    <mat-icon>edit</mat-icon>\r\n                </button>\r\n                <button mat-icon-button aria-label=\"Deletar\" color=\"warn\" (click)=\"excluir(valor)\">\r\n                    <mat-icon>delete</mat-icon>\r\n                </button>\r\n            </td>\r\n        </tr>\r\n    </table>\r\n</div>"]}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { UnbPessoaEndereco } from '../unb-pessoa-models/unb-pessoa-endereco.model';
|
|
3
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/material/snack-bar";
|
|
6
|
+
import * as i2 from "../unb-pessoa.service";
|
|
7
|
+
import * as i3 from "@angular/material/dialog";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "@angular/forms";
|
|
10
|
+
import * as i6 from "@angular/material/icon";
|
|
11
|
+
import * as i7 from "@angular/material/button";
|
|
12
|
+
import * as i8 from "@angular/material/form-field";
|
|
13
|
+
import * as i9 from "@angular/material/input";
|
|
14
|
+
import * as i10 from "@angular/material/select";
|
|
15
|
+
import * as i11 from "@angular/material/core";
|
|
16
|
+
export class UnbPessoaEnderecoFormComponent {
|
|
17
|
+
constructor(snackBar, service, dialogRef, data) {
|
|
18
|
+
this.snackBar = snackBar;
|
|
19
|
+
this.service = service;
|
|
20
|
+
this.dialogRef = dialogRef;
|
|
21
|
+
this.data = data;
|
|
22
|
+
this.endereco = new UnbPessoaEndereco();
|
|
23
|
+
this.listaTipoEndereco = [];
|
|
24
|
+
this.endereco = JSON.parse(JSON.stringify(data.endereco)); // O e-mail específico para edição
|
|
25
|
+
// Verifique se a lista de e-mails foi passada e atribua-a
|
|
26
|
+
if (data.enderecosList) {
|
|
27
|
+
this.enderecosList = JSON.parse(JSON.stringify(data.enderecosList)); // Faça uma cópia profunda se for manipular
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
this.enderecosList = []; // Inicialize como vazio se não for passada
|
|
31
|
+
}
|
|
32
|
+
if (!this.endereco) {
|
|
33
|
+
this.endereco = new UnbPessoaEndereco();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
this.tipoEndereco = this.service.getTipoEndereco();
|
|
38
|
+
// Inscreve para guardar a lista em uma variável comum
|
|
39
|
+
this.tipoEndereco.subscribe(lista => {
|
|
40
|
+
this.listaTipoEndereco = lista;
|
|
41
|
+
// Se já tiver tipoEmailCodigo, preenche o nome correspondente
|
|
42
|
+
if (this.endereco.tipoEnderecoCodigo != null) {
|
|
43
|
+
const tipoEncontrado = lista.find(t => t.codigo === this.endereco.tipoEnderecoCodigo);
|
|
44
|
+
if (tipoEncontrado) {
|
|
45
|
+
this.endereco.tipo = tipoEncontrado.denominacao;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else if (this.endereco.tipo) {
|
|
49
|
+
const tipoEncontrado = lista.find(t => t.denominacao?.toLowerCase() === this.endereco.tipo?.toLowerCase());
|
|
50
|
+
if (tipoEncontrado) {
|
|
51
|
+
this.endereco.tipoEnderecoCodigo = tipoEncontrado.codigo;
|
|
52
|
+
}
|
|
53
|
+
// O metodo get retorna uf, mas o put espera ufEndereco
|
|
54
|
+
if (this.endereco.uf) {
|
|
55
|
+
this.endereco.ufEndereco = this.endereco.uf; // Converte ufEndereco para uf
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
salvar(form) {
|
|
61
|
+
if (form.invalid) {
|
|
62
|
+
this.openSnackBar('Existem erros no formulário, por favor, verificar.');
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
if (this.validar(this.endereco) == false)
|
|
66
|
+
return;
|
|
67
|
+
this.enderecoSalvo = this.endereco;
|
|
68
|
+
this.salvarclose();
|
|
69
|
+
}
|
|
70
|
+
compararTipos(t1, t2) {
|
|
71
|
+
return t1 && t2 && t1.codigo === t2.codigo;
|
|
72
|
+
}
|
|
73
|
+
onTipoSelecionado(codigoSelecionado) {
|
|
74
|
+
const tipoSelecionado = this.listaTipoEndereco.find(t => t.codigo === codigoSelecionado);
|
|
75
|
+
if (tipoSelecionado) {
|
|
76
|
+
this.endereco.tipo = tipoSelecionado.denominacao;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
pesquisarCep() {
|
|
80
|
+
if (this.endereco.cep && this.endereco.cep.trim() !== '') {
|
|
81
|
+
let cepFormatado = this.endereco.cep.replace(/\D/g, ''); // Remove caracteres não numéricos
|
|
82
|
+
this.service.pesquisarCep(cepFormatado).subscribe({
|
|
83
|
+
next: (data) => {
|
|
84
|
+
this.endereco.logradouro = data.logradouro;
|
|
85
|
+
this.endereco.bairro = data.bairro;
|
|
86
|
+
this.endereco.ufEndereco = data.uf;
|
|
87
|
+
this.endereco.uf = data.uf;
|
|
88
|
+
this.endereco.complemento = data.complemento;
|
|
89
|
+
},
|
|
90
|
+
error: (error) => {
|
|
91
|
+
this.openSnackBar('Falha ao encontrar o CEP');
|
|
92
|
+
console.error('Erro ao pesquisar CEP:', error);
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
this.openSnackBar('Por favor, insira um CEP válido.');
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
getListaEstados() {
|
|
101
|
+
return [
|
|
102
|
+
'AC', 'AL', 'AP', 'AM', 'BA', 'CE', 'DF', 'ES', 'GO', 'MA',
|
|
103
|
+
'MT', 'MS', 'MG', 'PA', 'PB', 'PR', 'PE', 'PI', 'RJ', 'RN',
|
|
104
|
+
'RS', 'RO', 'RR', 'SC', 'SP', 'SE', 'TO'
|
|
105
|
+
];
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Valida o objeto de e-mail.
|
|
109
|
+
* Retorna true se o e-mail for válido, false caso contrário.
|
|
110
|
+
*/
|
|
111
|
+
validar(enderecoToValidate) {
|
|
112
|
+
// 3. Validação de e-mail duplicado na lista existente
|
|
113
|
+
// Filtra a lista para excluir o próprio endereço que está sendo editado (se ele tiver um 'codigo')
|
|
114
|
+
const isDuplicate = this.enderecosList.some(existingEndereco => existingEndereco.logradouro?.toLowerCase() === enderecoToValidate.logradouro?.toLowerCase() &&
|
|
115
|
+
existingEndereco.codigo !== enderecoToValidate.codigo // Ignora o próprio endereço se estiver sendo editado
|
|
116
|
+
);
|
|
117
|
+
if (isDuplicate) {
|
|
118
|
+
this.openSnackBar("Este endereço já existe na lista.");
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
return true;
|
|
122
|
+
}
|
|
123
|
+
close() {
|
|
124
|
+
this.dialogRef.close(null);
|
|
125
|
+
}
|
|
126
|
+
salvarclose() {
|
|
127
|
+
this.dialogRef.close(this.enderecoSalvo);
|
|
128
|
+
}
|
|
129
|
+
openSnackBar(message) {
|
|
130
|
+
this.snackBar.open(message, 'x', {
|
|
131
|
+
duration: 5000,
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEnderecoFormComponent, deps: [{ token: i1.MatSnackBar }, { token: i2.UnBPessoaService }, { token: i3.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
135
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbPessoaEnderecoFormComponent, selector: "lib-unb-pessoa-endereco-form", ngImport: i0, template: "<h1 mat-dialog-title>Cadastro de E-mail</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n <mat-dialog-content>\r\n <div class=\"form-container\">\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Tipo</mat-label>\r\n <mat-select [(ngModel)]=\"endereco.tipoEnderecoCodigo\" name=\"tipo\" #tipo=\"ngModel\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of tipoEndereco | async\" [value]=\"tipo.codigo\">\r\n {{tipo.denominacao}}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>CEP</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.cep\" name=\"cep\" #cep=\"ngModel\" />\r\n <button matSuffix mat-icon-button type=\"button\" aria-label=\"Pesquisar\" (click)=\"pesquisarCep()\">\r\n <mat-icon style=\"margin-right: 2px;\">search</mat-icon> \r\n </button>\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-25\" appearance=\"outline\">\r\n <mat-label>Endere\u00E7o</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.logradouro\" name=\"logradouro\" #logradouro=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Bairro</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.bairro\" name=\"bairro\" #bairro=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Complemento</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.complemento\" name=\"complemento\" #complemento=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>UF</mat-label>\r\n <mat-select [(ngModel)]=\"endereco.uf\" name=\"uf\" #uf=\"ngModel\">\r\n <mat-option *ngFor=\"let uf of getListaEstados()\" [value]=\"uf\">\r\n {{ uf }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n </mat-dialog-content>\r\n\r\n <mat-dialog-actions align=\"end\">\r\n <button mat-stroked-button type=\"button\" color=\"warn\" (click)=\"close()\">Fechar</button>\r\n <button mat-flat-button type=\"submit\" color=\"primary\">Salvar</button>\r\n </mat-dialog-actions>\r\n</form>", styles: [".card-actions-buttons{display:flex;gap:5px;flex-wrap:wrap}.form-container{display:flex;flex-wrap:wrap;column-gap:10px;margin:10px}@media (max-width: 1000px){.form-container{flex-direction:column;gap:5px}}.break{flex-basis:100%;height:0}.form-5{flex:1 1 5%}.inline-table-container{display:flex;align-items:center;justify-content:space-between;padding:5px}@media (max-width: 600px){.form-5,.form-10,.form-15{flex:1 1 100%}}.form-10{flex:1 1 10%}.form-15{flex:1 1 15%}.form-20{flex:1 1 20%}.form-25{flex:1 1 25%}.form-30{flex:1 1 30%}.form-35{flex:1 1 35%}.form-40{flex:1 1 40%}.form-45{flex:1 1 45%}.form-50{flex:1 1 50%}.form-100{flex:1 1 100%;min-width:250px}.botoes-container{display:flex;gap:5px}@media (max-width: 600px){.botoes-container{margin-bottom:10px}.botoes-container button{flex:1;max-width:50%}}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i8.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i8.MatLabel, selector: "mat-label" }, { kind: "directive", type: i8.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i3.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i3.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i3.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i10.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i11.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] }); }
|
|
136
|
+
}
|
|
137
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEnderecoFormComponent, decorators: [{
|
|
138
|
+
type: Component,
|
|
139
|
+
args: [{ standalone: false, selector: 'lib-unb-pessoa-endereco-form', template: "<h1 mat-dialog-title>Cadastro de E-mail</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n <mat-dialog-content>\r\n <div class=\"form-container\">\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Tipo</mat-label>\r\n <mat-select [(ngModel)]=\"endereco.tipoEnderecoCodigo\" name=\"tipo\" #tipo=\"ngModel\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of tipoEndereco | async\" [value]=\"tipo.codigo\">\r\n {{tipo.denominacao}}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>CEP</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.cep\" name=\"cep\" #cep=\"ngModel\" />\r\n <button matSuffix mat-icon-button type=\"button\" aria-label=\"Pesquisar\" (click)=\"pesquisarCep()\">\r\n <mat-icon style=\"margin-right: 2px;\">search</mat-icon> \r\n </button>\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-25\" appearance=\"outline\">\r\n <mat-label>Endere\u00E7o</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.logradouro\" name=\"logradouro\" #logradouro=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Bairro</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.bairro\" name=\"bairro\" #bairro=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>Complemento</mat-label>\r\n <input type=\"text\" matInput [(ngModel)]=\"endereco.complemento\" name=\"complemento\" #complemento=\"ngModel\" />\r\n </mat-form-field>\r\n\r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>UF</mat-label>\r\n <mat-select [(ngModel)]=\"endereco.uf\" name=\"uf\" #uf=\"ngModel\">\r\n <mat-option *ngFor=\"let uf of getListaEstados()\" [value]=\"uf\">\r\n {{ uf }}\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n </mat-dialog-content>\r\n\r\n <mat-dialog-actions align=\"end\">\r\n <button mat-stroked-button type=\"button\" color=\"warn\" (click)=\"close()\">Fechar</button>\r\n <button mat-flat-button type=\"submit\" color=\"primary\">Salvar</button>\r\n </mat-dialog-actions>\r\n</form>", styles: [".card-actions-buttons{display:flex;gap:5px;flex-wrap:wrap}.form-container{display:flex;flex-wrap:wrap;column-gap:10px;margin:10px}@media (max-width: 1000px){.form-container{flex-direction:column;gap:5px}}.break{flex-basis:100%;height:0}.form-5{flex:1 1 5%}.inline-table-container{display:flex;align-items:center;justify-content:space-between;padding:5px}@media (max-width: 600px){.form-5,.form-10,.form-15{flex:1 1 100%}}.form-10{flex:1 1 10%}.form-15{flex:1 1 15%}.form-20{flex:1 1 20%}.form-25{flex:1 1 25%}.form-30{flex:1 1 30%}.form-35{flex:1 1 35%}.form-40{flex:1 1 40%}.form-45{flex:1 1 45%}.form-50{flex:1 1 50%}.form-100{flex:1 1 100%;min-width:250px}.botoes-container{display:flex;gap:5px}@media (max-width: 600px){.botoes-container{margin-bottom:10px}.botoes-container button{flex:1;max-width:50%}}\n"] }]
|
|
140
|
+
}], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.MatDialogRef }, { type: undefined, decorators: [{
|
|
141
|
+
type: Inject,
|
|
142
|
+
args: [MAT_DIALOG_DATA]
|
|
143
|
+
}] }] });
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unb-pessoa-endereco-form.js","sourceRoot":"","sources":["../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.ts","../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject } from '@angular/core';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { Observable } from 'rxjs';\r\nimport { UnbPessoaEndereco, UnbPessoaEnderecoTipo } from '../unb-pessoa-models/unb-pessoa-endereco.model';\r\nimport { UnBPessoaService } from '../unb-pessoa.service';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { NgForm } from '@angular/forms';\r\n\r\n\r\n@Component({\r\n  standalone: false,\r\n  selector: 'lib-unb-pessoa-endereco-form',\r\n  templateUrl: './unb-pessoa-endereco-form.html',\r\n  styleUrl: './unb-pessoa-endereco-form.css'\r\n})\r\nexport class UnbPessoaEnderecoFormComponent implements OnInit {\r\n\r\n  enderecoSalvo!: UnbPessoaEndereco;\r\n  endereco = new UnbPessoaEndereco();\r\n  enderecosList: UnbPessoaEndereco[];\r\n  tipoEndereco!: Observable<UnbPessoaEnderecoTipo[]>;\r\n  listaTipoEndereco: UnbPessoaEnderecoTipo[] = [];\r\n\r\n  constructor(private snackBar: MatSnackBar, private service: UnBPessoaService, public dialogRef: MatDialogRef<UnbPessoaEnderecoFormComponent>, @Inject(MAT_DIALOG_DATA) public data: any) {\r\n    this.endereco = JSON.parse(JSON.stringify(data.endereco)); // O e-mail específico para edição\r\n\r\n    // Verifique se a lista de e-mails foi passada e atribua-a\r\n    if (data.enderecosList) {\r\n      this.enderecosList = JSON.parse(JSON.stringify(data.enderecosList)); // Faça uma cópia profunda se for manipular\r\n    } else {\r\n      this.enderecosList = []; // Inicialize como vazio se não for passada\r\n    }\r\n\r\n    if (!this.endereco) {\r\n      this.endereco = new UnbPessoaEndereco();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.tipoEndereco = this.service.getTipoEndereco();\r\n    // Inscreve para guardar a lista em uma variável comum\r\n    this.tipoEndereco.subscribe(lista => {\r\n      this.listaTipoEndereco = lista;\r\n\r\n      // Se já tiver tipoEmailCodigo, preenche o nome correspondente\r\n      if (this.endereco.tipoEnderecoCodigo != null) {\r\n        const tipoEncontrado = lista.find(t => t.codigo === this.endereco.tipoEnderecoCodigo);\r\n        if (tipoEncontrado) {\r\n          this.endereco.tipo = tipoEncontrado.denominacao;\r\n        }\r\n      } else if (this.endereco.tipo) {\r\n        const tipoEncontrado = lista.find(\r\n          t => t.denominacao?.toLowerCase() === this.endereco.tipo?.toLowerCase()\r\n        );\r\n\r\n        if (tipoEncontrado) {\r\n            this.endereco.tipoEnderecoCodigo = tipoEncontrado.codigo!;\r\n        }\r\n\r\n        // O metodo get retorna uf, mas o put espera ufEndereco\r\n        if (this.endereco.uf) {\r\n          this.endereco.ufEndereco = this.endereco.uf; // Converte ufEndereco para uf\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  salvar(form: NgForm) {\r\n    if (form.invalid) {\r\n      this.openSnackBar('Existem erros no formulário, por favor, verificar.');\r\n      return;\r\n    }\r\n    if (this.validar(this.endereco) == false) return;\r\n\r\n    this.enderecoSalvo = this.endereco;\r\n    this.salvarclose()\r\n  }\r\n\r\n  compararTipos(t1: any, t2: any): boolean {\r\n    return t1 && t2 && t1.codigo === t2.codigo;\r\n  }\r\n\r\n  onTipoSelecionado(codigoSelecionado: number) {\r\n    const tipoSelecionado = this.listaTipoEndereco.find(t => t.codigo === codigoSelecionado);\r\n    if (tipoSelecionado) {\r\n      this.endereco.tipo = tipoSelecionado.denominacao;\r\n    }\r\n  }\r\n\r\n  pesquisarCep() {\r\n   if (this.endereco.cep && this.endereco.cep.trim() !== '') {\r\n      let cepFormatado = this.endereco.cep.replace(/\\D/g, ''); // Remove caracteres não numéricos\r\n      this.service.pesquisarCep(cepFormatado).subscribe({\r\n        next: (data: UnbPessoaEndereco) => {\r\n          this.endereco.logradouro = data.logradouro;\r\n          this.endereco.bairro = data.bairro;\r\n          this.endereco.ufEndereco = data.uf;\r\n          this.endereco.uf = data.uf;\r\n          this.endereco.complemento = data.complemento;\r\n        },\r\n        error: (error) => {\r\n          this.openSnackBar('Falha ao encontrar o CEP');\r\n          console.error('Erro ao pesquisar CEP:', error);\r\n        }\r\n      });\r\n    } else {\r\n      this.openSnackBar('Por favor, insira um CEP válido.');\r\n    }\r\n  }\r\n\r\n  getListaEstados(): any {\r\n    return [\r\n      'AC', 'AL', 'AP', 'AM', 'BA', 'CE', 'DF', 'ES', 'GO', 'MA',\r\n      'MT', 'MS', 'MG', 'PA', 'PB', 'PR', 'PE', 'PI', 'RJ', 'RN',\r\n      'RS', 'RO', 'RR', 'SC', 'SP', 'SE', 'TO'\r\n    ];\r\n  }\r\n\r\n /**\r\n   * Valida o objeto de e-mail.\r\n   * Retorna true se o e-mail for válido, false caso contrário.\r\n   */\r\n  validar(enderecoToValidate: UnbPessoaEndereco): boolean {\r\n   \r\n\r\n    // 3. Validação de e-mail duplicado na lista existente\r\n    // Filtra a lista para excluir o próprio endereço que está sendo editado (se ele tiver um 'codigo')\r\n    const isDuplicate = this.enderecosList.some(existingEndereco =>\r\n      existingEndereco.logradouro?.toLowerCase() === enderecoToValidate.logradouro?.toLowerCase() &&\r\n      existingEndereco.codigo !== enderecoToValidate.codigo // Ignora o próprio endereço se estiver sendo editado\r\n    );\r\n\r\n    if (isDuplicate) {\r\n      this.openSnackBar(\"Este endereço já existe na lista.\");\r\n      return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  close() {\r\n    this.dialogRef.close(null);\r\n  }\r\n\r\n  salvarclose() {\r\n    this.dialogRef.close(this.enderecoSalvo);\r\n  }\r\n\r\n  openSnackBar(message: string) {\r\n    this.snackBar.open(message, 'x', {\r\n      duration: 5000,\r\n    });\r\n  }\r\n\r\n}","<h1 mat-dialog-title>Cadastro de E-mail</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n  <mat-dialog-content>\r\n    <div class=\"form-container\">\r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>Tipo</mat-label>\r\n        <mat-select [(ngModel)]=\"endereco.tipoEnderecoCodigo\" name=\"tipo\" #tipo=\"ngModel\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n          <mat-option *ngFor=\"let tipo of tipoEndereco | async\" [value]=\"tipo.codigo\">\r\n            {{tipo.denominacao}}\r\n          </mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n\r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>CEP</mat-label>\r\n        <input type=\"text\" matInput [(ngModel)]=\"endereco.cep\" name=\"cep\" #cep=\"ngModel\" />\r\n         <button matSuffix mat-icon-button type=\"button\" aria-label=\"Pesquisar\" (click)=\"pesquisarCep()\">\r\n            <mat-icon style=\"margin-right: 2px;\">search</mat-icon>            \r\n        </button>\r\n      </mat-form-field>\r\n\r\n      <mat-form-field class=\"form-25\" appearance=\"outline\">\r\n        <mat-label>Endereço</mat-label>\r\n        <input type=\"text\" matInput [(ngModel)]=\"endereco.logradouro\" name=\"logradouro\" #logradouro=\"ngModel\" />\r\n      </mat-form-field>\r\n\r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>Bairro</mat-label>\r\n        <input type=\"text\" matInput [(ngModel)]=\"endereco.bairro\" name=\"bairro\" #bairro=\"ngModel\" />\r\n      </mat-form-field>\r\n\r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>Complemento</mat-label>\r\n        <input type=\"text\" matInput [(ngModel)]=\"endereco.complemento\" name=\"complemento\" #complemento=\"ngModel\" />\r\n      </mat-form-field>\r\n\r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>UF</mat-label>\r\n        <mat-select [(ngModel)]=\"endereco.uf\" name=\"uf\" #uf=\"ngModel\">\r\n          <mat-option *ngFor=\"let uf of getListaEstados()\" [value]=\"uf\">\r\n            {{ uf }}\r\n          </mat-option>\r\n        </mat-select>\r\n      </mat-form-field>\r\n    </div>\r\n  </mat-dialog-content>\r\n\r\n  <mat-dialog-actions align=\"end\">\r\n    <button mat-stroked-button type=\"button\" color=\"warn\" (click)=\"close()\">Fechar</button>\r\n    <button mat-flat-button type=\"submit\" color=\"primary\">Salvar</button>\r\n  </mat-dialog-actions>\r\n</form>"]}
|