@stiunb/unb-lib-components 18.0.23 → 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.
Files changed (25) hide show
  1. package/esm2022/lib/unb-mensagem/unb-mensagem.component.mjs +18 -26
  2. package/esm2022/lib/unb-mensagem/unb-mensagem.service.mjs +16 -21
  3. package/esm2022/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.mjs +60 -29
  4. package/esm2022/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.mjs +4 -4
  5. package/esm2022/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.mjs +98 -67
  6. package/esm2022/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-list.mjs +4 -4
  7. package/esm2022/lib/unb-pessoa/unb-pessoa-form/unb-pessoa-form.component.mjs +57 -73
  8. package/esm2022/lib/unb-pessoa/unb-pessoa-pesquisar/unb-pessoa-pesquisar.component.mjs +49 -36
  9. package/esm2022/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.mjs +57 -29
  10. package/esm2022/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.mjs +4 -4
  11. package/esm2022/lib/unb-pessoa/unb-pessoa.service.mjs +141 -45
  12. package/fesm2022/stiunb-unb-lib-components.mjs +467 -309
  13. package/fesm2022/stiunb-unb-lib-components.mjs.map +1 -1
  14. package/lib/unb-mensagem/unb-mensagem.component.d.ts +3 -17
  15. package/lib/unb-mensagem/unb-mensagem.service.d.ts +16 -18
  16. package/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-form.d.ts +6 -2
  17. package/lib/unb-pessoa/unb-pessoa-email-form/unb-pessoa-email-list.d.ts +2 -5
  18. package/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-form.d.ts +6 -3
  19. package/lib/unb-pessoa/unb-pessoa-endereco-form/unb-pessoa-endereco-list.d.ts +2 -5
  20. package/lib/unb-pessoa/unb-pessoa-form/unb-pessoa-form.component.d.ts +8 -8
  21. package/lib/unb-pessoa/unb-pessoa-pesquisar/unb-pessoa-pesquisar.component.d.ts +8 -8
  22. package/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-form.d.ts +6 -4
  23. package/lib/unb-pessoa/unb-pessoa-telefone-form/unb-pessoa-telefone-list.d.ts +2 -5
  24. package/lib/unb-pessoa/unb-pessoa.service.d.ts +9 -13
  25. package/package.json +1 -1
@@ -8,47 +8,39 @@ export class UnbMensagemComponent {
8
8
  this.mensagemService = mensagemService;
9
9
  }
10
10
  ngOnInit() {
11
- this.subscription = this.mensagemService.getMessageSubject().subscribe(message => {
12
- if (message) {
13
- this.alertMessage = message;
11
+ this.subscription = this.mensagemService.getMessageSubject().subscribe(event => {
12
+ // LÓGICA DE FILTRAGEM:
13
+ // 1. Se a mensagem tem um targetId, mas este componente não tem ID ou o ID não bate: IGNORA
14
+ if (event.targetId && event.targetId !== this.identificador) {
15
+ return;
14
16
  }
15
- else {
16
- //this.alertMessage = undefined;
17
+ // 2. Se a mensagem tem targetId e bate com o meu ID: ACEITA
18
+ // 3. Se a mensagem NÃO tem targetId (global): ACEITA (comportamento padrão/antigo)
19
+ if (event.model) {
20
+ this.alertMessage = event.model;
17
21
  }
18
22
  });
19
23
  }
20
24
  ngAfterContentInit() {
21
25
  if (this.mensagem != null && this.mensagem != undefined) {
26
+ // Aqui passamos o this.id para garantir que a mensagem inicial fique neste componente
22
27
  this.showMessage(this.mensagem, this.getTipo());
23
28
  }
24
29
  }
25
- /**
26
- * Esconde o componente de mensagem
27
- */
28
30
  hide() {
29
- this.mensagemService.hideMessage();
31
+ // Ao fechar pelo X, passamos o próprio ID para não fechar outros componentes sem querer
32
+ this.mensagemService.hideMessage(this.identificador);
30
33
  }
31
- /**
32
- *
33
- * @param message mensagem que vai aparecer na tela
34
- * @param tipo tipo da mensagem: success, info, warning, danger.
35
- */
36
34
  showMessage(message, tipo) {
37
- this.mensagemService.showMessage(message, tipo);
35
+ this.mensagemService.showMessage(message, tipo, this.identificador);
38
36
  }
39
37
  ngOnDestroy() {
40
- // unsubscribe to ensure no memory leaks
41
38
  if (this.subscription) {
42
39
  this.subscription.unsubscribe();
43
40
  }
44
41
  }
45
- /**
46
- * Recupera qual o tipo da mensagem.
47
- * O método tenta achar o tipo conforme o valor informado, incluido erros de digitação
48
- *
49
- * @returns o valor correspondente do informa. Caso não encontra, emite um erro e coloca retorna o padrão info como default
50
- */
51
42
  getTipo() {
43
+ // ... (mesma implementação anterior) ...
52
44
  if (this.tipo != null && this.tipo != undefined) {
53
45
  let valor = this.tipo.toLowerCase();
54
46
  if (valor == 'warning' || valor == 'warn' || valor == 'aviso') {
@@ -64,12 +56,10 @@ export class UnbMensagemComponent {
64
56
  return UnbTipoMensagemEnum.INFO;
65
57
  }
66
58
  }
67
- // o padrao eh o info
68
- console.log("Erro: Input [tipo] do componente unb-mensagem tem um valor inválido. Utilize: " + UnbTipoMensagemEnum.SUCCESS + " | " + UnbTipoMensagemEnum.INFO + " | " + UnbTipoMensagemEnum.WARNING + " | " + UnbTipoMensagemEnum.DANGER);
69
59
  return UnbTipoMensagemEnum.INFO;
70
60
  }
71
61
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbMensagemComponent, deps: [{ token: i1.UnbMensagemService }], target: i0.ɵɵFactoryTarget.Component }); }
72
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbMensagemComponent, selector: "unb-mensagem", inputs: { mensagem: "mensagem", tipo: "tipo" }, ngImport: i0, template: "\r\n<div class=\"alert\" *ngIf=\"alertMessage && alertMessage.message && alertMessage.message.length > 1\" [ngStyle]=\"{background: alertMessage.background_color, 'border-color': alertMessage.border_color}\"> \r\n <div class=\"mensagem\" [ngStyle]=\"{color: alertMessage.font_color}\" [innerHtml]= \"alertMessage.message\"></div>\r\n <a class=\"close\" (click)=\"hide()\" aria-label=\"fechar\" [ngStyle]=\"{color: alertMessage.font_color}\">x</a>\r\n</div> \r\n\r\n", styles: [".alert{display:flex;text-align:center;justify-content:space-between;border-top-color:darken(1px,5%);padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.42857143;font-weight:400;border-color:#fff}.mensagem{margin:0 auto}.close{float:right;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;cursor:pointer;justify-content:flex-end}.close:hover{opacity:.7}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
62
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.2", type: UnbMensagemComponent, selector: "unb-mensagem", inputs: { mensagem: "mensagem", tipo: "tipo", identificador: "identificador" }, ngImport: i0, template: "\r\n<div class=\"alert\" *ngIf=\"alertMessage && alertMessage.message && alertMessage.message.length > 1\" [ngStyle]=\"{background: alertMessage.background_color, 'border-color': alertMessage.border_color}\"> \r\n <div class=\"mensagem\" [ngStyle]=\"{color: alertMessage.font_color}\" [innerHtml]= \"alertMessage.message\"></div>\r\n <a class=\"close\" (click)=\"hide()\" aria-label=\"fechar\" [ngStyle]=\"{color: alertMessage.font_color}\">x</a>\r\n</div> \r\n\r\n", styles: [".alert{display:flex;text-align:center;justify-content:space-between;border-top-color:darken(1px,5%);padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.42857143;font-weight:400;border-color:#fff}.mensagem{margin:0 auto}.close{float:right;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;cursor:pointer;justify-content:flex-end}.close:hover{opacity:.7}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
73
63
  }
74
64
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbMensagemComponent, decorators: [{
75
65
  type: Component,
@@ -78,5 +68,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
78
68
  type: Input
79
69
  }], tipo: [{
80
70
  type: Input
71
+ }], identificador: [{
72
+ type: Input
81
73
  }] } });
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iLW1lbnNhZ2VtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VuYi1saWItY29tcG9uZW50cy9zcmMvbGliL3VuYi1tZW5zYWdlbS91bmItbWVuc2FnZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdW5iLWxpYi1jb21wb25lbnRzL3NyYy9saWIvdW5iLW1lbnNhZ2VtL3VuYi1tZW5zYWdlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFFaEYsT0FBTyxFQUFHLG1CQUFtQixFQUFzQixNQUFNLHdCQUF3QixDQUFDOzs7O0FBVWxGLE1BQU0sT0FBTyxvQkFBb0I7SUFRL0IsWUFBb0IsZUFBbUM7UUFBbkMsb0JBQWUsR0FBZixlQUFlLENBQW9CO0lBRXZELENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLGlCQUFpQixFQUFFLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQy9FLElBQUcsT0FBTyxFQUFDLENBQUM7Z0JBQ1YsSUFBSSxDQUFDLFlBQVksR0FBSSxPQUFPLENBQUM7WUFDL0IsQ0FBQztpQkFBSSxDQUFDO2dCQUNKLGlDQUFpQztZQUNuQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxTQUFTLEVBQUMsQ0FBQztZQUN2RCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDbEQsQ0FBQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNILElBQUk7UUFDRixJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsV0FBVyxDQUFDLE9BQWUsRUFBRSxJQUFZO1FBQ3ZDLElBQUksQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsV0FBVztRQUNULHdDQUF3QztRQUN4QyxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUMsQ0FBQztZQUNyQixJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ2xDLENBQUM7SUFDSCxDQUFDO0lBRUY7Ozs7O09BS0c7SUFDRixPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLFNBQVMsRUFBQyxDQUFDO1lBQy9DLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDcEMsSUFBSSxLQUFLLElBQUksU0FBUyxJQUFJLEtBQUssSUFBSSxNQUFNLElBQUksS0FBSyxJQUFJLE9BQU8sRUFBQyxDQUFDO2dCQUM3RCxPQUFPLG1CQUFtQixDQUFDLE9BQU8sQ0FBRTtZQUN0QyxDQUFDO2lCQUFLLElBQUssS0FBSyxJQUFJLFNBQVMsSUFBSSxLQUFLLElBQUksU0FBUyxJQUFJLEtBQUssSUFBSSxRQUFRLEVBQUMsQ0FBQztnQkFDeEUsT0FBTyxtQkFBbUIsQ0FBQyxPQUFPLENBQUM7WUFDckMsQ0FBQztpQkFBSyxJQUFLLEtBQUssSUFBSSxRQUFRLElBQUksS0FBSyxJQUFJLE1BQU0sSUFBSSxLQUFLLElBQUksT0FBTyxFQUFDLENBQUM7Z0JBQ25FLE9BQU8sbUJBQW1CLENBQUMsTUFBTSxDQUFDO1lBQ3BDLENBQUM7aUJBQUssSUFBSSxLQUFLLElBQUksTUFBTSxFQUFDLENBQUM7Z0JBQ3pCLE9BQU8sbUJBQW1CLENBQUMsSUFBSSxDQUFDO1lBQ2xDLENBQUM7UUFDSCxDQUFDO1FBQ0QscUJBQXFCO1FBQ3JCLE9BQU8sQ0FBQyxHQUFHLENBQUMsZ0ZBQWdGLEdBQUcsbUJBQW1CLENBQUMsT0FBTyxHQUFHLEtBQUssR0FBRyxtQkFBbUIsQ0FBQyxJQUFJLEdBQUcsS0FBSyxHQUFHLG1CQUFtQixDQUFDLE9BQU8sR0FBRyxLQUFLLEdBQUcsbUJBQW1CLENBQUMsTUFBTSxDQUFFLENBQUE7UUFDMU8sT0FBTyxtQkFBbUIsQ0FBQyxJQUFJLENBQUM7SUFDbEMsQ0FBQzs4R0F6RVUsb0JBQW9CO2tHQUFwQixvQkFBb0Isb0dDWmpDLDhkQU1BOzsyRkRNYSxvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0UsY0FBYzt1RkFNZixRQUFRO3NCQUFoQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgIFVuYlRpcG9NZW5zYWdlbUVudW0sIFVuYk1lbnNhZ2VtU2VydmljZSB9IGZyb20gJy4vdW5iLW1lbnNhZ2VtLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBVbmJNZW5zYWdlbU1vZGVsIH0gZnJvbSAnLi91bmItbWVzc2FnZS5tb2RlbCc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAndW5iLW1lbnNhZ2VtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdW5iLW1lbnNhZ2VtLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi91bmItbWVuc2FnZW0uY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVbmJNZW5zYWdlbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95ICB7XHJcblxyXG4gIEBJbnB1dCgpIG1lbnNhZ2VtITogc3RyaW5nOyAvLyBtZW5zYWdlbSBxdWUgdmFpIGFwYXJlY2VyIG5vIGNvbXBvbmVudGUsIFxyXG4gIEBJbnB1dCgpIHRpcG8hOiBzdHJpbmc7ICAvLyB0aXBvIGRhIG1lbnNhZ2VtOiBzdWNjZXNzLCBpbmZvLCB3YXJuaW5nLCBkYW5nZXIuIFxyXG4gXHJcbiAgYWxlcnRNZXNzYWdlITogVW5iTWVuc2FnZW1Nb2RlbDtcclxuICBwcml2YXRlIHN1YnNjcmlwdGlvbiE6IFN1YnNjcmlwdGlvbiB8IG51bGw7XHJcbiAgXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBtZW5zYWdlbVNlcnZpY2U6IFVuYk1lbnNhZ2VtU2VydmljZSkgeyBcclxuXHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpIHsgIFxyXG4gICAgdGhpcy5zdWJzY3JpcHRpb24gPSB0aGlzLm1lbnNhZ2VtU2VydmljZS5nZXRNZXNzYWdlU3ViamVjdCgpLnN1YnNjcmliZShtZXNzYWdlID0+IHtcclxuICAgICAgaWYobWVzc2FnZSl7XHJcbiAgICAgICAgdGhpcy5hbGVydE1lc3NhZ2UgID0gbWVzc2FnZTtcclxuICAgICAgfWVsc2V7XHJcbiAgICAgICAgLy90aGlzLmFsZXJ0TWVzc2FnZSAgPSB1bmRlZmluZWQ7XHJcbiAgICAgIH0gICAgXHJcbiAgICB9KTsgXHJcbiAgfVxyXG5cclxuICBuZ0FmdGVyQ29udGVudEluaXQoKXtcclxuICAgIGlmICh0aGlzLm1lbnNhZ2VtICE9IG51bGwgJiYgdGhpcy5tZW5zYWdlbSAhPSB1bmRlZmluZWQpe1xyXG4gICAgICB0aGlzLnNob3dNZXNzYWdlKHRoaXMubWVuc2FnZW0sIHRoaXMuZ2V0VGlwbygpKTsgXHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBFc2NvbmRlIG8gY29tcG9uZW50ZSBkZSBtZW5zYWdlbVxyXG4gICAqL1xyXG4gIGhpZGUoKTogdm9pZCB7IFxyXG4gICAgdGhpcy5tZW5zYWdlbVNlcnZpY2UuaGlkZU1lc3NhZ2UoKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFxyXG4gICAqIEBwYXJhbSBtZXNzYWdlIG1lbnNhZ2VtIHF1ZSB2YWkgYXBhcmVjZXIgbmEgdGVsYVxyXG4gICAqIEBwYXJhbSB0aXBvIHRpcG8gZGEgbWVuc2FnZW06IHN1Y2Nlc3MsIGluZm8sIHdhcm5pbmcsIGRhbmdlci4gXHJcbiAgICovXHJcbiAgc2hvd01lc3NhZ2UobWVzc2FnZTogc3RyaW5nLCB0aXBvOiBudW1iZXIpIHtcclxuICAgIHRoaXMubWVuc2FnZW1TZXJ2aWNlLnNob3dNZXNzYWdlKG1lc3NhZ2UsIHRpcG8pO1xyXG4gIH1cclxuICBcclxuICBuZ09uRGVzdHJveSgpIHtcclxuICAgIC8vIHVuc3Vic2NyaWJlIHRvIGVuc3VyZSBubyBtZW1vcnkgbGVha3NcclxuICAgIGlmICh0aGlzLnN1YnNjcmlwdGlvbil7IFxyXG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAvKipcclxuICAqIFJlY3VwZXJhIHF1YWwgbyB0aXBvIGRhIG1lbnNhZ2VtLiBcclxuICAqIE8gbcOpdG9kbyB0ZW50YSBhY2hhciBvIHRpcG8gY29uZm9ybWUgbyB2YWxvciBpbmZvcm1hZG8sIGluY2x1aWRvIGVycm9zIGRlIGRpZ2l0YcOnw6NvXHJcbiAgKiBcclxuICAqIEByZXR1cm5zIG8gdmFsb3IgY29ycmVzcG9uZGVudGUgZG8gaW5mb3JtYS4gQ2FzbyBuw6NvIGVuY29udHJhLCBlbWl0ZSB1bSBlcnJvIGUgY29sb2NhIHJldG9ybmEgbyBwYWRyw6NvIGluZm8gY29tbyBkZWZhdWx0XHJcbiAgKi9cclxuICBnZXRUaXBvKCk6IG51bWJlciB7XHJcbiAgICBpZiAodGhpcy50aXBvICE9IG51bGwgJiYgdGhpcy50aXBvICE9IHVuZGVmaW5lZCl7IFxyXG4gICAgICBsZXQgdmFsb3IgPSB0aGlzLnRpcG8udG9Mb3dlckNhc2UoKTtcclxuICAgICAgaWYgKHZhbG9yID09ICd3YXJuaW5nJyB8fCB2YWxvciA9PSAnd2FybicgfHwgdmFsb3IgPT0gJ2F2aXNvJyl7XHJcbiAgICAgICAgcmV0dXJuIFVuYlRpcG9NZW5zYWdlbUVudW0uV0FSTklORyA7XHJcbiAgICAgIH1lbHNlIGlmICAodmFsb3IgPT0gJ3N1Y2Vzc28nIHx8IHZhbG9yID09ICdzdWNjZXNzJyB8fCB2YWxvciA9PSAnc3VjZXNzJyl7XHJcbiAgICAgICAgcmV0dXJuIFVuYlRpcG9NZW5zYWdlbUVudW0uU1VDQ0VTUztcclxuICAgICAgfWVsc2UgaWYgICh2YWxvciA9PSAnZGFuZ2VyJyB8fCB2YWxvciA9PSAnZXJybycgfHwgdmFsb3IgPT0gJ2Vycm9yJyl7XHJcbiAgICAgICAgcmV0dXJuIFVuYlRpcG9NZW5zYWdlbUVudW0uREFOR0VSO1xyXG4gICAgICB9ZWxzZSBpZiAodmFsb3IgPT0gJ2luZm8nKXtcclxuICAgICAgICByZXR1cm4gVW5iVGlwb01lbnNhZ2VtRW51bS5JTkZPO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICAvLyBvIHBhZHJhbyBlaCBvIGluZm9cclxuICAgIGNvbnNvbGUubG9nKFwiRXJybzogSW5wdXQgW3RpcG9dIGRvIGNvbXBvbmVudGUgdW5iLW1lbnNhZ2VtIHRlbSB1bSB2YWxvciBpbnbDoWxpZG8uIFV0aWxpemU6IFwiICsgVW5iVGlwb01lbnNhZ2VtRW51bS5TVUNDRVNTICsgXCIgfCBcIiArIFVuYlRpcG9NZW5zYWdlbUVudW0uSU5GTyArIFwiIHwgXCIgKyBVbmJUaXBvTWVuc2FnZW1FbnVtLldBUk5JTkcgKyBcIiB8IFwiICsgVW5iVGlwb01lbnNhZ2VtRW51bS5EQU5HRVIgKVxyXG4gICAgcmV0dXJuIFVuYlRpcG9NZW5zYWdlbUVudW0uSU5GTztcclxuICB9XHJcbn1cclxuIiwiXHJcbjxkaXYgY2xhc3M9XCJhbGVydFwiICpuZ0lmPVwiYWxlcnRNZXNzYWdlICYmIGFsZXJ0TWVzc2FnZS5tZXNzYWdlICYmIGFsZXJ0TWVzc2FnZS5tZXNzYWdlLmxlbmd0aCA+IDFcIiBbbmdTdHlsZV09XCJ7YmFja2dyb3VuZDogYWxlcnRNZXNzYWdlLmJhY2tncm91bmRfY29sb3IsICdib3JkZXItY29sb3InOiBhbGVydE1lc3NhZ2UuYm9yZGVyX2NvbG9yfVwiPiAgICAgXHJcbiAgICA8ZGl2IGNsYXNzPVwibWVuc2FnZW1cIiBbbmdTdHlsZV09XCJ7Y29sb3I6IGFsZXJ0TWVzc2FnZS5mb250X2NvbG9yfVwiIFtpbm5lckh0bWxdPSBcImFsZXJ0TWVzc2FnZS5tZXNzYWdlXCI+PC9kaXY+XHJcbiAgICA8YSAgY2xhc3M9XCJjbG9zZVwiIChjbGljayk9XCJoaWRlKClcIiBhcmlhLWxhYmVsPVwiZmVjaGFyXCIgW25nU3R5bGVdPVwie2NvbG9yOiBhbGVydE1lc3NhZ2UuZm9udF9jb2xvcn1cIj54PC9hPlxyXG48L2Rpdj4gXHJcblxyXG4iXX0=
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iLW1lbnNhZ2VtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VuYi1saWItY29tcG9uZW50cy9zcmMvbGliL3VuYi1tZW5zYWdlbS91bmItbWVuc2FnZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdW5iLWxpYi1jb21wb25lbnRzL3NyYy9saWIvdW5iLW1lbnNhZ2VtL3VuYi1tZW5zYWdlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDcEUsT0FBTyxFQUFFLG1CQUFtQixFQUFzQixNQUFNLHdCQUF3QixDQUFDOzs7O0FBU2pGLE1BQU0sT0FBTyxvQkFBb0I7SUFXL0IsWUFBb0IsZUFBbUM7UUFBbkMsb0JBQWUsR0FBZixlQUFlLENBQW9CO0lBQUcsQ0FBQztJQUUzRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLGlCQUFpQixFQUFFLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBRTdFLHVCQUF1QjtZQUV2Qiw0RkFBNEY7WUFDNUYsSUFBSSxLQUFLLENBQUMsUUFBUSxJQUFJLEtBQUssQ0FBQyxRQUFRLEtBQUssSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUM1RCxPQUFPO1lBQ1QsQ0FBQztZQUVELDREQUE0RDtZQUM1RCxtRkFBbUY7WUFFbkYsSUFBSSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7Z0JBQ2hCLElBQUksQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQztZQUNsQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLFFBQVEsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUN4RCxzRkFBc0Y7WUFDdEYsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ2xELENBQUM7SUFDSCxDQUFDO0lBRUQsSUFBSTtRQUNGLHdGQUF3RjtRQUN4RixJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFlLEVBQUUsSUFBWTtRQUN2QyxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUN0RSxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDbEMsQ0FBQztJQUNILENBQUM7SUFFRCxPQUFPO1FBQ0wseUNBQXlDO1FBQ3pDLElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxTQUFTLEVBQUMsQ0FBQztZQUMvQyxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3BDLElBQUksS0FBSyxJQUFJLFNBQVMsSUFBSSxLQUFLLElBQUksTUFBTSxJQUFJLEtBQUssSUFBSSxPQUFPLEVBQUMsQ0FBQztnQkFDN0QsT0FBTyxtQkFBbUIsQ0FBQyxPQUFPLENBQUU7WUFDdEMsQ0FBQztpQkFBTSxJQUFJLEtBQUssSUFBSSxTQUFTLElBQUksS0FBSyxJQUFJLFNBQVMsSUFBSSxLQUFLLElBQUksUUFBUSxFQUFDLENBQUM7Z0JBQ3hFLE9BQU8sbUJBQW1CLENBQUMsT0FBTyxDQUFDO1lBQ3JDLENBQUM7aUJBQU0sSUFBSSxLQUFLLElBQUksUUFBUSxJQUFJLEtBQUssSUFBSSxNQUFNLElBQUksS0FBSyxJQUFJLE9BQU8sRUFBQyxDQUFDO2dCQUNuRSxPQUFPLG1CQUFtQixDQUFDLE1BQU0sQ0FBQztZQUNwQyxDQUFDO2lCQUFNLElBQUksS0FBSyxJQUFJLE1BQU0sRUFBQyxDQUFDO2dCQUMxQixPQUFPLG1CQUFtQixDQUFDLElBQUksQ0FBQztZQUNsQyxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sbUJBQW1CLENBQUMsSUFBSSxDQUFDO0lBQ2xDLENBQUM7OEdBckVVLG9CQUFvQjtrR0FBcEIsb0JBQW9CLG9JQ1ZqQyw4ZEFNQTs7MkZESWEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNFLGNBQWM7dUZBTWYsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBR0csYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFVuYlRpcG9NZW5zYWdlbUVudW0sIFVuYk1lbnNhZ2VtU2VydmljZSB9IGZyb20gJy4vdW5iLW1lbnNhZ2VtLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBVbmJNZW5zYWdlbU1vZGVsIH0gZnJvbSAnLi91bmItbWVzc2FnZS5tb2RlbCc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd1bmItbWVuc2FnZW0nLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi91bmItbWVuc2FnZW0uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3VuYi1tZW5zYWdlbS5jb21wb25lbnQuY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFVuYk1lbnNhZ2VtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG5cclxuICBASW5wdXQoKSBtZW5zYWdlbSE6IHN0cmluZzsgXHJcbiAgQElucHV0KCkgdGlwbyE6IHN0cmluZztcclxuICBcclxuICAvLyBJbnB1dCBvcGNpb25hbCBwYXJhIGlkZW50aWZpY2FyIGVzdGUgY29tcG9uZW50ZSBlc3BlY8OtZmljb1xyXG4gIEBJbnB1dCgpIGlkZW50aWZpY2Fkb3I/OiBzdHJpbmc7XHJcbiBcclxuICBhbGVydE1lc3NhZ2UhOiBVbmJNZW5zYWdlbU1vZGVsO1xyXG4gIHByaXZhdGUgc3Vic2NyaXB0aW9uITogU3Vic2NyaXB0aW9uIHwgbnVsbDtcclxuICBcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIG1lbnNhZ2VtU2VydmljZTogVW5iTWVuc2FnZW1TZXJ2aWNlKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpIHsgIFxyXG4gICAgdGhpcy5zdWJzY3JpcHRpb24gPSB0aGlzLm1lbnNhZ2VtU2VydmljZS5nZXRNZXNzYWdlU3ViamVjdCgpLnN1YnNjcmliZShldmVudCA9PiB7XHJcbiAgICAgIFxyXG4gICAgICAvLyBMw5NHSUNBIERFIEZJTFRSQUdFTTpcclxuICAgICAgXHJcbiAgICAgIC8vIDEuIFNlIGEgbWVuc2FnZW0gdGVtIHVtIHRhcmdldElkLCBtYXMgZXN0ZSBjb21wb25lbnRlIG7Do28gdGVtIElEIG91IG8gSUQgbsOjbyBiYXRlOiBJR05PUkFcclxuICAgICAgaWYgKGV2ZW50LnRhcmdldElkICYmIGV2ZW50LnRhcmdldElkICE9PSB0aGlzLmlkZW50aWZpY2Fkb3IpIHtcclxuICAgICAgICByZXR1cm47IFxyXG4gICAgICB9XHJcblxyXG4gICAgICAvLyAyLiBTZSBhIG1lbnNhZ2VtIHRlbSB0YXJnZXRJZCBlIGJhdGUgY29tIG8gbWV1IElEOiBBQ0VJVEFcclxuICAgICAgLy8gMy4gU2UgYSBtZW5zYWdlbSBOw4NPIHRlbSB0YXJnZXRJZCAoZ2xvYmFsKTogQUNFSVRBIChjb21wb3J0YW1lbnRvIHBhZHLDo28vYW50aWdvKVxyXG4gICAgICBcclxuICAgICAgaWYgKGV2ZW50Lm1vZGVsKSB7XHJcbiAgICAgICAgdGhpcy5hbGVydE1lc3NhZ2UgPSBldmVudC5tb2RlbDtcclxuICAgICAgfVxyXG4gICAgfSk7IFxyXG4gIH1cclxuXHJcbiAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xyXG4gICAgaWYgKHRoaXMubWVuc2FnZW0gIT0gbnVsbCAmJiB0aGlzLm1lbnNhZ2VtICE9IHVuZGVmaW5lZCkge1xyXG4gICAgICAvLyBBcXVpIHBhc3NhbW9zIG8gdGhpcy5pZCBwYXJhIGdhcmFudGlyIHF1ZSBhIG1lbnNhZ2VtIGluaWNpYWwgZmlxdWUgbmVzdGUgY29tcG9uZW50ZVxyXG4gICAgICB0aGlzLnNob3dNZXNzYWdlKHRoaXMubWVuc2FnZW0sIHRoaXMuZ2V0VGlwbygpKTsgXHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBoaWRlKCk6IHZvaWQgeyBcclxuICAgIC8vIEFvIGZlY2hhciBwZWxvIFgsIHBhc3NhbW9zIG8gcHLDs3ByaW8gSUQgcGFyYSBuw6NvIGZlY2hhciBvdXRyb3MgY29tcG9uZW50ZXMgc2VtIHF1ZXJlclxyXG4gICAgdGhpcy5tZW5zYWdlbVNlcnZpY2UuaGlkZU1lc3NhZ2UodGhpcy5pZGVudGlmaWNhZG9yKTtcclxuICB9XHJcblxyXG4gIHNob3dNZXNzYWdlKG1lc3NhZ2U6IHN0cmluZywgdGlwbzogbnVtYmVyKSB7XHJcbiAgICB0aGlzLm1lbnNhZ2VtU2VydmljZS5zaG93TWVzc2FnZShtZXNzYWdlLCB0aXBvLCB0aGlzLmlkZW50aWZpY2Fkb3IpO1xyXG4gIH1cclxuICBcclxuICBuZ09uRGVzdHJveSgpIHtcclxuICAgIGlmICh0aGlzLnN1YnNjcmlwdGlvbikgeyBcclxuICAgICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGdldFRpcG8oKTogbnVtYmVyIHtcclxuICAgIC8vIC4uLiAobWVzbWEgaW1wbGVtZW50YcOnw6NvIGFudGVyaW9yKSAuLi5cclxuICAgIGlmICh0aGlzLnRpcG8gIT0gbnVsbCAmJiB0aGlzLnRpcG8gIT0gdW5kZWZpbmVkKXsgXHJcbiAgICAgIGxldCB2YWxvciA9IHRoaXMudGlwby50b0xvd2VyQ2FzZSgpO1xyXG4gICAgICBpZiAodmFsb3IgPT0gJ3dhcm5pbmcnIHx8IHZhbG9yID09ICd3YXJuJyB8fCB2YWxvciA9PSAnYXZpc28nKXtcclxuICAgICAgICByZXR1cm4gVW5iVGlwb01lbnNhZ2VtRW51bS5XQVJOSU5HIDtcclxuICAgICAgfSBlbHNlIGlmICh2YWxvciA9PSAnc3VjZXNzbycgfHwgdmFsb3IgPT0gJ3N1Y2Nlc3MnIHx8IHZhbG9yID09ICdzdWNlc3MnKXtcclxuICAgICAgICByZXR1cm4gVW5iVGlwb01lbnNhZ2VtRW51bS5TVUNDRVNTO1xyXG4gICAgICB9IGVsc2UgaWYgKHZhbG9yID09ICdkYW5nZXInIHx8IHZhbG9yID09ICdlcnJvJyB8fCB2YWxvciA9PSAnZXJyb3InKXtcclxuICAgICAgICByZXR1cm4gVW5iVGlwb01lbnNhZ2VtRW51bS5EQU5HRVI7XHJcbiAgICAgIH0gZWxzZSBpZiAodmFsb3IgPT0gJ2luZm8nKXtcclxuICAgICAgICByZXR1cm4gVW5iVGlwb01lbnNhZ2VtRW51bS5JTkZPO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gVW5iVGlwb01lbnNhZ2VtRW51bS5JTkZPO1xyXG4gIH1cclxufSIsIlxyXG48ZGl2IGNsYXNzPVwiYWxlcnRcIiAqbmdJZj1cImFsZXJ0TWVzc2FnZSAmJiBhbGVydE1lc3NhZ2UubWVzc2FnZSAmJiBhbGVydE1lc3NhZ2UubWVzc2FnZS5sZW5ndGggPiAxXCIgW25nU3R5bGVdPVwie2JhY2tncm91bmQ6IGFsZXJ0TWVzc2FnZS5iYWNrZ3JvdW5kX2NvbG9yLCAnYm9yZGVyLWNvbG9yJzogYWxlcnRNZXNzYWdlLmJvcmRlcl9jb2xvcn1cIj4gICAgIFxyXG4gICAgPGRpdiBjbGFzcz1cIm1lbnNhZ2VtXCIgW25nU3R5bGVdPVwie2NvbG9yOiBhbGVydE1lc3NhZ2UuZm9udF9jb2xvcn1cIiBbaW5uZXJIdG1sXT0gXCJhbGVydE1lc3NhZ2UubWVzc2FnZVwiPjwvZGl2PlxyXG4gICAgPGEgIGNsYXNzPVwiY2xvc2VcIiAoY2xpY2spPVwiaGlkZSgpXCIgYXJpYS1sYWJlbD1cImZlY2hhclwiIFtuZ1N0eWxlXT1cIntjb2xvcjogYWxlcnRNZXNzYWdlLmZvbnRfY29sb3J9XCI+eDwvYT5cclxuPC9kaXY+IFxyXG5cclxuIl19
@@ -2,7 +2,6 @@ import { Injectable } from '@angular/core';
2
2
  import { Subject } from 'rxjs';
3
3
  import { UnbMensagemModel } from './unb-message.model';
4
4
  import * as i0 from "@angular/core";
5
- // faz com que a enum seja uma contagem de 0 a 3
6
5
  export var UnbTipoMensagemEnum;
7
6
  (function (UnbTipoMensagemEnum) {
8
7
  UnbTipoMensagemEnum[UnbTipoMensagemEnum["SUCCESS"] = 0] = "SUCCESS";
@@ -12,8 +11,8 @@ export var UnbTipoMensagemEnum;
12
11
  })(UnbTipoMensagemEnum || (UnbTipoMensagemEnum = {}));
13
12
  export class UnbMensagemService {
14
13
  constructor() {
14
+ // Mudamos o tipo do Subject para aceitar o evento com ID
15
15
  this.messageSubject = new Subject();
16
- // [background_color, font_color, border_color]
17
16
  this.cores = [
18
17
  ['#dff0d8', '#3c763d', '#d6e9c6'], // SUCCESS
19
18
  ['#d9edf7', '#31708f', '#bce8f1'], // INFO
@@ -22,30 +21,26 @@ export class UnbMensagemService {
22
21
  ];
23
22
  }
24
23
  /**
25
- *
26
- * @param message mensagem que vai aparecer na tela
27
- * @param tipo tipo da mensagem: success, info, warning, danger.
28
- */
29
- showMessage(message, type) {
30
- this.messageSubject.next(this.createAlertMessage(message, ...this.cores[type]));
24
+ * @param message mensagem que vai aparecer na tela
25
+ * @param tipo tipo da mensagem: success, info, warning, danger.
26
+ * @param id (Opcional) Identificador do componente que deve exibir a mensagem
27
+ */
28
+ showMessage(message, type, id) {
29
+ const model = this.createAlertMessage(message, ...this.cores[type]);
30
+ // Envia o modelo E o id alvo (se houver)
31
+ this.messageSubject.next({ model: model, targetId: id });
31
32
  }
32
33
  /**
33
- * Esconde o componente de mensagem passando um valor vazio
34
- */
35
- hideMessage() {
36
- this.messageSubject.next(new UnbMensagemModel());
34
+ * Esconde o componente.
35
+ * @param id (Opcional) Se informado, esconde apenas o componente com este ID.
36
+ */
37
+ hideMessage(id) {
38
+ // Envia modelo vazio para esconder
39
+ this.messageSubject.next({ model: new UnbMensagemModel(), targetId: id });
37
40
  }
38
41
  getMessageSubject() {
39
42
  return this.messageSubject.asObservable();
40
43
  }
41
- /**
42
- *
43
- * @param message Cria a mensagem passando os parametros com base nas cores criadas no construturo
44
- * @param background_color cor de fundo
45
- * @param font_color cor da fonte
46
- * @param border_color cor da borda
47
- * @returns
48
- */
49
44
  createAlertMessage(message, background_color, font_color, border_color) {
50
45
  return { message, background_color, font_color, border_color };
51
46
  }
@@ -58,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
58
53
  providedIn: 'root'
59
54
  }]
60
55
  }], ctorParameters: () => [] });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iLW1lbnNhZ2VtLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91bmItbGliLWNvbXBvbmVudHMvc3JjL2xpYi91bmItbWVuc2FnZW0vdW5iLW1lbnNhZ2VtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQWMsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQUV2RCxnREFBZ0Q7QUFDaEQsTUFBTSxDQUFOLElBQVksbUJBS1g7QUFMRCxXQUFZLG1CQUFtQjtJQUM3QixtRUFBVyxDQUFBO0lBQ1gsNkRBQUksQ0FBQTtJQUNKLG1FQUFPLENBQUE7SUFDUCxpRUFBTSxDQUFBO0FBQ1IsQ0FBQyxFQUxXLG1CQUFtQixLQUFuQixtQkFBbUIsUUFLOUI7QUFLRCxNQUFNLE9BQU8sa0JBQWtCO0lBSzdCO1FBSE8sbUJBQWMsR0FBRyxJQUFJLE9BQU8sRUFBb0IsQ0FBQztRQUl0RCwrQ0FBK0M7UUFDL0MsSUFBSSxDQUFDLEtBQUssR0FBRztZQUNYLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsRUFBRSxVQUFVO1lBQzdDLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsRUFBRSxPQUFPO1lBQzFDLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsRUFBRSxVQUFVO1lBQzdDLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQyxTQUFTO1NBQzVDLENBQUE7SUFDSCxDQUFDO0lBRUM7Ozs7S0FJQztJQUNJLFdBQVcsQ0FBQyxPQUFlLEVBQUUsSUFBWTtRQUM5QyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbEYsQ0FBQztJQUVBOztNQUVFO0lBQ0ksV0FBVztRQUNoQixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLGdCQUFnQixFQUFFLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBRU0saUJBQWlCO1FBQ3RCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRUQ7Ozs7Ozs7T0FPRztJQUNLLGtCQUFrQixDQUFFLE9BQWUsRUFBRSxnQkFBd0IsRUFBRSxVQUFrQixFQUFFLFlBQW9CO1FBQzdHLE9BQU8sRUFBQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBQyxDQUFDO0lBQy9ELENBQUM7OEdBN0NVLGtCQUFrQjtrSEFBbEIsa0JBQWtCLGNBRmpCLE1BQU07OzJGQUVQLGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IFVuYk1lbnNhZ2VtTW9kZWwgfSBmcm9tICcuL3VuYi1tZXNzYWdlLm1vZGVsJztcclxuXHJcbi8vIGZheiBjb20gcXVlIGEgZW51bSBzZWphIHVtYSBjb250YWdlbSBkZSAwIGEgM1xyXG5leHBvcnQgZW51bSBVbmJUaXBvTWVuc2FnZW1FbnVtIHtcclxuICBTVUNDRVNTID0gMCxcclxuICBJTkZPLFxyXG4gIFdBUk5JTkcsXHJcbiAgREFOR0VSLFxyXG59XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVbmJNZW5zYWdlbVNlcnZpY2Uge1xyXG5cclxuICBwdWJsaWMgbWVzc2FnZVN1YmplY3QgPSBuZXcgU3ViamVjdDxVbmJNZW5zYWdlbU1vZGVsPigpOyBcclxuICBwdWJsaWMgY29yZXM6IFtbc3RyaW5nLCBzdHJpbmcsIHN0cmluZ10sIFtzdHJpbmcsIHN0cmluZywgc3RyaW5nXSwgW3N0cmluZywgc3RyaW5nLCBzdHJpbmddLCBbc3RyaW5nLCBzdHJpbmcsIHN0cmluZ11dXHJcblxyXG4gIGNvbnN0cnVjdG9yKCl7XHJcbiAgICAvLyBbYmFja2dyb3VuZF9jb2xvciwgZm9udF9jb2xvciwgYm9yZGVyX2NvbG9yXVxyXG4gICAgdGhpcy5jb3JlcyA9IFtcclxuICAgICAgWycjZGZmMGQ4JywgJyMzYzc2M2QnLCAnI2Q2ZTljNiddLCAvLyBTVUNDRVNTXHJcbiAgICAgIFsnI2Q5ZWRmNycsICcjMzE3MDhmJywgJyNiY2U4ZjEnXSwgLy8gSU5GT1xyXG4gICAgICBbJyNmY2Y4ZTMnLCAnIzhhNmQzYicsICcjZmFlYmNjJ10sIC8vIFdBUk5JTkdcclxuICAgICAgWycjZjJkZWRlJywgJyNhOTQ0NDInLCAnI2ViY2NkMSddIC8vIERBTkdFUlxyXG4gICAgXVxyXG4gIH1cclxuXHJcbiAgICAvKipcclxuICAgKiBcclxuICAgKiBAcGFyYW0gbWVzc2FnZSBtZW5zYWdlbSBxdWUgdmFpIGFwYXJlY2VyIG5hIHRlbGFcclxuICAgKiBAcGFyYW0gdGlwbyB0aXBvIGRhIG1lbnNhZ2VtOiBzdWNjZXNzLCBpbmZvLCB3YXJuaW5nLCBkYW5nZXIuIFxyXG4gICAqL1xyXG4gIHB1YmxpYyBzaG93TWVzc2FnZShtZXNzYWdlOiBzdHJpbmcsIHR5cGU6IG51bWJlcil7XHJcbiAgICB0aGlzLm1lc3NhZ2VTdWJqZWN0Lm5leHQodGhpcy5jcmVhdGVBbGVydE1lc3NhZ2UobWVzc2FnZSwgLi4udGhpcy5jb3Jlc1t0eXBlXSkpOyAgICBcclxuICB9XHJcblxyXG4gICAvKipcclxuICAgKiBFc2NvbmRlIG8gY29tcG9uZW50ZSBkZSBtZW5zYWdlbSBwYXNzYW5kbyB1bSB2YWxvciB2YXppb1xyXG4gICAqL1xyXG4gIHB1YmxpYyBoaWRlTWVzc2FnZSgpe1xyXG4gICAgdGhpcy5tZXNzYWdlU3ViamVjdC5uZXh0KG5ldyBVbmJNZW5zYWdlbU1vZGVsKCkpOyBcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXRNZXNzYWdlU3ViamVjdCgpOiAgT2JzZXJ2YWJsZTxhbnk+IHtcclxuICAgIHJldHVybiB0aGlzLm1lc3NhZ2VTdWJqZWN0LmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH0gXHJcblxyXG4gIC8qKlxyXG4gICAqIFxyXG4gICAqIEBwYXJhbSBtZXNzYWdlIENyaWEgYSBtZW5zYWdlbSBwYXNzYW5kbyBvcyBwYXJhbWV0cm9zIGNvbSBiYXNlIG5hcyBjb3JlcyBjcmlhZGFzIG5vIGNvbnN0cnV0dXJvXHJcbiAgICogQHBhcmFtIGJhY2tncm91bmRfY29sb3IgY29yIGRlIGZ1bmRvXHJcbiAgICogQHBhcmFtIGZvbnRfY29sb3IgIGNvciBkYSBmb250ZVxyXG4gICAqIEBwYXJhbSBib3JkZXJfY29sb3IgIGNvciBkYSBib3JkYVxyXG4gICAqIEByZXR1cm5zIFxyXG4gICAqL1xyXG4gIHByaXZhdGUgY3JlYXRlQWxlcnRNZXNzYWdlKCBtZXNzYWdlOiBzdHJpbmcsIGJhY2tncm91bmRfY29sb3I6IHN0cmluZywgZm9udF9jb2xvcjogc3RyaW5nLCBib3JkZXJfY29sb3I6IHN0cmluZyk6IFVuYk1lbnNhZ2VtTW9kZWwge1xyXG4gICAgcmV0dXJuIHttZXNzYWdlLCBiYWNrZ3JvdW5kX2NvbG9yLCBmb250X2NvbG9yLCBib3JkZXJfY29sb3J9OyBcclxuICB9XHJcblxyXG5cclxufSJdfQ==
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5iLW1lbnNhZ2VtLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91bmItbGliLWNvbXBvbmVudHMvc3JjL2xpYi91bmItbWVuc2FnZW0vdW5iLW1lbnNhZ2VtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQWMsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQUV2RCxNQUFNLENBQU4sSUFBWSxtQkFLWDtBQUxELFdBQVksbUJBQW1CO0lBQzdCLG1FQUFXLENBQUE7SUFDWCw2REFBSSxDQUFBO0lBQ0osbUVBQU8sQ0FBQTtJQUNQLGlFQUFNLENBQUE7QUFDUixDQUFDLEVBTFcsbUJBQW1CLEtBQW5CLG1CQUFtQixRQUs5QjtBQVdELE1BQU0sT0FBTyxrQkFBa0I7SUFXN0I7UUFUQSx5REFBeUQ7UUFDbEQsbUJBQWMsR0FBRyxJQUFJLE9BQU8sRUFBb0IsQ0FBQztRQUNqRCxVQUFLLEdBQStCO1lBQ3ZDLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsRUFBRSxVQUFVO1lBQzdDLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsRUFBRSxPQUFPO1lBQzFDLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsRUFBRSxVQUFVO1lBQzdDLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBRSxTQUFTO1NBQy9DLENBQUM7SUFFYSxDQUFDO0lBRWhCOzs7O09BSUc7SUFDSSxXQUFXLENBQUMsT0FBZSxFQUFFLElBQVksRUFBRSxFQUFXO1FBQzNELE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDcEUseUNBQXlDO1FBQ3pDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksV0FBVyxDQUFDLEVBQVc7UUFDNUIsbUNBQW1DO1FBQ25DLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksZ0JBQWdCLEVBQUUsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM1RSxDQUFDO0lBRU0saUJBQWlCO1FBQ3RCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRU8sa0JBQWtCLENBQUMsT0FBZSxFQUFFLGdCQUF3QixFQUFFLFVBQWtCLEVBQUUsWUFBb0I7UUFDNUcsT0FBTyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLENBQUM7SUFDakUsQ0FBQzs4R0F2Q1Usa0JBQWtCO2tIQUFsQixrQkFBa0IsY0FGakIsTUFBTTs7MkZBRVAsa0JBQWtCO2tCQUg5QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBVbmJNZW5zYWdlbU1vZGVsIH0gZnJvbSAnLi91bmItbWVzc2FnZS5tb2RlbCc7XHJcblxyXG5leHBvcnQgZW51bSBVbmJUaXBvTWVuc2FnZW1FbnVtIHtcclxuICBTVUNDRVNTID0gMCxcclxuICBJTkZPLFxyXG4gIFdBUk5JTkcsXHJcbiAgREFOR0VSLFxyXG59XHJcblxyXG4vLyBJbnRlcmZhY2UgYXV4aWxpYXIgcGFyYSBvIGV2ZW50b1xyXG5pbnRlcmZhY2UgVW5iTWVuc2FnZW1FdmVudCB7XHJcbiAgbW9kZWw6IFVuYk1lbnNhZ2VtTW9kZWw7XHJcbiAgdGFyZ2V0SWQ/OiBzdHJpbmc7XHJcbn1cclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFVuYk1lbnNhZ2VtU2VydmljZSB7XHJcblxyXG4gIC8vIE11ZGFtb3MgbyB0aXBvIGRvIFN1YmplY3QgcGFyYSBhY2VpdGFyIG8gZXZlbnRvIGNvbSBJRFxyXG4gIHB1YmxpYyBtZXNzYWdlU3ViamVjdCA9IG5ldyBTdWJqZWN0PFVuYk1lbnNhZ2VtRXZlbnQ+KCk7IFxyXG4gIHB1YmxpYyBjb3JlczogW3N0cmluZywgc3RyaW5nLCBzdHJpbmddW10gPSBbIC8vIEFqdXN0ZWkgYSB0aXBhZ2VtIGRvIGFycmF5XHJcbiAgICAgIFsnI2RmZjBkOCcsICcjM2M3NjNkJywgJyNkNmU5YzYnXSwgLy8gU1VDQ0VTU1xyXG4gICAgICBbJyNkOWVkZjcnLCAnIzMxNzA4ZicsICcjYmNlOGYxJ10sIC8vIElORk9cclxuICAgICAgWycjZmNmOGUzJywgJyM4YTZkM2InLCAnI2ZhZWJjYyddLCAvLyBXQVJOSU5HXHJcbiAgICAgIFsnI2YyZGVkZScsICcjYTk0NDQyJywgJyNlYmNjZDEnXSAgLy8gREFOR0VSXHJcbiAgXTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7fVxyXG5cclxuICAvKipcclxuICAgKiBAcGFyYW0gbWVzc2FnZSBtZW5zYWdlbSBxdWUgdmFpIGFwYXJlY2VyIG5hIHRlbGFcclxuICAgKiBAcGFyYW0gdGlwbyB0aXBvIGRhIG1lbnNhZ2VtOiBzdWNjZXNzLCBpbmZvLCB3YXJuaW5nLCBkYW5nZXIuXHJcbiAgICogQHBhcmFtIGlkIChPcGNpb25hbCkgSWRlbnRpZmljYWRvciBkbyBjb21wb25lbnRlIHF1ZSBkZXZlIGV4aWJpciBhIG1lbnNhZ2VtXHJcbiAgICovXHJcbiAgcHVibGljIHNob3dNZXNzYWdlKG1lc3NhZ2U6IHN0cmluZywgdHlwZTogbnVtYmVyLCBpZD86IHN0cmluZykge1xyXG4gICAgY29uc3QgbW9kZWwgPSB0aGlzLmNyZWF0ZUFsZXJ0TWVzc2FnZShtZXNzYWdlLCAuLi50aGlzLmNvcmVzW3R5cGVdKTtcclxuICAgIC8vIEVudmlhIG8gbW9kZWxvIEUgbyBpZCBhbHZvIChzZSBob3V2ZXIpXHJcbiAgICB0aGlzLm1lc3NhZ2VTdWJqZWN0Lm5leHQoeyBtb2RlbDogbW9kZWwsIHRhcmdldElkOiBpZCB9KTsgICAgXHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBFc2NvbmRlIG8gY29tcG9uZW50ZS4gXHJcbiAgICogQHBhcmFtIGlkIChPcGNpb25hbCkgU2UgaW5mb3JtYWRvLCBlc2NvbmRlIGFwZW5hcyBvIGNvbXBvbmVudGUgY29tIGVzdGUgSUQuXHJcbiAgICovXHJcbiAgcHVibGljIGhpZGVNZXNzYWdlKGlkPzogc3RyaW5nKSB7XHJcbiAgICAvLyBFbnZpYSBtb2RlbG8gdmF6aW8gcGFyYSBlc2NvbmRlclxyXG4gICAgdGhpcy5tZXNzYWdlU3ViamVjdC5uZXh0KHsgbW9kZWw6IG5ldyBVbmJNZW5zYWdlbU1vZGVsKCksIHRhcmdldElkOiBpZCB9KTsgXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0TWVzc2FnZVN1YmplY3QoKTogT2JzZXJ2YWJsZTxVbmJNZW5zYWdlbUV2ZW50PiB7XHJcbiAgICByZXR1cm4gdGhpcy5tZXNzYWdlU3ViamVjdC5hc09ic2VydmFibGUoKTtcclxuICB9IFxyXG5cclxuICBwcml2YXRlIGNyZWF0ZUFsZXJ0TWVzc2FnZShtZXNzYWdlOiBzdHJpbmcsIGJhY2tncm91bmRfY29sb3I6IHN0cmluZywgZm9udF9jb2xvcjogc3RyaW5nLCBib3JkZXJfY29sb3I6IHN0cmluZyk6IFVuYk1lbnNhZ2VtTW9kZWwge1xyXG4gICAgcmV0dXJuIHsgbWVzc2FnZSwgYmFja2dyb3VuZF9jb2xvciwgZm9udF9jb2xvciwgYm9yZGVyX2NvbG9yIH07IFxyXG4gIH1cclxufSJdfQ==
@@ -1,25 +1,30 @@
1
1
  import { Component, Inject } from '@angular/core';
2
2
  import { UnbPessoaEmail } from '../unb-pessoa-models/unb-pessoa-email.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 "@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";
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 UnbPessoaEmailFormComponent {
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.email = new UnbPessoaEmail();
22
26
  this.listaTipoEmail = [];
27
+ this.idMensagemService = "UnbPessoaEmailForm";
23
28
  this.email = JSON.parse(JSON.stringify(data.email)); // 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.emailsList) {
@@ -33,23 +38,27 @@ export class UnbPessoaEmailFormComponent {
33
38
  }
34
39
  }
35
40
  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;
41
+ // Chamamos o serviço direto. Não guardamos o observable, apenas o resultado.
42
+ this.service.getTipoEmail().subscribe({
43
+ next: (lista) => {
44
+ // 1. Guarda a lista para o HTML usar
45
+ this.listaTipoEmail = lista;
46
+ // 2. Lógica de Seleção Automática (Match)
47
+ if (this.email.tipoEmailCodigo != null) {
48
+ const tipoEncontrado = lista.find(t => t.codigo === this.email.tipoEmailCodigo);
49
+ if (tipoEncontrado) {
50
+ this.email.tipo = tipoEncontrado.denominacao;
51
+ }
45
52
  }
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;
53
+ else if (this.email.tipo) {
54
+ const tipoEncontrado = lista.find(t => t.denominacao?.toLowerCase() === this.email.tipo?.toLowerCase());
55
+ if (tipoEncontrado) {
56
+ this.email.tipoEmailCodigo = tipoEncontrado.codigo;
57
+ }
51
58
  }
52
- }
59
+ },
60
+ // 3. Usa seu tratamento de erro novo
61
+ error: (err) => this.handleError(err)
53
62
  });
54
63
  }
55
64
  salvar(form) {
@@ -127,19 +136,41 @@ export class UnbPessoaEmailFormComponent {
127
136
  salvarclose() {
128
137
  this.dialogRef.close(this.emailSalvo);
129
138
  }
139
+ handleError(erro) {
140
+ let erroTratado;
141
+ // Converte string local em Objeto Padrão
142
+ if (typeof erro === 'string') {
143
+ erroTratado = {
144
+ status: 400,
145
+ mensagemSimples: erro,
146
+ mensagemHtml: `<strong>${erro}</strong>`
147
+ };
148
+ }
149
+ else {
150
+ erroTratado = erro;
151
+ }
152
+ // 1. SnackBar
153
+ if (erroTratado.mensagemSimples) {
154
+ this.openSnackBar(erroTratado.mensagemSimples);
155
+ }
156
+ // 2. AlertService (Se houver tag <unb-mensagem> no HTML do dialog)
157
+ if (this.alertService && erroTratado.mensagemHtml) {
158
+ this.alertService.showMessage(erroTratado.mensagemHtml, UnbTipoMensagemEnum.DANGER, this.idMensagemService);
159
+ }
160
+ }
130
161
  openSnackBar(message) {
131
162
  this.snackBar.open(message, 'x', {
132
163
  duration: 5000,
133
164
  });
134
165
  }
135
- 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 }); }
136
- 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>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 <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 </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" }] }); }
166
+ 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.UnbMensagemService }, { token: i4.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
167
+ 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 <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)]=\"email.tipoEmailCodigo\" [compareWith]=\"compararTipos\" name=\"tipoEmailCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of listaTipoEmail\" [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>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 </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: 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.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"] }] }); }
137
168
  }
138
169
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEmailFormComponent, decorators: [{
139
170
  type: Component,
140
- 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>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 <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 </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"] }]
141
- }], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.MatDialogRef }, { type: undefined, decorators: [{
171
+ 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 <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)]=\"email.tipoEmailCodigo\" [compareWith]=\"compararTipos\" name=\"tipoEmailCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n <mat-option *ngFor=\"let tipo of listaTipoEmail\" [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>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 </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"] }]
172
+ }], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.UnBPessoaService }, { type: i3.UnbMensagemService }, { type: i4.MatDialogRef }, { type: undefined, decorators: [{
142
173
  type: Inject,
143
174
  args: [MAT_DIALOG_DATA]
144
175
  }] }] });
145
- //# 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\r\n    // 1. Define o 'tipo' padrão (ex: 1 para 'Pessoal') se não for preenchido\r\n    if (!this.email.tipoEmailCodigo) {\r\n      this.email.tipoEmailCodigo = 1; // 1 é geralmente 'Pessoal'\r\n    }\r\n\r\n    // 2. Define a 'ordem' (que o back-end chama de 'ordemEmail')\r\n    if (!this.email.ordem || this.email.ordem === 0) {\r\n      let maxOrdem = 0;\r\n\r\n      // Verifica se a lista de emails já existe e tem itens\r\n      if (this.emailsList && this.emailsList.length > 0) {\r\n        maxOrdem = Math.max(...this.emailsList.map(e => e.ordem || 0));\r\n      }\r\n\r\n      // Define a ordem do novo email como a maior ordem + 1\r\n      this.email.ordem = maxOrdem + 1;\r\n    }\r\n    // --- Fim da Modificação ---\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   * Valida o objeto de e-mail, replicando as regras do validador do backend.\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\r\n    // 1. Validação de campo obrigatório (do Java)\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 Tamanho Máximo (do Java)\r\n    if (emailToValidate.email.trim().length > 60) {\r\n      this.openSnackBar(\"E-mail deve ter no máximo 60 caracteres.\");\r\n      return false;\r\n    }\r\n\r\n    // 3. Validação de formato de e-mail (do Java e do Angular)\r\n    //    [Java: !Validadores.validarEmail(request.getEmail())]\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    // 4. Validação de e-mail duplicado (do seu Angular)\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    // Nota: As validações de 'ordemEmail' e 'tipoEmailCodigo' do Java\r\n    // já são tratadas na sua função 'salvar()',\r\n    // que atribui valores padrão antes desta função 'validar()' ser chamada.\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.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>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      <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    </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>"]}
176
+ //# 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 { 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-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  idMensagemService = \"UnbPessoaEmailForm\";\r\n\r\n  constructor(private snackBar: MatSnackBar, private service: UnBPessoaService, private alertService: UnbMensagemService, 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    // Chamamos o serviço direto. Não guardamos o observable, apenas o resultado.\r\n    this.service.getTipoEmail().subscribe({\r\n      next: (lista) => {\r\n        // 1. Guarda a lista para o HTML usar\r\n        this.listaTipoEmail = lista;\r\n\r\n        // 2. Lógica de Seleção Automática (Match)\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      // 3. Usa seu tratamento de erro novo\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\r\n    // 1. Define o 'tipo' padrão (ex: 1 para 'Pessoal') se não for preenchido\r\n    if (!this.email.tipoEmailCodigo) {\r\n      this.email.tipoEmailCodigo = 1; // 1 é geralmente 'Pessoal'\r\n    }\r\n\r\n    // 2. Define a 'ordem' (que o back-end chama de 'ordemEmail')\r\n    if (!this.email.ordem || this.email.ordem === 0) {\r\n      let maxOrdem = 0;\r\n\r\n      // Verifica se a lista de emails já existe e tem itens\r\n      if (this.emailsList && this.emailsList.length > 0) {\r\n        maxOrdem = Math.max(...this.emailsList.map(e => e.ordem || 0));\r\n      }\r\n\r\n      // Define a ordem do novo email como a maior ordem + 1\r\n      this.email.ordem = maxOrdem + 1;\r\n    }\r\n    // --- Fim da Modificação ---\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   * Valida o objeto de e-mail, replicando as regras do validador do backend.\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\r\n    // 1. Validação de campo obrigatório (do Java)\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 Tamanho Máximo (do Java)\r\n    if (emailToValidate.email.trim().length > 60) {\r\n      this.openSnackBar(\"E-mail deve ter no máximo 60 caracteres.\");\r\n      return false;\r\n    }\r\n\r\n    // 3. Validação de formato de e-mail (do Java e do Angular)\r\n    //    [Java: !Validadores.validarEmail(request.getEmail())]\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    // 4. Validação de e-mail duplicado (do seu Angular)\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    // Nota: As validações de 'ordemEmail' e 'tipoEmailCodigo' do Java\r\n    // já são tratadas na sua função 'salvar()',\r\n    // que atribui valores padrão antes desta função 'validar()' ser chamada.\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.emailSalvo);\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 E-mail</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)]=\"email.tipoEmailCodigo\" [compareWith]=\"compararTipos\" name=\"tipoEmailCodigo\" (selectionChange)=\"onTipoSelecionado($event.value)\" required>\r\n          <mat-option *ngFor=\"let tipo of listaTipoEmail\" [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>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    </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>"]}
@@ -16,7 +16,7 @@ export class UnbPessoaEmailListComponent {
16
16
  this.dialog = dialog;
17
17
  this.podeEditar = true;
18
18
  this.emails = [];
19
- this.apiPessoaConfig = { url: '', token: '' };
19
+ this.backendURL = '';
20
20
  this.emailsEmitted = new EventEmitter();
21
21
  }
22
22
  ngOnInit() {
@@ -141,7 +141,7 @@ export class UnbPessoaEmailListComponent {
141
141
  this.emails.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0)); // <-- 'ordem'
142
142
  }
143
143
  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 }); }
144
- 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" }, 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 {{ 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 type=\"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\" cdkDropList (cdkDropListDropped)=\"moverLinha($event)\">\r\n\r\n <tr style=\"background-color: #e4e3e3cc;\">\r\n <th style=\"width: 5%; text-align: center;\">Ordem</th>\r\n <th>E-mail</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 emails; let i = index\" class=\"my-tr\" cdkDrag>\r\n\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\r\n <td>{{ valor.email }}</td>\r\n\r\n <td>{{ valor.tipo?.toUpperCase() }}</td>\r\n\r\n <td>\r\n <div class=\"actions-container\">\r\n <button type=\"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 type=\"button\" mat-icon-button aria-label=\"Deletar\" 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"] }] }); }
144
+ 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", backendURL: "backendURL" }, outputs: { emailsEmitted: "emailsEmitted" }, 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 {{ 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 type=\"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\" cdkDropList (cdkDropListDropped)=\"moverLinha($event)\">\r\n\r\n <tr style=\"background-color: #e4e3e3cc;\">\r\n <th style=\"width: 5%; text-align: center;\">Ordem</th>\r\n <th>E-mail</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 emails; let i = index\" class=\"my-tr\" cdkDrag>\r\n\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\r\n <td>{{ valor.email }}</td>\r\n\r\n <td>{{ valor.tipo?.toUpperCase() }}</td>\r\n\r\n <td>\r\n <div class=\"actions-container\">\r\n <button type=\"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 type=\"button\" mat-icon-button aria-label=\"Deletar\" 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"] }] }); }
145
145
  }
146
146
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: UnbPessoaEmailListComponent, decorators: [{
147
147
  type: Component,
@@ -150,9 +150,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
150
150
  type: Input
151
151
  }], emails: [{
152
152
  type: Input
153
- }], apiPessoaConfig: [{
153
+ }], backendURL: [{
154
154
  type: Input
155
155
  }], emailsEmitted: [{
156
156
  type: Output
157
157
  }] } });
158
- //# 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, 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 { 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\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\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, OnChanges {\r\n\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  // tem que fazer isso pq no on init eu ainda nao tenho a lista\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    // Verifica se a propriedade 'emails' mudou\r\n    if (changes['emails'] && this.emails) {\r\n      // chamada quando os dados realmente chegarem\r\n      this.sortAndAssignOrder();\r\n    }\r\n  }\r\n\r\n  excluir(emailParaExcluir: UnbPessoaEmail) { // <-- TIPO CORRIGIDO\r\n\r\n    if (emailParaExcluir.codigo) {\r\n      // Se tem código, remove por ele\r\n      this.emails = this.emails.filter(e => e.codigo !== emailParaExcluir.codigo);\r\n    } else {\r\n      // Se não tem código (novo item), remove pela ordem\r\n      this.emails = this.emails.filter(e => e.ordem !== emailParaExcluir.ordem);\r\n    }\r\n\r\n    // Chama sua função existente que re-calcula as ordens e emite a lista\r\n    this.atualizarOrdem();\r\n  }\r\n\r\n  editar(email: UnbPessoaEmailTipo) {\r\n    this.openFormDialog(email);\r\n  }\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        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.emails.findIndex(e => e.codigo === result.codigo);\r\n      }\r\n\r\n      // 2. Se não achou pelo 'codigo', tenta pela 'ordem'.\r\n      if (index === -1 && result.ordem) {\r\n        index = this.emails.findIndex(e => e.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.emails[index] = result;\r\n      } else {\r\n        // NÃO ENCONTROU: É um item 100% novo (não uma edição)\r\n        this.emails.push(result);\r\n      }\r\n\r\n      // Re-ordena a lista pela 'ordem' e emite uma *nova cópia*\r\n      this.emails.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));\r\n      this.emailsEmitted.emit([...this.emails]); // <-- Emite nova cópia\r\n    });\r\n  }\r\n\r\n  moverLinha(event: CdkDragDrop<any[]>) {\r\n    moveItemInArray(this.emails, event.previousIndex, event.currentIndex);\r\n    this.atualizarOrdem()\r\n  }\r\n\r\nprivate sortAndAssignOrder(): void {\r\n    // 1. Crie uma cópia da lista\r\n    const tempEmails = [...this.emails]; // <-- NOME CORRIGIDO\r\n\r\n    // 2. Mapeie as ordens existentes\r\n    const orderMap = new Map<number, UnbPessoaEmail[]>();\r\n    const emailsWithoutOrder: UnbPessoaEmail[] = [];\r\n\r\n    tempEmails.forEach(email => {\r\n      // CORREÇÃO AQUI: 'ordem' em vez de 'ordemEmail'\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. ... (Funções 'finalUsedOrders', 'nextAvailableOrder' continuam iguais) ...\r\n    const finalUsedOrders = new Set<number>();\r\n    let nextAvailableOrder = 0;\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    this.emails.forEach(email => { // <-- NOME CORRIGIDO\r\n      // CORREÇÃO AQUI: 'ordem' em vez de 'ordemEmail'\r\n      if (email.ordem !== undefined && email.ordem !== null) {\r\n        if (!finalUsedOrders.has(email.ordem)) {\r\n          finalUsedOrders.add(email.ordem);\r\n        } else {\r\n          // Duplicata, atribua uma nova\r\n          email.ordem = getNextAvailableOrder();\r\n          finalUsedOrders.add(email.ordem);\r\n        }\r\n      }\r\n    });\r\n\r\n    // 5. Atribua ordens para emails que não tinham ordem\r\n    emailsWithoutOrder.forEach(email => { // <-- NOME CORRIGIDO\r\n      email.ordem = getNextAvailableOrder(); \r\n      finalUsedOrders.add(email.ordem); \r\n    });\r\n\r\n    // 6. Finalmente, ordene a lista\r\n    this.emails.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0)); // <-- 'ordem'\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 type=\"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\" cdkDropList (cdkDropListDropped)=\"moverLinha($event)\">\r\n\r\n        <tr style=\"background-color: #e4e3e3cc;\">\r\n            <th style=\"width: 5%; text-align: center;\">Ordem</th>\r\n            <th>E-mail</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 emails; let i = index\" class=\"my-tr\" cdkDrag>\r\n\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\r\n            <td>{{ valor.email }}</td>\r\n\r\n            <td>{{ valor.tipo?.toUpperCase() }}</td>\r\n\r\n            <td>\r\n                <div class=\"actions-container\">\r\n                    <button type=\"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 type=\"button\" mat-icon-button aria-label=\"Deletar\" 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>"]}
158
+ //# 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, 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 { 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\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\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, OnChanges {\r\n\r\n  @Input() podeEditar = true;\r\n  @Input() emails: any = [];\r\n  @Input() backendURL: string = '';\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  // tem que fazer isso pq no on init eu ainda nao tenho a lista\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    // Verifica se a propriedade 'emails' mudou\r\n    if (changes['emails'] && this.emails) {\r\n      // chamada quando os dados realmente chegarem\r\n      this.sortAndAssignOrder();\r\n    }\r\n  }\r\n\r\n  excluir(emailParaExcluir: UnbPessoaEmail) { // <-- TIPO CORRIGIDO\r\n\r\n    if (emailParaExcluir.codigo) {\r\n      // Se tem código, remove por ele\r\n      this.emails = this.emails.filter(e => e.codigo !== emailParaExcluir.codigo);\r\n    } else {\r\n      // Se não tem código (novo item), remove pela ordem\r\n      this.emails = this.emails.filter(e => e.ordem !== emailParaExcluir.ordem);\r\n    }\r\n\r\n    // Chama sua função existente que re-calcula as ordens e emite a lista\r\n    this.atualizarOrdem();\r\n  }\r\n\r\n  editar(email: UnbPessoaEmailTipo) {\r\n    this.openFormDialog(email);\r\n  }\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        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.emails.findIndex(e => e.codigo === result.codigo);\r\n      }\r\n\r\n      // 2. Se não achou pelo 'codigo', tenta pela 'ordem'.\r\n      if (index === -1 && result.ordem) {\r\n        index = this.emails.findIndex(e => e.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.emails[index] = result;\r\n      } else {\r\n        // NÃO ENCONTROU: É um item 100% novo (não uma edição)\r\n        this.emails.push(result);\r\n      }\r\n\r\n      // Re-ordena a lista pela 'ordem' e emite uma *nova cópia*\r\n      this.emails.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0));\r\n      this.emailsEmitted.emit([...this.emails]); // <-- Emite nova cópia\r\n    });\r\n  }\r\n\r\n  moverLinha(event: CdkDragDrop<any[]>) {\r\n    moveItemInArray(this.emails, event.previousIndex, event.currentIndex);\r\n    this.atualizarOrdem()\r\n  }\r\n\r\nprivate sortAndAssignOrder(): void {\r\n    // 1. Crie uma cópia da lista\r\n    const tempEmails = [...this.emails]; // <-- NOME CORRIGIDO\r\n\r\n    // 2. Mapeie as ordens existentes\r\n    const orderMap = new Map<number, UnbPessoaEmail[]>();\r\n    const emailsWithoutOrder: UnbPessoaEmail[] = [];\r\n\r\n    tempEmails.forEach(email => {\r\n      // CORREÇÃO AQUI: 'ordem' em vez de 'ordemEmail'\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. ... (Funções 'finalUsedOrders', 'nextAvailableOrder' continuam iguais) ...\r\n    const finalUsedOrders = new Set<number>();\r\n    let nextAvailableOrder = 0;\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    this.emails.forEach(email => { // <-- NOME CORRIGIDO\r\n      // CORREÇÃO AQUI: 'ordem' em vez de 'ordemEmail'\r\n      if (email.ordem !== undefined && email.ordem !== null) {\r\n        if (!finalUsedOrders.has(email.ordem)) {\r\n          finalUsedOrders.add(email.ordem);\r\n        } else {\r\n          // Duplicata, atribua uma nova\r\n          email.ordem = getNextAvailableOrder();\r\n          finalUsedOrders.add(email.ordem);\r\n        }\r\n      }\r\n    });\r\n\r\n    // 5. Atribua ordens para emails que não tinham ordem\r\n    emailsWithoutOrder.forEach(email => { // <-- NOME CORRIGIDO\r\n      email.ordem = getNextAvailableOrder(); \r\n      finalUsedOrders.add(email.ordem); \r\n    });\r\n\r\n    // 6. Finalmente, ordene a lista\r\n    this.emails.sort((a, b) => (a.ordem ?? 0) - (b.ordem ?? 0)); // <-- 'ordem'\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 type=\"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\" cdkDropList (cdkDropListDropped)=\"moverLinha($event)\">\r\n\r\n        <tr style=\"background-color: #e4e3e3cc;\">\r\n            <th style=\"width: 5%; text-align: center;\">Ordem</th>\r\n            <th>E-mail</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 emails; let i = index\" class=\"my-tr\" cdkDrag>\r\n\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\r\n            <td>{{ valor.email }}</td>\r\n\r\n            <td>{{ valor.tipo?.toUpperCase() }}</td>\r\n\r\n            <td>\r\n                <div class=\"actions-container\">\r\n                    <button type=\"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 type=\"button\" mat-icon-button aria-label=\"Deletar\" 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>"]}