keevo-components 1.8.536 → 1.8.538
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/components/kv-layout/layout/kv-layout.component.mjs +9 -9
- package/fesm2022/keevo-components.mjs +8 -8
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-layout/layout/kv-layout.component.d.ts +4 -4
- package/package.json +1 -1
- package/src/lib/components/kv-inputs/kv-dropdown/kv-dropdown.component.scss +56 -0
|
@@ -28,10 +28,10 @@ export class KvLayoutComponent {
|
|
|
28
28
|
* @type {Array<{id: number, numNotifications?: number, action?: (e: any) => void}>}
|
|
29
29
|
*
|
|
30
30
|
* Opções disponíveis:
|
|
31
|
-
* - 2 -
|
|
32
|
-
* - 3 -
|
|
33
|
-
* - 4 -
|
|
34
|
-
* - 5 -
|
|
31
|
+
* - 2 - Kiara
|
|
32
|
+
* - 3 - Notificações
|
|
33
|
+
* - 4 - Tarefas
|
|
34
|
+
* - 5 - Comunicador
|
|
35
35
|
*
|
|
36
36
|
* @property {number} id - identificador do menu.
|
|
37
37
|
* @property {number} [numNotifications] - Número de notificações (opcional).
|
|
@@ -41,10 +41,10 @@ export class KvLayoutComponent {
|
|
|
41
41
|
this.topMenusVisible = input([]);
|
|
42
42
|
this.topMenuOptions = [
|
|
43
43
|
{ id: 1, visible: true, icon: 'ti-user', tooltip: 'Meus Dados', numNotifications: 0, action: (e) => { this.meusDadosPanel.toggle(e); } },
|
|
44
|
-
{ id: 2, visible: false, icon: 'ti-
|
|
45
|
-
{ id: 3, visible: false, icon: 'ti-
|
|
46
|
-
{ id: 4, visible: false, icon: 'ti-
|
|
47
|
-
{ id: 5, visible: false, icon: 'ti-
|
|
44
|
+
{ id: 2, visible: false, icon: 'ti-sparkles', tooltip: 'Kiara', numNotifications: 0, action: () => { } },
|
|
45
|
+
{ id: 3, visible: false, icon: 'ti-bell', tooltip: 'Notificações', numNotifications: 0, action: () => { } },
|
|
46
|
+
{ id: 4, visible: false, icon: 'ti-list-check', tooltip: 'Tarefas', numNotifications: 0, action: () => { } },
|
|
47
|
+
{ id: 5, visible: false, icon: 'ti-message', tooltip: 'Comunicador', numNotifications: 0, action: () => { } },
|
|
48
48
|
];
|
|
49
49
|
this.profileImage = input('');
|
|
50
50
|
this.breadCrumbItems = [];
|
|
@@ -346,4 +346,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
346
346
|
type: HostListener,
|
|
347
347
|
args: ['window:resize', ['$event']]
|
|
348
348
|
}] } });
|
|
349
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-layout.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-layout/layout/kv-layout.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-layout/layout/kv-layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\r\n\r\nimport {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  computed,\r\n  contentChildren,\r\n  effect,\r\n  EventEmitter,\r\n  HostListener,\r\n  input,\r\n  Input,\r\n  model,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  signal,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  WritableSignal,\r\n} from '@angular/core';\r\n\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\nimport { Sidebar } from 'primeng/sidebar';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport {\r\n  animate,\r\n  state,\r\n  style,\r\n  transition,\r\n  trigger,\r\n} from '@angular/animations';\r\nimport { TopActionsModel } from '../top-icons/top-icons.component';\r\nimport { link } from 'd3';\r\nimport { MenuItem } from 'primeng/api';\r\n\r\nexport interface LayoutMenuItem {\r\n  idmenu: number;\r\n  idmenupai: number | null;\r\n  idaplicativo: number;\r\n  descricaomenu: string;\r\n  link: string | null;\r\n  icone: string | null;\r\n  indpublicado: boolean;\r\n  indmenupai: boolean;\r\n  listaidvisaomenu: number[];\r\n  bgColor?: string;\r\n  textColor?: string;\r\n} \r\n\r\n@Component({\r\n  selector: 'kv-layout',\r\n  templateUrl: './kv-layout.component.html',\r\n  styleUrls: ['./kv-layout.component.scss'],\r\n})\r\nexport class KvLayoutComponent implements OnInit, OnChanges {\r\n  @Input() apps: {\r\n    idaplicativo: number;\r\n    idsistema: number;\r\n    nomeaplicativo: string;\r\n    descricaoaplicativo: string;\r\n    rotapadrao: string;\r\n    indpublicado: boolean;\r\n    indpublicacaogradativa: boolean;\r\n    indexigeempresaentrada: boolean;\r\n    urlicone?: string;\r\n  }[] = [];\r\n\r\n  @Input() actions: { icon: string; label: string; action: () => void }[] = [];\r\n\r\n  /**\r\n   * Indica quais menus são visíveis no topo.\r\n   * \r\n   * @type {Array<{id: number, numNotifications?: number, action?: (e: any) => void}>}\r\n   * \r\n   * Opções disponíveis:\r\n   * - 2 - Notificações \r\n   * - 3 - Comunicador\r\n   * - 4 - Kiara\r\n   * - 5 - Tarefas\r\n   * \r\n   * @property {number} id - identificador do menu.\r\n   * @property {number} [numNotifications] - Número de notificações (opcional).\r\n   * @property {(e: any) => void} [action] - Ação do clique, que retorna o evento do clique (optional).\r\n   * \r\n   */\r\n  topMenusVisible = input<{id:number, numNotifications?:number, action?:(e:any) => void}[]>([]);\r\n\r\n  topMenuOptions: TopActionsModel[]=[\r\n    {id: 1, visible: true, icon: 'ti-user', tooltip: 'Meus Dados', numNotifications: 0, action: (e:any) => {this.meusDadosPanel.toggle(e)}},\r\n    {id: 2, visible: false, icon: 'ti-bell', tooltip: 'Notificações', numNotifications: 0, action: () => {}},\r\n    {id: 3, visible: false, icon: 'ti-message', tooltip: 'Comunicador', numNotifications: 0, action: () => {}},\r\n    {id: 4, visible: false, icon: 'ti-sparkles', tooltip: 'Kiara', numNotifications: 0, action: () => {}},\r\n    {id: 5, visible: false, icon: 'ti-list-check', tooltip: 'Tarefas', numNotifications: 0, action: () => {}}\r\n  ];\r\n  \r\n  profileImage = input<string>('');\r\n\r\n  @Input() breadCrumbItems: {\r\n    label: string;\r\n    routerLink: string;\r\n  }[] = [];\r\n\r\n  @Input() masters: {\r\n    idmaster: number;\r\n    cpfcnpj: string;\r\n    nome: string;\r\n    idmasternome: string;\r\n  }[] = [];\r\n\r\n  menus = model<LayoutMenuItem[]>([]);\r\n  menuVisivel = signal<number|undefined>(undefined);\r\n  showMenuSistemas = signal<boolean>(false);\r\n\r\n  expandMenu = model<boolean>(true);\r\n\r\n  @Input() logoMenuExpand!: any;\r\n  @Input() logoMenuHide!: any;\r\n\r\n  @Input() selectedApp!: number;\r\n  @Input() selectedEmpresa!: any;\r\n  @Input() selectedMaster!: number;\r\n\r\n  @Input() showButtonApps: boolean = true;\r\n  @Input() showButtonUser: boolean = true;\r\n  @Input() showExpandMenu: boolean = true;\r\n  @Input() showDropdownLicenca: boolean = true;\r\n  @Input() showMenu: boolean = true;\r\n  @Input() showTrocaEmpresa: boolean = false;\r\n  @Input() showBreadcrumb: boolean = true;\r\n  @Input() userName: string = 'Usuário';\r\n  @Input() masterName!: string;\r\n  @Input() empresaName!: string;\r\n\r\n  @Output() accessKeePassEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() changeEmpresaEmit: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() changeLicenseEmit: EventEmitter<number> = new EventEmitter();\r\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() logoutEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() selectAppEmit: EventEmitter<number> = new EventEmitter();\r\n  @Output() navigateToDefaultRouteEmit: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\r\n\r\n  // topMenuActions = contentChildren<TemplateRef<any>>('topMenuAction');\r\n\r\n  formGroup!: FormGroup;\r\n  heightCard!: number;\r\n  mouseOverFilhoIndex: any;\r\n  mouseOverIndex: any;\r\n  widthCard!: number;\r\n\r\n  widthPage = signal<number>(0);\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private fb: FormBuilder,\r\n    protected router: Router,\r\n    protected activatedRoute: ActivatedRoute\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.formGroup = this.fb.group({\r\n      idmaster: [this.selectedMaster, []],\r\n    });\r\n\r\n    this.processarMenus();\r\n    this.adjustWidthCard();\r\n    this.verifyMenuBehavior();\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  processarMenus() {\r\n    if(this.profileImage()){\r\n      this.topMenuOptions[0].img = this.profileImage();\r\n    }\r\n    //inverter o topMenuOptions\r\n    this.topMenuOptions.reverse();\r\n\r\n    this.topMenusVisible().forEach((item:any) => {\r\n      let menu = this.topMenuOptions.find((x) => x.id === item.id);\r\n      if(menu){\r\n        menu.visible = true;\r\n        if(item.action){\r\n          menu.action = item.action;\r\n        }\r\n        if(item.numNotifications){\r\n          menu.numNotifications = item.numNotifications;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  public accessKeePass(event: any) {\r\n    this.accessKeePassEmit.emit(event);\r\n  }\r\n\r\n  public adjustHeightCard(): number {\r\n    if (this.widthCard > 400) {\r\n      if (this.widthPage() < 992 && this.showLicencas()) return 145;\r\n\r\n      if (this.breadCrumbItems.length > 0) return 95;\r\n      else return 85;\r\n    }\r\n\r\n    return 125;\r\n  }\r\n\r\n  private adjustWidthCard() {\r\n    this.widthPage.set(window.innerWidth);\r\n\r\n    this.heightCard = Number(\r\n      document.getElementById('page-content')?.offsetHeight\r\n    );\r\n    if (this.showMenu)\r\n      this.widthCard =\r\n        Number(window.innerWidth) - (this.expandMenu() ? 333 : 93);\r\n    else this.widthCard = Number(window.innerWidth);\r\n  }\r\n\r\n  public callRoute(rota: any, expand?: boolean) {\r\n    if (!expand && !this.expandMenu() && this.showExpandMenu)\r\n      this.expandMenu.update((currentValue: boolean) => !currentValue);\r\n\r\n    if (this.widthPage() != 0 && this.widthPage() < 800 && this.expandMenu() && this.showExpandMenu)\r\n      this.expandMenu.set(false);\r\n\r\n    this.router.navigateByUrl(rota);\r\n  }\r\n\r\n  public changeEmpresa(event: any) {\r\n    this.changeEmpresaEmit.emit(event);\r\n  }\r\n\r\n  public changeLicense(event: any) {\r\n    this.changeLicenseEmit.emit(event);\r\n  }\r\n\r\n  private verifyMenuBehavior() {\r\n    if (this.widthPage() < 800)\r\n      this.expandMenu.set(false);\r\n  }\r\n\r\n  private expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu());\r\n  }\r\n\r\n  public logout(event: any) {\r\n    this.logoutEmit.emit(event);\r\n  }\r\n\r\n  private menusPerApp() {\r\n    if (this.router.url && this.menus() && this.menus().length > 0) {\r\n      if (this.router.url === '/') {\r\n        // this.navigateToFirstMenu();\r\n      } else {\r\n        const menuSelecionado = this.menus().find(\r\n          (menu: any) =>\r\n            menu.link && menu.link.includes(this.router.url.slice(1))\r\n        );\r\n        if (menuSelecionado) {\r\n          this.navigateToMenu(menuSelecionado);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  public nameEmpresa(nomeLicenca: any): string {\r\n    if (nomeLicenca) {\r\n      if (nomeLicenca.length > 23) return nomeLicenca.substring(0, 23) + '...';\r\n      else return nomeLicenca;\r\n    } else return '';\r\n  }\r\n\r\n  private navigateToFirstMenu(): void {\r\n    const firstMenu = this.menus()[0];\r\n    if (firstMenu.indmenupai) {\r\n      const filhos = this.returnMenuChild(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  private navigateToMenu(menu: any): void {\r\n    if (menu.menupai) {\r\n      const filhos = this.returnMenuChild(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  menuSelecionado = signal<any>(null);\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const latestRequest = changes['menus'];\r\n    if (latestRequest?.currentValue) {\r\n      this.menusPerApp();\r\n    }\r\n\r\n    this.selecionarMenu();\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  public onWindowResize() {\r\n    this.adjustWidthCard();\r\n    // this.verifyMenuBehavior();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isSelectedMenuPai(menu: any) {\r\n    if (!this.expandMenu() && menu.indmenupai)\r\n      return menu.idmenu === this.menuSelecionado()?.idmenupai;\r\n\r\n    return false;\r\n  }\r\n\r\n  selecionarMenu() {\r\n    const url = new URL(this.router.url, window.origin);\r\n\r\n    const currentPath = url.pathname;\r\n    const purePath = currentPath.match(/^[^;]*/i);\r\n\r\n    const paths = purePath![0];\r\n\r\n    this.menus.set(\r\n      this.menus().map((menu) => {\r\n        if (menu.link) {\r\n          return {\r\n            ...menu,\r\n            bgColor: paths.includes(menu.link!) ? 'rgb(41, 185, 45)' : '',\r\n            textColor: paths.includes(menu.link!) ? 'text-white' : '',\r\n          };\r\n        }\r\n        return menu;\r\n      })\r\n    )\r\n\r\n    const menu = this.menus().find((menu: any) => {\r\n      return menu.link && paths.includes(menu.link!);\r\n    });\r\n\r\n    this.menuSelecionado.set(menu);\r\n  }\r\n\r\n  public returnMenuChild(idmenu: number) {\r\n    return this.menus().filter((x: any) => x.idmenupai == idmenu);\r\n  }\r\n\r\n\r\n  public selectApp(idaplicativo: number) {\r\n    this.selectAppEmit.emit(idaplicativo);\r\n  }\r\n\r\n  public showLicencas(): boolean {\r\n    return this.showDropdownLicenca && (this.masters || []).length > 1;\r\n  }\r\n\r\n  public toggleMenu() {\r\n    this.expandMenu.update((currentValue: boolean) => !currentValue);\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  navigateToDefaultRoute() {\r\n    if (this.widthPage() < 800 && this.expandMenu())\r\n      this.expandMenu.set(false);\r\n\r\n    this.navigateToDefaultRouteEmit.emit();\r\n  }\r\n\r\n  get exibirNomes() {\r\n    return !this.showLicencas() && (this.masterName || this.empresaName);\r\n  }\r\n\r\n  exibirMenuChild(event:any, index:number){\r\n    this.menuVisivel.set(index);\r\n      let menuParent ;\r\n      let menuChild ;\r\n      if(index === -1){\r\n        menuParent = document.getElementById(`menu-sistemas-parent`);\r\n        menuChild = document.getElementById(`menu-sistemas-child`);\r\n      }\r\n      else{\r\n        menuParent = document.getElementById(`menu-parent-${index}`);\r\n        menuChild = document.getElementById(`menu-child-${index}`);\r\n      }\r\n\r\n      if (menuParent) {\r\n        const rect_parent = menuParent.getBoundingClientRect();\r\n        let x = rect_parent.right - 10;\r\n        let y = rect_parent.top -5;\r\n  \r\n        if (menuChild) {\r\n          const rect_child = menuChild.getBoundingClientRect();\r\n          const viewportHeight = window.innerHeight;\r\n  \r\n          //Verifica se o menu filho vai utrapassar o final do viewport pra baixo\r\n          if (rect_parent.bottom + rect_child.height > viewportHeight) {\r\n            y = rect_parent.bottom - rect_child.height - 10;\r\n          }\r\n  \r\n          // Verifica se o menu pai está muito em cima\r\n          if (rect_parent.top <= 0) {\r\n            y = rect_parent.bottom + 5;\r\n          }\r\n  \r\n          menuChild.style.top = `${y}px`;\r\n          menuChild.style.left = `${x}px`;\r\n        }\r\n      }\r\n  }\r\n\r\n}\r\n","<div class=\"flex flex-row full-container\">\r\n  @if(showMenu) {\r\n    <p-sidebar\r\n      #sidebarRef\r\n      [visible]=\"true\"\r\n      [showCloseIcon]=\"false\"\r\n      [modal]=\"false\"\r\n      [style]=\"{ width: expandMenu() ? '17rem' : '3.65rem' }\"\r\n      styleClass=\"transition-all\"\r\n    >\r\n      <ng-template pTemplate=\"headless\">\r\n        <div class=\"h-full flex flex-column overflow-hidden p-2\">\r\n          \r\n          <!-- LOGO -->\r\n          <div class=\"flex-none flex flex-column gap-1 justify-content-between flex-shrink-0 overflow-hidden\">\r\n            <div\r\n              class=\"flex {{\r\n                expandMenu() ? 'flex-row' : 'flex-column'\r\n              }} align-items-center {{\r\n                expandMenu()\r\n                  ? 'justify-content-between'\r\n                  : 'justify-content-center'\r\n              }} p-2\"\r\n            >\r\n              <!-- Logo para o menu expandido -->\r\n              @if(expandMenu() && logoMenuExpand){\r\n                <img\r\n                  alt=\"Card\"\r\n                  [src]=\"logoMenuExpand\"\r\n                  [style.height]=\"'2.4rem'\"\r\n                  width=\"auto\"\r\n                  class=\"cursor-pointer p-0\"\r\n                  (click)=\"navigateToDefaultRoute()\"\r\n                />\r\n              }\r\n\r\n              <!-- Logo para o menu minimizado-->\r\n              @if(!expandMenu() && logoMenuHide){\r\n                <img\r\n                  alt=\"Card\"\r\n                  [src]=\"logoMenuHide\"\r\n                  [style.height]=\"'2.4rem'\"\r\n                  width=\"auto\"\r\n                  class=\"cursor-pointer p-1\"\r\n                  (click)=\"navigateToDefaultRoute()\"\r\n                />\r\n              }\r\n\r\n              <!-- Toggle menu -->\r\n              @if(showExpandMenu){\r\n                <kv-icon\r\n                  name=\"ti-menu-2\"\r\n                  [clickable]=\"true\"\r\n                  [pTooltip]=\"expandMenu() ? 'Ocultar Menu' : 'Expandir Menu'\"\r\n                  [tooltipPosition]=\"'right'\"\r\n                  (onClick)=\"toggleMenu()\"\r\n                />\r\n              }\r\n            </div>\r\n\r\n            @if(showTrocaEmpresa){\r\n              <div\r\n                class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item troca-sistema-container mb-2\" \r\n                [pTooltip]=\"'Trocar de empresa'\"\r\n                [tooltipPosition]=\"'right'\"\r\n                (click)=\"changeEmpresa($event)\"\r\n              >\r\n              <kv-icon\r\n                name=\"ti-building-skyscraper\"\r\n                size=\"1.1rem\"\r\n              />\r\n                @if(expandMenu() && selectedEmpresa){\r\n                  <div\r\n                    class=\"flex flex-column w-full\"\r\n                    (click)=\"changeEmpresa($event)\"\r\n                  >\r\n                    @if(this.selectedEmpresa.razaosocial){\r\n                      <span\r\n                        class=\"text-xs font-semibold mr-2 color-system\"\r\n                        [style.fontSuze]=\"'.5rem'\"\r\n                      >\r\n                        {{ nameEmpresa(this.selectedEmpresa.razaosocial) }}\r\n                      </span>\r\n                    }\r\n                    @if(this.selectedEmpresa.cpfcnpj){\r\n                      <span class=\"text-xs mt-1 color-system\" [style.fontSuze]=\"'.5rem'\">{{\r\n                        this.selectedEmpresa.cpfcnpj | cpfCnpj\r\n                      }}</span>\r\n                    }\r\n                  </div>\r\n                  \r\n                }\r\n              </div>\r\n            }\r\n            @else {\r\n              <!-- <div style=\"width:100%; height:.75rem\"></div> -->\r\n              <p-divider class=\"px-2\" [style.opacity]=\"1\" type=\"solid\"></p-divider>\r\n            }\r\n          </div>\r\n\r\n\r\n          <!-- MENUS -->\r\n          <div class=\"flex-1 list-none m-0 overflow-y-auto max-h-full\">\r\n            <!-- menus -->\r\n            @for (menu of menus(); track $index) {\r\n              <li>\r\n                <!-- menu que não tem filho -->\r\n                  @if( !menu.indmenupai && (!menu.idmenupai || menu.idmenupai == 0)){\r\n                    <div\r\n                        class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\"\r\n                        style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                        (click)=\"callRoute(menu.link)\"\r\n                      >\r\n                        <kv-icon\r\n                          [name]=\"menu.icone|| 'ti-circle-dotted'\"\r\n                        />\r\n                        @if(expandMenu()){\r\n                          <label>{{menu.descricaomenu}}</label>\r\n                        }\r\n                    </div>\r\n                  }\r\n                <!-- menu com filho -->\r\n                  @if(menu.indmenupai){\r\n                    <div class=\"menu-parent\" id=\"menu-parent-{{$index}}\" (mouseenter)=\"exibirMenuChild($event, $index)\" (mouseleave)=\"menuVisivel.set(undefined)\" >\r\n                      <div\r\n                        class=\" flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\" style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                        \r\n                        \r\n                      >\r\n                        <kv-icon\r\n                          [name]=\"menu.icone|| 'ti-circle-dotted'\"\r\n                        />\r\n                        @if(expandMenu()){\r\n                          <label>{{menu.descricaomenu}}</label>\r\n                          <kv-icon\r\n                            #chevronIcon\r\n                            name=\"ti-chevron-right\"\r\n                          />\r\n                        }\r\n                      </div>\r\n\r\n                      <div class=\"menu-childs\" id=\"menu-child-{{$index}}\" [style.opacity]=\"menuVisivel()===$index?'1':'0'\" [style.pointerEvents]=\"menuVisivel()===$index?'auto':'none'\">\r\n                        <div class=\"h-2rem flex align-items-center\">\r\n                          <p class=\"p-0 m-0 font-bold pt-2 pl-3 text-xs\">\r\n                            {{menu.descricaomenu}}\r\n                          </p>\r\n                        </div>\r\n                        @for (item of returnMenuChild(menu.idmenu); track $index) {\r\n\r\n                          <div \r\n                            class=\" side-menu-item py-2 pl-3 pr-1 text-sm\"\r\n                            (click)=\"callRoute(item.link)\"\r\n                          >\r\n                            {{item.descricaomenu}}\r\n                          </div>\r\n                        }\r\n                      </div>\r\n                    </div>\r\n                  }\r\n              </li>\r\n            }\r\n          </div>\r\n\r\n          <p-divider class=\"px-2\" [style.opacity]=\"1\" type=\"solid\"></p-divider>\r\n          \r\n          <!-- APPS E SAIR -->\r\n          <div class=\"flex-none list-none m-0 overflow-y-auto max-h-full\">\r\n            <li>\r\n              <div class=\"menu-parent\" id=\"menu-sistemas-parent\" (mouseenter)=\"exibirMenuChild($event, -1)\" (mouseleave)=\"menuVisivel.set(undefined)\" >\r\n                <div\r\n                  class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\"\r\n                  style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                  [pTooltip]=\"!expandMenu() ? 'Sistemas' : ''\"\r\n                >\r\n                  <kv-icon\r\n                    [name]=\"'ti-apps'\"\r\n                  />\r\n                  @if(expandMenu()){\r\n                    <label>Sistemas</label>\r\n                    <kv-icon\r\n                      #chevronIcon\r\n                      name=\"ti-chevron-right\"\r\n                    />\r\n                  }\r\n                </div>\r\n\r\n                <div class=\"menu-childs\" id=\"menu-sistemas-child\" [style.opacity]=\"menuVisivel()===-1?'1':'0'\" [style.pointerEvents]=\"menuVisivel()===-1?'auto':'none'\">\r\n                  <p class=\"p-0 m-0 font-bold pt-2 pl-3 text-xs\">Sistemas</p>\r\n                  @for (item of apps; track $index) {\r\n                      <div class=\"flex flex-row align-items-center gap-2 side-menu-item py-2 pl-3 pr-1\" (click)=\"callRoute(item.rotapadrao) ; selectApp(item.idaplicativo)\">\r\n                        <img\r\n                          [src]=\"item.urlicone\"\r\n                          class=\"h-2rem w-2rem border-round-lg\"\r\n                        />\r\n                        <div class=\"text-sm\">\r\n                          {{item.nomeaplicativo}}\r\n                        </div>\r\n                      </div>\r\n                  }\r\n                </div>\r\n    \r\n              </div>\r\n            </li>\r\n            <li>\r\n              <div\r\n                class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\"\r\n                style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                [pTooltip]=\"!expandMenu() ? 'Sair' : ''\"\r\n                [style.color]=\"'red'\"\r\n                [style.opacity]=\"0.5\"\r\n                (click)=\"logout($event)\"\r\n              >\r\n                <kv-icon\r\n                  [name]=\"'ti-logout'\"\r\n                  \r\n                />\r\n                @if(expandMenu()){\r\n                  <label>Sair</label>\r\n                }\r\n              </div>\r\n            </li>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n    </p-sidebar>\r\n  }\r\n\r\n  <!-- SEÇÃO CONTEÚDO  -->\r\n  <div\r\n    class=\"w-auto h-screen page-content overflow-y-hidden flex flex-column\"\r\n    id=\"page-content\"\r\n    style=\"width: 100vw !important\"\r\n  >\r\n    <!-- TOPO -->\r\n    <div\r\n      class=\"flex flex-row flex-wrap align-items-center justify-content-between my-2 mx-3 mb-0\"\r\n    >\r\n      @if(!showMenu) {\r\n      <!-- Logo home -->\r\n        <div>\r\n          <img [src]=\"logoMenuExpand\" width=\"150\" />\r\n        </div>\r\n      } \r\n      @else {\r\n        <!-- Breadcrumbs -->\r\n        @if(showBreadcrumb) {\r\n          <div class=\"h-full\">\r\n              <p-breadcrumb\r\n                *ngIf=\"widthCard > 400\"\r\n                styleClass=\"border-none p-0 flex align-items-center h-2rem bg-transparent\"\r\n                [model]=\"breadCrumbItems\"\r\n                (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n              >\r\n              <ng-template pTemplate=\"item\" let-item let-i=\"index\">\r\n                  @if(breadCrumbItems.indexOf(item) < breadCrumbItems.length - 1){\r\n                    <span class=\"font-normal\">{{ item.label }}</span>\r\n                  }\r\n                  @else {\r\n                    <span class=\"font-bold\">{{ item.label }}</span>\r\n                  }\r\n              </ng-template>\r\n            </p-breadcrumb>\r\n          </div>\r\n        }\r\n        @else {\r\n          <!-- GHOST DIV PARA OCPUAR ESPAÇO NO SPACE BETWEEN -->\r\n          <div></div>\r\n        }\r\n      } \r\n      @if (exibirNomes) { \r\n        @if(widthCard >= 517) {\r\n          <div\r\n            class=\"w-auto flex flex-column justify-content-center align-items-center gap-2\"\r\n          >\r\n            @if (masterName) { <span class=\"font-semibold system-color\">{{ masterName }}</span> }\r\n            @if (empresaName) {<span class=\"empresa-name\"\r\n              >Organização: {{ empresaName }}</span\r\n            >\r\n            }\r\n          </div>\r\n\r\n          <div\r\n            class=\"w-auto flex flex-row justify-content-center align-items-center gap-2\"\r\n          >\r\n            <!-- Navegação de sistemas e usuários -->\r\n            <!-- @for (topAction of topMenuActions(); track $index) {\r\n            <ng-container *ngTemplateOutlet=\"topAction\" />\r\n            } -->\r\n            <kv-top-icons\r\n              [topActions]=\"topMenuOptions\"\r\n            />\r\n\r\n          </div>\r\n        } \r\n        @else {\r\n          <div\r\n            class=\"w-auto flex flex-row justify-content-center align-items-center gap-2\"\r\n          >\r\n            <!-- Navegação de sistemas e usuários -->\r\n            <!-- @for (topAction of topMenuActions(); track $index) {\r\n            <ng-container *ngTemplateOutlet=\"topAction\" />\r\n            } -->\r\n            <kv-top-icons\r\n              [topActions]=\"topMenuOptions\"\r\n            />\r\n\r\n          </div>\r\n\r\n          <div\r\n            class=\"w-auto flex flex-column justify-content-center align-items-center gap-2\"\r\n          >\r\n            @if (masterName) { <span class=\"master-name\">{{ masterName }}</span> }\r\n            @if (empresaName) {<span class=\"empresa-name\">{{ empresaName }}</span> }\r\n          </div>\r\n        } \r\n      } \r\n      @else { \r\n        @if(widthPage() > 992){\r\n          <!-- dropdown para seleção de empresa/licenca -->\r\n          <dropdown-master\r\n            *ngIf=\"showLicencas()\"\r\n            class=\"max-w-25rem flex-1\"\r\n            formControlName=\"idmaster\"\r\n            [formGroup]=\"formGroup\"\r\n            [masters]=\"masters\"\r\n            (onSelectionChange)=\"changeLicense($event)\"\r\n            (onSelectionValue)=\"changeLicense($event)\"\r\n          >\r\n          </dropdown-master>\r\n        }\r\n\r\n        <!-- Navegação de sistemas e usuários -->\r\n        <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n\r\n          <kv-top-icons\r\n            [topActions]=\"topMenuOptions\"\r\n          />\r\n\r\n        </div>\r\n      }\r\n    </div>\r\n\r\n    @if(widthPage() <= 992){\r\n      <!-- dropdown para seleção de empresa/licenca -->\r\n      <div class=\"h-2rem mx-3\">\r\n        <dropdown-master\r\n          *ngIf=\"showLicencas()\"\r\n          formControlName=\"idmaster\"\r\n          [formGroup]=\"formGroup\"\r\n          [masters]=\"masters\"\r\n          (onSelectionChange)=\"changeLicense($event)\"\r\n          (onSelectionValue)=\"changeLicense($event)\"\r\n        />\r\n      </div>\r\n\r\n    } \r\n\r\n    <!-- Container -->\r\n    <div class=\"overflow-hidden flex-1 p-0 m-0 mb-2 h-full\">\r\n      <p-card\r\n        styleClass=\"overflow-y-auto h-full max-h-full {{\r\n          !showMenu && 'sm:overflow-y-hidden'\r\n        }} card-container\"\r\n      >\r\n        <ng-content></ng-content>\r\n        \r\n      </p-card>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Painel do usuário -->\r\n  <p-overlayPanel\r\n    #meusDadosPanel\r\n    [showTransitionOptions]=\"'350ms ease-out'\"\r\n    [hideTransitionOptions]=\"'250ms ease-in'\"\r\n  >\r\n  <ng-template pTemplate=\"container\">\r\n    <p class=\"system-color font-medium text-lg px-2 py-3 m-0\">\r\n      Olá, {{ userName ? userName.split(\" \")[0] : \"Usuário\" }}!\r\n    </p>\r\n    <!-- <div class=\"mt-5 mb-3\"></div> -->\r\n  \r\n    <!-- Contêiner com direção em coluna para empilhar os botões -->\r\n    <div class=\"flex flex-column\">\r\n      <!-- Botões adicionais dinâmicos -->\r\n      @for (action of actions; track $index) {\r\n        <ng-container>\r\n          <div class=\"flex flex-row align-items-center gap-2 side-menu-item py-2 px-2\"\r\n            (click)=\"action.action()\"\r\n          >\r\n            <kv-icon\r\n              [name]=\"action.icon\"\r\n            />\r\n            <span>{{action.label}}</span>\r\n          </div>\r\n        </ng-container>\r\n      }\r\n\r\n      <div class=\"flex flex-row align-items-center gap-2 side-menu-item py-2 px-2\"\r\n        (click)=\"accessKeePass($event)\"\r\n      >\r\n          <kv-icon\r\n            name=\"ti-lock\"\r\n          />\r\n          <span>Acessar KeePass</span>\r\n      </div>\r\n  \r\n    </div>\r\n  </ng-template>\r\n  \r\n  </p-overlayPanel>\r\n</div>\r\n"]}
|
|
349
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-layout.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-layout/layout/kv-layout.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-layout/layout/kv-layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\r\n\r\nimport {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  computed,\r\n  contentChildren,\r\n  effect,\r\n  EventEmitter,\r\n  HostListener,\r\n  input,\r\n  Input,\r\n  model,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  signal,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  WritableSignal,\r\n} from '@angular/core';\r\n\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\nimport { Sidebar } from 'primeng/sidebar';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport {\r\n  animate,\r\n  state,\r\n  style,\r\n  transition,\r\n  trigger,\r\n} from '@angular/animations';\r\nimport { TopActionsModel } from '../top-icons/top-icons.component';\r\nimport { link } from 'd3';\r\nimport { MenuItem } from 'primeng/api';\r\n\r\nexport interface LayoutMenuItem {\r\n  idmenu: number;\r\n  idmenupai: number | null;\r\n  idaplicativo: number;\r\n  descricaomenu: string;\r\n  link: string | null;\r\n  icone: string | null;\r\n  indpublicado: boolean;\r\n  indmenupai: boolean;\r\n  listaidvisaomenu: number[];\r\n  bgColor?: string;\r\n  textColor?: string;\r\n} \r\n\r\n@Component({\r\n  selector: 'kv-layout',\r\n  templateUrl: './kv-layout.component.html',\r\n  styleUrls: ['./kv-layout.component.scss'],\r\n})\r\nexport class KvLayoutComponent implements OnInit, OnChanges {\r\n  @Input() apps: {\r\n    idaplicativo: number;\r\n    idsistema: number;\r\n    nomeaplicativo: string;\r\n    descricaoaplicativo: string;\r\n    rotapadrao: string;\r\n    indpublicado: boolean;\r\n    indpublicacaogradativa: boolean;\r\n    indexigeempresaentrada: boolean;\r\n    urlicone?: string;\r\n  }[] = [];\r\n\r\n  @Input() actions: { icon: string; label: string; action: () => void }[] = [];\r\n\r\n  /**\r\n   * Indica quais menus são visíveis no topo.\r\n   * \r\n   * @type {Array<{id: number, numNotifications?: number, action?: (e: any) => void}>}\r\n   * \r\n   * Opções disponíveis:\r\n   * - 2 - Kiara \r\n   * - 3 - Notificações\r\n   * - 4 - Tarefas\r\n   * - 5 - Comunicador\r\n   * \r\n   * @property {number} id - identificador do menu.\r\n   * @property {number} [numNotifications] - Número de notificações (opcional).\r\n   * @property {(e: any) => void} [action] - Ação do clique, que retorna o evento do clique (optional).\r\n   * \r\n   */\r\n  topMenusVisible = input<{id:number, numNotifications?:number, action?:(e:any) => void}[]>([]);\r\n\r\n  topMenuOptions: TopActionsModel[]=[\r\n    {id: 1, visible: true, icon: 'ti-user', tooltip: 'Meus Dados', numNotifications: 0, action: (e:any) => {this.meusDadosPanel.toggle(e)}},\r\n    {id: 2, visible: false, icon: 'ti-sparkles', tooltip: 'Kiara', numNotifications: 0, action: () => {}},\r\n    {id: 3, visible: false, icon: 'ti-bell', tooltip: 'Notificações', numNotifications: 0, action: () => {}},\r\n    {id: 4, visible: false, icon: 'ti-list-check', tooltip: 'Tarefas', numNotifications: 0, action: () => {}},\r\n    {id: 5, visible: false, icon: 'ti-message', tooltip: 'Comunicador', numNotifications: 0, action: () => {}},\r\n  ];\r\n  \r\n  profileImage = input<string>('');\r\n\r\n  @Input() breadCrumbItems: {\r\n    label: string;\r\n    routerLink: string;\r\n  }[] = [];\r\n\r\n  @Input() masters: {\r\n    idmaster: number;\r\n    cpfcnpj: string;\r\n    nome: string;\r\n    idmasternome: string;\r\n  }[] = [];\r\n\r\n  menus = model<LayoutMenuItem[]>([]);\r\n  menuVisivel = signal<number|undefined>(undefined);\r\n  showMenuSistemas = signal<boolean>(false);\r\n\r\n  expandMenu = model<boolean>(true);\r\n\r\n  @Input() logoMenuExpand!: any;\r\n  @Input() logoMenuHide!: any;\r\n\r\n  @Input() selectedApp!: number;\r\n  @Input() selectedEmpresa!: any;\r\n  @Input() selectedMaster!: number;\r\n\r\n  @Input() showButtonApps: boolean = true;\r\n  @Input() showButtonUser: boolean = true;\r\n  @Input() showExpandMenu: boolean = true;\r\n  @Input() showDropdownLicenca: boolean = true;\r\n  @Input() showMenu: boolean = true;\r\n  @Input() showTrocaEmpresa: boolean = false;\r\n  @Input() showBreadcrumb: boolean = true;\r\n  @Input() userName: string = 'Usuário';\r\n  @Input() masterName!: string;\r\n  @Input() empresaName!: string;\r\n\r\n  @Output() accessKeePassEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() changeEmpresaEmit: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() changeLicenseEmit: EventEmitter<number> = new EventEmitter();\r\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() logoutEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() selectAppEmit: EventEmitter<number> = new EventEmitter();\r\n  @Output() navigateToDefaultRouteEmit: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\r\n\r\n  // topMenuActions = contentChildren<TemplateRef<any>>('topMenuAction');\r\n\r\n  formGroup!: FormGroup;\r\n  heightCard!: number;\r\n  mouseOverFilhoIndex: any;\r\n  mouseOverIndex: any;\r\n  widthCard!: number;\r\n\r\n  widthPage = signal<number>(0);\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private fb: FormBuilder,\r\n    protected router: Router,\r\n    protected activatedRoute: ActivatedRoute\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.formGroup = this.fb.group({\r\n      idmaster: [this.selectedMaster, []],\r\n    });\r\n\r\n    this.processarMenus();\r\n    this.adjustWidthCard();\r\n    this.verifyMenuBehavior();\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  processarMenus() {\r\n    if(this.profileImage()){\r\n      this.topMenuOptions[0].img = this.profileImage();\r\n    }\r\n    //inverter o topMenuOptions\r\n    this.topMenuOptions.reverse();\r\n\r\n    this.topMenusVisible().forEach((item:any) => {\r\n      let menu = this.topMenuOptions.find((x) => x.id === item.id);\r\n      if(menu){\r\n        menu.visible = true;\r\n        if(item.action){\r\n          menu.action = item.action;\r\n        }\r\n        if(item.numNotifications){\r\n          menu.numNotifications = item.numNotifications;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  public accessKeePass(event: any) {\r\n    this.accessKeePassEmit.emit(event);\r\n  }\r\n\r\n  public adjustHeightCard(): number {\r\n    if (this.widthCard > 400) {\r\n      if (this.widthPage() < 992 && this.showLicencas()) return 145;\r\n\r\n      if (this.breadCrumbItems.length > 0) return 95;\r\n      else return 85;\r\n    }\r\n\r\n    return 125;\r\n  }\r\n\r\n  private adjustWidthCard() {\r\n    this.widthPage.set(window.innerWidth);\r\n\r\n    this.heightCard = Number(\r\n      document.getElementById('page-content')?.offsetHeight\r\n    );\r\n    if (this.showMenu)\r\n      this.widthCard =\r\n        Number(window.innerWidth) - (this.expandMenu() ? 333 : 93);\r\n    else this.widthCard = Number(window.innerWidth);\r\n  }\r\n\r\n  public callRoute(rota: any, expand?: boolean) {\r\n    if (!expand && !this.expandMenu() && this.showExpandMenu)\r\n      this.expandMenu.update((currentValue: boolean) => !currentValue);\r\n\r\n    if (this.widthPage() != 0 && this.widthPage() < 800 && this.expandMenu() && this.showExpandMenu)\r\n      this.expandMenu.set(false);\r\n\r\n    this.router.navigateByUrl(rota);\r\n  }\r\n\r\n  public changeEmpresa(event: any) {\r\n    this.changeEmpresaEmit.emit(event);\r\n  }\r\n\r\n  public changeLicense(event: any) {\r\n    this.changeLicenseEmit.emit(event);\r\n  }\r\n\r\n  private verifyMenuBehavior() {\r\n    if (this.widthPage() < 800)\r\n      this.expandMenu.set(false);\r\n  }\r\n\r\n  private expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu());\r\n  }\r\n\r\n  public logout(event: any) {\r\n    this.logoutEmit.emit(event);\r\n  }\r\n\r\n  private menusPerApp() {\r\n    if (this.router.url && this.menus() && this.menus().length > 0) {\r\n      if (this.router.url === '/') {\r\n        // this.navigateToFirstMenu();\r\n      } else {\r\n        const menuSelecionado = this.menus().find(\r\n          (menu: any) =>\r\n            menu.link && menu.link.includes(this.router.url.slice(1))\r\n        );\r\n        if (menuSelecionado) {\r\n          this.navigateToMenu(menuSelecionado);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  public nameEmpresa(nomeLicenca: any): string {\r\n    if (nomeLicenca) {\r\n      if (nomeLicenca.length > 23) return nomeLicenca.substring(0, 23) + '...';\r\n      else return nomeLicenca;\r\n    } else return '';\r\n  }\r\n\r\n  private navigateToFirstMenu(): void {\r\n    const firstMenu = this.menus()[0];\r\n    if (firstMenu.indmenupai) {\r\n      const filhos = this.returnMenuChild(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  private navigateToMenu(menu: any): void {\r\n    if (menu.menupai) {\r\n      const filhos = this.returnMenuChild(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  menuSelecionado = signal<any>(null);\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const latestRequest = changes['menus'];\r\n    if (latestRequest?.currentValue) {\r\n      this.menusPerApp();\r\n    }\r\n\r\n    this.selecionarMenu();\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  public onWindowResize() {\r\n    this.adjustWidthCard();\r\n    // this.verifyMenuBehavior();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  isSelectedMenuPai(menu: any) {\r\n    if (!this.expandMenu() && menu.indmenupai)\r\n      return menu.idmenu === this.menuSelecionado()?.idmenupai;\r\n\r\n    return false;\r\n  }\r\n\r\n  selecionarMenu() {\r\n    const url = new URL(this.router.url, window.origin);\r\n\r\n    const currentPath = url.pathname;\r\n    const purePath = currentPath.match(/^[^;]*/i);\r\n\r\n    const paths = purePath![0];\r\n\r\n    this.menus.set(\r\n      this.menus().map((menu) => {\r\n        if (menu.link) {\r\n          return {\r\n            ...menu,\r\n            bgColor: paths.includes(menu.link!) ? 'rgb(41, 185, 45)' : '',\r\n            textColor: paths.includes(menu.link!) ? 'text-white' : '',\r\n          };\r\n        }\r\n        return menu;\r\n      })\r\n    )\r\n\r\n    const menu = this.menus().find((menu: any) => {\r\n      return menu.link && paths.includes(menu.link!);\r\n    });\r\n\r\n    this.menuSelecionado.set(menu);\r\n  }\r\n\r\n  public returnMenuChild(idmenu: number) {\r\n    return this.menus().filter((x: any) => x.idmenupai == idmenu);\r\n  }\r\n\r\n\r\n  public selectApp(idaplicativo: number) {\r\n    this.selectAppEmit.emit(idaplicativo);\r\n  }\r\n\r\n  public showLicencas(): boolean {\r\n    return this.showDropdownLicenca && (this.masters || []).length > 1;\r\n  }\r\n\r\n  public toggleMenu() {\r\n    this.expandMenu.update((currentValue: boolean) => !currentValue);\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  navigateToDefaultRoute() {\r\n    if (this.widthPage() < 800 && this.expandMenu())\r\n      this.expandMenu.set(false);\r\n\r\n    this.navigateToDefaultRouteEmit.emit();\r\n  }\r\n\r\n  get exibirNomes() {\r\n    return !this.showLicencas() && (this.masterName || this.empresaName);\r\n  }\r\n\r\n  exibirMenuChild(event:any, index:number){\r\n    this.menuVisivel.set(index);\r\n      let menuParent ;\r\n      let menuChild ;\r\n      if(index === -1){\r\n        menuParent = document.getElementById(`menu-sistemas-parent`);\r\n        menuChild = document.getElementById(`menu-sistemas-child`);\r\n      }\r\n      else{\r\n        menuParent = document.getElementById(`menu-parent-${index}`);\r\n        menuChild = document.getElementById(`menu-child-${index}`);\r\n      }\r\n\r\n      if (menuParent) {\r\n        const rect_parent = menuParent.getBoundingClientRect();\r\n        let x = rect_parent.right - 10;\r\n        let y = rect_parent.top -5;\r\n  \r\n        if (menuChild) {\r\n          const rect_child = menuChild.getBoundingClientRect();\r\n          const viewportHeight = window.innerHeight;\r\n  \r\n          //Verifica se o menu filho vai utrapassar o final do viewport pra baixo\r\n          if (rect_parent.bottom + rect_child.height > viewportHeight) {\r\n            y = rect_parent.bottom - rect_child.height - 10;\r\n          }\r\n  \r\n          // Verifica se o menu pai está muito em cima\r\n          if (rect_parent.top <= 0) {\r\n            y = rect_parent.bottom + 5;\r\n          }\r\n  \r\n          menuChild.style.top = `${y}px`;\r\n          menuChild.style.left = `${x}px`;\r\n        }\r\n      }\r\n  }\r\n\r\n}\r\n","<div class=\"flex flex-row full-container\">\r\n  @if(showMenu) {\r\n    <p-sidebar\r\n      #sidebarRef\r\n      [visible]=\"true\"\r\n      [showCloseIcon]=\"false\"\r\n      [modal]=\"false\"\r\n      [style]=\"{ width: expandMenu() ? '17rem' : '3.65rem' }\"\r\n      styleClass=\"transition-all\"\r\n    >\r\n      <ng-template pTemplate=\"headless\">\r\n        <div class=\"h-full flex flex-column overflow-hidden p-2\">\r\n          \r\n          <!-- LOGO -->\r\n          <div class=\"flex-none flex flex-column gap-1 justify-content-between flex-shrink-0 overflow-hidden\">\r\n            <div\r\n              class=\"flex {{\r\n                expandMenu() ? 'flex-row' : 'flex-column'\r\n              }} align-items-center {{\r\n                expandMenu()\r\n                  ? 'justify-content-between'\r\n                  : 'justify-content-center'\r\n              }} p-2\"\r\n            >\r\n              <!-- Logo para o menu expandido -->\r\n              @if(expandMenu() && logoMenuExpand){\r\n                <img\r\n                  alt=\"Card\"\r\n                  [src]=\"logoMenuExpand\"\r\n                  [style.height]=\"'2.4rem'\"\r\n                  width=\"auto\"\r\n                  class=\"cursor-pointer p-0\"\r\n                  (click)=\"navigateToDefaultRoute()\"\r\n                />\r\n              }\r\n\r\n              <!-- Logo para o menu minimizado-->\r\n              @if(!expandMenu() && logoMenuHide){\r\n                <img\r\n                  alt=\"Card\"\r\n                  [src]=\"logoMenuHide\"\r\n                  [style.height]=\"'2.4rem'\"\r\n                  width=\"auto\"\r\n                  class=\"cursor-pointer p-1\"\r\n                  (click)=\"navigateToDefaultRoute()\"\r\n                />\r\n              }\r\n\r\n              <!-- Toggle menu -->\r\n              @if(showExpandMenu){\r\n                <kv-icon\r\n                  name=\"ti-menu-2\"\r\n                  [clickable]=\"true\"\r\n                  [pTooltip]=\"expandMenu() ? 'Ocultar Menu' : 'Expandir Menu'\"\r\n                  [tooltipPosition]=\"'right'\"\r\n                  (onClick)=\"toggleMenu()\"\r\n                />\r\n              }\r\n            </div>\r\n\r\n            @if(showTrocaEmpresa){\r\n              <div\r\n                class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item troca-sistema-container mb-2\" \r\n                [pTooltip]=\"'Trocar de empresa'\"\r\n                [tooltipPosition]=\"'right'\"\r\n                (click)=\"changeEmpresa($event)\"\r\n              >\r\n              <kv-icon\r\n                name=\"ti-building-skyscraper\"\r\n                size=\"1.1rem\"\r\n              />\r\n                @if(expandMenu() && selectedEmpresa){\r\n                  <div\r\n                    class=\"flex flex-column w-full\"\r\n                    (click)=\"changeEmpresa($event)\"\r\n                  >\r\n                    @if(this.selectedEmpresa.razaosocial){\r\n                      <span\r\n                        class=\"text-xs font-semibold mr-2 color-system\"\r\n                        [style.fontSuze]=\"'.5rem'\"\r\n                      >\r\n                        {{ nameEmpresa(this.selectedEmpresa.razaosocial) }}\r\n                      </span>\r\n                    }\r\n                    @if(this.selectedEmpresa.cpfcnpj){\r\n                      <span class=\"text-xs mt-1 color-system\" [style.fontSuze]=\"'.5rem'\">{{\r\n                        this.selectedEmpresa.cpfcnpj | cpfCnpj\r\n                      }}</span>\r\n                    }\r\n                  </div>\r\n                  \r\n                }\r\n              </div>\r\n            }\r\n            @else {\r\n              <!-- <div style=\"width:100%; height:.75rem\"></div> -->\r\n              <p-divider class=\"px-2\" [style.opacity]=\"1\" type=\"solid\"></p-divider>\r\n            }\r\n          </div>\r\n\r\n\r\n          <!-- MENUS -->\r\n          <div class=\"flex-1 list-none m-0 overflow-y-auto max-h-full\">\r\n            <!-- menus -->\r\n            @for (menu of menus(); track $index) {\r\n              <li>\r\n                <!-- menu que não tem filho -->\r\n                  @if( !menu.indmenupai && (!menu.idmenupai || menu.idmenupai == 0)){\r\n                    <div\r\n                        class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\"\r\n                        style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                        (click)=\"callRoute(menu.link)\"\r\n                      >\r\n                        <kv-icon\r\n                          [name]=\"menu.icone|| 'ti-circle-dotted'\"\r\n                        />\r\n                        @if(expandMenu()){\r\n                          <label>{{menu.descricaomenu}}</label>\r\n                        }\r\n                    </div>\r\n                  }\r\n                <!-- menu com filho -->\r\n                  @if(menu.indmenupai){\r\n                    <div class=\"menu-parent\" id=\"menu-parent-{{$index}}\" (mouseenter)=\"exibirMenuChild($event, $index)\" (mouseleave)=\"menuVisivel.set(undefined)\" >\r\n                      <div\r\n                        class=\" flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\" style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                        \r\n                        \r\n                      >\r\n                        <kv-icon\r\n                          [name]=\"menu.icone|| 'ti-circle-dotted'\"\r\n                        />\r\n                        @if(expandMenu()){\r\n                          <label>{{menu.descricaomenu}}</label>\r\n                          <kv-icon\r\n                            #chevronIcon\r\n                            name=\"ti-chevron-right\"\r\n                          />\r\n                        }\r\n                      </div>\r\n\r\n                      <div class=\"menu-childs\" id=\"menu-child-{{$index}}\" [style.opacity]=\"menuVisivel()===$index?'1':'0'\" [style.pointerEvents]=\"menuVisivel()===$index?'auto':'none'\">\r\n                        <div class=\"h-2rem flex align-items-center\">\r\n                          <p class=\"p-0 m-0 font-bold pt-2 pl-3 text-xs\">\r\n                            {{menu.descricaomenu}}\r\n                          </p>\r\n                        </div>\r\n                        @for (item of returnMenuChild(menu.idmenu); track $index) {\r\n\r\n                          <div \r\n                            class=\" side-menu-item py-2 pl-3 pr-1 text-sm\"\r\n                            (click)=\"callRoute(item.link)\"\r\n                          >\r\n                            {{item.descricaomenu}}\r\n                          </div>\r\n                        }\r\n                      </div>\r\n                    </div>\r\n                  }\r\n              </li>\r\n            }\r\n          </div>\r\n\r\n          <p-divider class=\"px-2\" [style.opacity]=\"1\" type=\"solid\"></p-divider>\r\n          \r\n          <!-- APPS E SAIR -->\r\n          <div class=\"flex-none list-none m-0 overflow-y-auto max-h-full\">\r\n            <li>\r\n              <div class=\"menu-parent\" id=\"menu-sistemas-parent\" (mouseenter)=\"exibirMenuChild($event, -1)\" (mouseleave)=\"menuVisivel.set(undefined)\" >\r\n                <div\r\n                  class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\"\r\n                  style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                  [pTooltip]=\"!expandMenu() ? 'Sistemas' : ''\"\r\n                >\r\n                  <kv-icon\r\n                    [name]=\"'ti-apps'\"\r\n                  />\r\n                  @if(expandMenu()){\r\n                    <label>Sistemas</label>\r\n                    <kv-icon\r\n                      #chevronIcon\r\n                      name=\"ti-chevron-right\"\r\n                    />\r\n                  }\r\n                </div>\r\n\r\n                <div class=\"menu-childs\" id=\"menu-sistemas-child\" [style.opacity]=\"menuVisivel()===-1?'1':'0'\" [style.pointerEvents]=\"menuVisivel()===-1?'auto':'none'\">\r\n                  <p class=\"p-0 m-0 font-bold pt-2 pl-3 text-xs\">Sistemas</p>\r\n                  @for (item of apps; track $index) {\r\n                      <div class=\"flex flex-row align-items-center gap-2 side-menu-item py-2 pl-3 pr-1\" (click)=\"callRoute(item.rotapadrao) ; selectApp(item.idaplicativo)\">\r\n                        <img\r\n                          [src]=\"item.urlicone\"\r\n                          class=\"h-2rem w-2rem border-round-lg\"\r\n                        />\r\n                        <div class=\"text-sm\">\r\n                          {{item.nomeaplicativo}}\r\n                        </div>\r\n                      </div>\r\n                  }\r\n                </div>\r\n    \r\n              </div>\r\n            </li>\r\n            <li>\r\n              <div\r\n                class=\"flex flex-row align-items-center justify-content-{{expandMenu() ?'between':'center'}} gap-2 side-menu-item\"\r\n                style=\"padding-top: 0.75rem; padding-bottom:0.75rem;\"\r\n                [pTooltip]=\"!expandMenu() ? 'Sair' : ''\"\r\n                [style.color]=\"'red'\"\r\n                [style.opacity]=\"0.5\"\r\n                (click)=\"logout($event)\"\r\n              >\r\n                <kv-icon\r\n                  [name]=\"'ti-logout'\"\r\n                  \r\n                />\r\n                @if(expandMenu()){\r\n                  <label>Sair</label>\r\n                }\r\n              </div>\r\n            </li>\r\n          </div>\r\n        </div>\r\n      </ng-template>\r\n    </p-sidebar>\r\n  }\r\n\r\n  <!-- SEÇÃO CONTEÚDO  -->\r\n  <div\r\n    class=\"w-auto h-screen page-content overflow-y-hidden flex flex-column\"\r\n    id=\"page-content\"\r\n    style=\"width: 100vw !important\"\r\n  >\r\n    <!-- TOPO -->\r\n    <div\r\n      class=\"flex flex-row flex-wrap align-items-center justify-content-between my-2 mx-3 mb-0\"\r\n    >\r\n      @if(!showMenu) {\r\n      <!-- Logo home -->\r\n        <div>\r\n          <img [src]=\"logoMenuExpand\" width=\"150\" />\r\n        </div>\r\n      } \r\n      @else {\r\n        <!-- Breadcrumbs -->\r\n        @if(showBreadcrumb) {\r\n          <div class=\"h-full\">\r\n              <p-breadcrumb\r\n                *ngIf=\"widthCard > 400\"\r\n                styleClass=\"border-none p-0 flex align-items-center h-2rem bg-transparent\"\r\n                [model]=\"breadCrumbItems\"\r\n                (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n              >\r\n              <ng-template pTemplate=\"item\" let-item let-i=\"index\">\r\n                  @if(breadCrumbItems.indexOf(item) < breadCrumbItems.length - 1){\r\n                    <span class=\"font-normal\">{{ item.label }}</span>\r\n                  }\r\n                  @else {\r\n                    <span class=\"font-bold\">{{ item.label }}</span>\r\n                  }\r\n              </ng-template>\r\n            </p-breadcrumb>\r\n          </div>\r\n        }\r\n        @else {\r\n          <!-- GHOST DIV PARA OCPUAR ESPAÇO NO SPACE BETWEEN -->\r\n          <div></div>\r\n        }\r\n      } \r\n      @if (exibirNomes) { \r\n        @if(widthCard >= 517) {\r\n          <div\r\n            class=\"w-auto flex flex-column justify-content-center align-items-center gap-2\"\r\n          >\r\n            @if (masterName) { <span class=\"font-semibold system-color\">{{ masterName }}</span> }\r\n            @if (empresaName) {<span class=\"empresa-name\"\r\n              >Organização: {{ empresaName }}</span\r\n            >\r\n            }\r\n          </div>\r\n\r\n          <div\r\n            class=\"w-auto flex flex-row justify-content-center align-items-center gap-2\"\r\n          >\r\n            <!-- Navegação de sistemas e usuários -->\r\n            <!-- @for (topAction of topMenuActions(); track $index) {\r\n            <ng-container *ngTemplateOutlet=\"topAction\" />\r\n            } -->\r\n            <kv-top-icons\r\n              [topActions]=\"topMenuOptions\"\r\n            />\r\n\r\n          </div>\r\n        } \r\n        @else {\r\n          <div\r\n            class=\"w-auto flex flex-row justify-content-center align-items-center gap-2\"\r\n          >\r\n            <!-- Navegação de sistemas e usuários -->\r\n            <!-- @for (topAction of topMenuActions(); track $index) {\r\n            <ng-container *ngTemplateOutlet=\"topAction\" />\r\n            } -->\r\n            <kv-top-icons\r\n              [topActions]=\"topMenuOptions\"\r\n            />\r\n\r\n          </div>\r\n\r\n          <div\r\n            class=\"w-auto flex flex-column justify-content-center align-items-center gap-2\"\r\n          >\r\n            @if (masterName) { <span class=\"master-name\">{{ masterName }}</span> }\r\n            @if (empresaName) {<span class=\"empresa-name\">{{ empresaName }}</span> }\r\n          </div>\r\n        } \r\n      } \r\n      @else { \r\n        @if(widthPage() > 992){\r\n          <!-- dropdown para seleção de empresa/licenca -->\r\n          <dropdown-master\r\n            *ngIf=\"showLicencas()\"\r\n            class=\"max-w-25rem flex-1\"\r\n            formControlName=\"idmaster\"\r\n            [formGroup]=\"formGroup\"\r\n            [masters]=\"masters\"\r\n            (onSelectionChange)=\"changeLicense($event)\"\r\n            (onSelectionValue)=\"changeLicense($event)\"\r\n          >\r\n          </dropdown-master>\r\n        }\r\n\r\n        <!-- Navegação de sistemas e usuários -->\r\n        <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n\r\n          <kv-top-icons\r\n            [topActions]=\"topMenuOptions\"\r\n          />\r\n\r\n        </div>\r\n      }\r\n    </div>\r\n\r\n    @if(widthPage() <= 992){\r\n      <!-- dropdown para seleção de empresa/licenca -->\r\n      <div class=\"h-2rem mx-3\">\r\n        <dropdown-master\r\n          *ngIf=\"showLicencas()\"\r\n          formControlName=\"idmaster\"\r\n          [formGroup]=\"formGroup\"\r\n          [masters]=\"masters\"\r\n          (onSelectionChange)=\"changeLicense($event)\"\r\n          (onSelectionValue)=\"changeLicense($event)\"\r\n        />\r\n      </div>\r\n\r\n    } \r\n\r\n    <!-- Container -->\r\n    <div class=\"overflow-hidden flex-1 p-0 m-0 mb-2 h-full\">\r\n      <p-card\r\n        styleClass=\"overflow-y-auto h-full max-h-full {{\r\n          !showMenu && 'sm:overflow-y-hidden'\r\n        }} card-container\"\r\n      >\r\n        <ng-content></ng-content>\r\n        \r\n      </p-card>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Painel do usuário -->\r\n  <p-overlayPanel\r\n    #meusDadosPanel\r\n    [showTransitionOptions]=\"'350ms ease-out'\"\r\n    [hideTransitionOptions]=\"'250ms ease-in'\"\r\n  >\r\n  <ng-template pTemplate=\"container\">\r\n    <p class=\"system-color font-medium text-lg px-2 py-3 m-0\">\r\n      Olá, {{ userName ? userName.split(\" \")[0] : \"Usuário\" }}!\r\n    </p>\r\n    <!-- <div class=\"mt-5 mb-3\"></div> -->\r\n  \r\n    <!-- Contêiner com direção em coluna para empilhar os botões -->\r\n    <div class=\"flex flex-column\">\r\n      <!-- Botões adicionais dinâmicos -->\r\n      @for (action of actions; track $index) {\r\n        <ng-container>\r\n          <div class=\"flex flex-row align-items-center gap-2 side-menu-item py-2 px-2\"\r\n            (click)=\"action.action()\"\r\n          >\r\n            <kv-icon\r\n              [name]=\"action.icon\"\r\n            />\r\n            <span>{{action.label}}</span>\r\n          </div>\r\n        </ng-container>\r\n      }\r\n\r\n      <div class=\"flex flex-row align-items-center gap-2 side-menu-item py-2 px-2\"\r\n        (click)=\"accessKeePass($event)\"\r\n      >\r\n          <kv-icon\r\n            name=\"ti-lock\"\r\n          />\r\n          <span>Acessar KeePass</span>\r\n      </div>\r\n  \r\n    </div>\r\n  </ng-template>\r\n  \r\n  </p-overlayPanel>\r\n</div>\r\n"]}
|
|
@@ -5856,10 +5856,10 @@ class KvLayoutComponent {
|
|
|
5856
5856
|
* @type {Array<{id: number, numNotifications?: number, action?: (e: any) => void}>}
|
|
5857
5857
|
*
|
|
5858
5858
|
* Opções disponíveis:
|
|
5859
|
-
* - 2 -
|
|
5860
|
-
* - 3 -
|
|
5861
|
-
* - 4 -
|
|
5862
|
-
* - 5 -
|
|
5859
|
+
* - 2 - Kiara
|
|
5860
|
+
* - 3 - Notificações
|
|
5861
|
+
* - 4 - Tarefas
|
|
5862
|
+
* - 5 - Comunicador
|
|
5863
5863
|
*
|
|
5864
5864
|
* @property {number} id - identificador do menu.
|
|
5865
5865
|
* @property {number} [numNotifications] - Número de notificações (opcional).
|
|
@@ -5869,10 +5869,10 @@ class KvLayoutComponent {
|
|
|
5869
5869
|
this.topMenusVisible = input([]);
|
|
5870
5870
|
this.topMenuOptions = [
|
|
5871
5871
|
{ id: 1, visible: true, icon: 'ti-user', tooltip: 'Meus Dados', numNotifications: 0, action: (e) => { this.meusDadosPanel.toggle(e); } },
|
|
5872
|
-
{ id: 2, visible: false, icon: 'ti-
|
|
5873
|
-
{ id: 3, visible: false, icon: 'ti-
|
|
5874
|
-
{ id: 4, visible: false, icon: 'ti-
|
|
5875
|
-
{ id: 5, visible: false, icon: 'ti-
|
|
5872
|
+
{ id: 2, visible: false, icon: 'ti-sparkles', tooltip: 'Kiara', numNotifications: 0, action: () => { } },
|
|
5873
|
+
{ id: 3, visible: false, icon: 'ti-bell', tooltip: 'Notificações', numNotifications: 0, action: () => { } },
|
|
5874
|
+
{ id: 4, visible: false, icon: 'ti-list-check', tooltip: 'Tarefas', numNotifications: 0, action: () => { } },
|
|
5875
|
+
{ id: 5, visible: false, icon: 'ti-message', tooltip: 'Comunicador', numNotifications: 0, action: () => { } },
|
|
5876
5876
|
];
|
|
5877
5877
|
this.profileImage = input('');
|
|
5878
5878
|
this.breadCrumbItems = [];
|