@stiunb/unb-lib-components 18.0.25 → 18.0.26

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.
@@ -155,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAA4B,MAAM,eAAe,CAAC;AAMzG,OAAO,EAAE,2BAA2B,EAAE,MAAM,yBAAyB,CAAC;AAEtE,OAAO,EAAe,eAAe,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;;AAQtE,MAAM,OAAO,2BAA2B;IAStC,YAAoB,QAAqB,EAAU,OAAyB,EAAS,MAAiB;QAAlF,aAAQ,GAAR,QAAQ,CAAa;QAAU,YAAO,GAAP,OAAO,CAAkB;QAAS,WAAM,GAAN,MAAM,CAAW;QAP7F,eAAU,GAAG,IAAI,CAAC;QAClB,WAAM,GAAQ,EAAE,CAAC;QACjB,eAAU,GAAW,EAAE,CAAC;QACvB,kBAAa,GAAG,IAAI,YAAY,EAAoB,CAAC;IAM/D,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;QAE7C,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,wEAAwE;IACrG,CAAC;IAED,8DAA8D;IAC9D,WAAW,CAAC,OAAsB;QAChC,2CAA2C;QAC3C,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACrC,6CAA6C;YAC7C,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,OAAO,CAAC,gBAAgC;QAEtC,IAAI,gBAAgB,CAAC,MAAM,EAAE,CAAC;YAC5B,gCAAgC;YAChC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC9E,CAAC;aAAM,CAAC;YACN,mDAAmD;YACnD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC5E,CAAC;QAED,sEAAsE;QACtE,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,MAAM,CAAC,KAAyB;QAC9B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAGD,cAAc;QACZ,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;YACjC,KAAK,CAAC,KAAK,GAAG,GAAG,GAAG,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,cAAc,CAAC,WAAgB;QAC7B,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,EAAE;YAC9D,KAAK,EAAE,OAAO;YACd,IAAI,EAAE;gBACJ,KAAK,EAAE,WAAW,EAAE,0CAA0C;gBAC9D,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,kCAAkC;aAC3D;SACF,CAAC,CAAC;QAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACzC,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,OAAO,CAAC,2CAA2C;YACrD,CAAC;YAED,8DAA8D;YAC9D,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC;YAEf,uEAAuE;YACvE,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;gBAClB,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC;YACjE,CAAC;YAED,qDAAqD;YACrD,IAAI,KAAK,KAAK,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;gBACjC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,CAAC;YAC/D,CAAC;YAED,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;gBACf,uEAAuE;gBACvE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC;YAC9B,CAAC;iBAAM,CAAC;gBACN,sDAAsD;gBACtD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;YAED,0DAA0D;YAC1D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC;YAC5D,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,uBAAuB;QACpE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,KAAyB;QAClC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;QACtE,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEK,kBAAkB;QACtB,6BAA6B;QAC7B,MAAM,UAAU,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,qBAAqB;QAE1D,iCAAiC;QACjC,MAAM,QAAQ,GAAG,IAAI,GAAG,EAA4B,CAAC;QACrD,MAAM,kBAAkB,GAAqB,EAAE,CAAC;QAEhD,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACzB,gDAAgD;YAChD,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,EAAE,CAAC;gBACtD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC/B,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;gBAChC,CAAC;gBACD,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACzC,CAAC;iBAAM,CAAC;gBACN,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACjC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,gFAAgF;QAChF,MAAM,eAAe,GAAG,IAAI,GAAG,EAAU,CAAC;QAC1C,IAAI,kBAAkB,GAAG,CAAC,CAAC;QAC3B,MAAM,qBAAqB,GAAG,GAAG,EAAE;YACjC,OAAO,eAAe,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE,CAAC;gBAC/C,kBAAkB,EAAE,CAAC;YACvB,CAAC;YACD,OAAO,kBAAkB,EAAE,CAAC;QAC9B,CAAC,CAAC;QAEF,yCAAyC;QACzC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAC1B,gDAAgD;YAChD,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,EAAE,CAAC;gBACtD,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;oBACtC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACnC,CAAC;qBAAM,CAAC;oBACN,8BAA8B;oBAC9B,KAAK,CAAC,KAAK,GAAG,qBAAqB,EAAE,CAAC;oBACtC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACnC,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,qDAAqD;QACrD,kBAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACjC,KAAK,CAAC,KAAK,GAAG,qBAAqB,EAAE,CAAC;YACtC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc;IAC3E,CAAC;8GAzJQ,2BAA2B;kGAA3B,2BAA2B,qNChBxC,8jEAiDM;;2FDjCO,2BAA2B;kBANvC,SAAS;iCACI,KAAK,YACP,2BAA2B;uIAM5B,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACI,aAAa;sBAAtB,MAAM","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>"]}
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 { UnbTipoPessoaEnum } 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>"]}