@stiunb/unb-lib-components 18.0.22 → 18.0.24
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/esm2022/lib/unb-mensagem/unb-mensagem.component.mjs +18 -26
- package/esm2022/lib/unb-mensagem/unb-mensagem.service.mjs +16 -21
- package/esm2022/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.mjs +91 -37
- package/esm2022/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.mjs +67 -49
- package/esm2022/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.mjs +160 -41
- package/esm2022/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-list.mjs +73 -57
- package/esm2022/lib/unb-pessoa/unb-pessoa-form/unb-pessoa-form.component.mjs +225 -56
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-email.model.mjs +1 -1
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-endereco.model.mjs +1 -1
- package/esm2022/lib/unb-pessoa/unb-pessoa-models/unb-pessoa.model.mjs +2 -1
- package/esm2022/lib/unb-pessoa/unb-pessoa-pesquisar/unb-pessoa-pesquisar.component.mjs +186 -40
- package/esm2022/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.mjs +115 -33
- package/esm2022/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.mjs +64 -34
- package/esm2022/lib/unb-pessoa/unb-pessoa.module.mjs +9 -1
- package/esm2022/lib/unb-pessoa/unb-pessoa.service.mjs +146 -50
- package/esm2022/lib/unb-pessoa/unb-tipo-pessoa.enum.mjs +1 -1
- package/esm2022/lib/unb-usuario/oidc-decoded-token.mjs +1 -1
- package/esm2022/lib/unb-usuario/oidc-user-data.mjs +1 -1
- package/esm2022/public-api.mjs +14 -13
- package/esm2022/stiunb-unb-lib-components.mjs +5 -0
- package/fesm2022/stiunb-unb-lib-components.mjs +2627 -0
- package/fesm2022/stiunb-unb-lib-components.mjs.map +1 -0
- package/index.d.ts +1 -1
- package/lib/unb-mensagem/unb-mensagem.component.d.ts +3 -17
- package/lib/unb-mensagem/unb-mensagem.service.d.ts +16 -18
- package/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.d.ts +9 -5
- package/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.d.ts +8 -10
- package/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.d.ts +12 -6
- package/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-list.d.ts +8 -10
- package/lib/unb-pessoa/unb-pessoa-form/unb-pessoa-form.component.d.ts +24 -12
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-email.model.d.ts +1 -0
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa-endereco.model.d.ts +3 -2
- package/lib/unb-pessoa/unb-pessoa-models/unb-pessoa.model.d.ts +5 -4
- package/lib/unb-pessoa/unb-pessoa-pesquisar/unb-pessoa-pesquisar.component.d.ts +21 -8
- package/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.d.ts +8 -6
- package/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.d.ts +8 -10
- package/lib/unb-pessoa/unb-pessoa.module.d.ts +20 -18
- package/lib/unb-pessoa/unb-pessoa.service.d.ts +11 -14
- package/package.json +5 -5
- package/public-api.d.ts +10 -10
- package/esm2022/unb-lib-components.mjs +0 -5
- package/fesm2022/unb-lib-components.mjs +0 -1923
- package/fesm2022/unb-lib-components.mjs.map +0 -1
|
@@ -1,25 +1,30 @@
|
|
|
1
1
|
import { Component, Inject } from '@angular/core';
|
|
2
2
|
import { UnbPessoaTelefone } from '../unb-pessoa-models/unb-pessoa-telefone.model';
|
|
3
3
|
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
|
+
import { UnbTipoMensagemEnum } from '../../unb-mensagem/unb-mensagem.service';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/material/snack-bar";
|
|
6
7
|
import * as i2 from "../unb-pessoa.service";
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "@angular/
|
|
9
|
-
import * as i5 from "@angular/
|
|
10
|
-
import * as i6 from "@angular/
|
|
11
|
-
import * as i7 from "@angular/material/
|
|
12
|
-
import * as i8 from "
|
|
13
|
-
import * as i9 from "@angular/material/
|
|
14
|
-
import * as i10 from "@angular/material/
|
|
8
|
+
import * as i3 from "../../unb-mensagem/unb-mensagem.service";
|
|
9
|
+
import * as i4 from "@angular/material/dialog";
|
|
10
|
+
import * as i5 from "@angular/common";
|
|
11
|
+
import * as i6 from "@angular/forms";
|
|
12
|
+
import * as i7 from "@angular/material/button";
|
|
13
|
+
import * as i8 from "../../unb-mensagem/unb-mensagem.component";
|
|
14
|
+
import * as i9 from "@angular/material/form-field";
|
|
15
|
+
import * as i10 from "@angular/material/input";
|
|
16
|
+
import * as i11 from "@angular/material/select";
|
|
17
|
+
import * as i12 from "@angular/material/core";
|
|
15
18
|
export class UnbPessoaTelefoneFormComponent {
|
|
16
|
-
constructor(snackBar, service, dialogRef, data) {
|
|
19
|
+
constructor(snackBar, service, alertService, dialogRef, data) {
|
|
17
20
|
this.snackBar = snackBar;
|
|
18
21
|
this.service = service;
|
|
22
|
+
this.alertService = alertService;
|
|
19
23
|
this.dialogRef = dialogRef;
|
|
20
24
|
this.data = data;
|
|
21
25
|
this.telefone = new UnbPessoaTelefone();
|
|
22
|
-
this.
|
|
26
|
+
this.listaTipoTelefone = [];
|
|
27
|
+
this.idMensagemService = "UnbPessoaTelefoneForm";
|
|
23
28
|
this.telefone = JSON.parse(JSON.stringify(data.telefone)); // O e-mail específico para edição
|
|
24
29
|
// Verifique se a lista de e-mails foi passada e atribua-a
|
|
25
30
|
if (data.telefonesList) {
|
|
@@ -33,23 +38,24 @@ export class UnbPessoaTelefoneFormComponent {
|
|
|
33
38
|
}
|
|
34
39
|
}
|
|
35
40
|
ngOnInit() {
|
|
36
|
-
this.
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
41
|
+
this.service.getTipoTelefone().subscribe({
|
|
42
|
+
next: (lista) => {
|
|
43
|
+
this.listaTipoTelefone = lista;
|
|
44
|
+
// Se já tiver tipoTelefoneCodigo, preenche o nome correspondente
|
|
45
|
+
if (this.telefone.tipoTelefoneCodigo != null) {
|
|
46
|
+
const tipoEncontrado = lista.find(t => t.codigo === this.telefone.tipoTelefoneCodigo);
|
|
47
|
+
if (tipoEncontrado) {
|
|
48
|
+
this.telefone.tipo = tipoEncontrado.denominacao;
|
|
49
|
+
}
|
|
45
50
|
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
+
else if (this.telefone.tipo) {
|
|
52
|
+
const tipoEncontrado = lista.find(t => t.denominacao?.toLowerCase() === this.telefone.tipo?.toLowerCase());
|
|
53
|
+
if (tipoEncontrado) {
|
|
54
|
+
this.telefone.tipoTelefoneCodigo = tipoEncontrado.codigo;
|
|
55
|
+
}
|
|
51
56
|
}
|
|
52
|
-
}
|
|
57
|
+
},
|
|
58
|
+
error: (err) => this.handleError(err)
|
|
53
59
|
});
|
|
54
60
|
}
|
|
55
61
|
salvar(form) {
|
|
@@ -57,6 +63,20 @@ export class UnbPessoaTelefoneFormComponent {
|
|
|
57
63
|
this.openSnackBar('Existem erros no formulário, por favor, verificar.');
|
|
58
64
|
return;
|
|
59
65
|
}
|
|
66
|
+
// 1. Define o 'tipo' padrão (1) se não for preenchido (Conforme sua solicitação)
|
|
67
|
+
if (!this.telefone.tipoTelefoneCodigo) {
|
|
68
|
+
this.telefone.tipoTelefoneCodigo = 1; // 1 é geralmente 'Residencial' ou 'Principal'
|
|
69
|
+
}
|
|
70
|
+
// 2. Define a 'ordem' (que o back-end chama de 'ordemTelefone')
|
|
71
|
+
if (!this.telefone.ordem || this.telefone.ordem === 0) {
|
|
72
|
+
let maxOrdem = 0;
|
|
73
|
+
// Verifica se a lista de telefones já existe e tem itens
|
|
74
|
+
if (this.telefonesList && this.telefonesList.length > 0) {
|
|
75
|
+
maxOrdem = Math.max(...this.telefonesList.map(t => t.ordem || 0));
|
|
76
|
+
}
|
|
77
|
+
// Define a ordem do novo telefone como a maior ordem + 1
|
|
78
|
+
this.telefone.ordem = maxOrdem + 1;
|
|
79
|
+
}
|
|
60
80
|
if (this.validar(this.telefone) == false)
|
|
61
81
|
return;
|
|
62
82
|
this.telefoneSalvo = this.telefone;
|
|
@@ -66,17 +86,57 @@ export class UnbPessoaTelefoneFormComponent {
|
|
|
66
86
|
return t1 && t2 && t1 === t2;
|
|
67
87
|
}
|
|
68
88
|
onTipoSelecionado(codigoSelecionado) {
|
|
69
|
-
const tipoSelecionado = this.
|
|
89
|
+
const tipoSelecionado = this.listaTipoTelefone.find(t => t.codigo === codigoSelecionado); // <--- Renomeado de listaTipoEndereco
|
|
70
90
|
if (tipoSelecionado) {
|
|
71
91
|
this.telefone.tipo = tipoSelecionado.denominacao;
|
|
72
92
|
}
|
|
73
93
|
}
|
|
74
94
|
/**
|
|
75
|
-
* Valida o objeto de telefone.
|
|
95
|
+
* Valida o objeto de telefone com base nas regras do backend.
|
|
76
96
|
* Retorna true se o telefone for válido, false caso contrário.
|
|
77
97
|
*/
|
|
78
98
|
validar(telefoneToValidate) {
|
|
79
|
-
|
|
99
|
+
// 1. Validação de Número (Obrigatório)
|
|
100
|
+
if (!telefoneToValidate.numero || telefoneToValidate.numero.trim() === '') {
|
|
101
|
+
this.openSnackBar("Número do telefone é um campo obrigatório.");
|
|
102
|
+
return false;
|
|
103
|
+
}
|
|
104
|
+
// 2. Validação de Número (Formato)
|
|
105
|
+
// que ele espera 8 ou 9 dígitos numéricos (padrão Brasil).
|
|
106
|
+
const numeroLimpo = telefoneToValidate.numero.replace(/\D/g, ''); // Remove não-dígitos
|
|
107
|
+
if (numeroLimpo.length !== 9) {
|
|
108
|
+
this.openSnackBar("Número do telefone deve conter exatamente 9 dígitos.");
|
|
109
|
+
return false;
|
|
110
|
+
}
|
|
111
|
+
// 3. Validação de DDD (Obrigatório - Boa prática, embora o Java não exija)
|
|
112
|
+
if (!telefoneToValidate.ddd || telefoneToValidate.ddd.trim() === '') {
|
|
113
|
+
this.openSnackBar("DDD é um campo obrigatório.");
|
|
114
|
+
return false;
|
|
115
|
+
}
|
|
116
|
+
// 4. Validação de DDD (Tamanho Máximo)
|
|
117
|
+
if (telefoneToValidate.ddd.trim().length > 3) {
|
|
118
|
+
this.openSnackBar("DDD deve ter no máximo 3 caracteres.");
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
// 5. Validação de DDI (Tamanho Máximo)
|
|
122
|
+
//
|
|
123
|
+
if (telefoneToValidate.ddi && telefoneToValidate.ddi.trim().length > 5) {
|
|
124
|
+
this.openSnackBar("DDI deve ter no máximo 5 caracteres.");
|
|
125
|
+
return false;
|
|
126
|
+
}
|
|
127
|
+
// 6. Validação de Ramal (Tamanho Máximo)
|
|
128
|
+
//
|
|
129
|
+
if (telefoneToValidate.ramal && telefoneToValidate.ramal.trim().length > 6) {
|
|
130
|
+
this.openSnackBar("Ramal deve ter no máximo 6 caracteres.");
|
|
131
|
+
return false;
|
|
132
|
+
}
|
|
133
|
+
// 7. Validação de NomeResponsavel (Tamanho Máximo)
|
|
134
|
+
//
|
|
135
|
+
if (telefoneToValidate.nomeResponsavel && telefoneToValidate.nomeResponsavel.trim().length > 100) {
|
|
136
|
+
this.openSnackBar("Nome do Responsável deve ter no máximo 100 caracteres.");
|
|
137
|
+
return false;
|
|
138
|
+
}
|
|
139
|
+
return true; // Passou em todas as validações!
|
|
80
140
|
}
|
|
81
141
|
close() {
|
|
82
142
|
this.dialogRef.close(null);
|
|
@@ -84,19 +144,41 @@ export class UnbPessoaTelefoneFormComponent {
|
|
|
84
144
|
salvarclose() {
|
|
85
145
|
this.dialogRef.close(this.telefoneSalvo);
|
|
86
146
|
}
|
|
147
|
+
handleError(erro) {
|
|
148
|
+
let erroTratado;
|
|
149
|
+
// Converte string local em Objeto Padrão
|
|
150
|
+
if (typeof erro === 'string') {
|
|
151
|
+
erroTratado = {
|
|
152
|
+
status: 400,
|
|
153
|
+
mensagemSimples: erro,
|
|
154
|
+
mensagemHtml: `<strong>${erro}</strong>`
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
erroTratado = erro;
|
|
159
|
+
}
|
|
160
|
+
// 1. SnackBar
|
|
161
|
+
if (erroTratado.mensagemSimples) {
|
|
162
|
+
this.openSnackBar(erroTratado.mensagemSimples);
|
|
163
|
+
}
|
|
164
|
+
// 2. AlertService (Se houver tag <unb-mensagem> no HTML do dialog)
|
|
165
|
+
if (this.alertService && erroTratado.mensagemHtml) {
|
|
166
|
+
this.alertService.showMessage(erroTratado.mensagemHtml, UnbTipoMensagemEnum.DANGER, this.idMensagemService);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
87
169
|
openSnackBar(message) {
|
|
88
170
|
this.snackBar.open(message, 'x', {
|
|
89
171
|
duration: 5000,
|
|
90
172
|
});
|
|
91
173
|
}
|
|
92
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaTelefoneFormComponent, deps: [{ token: i1.MatSnackBar }, { token: i2.UnBPessoaService }, { token: i3.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
93
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbPessoaTelefoneFormComponent, selector: "lib-unb-pessoa-telefone-form", ngImport: i0, template: "<h1 mat-dialog-title>Cadastro de Telefone</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>
|
|
174
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaTelefoneFormComponent, deps: [{ token: i1.MatSnackBar }, { token: i2.UnBPessoaService }, { token: i3.UnbMensagemService }, { token: i4.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
175
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbPessoaTelefoneFormComponent, selector: "lib-unb-pessoa-telefone-form", ngImport: i0, template: "<h1 mat-dialog-title>Cadastro de Telefone</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n <mat-dialog-content>\r\n <unb-mensagem [identificador]=\"idMensagemService\"></unb-mensagem>\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)]=\"telefone.tipoTelefoneCodigo\" [compareWith]=\"compararTipos\" name=\"tipoTelefoneCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of listaTipoTelefone\" [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>DDD</mat-label>\r\n <input type=\"text\" maxlength=\"3\" required matInput [(ngModel)]=\"telefone.ddd\" name=\"dddValue\" #dddValue=\"ngModel\" />\r\n </mat-form-field> \r\n \r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>N\u00FAmero</mat-label>\r\n <input type=\"text\" required maxlength=\"9\" matInput [(ngModel)]=\"telefone.numero\" name=\"telefoneValue\" #telefoneValue=\"ngModel\" />\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: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i6.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: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { 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: i8.UnbMensagemComponent, selector: "unb-mensagem", inputs: ["mensagem", "tipo", "identificador"] }, { kind: "component", type: i9.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i9.MatLabel, selector: "mat-label" }, { kind: "directive", type: i10.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: i4.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i4.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i4.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i11.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: i12.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }] }); }
|
|
94
176
|
}
|
|
95
177
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaTelefoneFormComponent, decorators: [{
|
|
96
178
|
type: Component,
|
|
97
|
-
args: [{ standalone: false, selector: 'lib-unb-pessoa-telefone-form', template: "<h1 mat-dialog-title>Cadastro de Telefone</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>
|
|
98
|
-
}], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.MatDialogRef }, { type: undefined, decorators: [{
|
|
179
|
+
args: [{ standalone: false, selector: 'lib-unb-pessoa-telefone-form', template: "<h1 mat-dialog-title>Cadastro de Telefone</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n <mat-dialog-content>\r\n <unb-mensagem [identificador]=\"idMensagemService\"></unb-mensagem>\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)]=\"telefone.tipoTelefoneCodigo\" [compareWith]=\"compararTipos\" name=\"tipoTelefoneCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of listaTipoTelefone\" [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>DDD</mat-label>\r\n <input type=\"text\" maxlength=\"3\" required matInput [(ngModel)]=\"telefone.ddd\" name=\"dddValue\" #dddValue=\"ngModel\" />\r\n </mat-form-field> \r\n \r\n <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n <mat-label>N\u00FAmero</mat-label>\r\n <input type=\"text\" required maxlength=\"9\" matInput [(ngModel)]=\"telefone.numero\" name=\"telefoneValue\" #telefoneValue=\"ngModel\" />\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"] }]
|
|
180
|
+
}], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.UnbMensagemService }, { type: i4.MatDialogRef }, { type: undefined, decorators: [{
|
|
99
181
|
type: Inject,
|
|
100
182
|
args: [MAT_DIALOG_DATA]
|
|
101
183
|
}] }] });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unb-pessoa-telefone-form.js","sourceRoot":"","sources":["../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.ts","../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-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 { UnbPessoaTelefone, UnbPessoaTelefoneTipo } from '../unb-pessoa-models/unb-pessoa-telefone.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@Component({\r\n  standalone: false,\r\n  selector: 'lib-unb-pessoa-telefone-form',\r\n  templateUrl: './unb-pessoa-telefone-form.html',\r\n  styleUrl: './unb-pessoa-telefone-form.css'\r\n})\r\nexport class UnbPessoaTelefoneFormComponent implements OnInit {\r\n  telefoneSalvo!: UnbPessoaTelefone;\r\n  telefone = new UnbPessoaTelefone();\r\n  telefonesList: UnbPessoaTelefone[];\r\n  tipoTelefone!: Observable<UnbPessoaTelefoneTipo[]>;\r\n  listaTipoEndereco: UnbPessoaTelefoneTipo[] = [];\r\n\r\n  constructor(private snackBar: MatSnackBar, private service: UnBPessoaService, public dialogRef: MatDialogRef<UnbPessoaTelefoneFormComponent>, @Inject(MAT_DIALOG_DATA) public data: any) {\r\n    this.telefone = JSON.parse(JSON.stringify(data.telefone)); // 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.telefonesList) {\r\n      this.telefonesList = JSON.parse(JSON.stringify(data.telefonesList)); // Faça uma cópia profunda se for manipular\r\n    } else {\r\n      this.telefonesList = []; // Inicialize como vazio se não for passada\r\n    }\r\n\r\n    if (!this.telefone) {\r\n      this.telefone = new UnbPessoaTelefone();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.tipoTelefone = this.service.getTipoTelefone();\r\n    // Inscreve para guardar a lista em uma variável comum\r\n    this.tipoTelefone.subscribe(lista => {\r\n      this.listaTipoEndereco = lista;\r\n\r\n      // Se já tiver tipoTelefoneCodigo, preenche o nome correspondente\r\n      if (this.telefone.tipoTelefoneCodigo != null) {\r\n        const tipoEncontrado = lista.find(t => t.codigo === this.telefone.tipoTelefoneCodigo);\r\n        if (tipoEncontrado) {\r\n          this.telefone.tipo = tipoEncontrado.denominacao;\r\n        }\r\n      } else if (this.telefone.tipo) {\r\n        const tipoEncontrado = lista.find(\r\n          t => t.denominacao?.toLowerCase() === this.telefone.tipo?.toLowerCase()\r\n        );\r\n        if (tipoEncontrado) {\r\n          this.telefone.tipoTelefoneCodigo = 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.telefone) == false) return;\r\n\r\n    this.telefoneSalvo = this.telefone;\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.listaTipoEndereco.find(t => t.codigo === codigoSelecionado);\r\n    if (tipoSelecionado) {\r\n      this.telefone.tipo = tipoSelecionado.denominacao;\r\n    }\r\n  }\r\n  \r\n\r\n  /**\r\n   * Valida o objeto de telefone.\r\n   * Retorna true se o telefone for válido, false caso contrário.\r\n   */\r\n  validar(telefoneToValidate: UnbPessoaTelefone): boolean {\r\n    return true; // Implementar a lógica de validação conforme necessário\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.telefoneSalvo);\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 Telefone</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>DDD</mat-label>\r\n        <input type=\"text\" matInput [(ngModel)]=\"telefone.ddd\" name=\"dddValue\" #dddValue=\"ngModel\" />\r\n      </mat-form-field> \r\n      \r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>Número</mat-label>\r\n        <input type=\"text\" matInput [(ngModel)]=\"telefone.numero\" name=\"telefoneValue\" #telefoneValue=\"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)]=\"telefone.tipoTelefoneCodigo\" [compareWith]=\"compararTipos\" name=\"tipoTelefoneCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n          <mat-option *ngFor=\"let tipo of tipoTelefone | 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>"]}
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unb-pessoa-telefone-form.js","sourceRoot":"","sources":["../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.ts","../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-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 { UnbPessoaTelefone, UnbPessoaTelefoneTipo } from '../unb-pessoa-models/unb-pessoa-telefone.model';\r\nimport { UnbPessoaErroPadrao, UnBPessoaService } from '../unb-pessoa.service';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { NgForm } from '@angular/forms';\r\nimport { UnbMensagemService, UnbTipoMensagemEnum } from '../../unb-mensagem/unb-mensagem.service';\r\n\r\n@Component({\r\n  standalone: false,\r\n  selector: 'lib-unb-pessoa-telefone-form',\r\n  templateUrl: './unb-pessoa-telefone-form.html',\r\n  styleUrl: './unb-pessoa-telefone-form.css'\r\n})\r\nexport class UnbPessoaTelefoneFormComponent implements OnInit {\r\n  telefoneSalvo!: UnbPessoaTelefone;\r\n  telefone = new UnbPessoaTelefone();\r\n  telefonesList: UnbPessoaTelefone[];\r\n  listaTipoTelefone: UnbPessoaTelefoneTipo[] = [];\r\n  idMensagemService = \"UnbPessoaTelefoneForm\";\r\n\r\n  constructor(private snackBar: MatSnackBar, private service: UnBPessoaService, private alertService: UnbMensagemService, public dialogRef: MatDialogRef<UnbPessoaTelefoneFormComponent>, @Inject(MAT_DIALOG_DATA) public data: any) {\r\n    this.telefone = JSON.parse(JSON.stringify(data.telefone)); // 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.telefonesList) {\r\n      this.telefonesList = JSON.parse(JSON.stringify(data.telefonesList)); // Faça uma cópia profunda se for manipular\r\n    } else {\r\n      this.telefonesList = []; // Inicialize como vazio se não for passada\r\n    }\r\n\r\n    if (!this.telefone) {\r\n      this.telefone = new UnbPessoaTelefone();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.service.getTipoTelefone().subscribe({\r\n      next: (lista) => {\r\n      this.listaTipoTelefone = lista;\r\n\r\n      // Se já tiver tipoTelefoneCodigo, preenche o nome correspondente\r\n      if (this.telefone.tipoTelefoneCodigo != null) {\r\n        const tipoEncontrado = lista.find(t => t.codigo === this.telefone.tipoTelefoneCodigo);\r\n        if (tipoEncontrado) {\r\n          this.telefone.tipo = tipoEncontrado.denominacao;\r\n        }\r\n      } else if (this.telefone.tipo) {\r\n        const tipoEncontrado = lista.find(\r\n          t => t.denominacao?.toLowerCase() === this.telefone.tipo?.toLowerCase()\r\n        );\r\n        if (tipoEncontrado) {\r\n          this.telefone.tipoTelefoneCodigo = tipoEncontrado.codigo!;\r\n        }\r\n      }\r\n    },\r\n      error: (err: UnbPessoaErroPadrao) => this.handleError(err)\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    // 1. Define o 'tipo' padrão (1) se não for preenchido (Conforme sua solicitação)\r\n    if (!this.telefone.tipoTelefoneCodigo) {\r\n      this.telefone.tipoTelefoneCodigo = 1; // 1 é geralmente 'Residencial' ou 'Principal'\r\n    }\r\n\r\n    // 2. Define a 'ordem' (que o back-end chama de 'ordemTelefone')\r\n    if (!this.telefone.ordem || this.telefone.ordem === 0) {\r\n      let maxOrdem = 0;\r\n\r\n      // Verifica se a lista de telefones já existe e tem itens\r\n      if (this.telefonesList && this.telefonesList.length > 0) {\r\n        maxOrdem = Math.max(...this.telefonesList.map(t => t.ordem || 0));\r\n      }\r\n\r\n      // Define a ordem do novo telefone como a maior ordem + 1\r\n      this.telefone.ordem = maxOrdem + 1;\r\n    }\r\n    if (this.validar(this.telefone) == false) return;\r\n\r\n    this.telefoneSalvo = this.telefone;\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.listaTipoTelefone.find(t => t.codigo === codigoSelecionado); // <--- Renomeado de listaTipoEndereco\r\n    if (tipoSelecionado) {\r\n      this.telefone.tipo = tipoSelecionado.denominacao;\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Valida o objeto de telefone com base nas regras do backend.\r\n   * Retorna true se o telefone for válido, false caso contrário.\r\n   */\r\n  validar(telefoneToValidate: UnbPessoaTelefone): boolean {\r\n    \r\n    // 1. Validação de Número (Obrigatório)\r\n    if (!telefoneToValidate.numero || telefoneToValidate.numero.trim() === '') {\r\n      this.openSnackBar(\"Número do telefone é um campo obrigatório.\");\r\n      return false;\r\n    }\r\n\r\n    // 2. Validação de Número (Formato)\r\n    // que ele espera 8 ou 9 dígitos numéricos (padrão Brasil).\r\n    const numeroLimpo = telefoneToValidate.numero.replace(/\\D/g, ''); // Remove não-dígitos\r\n    if (numeroLimpo.length !== 9) {\r\n      this.openSnackBar(\"Número do telefone deve conter exatamente 9 dígitos.\");\r\n      return false;\r\n    }\r\n    \r\n    // 3. Validação de DDD (Obrigatório - Boa prática, embora o Java não exija)\r\n    if (!telefoneToValidate.ddd || telefoneToValidate.ddd.trim() === '') {\r\n      this.openSnackBar(\"DDD é um campo obrigatório.\");\r\n      return false;\r\n    }\r\n\r\n    // 4. Validação de DDD (Tamanho Máximo)\r\n    if (telefoneToValidate.ddd.trim().length > 3) {\r\n      this.openSnackBar(\"DDD deve ter no máximo 3 caracteres.\");\r\n      return false;\r\n    }\r\n\r\n    // 5. Validação de DDI (Tamanho Máximo)\r\n    //\r\n    if (telefoneToValidate.ddi && telefoneToValidate.ddi.trim().length > 5) {\r\n      this.openSnackBar(\"DDI deve ter no máximo 5 caracteres.\");\r\n      return false;\r\n    }\r\n\r\n    // 6. Validação de Ramal (Tamanho Máximo)\r\n    //\r\n    if (telefoneToValidate.ramal && telefoneToValidate.ramal.trim().length > 6) {\r\n      this.openSnackBar(\"Ramal deve ter no máximo 6 caracteres.\");\r\n      return false;\r\n    }\r\n    \r\n    // 7. Validação de NomeResponsavel (Tamanho Máximo)\r\n    //\r\n    if (telefoneToValidate.nomeResponsavel && telefoneToValidate.nomeResponsavel.trim().length > 100) {\r\n      this.openSnackBar(\"Nome do Responsável deve ter no máximo 100 caracteres.\");\r\n      return false;\r\n    }\r\n\r\n    return true; // Passou em todas as validações!\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.telefoneSalvo);\r\n  }\r\n\r\n  handleError(erro: UnbPessoaErroPadrao | string) {\r\n    let erroTratado: UnbPessoaErroPadrao;\r\n\r\n    // Converte string local em Objeto Padrão\r\n    if (typeof erro === 'string') {\r\n      erroTratado = {\r\n        status: 400,\r\n        mensagemSimples: erro,\r\n        mensagemHtml: `<strong>${erro}</strong>`\r\n      };\r\n    } else {\r\n      erroTratado = erro;\r\n    }\r\n\r\n    // 1. SnackBar\r\n    if (erroTratado.mensagemSimples) {\r\n      this.openSnackBar(erroTratado.mensagemSimples);\r\n    }\r\n\r\n    // 2. AlertService (Se houver tag <unb-mensagem> no HTML do dialog)\r\n    if (this.alertService && erroTratado.mensagemHtml) {\r\n      this.alertService.showMessage(erroTratado.mensagemHtml, UnbTipoMensagemEnum.DANGER, this.idMensagemService);\r\n    }\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 Telefone</h1>\r\n<form (ngSubmit)=\"salvar(form)\" #form=\"ngForm\">\r\n  <mat-dialog-content>\r\n    <unb-mensagem [identificador]=\"idMensagemService\"></unb-mensagem>\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)]=\"telefone.tipoTelefoneCodigo\" [compareWith]=\"compararTipos\" name=\"tipoTelefoneCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n          <mat-option *ngFor=\"let tipo of listaTipoTelefone\" [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>DDD</mat-label>\r\n        <input type=\"text\" maxlength=\"3\" required matInput [(ngModel)]=\"telefone.ddd\" name=\"dddValue\" #dddValue=\"ngModel\" />\r\n      </mat-form-field> \r\n      \r\n      <mat-form-field class=\"form-100\" appearance=\"outline\">\r\n        <mat-label>Número</mat-label>\r\n        <input type=\"text\" required maxlength=\"9\" matInput [(ngModel)]=\"telefone.numero\" name=\"telefoneValue\" #telefoneValue=\"ngModel\" />\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>"]}
|
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import { UnbPessoaTelefoneFormComponent } from './unb-pessoa-telefone-form';
|
|
3
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/material/snack-bar";
|
|
5
6
|
import * as i2 from "../unb-pessoa.service";
|
|
6
7
|
import * as i3 from "@angular/material/dialog";
|
|
7
8
|
import * as i4 from "@angular/common";
|
|
8
9
|
import * as i5 from "@angular/material/icon";
|
|
9
|
-
import * as i6 from "@angular/
|
|
10
|
+
import * as i6 from "@angular/cdk/drag-drop";
|
|
11
|
+
import * as i7 from "@angular/material/button";
|
|
10
12
|
export class UnbPessoaTelefoneListComponent {
|
|
11
13
|
constructor(snackBar, service, dialog) {
|
|
12
14
|
this.snackBar = snackBar;
|
|
@@ -14,34 +16,41 @@ export class UnbPessoaTelefoneListComponent {
|
|
|
14
16
|
this.dialog = dialog;
|
|
15
17
|
this.podeEditar = true;
|
|
16
18
|
this.telefones = [];
|
|
17
|
-
this.
|
|
19
|
+
this.backendURL = '';
|
|
18
20
|
this.telefonesEmitted = new EventEmitter();
|
|
19
21
|
}
|
|
20
22
|
ngOnInit() {
|
|
21
23
|
this.tipoTelefone = this.service.getTipoTelefone();
|
|
22
|
-
this.sortAndAssignOrder(); // organiza a lista de telefones. As vezes tem ordem duplicada ou faltando.
|
|
23
24
|
}
|
|
24
|
-
|
|
25
|
+
// tem que fazer isso pq no on init eu ainda nao tenho a lista de telefones
|
|
26
|
+
ngOnChanges(changes) {
|
|
27
|
+
// Verifica se a propriedade 'telefones' mudou
|
|
28
|
+
if (changes['telefones'] && this.telefones) {
|
|
29
|
+
// chamada quando os dados realmente chegarem
|
|
30
|
+
this.sortAndAssignOrder();
|
|
31
|
+
}
|
|
25
32
|
}
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
+
excluir(telefoneParaExcluir) {
|
|
34
|
+
if (telefoneParaExcluir.codigo) {
|
|
35
|
+
// Se tem código, remove por ele (mais seguro)
|
|
36
|
+
this.telefones = this.telefones.filter(t => t.codigo !== telefoneParaExcluir.codigo);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
// Se não tem código (novo item), remove pela ordem
|
|
40
|
+
this.telefones = this.telefones.filter(t => t.ordem !== telefoneParaExcluir.ordem);
|
|
41
|
+
}
|
|
42
|
+
// Chama função existente que re-calcula as ordens e emite a lista atualizada
|
|
33
43
|
this.atualizarOrdem();
|
|
44
|
+
this.telefonesEmitted.emit(this.telefones);
|
|
34
45
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
return;
|
|
38
|
-
[this.telefones[index], this.telefones[index + 1]] = [this.telefones[index + 1], this.telefones[index]];
|
|
39
|
-
this.atualizarOrdem();
|
|
46
|
+
editar(telefone) {
|
|
47
|
+
this.openFormDialog(telefone);
|
|
40
48
|
}
|
|
41
49
|
atualizarOrdem() {
|
|
42
50
|
this.telefones.forEach((telefone, idx) => {
|
|
43
51
|
telefone.ordem = idx + 1;
|
|
44
52
|
});
|
|
53
|
+
// reemite a lista atualizada, igual antes
|
|
45
54
|
this.telefonesEmitted.emit(this.telefones);
|
|
46
55
|
}
|
|
47
56
|
openFormDialog(toEdit) {
|
|
@@ -49,26 +58,47 @@ export class UnbPessoaTelefoneListComponent {
|
|
|
49
58
|
width: '900px',
|
|
50
59
|
data: {
|
|
51
60
|
telefone: toEdit, // E-mail a ser editado ou vazio para novo
|
|
52
|
-
|
|
61
|
+
telefonesList: this.telefones // A sua lista COMPLETA de e-mails
|
|
53
62
|
},
|
|
54
63
|
});
|
|
55
64
|
dialogRef.afterClosed().subscribe(result => {
|
|
56
|
-
if (result) {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
65
|
+
if (!result) {
|
|
66
|
+
return; // Usuário clicou em 'Fechar' ou 'Cancelar'
|
|
67
|
+
}
|
|
68
|
+
// 'result' é o objeto retornado pelo dialog (editado ou novo)
|
|
69
|
+
let index = -1;
|
|
70
|
+
// 1. Tenta encontrar pelo 'codigo' (para itens que já vieram do banco)
|
|
71
|
+
if (result.codigo) {
|
|
72
|
+
index = this.telefones.findIndex(t => t.codigo === result.codigo);
|
|
73
|
+
}
|
|
74
|
+
// 2. Se não achou pelo 'codigo', tenta pela 'ordem'.
|
|
75
|
+
// A 'ordem' é o nosso identificador único para itens que
|
|
76
|
+
// ainda não foram salvos no banco (criados/editados localmente).
|
|
77
|
+
if (index === -1 && result.ordem) {
|
|
78
|
+
index = this.telefones.findIndex(t => t.ordem === result.ordem);
|
|
79
|
+
}
|
|
80
|
+
if (index > -1) {
|
|
81
|
+
// ENCONTROU (pelo 'codigo' ou pela 'ordem'): Atualiza o item existente
|
|
82
|
+
this.telefones[index] = result;
|
|
69
83
|
}
|
|
84
|
+
else {
|
|
85
|
+
// NÃO ENCONTROU: É um item 100% novo (não uma edição)
|
|
86
|
+
// O form (unb-pessoa-telefone-form) já cuidou de
|
|
87
|
+
// atribuir a 'ordem' correta (maxOrdem + 1)
|
|
88
|
+
this.telefones.push(result);
|
|
89
|
+
}
|
|
90
|
+
// vamos apenas re-ordenar a lista pela 'ordem' que já temos
|
|
91
|
+
// e depois emitir.
|
|
92
|
+
this.telefones.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));
|
|
93
|
+
this.telefonesEmitted.emit(this.telefones);
|
|
70
94
|
});
|
|
71
95
|
}
|
|
96
|
+
moverTelefone(event) {
|
|
97
|
+
// troca a posição dentro do array
|
|
98
|
+
moveItemInArray(this.telefones, event.previousIndex, event.currentIndex);
|
|
99
|
+
// atualiza o campo 'ordem' em cada item
|
|
100
|
+
this.atualizarOrdem();
|
|
101
|
+
}
|
|
72
102
|
sortAndAssignOrder() {
|
|
73
103
|
// 1. Crie uma cópia da lista para não modificar a original durante a iteração inicial
|
|
74
104
|
const tempEmails = [...this.telefones];
|
|
@@ -123,18 +153,18 @@ export class UnbPessoaTelefoneListComponent {
|
|
|
123
153
|
this.telefones.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));
|
|
124
154
|
}
|
|
125
155
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaTelefoneListComponent, 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: UnbPessoaTelefoneListComponent, selector: "lib-unb-pessoa-telefone-list", inputs: { podeEditar: "podeEditar", telefones: "telefones",
|
|
156
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbPessoaTelefoneListComponent, selector: "lib-unb-pessoa-telefone-list", inputs: { podeEditar: "podeEditar", telefones: "telefones", backendURL: "backendURL" }, outputs: { telefonesEmitted: "telefonesEmitted" }, usesOnChanges: true, 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 {{ telefones?.length === 1 ? 'Telefone Cadastrado' : 'Telefones Cadastrados' }}\r\n </span>\r\n <span class=\"titulo\">({{ telefones?.length || 0 }})</span>\r\n </div>\r\n\r\n <button type=\"button\" matTooltip=\"Novo Telefone\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n Cadastrar Novo Telefone\r\n </button>\r\n </div>\r\n\r\n\r\n <!-- Exibe a tabela de despesas somente se houver despesas -->\r\n <table class=\"my-table\" *ngIf=\"telefones && telefones.length > 0\" cdkDropList (cdkDropListDropped)=\"moverTelefone($event)\">\r\n <tr style=\"background-color: #e4e3e3cc;\">\r\n <th style=\"width: 5%; text-align: center;\">Ordem</th>\r\n <th style=\"width: 20%;\">DDD</th>\r\n <th>N\u00FAmero</th> \r\n <th>Tipo</th>\r\n <th style=\"width: 1%; text-align: center;\">A\u00E7\u00F5es</th>\r\n </tr>\r\n\r\n <tr *ngFor=\"let valor of telefones; let i = index\" class=\"my-tr\" cdkDrag>\r\n <td style=\"text-align: center;\"> \r\n <div class=\"drag-cell\" cdkDragHandle>\r\n <mat-icon>drag_indicator</mat-icon>\r\n <span>{{ i + 1 }}</span>\r\n </div>\r\n </td>\r\n <td>{{ valor.ddd }}</td> \r\n <td>{{ valor.numero }}</td> \r\n <td>{{ valor.tipo?.toUpperCase() }}</td>\r\n <td>\r\n <div class=\"actions-container\">\r\n <button type=\"button\" mat-icon-button color=\"primary\" (click)=\"editar(valor)\">\r\n <mat-icon>edit</mat-icon>\r\n </button>\r\n <button type=\"button\" mat-icon-button color=\"warn\" (click)=\"excluir(valor)\">\r\n <mat-icon>delete</mat-icon>\r\n </button>\r\n </div>\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}.order-input{width:40px;text-align:center;border:1px solid #ccc;border-radius:4px;padding:2px}.order-input:focus{border-color:#1976d2;outline:none}.drag-cell{display:inline-flex;align-items:center;justify-content:center;gap:4px;cursor:grab;-webkit-user-select:none;user-select:none}.drag-cell mat-icon{font-size:18px;line-height:1;vertical-align:middle}.cdk-drag-preview{background:#fff;border-radius:6px;box-shadow:0 4px 12px #0003;display:table;border-collapse:collapse}.cdk-drag-placeholder{opacity:0;display:table-row}.cdk-drag-animating{transition:transform .2s cubic-bezier(0,0,.2,1)}table[cdkDropList] tr{border-bottom:1px solid #e0e0e0}table[cdkDropList] td{padding:8px}.actions-container{display:flex;justify-content:flex-end;gap:4px}\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: "directive", type: i6.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i6.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i6.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { 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"] }] }); }
|
|
127
157
|
}
|
|
128
158
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaTelefoneListComponent, decorators: [{
|
|
129
159
|
type: Component,
|
|
130
|
-
args: [{ standalone: false, selector: 'lib-unb-pessoa-telefone-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 {{ telefones?.length === 1 ? 'Telefone Cadastrado' : 'Telefones Cadastrados' }}\r\n </span>\r\n <span class=\"titulo\">({{ telefones?.length || 0 }})</span>\r\n </div>\r\n\r\n <button matTooltip=\"Novo Telefone\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n Cadastrar Novo Telefone\r\n </button>\r\n </div>\r\n\r\n <!-- Exibe a tabela de despesas somente se houver despesas -->\r\n
|
|
160
|
+
args: [{ standalone: false, selector: 'lib-unb-pessoa-telefone-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 {{ telefones?.length === 1 ? 'Telefone Cadastrado' : 'Telefones Cadastrados' }}\r\n </span>\r\n <span class=\"titulo\">({{ telefones?.length || 0 }})</span>\r\n </div>\r\n\r\n <button type=\"button\" matTooltip=\"Novo Telefone\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n Cadastrar Novo Telefone\r\n </button>\r\n </div>\r\n\r\n\r\n <!-- Exibe a tabela de despesas somente se houver despesas -->\r\n <table class=\"my-table\" *ngIf=\"telefones && telefones.length > 0\" cdkDropList (cdkDropListDropped)=\"moverTelefone($event)\">\r\n <tr style=\"background-color: #e4e3e3cc;\">\r\n <th style=\"width: 5%; text-align: center;\">Ordem</th>\r\n <th style=\"width: 20%;\">DDD</th>\r\n <th>N\u00FAmero</th> \r\n <th>Tipo</th>\r\n <th style=\"width: 1%; text-align: center;\">A\u00E7\u00F5es</th>\r\n </tr>\r\n\r\n <tr *ngFor=\"let valor of telefones; let i = index\" class=\"my-tr\" cdkDrag>\r\n <td style=\"text-align: center;\"> \r\n <div class=\"drag-cell\" cdkDragHandle>\r\n <mat-icon>drag_indicator</mat-icon>\r\n <span>{{ i + 1 }}</span>\r\n </div>\r\n </td>\r\n <td>{{ valor.ddd }}</td> \r\n <td>{{ valor.numero }}</td> \r\n <td>{{ valor.tipo?.toUpperCase() }}</td>\r\n <td>\r\n <div class=\"actions-container\">\r\n <button type=\"button\" mat-icon-button color=\"primary\" (click)=\"editar(valor)\">\r\n <mat-icon>edit</mat-icon>\r\n </button>\r\n <button type=\"button\" mat-icon-button color=\"warn\" (click)=\"excluir(valor)\">\r\n <mat-icon>delete</mat-icon>\r\n </button>\r\n </div>\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}.order-input{width:40px;text-align:center;border:1px solid #ccc;border-radius:4px;padding:2px}.order-input:focus{border-color:#1976d2;outline:none}.drag-cell{display:inline-flex;align-items:center;justify-content:center;gap:4px;cursor:grab;-webkit-user-select:none;user-select:none}.drag-cell mat-icon{font-size:18px;line-height:1;vertical-align:middle}.cdk-drag-preview{background:#fff;border-radius:6px;box-shadow:0 4px 12px #0003;display:table;border-collapse:collapse}.cdk-drag-placeholder{opacity:0;display:table-row}.cdk-drag-animating{transition:transform .2s cubic-bezier(0,0,.2,1)}table[cdkDropList] tr{border-bottom:1px solid #e0e0e0}table[cdkDropList] td{padding:8px}.actions-container{display:flex;justify-content:flex-end;gap:4px}\n"] }]
|
|
131
161
|
}], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.MatDialog }], propDecorators: { podeEditar: [{
|
|
132
162
|
type: Input
|
|
133
163
|
}], telefones: [{
|
|
134
164
|
type: Input
|
|
135
|
-
}],
|
|
165
|
+
}], backendURL: [{
|
|
136
166
|
type: Input
|
|
137
167
|
}], telefonesEmitted: [{
|
|
138
168
|
type: Output
|
|
139
169
|
}] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unb-pessoa-telefone-list.js","sourceRoot":"","sources":["../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.ts","../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-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 { UnbPessoaTelefone, UnbPessoaTelefoneTipo } from '../unb-pessoa-models/unb-pessoa-telefone.model';\r\nimport { UnBPessoaService } from '../unb-pessoa.service';\r\nimport { UnbPessoaTelefoneFormComponent } from './unb-pessoa-telefone-form';\r\n\r\n@Component({\r\n  standalone: false,\r\n  selector: 'lib-unb-pessoa-telefone-list',\r\n  templateUrl: './unb-pessoa-telefone-list.html',\r\n  styleUrl: './unb-pessoa-telefone-list.css'\r\n})\r\nexport class UnbPessoaTelefoneListComponent implements OnInit {\r\n  @Input() podeEditar = true;\r\n  @Input() telefones: any = [];\r\n  @Input() apiPessoaConfig: { url: string; token: string } = { url: '', token: '' };\r\n  @Output() telefonesEmitted = new EventEmitter<UnbPessoaTelefone[]>();\r\n\r\n  tipoTelefone!: Observable<UnbPessoaTelefoneTipo[]>;\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.tipoTelefone = this.service.getTipoTelefone();\r\n\r\n    this.sortAndAssignOrder(); // organiza a lista de telefones. As vezes tem ordem duplicada ou faltando.\r\n  }\r\n\r\n  excluir(telefone: UnbPessoaTelefoneTipo) {\r\n\r\n  }\r\n\r\n  editar(telefone: UnbPessoaTelefoneTipo) {\r\n    this.openFormDialog(telefone);\r\n  }\r\n\r\n  moverParaCima(index: number) {\r\n    if (index <= 0) return;\r\n\r\n    [this.telefones[index - 1], this.telefones[index]] = [this.telefones[index], this.telefones[index - 1]];\r\n    this.atualizarOrdem();\r\n  }\r\n\r\n  moverParaBaixo(index: number) {\r\n    if (index >= this.telefones.length - 1) return;\r\n\r\n    [this.telefones[index], this.telefones[index + 1]] = [this.telefones[index + 1], this.telefones[index]];\r\n    this.atualizarOrdem();\r\n  }\r\n\r\n  atualizarOrdem() {\r\n    this.telefones.forEach((telefone, idx) => {\r\n      telefone.ordem = idx + 1;\r\n    });\r\n\r\n    this.telefonesEmitted.emit(this.telefones);\r\n  }\r\n\r\n  openFormDialog(toEdit: any) {\r\n    const dialogRef = this.dialog.open(UnbPessoaTelefoneFormComponent, {\r\n      width: '900px',\r\n      data: {\r\n        telefone: toEdit, // E-mail a ser editado ou vazio para novo\r\n        emailsList: this.telefones // 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.telefones.findIndex(e => e.codigo === result.codigo);\r\n\r\n        if (result.codigo && index > -1) {\r\n          // Atualiza e-mail existente\r\n          this.telefones[index] = result;\r\n        } else {\r\n          // Adiciona novo e-mail (gera ordem automaticamente se quiser)\r\n          result.ordem = this.telefones.length + 1;\r\n          this.telefones.push(result);\r\n        }\r\n        // Emite lista atualizada\r\n        this.telefonesEmitted.emit(this.telefones);\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.telefones];\r\n\r\n    // 2. Mapeie as ordens existentes para identificar duplicatas e ausentes\r\n    const orderMap = new Map<number, UnbPessoaTelefone[]>();\r\n    const emailsWithoutOrder: UnbPessoaTelefone[] = [];\r\n\r\n    tempEmails.forEach(telefone => {\r\n      if (telefone.ordem !== undefined && telefone.ordem !== null) {\r\n        if (!orderMap.has(telefone.ordem)) {\r\n          orderMap.set(telefone.ordem, []);\r\n        }\r\n        orderMap.get(telefone.ordem)?.push(telefone);\r\n      } else {\r\n        emailsWithoutOrder.push(telefone);\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 telefones 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.telefones.forEach(telefone => { // Iterar sobre a lista original para modificar in-place\r\n      if (telefone.ordem !== undefined && telefone.ordem !== null) {\r\n        if (!finalUsedOrders.has(telefone.ordem)) {\r\n          // Se a ordem ainda não foi usada, use-a e adicione ao set\r\n          finalUsedOrders.add(telefone.ordem);\r\n        } else {\r\n          // Se a ordem já foi usada (é uma duplicata), atribua uma nova\r\n          telefone.ordem = getNextAvailableOrder();\r\n          finalUsedOrders.add(telefone.ordem); // Adiciona a nova ordem ao set\r\n        }\r\n      }\r\n    });\r\n\r\n    // 5. Atribua ordens para telefones que não tinham ordem definida\r\n    emailsWithoutOrder.forEach(telefone => {\r\n      telefone.ordem = getNextAvailableOrder();\r\n      finalUsedOrders.add(telefone.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.telefones.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));\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                {{ telefones?.length === 1 ? 'Telefone Cadastrado' : 'Telefones Cadastrados' }}\r\n            </span>\r\n            <span class=\"titulo\">({{ telefones?.length || 0 }})</span>\r\n        </div>\r\n\r\n        <button matTooltip=\"Novo Telefone\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n            Cadastrar Novo Telefone\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=\"telefones && telefones.length > 0\">\r\n        <tr style=\"background-color: #e4e3e3cc;\">\r\n            <th style=\"text-align: center;\" >Ordem</th>\r\n            <th>DDD</th>\r\n            <th>Número</th>\r\n            <th style=\"text-align: center;\">Ações</th>\r\n        </tr>\r\n\r\n        <tr *ngFor=\"let valor of telefones; let i = index\" class=\"my-tr\">\r\n            <td style=\"width: 5%; text-align: center;\">                \r\n                <button *ngIf=\"telefones.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=\"telefones.length > 1 && i < telefones.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: 20%;\">{{ valor.ddd }}</td>\r\n            <td style=\"width: 60%;\">{{ valor.numero}}</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>"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unb-pessoa-telefone-list.js","sourceRoot":"","sources":["../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.ts","../../../../../../projects/unb-lib-components/src/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, OnChanges, SimpleChanges } 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 { UnbPessoaTelefone, UnbPessoaTelefoneTipo } from '../unb-pessoa-models/unb-pessoa-telefone.model';\r\nimport { UnBPessoaService } from '../unb-pessoa.service';\r\nimport { UnbPessoaTelefoneFormComponent } from './unb-pessoa-telefone-form';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\n\r\n@Component({\r\n  standalone: false,\r\n  selector: 'lib-unb-pessoa-telefone-list',\r\n  templateUrl: './unb-pessoa-telefone-list.html',\r\n  styleUrl: './unb-pessoa-telefone-list.css'\r\n})\r\nexport class UnbPessoaTelefoneListComponent implements OnInit, OnChanges {\r\n\r\n  @Input() podeEditar = true;\r\n  @Input() telefones: any = [];\r\n  @Input() backendURL: string = '';\r\n  @Output() telefonesEmitted = new EventEmitter<UnbPessoaTelefone[]>();\r\n\r\n  tipoTelefone!: Observable<UnbPessoaTelefoneTipo[]>;\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.tipoTelefone = this.service.getTipoTelefone();\r\n  }\r\n\r\n  // tem que fazer isso pq no on init eu ainda nao tenho a lista de telefones\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    // Verifica se a propriedade 'telefones' mudou\r\n    if (changes['telefones'] && this.telefones) {\r\n      // chamada quando os dados realmente chegarem\r\n      this.sortAndAssignOrder(); \r\n    }\r\n  }\r\n\r\n  excluir(telefoneParaExcluir: UnbPessoaTelefone) {\r\n    if (telefoneParaExcluir.codigo) {\r\n      // Se tem código, remove por ele (mais seguro)\r\n      this.telefones = this.telefones.filter(t => t.codigo !== telefoneParaExcluir.codigo);\r\n    } else {\r\n      // Se não tem código (novo item), remove pela ordem\r\n      this.telefones = this.telefones.filter(t => t.ordem !== telefoneParaExcluir.ordem);\r\n    }\r\n\r\n    // Chama função existente que re-calcula as ordens e emite a lista atualizada\r\n    this.atualizarOrdem();\r\n    this.telefonesEmitted.emit(this.telefones);\r\n  }\r\n\r\n  editar(telefone: UnbPessoaTelefoneTipo) {\r\n    this.openFormDialog(telefone);\r\n  }\r\n\r\n  atualizarOrdem() {\r\n    this.telefones.forEach((telefone, idx) => {\r\n      telefone.ordem = idx + 1;\r\n    });\r\n\r\n    // reemite a lista atualizada, igual antes\r\n    this.telefonesEmitted.emit(this.telefones);\r\n  }\r\n\r\n  openFormDialog(toEdit: any) {\r\n    const dialogRef = this.dialog.open(UnbPessoaTelefoneFormComponent, {\r\n      width: '900px',\r\n      data: {\r\n        telefone: toEdit, // E-mail a ser editado ou vazio para novo\r\n        telefonesList: this.telefones // 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        return; // Usuário clicou em 'Fechar' ou 'Cancelar'\r\n      }\r\n\r\n      // 'result' é o objeto retornado pelo dialog (editado ou novo)\r\n      let index = -1;\r\n\r\n      // 1. Tenta encontrar pelo 'codigo' (para itens que já vieram do banco)\r\n      if (result.codigo) {\r\n        index = this.telefones.findIndex(t => t.codigo === result.codigo);\r\n      }\r\n      \r\n      // 2. Se não achou pelo 'codigo', tenta pela 'ordem'.\r\n      // A 'ordem' é o nosso identificador único para itens que\r\n      // ainda não foram salvos no banco (criados/editados localmente).\r\n      if (index === -1 && result.ordem) {\r\n         index = this.telefones.findIndex(t => t.ordem === result.ordem);\r\n      }\r\n\r\n      if (index > -1) {\r\n        // ENCONTROU (pelo 'codigo' ou pela 'ordem'): Atualiza o item existente\r\n        this.telefones[index] = result;\r\n      } else {\r\n        // NÃO ENCONTROU: É um item 100% novo (não uma edição)\r\n        // O form (unb-pessoa-telefone-form) já cuidou de\r\n        // atribuir a 'ordem' correta (maxOrdem + 1)\r\n        this.telefones.push(result);\r\n      }\r\n\r\n      // vamos apenas re-ordenar a lista pela 'ordem' que já temos\r\n      // e depois emitir.\r\n      this.telefones.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));\r\n      this.telefonesEmitted.emit(this.telefones);\r\n    });\r\n  }\r\n\r\n  moverTelefone(event: CdkDragDrop<any[]>) {\r\n    // troca a posição dentro do array\r\n    moveItemInArray(this.telefones, event.previousIndex, event.currentIndex);\r\n\r\n    // atualiza o campo 'ordem' em cada item\r\n    this.atualizarOrdem();\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.telefones];\r\n\r\n    // 2. Mapeie as ordens existentes para identificar duplicatas e ausentes\r\n    const orderMap = new Map<number, UnbPessoaTelefone[]>();\r\n    const emailsWithoutOrder: UnbPessoaTelefone[] = [];\r\n\r\n    tempEmails.forEach(telefone => {\r\n      if (telefone.ordem !== undefined && telefone.ordem !== null) {\r\n        if (!orderMap.has(telefone.ordem)) {\r\n          orderMap.set(telefone.ordem, []);\r\n        }\r\n        orderMap.get(telefone.ordem)?.push(telefone);\r\n      } else {\r\n        emailsWithoutOrder.push(telefone);\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 telefones 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.telefones.forEach(telefone => { // Iterar sobre a lista original para modificar in-place\r\n      if (telefone.ordem !== undefined && telefone.ordem !== null) {\r\n        if (!finalUsedOrders.has(telefone.ordem)) {\r\n          // Se a ordem ainda não foi usada, use-a e adicione ao set\r\n          finalUsedOrders.add(telefone.ordem);\r\n        } else {\r\n          // Se a ordem já foi usada (é uma duplicata), atribua uma nova\r\n          telefone.ordem = getNextAvailableOrder();\r\n          finalUsedOrders.add(telefone.ordem); // Adiciona a nova ordem ao set\r\n        }\r\n      }\r\n    });\r\n\r\n    // 5. Atribua ordens para telefones que não tinham ordem definida\r\n    emailsWithoutOrder.forEach(telefone => {\r\n      telefone.ordem = getNextAvailableOrder();\r\n      finalUsedOrders.add(telefone.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.telefones.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));\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                {{ telefones?.length === 1 ? 'Telefone Cadastrado' : 'Telefones Cadastrados' }}\r\n            </span>\r\n            <span class=\"titulo\">({{ telefones?.length || 0 }})</span>\r\n        </div>\r\n\r\n        <button type=\"button\" matTooltip=\"Novo Telefone\" mat-flat-button color=\"primary\" (click)=\"openFormDialog(null)\">\r\n            Cadastrar Novo Telefone\r\n        </button>\r\n    </div>\r\n\r\n\r\n    <!-- Exibe a tabela de despesas somente se houver despesas -->\r\n   <table class=\"my-table\" *ngIf=\"telefones && telefones.length > 0\" cdkDropList (cdkDropListDropped)=\"moverTelefone($event)\">\r\n    <tr style=\"background-color: #e4e3e3cc;\">\r\n        <th style=\"width: 5%; text-align: center;\">Ordem</th>\r\n        <th style=\"width: 20%;\">DDD</th>\r\n        <th>Número</th> \r\n        <th>Tipo</th>\r\n        <th style=\"width: 1%; text-align: center;\">Ações</th>\r\n    </tr>\r\n\r\n    <tr *ngFor=\"let valor of telefones; let i = index\" class=\"my-tr\" cdkDrag>\r\n        <td style=\"text-align: center;\"> \r\n            <div class=\"drag-cell\" cdkDragHandle>\r\n                <mat-icon>drag_indicator</mat-icon>\r\n                <span>{{ i + 1 }}</span>\r\n            </div>\r\n        </td>\r\n        <td>{{ valor.ddd }}</td> \r\n        <td>{{ valor.numero }}</td> \r\n        <td>{{ valor.tipo?.toUpperCase() }}</td>\r\n        <td>\r\n            <div class=\"actions-container\">\r\n                <button type=\"button\" mat-icon-button color=\"primary\" (click)=\"editar(valor)\">\r\n                    <mat-icon>edit</mat-icon>\r\n                </button>\r\n                <button type=\"button\" mat-icon-button color=\"warn\" (click)=\"excluir(valor)\">\r\n                    <mat-icon>delete</mat-icon>\r\n                </button>\r\n            </div>\r\n        </td>\r\n    </tr>\r\n</table>\r\n</div>"]}
|