keevo-components 1.8.74 → 1.8.75

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.
@@ -195,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
195
195
  type: HostListener,
196
196
  args: ['window:resize', ['$event']]
197
197
  }] } });
198
- //# 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":"AAMA,OAAO,EAEL,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;AAavB,MAAM,OAAO,eAAe;IA+B1B,YACU,GAAsB,EACpB,MAAc,EAChB,KAAqB;QAFrB,QAAG,GAAH,GAAG,CAAmB;QACpB,WAAM,GAAN,MAAM,CAAQ;QAChB,UAAK,GAAL,KAAK,CAAgB;QAhCtB,gBAAW,GAAsB,EAAE,CAAC;QAGpC,oBAAe,GAA4C,EAAE,CAAC;QAC9D,aAAQ,GAAuB,EAAE,CAAC;QAKjC,mBAAc,GAA0B,IAAI,YAAY,EAAE,CAAC;QAC3D,0BAAqB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC9D,kBAAa,GAAsB,IAAI,YAAY,EAAE,CAAC;QACtD,cAAS,GAAsB,IAAI,YAAY,EAAE,CAAC;QAClD,6BAAwB,GAAyB,IAAI,YAAY,EAAE,CAAC;QACpE,sBAAiB,GAA0B,IAAI,YAAY,EAAE,CAAC;QAMxE,UAAK,GAAgB,EAAE,CAAC;QAExB,eAAU,GAAY,IAAI,CAAC;QAI3B,yBAAoB,GAAY,KAAK,CAAC;IAMH,CAAC;IAE7B,iBAAiB;QACtB,IAAI,IAAI,CAAC,SAAS,GAAG,GAAG,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC;gBAAE,OAAO,GAAG,CAAA;;gBAC1C,OAAO,EAAE,CAAA;QAChB,CAAC;;YAAM,OAAO,EAAE,CAAA;IAClB,CAAC;IAEM,SAAS,CAAC,CAAM,EAAE,MAAgB;QACvC,IAAI,CAAC,MAAM;YACT,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;QAE7D,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAA;IAC9B,CAAC;IAEO,kBAAkB;QACxB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,2BAA2B,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;QACrG,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAEO,sBAAsB,CAAC,YAAoB;QACjD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,IAAI,YAAY,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC;QAEvF,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3D,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;gBAC5B,IAAI,CAAC,mBAAmB,EAAE,CAAA;YAC5B,CAAC;iBACI,CAAC;gBACJ,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAClH,IAAI,eAAe,EAAE,CAAC;oBACpB,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC5C,CAAC;IAEM,gBAAgB,CAAC,KAAU;QAChC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IACxC,CAAC;IAEM,kBAAkB,CAAC,WAAgB;QACxC,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,WAAW,CAAC,MAAM,GAAG,EAAE;gBACzB,OAAO,WAAW,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC;;gBACzC,OAAO,WAAW,CAAC;QAC1B,CAAC;;YAAM,OAAO,EAAE,CAAC;IACnB,CAAC;IAEO,mBAAmB;QACzB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAChC,IAAI,SAAS,CAAC,UAAU,EAAE,CAAC;YACzB,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,YAAY,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC;YACjF,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACvC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACvC,CAAC;IACH,CAAC;IAEO,cAAc,CAAC,IAAS;QAC9B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YACpE,IAAI,MAAM,EAAE,CAAC;gBACX,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACvC,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,YAAY,CAAC,CAAC;QAChF,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAC1E,IAAI,CAAC,eAAe,EAAE,CAAA;IACxB,CAAC;IAEM,YAAY,CAAC,KAAa;QAC/B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IAEM,iBAAiB,CAAC,KAAa;QACpC,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;IACnC,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IAClC,CAAC;IAGM,cAAc;QACnB,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,YAAY,CAAC,CAAC;QAChF,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAC1E,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAEM,kBAAkB,CAAC,YAAoB,EAAE,MAAc;QAC5D,OAAO,IAAI,CAAC,WAAW;aACpB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,IAAI,YAAY,CAAC,EAAE,KAAK;aAClD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,IAAI,MAAM,CAAC,CAAC;IAC1C,CAAC;IAEM,IAAI,CAAC,KAAU;QACpB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC5B,CAAC;IAEM,oBAAoB,CAAC,YAAoB;QAC9C,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACjD,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,CAAC;IAC5C,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;QACnC,IAAI,CAAC,eAAe,EAAE,CAAA;IACxB,CAAC;IAEM,aAAa;QAClB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;IAEM,0BAA0B,CAAC,IAAS;QACzC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC;8GAxKU,eAAe;kGAAf,eAAe,k5BC5B5B,g7VAmSiB;;2FDvQJ,eAAe;kBAL3B,SAAS;+BACE,SAAS;wIAMV,WAAW;sBAAnB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEI,cAAc;sBAAvB,MAAM;gBACG,qBAAqB;sBAA9B,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,wBAAwB;sBAAjC,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBAEsB,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB;gBACF,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBACK,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBAmHnB,cAAc;sBADpB,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","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 { OverlayPanel } from 'primeng/overlaypanel';\nimport { Sidebar } from 'primeng/sidebar';\nimport { AplicativoModel } from '../../api/models/aplicativo-model';\nimport { MasterComboModel } from '../../api/models/master-combo-model';\nimport { MenuModel } from '../../api/models/menu-model';\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() ultimoAplicativoSelecionado!: number;\n\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() selecionarAplicativoEmit: EventEmitter<number> = 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\n  public 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  public callRoute(e: any, expand?: boolean) {\n    if (!expand)\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : '';\n\n    this.router.navigateByUrl(e)\n  }\n\n  private configurarLicencas() {\n    setTimeout(() => {\n      this.definirMenusPorSistema(this.ultimoAplicativoSelecionado || this.aplicativos[0]?.idaplicativo);\n    }, 1);\n  }\n\n  private definirMenusPorSistema(idaplicativo: number) {\n    this.menus = this.aplicativos.find((x) => x.idaplicativo == idaplicativo)?.menus || [];\n\n    if (this.router.url && this.menus && 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 && 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  private expandMenuEvent() {\n    this.expandMenuEmit.emit(this.expandMenu);\n  }\n\n  public gerenciarKeePass(event: any) {\n    this.sistemasPanel.hide();\n    this.gerenciarKeePassEvent.emit(event)\n  }\n\n  public 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  private 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  private 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  public 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  public onMouseEnter(index: number) {\n    this.mouseOverIndex = index;\n  }\n\n  public onMouseFilhoEnter(index: number) {\n    this.mouseOverFilhoIndex = index;\n  }\n\n  public onMouseLeave() {\n    this.mouseOverIndex = null;\n    this.mouseOverFilhoIndex = null;\n  }\n\n  @HostListener('window:resize', ['$event'])\n  public 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  public retornarMenuFilhos(idaplicativo: number, idmenu: number) {\n    return this.aplicativos\n      .find((x) => x.idaplicativo == idaplicativo)?.menus\n      .filter((x) => x.idmenupai == idmenu);\n  }\n\n  public sair(event: any) {\n    this.sistemasPanel.hide();\n    this.sairEvent.emit(event)\n  }\n\n  public selecionarAplicativo(idaplicativo: number) {\n    this.selecionarAplicativoEmit.emit(idaplicativo);\n    this.definirMenusPorSistema(idaplicativo);\n  }\n\n  public toggleMenu() {\n    this.expandMenu = !this.expandMenu;\n    this.expandMenuEvent()\n  }\n\n  public trocarLicenca() {\n    this.trocarLicencaEmit.emit();\n  }\n\n  public 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  >\n    <ng-template pTemplate=\"headless\">\n      <div class=\"flex flex-column mx-1\">\n        <div 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          >\n            <img\n              *ngIf=\"expandMenu\"\n              alt=\"Card\"\n              [src]=\"logoImage\"\n              width=\"150\"\n            />\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            >\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          >\n            <div\n              class=\"flex flex-column cursor-pointer\"\n              *ngIf=\"expandMenu\"\n              (click)=\"trocarLicenca()\"\n            >\n              <span\n                class=\"text-sm font-semibold mr-2\"\n                [pTooltip]=\"this.licencaSelecionada.nome\"\n                [tooltipPosition]=\"'right'\"\n              >\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            >\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        >\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\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              >\n                {{ menu.icone }}\n              </i>\n              <span\n                class=\"text-base text-blue-900 font-medium {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\n                *ngIf=\"expandMenu\"\n              >{{ 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              >\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                  >\n                    {{ menu.icone }}\n                  </i>\n                  <span\n                    class=\"text-base text-blue-900 font-medium\"\n                    *ngIf=\"expandMenu\"\n                  >{{ 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}\"\n                ></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              >\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            >\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              >\n                {{ filho.icone }}\n              </i>\n              <span\n                class=\"text-base text-blue-900 ml-4 {{verificarPaginaSelecionada(filho.link) ? 'text-white' : ''}}\"\n                *ngIf=\"expandMenu\"\n              >{{ 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\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 -\n        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)\"\n      ></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'\"\n      ></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)\"\n      ></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  >\n    <div\n      class=\"card-container w-full overflow-y-hidden\"\n      [style]=\"{width: widthCard + 'px'}\"\n    >\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>\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    >\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)=\"selecionarAplicativo(aplicativo.idaplicativo)\"\n        [pTooltip]=\"aplicativo?.descricaoaplicativo\"\n        [tooltipPosition]=\"'left'\"\n      >\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\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=\"Acessar Keepass\"\n      (onClick)=\"gerenciarKeePass($event)\"\n      styleClass=\"border-noround w-full text-blue-900\"\n      [text]=\"true\"\n    ></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\"\n    ></p-button>\n  </ng-template>\n\n</p-overlayPanel>"]}
198
+ //# 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 { 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: any[] = [];\n  @Input() ultimoAplicativoSelecionado!: number;\n\n  @Input() breadCrumbItems: { label: string, routerLink: string }[] = [];\n  @Input() licencas: any[] = [];\n  @Input() licencaSelecionada!: any;\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() selecionarAplicativoEmit: EventEmitter<number> = 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: any[] = [];\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\n  public 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  public callRoute(e: any, expand?: boolean) {\n    if (!expand)\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : '';\n\n    this.router.navigateByUrl(e)\n  }\n\n  private configurarLicencas() {\n    setTimeout(() => {\n      this.definirMenusPorSistema(this.ultimoAplicativoSelecionado || this.aplicativos[0]?.idaplicativo);\n    }, 1);\n  }\n\n  private definirMenusPorSistema(idaplicativo: number) {\n    this.menus = this.aplicativos.find((x) => x.idaplicativo == idaplicativo)?.menus || [];\n\n    if (this.router.url && this.menus && 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 && 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  private expandMenuEvent() {\n    this.expandMenuEmit.emit(this.expandMenu);\n  }\n\n  public gerenciarKeePass(event: any) {\n    this.sistemasPanel.hide();\n    this.gerenciarKeePassEvent.emit(event)\n  }\n\n  public 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  private 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  private 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  public 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  public onMouseEnter(index: number) {\n    this.mouseOverIndex = index;\n  }\n\n  public onMouseFilhoEnter(index: number) {\n    this.mouseOverFilhoIndex = index;\n  }\n\n  public onMouseLeave() {\n    this.mouseOverIndex = null;\n    this.mouseOverFilhoIndex = null;\n  }\n\n  @HostListener('window:resize', ['$event'])\n  public 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  public retornarMenuFilhos(idaplicativo: number, idmenu: number) {\n    return this.aplicativos\n      .find((x) => x.idaplicativo == idaplicativo)?.menus\n      .filter((x: any) => x.idmenupai == idmenu);\n  }\n\n  public sair(event: any) {\n    this.sistemasPanel.hide();\n    this.sairEvent.emit(event)\n  }\n\n  public selecionarAplicativo(idaplicativo: number) {\n    this.selecionarAplicativoEmit.emit(idaplicativo);\n    this.definirMenusPorSistema(idaplicativo);\n  }\n\n  public toggleMenu() {\n    this.expandMenu = !this.expandMenu;\n    this.expandMenuEvent()\n  }\n\n  public trocarLicenca() {\n    this.trocarLicencaEmit.emit();\n  }\n\n  public 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  >\n    <ng-template pTemplate=\"headless\">\n      <div class=\"flex flex-column mx-1\">\n        <div 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          >\n            <img\n              *ngIf=\"expandMenu\"\n              alt=\"Card\"\n              [src]=\"logoImage\"\n              width=\"150\"\n            />\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            >\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          >\n            <div\n              class=\"flex flex-column cursor-pointer\"\n              *ngIf=\"expandMenu\"\n              (click)=\"trocarLicenca()\"\n            >\n              <span\n                class=\"text-sm font-semibold mr-2\"\n                [pTooltip]=\"this.licencaSelecionada.nome\"\n                [tooltipPosition]=\"'right'\"\n              >\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            >\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        >\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\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              >\n                {{ menu.icone }}\n              </i>\n              <span\n                class=\"text-base text-blue-900 font-medium {{verificarPaginaSelecionada(menu.link) ? 'text-white' : ''}}\"\n                *ngIf=\"expandMenu\"\n              >{{ 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              >\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                  >\n                    {{ menu.icone }}\n                  </i>\n                  <span\n                    class=\"text-base text-blue-900 font-medium\"\n                    *ngIf=\"expandMenu\"\n                  >{{ 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}\"\n                ></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              >\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            >\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              >\n                {{ filho.icone }}\n              </i>\n              <span\n                class=\"text-base text-blue-900 ml-4 {{verificarPaginaSelecionada(filho.link) ? 'text-white' : ''}}\"\n                *ngIf=\"expandMenu\"\n              >{{ 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\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 -\n        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)\"\n      ></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'\"\n      ></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)\"\n      ></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  >\n    <div\n      class=\"card-container w-full overflow-y-hidden\"\n      [style]=\"{width: widthCard + 'px'}\"\n    >\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>\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    >\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)=\"selecionarAplicativo(aplicativo.idaplicativo)\"\n        [pTooltip]=\"aplicativo?.descricaoaplicativo\"\n        [tooltipPosition]=\"'left'\"\n      >\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\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=\"Acessar Keepass\"\n      (onClick)=\"gerenciarKeePass($event)\"\n      styleClass=\"border-noround w-full text-blue-900\"\n      [text]=\"true\"\n    ></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\"\n    ></p-button>\n  </ng-template>\n\n</p-overlayPanel>"]}