keevo-components 1.8.49 → 1.8.51
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.
|
@@ -72,6 +72,7 @@ export class KvMenuComponent {
|
|
|
72
72
|
}
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
|
+
this.usuarioLogadoService.setUltimoAplicativoLogado(idaplicativo);
|
|
75
76
|
this.sistemasPanel.hide();
|
|
76
77
|
}
|
|
77
78
|
expandMenuEvent() {
|
|
@@ -193,4 +194,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
193
194
|
type: HostListener,
|
|
194
195
|
args: ['window:resize', ['$event']]
|
|
195
196
|
}] } });
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-menu/kv-menu.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-menu/kv-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport {\n  ActivatedRoute,\n  Router\n} from '@angular/router';\n\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\n\nimport {\n  AplicativoModel,\n  MasterComboModel,\n  MenuModel,\n  UsuarioLogadoService\n} from 'keevo-api-services-keevocenter';\n\nimport { OverlayPanel } from 'primeng/overlaypanel';\nimport { Sidebar } from 'primeng/sidebar';\n\n@Component({\n  selector: 'kv-menu',\n  templateUrl: './kv-menu.component.html',\n  styleUrls: ['./kv-menu.component.scss'],\n})\nexport class KvMenuComponent implements OnInit {\n\n  @Input() aplicativos: AplicativoModel[] = [];\n  @Input() breadCrumbItems: { label: string, routerLink: string }[] = [];\n  @Input() licencas: MasterComboModel[] = [];\n  @Input() licencaSelecionada!: MasterComboModel;\n  @Input() logoImage!: any;\n  @Input() nomeUsuario!: string;\n\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\n  @Output() gerenciarKeePassEvent: EventEmitter<any> = new EventEmitter();\n  @Output() licencaChange: EventEmitter<any> = new EventEmitter();\n  @Output() sairEvent: EventEmitter<any> = new EventEmitter();\n  @Output() trocarLicencaEmit: EventEmitter<boolean> = new EventEmitter();\n\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\n  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\n\n  menus: MenuModel[] = [];\n\n  expandMenu: boolean = true;\n  heigthCard!: number;\n  mouseOverFilhoIndex: any;\n  mouseOverIndex: any;\n  visibleDialogLicenca: boolean = false;\n  widthCard!: number;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    protected router: Router,\n    private route: ActivatedRoute,\n    private usuarioLogadoService: UsuarioLogadoService) { }\n\n  ajustarHeigthCard(): number {\n    if (this.widthCard > 400) {\n      if (this.breadCrumbItems.length > 0) return 105\n      else return 85\n    } else return 83\n  }\n\n  callRoute(e: any, expand?: boolean) {\n    if (!expand)\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : '';\n\n    this.router.navigateByUrl(e)\n  }\n\n  closeCallback(e: Event): void {\n    this.sidebarRef.close(e);\n  }\n\n  configurarLicencas() {\n    setTimeout(() => {\n      const ultimoAplicativoSelecionado = this.usuarioLogadoService.getUltimoAplicativoSelecionado() as number;\n      if (ultimoAplicativoSelecionado)\n        this.definirMenusPorSistema(ultimoAplicativoSelecionado)\n      else this.definirMenusPorSistema(this.aplicativos[0]?.idaplicativo);\n    }, 1);\n  }\n\n  definirMenusPorSistema(idaplicativo: number) {\n    this.menus = this.aplicativos.find((x) => x.idaplicativo == idaplicativo)?.menus || [];\n\n    if (this.router.url && this.menus.length > 0) {\n      if (this.router.url === '/') {\n        this.navigateToFirstMenu()\n      }\n      else {\n        const menuSelecionado = this.menus.find((menu: any) => menu.link.includes(this.router.url.slice(1)));\n        if (menuSelecionado) {\n          this.navigateToMenu(menuSelecionado);\n        }\n      }\n    }\n\n    this.sistemasPanel.hide();\n  }\n\n  expandMenuEvent() {\n    this.expandMenuEmit.emit(this.expandMenu);\n  }\n\n  gerenciarKeePass(event: any) {\n    this.sistemasPanel.hide();\n    this.gerenciarKeePassEvent.emit(event)\n  }\n\n  mascaraNomeLicenca(nomeLicenca: any): string {\n    if (nomeLicenca) {\n      if (nomeLicenca.length > 23)\n        return nomeLicenca.substring(0, 23) + '...';\n      else return nomeLicenca;\n    } else return '';\n  }\n\n  navigateToFirstMenu(): void {\n    const firstMenu = this.menus[0];\n    if (firstMenu.indmenupai) {\n      const filhos = this.retornarMenuFilhos(firstMenu.idaplicativo, firstMenu.idmenu);\n      if (filhos) {\n        this.callRoute(filhos[0].link, true);\n      }\n    } else {\n      this.callRoute(firstMenu.link, true);\n    }\n  }\n\n  navigateToMenu(menu: any): void {\n    if (menu.menupai) {\n      const filhos = this.retornarMenuFilhos(menu.idsistema, menu.idmenu);\n      if (filhos) {\n        this.callRoute(filhos[0].link, true);\n      }\n    } else {\n      this.callRoute(menu.link, true);\n    }\n  }\n\n  ngOnInit(): void {\n    this.configurarLicencas();\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\n    this.expandMenuEvent()\n  }\n\n  onMouseEnter(index: number) {\n    this.mouseOverIndex = index;\n  }\n\n  onMouseFilhoEnter(index: number) {\n    this.mouseOverFilhoIndex = index;\n  }\n\n  onMouseLeave() {\n    this.mouseOverIndex = null;\n    this.mouseOverFilhoIndex = null;\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onWindowResize() {\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\n    this.cdr.detectChanges();\n  }\n\n  retornarMenuFilhos(idaplicativo: number, idmenu: number) {\n    return this.aplicativos.find((x) => x.idaplicativo == idaplicativo)?.menus.filter((x) => x.idmenupai == idmenu);\n  }\n\n  sair(event: any) {\n    this.sistemasPanel.hide();\n    this.sairEvent.emit(event)\n  }\n\n  toggleMenu() {\n    this.expandMenu = !this.expandMenu;\n    this.expandMenuEvent()\n  }\n\n  trocarLicenca() {\n    this.trocarLicencaEmit.emit();\n  }\n\n  verificarPaginaSelecionada(link: any): boolean {\n    return this.router.url.includes(link);\n  }\n}\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\n\n  <div [style]=\"{minWidth: expandMenu ? '300px' : '60px'}\"></div>\n\n  <p-sidebar\n    #sidebarRef\n    [visible]=\"true\"\n    [showCloseIcon]=\"false\"\n    [modal]=\"false\"\n    [style]=\"{width: expandMenu ? '300px' : '60px'}\">\n    <ng-template pTemplate=\"headless\">\n      <div class=\"flex flex-column mx-1\">\n        <div\n          class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2\">\n          <div\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}} py-3\">\n            <img\n              *ngIf=\"expandMenu\"\n              alt=\"Card\"\n              [src]=\"logoImage\"\n              width=\"150\" />\n\n            <button\n              pButton\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\n              (click)=\"toggleMenu()\"\n              [pTooltip]=\"expandMenu ? 'Ocutar Menu' : 'Expandir Menu'\"\n              [tooltipPosition]=\"'right'\">\n              <i class=\"material-symbols-outlined\">\n                menu\n              </i>\n            </button>\n          </div>\n\n          <div\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}}\">\n            <div\n              class=\"flex flex-column cursor-pointer\"\n              *ngIf=\"expandMenu\"\n              (click)=\"trocarLicenca()\">\n              <span\n                class=\"text-sm font-semibold mr-2\"\n                [pTooltip]=\"this.licencaSelecionada.nome\"\n                [tooltipPosition]=\"'right'\">\n                {{mascaraNomeLicenca(this.licencaSelecionada.nome)}}\n              </span>\n              <span class=\"text-sm mt-1\">{{this.licencaSelecionada.cpfcnpj |\n                cpfCnpj }}</span>\n            </div>\n\n            <button\n              pButton\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\n              (click)=\"trocarLicenca()\"\n              [pTooltip]=\"'Alterar workspace'\"\n              [tooltipPosition]=\"'right'\">\n              <i class=\"material-symbols-outlined\">\n                sync_alt\n              </i>\n            </button>\n\n          </div>\n          <p-divider type=\"solid\"></p-divider>\n        </div>\n\n        <div\n          class=\"list-none m-0  card-container {{expandMenu ? 'mx-1' : ''}}\"\n          [style.max-height]=\"(heigthCard - 220) + 'px'\"\n          style=\"overflow-y: auto;\">\n          <!-- menus -->\n          <li *ngFor=\"let menu of menus; let i = index\">\n            <!-- menu que não tem filho -->\n            <a\n              (mouseenter)=\"onMouseEnter(i)\"\n              (mouseleave)=\"onMouseLeave()\"\n              [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\n              (click)=\"callRoute(menu.link)\"\n              *ngIf=\"!menu.indmenupai && (!menu.idmenupai || menu.idmenupai == 0)\"\n              pRipple\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\n              [tooltipPosition]=\"'right'\"\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\">\n\n              <i\n                class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}  icon-hover-color {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\n                *ngIf=\"menu.icone\">\n                {{ menu.icone }}\n              </i>\n              <span\n                class=\"text-base text-blue-900 font-medium {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\n                *ngIf=\"expandMenu\">{{ menu.descricaomenu }}</span>\n            </a>\n            <!-- menu com filho -->\n            <div *ngIf=\"menu.indmenupai\">\n              <a\n                (mouseenter)=\"onMouseEnter(i)\"\n                (mouseleave)=\"onMouseLeave()\"\n                [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\n                pRipple\n                pStyleClass=\"@next\"\n                enterClass=\"hidden\"\n                enterActiveClass=\"slidedown\"\n                leaveToClass=\"hidden\"\n                leaveActiveClass=\"slideup\"\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\"\n                [tooltipPosition]=\"'right'\"\n                [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\n                (click)=\"!expandMenu ? expandMenu = !expandMenu : ''\">\n                <div class=\"flex flex-row align-items-center\">\n\n                  <i\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}} icon-hover-color\"\n                    *ngIf=\"menu.icone\"\n                    [ngClass]=\"{'hover-color': mouseOverIndex === i}\">\n                    {{ menu.icone }}\n                  </i>\n                  <span\n                    class=\"text-base text-blue-900 font-medium\"\n                    *ngIf=\"expandMenu\">{{ menu.descricaomenu }}</span>\n                </div>\n                <i\n                  class=\"pi pi-chevron-down text-blue-900 mr-1 icon-hover-color\"\n                  *ngIf=\"expandMenu\"\n                  [ngClass]=\"{'hover-color': mouseOverIndex === i}\"></i>\n              </a>\n\n              <!-- filhos -->\n              <div\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\">\n                <li *ngFor=\"\n              let filho of retornarMenuFilhos(menu.idaplicativo, menu.idmenu);  let iFilho = index\n            \">\n                  <a\n                    (mouseenter)=\"onMouseFilhoEnter(filho.idmenu)\"\n                    (mouseleave)=\"onMouseLeave()\"\n                    [ngClass]=\"{'hover-color': mouseOverFilhoIndex === filho.idmenu}\"\n                    *ngIf=\"expandMenu\"\n                    (click)=\"callRoute(filho.link)\"\n                    pRipple\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\">\n                    <i\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}} icon-hover-color\"\n                    *ngIf=\"filho.icone\"\n                    [ngClass]=\"{'hover-color': mouseOverIndex === i}\">\n                    {{ filho.icone }}\n                  </i>\n                    <span\n                      class=\"text-base text-blue-900 ml-4 {{verificarPaginaSelecionada(filho.link) ? 'text-white' : ''}}\"\n                      *ngIf=\"expandMenu\">{{ filho.descricaomenu }}</span>\n                  </a>\n                </li>\n              </div>\n            </div>\n          </div>\n        </div>\n      </ng-template>\n    </p-sidebar>\n\n    <div\n      class=\"w-auto h-screen page-content overflow-y-hidden\"\n      id=\"page-content\">\n\n      <div class=\"flex flex-row align-items-center justify-content-between m-3\">\n        <div>\n          <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">{{breadCrumbItems[breadCrumbItems.length - 1]?.label}}</p>\n          <p-breadcrumb\n            *ngIf=\"widthCard > 400\"\n            styleClass=\"border-none p-0 flex align-items-center h-2rem !important;\"\n            [model]=\"breadCrumbItems\"\n            [style]=\"{backgroundColor: '#d4d3d3'}\"\n            (onItemClick)=\"callRoute($event.item.routerLink, true)\"></p-breadcrumb>\n        </div>\n\n        <div class=\"w-auto flex flex-row align-items-center gap-2\">\n\n          <p-button\n            styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\n            icon=\"pi pi-th-large\"\n            [rounded]=\"true\"\n            [text]=\"true\"\n            (click)=\"sistemasPanel.toggle($event)\"\n            [pTooltip]=\"'Sistemas'\"\n            [tooltipPosition]=\"'left'\"></p-button>\n\n          <p-button\n            styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\n            icon=\"pi pi-user\"\n            [rounded]=\"true\"\n            [text]=\"true\"\n            [pTooltip]=\"'Menu do Usuário'\"\n            [tooltipPosition]=\"'left'\"\n            (click)=\"meusDadosPanel.toggle($event)\"></p-button>\n\n        </div>\n      </div>\n\n      <p-card\n        class=\"card-container\"\n        styleClass=\"m-3 border-noround overflow-y-auto card-container\"\n        [style]=\"{height: heigthCard - ajustarHeigthCard() + 'px'}\">\n        <div class=\"card-container w-full\" [style]=\"{width: widthCard + 'px'}\">\n          <ng-content></ng-content>\n        </div>\n      </p-card>\n\n    </div>\n\n    <p-overlayPanel\n      #sistemasPanel\n      [showTransitionOptions]=\"'350ms ease-out'\"\n      [hideTransitionOptions]=\"'250ms ease-in'\">\n      <ng-template pTemplate=\"container\">\n        <p class=\"title-style mt-3\">Sistemas</p>\n        <div\n          class=\"flex flex-row flex-wrap gap-2 align-items-center justify-content-center mt-5 mb-3\"\n          style=\"width: 250px; height: 100%;\">\n          <button\n            *ngFor=\"let aplicativo of aplicativos\"\n            pButton\n            pRipple\n            class=\"btn-sistema-2 btn-sistema hover-btn-cor-padrao remove-focus h-4rem w-4rem\"\n            (click)=\"definirMenusPorSistema(aplicativo.idaplicativo)\"\n            [pTooltip]=\"aplicativo?.descricaoaplicativo\"\n            [tooltipPosition]=\"'left'\">\n            {{ aplicativo.nomeaplicativo.charAt(0).toUpperCase() }}\n          </button>\n        </div>\n      </ng-template>\n    </p-overlayPanel>\n\n    <p-overlayPanel\n      #meusDadosPanel\n      [showTransitionOptions]=\"'350ms ease-out'\"\n      [hideTransitionOptions]=\"'250ms ease-in'\">\n\n      <ng-template pTemplate=\"container\">\n\n        <p class=\"title-style mt-3\">Olá, {{nomeUsuario ?\n          nomeUsuario.split(' ')[0] : 'Usuário'}} !</p>\n        <div class=\"mt-5 mb-3\">\n\n        </div>\n\n        <p-button\n          icon=\"pi pi-lock\"\n          label=\"Gerênciar KeevoPass\"\n          (onClick)=\"gerenciarKeePass($event)\"\n          styleClass=\"border-noround w-full text-blue-900\"\n          [text]=\"true\"\n          [disabled]=\"true\"></p-button>\n        <p-button\n          icon=\"pi pi-sign-out\"\n          label=\"Sair\"\n          (onClick)=\"sair($event)\"\n          styleClass=\"border-noround w-full text-blue-900\"\n          [text]=\"true\"></p-button>\n      </ng-template>\n\n    </p-overlayPanel>"]}
|
|
197
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-menu/kv-menu.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-menu/kv-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport {\n  ActivatedRoute,\n  Router\n} from '@angular/router';\n\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\n\nimport {\n  AplicativoModel,\n  MasterComboModel,\n  MenuModel,\n  UsuarioLogadoService\n} from 'keevo-api-services-keevocenter';\n\nimport { OverlayPanel } from 'primeng/overlaypanel';\nimport { Sidebar } from 'primeng/sidebar';\n\n@Component({\n  selector: 'kv-menu',\n  templateUrl: './kv-menu.component.html',\n  styleUrls: ['./kv-menu.component.scss'],\n})\nexport class KvMenuComponent implements OnInit {\n\n  @Input() aplicativos: AplicativoModel[] = [];\n  @Input() breadCrumbItems: { label: string, routerLink: string }[] = [];\n  @Input() licencas: MasterComboModel[] = [];\n  @Input() licencaSelecionada!: MasterComboModel;\n  @Input() logoImage!: any;\n  @Input() nomeUsuario!: string;\n\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\n  @Output() gerenciarKeePassEvent: EventEmitter<any> = new EventEmitter();\n  @Output() licencaChange: EventEmitter<any> = new EventEmitter();\n  @Output() sairEvent: EventEmitter<any> = new EventEmitter();\n  @Output() trocarLicencaEmit: EventEmitter<boolean> = new EventEmitter();\n\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\n  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\n\n  menus: MenuModel[] = [];\n\n  expandMenu: boolean = true;\n  heigthCard!: number;\n  mouseOverFilhoIndex: any;\n  mouseOverIndex: any;\n  visibleDialogLicenca: boolean = false;\n  widthCard!: number;\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    protected router: Router,\n    private route: ActivatedRoute,\n    private usuarioLogadoService: UsuarioLogadoService) { }\n\n  ajustarHeigthCard(): number {\n    if (this.widthCard > 400) {\n      if (this.breadCrumbItems.length > 0) return 105\n      else return 85\n    } else return 83\n  }\n\n  callRoute(e: any, expand?: boolean) {\n    if (!expand)\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : '';\n\n    this.router.navigateByUrl(e)\n  }\n\n  closeCallback(e: Event): void {\n    this.sidebarRef.close(e);\n  }\n\n  configurarLicencas() {\n    setTimeout(() => {\n      const ultimoAplicativoSelecionado = this.usuarioLogadoService.getUltimoAplicativoSelecionado() as number;\n      if (ultimoAplicativoSelecionado)\n        this.definirMenusPorSistema(ultimoAplicativoSelecionado)\n      else this.definirMenusPorSistema(this.aplicativos[0]?.idaplicativo);\n    }, 1);\n  }\n\n  definirMenusPorSistema(idaplicativo: number) {\n    this.menus = this.aplicativos.find((x) => x.idaplicativo == idaplicativo)?.menus || [];\n\n    if (this.router.url && this.menus.length > 0) {\n      if (this.router.url === '/') {\n        this.navigateToFirstMenu()\n      }\n      else {\n        const menuSelecionado = this.menus.find((menu: any) => menu.link.includes(this.router.url.slice(1)));\n        if (menuSelecionado) {\n          this.navigateToMenu(menuSelecionado);\n        }\n      }\n    }\n\n    this.usuarioLogadoService.setUltimoAplicativoLogado(idaplicativo);\n    this.sistemasPanel.hide();\n  }\n\n  expandMenuEvent() {\n    this.expandMenuEmit.emit(this.expandMenu);\n  }\n\n  gerenciarKeePass(event: any) {\n    this.sistemasPanel.hide();\n    this.gerenciarKeePassEvent.emit(event)\n  }\n\n  mascaraNomeLicenca(nomeLicenca: any): string {\n    if (nomeLicenca) {\n      if (nomeLicenca.length > 23)\n        return nomeLicenca.substring(0, 23) + '...';\n      else return nomeLicenca;\n    } else return '';\n  }\n\n  navigateToFirstMenu(): void {\n    const firstMenu = this.menus[0];\n    if (firstMenu.indmenupai) {\n      const filhos = this.retornarMenuFilhos(firstMenu.idaplicativo, firstMenu.idmenu);\n      if (filhos) {\n        this.callRoute(filhos[0].link, true);\n      }\n    } else {\n      this.callRoute(firstMenu.link, true);\n    }\n  }\n\n  navigateToMenu(menu: any): void {\n    if (menu.menupai) {\n      const filhos = this.retornarMenuFilhos(menu.idsistema, menu.idmenu);\n      if (filhos) {\n        this.callRoute(filhos[0].link, true);\n      }\n    } else {\n      this.callRoute(menu.link, true);\n    }\n  }\n\n  ngOnInit(): void {\n    this.configurarLicencas();\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\n    this.expandMenuEvent()\n  }\n\n  onMouseEnter(index: number) {\n    this.mouseOverIndex = index;\n  }\n\n  onMouseFilhoEnter(index: number) {\n    this.mouseOverFilhoIndex = index;\n  }\n\n  onMouseLeave() {\n    this.mouseOverIndex = null;\n    this.mouseOverFilhoIndex = null;\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onWindowResize() {\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\n    this.cdr.detectChanges();\n  }\n\n  retornarMenuFilhos(idaplicativo: number, idmenu: number) {\n    return this.aplicativos.find((x) => x.idaplicativo == idaplicativo)?.menus.filter((x) => x.idmenupai == idmenu);\n  }\n\n  sair(event: any) {\n    this.sistemasPanel.hide();\n    this.sairEvent.emit(event)\n  }\n\n  toggleMenu() {\n    this.expandMenu = !this.expandMenu;\n    this.expandMenuEvent()\n  }\n\n  trocarLicenca() {\n    this.trocarLicencaEmit.emit();\n  }\n\n  verificarPaginaSelecionada(link: any): boolean {\n    return this.router.url.includes(link);\n  }\n}\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\n\n  <div [style]=\"{minWidth: expandMenu ? '300px' : '60px'}\"></div>\n\n  <p-sidebar\n    #sidebarRef\n    [visible]=\"true\"\n    [showCloseIcon]=\"false\"\n    [modal]=\"false\"\n    [style]=\"{width: expandMenu ? '300px' : '60px'}\">\n    <ng-template pTemplate=\"headless\">\n      <div class=\"flex flex-column mx-1\">\n        <div\n          class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2\">\n          <div\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}} py-3\">\n            <img\n              *ngIf=\"expandMenu\"\n              alt=\"Card\"\n              [src]=\"logoImage\"\n              width=\"150\" />\n\n            <button\n              pButton\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\n              (click)=\"toggleMenu()\"\n              [pTooltip]=\"expandMenu ? 'Ocutar Menu' : 'Expandir Menu'\"\n              [tooltipPosition]=\"'right'\">\n              <i class=\"material-symbols-outlined\">\n                menu\n              </i>\n            </button>\n          </div>\n\n          <div\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}}\">\n            <div\n              class=\"flex flex-column cursor-pointer\"\n              *ngIf=\"expandMenu\"\n              (click)=\"trocarLicenca()\">\n              <span\n                class=\"text-sm font-semibold mr-2\"\n                [pTooltip]=\"this.licencaSelecionada.nome\"\n                [tooltipPosition]=\"'right'\">\n                {{mascaraNomeLicenca(this.licencaSelecionada.nome)}}\n              </span>\n              <span class=\"text-sm mt-1\">{{this.licencaSelecionada.cpfcnpj |\n                cpfCnpj }}</span>\n            </div>\n\n            <button\n              pButton\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\n              (click)=\"trocarLicenca()\"\n              [pTooltip]=\"'Alterar workspace'\"\n              [tooltipPosition]=\"'right'\">\n              <i class=\"material-symbols-outlined\">\n                sync_alt\n              </i>\n            </button>\n\n          </div>\n          <p-divider type=\"solid\"></p-divider>\n        </div>\n\n        <div\n          class=\"list-none m-0  card-container {{expandMenu ? 'mx-1' : ''}}\"\n          [style.max-height]=\"(heigthCard - 220) + 'px'\"\n          style=\"overflow-y: auto;\">\n          <!-- menus -->\n          <li *ngFor=\"let menu of menus; let i = index\">\n            <!-- menu que não tem filho -->\n            <a\n              (mouseenter)=\"onMouseEnter(i)\"\n              (mouseleave)=\"onMouseLeave()\"\n              [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\n              (click)=\"callRoute(menu.link)\"\n              *ngIf=\"!menu.indmenupai && (!menu.idmenupai || menu.idmenupai == 0)\"\n              pRipple\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\n              [tooltipPosition]=\"'right'\"\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\">\n\n              <i\n                class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}  icon-hover-color {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\n                *ngIf=\"menu.icone\">\n                {{ menu.icone }}\n              </i>\n              <span\n                class=\"text-base text-blue-900 font-medium {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\n                *ngIf=\"expandMenu\">{{ menu.descricaomenu }}</span>\n            </a>\n            <!-- menu com filho -->\n            <div *ngIf=\"menu.indmenupai\">\n              <a\n                (mouseenter)=\"onMouseEnter(i)\"\n                (mouseleave)=\"onMouseLeave()\"\n                [ngClass]=\"{'hover-color': mouseOverIndex === i}\"\n                pRipple\n                pStyleClass=\"@next\"\n                enterClass=\"hidden\"\n                enterActiveClass=\"slidedown\"\n                leaveToClass=\"hidden\"\n                leaveActiveClass=\"slideup\"\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\"\n                [tooltipPosition]=\"'right'\"\n                [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\n                (click)=\"!expandMenu ? expandMenu = !expandMenu : ''\">\n                <div class=\"flex flex-row align-items-center\">\n\n                  <i\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}} icon-hover-color\"\n                    *ngIf=\"menu.icone\"\n                    [ngClass]=\"{'hover-color': mouseOverIndex === i}\">\n                    {{ menu.icone }}\n                  </i>\n                  <span\n                    class=\"text-base text-blue-900 font-medium\"\n                    *ngIf=\"expandMenu\">{{ menu.descricaomenu }}</span>\n                </div>\n                <i\n                  class=\"pi pi-chevron-down text-blue-900 mr-1 icon-hover-color\"\n                  *ngIf=\"expandMenu\"\n                  [ngClass]=\"{'hover-color': mouseOverIndex === i}\"></i>\n              </a>\n\n              <!-- filhos -->\n              <div\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\">\n                <li *ngFor=\"\n              let filho of retornarMenuFilhos(menu.idaplicativo, menu.idmenu);  let iFilho = index\n            \">\n                  <a\n                    (mouseenter)=\"onMouseFilhoEnter(filho.idmenu)\"\n                    (mouseleave)=\"onMouseLeave()\"\n                    [ngClass]=\"{'hover-color': mouseOverFilhoIndex === filho.idmenu}\"\n                    *ngIf=\"expandMenu\"\n                    (click)=\"callRoute(filho.link)\"\n                    pRipple\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\">\n                    <i\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}} icon-hover-color\"\n                    *ngIf=\"filho.icone\"\n                    [ngClass]=\"{'hover-color': mouseOverIndex === i}\">\n                    {{ filho.icone }}\n                  </i>\n                    <span\n                      class=\"text-base text-blue-900 ml-4 {{verificarPaginaSelecionada(filho.link) ? 'text-white' : ''}}\"\n                      *ngIf=\"expandMenu\">{{ filho.descricaomenu }}</span>\n                  </a>\n                </li>\n              </div>\n            </div>\n          </div>\n        </div>\n      </ng-template>\n    </p-sidebar>\n\n    <div\n      class=\"w-auto h-screen page-content overflow-y-hidden\"\n      id=\"page-content\">\n\n      <div class=\"flex flex-row align-items-center justify-content-between m-3\">\n        <div>\n          <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">{{breadCrumbItems[breadCrumbItems.length - 1]?.label}}</p>\n          <p-breadcrumb\n            *ngIf=\"widthCard > 400\"\n            styleClass=\"border-none p-0 flex align-items-center h-2rem !important;\"\n            [model]=\"breadCrumbItems\"\n            [style]=\"{backgroundColor: '#d4d3d3'}\"\n            (onItemClick)=\"callRoute($event.item.routerLink, true)\"></p-breadcrumb>\n        </div>\n\n        <div class=\"w-auto flex flex-row align-items-center gap-2\">\n\n          <p-button\n            styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\n            icon=\"pi pi-th-large\"\n            [rounded]=\"true\"\n            [text]=\"true\"\n            (click)=\"sistemasPanel.toggle($event)\"\n            [pTooltip]=\"'Sistemas'\"\n            [tooltipPosition]=\"'left'\"></p-button>\n\n          <p-button\n            styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\n            icon=\"pi pi-user\"\n            [rounded]=\"true\"\n            [text]=\"true\"\n            [pTooltip]=\"'Menu do Usuário'\"\n            [tooltipPosition]=\"'left'\"\n            (click)=\"meusDadosPanel.toggle($event)\"></p-button>\n\n        </div>\n      </div>\n\n      <p-card\n        class=\"card-container\"\n        styleClass=\"m-3 border-noround overflow-y-auto card-container\"\n        [style]=\"{height: heigthCard - ajustarHeigthCard() + 'px'}\">\n        <div class=\"card-container w-full\" [style]=\"{width: widthCard + 'px'}\">\n          <ng-content></ng-content>\n        </div>\n      </p-card>\n\n    </div>\n\n    <p-overlayPanel\n      #sistemasPanel\n      [showTransitionOptions]=\"'350ms ease-out'\"\n      [hideTransitionOptions]=\"'250ms ease-in'\">\n      <ng-template pTemplate=\"container\">\n        <p class=\"title-style mt-3\">Sistemas</p>\n        <div\n          class=\"flex flex-row flex-wrap gap-2 align-items-center justify-content-center mt-5 mb-3\"\n          style=\"width: 250px; height: 100%;\">\n          <button\n            *ngFor=\"let aplicativo of aplicativos\"\n            pButton\n            pRipple\n            class=\"btn-sistema-2 btn-sistema hover-btn-cor-padrao remove-focus h-4rem w-4rem\"\n            (click)=\"definirMenusPorSistema(aplicativo.idaplicativo)\"\n            [pTooltip]=\"aplicativo?.descricaoaplicativo\"\n            [tooltipPosition]=\"'left'\">\n            {{ aplicativo.nomeaplicativo.charAt(0).toUpperCase() }}\n          </button>\n        </div>\n      </ng-template>\n    </p-overlayPanel>\n\n    <p-overlayPanel\n      #meusDadosPanel\n      [showTransitionOptions]=\"'350ms ease-out'\"\n      [hideTransitionOptions]=\"'250ms ease-in'\">\n\n      <ng-template pTemplate=\"container\">\n\n        <p class=\"title-style mt-3\">Olá, {{nomeUsuario ?\n          nomeUsuario.split(' ')[0] : 'Usuário'}} !</p>\n        <div class=\"mt-5 mb-3\">\n\n        </div>\n\n        <p-button\n          icon=\"pi pi-lock\"\n          label=\"Gerênciar KeevoPass\"\n          (onClick)=\"gerenciarKeePass($event)\"\n          styleClass=\"border-noround w-full text-blue-900\"\n          [text]=\"true\"\n          [disabled]=\"true\"></p-button>\n        <p-button\n          icon=\"pi pi-sign-out\"\n          label=\"Sair\"\n          (onClick)=\"sair($event)\"\n          styleClass=\"border-noround w-full text-blue-900\"\n          [text]=\"true\"></p-button>\n      </ng-template>\n\n    </p-overlayPanel>"]}
|