keevo-components 1.7.18 → 1.7.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/api/components/table/table.config.column.mjs +1 -1
- package/esm2022/lib/menu/menu.component.mjs +1 -3
- package/esm2022/lib/treetable/treetable.component.mjs +10 -3
- package/esm2022/lib/workspace/workspace.component.mjs +1 -6
- package/fesm2022/keevo-components.mjs +11 -11
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/api/components/table/table.config.column.d.ts +2 -0
- package/lib/treetable/treetable.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmNvbHVtbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvY29tcG9uZW50cy90YWJsZS90YWJsZS5jb25maWcuY29sdW1uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnQ29sdW1uIHtcclxuICBwb3NpdGlvbj86IG51bWJlcjtcclxuICBmaWVsZDogc3RyaW5nO1xyXG4gIGhlYWRlcjogc3RyaW5nO1xyXG4gIGhlYWRlclRvb2x0aXA/OiBzdHJpbmc7XHJcbiAgZmllbGRUeXBlPzogc3RyaW5nO1xyXG4gIG9ubHlSZWFkRmllbGQ/OiBib29sZWFuO1xyXG4gIHdpZHRoPzogc3RyaW5nO1xyXG4gIHBpcGU/OiAnZGF0ZScgfCAnZGVjaW1hbCcgfCAnY3BmY25waicgfCAndGVsZWZvbmUnIHwgJ2NvZGlnb2ZpcGUnIHwgJ21vbmV5JyB8ICdwZXJjZW50YWdlJztcclxuICBzb3J0YWJsZTogYm9vbGVhbjtcclxuICBncm91cGVkPzogYm9vbGVhbjtcclxuICBjZW50cmFsaXplPzogYm9vbGVhbjtcclxuICBleHBpcmVkRGF0ZT86IGJvb2xlYW47XHJcbiAgaWNvbj86IHN0cmluZztcclxuICBpY29uRmllbGQ/OiBib29sZWFuO1xyXG4gIGluZEljb25NYXRlcmlhbD86IGJvb2xlYW47XHJcbiAgY2hlY2tlZD86IGJvb2xlYW47XHJcbiAgaGlkZUNvbHVtbj86IGJvb2xlYW47XHJcbiAgZml4ZWRDb2x1bW4/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmNvbHVtbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvY29tcG9uZW50cy90YWJsZS90YWJsZS5jb25maWcuY29sdW1uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnQ29sdW1uIHtcclxuICBwb3NpdGlvbj86IG51bWJlcjtcclxuICBmaWVsZDogc3RyaW5nO1xyXG4gIGhlYWRlcjogc3RyaW5nO1xyXG4gIGhlYWRlclRvb2x0aXA/OiBzdHJpbmc7XHJcbiAgZmllbGRUeXBlPzogc3RyaW5nO1xyXG4gIG9ubHlSZWFkRmllbGQ/OiBib29sZWFuO1xyXG4gIHdpZHRoPzogc3RyaW5nO1xyXG4gIHBpcGU/OiAnZGF0ZScgfCAnZGVjaW1hbCcgfCAnY3BmY25waicgfCAndGVsZWZvbmUnIHwgJ2NvZGlnb2ZpcGUnIHwgJ21vbmV5JyB8ICdwZXJjZW50YWdlJztcclxuICBzb3J0YWJsZTogYm9vbGVhbjtcclxuICBncm91cGVkPzogYm9vbGVhbjtcclxuICBjZW50cmFsaXplPzogYm9vbGVhbjtcclxuICBleHBpcmVkRGF0ZT86IGJvb2xlYW47XHJcbiAgaWNvbj86IHN0cmluZztcclxuICBpY29uRmllbGQ/OiBib29sZWFuO1xyXG4gIGluZEljb25NYXRlcmlhbD86IGJvb2xlYW47XHJcbiAgY2hlY2tlZD86IGJvb2xlYW47XHJcbiAgaGlkZUNvbHVtbj86IGJvb2xlYW47XHJcbiAgZml4ZWRDb2x1bW4/OiBib29sZWFuO1xyXG4gIHRlbXBsYXRlPzogYW55O1xyXG4gIGFsaWduPzogc3RyaW5nO1xyXG4gIHN1YnRpdGxlPzogc3RyaW5nO1xyXG4gIGJvb2xlYW4/OiBib29sZWFuO1xyXG59XHJcbiJdfQ==
|
|
@@ -21,7 +21,6 @@ export class MenuComponent {
|
|
|
21
21
|
this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);
|
|
22
22
|
this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);
|
|
23
23
|
this.cdr.detectChanges();
|
|
24
|
-
console.log(this.widthCard, 'wid');
|
|
25
24
|
}
|
|
26
25
|
constructor(cdr, router, route) {
|
|
27
26
|
this.cdr = cdr;
|
|
@@ -45,7 +44,6 @@ export class MenuComponent {
|
|
|
45
44
|
this.configurarLicencas();
|
|
46
45
|
this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);
|
|
47
46
|
this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);
|
|
48
|
-
console.log(this.widthCard, 'wid');
|
|
49
47
|
}
|
|
50
48
|
configurarLicencas() {
|
|
51
49
|
setTimeout(() => this.setLicenca(), 1500);
|
|
@@ -214,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
214
212
|
type: HostListener,
|
|
215
213
|
args: ['window:resize', ['$event']]
|
|
216
214
|
}] } });
|
|
217
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/menu/menu.component.ts","../../../../../projects/keevo-components/src/lib/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MasterComboModel } from 'keevo-api-services-keevocenter';\r\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\r\nimport { ChangeDetectorRef, Component, EventEmitter, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\r\n\r\nimport { Sidebar } from 'primeng/sidebar';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\n\r\nimport { menuCompletoModel } from '../api/models/menu/menucompleto.model';\r\nimport { menuModel } from '../api/models/menu/menu.model';\r\n\r\n@Component({\r\n  selector: 'kv-menu',\r\n  templateUrl: './menu.component.html',\r\n  styleUrls: ['./menu.component.scss'],\r\n})\r\nexport class MenuComponent implements OnInit {\r\n\r\n  @Input() menuCompleto: menuCompletoModel[] = [];\r\n  @Input() licencas: MasterComboModel[] = []\r\n  @Input() licencaSelecionada!: MasterComboModel;\r\n  @Input() logoImage!: any;\r\n  @Input() nomeUsuario!: string;\r\n  @Input() breadCrumbItems: { label: string, routerLink: string }[] = [];\r\n\r\n  @Output() licencaChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() gerenciarKeePassEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() sairEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() trocarLicencaEmit: EventEmitter<boolean> = new EventEmitter();\r\n\r\n\r\n  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\r\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\r\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\r\n\r\n  licencasOptions: { id: number, descricao: string, cpfcnpj: string }[] = []\r\n  licencaSelected!: { id: number, descricao: string, cpfcnpj: string };\r\n\r\n  menusFiltrados: menuCompletoModel[] = [];\r\n  menus: menuModel[] = [];\r\n\r\n\r\n  heigthCard!: number;\r\n  widthCard!: number;\r\n  expandMenu: boolean = true;\r\n\r\n  visibleDialogLicenca: boolean = false;\r\n\r\n  mouseOverIndex: any;\r\n  mouseOverFilhoIndex: any;\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n    this.cdr.detectChanges();\r\n    console.log(this.widthCard, 'wid')\r\n  }\r\n\r\n  constructor(private cdr: ChangeDetectorRef, protected router: Router, private route: ActivatedRoute) { }\r\n\r\n  ngOnInit(): void {\r\n    this.configurarLicencas();\r\n\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n    console.log(this.widthCard, 'wid')\r\n  }\r\n\r\n  configurarLicencas() {\r\n    setTimeout(() => this.setLicenca(), 1500)\r\n\r\n    this.licencas.forEach((x, i) => {\r\n      this.licencasOptions.push({\r\n        id: i,\r\n        descricao: x.nome,\r\n        cpfcnpj: x.cpfcnpj\r\n      })\r\n    })\r\n\r\n    var licenca = this.licencasOptions.find((x) => x.cpfcnpj == this.licencaSelecionada.cpfcnpj);\r\n\r\n    if (licenca != undefined)\r\n      this.licencaSelected = licenca;\r\n  }\r\n\r\n  closeCallback(e: Event): void {\r\n    this.sidebarRef.close(e);\r\n  }\r\n\r\n  MascaraNomeLicenca(nomeLicenca: any): string {\r\n    if (nomeLicenca) {\r\n      if (nomeLicenca.length > 23)\r\n        return nomeLicenca.substring(0, 23) + '...';\r\n      else return nomeLicenca;\r\n    } else return '';\r\n  }\r\n\r\n  MascaraCnpj(cpfcnpj: string): string {\r\n    const cpfcnpjLimpo = cpfcnpj.replace(/\\D/g, '');\r\n\r\n    return cpfcnpjLimpo.replace(\r\n      /^(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{2})$/,\r\n      '$1.$2.$3/$4-$5'\r\n    );\r\n  }\r\n\r\n  retornarMenuFilhos(idsistema: number, idmenu: number) {\r\n    return this.menuCompleto\r\n      .find((x) => x.sistema.idsistema == idsistema)\r\n      ?.menus.filter((x) => x.idmenupai == idmenu);\r\n  }\r\n\r\n  callRoute(e: any, expand?: boolean) {\r\n    if (!expand)\r\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : ''\r\n    this.router.navigateByUrl(e)\r\n  }\r\n\r\n  toggleMenu() {\r\n    this.expandMenu = !this.expandMenu;\r\n    this.expandMenuEvent()\r\n  }\r\n\r\n  trocarLicenca() {\r\n    this.trocarLicencaEmit.emit();\r\n  }\r\n\r\n  setLicenca() {\r\n    var licenca = this.licencas.find((licenca) => licenca.idmaster == this.licencaSelected.id);\r\n    if (licenca) this.licencaSelecionada = licenca;\r\n\r\n    this.visibleDialogLicenca = false\r\n\r\n    this.licencaChange.emit(this.licencaSelecionada);\r\n\r\n    this.definirMenusPorSistema(this.menuCompleto[0]?.sistema.idsistema)\r\n  }\r\n\r\n  definirMenusPorSistema(idsistema: number) {\r\n    this.menus =\r\n      this.menuCompleto.find((x) => x.sistema.idsistema == idsistema)?.menus ||\r\n      [];\r\n\r\n    if (this.router.url === '/')\r\n      this.navigateToFirstMenu()\r\n    else {\r\n      const menuSelecionado = this.menus.find((menu: any) => menu.link.includes(this.router.url.slice(1)));\r\n      if (menuSelecionado) {\r\n        this.navigateToMenu(menuSelecionado);\r\n      }\r\n    }\r\n\r\n    this.sistemasPanel.hide();\r\n  }\r\n\r\n  navigateToFirstMenu(): void {\r\n    const firstMenu = this.menus[0];\r\n    if (firstMenu.menupai) {\r\n      const filhos = this.retornarMenuFilhos(firstMenu.idsistema, firstMenu.idmenu);\r\n      if (filhos) {\r\n        this.callRoute(filhos[0].link, true);\r\n      }\r\n    } else {\r\n      this.callRoute(firstMenu.link, true);\r\n    }\r\n  }\r\n\r\n  navigateToMenu(menu: any): void {\r\n    if (menu.menupai) {\r\n      const filhos = this.retornarMenuFilhos(menu.idsistema, menu.idmenu);\r\n      if (filhos) {\r\n        this.callRoute(filhos[0].link, true);\r\n      }\r\n    } else {\r\n      this.callRoute(menu.link, true);\r\n    }\r\n  }\r\n\r\n  gerenciarKeePass(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.gerenciarKeePassEvent.emit(event)\r\n  }\r\n\r\n  sair(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.sairEvent.emit(event)\r\n  }\r\n\r\n  expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu);\r\n  }\r\n\r\n  ajustarHeigthCard(): number {\r\n    if (this.widthCard > 400) {\r\n      if (this.breadCrumbItems.length > 0) return 105\r\n      else return 85\r\n    } else return 83\r\n  }\r\n\r\n  verificarPaginaSelecionada(link: any): boolean {\r\n    return this.router.url.includes(link);\r\n  }\r\n\r\n  onMouseEnter(index: number) {\r\n    this.mouseOverIndex = index;\r\n  }\r\n\r\n  onMouseFilhoEnter(index: number) {\r\n    this.mouseOverFilhoIndex = index;\r\n  }\r\n\r\n  onMouseLeave() {\r\n    this.mouseOverIndex = null;\r\n    this.mouseOverFilhoIndex = null;\r\n  }\r\n}\r\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\r\n\r\n  <div [style]=\"{minWidth: expandMenu ? '300px' : '60px'}\"></div>\r\n\r\n  <p-sidebar\r\n    #sidebarRef\r\n    [visible]=\"true\"\r\n    [showCloseIcon]=\"false\"\r\n    [modal]=\"false\"\r\n    [style]=\"{width: expandMenu ? '300px' : '60px'}\"\r\n  >\r\n    <ng-template pTemplate=\"headless\">\r\n      <div class=\"flex flex-column mx-1\">\r\n        <div class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2\">\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}} py-3\"\r\n          >\r\n            <img\r\n              *ngIf=\"expandMenu\"\r\n              alt=\"Card\"\r\n              [src]=\"logoImage\"\r\n              width=\"150\"\r\n            />\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"toggleMenu()\"\r\n              [pTooltip]=\"expandMenu ? 'Ocutar Menu' : 'Expandir Menu'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                menu\r\n              </i>\r\n            </button>\r\n          </div>\r\n\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}}\"\r\n          >\r\n            <div\r\n              class=\"flex flex-column cursor-pointer\"\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"trocarLicenca()\"\r\n            >\r\n              <span\r\n                class=\"text-sm font-semibold mr-2\"\r\n                [pTooltip]=\"this.licencaSelecionada.nome\"\r\n                [tooltipPosition]=\"'right'\"\r\n              >\r\n                {{MascaraNomeLicenca(this.licencaSelecionada.nome)}}\r\n              </span>\r\n              <span class=\"text-sm mt-1\">{{MascaraCnpj(this.licencaSelecionada.cpfcnpj || '')}}</span>\r\n            </div>\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"trocarLicenca()\"\r\n              [pTooltip]=\"'Alterar workspace'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                sync_alt\r\n              </i>\r\n            </button>\r\n\r\n          </div>\r\n          <p-divider type=\"solid\"></p-divider>\r\n        </div>\r\n\r\n        <div\r\n          class=\"list-none m-0  card-container {{expandMenu ? 'mx-1' : ''}}\"\r\n          [style.max-height]=\"(heigthCard - 220) + 'px'\"\r\n          style=\"overflow-y: auto;\"\r\n        >\r\n          <!-- menus -->\r\n          <li *ngFor=\"let menu of menus; let i = index\">\r\n            <!-- menu que não tem filho -->\r\n            <a\r\n              (mouseenter)=\"onMouseEnter(i)\"\r\n              (mouseleave)=\"onMouseLeave()\"\r\n              [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n              (click)=\"callRoute(menu.link)\"\r\n              *ngIf=\"!menu.menupai && menu.idmenupai == 0\"\r\n              pRipple\r\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n              [tooltipPosition]=\"'right'\"\r\n              class=\"{{verificarPaginaSelecionada(menu.link) ? 'bg-green-600' : ''}} menu-option flex align-items-center no-underline {{!expandMenu ? 'justify-content-center' : ''}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n            >\r\n\r\n              <i\r\n                class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}  icon-hover-color {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\r\n                *ngIf=\"menu.icone && menu.icone !== ''\"\r\n              >\r\n                {{ menu.icone }}\r\n              </i>\r\n              <span\r\n                class=\"text-base text-blue-900 font-medium {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ menu.descricaomenu }}</span>\r\n            </a>\r\n            <!-- menu com filho -->\r\n            <div *ngIf=\"menu.menupai\">\r\n              <a\r\n                (mouseenter)=\"onMouseEnter(i)\"\r\n                (mouseleave)=\"onMouseLeave()\"\r\n                [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n                pRipple\r\n                pStyleClass=\"@next\"\r\n                enterClass=\"hidden\"\r\n                enterActiveClass=\"slidedown\"\r\n                leaveToClass=\"hidden\"\r\n                leaveActiveClass=\"slideup\"\r\n                class=\"menu-option flex align-items-center {{!expandMenu ? 'justify-content-center' : 'justify-content-between'}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n                [tooltipPosition]=\"'right'\"\r\n                [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n                (click)=\"!expandMenu ? expandMenu = !expandMenu : ''\"\r\n              >\r\n                <div class=\"flex flex-row align-items-center\">\r\n\r\n                  <i\r\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}} icon-hover-color\"\r\n                    *ngIf=\"menu.icone && menu.icone !== ''\"\r\n                    [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n                  >\r\n                    {{ menu.icone }}\r\n                  </i>\r\n                  <span\r\n                    class=\"text-base text-blue-900 font-medium\"\r\n                    *ngIf=\"expandMenu\"\r\n                  >{{ menu.descricaomenu }}</span>\r\n                </div>\r\n                <i\r\n                  class=\"pi pi-chevron-down text-blue-900 mr-1 icon-hover-color\"\r\n                  *ngIf=\"expandMenu\"\r\n                  [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n                ></i>\r\n              </a>\r\n\r\n              <!-- filhos -->\r\n              <div\r\n                class=\"list-none py-0 pl-3 pr-0 m-0 hidden overflow-y-hidden transition-all transition-duration-400 transition-ease-in-out\"\r\n              >\r\n          <li *ngFor=\"\r\n              let filho of retornarMenuFilhos(menu.idsistema, menu.idmenu);  let iFilho = index\r\n            \">\r\n            <a\r\n              (mouseenter)=\"onMouseFilhoEnter(filho.idmenu)\"\r\n              (mouseleave)=\"onMouseLeave()\"\r\n              [ngClass]=\"{'hover-color': mouseOverFilhoIndex === filho.idmenu}\"\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"callRoute(filho.link)\"\r\n              pRipple\r\n              class=\"{{verificarPaginaSelecionada(filho.link) ? 'bg-green-600' : ''}} menu-option flex align-items-center no-underline cursor-pointer border-round text-700 hover:bg-green-600 transition-duration-150 transition-colors p-ripple p-2\"\r\n            >\r\n              <i\r\n                class=\"pi pi-chart-line mr-2 ml-1 adjust-icon-menu\"\r\n                *ngIf=\"filho.icone && filho.icone !== ''\"\r\n              ></i>\r\n              <span\r\n                class=\"text-base text-blue-900 ml-4 {{verificarPaginaSelecionada(filho.link) ? 'text-white' : ''}}\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ filho.descricaomenu }}</span>\r\n            </a>\r\n          </li>\r\n        </div>\r\n      </div>\r\n</div>\r\n</div>\r\n</ng-template>\r\n</p-sidebar>\r\n\r\n\r\n<div\r\n  class=\"w-auto h-screen page-content overflow-y-hidden\"\r\n  id=\"page-content\"\r\n>\r\n\r\n  <div class=\"flex flex-row align-items-center justify-content-between m-3\">\r\n    <div>\r\n      <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">{{breadCrumbItems[breadCrumbItems.length -\r\n        1]?.label}}</p>\r\n      <p-breadcrumb\r\n        *ngIf=\"widthCard > 400\"\r\n        styleClass=\"border-none p-0 flex align-items-center h-2rem !important;\"\r\n        [model]=\"breadCrumbItems\"\r\n        [style]=\"{backgroundColor: '#d4d3d3'}\"\r\n        (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n      ></p-breadcrumb>\r\n    </div>\r\n\r\n    <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n\r\n      <p-button\r\n        styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n        icon=\"pi pi-th-large\"\r\n        [rounded]=\"true\"\r\n        [text]=\"true\"\r\n        (click)=\"sistemasPanel.toggle($event)\"\r\n        [pTooltip]=\"'Sistemas'\"\r\n        [tooltipPosition]=\"'left'\"\r\n      ></p-button>\r\n\r\n      <p-button\r\n        styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n        icon=\"pi pi-user\"\r\n        [rounded]=\"true\"\r\n        [text]=\"true\"\r\n        [pTooltip]=\"'Menu do Usuário'\"\r\n        [tooltipPosition]=\"'left'\"\r\n        (click)=\"meusDadosPanel.toggle($event)\"\r\n      ></p-button>\r\n\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p-card\r\n    class=\"card-container\"\r\n    styleClass=\"m-3 border-noround overflow-y-auto card-container\"\r\n    [style]=\"{height: heigthCard - ajustarHeigthCard() + 'px'}\"\r\n  >\r\n    <div class=\"card-container w-full\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n  </p-card>\r\n\r\n</div>\r\n\r\n\r\n<p-overlayPanel\r\n  #sistemasPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n  <ng-template pTemplate=\"container\">\r\n    <p class=\"title-style mt-3\">Sistemas</p>\r\n    <div\r\n      class=\"flex flex-row flex-wrap gap-2 align-items-center justify-content-center mt-5 mb-3\"\r\n      style=\"width: 250px; height: 100%;\"\r\n    >\r\n      <button\r\n        *ngFor=\"let menu of menuCompleto\"\r\n        pButton\r\n        pRipple\r\n        class=\"btn-sistema-2 btn-sistema hover-btn-cor-padrao remove-focus h-4rem w-4rem\"\r\n        (click)=\"definirMenusPorSistema(menu.sistema.idsistema)\"\r\n        [pTooltip]=\"menu.sistema.descricaosistema\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        {{ menu.sistema.nomesistema.charAt(0).toUpperCase() }}\r\n      </button>\r\n\r\n    </div>\r\n  </ng-template>\r\n</p-overlayPanel>\r\n\r\n<p-overlayPanel\r\n  #meusDadosPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n\r\n  <ng-template pTemplate=\"container\">\r\n\r\n    <p class=\"title-style mt-3\">Olá, {{nomeUsuario ? nomeUsuario.split(' ')[0] : 'Usuário'}} !</p>\r\n    <div class=\"mt-5 mb-3\">\r\n\r\n    </div>\r\n\r\n    <p-button\r\n      icon=\"pi pi-lock\"\r\n      label=\"Gerênciar KeevoPass\"\r\n      (onClick)=\"gerenciarKeePass($event)\"\r\n      styleClass=\"border-noround w-full text-blue-900\"\r\n      [text]=\"true\"\r\n      [disabled]=\"true\"\r\n    ></p-button>\r\n    <p-button\r\n      icon=\"pi pi-sign-out\"\r\n      label=\"Sair\"\r\n      (onClick)=\"sair($event)\"\r\n      styleClass=\"border-noround w-full text-blue-900\"\r\n      [text]=\"true\"\r\n    ></p-button>\r\n  </ng-template>\r\n\r\n</p-overlayPanel>\r\n\r\n<p-dialog\r\n  [(visible)]=\"visibleDialogLicenca\"\r\n  [modal]=\"true\"\r\n  [draggable]=\"false\"\r\n  header=\"Trocar Licença\"\r\n  [style]=\"{width: '50vh' }\"\r\n>\r\n  <div class=\"flex flex-column align-items-end\">\r\n\r\n    <div class=\"w-full\">\r\n      <p-dropdown\r\n        styleClass=\"w-full\"\r\n        [options]=\"licencasOptions\"\r\n        [(ngModel)]=\"licencaSelected\"\r\n        optionLabel=\"descricao\"\r\n      ></p-dropdown>\r\n    </div>\r\n\r\n    <kv-button-success\r\n      [label]=\"'Salvar'\"\r\n      class=\"mt-2\"\r\n      (onClick)=\"setLicenca()\"\r\n    ></kv-button-success>\r\n\r\n  </div>\r\n\r\n</p-dialog>"]}
|
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/menu/menu.component.ts","../../../../../projects/keevo-components/src/lib/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MasterComboModel } from 'keevo-api-services-keevocenter';\r\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\r\nimport { ChangeDetectorRef, Component, EventEmitter, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\r\n\r\nimport { Sidebar } from 'primeng/sidebar';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\n\r\nimport { menuCompletoModel } from '../api/models/menu/menucompleto.model';\r\nimport { menuModel } from '../api/models/menu/menu.model';\r\n\r\n@Component({\r\n  selector: 'kv-menu',\r\n  templateUrl: './menu.component.html',\r\n  styleUrls: ['./menu.component.scss'],\r\n})\r\nexport class MenuComponent implements OnInit {\r\n\r\n  @Input() menuCompleto: menuCompletoModel[] = [];\r\n  @Input() licencas: MasterComboModel[] = []\r\n  @Input() licencaSelecionada!: MasterComboModel;\r\n  @Input() logoImage!: any;\r\n  @Input() nomeUsuario!: string;\r\n  @Input() breadCrumbItems: { label: string, routerLink: string }[] = [];\r\n\r\n  @Output() licencaChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() gerenciarKeePassEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() sairEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() trocarLicencaEmit: EventEmitter<boolean> = new EventEmitter();\r\n\r\n\r\n  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\r\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\r\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\r\n\r\n  licencasOptions: { id: number, descricao: string, cpfcnpj: string }[] = []\r\n  licencaSelected!: { id: number, descricao: string, cpfcnpj: string };\r\n\r\n  menusFiltrados: menuCompletoModel[] = [];\r\n  menus: menuModel[] = [];\r\n\r\n\r\n  heigthCard!: number;\r\n  widthCard!: number;\r\n  expandMenu: boolean = true;\r\n\r\n  visibleDialogLicenca: boolean = false;\r\n\r\n  mouseOverIndex: any;\r\n  mouseOverFilhoIndex: any;\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  constructor(private cdr: ChangeDetectorRef, protected router: Router, private route: ActivatedRoute) { }\r\n\r\n  ngOnInit(): void {\r\n    this.configurarLicencas();\r\n\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n  }\r\n\r\n  configurarLicencas() {\r\n    setTimeout(() => this.setLicenca(), 1500)\r\n\r\n    this.licencas.forEach((x, i) => {\r\n      this.licencasOptions.push({\r\n        id: i,\r\n        descricao: x.nome,\r\n        cpfcnpj: x.cpfcnpj\r\n      })\r\n    })\r\n\r\n    var licenca = this.licencasOptions.find((x) => x.cpfcnpj == this.licencaSelecionada.cpfcnpj);\r\n\r\n    if (licenca != undefined)\r\n      this.licencaSelected = licenca;\r\n  }\r\n\r\n  closeCallback(e: Event): void {\r\n    this.sidebarRef.close(e);\r\n  }\r\n\r\n  MascaraNomeLicenca(nomeLicenca: any): string {\r\n    if (nomeLicenca) {\r\n      if (nomeLicenca.length > 23)\r\n        return nomeLicenca.substring(0, 23) + '...';\r\n      else return nomeLicenca;\r\n    } else return '';\r\n  }\r\n\r\n  MascaraCnpj(cpfcnpj: string): string {\r\n    const cpfcnpjLimpo = cpfcnpj.replace(/\\D/g, '');\r\n\r\n    return cpfcnpjLimpo.replace(\r\n      /^(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{2})$/,\r\n      '$1.$2.$3/$4-$5'\r\n    );\r\n  }\r\n\r\n  retornarMenuFilhos(idsistema: number, idmenu: number) {\r\n    return this.menuCompleto\r\n      .find((x) => x.sistema.idsistema == idsistema)\r\n      ?.menus.filter((x) => x.idmenupai == idmenu);\r\n  }\r\n\r\n  callRoute(e: any, expand?: boolean) {\r\n    if (!expand)\r\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : ''\r\n    this.router.navigateByUrl(e)\r\n  }\r\n\r\n  toggleMenu() {\r\n    this.expandMenu = !this.expandMenu;\r\n    this.expandMenuEvent()\r\n  }\r\n\r\n  trocarLicenca() {\r\n    this.trocarLicencaEmit.emit();\r\n  }\r\n\r\n  setLicenca() {\r\n    var licenca = this.licencas.find((licenca) => licenca.idmaster == this.licencaSelected.id);\r\n    if (licenca) this.licencaSelecionada = licenca;\r\n\r\n    this.visibleDialogLicenca = false\r\n\r\n    this.licencaChange.emit(this.licencaSelecionada);\r\n\r\n    this.definirMenusPorSistema(this.menuCompleto[0]?.sistema.idsistema)\r\n  }\r\n\r\n  definirMenusPorSistema(idsistema: number) {\r\n    this.menus =\r\n      this.menuCompleto.find((x) => x.sistema.idsistema == idsistema)?.menus ||\r\n      [];\r\n\r\n    if (this.router.url === '/')\r\n      this.navigateToFirstMenu()\r\n    else {\r\n      const menuSelecionado = this.menus.find((menu: any) => menu.link.includes(this.router.url.slice(1)));\r\n      if (menuSelecionado) {\r\n        this.navigateToMenu(menuSelecionado);\r\n      }\r\n    }\r\n\r\n    this.sistemasPanel.hide();\r\n  }\r\n\r\n  navigateToFirstMenu(): void {\r\n    const firstMenu = this.menus[0];\r\n    if (firstMenu.menupai) {\r\n      const filhos = this.retornarMenuFilhos(firstMenu.idsistema, firstMenu.idmenu);\r\n      if (filhos) {\r\n        this.callRoute(filhos[0].link, true);\r\n      }\r\n    } else {\r\n      this.callRoute(firstMenu.link, true);\r\n    }\r\n  }\r\n\r\n  navigateToMenu(menu: any): void {\r\n    if (menu.menupai) {\r\n      const filhos = this.retornarMenuFilhos(menu.idsistema, menu.idmenu);\r\n      if (filhos) {\r\n        this.callRoute(filhos[0].link, true);\r\n      }\r\n    } else {\r\n      this.callRoute(menu.link, true);\r\n    }\r\n  }\r\n\r\n  gerenciarKeePass(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.gerenciarKeePassEvent.emit(event)\r\n  }\r\n\r\n  sair(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.sairEvent.emit(event)\r\n  }\r\n\r\n  expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu);\r\n  }\r\n\r\n  ajustarHeigthCard(): number {\r\n    if (this.widthCard > 400) {\r\n      if (this.breadCrumbItems.length > 0) return 105\r\n      else return 85\r\n    } else return 83\r\n  }\r\n\r\n  verificarPaginaSelecionada(link: any): boolean {\r\n    return this.router.url.includes(link);\r\n  }\r\n\r\n  onMouseEnter(index: number) {\r\n    this.mouseOverIndex = index;\r\n  }\r\n\r\n  onMouseFilhoEnter(index: number) {\r\n    this.mouseOverFilhoIndex = index;\r\n  }\r\n\r\n  onMouseLeave() {\r\n    this.mouseOverIndex = null;\r\n    this.mouseOverFilhoIndex = null;\r\n  }\r\n}\r\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\r\n\r\n  <div [style]=\"{minWidth: expandMenu ? '300px' : '60px'}\"></div>\r\n\r\n  <p-sidebar\r\n    #sidebarRef\r\n    [visible]=\"true\"\r\n    [showCloseIcon]=\"false\"\r\n    [modal]=\"false\"\r\n    [style]=\"{width: expandMenu ? '300px' : '60px'}\"\r\n  >\r\n    <ng-template pTemplate=\"headless\">\r\n      <div class=\"flex flex-column mx-1\">\r\n        <div class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2\">\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}} py-3\"\r\n          >\r\n            <img\r\n              *ngIf=\"expandMenu\"\r\n              alt=\"Card\"\r\n              [src]=\"logoImage\"\r\n              width=\"150\"\r\n            />\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"toggleMenu()\"\r\n              [pTooltip]=\"expandMenu ? 'Ocutar Menu' : 'Expandir Menu'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                menu\r\n              </i>\r\n            </button>\r\n          </div>\r\n\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}}\"\r\n          >\r\n            <div\r\n              class=\"flex flex-column cursor-pointer\"\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"trocarLicenca()\"\r\n            >\r\n              <span\r\n                class=\"text-sm font-semibold mr-2\"\r\n                [pTooltip]=\"this.licencaSelecionada.nome\"\r\n                [tooltipPosition]=\"'right'\"\r\n              >\r\n                {{MascaraNomeLicenca(this.licencaSelecionada.nome)}}\r\n              </span>\r\n              <span class=\"text-sm mt-1\">{{MascaraCnpj(this.licencaSelecionada.cpfcnpj || '')}}</span>\r\n            </div>\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"trocarLicenca()\"\r\n              [pTooltip]=\"'Alterar workspace'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                sync_alt\r\n              </i>\r\n            </button>\r\n\r\n          </div>\r\n          <p-divider type=\"solid\"></p-divider>\r\n        </div>\r\n\r\n        <div\r\n          class=\"list-none m-0  card-container {{expandMenu ? 'mx-1' : ''}}\"\r\n          [style.max-height]=\"(heigthCard - 220) + 'px'\"\r\n          style=\"overflow-y: auto;\"\r\n        >\r\n          <!-- menus -->\r\n          <li *ngFor=\"let menu of menus; let i = index\">\r\n            <!-- menu que não tem filho -->\r\n            <a\r\n              (mouseenter)=\"onMouseEnter(i)\"\r\n              (mouseleave)=\"onMouseLeave()\"\r\n              [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n              (click)=\"callRoute(menu.link)\"\r\n              *ngIf=\"!menu.menupai && menu.idmenupai == 0\"\r\n              pRipple\r\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n              [tooltipPosition]=\"'right'\"\r\n              class=\"{{verificarPaginaSelecionada(menu.link) ? 'bg-green-600' : ''}} menu-option flex align-items-center no-underline {{!expandMenu ? 'justify-content-center' : ''}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n            >\r\n\r\n              <i\r\n                class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}  icon-hover-color {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\r\n                *ngIf=\"menu.icone && menu.icone !== ''\"\r\n              >\r\n                {{ menu.icone }}\r\n              </i>\r\n              <span\r\n                class=\"text-base text-blue-900 font-medium {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ menu.descricaomenu }}</span>\r\n            </a>\r\n            <!-- menu com filho -->\r\n            <div *ngIf=\"menu.menupai\">\r\n              <a\r\n                (mouseenter)=\"onMouseEnter(i)\"\r\n                (mouseleave)=\"onMouseLeave()\"\r\n                [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n                pRipple\r\n                pStyleClass=\"@next\"\r\n                enterClass=\"hidden\"\r\n                enterActiveClass=\"slidedown\"\r\n                leaveToClass=\"hidden\"\r\n                leaveActiveClass=\"slideup\"\r\n                class=\"menu-option flex align-items-center {{!expandMenu ? 'justify-content-center' : 'justify-content-between'}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n                [tooltipPosition]=\"'right'\"\r\n                [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n                (click)=\"!expandMenu ? expandMenu = !expandMenu : ''\"\r\n              >\r\n                <div class=\"flex flex-row align-items-center\">\r\n\r\n                  <i\r\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}} icon-hover-color\"\r\n                    *ngIf=\"menu.icone && menu.icone !== ''\"\r\n                    [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n                  >\r\n                    {{ menu.icone }}\r\n                  </i>\r\n                  <span\r\n                    class=\"text-base text-blue-900 font-medium\"\r\n                    *ngIf=\"expandMenu\"\r\n                  >{{ menu.descricaomenu }}</span>\r\n                </div>\r\n                <i\r\n                  class=\"pi pi-chevron-down text-blue-900 mr-1 icon-hover-color\"\r\n                  *ngIf=\"expandMenu\"\r\n                  [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\r\n                ></i>\r\n              </a>\r\n\r\n              <!-- filhos -->\r\n              <div\r\n                class=\"list-none py-0 pl-3 pr-0 m-0 hidden overflow-y-hidden transition-all transition-duration-400 transition-ease-in-out\"\r\n              >\r\n          <li *ngFor=\"\r\n              let filho of retornarMenuFilhos(menu.idsistema, menu.idmenu);  let iFilho = index\r\n            \">\r\n            <a\r\n              (mouseenter)=\"onMouseFilhoEnter(filho.idmenu)\"\r\n              (mouseleave)=\"onMouseLeave()\"\r\n              [ngClass]=\"{'hover-color': mouseOverFilhoIndex === filho.idmenu}\"\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"callRoute(filho.link)\"\r\n              pRipple\r\n              class=\"{{verificarPaginaSelecionada(filho.link) ? 'bg-green-600' : ''}} menu-option flex align-items-center no-underline cursor-pointer border-round text-700 hover:bg-green-600 transition-duration-150 transition-colors p-ripple p-2\"\r\n            >\r\n              <i\r\n                class=\"pi pi-chart-line mr-2 ml-1 adjust-icon-menu\"\r\n                *ngIf=\"filho.icone && filho.icone !== ''\"\r\n              ></i>\r\n              <span\r\n                class=\"text-base text-blue-900 ml-4 {{verificarPaginaSelecionada(filho.link) ? 'text-white' : ''}}\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ filho.descricaomenu }}</span>\r\n            </a>\r\n          </li>\r\n        </div>\r\n      </div>\r\n</div>\r\n</div>\r\n</ng-template>\r\n</p-sidebar>\r\n\r\n\r\n<div\r\n  class=\"w-auto h-screen page-content overflow-y-hidden\"\r\n  id=\"page-content\"\r\n>\r\n\r\n  <div class=\"flex flex-row align-items-center justify-content-between m-3\">\r\n    <div>\r\n      <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">{{breadCrumbItems[breadCrumbItems.length -\r\n        1]?.label}}</p>\r\n      <p-breadcrumb\r\n        *ngIf=\"widthCard > 400\"\r\n        styleClass=\"border-none p-0 flex align-items-center h-2rem !important;\"\r\n        [model]=\"breadCrumbItems\"\r\n        [style]=\"{backgroundColor: '#d4d3d3'}\"\r\n        (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n      ></p-breadcrumb>\r\n    </div>\r\n\r\n    <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n\r\n      <p-button\r\n        styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n        icon=\"pi pi-th-large\"\r\n        [rounded]=\"true\"\r\n        [text]=\"true\"\r\n        (click)=\"sistemasPanel.toggle($event)\"\r\n        [pTooltip]=\"'Sistemas'\"\r\n        [tooltipPosition]=\"'left'\"\r\n      ></p-button>\r\n\r\n      <p-button\r\n        styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n        icon=\"pi pi-user\"\r\n        [rounded]=\"true\"\r\n        [text]=\"true\"\r\n        [pTooltip]=\"'Menu do Usuário'\"\r\n        [tooltipPosition]=\"'left'\"\r\n        (click)=\"meusDadosPanel.toggle($event)\"\r\n      ></p-button>\r\n\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p-card\r\n    class=\"card-container\"\r\n    styleClass=\"m-3 border-noround overflow-y-auto card-container\"\r\n    [style]=\"{height: heigthCard - ajustarHeigthCard() + 'px'}\"\r\n  >\r\n    <div class=\"card-container w-full\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n  </p-card>\r\n\r\n</div>\r\n\r\n\r\n<p-overlayPanel\r\n  #sistemasPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n  <ng-template pTemplate=\"container\">\r\n    <p class=\"title-style mt-3\">Sistemas</p>\r\n    <div\r\n      class=\"flex flex-row flex-wrap gap-2 align-items-center justify-content-center mt-5 mb-3\"\r\n      style=\"width: 250px; height: 100%;\"\r\n    >\r\n      <button\r\n        *ngFor=\"let menu of menuCompleto\"\r\n        pButton\r\n        pRipple\r\n        class=\"btn-sistema-2 btn-sistema hover-btn-cor-padrao remove-focus h-4rem w-4rem\"\r\n        (click)=\"definirMenusPorSistema(menu.sistema.idsistema)\"\r\n        [pTooltip]=\"menu.sistema.descricaosistema\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        {{ menu.sistema.nomesistema.charAt(0).toUpperCase() }}\r\n      </button>\r\n\r\n    </div>\r\n  </ng-template>\r\n</p-overlayPanel>\r\n\r\n<p-overlayPanel\r\n  #meusDadosPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n\r\n  <ng-template pTemplate=\"container\">\r\n\r\n    <p class=\"title-style mt-3\">Olá, {{nomeUsuario ? nomeUsuario.split(' ')[0] : 'Usuário'}} !</p>\r\n    <div class=\"mt-5 mb-3\">\r\n\r\n    </div>\r\n\r\n    <p-button\r\n      icon=\"pi pi-lock\"\r\n      label=\"Gerênciar KeevoPass\"\r\n      (onClick)=\"gerenciarKeePass($event)\"\r\n      styleClass=\"border-noround w-full text-blue-900\"\r\n      [text]=\"true\"\r\n      [disabled]=\"true\"\r\n    ></p-button>\r\n    <p-button\r\n      icon=\"pi pi-sign-out\"\r\n      label=\"Sair\"\r\n      (onClick)=\"sair($event)\"\r\n      styleClass=\"border-noround w-full text-blue-900\"\r\n      [text]=\"true\"\r\n    ></p-button>\r\n  </ng-template>\r\n\r\n</p-overlayPanel>\r\n\r\n<p-dialog\r\n  [(visible)]=\"visibleDialogLicenca\"\r\n  [modal]=\"true\"\r\n  [draggable]=\"false\"\r\n  header=\"Trocar Licença\"\r\n  [style]=\"{width: '50vh' }\"\r\n>\r\n  <div class=\"flex flex-column align-items-end\">\r\n\r\n    <div class=\"w-full\">\r\n      <p-dropdown\r\n        styleClass=\"w-full\"\r\n        [options]=\"licencasOptions\"\r\n        [(ngModel)]=\"licencaSelected\"\r\n        optionLabel=\"descricao\"\r\n      ></p-dropdown>\r\n    </div>\r\n\r\n    <kv-button-success\r\n      [label]=\"'Salvar'\"\r\n      class=\"mt-2\"\r\n      (onClick)=\"setLicenca()\"\r\n    ></kv-button-success>\r\n\r\n  </div>\r\n\r\n</p-dialog>"]}
|
|
@@ -64,6 +64,8 @@ export class TreetableComponent {
|
|
|
64
64
|
const opacity = baseOpacity - (rowNode.level / maxLevels);
|
|
65
65
|
return `border-left: solid 4px rgba(59, 110, 158, ${opacity}) !important;`;
|
|
66
66
|
}
|
|
67
|
+
if (rowNode.level == 0)
|
|
68
|
+
return 'border-left: none !important; border-right: none !important';
|
|
67
69
|
return '';
|
|
68
70
|
}
|
|
69
71
|
alignColunasHeader(col) {
|
|
@@ -157,12 +159,17 @@ export class TreetableComponent {
|
|
|
157
159
|
// if (array.find((x: any) => x == 'ng-star-inserted') != undefined)
|
|
158
160
|
this.doubleClickEvent.emit(eventDoubleClick);
|
|
159
161
|
}
|
|
162
|
+
isDisabledCheckbox(rowData, rowNode) {
|
|
163
|
+
return this.config.disableControlCheckboxFunction
|
|
164
|
+
? this.config.disableControlCheckboxFunction(rowData, rowNode)
|
|
165
|
+
: false;
|
|
166
|
+
}
|
|
160
167
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreetableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
161
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TreetableComponent, selector: "kv-tree-table", inputs: { config: "config", dataSource: "dataSource", gridLines: "gridLines", acoesLinhaTabela: "acoesLinhaTabela" }, outputs: { onFilter: "onFilter", onPaginate: "onPaginate", onActiveItem: "onActiveItem", onActiveItemLote: "onActiveItemLote", doubleClickEvent: "doubleClickEvent" }, host: { listeners: { "window:resize": "onWindowResize($event)" } }, ngImport: i0, template: "<div class=\"m-3\">\r\n <p-treeTable\r\n #tt\r\n [value]=\"dataSource\"\r\n [columns]=\"config.columns\"\r\n [resizableColumns]=\"true\"\r\n [tableStyle]=\"{'min-width': '50rem'}\"\r\n [resizableColumns]=\"true\"\r\n [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n >\r\n\r\n <ng-template\r\n pTemplate=\"caption\"\r\n *ngIf=\"config.enableCation\"\r\n >\r\n <div\r\n class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\">\r\n <div class=\"col-12 flex flex-column\">\r\n <div\r\n *ngIf=\"config.title\"\r\n class=\"text-md font-bold my-3\"\r\n >\r\n {{ config.title }}\r\n </div>\r\n <div\r\n *ngIf=\"config.subtitle\"\r\n class=\"text-sm mb-4 font-medium\"\r\n >\r\n {{ config.subtitle }}\r\n </div>\r\n </div>\r\n\r\n <div [class]=\"\r\n tamanhoTela < 768\r\n ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n \">\r\n\r\n <span\r\n *ngIf=\"config.enableFilter\"\r\n class=\"p-input-icon-left\"\r\n >\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(tt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2.5rem\"\r\n />\r\n </span>\r\n\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n <div\r\n *ngFor=\"let action of config.actionsLote\"\r\n class=\"btns-options\"\r\n >\r\n <button\r\n id=\"actionLoteBtns\"\r\n pButton\r\n *ngIf=\"\r\n (selectedItems.length > 0 || action.showAcoesLote) &&\r\n exibirCampo(action, this.action)\r\n \"\r\n class=\"actionLoteBtns p-button-raised p-button-text\"\r\n (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n [tooltipPosition]=\"'bottom'\"\r\n [style.backgroundColor]=\"\r\n retornarCampo(action, selectedItems, 'btnColor')\r\n \"\r\n [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n [style.color]=\"\r\n retornarCampo(action, selectedItems, 'iconBtnColor')\r\n \"\r\n >\r\n {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n </span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns; index as i\"\r\n [ttSortableColumn]=\"col.field\"\r\n [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n class=\"text-sm\"\r\n [style.width]=\"col.width\"\r\n >\r\n <div>\r\n <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n <div *ngIf=\"i == 0 && config.enableSelect\">\r\n <p-treeTableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"></p-treeTableHeaderCheckbox>\r\n </div>\r\n\r\n <div\r\n [class]=\"\r\n centralizarColunas(col) && alignColunasHeader(col) == ''\r\n ? 'flex flex-row justify-content-center'\r\n : 'flex flex-row'\r\n \"\r\n [style]=\"alignColunasHeader(col)\"\r\n >\r\n <span>{{ col.header }}</span>\r\n <p-sortIcon\r\n *ngIf=\"col.sortable === true\"\r\n [field]=\"col.field\"\r\n style=\"font-size: 10px\"\r\n ></p-sortIcon>\r\n\r\n <span\r\n *ngIf=\"col.headerTooltip\"\r\n class=\"material-symbols-outlined flex align-items-center\"\r\n [pTooltip]=\"col.headerTooltip\"\r\n >info</span>\r\n </div>\r\n </div>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns\"\r\n ttResizableColumn\r\n [style.width]=\"col.width\"\r\n [style]=\"col.centralize ? 'text-align: center;' : ''\"\r\n >\r\n {{ col.header }} <br>\r\n </th>\r\n\r\n <th\r\n [style.width]=\"5\"\r\n *ngIf=\"config.actions.length > 0\"\r\n ></th>\r\n </tr>\r\n </ng-template>\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-rowNode\r\n let-rowData=\"rowData\"\r\n let-columns=\"columns\"\r\n >\r\n <tr\r\n [ttRow]=\"rowNode\"\r\n (dblclick)=\"doubleClick($event, rowData)\"\r\n >\r\n <td\r\n *ngFor=\"let col of columns; let i = index\"\r\n [style]=\"returnStyleRow(col, rowNode)\"\r\n [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n [style.left.px]=\"rowNode.level !== 0 ? rowNode.level*30 : null\"\r\n >\r\n\r\n <div class=\"flex flex-row {{col.boolean ? 'justify-content-center' : '' }}\">\r\n <p-treeTableToggler\r\n [rowNode]=\"rowNode\"\r\n *ngIf=\"i === 0\"\r\n ></p-treeTableToggler>\r\n\r\n\r\n <div class=\"flex flex-row align-items-center\">\r\n <div class=\"flex flex-row align-items-center justify-content-center\">\r\n\r\n <i\r\n *ngIf=\"col.boolean\"\r\n class=\"pi {{rowData[col.field] ? 'pi-check text-green-300' : ''}}\"\r\n style=\"font-size: 1.1rem;\"\r\n ></i>\r\n\r\n\r\n <div class=\"flex flex-column\">\r\n <span class=\"m-0\">{{ rowData[col.field] }}</span>\r\n\r\n <p\r\n *ngIf=\"col.subtitle\"\r\n class=\"m-0 text-xs font-semibold\"\r\n >{{rowData[col.subtitle]}}</p>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </td>\r\n\r\n <td>\r\n\r\n <div *ngIf=\"config.actions.length > 0 && validateActionPosition(rowNode)\">\r\n <div *ngFor=\"let action of config.actions\">\r\n\r\n <p-button\r\n *ngIf=\"acoesLinhaTabela\"\r\n icon=\"pi {{action.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"action.severity ? action.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"action.command($event)\"\r\n ></p-button>\r\n\r\n <span\r\n *ngIf=\"!acoesLinhaTabela\"\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 20px\"\r\n (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <div *ngFor=\"let action of config.actions\">\r\n {{ criarMenusModal(rowData) }}\r\n </div>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-menu>\r\n\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"config.actionsPai?.length > 0 && rowNode.level == 0\">\r\n\r\n <div *ngFor=\"let actionPai of config.actionsPai\">\r\n\r\n <p-button\r\n icon=\"pi {{actionPai.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"actionPai.severity ? actionPai.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"actionPai.command($event)\"\r\n ></p-button>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n\r\n\r\n </td>\r\n\r\n </tr>\r\n </ng-template>\r\n\r\n </p-treeTable>\r\n</div>", styles: ["@charset \"UTF-8\";:host ::ng-deep .p-treetable table{border-spacing:0 3px}#botaoFiltro:hover{color:#d4d4d4}:host ::ng-deep .p-treetable .p-treetable-header{background-color:#d1d1d1;padding:2px 0 0!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{background-color:#eaeaea;padding:.5rem!important;margin-bottom:-5px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{padding:.5rem!important}:host ::ng-deep .p-treetable .p-treetable-thead{border-spacing:0 1px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:first-of-type{background-color:#eaeaea;padding:.5rem!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:last-child{background-color:#eaeaea;padding:.5rem!important;border-radius:0 5px 5px 0!important;-webkit-border-radius:0 5px 5px 0!important;-moz-border-radius:0 5px 5px 0!important;-ms-border-radius:0 5px 5px 0!important;-o-border-radius:0 5px 5px 0!important}:host ::ng-deep .p-treetable-scrollable-header-box{padding:0!important}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th{background-color:#f2f2f2}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:first-of-type{border-radius:5px 0 0 5px}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:last-child{border-radius:0 5px 5px 0}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{border-bottom:1px solid #ddd!important;border-top:1px solid #ddd!important}:host ::ng-deep #tr-style{border-left:solid 4px #5289B4!important;border-radius:10px!important;display:block}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:first-of-type{border-left:solid 4px #5289B4!important;border-right:none!important;border-radius:10px 0 0 10px!important;-webkit-border-radius:10px 0 0 10px!important;-moz-border-radius:10px 0 0 10px!important;-ms-border-radius:10px 0 0 10px!important;-o-border-radius:10px 0 0 10px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:last-child{border-radius:0 10px 10px 0!important;border-right:1px solid #ddd!important;-webkit-border-radius:0 10px 10px 0!important;-moz-border-radius:0 10px 10px 0!important;-ms-border-radius:0 10px 10px 0!important;-o-border-radius:0 10px 10px 0!important}:host ::ng-deep .actionBtns,:host ::ng-deep .actionLoteBtns{border-radius:50%;box-shadow:#0000003d 0 3px 8px;width:2.5rem!important;height:2.5rem!important;display:flex;align-items:center;justify-content:center}:host ::ng-deep .p-treetable table{border-collapse:separate!important;table-layout:auto!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i3.AutoFocus, selector: "[pAutoFocus]", inputs: ["autofocus"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "size", "style", "styleClass", "badgeClass", "ariaLabel"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i5.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i6.InputText, selector: "[pInputText]" }, { kind: "component", type: i7.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaLabel", "ariaLabelledBy", "id", "tabindex"], outputs: ["onShow", "onHide", "onBlur", "onFocus"] }, { kind: "component", type: i8.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i9.TreeTable, selector: "p-treeTable", inputs: ["columns", "style", "styleClass", "tableStyle", "tableStyleClass", "autoLayout", "lazy", "lazyLoadOnInit", "paginator", "rows", "first", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "customSort", "selectionMode", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "compareSelectionBy", "rowHover", "loading", "loadingIcon", "showLoader", "scrollable", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "frozenColumns", "resizableColumns", "columnResizeMode", "reorderableColumns", "contextMenu", "rowTrackBy", "filters", "globalFilterFields", "filterDelay", "filterMode", "filterLocale", "paginatorLocale", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "value", "virtualRowHeight"], outputs: ["selectionChange", "contextMenuSelectionChange", "onFilter", "onNodeExpand", "onNodeCollapse", "onPage", "onSort", "onLazyLoad", "sortFunction", "onColResize", "onColReorder", "onNodeSelect", "onNodeUnselect", "onContextMenuSelect", "onHeaderCheckboxToggle", "onEditInit", "onEditComplete", "onEditCancel"] }, { kind: "component", type: i9.TreeTableToggler, selector: "p-treeTableToggler", inputs: ["rowNode"] }, { kind: "directive", type: i9.TTSortableColumn, selector: "[ttSortableColumn]", inputs: ["ttSortableColumn", "ttSortableColumnDisabled"] }, { kind: "directive", type: i9.TTResizableColumn, selector: "[ttResizableColumn]", inputs: ["ttResizableColumnDisabled"] }, { kind: "directive", type: i9.TTRow, selector: "[ttRow]", inputs: ["ttRow"] }, { kind: "component", type: i9.TTHeaderCheckbox, selector: "p-treeTableHeaderCheckbox" }] }); }
|
|
168
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TreetableComponent, selector: "kv-tree-table", inputs: { config: "config", dataSource: "dataSource", gridLines: "gridLines", acoesLinhaTabela: "acoesLinhaTabela" }, outputs: { onFilter: "onFilter", onPaginate: "onPaginate", onActiveItem: "onActiveItem", onActiveItemLote: "onActiveItemLote", doubleClickEvent: "doubleClickEvent" }, host: { listeners: { "window:resize": "onWindowResize($event)" } }, ngImport: i0, template: "<div class=\"m-3\">\r\n <p-treeTable\r\n #tt\r\n [value]=\"dataSource\"\r\n [columns]=\"config.columns\"\r\n [resizableColumns]=\"true\"\r\n [tableStyle]=\"{'min-width': '50rem'}\"\r\n [resizableColumns]=\"true\"\r\n [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n >\r\n\r\n <ng-template\r\n pTemplate=\"caption\"\r\n *ngIf=\"config.enableCation\"\r\n >\r\n <div\r\n class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\">\r\n <div class=\"col-12 flex flex-column\">\r\n <div\r\n *ngIf=\"config.title\"\r\n class=\"text-md font-bold my-3\"\r\n >\r\n {{ config.title }}\r\n </div>\r\n <div\r\n *ngIf=\"config.subtitle\"\r\n class=\"text-sm mb-4 font-medium\"\r\n >\r\n {{ config.subtitle }}\r\n </div>\r\n </div>\r\n\r\n <div [class]=\"\r\n tamanhoTela < 768\r\n ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n \">\r\n\r\n <span\r\n *ngIf=\"config.enableFilter\"\r\n class=\"p-input-icon-left\"\r\n >\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(tt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2.5rem\"\r\n />\r\n </span>\r\n\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n <div\r\n *ngFor=\"let action of config.actionsLote\"\r\n class=\"btns-options\"\r\n >\r\n <button\r\n id=\"actionLoteBtns\"\r\n pButton\r\n *ngIf=\"\r\n (selectedItems.length > 0 || action.showAcoesLote) &&\r\n exibirCampo(action, this.action)\r\n \"\r\n class=\"actionLoteBtns p-button-raised p-button-text\"\r\n (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n [tooltipPosition]=\"'bottom'\"\r\n [style.backgroundColor]=\"\r\n retornarCampo(action, selectedItems, 'btnColor')\r\n \"\r\n [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n [style.color]=\"\r\n retornarCampo(action, selectedItems, 'iconBtnColor')\r\n \"\r\n >\r\n {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n </span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns; index as i\"\r\n [ttSortableColumn]=\"col.field\"\r\n [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n class=\"text-sm\"\r\n [style.width]=\"col.width\"\r\n >\r\n <div>\r\n <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n <div *ngIf=\"i == 0 && config.enableSelect\">\r\n <p-treeTableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"></p-treeTableHeaderCheckbox>\r\n </div>\r\n\r\n <div\r\n [class]=\"\r\n centralizarColunas(col) && alignColunasHeader(col) == ''\r\n ? 'flex flex-row justify-content-center'\r\n : 'flex flex-row'\r\n \"\r\n [style]=\"alignColunasHeader(col)\"\r\n >\r\n <span>{{ col.header }}</span>\r\n <p-sortIcon\r\n *ngIf=\"col.sortable === true\"\r\n [field]=\"col.field\"\r\n style=\"font-size: 10px\"\r\n ></p-sortIcon>\r\n\r\n <span\r\n *ngIf=\"col.headerTooltip\"\r\n class=\"material-symbols-outlined flex align-items-center\"\r\n [pTooltip]=\"col.headerTooltip\"\r\n >info</span>\r\n </div>\r\n </div>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns\"\r\n ttResizableColumn\r\n [style.width]=\"col.width\"\r\n [style]=\"col.centralize ? 'text-align: center;' : ''\"\r\n >\r\n {{ col.header }} <br>\r\n </th>\r\n\r\n <th\r\n [style.width]=\"5\"\r\n *ngIf=\"config.actions.length > 0\"\r\n ></th>\r\n </tr>\r\n </ng-template>\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-rowNode\r\n let-rowData=\"rowData\"\r\n let-columns=\"columns\"\r\n >\r\n <tr\r\n [ttRow]=\"rowNode\"\r\n (dblclick)=\"doubleClick($event, rowData)\"\r\n >\r\n <td\r\n *ngFor=\"let col of columns; let i = index\"\r\n [style]=\"returnStyleRow(col, rowNode)\"\r\n [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n [style.left.px]=\"rowNode.level !== 0 ? rowNode.level*30 : null\"\r\n >\r\n\r\n <div class=\"flex flex-row {{col.boolean ? 'justify-content-center' : '' }}\">\r\n <div\r\n class=\"w-full-h-full flex align-items-center\"\r\n *ngIf=\"i == 0\"\r\n >\r\n <p-treeTableCheckbox\r\n [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n [value]=\"rowNode\"\r\n *ngIf=\"config.enableSelect == true\"\r\n ></p-treeTableCheckbox>\r\n\r\n <p-treeTableToggler\r\n class=\"hiddenVisible\"\r\n [rowNode]=\"rowNode\"\r\n ></p-treeTableToggler>\r\n <!-- \r\n <p-treeTableToggler\r\n [rowNode]=\"rowNode\"\r\n *ngIf=\"!rightCollapse\"\r\n ></p-treeTableToggler>\r\n <p-treeTableToggler\r\n class=\"hiddenVisible\"\r\n [rowNode]=\"rowNode\"\r\n *ngIf=\"rightCollapse\"\r\n ></p-treeTableToggler> -->\r\n </div>\r\n\r\n\r\n <div class=\"flex flex-row align-items-center\">\r\n <div class=\"flex flex-row align-items-center justify-content-center\">\r\n\r\n <i\r\n *ngIf=\"col.boolean\"\r\n class=\"pi {{rowData[col.field] ? 'pi-check text-green-300' : ''}}\"\r\n style=\"font-size: 1.1rem;\"\r\n ></i>\r\n\r\n\r\n <div\r\n class=\"flex flex-column\"\r\n *ngIf=\"!col.boolean\"\r\n >\r\n <span class=\"m-0\">{{ rowData[col.field] }}</span>\r\n\r\n <p\r\n *ngIf=\"col.subtitle\"\r\n class=\"m-0 text-xs font-semibold\"\r\n >{{rowData[col.subtitle]}}</p>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </td>\r\n\r\n <td style=\"border-left: none;\">\r\n\r\n <div *ngIf=\"config.actions.length > 0 && validateActionPosition(rowNode)\">\r\n <div\r\n *ngFor=\"let action of config.actions\"\r\n class=\"flex justify-content-center\"\r\n >\r\n\r\n <p-button\r\n *ngIf=\"acoesLinhaTabela\"\r\n icon=\"pi {{action.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"action.severity ? action.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"action.command($event)\"\r\n ></p-button>\r\n\r\n <span\r\n *ngIf=\"!acoesLinhaTabela\"\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 22px\"\r\n (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <div *ngFor=\"let action of config.actions\">\r\n {{ criarMenusModal(rowData) }}\r\n </div>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-menu>\r\n\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"config.actionsPai?.length > 0 && rowNode.level == 0\">\r\n\r\n <div\r\n *ngFor=\"let actionPai of config.actionsPai\"\r\n class=\"flex justify-content-end\"\r\n >\r\n\r\n <p-button\r\n icon=\"pi {{actionPai.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"actionPai.severity ? actionPai.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"actionPai.command($event)\"\r\n ></p-button>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n </td>\r\n\r\n </tr>\r\n </ng-template>\r\n\r\n </p-treeTable>\r\n</div>", styles: ["@charset \"UTF-8\";:host ::ng-deep .p-treetable table{border-spacing:0 3px}#botaoFiltro:hover{color:#d4d4d4}:host ::ng-deep .p-treetable .p-treetable-header{background-color:#d1d1d1;padding:2px 0 0!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{background-color:#eaeaea;padding:.5rem!important;margin-bottom:-5px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{padding:.5rem!important}:host ::ng-deep .p-treetable .p-treetable-thead{border-spacing:0 1px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:first-of-type{background-color:#eaeaea;padding:.5rem!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:last-child{background-color:#eaeaea;padding:.5rem!important;border-radius:0 5px 5px 0!important;-webkit-border-radius:0 5px 5px 0!important;-moz-border-radius:0 5px 5px 0!important;-ms-border-radius:0 5px 5px 0!important;-o-border-radius:0 5px 5px 0!important}:host ::ng-deep .p-treetable-scrollable-header-box{padding:0!important}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th{background-color:#f2f2f2}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:first-of-type{border-radius:5px 0 0 5px}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:last-child{border-radius:0 5px 5px 0}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{border-bottom:1px solid #ddd!important;border-top:1px solid #ddd!important}:host ::ng-deep #tr-style{border-left:solid 4px #5289B4!important;border-radius:10px!important;display:block}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:first-of-type{border-left:solid 4px #5289B4!important;border-right:none!important;border-radius:10px 0 0 10px!important;-webkit-border-radius:10px 0 0 10px!important;-moz-border-radius:10px 0 0 10px!important;-ms-border-radius:10px 0 0 10px!important;-o-border-radius:10px 0 0 10px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:last-child{border-radius:0 10px 10px 0!important;border-right:1px solid #ddd!important;-webkit-border-radius:0 10px 10px 0!important;-moz-border-radius:0 10px 10px 0!important;-ms-border-radius:0 10px 10px 0!important;-o-border-radius:0 10px 10px 0!important}:host ::ng-deep .actionBtns,:host ::ng-deep .actionLoteBtns{border-radius:50%;box-shadow:#0000003d 0 3px 8px;width:2.5rem!important;height:2.5rem!important;display:flex;align-items:center;justify-content:center}:host ::ng-deep .p-treetable table{border-collapse:separate!important;table-layout:auto!important}.icon-more-horiz:hover,.icon-more-horiz:focus{color:#5e5e5e;transform:scale(1.1);transition:color .3s,transform .3s}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i3.AutoFocus, selector: "[pAutoFocus]", inputs: ["autofocus"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "size", "style", "styleClass", "badgeClass", "ariaLabel"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i5.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i6.InputText, selector: "[pInputText]" }, { kind: "component", type: i7.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaLabel", "ariaLabelledBy", "id", "tabindex"], outputs: ["onShow", "onHide", "onBlur", "onFocus"] }, { kind: "component", type: i8.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i9.TreeTable, selector: "p-treeTable", inputs: ["columns", "style", "styleClass", "tableStyle", "tableStyleClass", "autoLayout", "lazy", "lazyLoadOnInit", "paginator", "rows", "first", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "customSort", "selectionMode", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "compareSelectionBy", "rowHover", "loading", "loadingIcon", "showLoader", "scrollable", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "frozenColumns", "resizableColumns", "columnResizeMode", "reorderableColumns", "contextMenu", "rowTrackBy", "filters", "globalFilterFields", "filterDelay", "filterMode", "filterLocale", "paginatorLocale", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "value", "virtualRowHeight"], outputs: ["selectionChange", "contextMenuSelectionChange", "onFilter", "onNodeExpand", "onNodeCollapse", "onPage", "onSort", "onLazyLoad", "sortFunction", "onColResize", "onColReorder", "onNodeSelect", "onNodeUnselect", "onContextMenuSelect", "onHeaderCheckboxToggle", "onEditInit", "onEditComplete", "onEditCancel"] }, { kind: "component", type: i9.TreeTableToggler, selector: "p-treeTableToggler", inputs: ["rowNode"] }, { kind: "directive", type: i9.TTSortableColumn, selector: "[ttSortableColumn]", inputs: ["ttSortableColumn", "ttSortableColumnDisabled"] }, { kind: "directive", type: i9.TTResizableColumn, selector: "[ttResizableColumn]", inputs: ["ttResizableColumnDisabled"] }, { kind: "directive", type: i9.TTRow, selector: "[ttRow]", inputs: ["ttRow"] }, { kind: "component", type: i9.TTCheckbox, selector: "p-treeTableCheckbox", inputs: ["disabled", "value"] }, { kind: "component", type: i9.TTHeaderCheckbox, selector: "p-treeTableHeaderCheckbox" }] }); }
|
|
162
169
|
}
|
|
163
170
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TreetableComponent, decorators: [{
|
|
164
171
|
type: Component,
|
|
165
|
-
args: [{ selector: 'kv-tree-table', template: "<div class=\"m-3\">\r\n <p-treeTable\r\n #tt\r\n [value]=\"dataSource\"\r\n [columns]=\"config.columns\"\r\n [resizableColumns]=\"true\"\r\n [tableStyle]=\"{'min-width': '50rem'}\"\r\n [resizableColumns]=\"true\"\r\n [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n >\r\n\r\n <ng-template\r\n pTemplate=\"caption\"\r\n *ngIf=\"config.enableCation\"\r\n >\r\n <div\r\n class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\">\r\n <div class=\"col-12 flex flex-column\">\r\n <div\r\n *ngIf=\"config.title\"\r\n class=\"text-md font-bold my-3\"\r\n >\r\n {{ config.title }}\r\n </div>\r\n <div\r\n *ngIf=\"config.subtitle\"\r\n class=\"text-sm mb-4 font-medium\"\r\n >\r\n {{ config.subtitle }}\r\n </div>\r\n </div>\r\n\r\n <div [class]=\"\r\n tamanhoTela < 768\r\n ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n \">\r\n\r\n <span\r\n *ngIf=\"config.enableFilter\"\r\n class=\"p-input-icon-left\"\r\n >\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(tt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2.5rem\"\r\n />\r\n </span>\r\n\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n <div\r\n *ngFor=\"let action of config.actionsLote\"\r\n class=\"btns-options\"\r\n >\r\n <button\r\n id=\"actionLoteBtns\"\r\n pButton\r\n *ngIf=\"\r\n (selectedItems.length > 0 || action.showAcoesLote) &&\r\n exibirCampo(action, this.action)\r\n \"\r\n class=\"actionLoteBtns p-button-raised p-button-text\"\r\n (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n [tooltipPosition]=\"'bottom'\"\r\n [style.backgroundColor]=\"\r\n retornarCampo(action, selectedItems, 'btnColor')\r\n \"\r\n [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n [style.color]=\"\r\n retornarCampo(action, selectedItems, 'iconBtnColor')\r\n \"\r\n >\r\n {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n </span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns; index as i\"\r\n [ttSortableColumn]=\"col.field\"\r\n [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n class=\"text-sm\"\r\n [style.width]=\"col.width\"\r\n >\r\n <div>\r\n <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n <div *ngIf=\"i == 0 && config.enableSelect\">\r\n <p-treeTableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"></p-treeTableHeaderCheckbox>\r\n </div>\r\n\r\n <div\r\n [class]=\"\r\n centralizarColunas(col) && alignColunasHeader(col) == ''\r\n ? 'flex flex-row justify-content-center'\r\n : 'flex flex-row'\r\n \"\r\n [style]=\"alignColunasHeader(col)\"\r\n >\r\n <span>{{ col.header }}</span>\r\n <p-sortIcon\r\n *ngIf=\"col.sortable === true\"\r\n [field]=\"col.field\"\r\n style=\"font-size: 10px\"\r\n ></p-sortIcon>\r\n\r\n <span\r\n *ngIf=\"col.headerTooltip\"\r\n class=\"material-symbols-outlined flex align-items-center\"\r\n [pTooltip]=\"col.headerTooltip\"\r\n >info</span>\r\n </div>\r\n </div>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns\"\r\n ttResizableColumn\r\n [style.width]=\"col.width\"\r\n [style]=\"col.centralize ? 'text-align: center;' : ''\"\r\n >\r\n {{ col.header }} <br>\r\n </th>\r\n\r\n <th\r\n [style.width]=\"5\"\r\n *ngIf=\"config.actions.length > 0\"\r\n ></th>\r\n </tr>\r\n </ng-template>\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-rowNode\r\n let-rowData=\"rowData\"\r\n let-columns=\"columns\"\r\n >\r\n <tr\r\n [ttRow]=\"rowNode\"\r\n (dblclick)=\"doubleClick($event, rowData)\"\r\n >\r\n <td\r\n *ngFor=\"let col of columns; let i = index\"\r\n [style]=\"returnStyleRow(col, rowNode)\"\r\n [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n [style.left.px]=\"rowNode.level !== 0 ? rowNode.level*30 : null\"\r\n >\r\n\r\n <div class=\"flex flex-row {{col.boolean ? 'justify-content-center' : '' }}\">\r\n <p-treeTableToggler\r\n [rowNode]=\"rowNode\"\r\n *ngIf=\"i === 0\"\r\n ></p-treeTableToggler>\r\n\r\n\r\n <div class=\"flex flex-row align-items-center\">\r\n <div class=\"flex flex-row align-items-center justify-content-center\">\r\n\r\n <i\r\n *ngIf=\"col.boolean\"\r\n class=\"pi {{rowData[col.field] ? 'pi-check text-green-300' : ''}}\"\r\n style=\"font-size: 1.1rem;\"\r\n ></i>\r\n\r\n\r\n <div class=\"flex flex-column\">\r\n <span class=\"m-0\">{{ rowData[col.field] }}</span>\r\n\r\n <p\r\n *ngIf=\"col.subtitle\"\r\n class=\"m-0 text-xs font-semibold\"\r\n >{{rowData[col.subtitle]}}</p>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </td>\r\n\r\n <td>\r\n\r\n <div *ngIf=\"config.actions.length > 0 && validateActionPosition(rowNode)\">\r\n <div *ngFor=\"let action of config.actions\">\r\n\r\n <p-button\r\n *ngIf=\"acoesLinhaTabela\"\r\n icon=\"pi {{action.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"action.severity ? action.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"action.command($event)\"\r\n ></p-button>\r\n\r\n <span\r\n *ngIf=\"!acoesLinhaTabela\"\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 20px\"\r\n (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <div *ngFor=\"let action of config.actions\">\r\n {{ criarMenusModal(rowData) }}\r\n </div>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-menu>\r\n\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"config.actionsPai?.length > 0 && rowNode.level == 0\">\r\n\r\n <div *ngFor=\"let actionPai of config.actionsPai\">\r\n\r\n <p-button\r\n icon=\"pi {{actionPai.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"actionPai.severity ? actionPai.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"actionPai.command($event)\"\r\n ></p-button>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n\r\n\r\n </td>\r\n\r\n </tr>\r\n </ng-template>\r\n\r\n </p-treeTable>\r\n</div>", styles: ["@charset \"UTF-8\";:host ::ng-deep .p-treetable table{border-spacing:0 3px}#botaoFiltro:hover{color:#d4d4d4}:host ::ng-deep .p-treetable .p-treetable-header{background-color:#d1d1d1;padding:2px 0 0!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{background-color:#eaeaea;padding:.5rem!important;margin-bottom:-5px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{padding:.5rem!important}:host ::ng-deep .p-treetable .p-treetable-thead{border-spacing:0 1px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:first-of-type{background-color:#eaeaea;padding:.5rem!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:last-child{background-color:#eaeaea;padding:.5rem!important;border-radius:0 5px 5px 0!important;-webkit-border-radius:0 5px 5px 0!important;-moz-border-radius:0 5px 5px 0!important;-ms-border-radius:0 5px 5px 0!important;-o-border-radius:0 5px 5px 0!important}:host ::ng-deep .p-treetable-scrollable-header-box{padding:0!important}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th{background-color:#f2f2f2}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:first-of-type{border-radius:5px 0 0 5px}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:last-child{border-radius:0 5px 5px 0}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{border-bottom:1px solid #ddd!important;border-top:1px solid #ddd!important}:host ::ng-deep #tr-style{border-left:solid 4px #5289B4!important;border-radius:10px!important;display:block}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:first-of-type{border-left:solid 4px #5289B4!important;border-right:none!important;border-radius:10px 0 0 10px!important;-webkit-border-radius:10px 0 0 10px!important;-moz-border-radius:10px 0 0 10px!important;-ms-border-radius:10px 0 0 10px!important;-o-border-radius:10px 0 0 10px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:last-child{border-radius:0 10px 10px 0!important;border-right:1px solid #ddd!important;-webkit-border-radius:0 10px 10px 0!important;-moz-border-radius:0 10px 10px 0!important;-ms-border-radius:0 10px 10px 0!important;-o-border-radius:0 10px 10px 0!important}:host ::ng-deep .actionBtns,:host ::ng-deep .actionLoteBtns{border-radius:50%;box-shadow:#0000003d 0 3px 8px;width:2.5rem!important;height:2.5rem!important;display:flex;align-items:center;justify-content:center}:host ::ng-deep .p-treetable table{border-collapse:separate!important;table-layout:auto!important}\n"] }]
|
|
172
|
+
args: [{ selector: 'kv-tree-table', template: "<div class=\"m-3\">\r\n <p-treeTable\r\n #tt\r\n [value]=\"dataSource\"\r\n [columns]=\"config.columns\"\r\n [resizableColumns]=\"true\"\r\n [tableStyle]=\"{'min-width': '50rem'}\"\r\n [resizableColumns]=\"true\"\r\n [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n >\r\n\r\n <ng-template\r\n pTemplate=\"caption\"\r\n *ngIf=\"config.enableCation\"\r\n >\r\n <div\r\n class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\">\r\n <div class=\"col-12 flex flex-column\">\r\n <div\r\n *ngIf=\"config.title\"\r\n class=\"text-md font-bold my-3\"\r\n >\r\n {{ config.title }}\r\n </div>\r\n <div\r\n *ngIf=\"config.subtitle\"\r\n class=\"text-sm mb-4 font-medium\"\r\n >\r\n {{ config.subtitle }}\r\n </div>\r\n </div>\r\n\r\n <div [class]=\"\r\n tamanhoTela < 768\r\n ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n \">\r\n\r\n <span\r\n *ngIf=\"config.enableFilter\"\r\n class=\"p-input-icon-left\"\r\n >\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(tt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2.5rem\"\r\n />\r\n </span>\r\n\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n <div\r\n *ngFor=\"let action of config.actionsLote\"\r\n class=\"btns-options\"\r\n >\r\n <button\r\n id=\"actionLoteBtns\"\r\n pButton\r\n *ngIf=\"\r\n (selectedItems.length > 0 || action.showAcoesLote) &&\r\n exibirCampo(action, this.action)\r\n \"\r\n class=\"actionLoteBtns p-button-raised p-button-text\"\r\n (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n [tooltipPosition]=\"'bottom'\"\r\n [style.backgroundColor]=\"\r\n retornarCampo(action, selectedItems, 'btnColor')\r\n \"\r\n [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n [style.color]=\"\r\n retornarCampo(action, selectedItems, 'iconBtnColor')\r\n \"\r\n >\r\n {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n </span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns; index as i\"\r\n [ttSortableColumn]=\"col.field\"\r\n [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n class=\"text-sm\"\r\n [style.width]=\"col.width\"\r\n >\r\n <div>\r\n <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n <div *ngIf=\"i == 0 && config.enableSelect\">\r\n <p-treeTableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"></p-treeTableHeaderCheckbox>\r\n </div>\r\n\r\n <div\r\n [class]=\"\r\n centralizarColunas(col) && alignColunasHeader(col) == ''\r\n ? 'flex flex-row justify-content-center'\r\n : 'flex flex-row'\r\n \"\r\n [style]=\"alignColunasHeader(col)\"\r\n >\r\n <span>{{ col.header }}</span>\r\n <p-sortIcon\r\n *ngIf=\"col.sortable === true\"\r\n [field]=\"col.field\"\r\n style=\"font-size: 10px\"\r\n ></p-sortIcon>\r\n\r\n <span\r\n *ngIf=\"col.headerTooltip\"\r\n class=\"material-symbols-outlined flex align-items-center\"\r\n [pTooltip]=\"col.headerTooltip\"\r\n >info</span>\r\n </div>\r\n </div>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template\r\n pTemplate=\"header\"\r\n let-columns\r\n >\r\n <tr>\r\n <th\r\n *ngFor=\"let col of columns\"\r\n ttResizableColumn\r\n [style.width]=\"col.width\"\r\n [style]=\"col.centralize ? 'text-align: center;' : ''\"\r\n >\r\n {{ col.header }} <br>\r\n </th>\r\n\r\n <th\r\n [style.width]=\"5\"\r\n *ngIf=\"config.actions.length > 0\"\r\n ></th>\r\n </tr>\r\n </ng-template>\r\n <ng-template\r\n pTemplate=\"body\"\r\n let-rowNode\r\n let-rowData=\"rowData\"\r\n let-columns=\"columns\"\r\n >\r\n <tr\r\n [ttRow]=\"rowNode\"\r\n (dblclick)=\"doubleClick($event, rowData)\"\r\n >\r\n <td\r\n *ngFor=\"let col of columns; let i = index\"\r\n [style]=\"returnStyleRow(col, rowNode)\"\r\n [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n [style.left.px]=\"rowNode.level !== 0 ? rowNode.level*30 : null\"\r\n >\r\n\r\n <div class=\"flex flex-row {{col.boolean ? 'justify-content-center' : '' }}\">\r\n <div\r\n class=\"w-full-h-full flex align-items-center\"\r\n *ngIf=\"i == 0\"\r\n >\r\n <p-treeTableCheckbox\r\n [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n [value]=\"rowNode\"\r\n *ngIf=\"config.enableSelect == true\"\r\n ></p-treeTableCheckbox>\r\n\r\n <p-treeTableToggler\r\n class=\"hiddenVisible\"\r\n [rowNode]=\"rowNode\"\r\n ></p-treeTableToggler>\r\n <!-- \r\n <p-treeTableToggler\r\n [rowNode]=\"rowNode\"\r\n *ngIf=\"!rightCollapse\"\r\n ></p-treeTableToggler>\r\n <p-treeTableToggler\r\n class=\"hiddenVisible\"\r\n [rowNode]=\"rowNode\"\r\n *ngIf=\"rightCollapse\"\r\n ></p-treeTableToggler> -->\r\n </div>\r\n\r\n\r\n <div class=\"flex flex-row align-items-center\">\r\n <div class=\"flex flex-row align-items-center justify-content-center\">\r\n\r\n <i\r\n *ngIf=\"col.boolean\"\r\n class=\"pi {{rowData[col.field] ? 'pi-check text-green-300' : ''}}\"\r\n style=\"font-size: 1.1rem;\"\r\n ></i>\r\n\r\n\r\n <div\r\n class=\"flex flex-column\"\r\n *ngIf=\"!col.boolean\"\r\n >\r\n <span class=\"m-0\">{{ rowData[col.field] }}</span>\r\n\r\n <p\r\n *ngIf=\"col.subtitle\"\r\n class=\"m-0 text-xs font-semibold\"\r\n >{{rowData[col.subtitle]}}</p>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </td>\r\n\r\n <td style=\"border-left: none;\">\r\n\r\n <div *ngIf=\"config.actions.length > 0 && validateActionPosition(rowNode)\">\r\n <div\r\n *ngFor=\"let action of config.actions\"\r\n class=\"flex justify-content-center\"\r\n >\r\n\r\n <p-button\r\n *ngIf=\"acoesLinhaTabela\"\r\n icon=\"pi {{action.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"action.severity ? action.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"action.command($event)\"\r\n ></p-button>\r\n\r\n <span\r\n *ngIf=\"!acoesLinhaTabela\"\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 22px\"\r\n (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <div *ngFor=\"let action of config.actions\">\r\n {{ criarMenusModal(rowData) }}\r\n </div>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-menu>\r\n\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"config.actionsPai?.length > 0 && rowNode.level == 0\">\r\n\r\n <div\r\n *ngFor=\"let actionPai of config.actionsPai\"\r\n class=\"flex justify-content-end\"\r\n >\r\n\r\n <p-button\r\n icon=\"pi {{actionPai.icon}}\"\r\n [rounded]=\"true\"\r\n [severity]=\"actionPai.severity ? actionPai.severity : 'secondary'\"\r\n [style]=\"{width: '2rem', height: '2rem'}\"\r\n (onClick)=\"actionPai.command($event)\"\r\n ></p-button>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n </td>\r\n\r\n </tr>\r\n </ng-template>\r\n\r\n </p-treeTable>\r\n</div>", styles: ["@charset \"UTF-8\";:host ::ng-deep .p-treetable table{border-spacing:0 3px}#botaoFiltro:hover{color:#d4d4d4}:host ::ng-deep .p-treetable .p-treetable-header{background-color:#d1d1d1;padding:2px 0 0!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th{background-color:#eaeaea;padding:.5rem!important;margin-bottom:-5px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{padding:.5rem!important}:host ::ng-deep .p-treetable .p-treetable-thead{border-spacing:0 1px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:first-of-type{background-color:#eaeaea;padding:.5rem!important;border-radius:5px!important}:host ::ng-deep .p-treetable .p-treetable-thead>tr>th:last-child{background-color:#eaeaea;padding:.5rem!important;border-radius:0 5px 5px 0!important;-webkit-border-radius:0 5px 5px 0!important;-moz-border-radius:0 5px 5px 0!important;-ms-border-radius:0 5px 5px 0!important;-o-border-radius:0 5px 5px 0!important}:host ::ng-deep .p-treetable-scrollable-header-box{padding:0!important}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th{background-color:#f2f2f2}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:first-of-type{border-radius:5px 0 0 5px}:host ::ng-deep .p-treetable.p-treetable-sm .p-treetable-thead>tr>th:last-child{border-radius:0 5px 5px 0}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td{border-bottom:1px solid #ddd!important;border-top:1px solid #ddd!important}:host ::ng-deep #tr-style{border-left:solid 4px #5289B4!important;border-radius:10px!important;display:block}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:first-of-type{border-left:solid 4px #5289B4!important;border-right:none!important;border-radius:10px 0 0 10px!important;-webkit-border-radius:10px 0 0 10px!important;-moz-border-radius:10px 0 0 10px!important;-ms-border-radius:10px 0 0 10px!important;-o-border-radius:10px 0 0 10px!important}:host ::ng-deep .p-treetable .p-treetable-tbody>tr>td:last-child{border-radius:0 10px 10px 0!important;border-right:1px solid #ddd!important;-webkit-border-radius:0 10px 10px 0!important;-moz-border-radius:0 10px 10px 0!important;-ms-border-radius:0 10px 10px 0!important;-o-border-radius:0 10px 10px 0!important}:host ::ng-deep .actionBtns,:host ::ng-deep .actionLoteBtns{border-radius:50%;box-shadow:#0000003d 0 3px 8px;width:2.5rem!important;height:2.5rem!important;display:flex;align-items:center;justify-content:center}:host ::ng-deep .p-treetable table{border-collapse:separate!important;table-layout:auto!important}.icon-more-horiz:hover,.icon-more-horiz:focus{color:#5e5e5e;transform:scale(1.1);transition:color .3s,transform .3s}\n"] }]
|
|
166
173
|
}], propDecorators: { config: [{
|
|
167
174
|
type: Input
|
|
168
175
|
}], dataSource: [{
|
|
@@ -185,4 +192,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
185
192
|
type: HostListener,
|
|
186
193
|
args: ['window:resize', ['$event']]
|
|
187
194
|
}] } });
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"treetable.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/treetable/treetable.component.ts","../../../../../projects/keevo-components/src/lib/treetable/treetable.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\r\nimport { KvMenuItem } from '../api/components/table/kv-menuitem';\r\nimport { TreeTable } from 'primeng/treetable';\r\nimport { TablePaginate } from '../api/components/table/table.paginate';\r\nimport { MenuItemCommandEvent } from 'primeng/api';\r\n\r\n@Component({\r\n  selector: 'kv-tree-table',\r\n  templateUrl: './treetable.component.html',\r\n  styleUrls: ['./treetable.component.scss']\r\n})\r\nexport class TreetableComponent {\r\n\r\n  menuItems: KvMenuItem[] = [];\r\n  tamanhoTela!: number;\r\n  selectedItems: any = [];\r\n  commandEvent!: MenuItemCommandEvent;\r\n\r\n  @Input() config!: any;\r\n  @Input() dataSource!: any;\r\n  @Input() gridLines: boolean = false;\r\n  @Input() acoesLinhaTabela: boolean = false;\r\n\r\n  @Output() onFilter: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n\r\n  ngOnInit() {\r\n    this.tamanhoTela = window.innerWidth;\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.tamanhoTela = window.innerWidth;\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  public activeItemLote(rowData: any) {\r\n    this.selectedItems = rowData;\r\n    this.onActiveItemLote.emit(rowData);\r\n  }\r\n\r\n  public onGlobalFilter(table: TreeTable, event: Event) {\r\n    this.onFilter.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate($event: any) {\r\n    if ($event) {\r\n      let paginaInicial =\r\n        ($event?.first > 0 ? $event.first / $event.rows : $event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if ($event.globalFilter) termoPesquisa = $event.globalFilter;\r\n\r\n      if ($event.sortField)\r\n        ordenacao = `${$event.sortField} ${$event.sortOrder === 1 ? 'ASC' : 'DESC'\r\n          }`;\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: $event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao,\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  returnStyleRow(col: any, rowNode: any): string {\r\n    const isFirstColumn = col.field === this.config.columns[0].field;\r\n    const baseOpacity = 1;\r\n    const maxLevels = 4;\r\n\r\n    if (isFirstColumn && rowNode.level >= 0) {\r\n      const opacity = baseOpacity - (rowNode.level / maxLevels);\r\n\r\n      return `border-left: solid 4px rgba(59, 110, 158, ${opacity}) !important;`;\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  alignColunasHeader(col: any): string {\r\n    if (col.align) {\r\n      if (col.align == 'right') return 'justify-content: end';\r\n      else return '';\r\n    } else return '';\r\n  }\r\n  centralizarColunas(col: any): string {\r\n    if (col.centralize) {\r\n      return 'text-align: center; ';\r\n    } else return '';\r\n  }\r\n  alignColunas(col: any): string {\r\n    if (col.align) {\r\n      return `text-align: ${col.align}`;\r\n    } else return '';\r\n  }\r\n\r\n  criarMenusModal(data: any) {\r\n    if (this.config.actions && data) {\r\n      const items = this.config.actions.map((action: any) => {\r\n        const icon = this.retornarCampo(action, data, 'icon');\r\n        const tooltip = this.retornarCampo(action, data, 'tooltip');\r\n        const tooltipPosition = this.retornarCampo(\r\n          action,\r\n          data,\r\n          'tooltipPosition'\r\n        );\r\n        const label = this.retornarCampo(action, data, 'label');\r\n        const command: any = this.retornarCampo(action, data, 'command');\r\n        const visible: boolean = action.visible ? action.visible(data) : true;\r\n        const disabled: boolean = action.disabled\r\n          ? action.disabled(data)\r\n          : false;\r\n\r\n        const menuInsert: KvMenuItem = {\r\n          label,\r\n          icon,\r\n          tooltip,\r\n          tooltipPosition,\r\n          command,\r\n          disabled,\r\n          visible,\r\n        };\r\n\r\n        let item = this.menuItems.filter(\r\n          (x) => x.command == menuInsert.command\r\n        );\r\n\r\n        if (item.length == 0) this.menuItems.push(menuInsert);\r\n        else {\r\n          if (menuInsert.label != item[0].label) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.visible != item[0].visible) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.disabled != item[0].disabled) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  retornarCampo(action: KvMenuItem, rowData: any, field: string): string {\r\n    const _function = action.dynamicfields\r\n      ? (action.dynamicfields[field] as Function)\r\n      : null;\r\n    const _field: string = _function\r\n      ? _function.apply(action, [rowData])\r\n      : action[field];\r\n    return _field;\r\n  }\r\n\r\n  exibirCampo(field: any, rowData: any) {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n    return visible;\r\n  }\r\n\r\n  validateActionPosition(rowNode: any): boolean {\r\n    if (this.config.actionsPai && rowNode.level == 0) return false;\r\n    else return true\r\n  }\r\n\r\n\r\n  doubleClick(e: any, rowData: any) {\r\n\r\n    let eventDoubleClick = { event: e, rowData: rowData };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    // if (array.find((x: any) => x == 'ng-star-inserted') != undefined)\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n\r\n}\r\n","<div class=\"m-3\">\r\n    <p-treeTable\r\n        #tt\r\n        [value]=\"dataSource\"\r\n        [columns]=\"config.columns\"\r\n        [resizableColumns]=\"true\"\r\n        [tableStyle]=\"{'min-width': '50rem'}\"\r\n        [resizableColumns]=\"true\"\r\n        [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n        (onLazyLoad)=\"paginate($event)\"\r\n    >\r\n\r\n        <ng-template\r\n            pTemplate=\"caption\"\r\n            *ngIf=\"config.enableCation\"\r\n        >\r\n            <div\r\n                class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\">\r\n                <div class=\"col-12 flex flex-column\">\r\n                    <div\r\n                        *ngIf=\"config.title\"\r\n                        class=\"text-md font-bold my-3\"\r\n                    >\r\n                        {{ config.title }}\r\n                    </div>\r\n                    <div\r\n                        *ngIf=\"config.subtitle\"\r\n                        class=\"text-sm mb-4 font-medium\"\r\n                    >\r\n                        {{ config.subtitle }}\r\n                    </div>\r\n                </div>\r\n\r\n                <div [class]=\"\r\n            tamanhoTela < 768\r\n              ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n              : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n          \">\r\n\r\n                    <span\r\n                        *ngIf=\"config.enableFilter\"\r\n                        class=\"p-input-icon-left\"\r\n                    >\r\n                        <i class=\"pi pi-search\"></i>\r\n\r\n                        <input\r\n                            pInputText\r\n                            pAutoFocus\r\n                            [autofocus]=\"true\"\r\n                            type=\"text\"\r\n                            (input)=\"onGlobalFilter(tt, $event)\"\r\n                            placeholder=\"Pesquisar...\"\r\n                            class=\"h-2.5rem\"\r\n                        />\r\n                    </span>\r\n\r\n                </div>\r\n\r\n                <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n                    <div\r\n                        *ngFor=\"let action of config.actionsLote\"\r\n                        class=\"btns-options\"\r\n                    >\r\n                        <button\r\n                            id=\"actionLoteBtns\"\r\n                            pButton\r\n                            *ngIf=\"\r\n                (selectedItems.length > 0 || action.showAcoesLote) &&\r\n                exibirCampo(action, this.action)\r\n              \"\r\n                            class=\"actionLoteBtns p-button-raised p-button-text\"\r\n                            (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n                            [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n                            [tooltipPosition]=\"'bottom'\"\r\n                            [style.backgroundColor]=\"\r\n                retornarCampo(action, selectedItems, 'btnColor')\r\n              \"\r\n                            [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n                        >\r\n                            <span\r\n                                class=\"material-symbols-outlined md-22\"\r\n                                [style.color]=\"\r\n                  retornarCampo(action, selectedItems, 'iconBtnColor')\r\n                \"\r\n                            >\r\n                                {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n                            </span>\r\n                        </button>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </ng-template>\r\n\r\n        <ng-template\r\n            pTemplate=\"header\"\r\n            let-columns\r\n        >\r\n            <tr>\r\n                <th\r\n                    *ngFor=\"let col of columns; index as i\"\r\n                    [ttSortableColumn]=\"col.field\"\r\n                    [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n                    class=\"text-sm\"\r\n                    [style.width]=\"col.width\"\r\n                >\r\n                    <div>\r\n                        <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n                            <div *ngIf=\"i == 0 && config.enableSelect\">\r\n                                <p-treeTableHeaderCheckbox\r\n                                    (click)=\"activeItemLote(selectedItems)\"></p-treeTableHeaderCheckbox>\r\n                            </div>\r\n\r\n                            <div\r\n                                [class]=\"\r\n                    centralizarColunas(col) && alignColunasHeader(col) == ''\r\n                      ? 'flex flex-row justify-content-center'\r\n                      : 'flex flex-row'\r\n                  \"\r\n                                [style]=\"alignColunasHeader(col)\"\r\n                            >\r\n                                <span>{{ col.header }}</span>\r\n                                <p-sortIcon\r\n                                    *ngIf=\"col.sortable === true\"\r\n                                    [field]=\"col.field\"\r\n                                    style=\"font-size: 10px\"\r\n                                ></p-sortIcon>\r\n\r\n                                <span\r\n                                    *ngIf=\"col.headerTooltip\"\r\n                                    class=\"material-symbols-outlined flex align-items-center\"\r\n                                    [pTooltip]=\"col.headerTooltip\"\r\n                                >info</span>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n        </ng-template>\r\n\r\n        <ng-template\r\n            pTemplate=\"header\"\r\n            let-columns\r\n        >\r\n            <tr>\r\n                <th\r\n                    *ngFor=\"let col of columns\"\r\n                    ttResizableColumn\r\n                    [style.width]=\"col.width\"\r\n                    [style]=\"col.centralize ? 'text-align: center;' : ''\"\r\n                >\r\n                    {{ col.header }} <br>\r\n                </th>\r\n\r\n                <th\r\n                    [style.width]=\"5\"\r\n                    *ngIf=\"config.actions.length > 0\"\r\n                ></th>\r\n            </tr>\r\n        </ng-template>\r\n        <ng-template\r\n            pTemplate=\"body\"\r\n            let-rowNode\r\n            let-rowData=\"rowData\"\r\n            let-columns=\"columns\"\r\n        >\r\n            <tr\r\n                [ttRow]=\"rowNode\"\r\n                (dblclick)=\"doubleClick($event, rowData)\"\r\n            >\r\n                <td\r\n                    *ngFor=\"let col of columns;  let i = index\"\r\n                    [style]=\"returnStyleRow(col, rowNode)\"\r\n                    [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n                    [style.left.px]=\"rowNode.level !== 0 ? rowNode.level*30 : null\"\r\n                >\r\n\r\n                    <div class=\"flex flex-row  {{col.boolean ? 'justify-content-center' : '' }}\">\r\n                        <p-treeTableToggler\r\n                            [rowNode]=\"rowNode\"\r\n                            *ngIf=\"i === 0\"\r\n                        ></p-treeTableToggler>\r\n\r\n\r\n                        <div class=\"flex flex-row align-items-center\">\r\n                            <div class=\"flex flex-row align-items-center justify-content-center\">\r\n\r\n                                <i\r\n                                    *ngIf=\"col.boolean\"\r\n                                    class=\"pi {{rowData[col.field] ? 'pi-check text-green-300' : ''}}\"\r\n                                    style=\"font-size: 1.1rem;\"\r\n                                ></i>\r\n\r\n\r\n                                <div class=\"flex flex-column\">\r\n                                    <span class=\"m-0\">{{ rowData[col.field] }}</span>\r\n\r\n                                    <p\r\n                                        *ngIf=\"col.subtitle\"\r\n                                        class=\"m-0 text-xs font-semibold\"\r\n                                    >{{rowData[col.subtitle]}}</p>\r\n                                </div>\r\n\r\n                            </div>\r\n                        </div>\r\n\r\n                    </div>\r\n\r\n                </td>\r\n\r\n                <td>\r\n\r\n                    <div *ngIf=\"config.actions.length > 0 && validateActionPosition(rowNode)\">\r\n                        <div *ngFor=\"let action of config.actions\">\r\n\r\n                            <p-button\r\n                                *ngIf=\"acoesLinhaTabela\"\r\n                                icon=\"pi {{action.icon}}\"\r\n                                [rounded]=\"true\"\r\n                                [severity]=\"action.severity ? action.severity : 'secondary'\"\r\n                                [style]=\"{width: '2rem', height: '2rem'}\"\r\n                                (onClick)=\"action.command($event)\"\r\n                            ></p-button>\r\n\r\n                            <span\r\n                                *ngIf=\"!acoesLinhaTabela\"\r\n                                class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n                                style=\"font-size: 20px\"\r\n                                (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n                            >\r\n                                more_horiz\r\n                            </span>\r\n\r\n                            <div *ngFor=\"let action of config.actions\">\r\n                                {{ criarMenusModal(rowData) }}\r\n                            </div>\r\n\r\n                            <p-menu\r\n                                #menu\r\n                                [popup]=\"true\"\r\n                                [model]=\"menuItems\"\r\n                                appendTo=\"body\"\r\n                            ></p-menu>\r\n\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div *ngIf=\"config.actionsPai?.length > 0 && rowNode.level == 0\">\r\n\r\n                        <div *ngFor=\"let actionPai of config.actionsPai\">\r\n\r\n                            <p-button\r\n                                icon=\"pi {{actionPai.icon}}\"\r\n                                [rounded]=\"true\"\r\n                                [severity]=\"actionPai.severity ? actionPai.severity : 'secondary'\"\r\n                                [style]=\"{width: '2rem', height: '2rem'}\"\r\n                                (onClick)=\"actionPai.command($event)\"\r\n                            ></p-button>\r\n\r\n                        </div>\r\n\r\n                    </div>\r\n\r\n\r\n\r\n\r\n                </td>\r\n\r\n            </tr>\r\n        </ng-template>\r\n\r\n    </p-treeTable>\r\n</div>"]}
|
|
195
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"treetable.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/treetable/treetable.component.ts","../../../../../projects/keevo-components/src/lib/treetable/treetable.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\r\nimport { KvMenuItem } from '../api/components/table/kv-menuitem';\r\nimport { TreeTable } from 'primeng/treetable';\r\nimport { TablePaginate } from '../api/components/table/table.paginate';\r\nimport { MenuItemCommandEvent } from 'primeng/api';\r\n\r\n@Component({\r\n  selector: 'kv-tree-table',\r\n  templateUrl: './treetable.component.html',\r\n  styleUrls: ['./treetable.component.scss']\r\n})\r\nexport class TreetableComponent {\r\n\r\n  menuItems: KvMenuItem[] = [];\r\n  tamanhoTela!: number;\r\n  selectedItems: any = [];\r\n  commandEvent!: MenuItemCommandEvent;\r\n\r\n  @Input() config!: any;\r\n  @Input() dataSource!: any;\r\n  @Input() gridLines: boolean = false;\r\n  @Input() acoesLinhaTabela: boolean = false;\r\n\r\n  @Output() onFilter: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n\r\n  ngOnInit() {\r\n    this.tamanhoTela = window.innerWidth;\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.tamanhoTela = window.innerWidth;\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  public activeItemLote(rowData: any) {\r\n    this.selectedItems = rowData;\r\n    this.onActiveItemLote.emit(rowData);\r\n  }\r\n\r\n  public onGlobalFilter(table: TreeTable, event: Event) {\r\n    this.onFilter.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate($event: any) {\r\n    if ($event) {\r\n      let paginaInicial =\r\n        ($event?.first > 0 ? $event.first / $event.rows : $event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if ($event.globalFilter) termoPesquisa = $event.globalFilter;\r\n\r\n      if ($event.sortField)\r\n        ordenacao = `${$event.sortField} ${$event.sortOrder === 1 ? 'ASC' : 'DESC'\r\n          }`;\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: $event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao,\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  returnStyleRow(col: any, rowNode: any): string {\r\n    const isFirstColumn = col.field === this.config.columns[0].field;\r\n    const baseOpacity = 1;\r\n    const maxLevels = 4;\r\n\r\n    if (isFirstColumn && rowNode.level >= 0) {\r\n      const opacity = baseOpacity - (rowNode.level / maxLevels);\r\n\r\n      return `border-left: solid 4px rgba(59, 110, 158, ${opacity}) !important;`;\r\n    }\r\n\r\n    if (rowNode.level == 0)\r\n      return 'border-left: none !important; border-right: none !important'\r\n\r\n    return '';\r\n  }\r\n\r\n  alignColunasHeader(col: any): string {\r\n    if (col.align) {\r\n      if (col.align == 'right') return 'justify-content: end';\r\n      else return '';\r\n    } else return '';\r\n  }\r\n  centralizarColunas(col: any): string {\r\n    if (col.centralize) {\r\n      return 'text-align: center; ';\r\n    } else return '';\r\n  }\r\n  alignColunas(col: any): string {\r\n    if (col.align) {\r\n      return `text-align: ${col.align}`;\r\n    } else return '';\r\n  }\r\n\r\n  criarMenusModal(data: any) {\r\n    if (this.config.actions && data) {\r\n      const items = this.config.actions.map((action: any) => {\r\n        const icon = this.retornarCampo(action, data, 'icon');\r\n        const tooltip = this.retornarCampo(action, data, 'tooltip');\r\n        const tooltipPosition = this.retornarCampo(\r\n          action,\r\n          data,\r\n          'tooltipPosition'\r\n        );\r\n        const label = this.retornarCampo(action, data, 'label');\r\n        const command: any = this.retornarCampo(action, data, 'command');\r\n        const visible: boolean = action.visible ? action.visible(data) : true;\r\n        const disabled: boolean = action.disabled\r\n          ? action.disabled(data)\r\n          : false;\r\n\r\n        const menuInsert: KvMenuItem = {\r\n          label,\r\n          icon,\r\n          tooltip,\r\n          tooltipPosition,\r\n          command,\r\n          disabled,\r\n          visible,\r\n        };\r\n\r\n        let item = this.menuItems.filter(\r\n          (x) => x.command == menuInsert.command\r\n        );\r\n\r\n        if (item.length == 0) this.menuItems.push(menuInsert);\r\n        else {\r\n          if (menuInsert.label != item[0].label) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.visible != item[0].visible) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.disabled != item[0].disabled) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  retornarCampo(action: KvMenuItem, rowData: any, field: string): string {\r\n    const _function = action.dynamicfields\r\n      ? (action.dynamicfields[field] as Function)\r\n      : null;\r\n    const _field: string = _function\r\n      ? _function.apply(action, [rowData])\r\n      : action[field];\r\n    return _field;\r\n  }\r\n\r\n  exibirCampo(field: any, rowData: any) {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n    return visible;\r\n  }\r\n\r\n  validateActionPosition(rowNode: any): boolean {\r\n    if (this.config.actionsPai && rowNode.level == 0) return false;\r\n    else return true\r\n  }\r\n\r\n\r\n  doubleClick(e: any, rowData: any) {\r\n\r\n    let eventDoubleClick = { event: e, rowData: rowData };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    // if (array.find((x: any) => x == 'ng-star-inserted') != undefined)\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n\r\n  isDisabledCheckbox(rowData: any, rowNode: any): boolean {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData, rowNode)\r\n      : false;\r\n  }\r\n\r\n}\r\n","<div class=\"m-3\">\r\n    <p-treeTable\r\n        #tt\r\n        [value]=\"dataSource\"\r\n        [columns]=\"config.columns\"\r\n        [resizableColumns]=\"true\"\r\n        [tableStyle]=\"{'min-width': '50rem'}\"\r\n        [resizableColumns]=\"true\"\r\n        [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n        (onLazyLoad)=\"paginate($event)\"\r\n    >\r\n\r\n        <ng-template\r\n            pTemplate=\"caption\"\r\n            *ngIf=\"config.enableCation\"\r\n        >\r\n            <div\r\n                class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\">\r\n                <div class=\"col-12 flex flex-column\">\r\n                    <div\r\n                        *ngIf=\"config.title\"\r\n                        class=\"text-md font-bold my-3\"\r\n                    >\r\n                        {{ config.title }}\r\n                    </div>\r\n                    <div\r\n                        *ngIf=\"config.subtitle\"\r\n                        class=\"text-sm mb-4 font-medium\"\r\n                    >\r\n                        {{ config.subtitle }}\r\n                    </div>\r\n                </div>\r\n\r\n                <div [class]=\"\r\n            tamanhoTela < 768\r\n              ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n              : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n          \">\r\n\r\n                    <span\r\n                        *ngIf=\"config.enableFilter\"\r\n                        class=\"p-input-icon-left\"\r\n                    >\r\n                        <i class=\"pi pi-search\"></i>\r\n\r\n                        <input\r\n                            pInputText\r\n                            pAutoFocus\r\n                            [autofocus]=\"true\"\r\n                            type=\"text\"\r\n                            (input)=\"onGlobalFilter(tt, $event)\"\r\n                            placeholder=\"Pesquisar...\"\r\n                            class=\"h-2.5rem\"\r\n                        />\r\n                    </span>\r\n\r\n                </div>\r\n\r\n                <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n                    <div\r\n                        *ngFor=\"let action of config.actionsLote\"\r\n                        class=\"btns-options\"\r\n                    >\r\n                        <button\r\n                            id=\"actionLoteBtns\"\r\n                            pButton\r\n                            *ngIf=\"\r\n                (selectedItems.length > 0 || action.showAcoesLote) &&\r\n                exibirCampo(action, this.action)\r\n              \"\r\n                            class=\"actionLoteBtns p-button-raised p-button-text\"\r\n                            (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n                            [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n                            [tooltipPosition]=\"'bottom'\"\r\n                            [style.backgroundColor]=\"\r\n                retornarCampo(action, selectedItems, 'btnColor')\r\n              \"\r\n                            [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n                        >\r\n                            <span\r\n                                class=\"material-symbols-outlined md-22\"\r\n                                [style.color]=\"\r\n                  retornarCampo(action, selectedItems, 'iconBtnColor')\r\n                \"\r\n                            >\r\n                                {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n                            </span>\r\n                        </button>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </ng-template>\r\n\r\n        <ng-template\r\n            pTemplate=\"header\"\r\n            let-columns\r\n        >\r\n            <tr>\r\n                <th\r\n                    *ngFor=\"let col of columns; index as i\"\r\n                    [ttSortableColumn]=\"col.field\"\r\n                    [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n                    class=\"text-sm\"\r\n                    [style.width]=\"col.width\"\r\n                >\r\n                    <div>\r\n                        <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n                            <div *ngIf=\"i == 0 && config.enableSelect\">\r\n                                <p-treeTableHeaderCheckbox\r\n                                    (click)=\"activeItemLote(selectedItems)\"></p-treeTableHeaderCheckbox>\r\n                            </div>\r\n\r\n                            <div\r\n                                [class]=\"\r\n                    centralizarColunas(col) && alignColunasHeader(col) == ''\r\n                      ? 'flex flex-row justify-content-center'\r\n                      : 'flex flex-row'\r\n                  \"\r\n                                [style]=\"alignColunasHeader(col)\"\r\n                            >\r\n                                <span>{{ col.header }}</span>\r\n                                <p-sortIcon\r\n                                    *ngIf=\"col.sortable === true\"\r\n                                    [field]=\"col.field\"\r\n                                    style=\"font-size: 10px\"\r\n                                ></p-sortIcon>\r\n\r\n                                <span\r\n                                    *ngIf=\"col.headerTooltip\"\r\n                                    class=\"material-symbols-outlined flex align-items-center\"\r\n                                    [pTooltip]=\"col.headerTooltip\"\r\n                                >info</span>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n            </tr>\r\n        </ng-template>\r\n\r\n        <ng-template\r\n            pTemplate=\"header\"\r\n            let-columns\r\n        >\r\n            <tr>\r\n                <th\r\n                    *ngFor=\"let col of columns\"\r\n                    ttResizableColumn\r\n                    [style.width]=\"col.width\"\r\n                    [style]=\"col.centralize ? 'text-align: center;' : ''\"\r\n                >\r\n                    {{ col.header }} <br>\r\n                </th>\r\n\r\n                <th\r\n                    [style.width]=\"5\"\r\n                    *ngIf=\"config.actions.length > 0\"\r\n                ></th>\r\n            </tr>\r\n        </ng-template>\r\n        <ng-template\r\n            pTemplate=\"body\"\r\n            let-rowNode\r\n            let-rowData=\"rowData\"\r\n            let-columns=\"columns\"\r\n        >\r\n            <tr\r\n                [ttRow]=\"rowNode\"\r\n                (dblclick)=\"doubleClick($event, rowData)\"\r\n            >\r\n                <td\r\n                    *ngFor=\"let col of columns;  let i = index\"\r\n                    [style]=\"returnStyleRow(col, rowNode)\"\r\n                    [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n                    [style.left.px]=\"rowNode.level !== 0 ? rowNode.level*30 : null\"\r\n                >\r\n\r\n                    <div class=\"flex flex-row  {{col.boolean ? 'justify-content-center' : '' }}\">\r\n                        <div\r\n                            class=\"w-full-h-full flex align-items-center\"\r\n                            *ngIf=\"i == 0\"\r\n                        >\r\n                            <p-treeTableCheckbox\r\n                                [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n                                (click)=\"activeItemLote(selectedItems)\"\r\n                                [value]=\"rowNode\"\r\n                                *ngIf=\"config.enableSelect == true\"\r\n                            ></p-treeTableCheckbox>\r\n\r\n                            <p-treeTableToggler\r\n                                class=\"hiddenVisible\"\r\n                                [rowNode]=\"rowNode\"\r\n                            ></p-treeTableToggler>\r\n                            <!-- \r\n                            <p-treeTableToggler\r\n                                [rowNode]=\"rowNode\"\r\n                                *ngIf=\"!rightCollapse\"\r\n                            ></p-treeTableToggler>\r\n                            <p-treeTableToggler\r\n                                class=\"hiddenVisible\"\r\n                                [rowNode]=\"rowNode\"\r\n                                *ngIf=\"rightCollapse\"\r\n                            ></p-treeTableToggler> -->\r\n                        </div>\r\n\r\n\r\n                        <div class=\"flex flex-row align-items-center\">\r\n                            <div class=\"flex flex-row align-items-center justify-content-center\">\r\n\r\n                                <i\r\n                                    *ngIf=\"col.boolean\"\r\n                                    class=\"pi {{rowData[col.field] ? 'pi-check text-green-300' : ''}}\"\r\n                                    style=\"font-size: 1.1rem;\"\r\n                                ></i>\r\n\r\n\r\n                                <div\r\n                                    class=\"flex flex-column\"\r\n                                    *ngIf=\"!col.boolean\"\r\n                                >\r\n                                    <span class=\"m-0\">{{ rowData[col.field] }}</span>\r\n\r\n                                    <p\r\n                                        *ngIf=\"col.subtitle\"\r\n                                        class=\"m-0 text-xs font-semibold\"\r\n                                    >{{rowData[col.subtitle]}}</p>\r\n                                </div>\r\n\r\n                            </div>\r\n                        </div>\r\n\r\n                    </div>\r\n\r\n                </td>\r\n\r\n                <td style=\"border-left: none;\">\r\n\r\n                    <div *ngIf=\"config.actions.length > 0 && validateActionPosition(rowNode)\">\r\n                        <div\r\n                            *ngFor=\"let action of config.actions\"\r\n                            class=\"flex justify-content-center\"\r\n                        >\r\n\r\n                            <p-button\r\n                                *ngIf=\"acoesLinhaTabela\"\r\n                                icon=\"pi {{action.icon}}\"\r\n                                [rounded]=\"true\"\r\n                                [severity]=\"action.severity ? action.severity : 'secondary'\"\r\n                                [style]=\"{width: '2rem', height: '2rem'}\"\r\n                                (onClick)=\"action.command($event)\"\r\n                            ></p-button>\r\n\r\n                            <span\r\n                                *ngIf=\"!acoesLinhaTabela\"\r\n                                class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n                                style=\"font-size: 22px\"\r\n                                (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n                            >\r\n                                more_horiz\r\n                            </span>\r\n\r\n                            <div *ngFor=\"let action of config.actions\">\r\n                                {{ criarMenusModal(rowData) }}\r\n                            </div>\r\n\r\n                            <p-menu\r\n                                #menu\r\n                                [popup]=\"true\"\r\n                                [model]=\"menuItems\"\r\n                                appendTo=\"body\"\r\n                            ></p-menu>\r\n\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div *ngIf=\"config.actionsPai?.length > 0 && rowNode.level == 0\">\r\n\r\n                        <div\r\n                            *ngFor=\"let actionPai of config.actionsPai\"\r\n                            class=\"flex justify-content-end\"\r\n                        >\r\n\r\n                            <p-button\r\n                                icon=\"pi {{actionPai.icon}}\"\r\n                                [rounded]=\"true\"\r\n                                [severity]=\"actionPai.severity ? actionPai.severity : 'secondary'\"\r\n                                [style]=\"{width: '2rem', height: '2rem'}\"\r\n                                (onClick)=\"actionPai.command($event)\"\r\n                            ></p-button>\r\n\r\n                        </div>\r\n\r\n                    </div>\r\n\r\n                </td>\r\n\r\n            </tr>\r\n        </ng-template>\r\n\r\n    </p-treeTable>\r\n</div>"]}
|