keevo-components 1.5.168 → 1.5.170
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/esm2020/lib/menu/menu.component.mjs +6 -6
- package/esm2020/lib/page-form/page-form.component.mjs +4 -4
- package/fesm2015/keevo-components.mjs +8 -8
- package/fesm2015/keevo-components.mjs.map +1 -1
- package/fesm2020/keevo-components.mjs +8 -8
- package/fesm2020/keevo-components.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -45,9 +45,9 @@ export class MenuComponent {
|
|
|
45
45
|
this.configurarLicencas();
|
|
46
46
|
this.router.events.subscribe((event) => {
|
|
47
47
|
if (event instanceof NavigationEnd) {
|
|
48
|
-
console.log('Evento de navegação:', event);
|
|
48
|
+
// console.log('Evento de navegação:', event);
|
|
49
49
|
this.breadCrumbItems = this.getBreadcrumbs(event.url);
|
|
50
|
-
console.log("breadCrumbItems ->", this.breadCrumbItems);
|
|
50
|
+
// console.log("breadCrumbItems ->", this.breadCrumbItems);
|
|
51
51
|
}
|
|
52
52
|
});
|
|
53
53
|
this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);
|
|
@@ -108,9 +108,9 @@ export class MenuComponent {
|
|
|
108
108
|
this.menus =
|
|
109
109
|
this.menuCompleto.find((x) => x.sistema.idsistema == idsistema)?.menus ||
|
|
110
110
|
[];
|
|
111
|
-
console.log(this.menus, 'menus')
|
|
112
|
-
console.log(this.menuCompleto, 'menuCompleto')
|
|
113
|
-
console.log(this.menus[0].menupai, 'menupai')
|
|
111
|
+
// console.log(this.menus, 'menus')
|
|
112
|
+
// console.log(this.menuCompleto, 'menuCompleto')
|
|
113
|
+
// console.log(this.menus[0].menupai, 'menupai')
|
|
114
114
|
if (this.menus[0].menupai) {
|
|
115
115
|
var filhos = this.retornarMenuFilhos(this.menus[0].idsistema, this.menus[0].idmenu);
|
|
116
116
|
if (filhos != undefined)
|
|
@@ -221,4 +221,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
|
221
221
|
type: HostListener,
|
|
222
222
|
args: ['window:resize', ['$event']]
|
|
223
223
|
}] } });
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/menu/menu.component.ts","../../../../../projects/keevo-components/src/lib/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { menuCompletoModel } from '../api/models/menu/menucompleto.model';\r\nimport { Sidebar } from 'primeng/sidebar';\r\nimport { menuModel } from '../api/models/menu/menu.model';\r\nimport { masterModel } from '../api/models/menu/master.model';\r\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\n\r\n@Component({\r\n  selector: 'kv-menu',\r\n  templateUrl: './menu.component.html',\r\n  styleUrls: ['./menu.component.scss'],\r\n})\r\nexport class MenuComponent implements OnInit {\r\n\r\n  @Input() menuCompleto: menuCompletoModel[] = [];\r\n  @Input() licencas: masterModel[] = []\r\n  @Input() licencaSelecionada!: masterModel;\r\n  @Input() logoImage!: any;\r\n  @Input() nomeUsuario!: string;\r\n  @Input() breadCrumbs: boolean = false;\r\n\r\n  @Output() licencaChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() gerenciarKeePassEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() sairEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\r\n\r\n  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\r\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\r\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\r\n\r\n  licencasOptions: { id: number, descricao: string, cnpj: string }[] = []\r\n  licencaSelected!: { id: number, descricao: string, cnpj: string };\r\n\r\n  menusFiltrados: menuCompletoModel[] = [];\r\n  menus: menuModel[] = [];\r\n\r\n  breadCrumbItems: { label: string, routerLink: string }[] = [];\r\n\r\n  heigthCard!: number;\r\n  widthCard!: number;\r\n  expandMenu: boolean = true;\r\n\r\n  visibleDialogLicenca: boolean = false;\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  constructor(private cdr: ChangeDetectorRef, protected router: Router, private route: ActivatedRoute) { }\r\n\r\n  ngOnInit(): void {\r\n    this.configurarLicencas();\r\n\r\n    this.router.events.subscribe((event) => {\r\n      if (event instanceof NavigationEnd) {\r\n        console.log('Evento de navegação:', event);\r\n        this.breadCrumbItems = this.getBreadcrumbs(event.url);\r\n        console.log(\"breadCrumbItems ->\", this.breadCrumbItems);\r\n      }\r\n    });\r\n\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n  }\r\n\r\n  configurarLicencas() {\r\n    setTimeout(() => this.setLicenca(), 1500)\r\n\r\n    this.licencas.forEach((x, i) => {\r\n      this.licencasOptions.push({\r\n        id: i,\r\n        descricao: x.razaosocial,\r\n        cnpj: x.cnpj\r\n      })\r\n    })\r\n\r\n    var licenca = this.licencasOptions.find((x) => x.cnpj == this.licencaSelecionada.cnpj);\r\n\r\n    if (licenca != undefined)\r\n      this.licencaSelected = licenca;\r\n  }\r\n\r\n\r\n  private getBreadcrumbs(url: string = '', breadcrumbs: { label: string, routerLink: string }[] = []): { label: string, routerLink: string }[] {\r\n\r\n    if (!url || url === '/') {\r\n      return breadcrumbs.length > 0 ? breadcrumbs : [{ label: 'Home', routerLink: '/' }];\r\n    }\r\n\r\n    const segments = url.split('/').filter(segment => segment !== '');\r\n\r\n    let currentUrl = '';\r\n    for (const segment of segments) {\r\n      currentUrl += `/${segment}`;\r\n      breadcrumbs.push({ label: segment, routerLink: currentUrl });\r\n    }\r\n\r\n    if (breadcrumbs.length > 0) {\r\n      breadcrumbs.forEach(item => {\r\n        let labelSegments = item.label.split('-');\r\n        labelSegments = labelSegments.map((segment, index) => {\r\n          return index === 0 ? segment.charAt(0).toUpperCase() + segment.slice(1).toLowerCase() : segment;\r\n        });\r\n        item.label = labelSegments.join(' ');\r\n      });\r\n    }\r\n    return breadcrumbs;\r\n  }\r\n\r\n  closeCallback(e: Event): void {\r\n    this.sidebarRef.close(e);\r\n  }\r\n\r\n  MascaraNomeLicenca(nomeLicenca: any): string {\r\n    if (nomeLicenca) {\r\n      if (nomeLicenca.length > 24)\r\n        return nomeLicenca.substring(0, 24) + '...';\r\n      else return nomeLicenca;\r\n    } else return '';\r\n  }\r\n\r\n  MascaraCnpj(cnpj: string): string {\r\n    const cnpjLimpo = cnpj.replace(/\\D/g, '');\r\n\r\n    return cnpjLimpo.replace(\r\n      /^(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{2})$/,\r\n      '$1.$2.$3/$4-$5'\r\n    );\r\n  }\r\n\r\n  definirMenusPorSistema(idsistema: number) {\r\n    this.menus =\r\n      this.menuCompleto.find((x) => x.sistema.idsistema == idsistema)?.menus ||\r\n      [];\r\n\r\n    console.log(this.menus, 'menus')\r\n    console.log(this.menuCompleto, 'menuCompleto')\r\n    console.log(this.menus[0].menupai, 'menupai')\r\n\r\n    if (this.menus[0].menupai) {\r\n      var filhos = this.retornarMenuFilhos(this.menus[0].idsistema, this.menus[0].idmenu);\r\n      if (filhos != undefined)\r\n        this.callRoute(filhos[0].link, true)\r\n    } else this.callRoute(this.menus[0].link, true)\r\n\r\n    this.sistemasPanel.hide();\r\n  }\r\n\r\n  retornarMenuFilhos(idsistema: number, idmenu: number) {\r\n    return this.menuCompleto\r\n      .find((x) => x.sistema.idsistema == idsistema)\r\n      ?.menus.filter((x) => x.idmenupai == idmenu);\r\n  }\r\n\r\n  callRoute(e: any, expand?: boolean) {\r\n    if (!expand)\r\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : ''\r\n    this.router.navigateByUrl(e)\r\n  }\r\n\r\n  toggleMenu() {\r\n    this.expandMenu = !this.expandMenu;\r\n    this.expandMenuEvent()\r\n  }\r\n\r\n  setLicenca() {\r\n    var licenca = this.licencas.find((licenca) => licenca.cnpj == this.licencaSelected.cnpj);\r\n    if (licenca) this.licencaSelecionada = licenca;\r\n\r\n    this.visibleDialogLicenca = false\r\n\r\n    this.licencaChange.emit(this.licencaSelecionada);\r\n\r\n    this.definirMenusPorSistema(this.menuCompleto[0]?.sistema.idsistema)\r\n  }\r\n\r\n  gerenciarKeePass(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.gerenciarKeePassEvent.emit(event)\r\n  }\r\n\r\n  sair(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.sairEvent.emit(event)\r\n  }\r\n\r\n  expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu);\r\n  }\r\n\r\n  ajustarHeigthCard(): number {\r\n    if (this.widthCard > 400) {\r\n      if (this.breadCrumbs) return 105\r\n      else return 85\r\n    } else return 83\r\n  }\r\n\r\n  verificarPaginaSelecionada(link: any): string {\r\n    if (this.router.url.includes(link)) return 'bg-green-600'\r\n    else return '';\r\n  }\r\n\r\n  // retornarTituloBreadCrumbs(label: any): string {\r\n  //   if (label)\r\n  //     return this.breadCrumbItems[this.breadCrumbItems.length - 1]?.label\r\n  //   else return '';\r\n  // }\r\n\r\n  retornarTituloBreadCrumbs(str: string) {\r\n\r\n    if (str.includes('-')) {\r\n      str = str.replace('-', ' ');\r\n    }\r\n\r\n    var primeiraLetra = str.charAt(0).toUpperCase() + str.slice(1);\r\n\r\n    str.slice(1);\r\n\r\n    return primeiraLetra;\r\n  }\r\n}\r\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\r\n\r\n  <div [style]=\"{minWidth: expandMenu ? '300px' : '60px'}\"></div>\r\n\r\n  <p-sidebar\r\n    #sidebarRef\r\n    [visible]=\"true\"\r\n    [showCloseIcon]=\"false\"\r\n    [modal]=\"false\"\r\n    [style]=\"{width: expandMenu ? '300px' : '60px'}\"\r\n  >\r\n    <ng-template pTemplate=\"headless\">\r\n      <div class=\"flex flex-column {{expandMenu ? 'mx-1' : 'mx-1'}}\">\r\n        <div class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2\">\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}} py-3\"\r\n          >\r\n            <img\r\n              *ngIf=\"expandMenu\"\r\n              alt=\"Card\"\r\n              [src]=\"logoImage\"\r\n              width=\"150\"\r\n            />\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"toggleMenu()\"\r\n              [pTooltip]=\"expandMenu ? 'Ocutar Menu' : 'Expandir Menu'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                menu\r\n              </i>\r\n            </button>\r\n          </div>\r\n\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}}\"\r\n          >\r\n            <div\r\n              class=\"flex flex-column cursor-pointer\"\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"visibleDialogLicenca = !visibleDialogLicenca\"\r\n            >\r\n              <span\r\n                class=\"text-sm font-semibold mr-2\"\r\n                [pTooltip]=\"this.licencaSelecionada.razaosocial\"\r\n                [tooltipPosition]=\"'right'\"\r\n              >\r\n                {{MascaraNomeLicenca(this.licencaSelecionada.razaosocial)}}\r\n              </span>\r\n              <span class=\"text-sm mt-1\">{{MascaraCnpj(this.licencaSelecionada.cnpj)}}</span>\r\n            </div>\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"visibleDialogLicenca = !visibleDialogLicenca\"\r\n              [pTooltip]=\"'Alterar Licença'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                sync_alt\r\n              </i>\r\n            </button>\r\n\r\n          </div>\r\n          <p-divider type=\"solid\"></p-divider>\r\n        </div>\r\n\r\n        <div\r\n          class=\"list-none m-0  card-container {{expandMenu ? 'mx-1' : ''}}\"\r\n          [style.max-height]=\"(heigthCard - 220) + 'px'\"\r\n          style=\"overflow-y: auto;\"\r\n        >\r\n          <!-- menus -->\r\n          <li *ngFor=\"let menu of menus\">\r\n            <!-- menu que não tem filho -->\r\n            <a\r\n              (click)=\"callRoute(menu.link)\"\r\n              *ngIf=\"!menu.menupai && menu.idmenupai == 0\"\r\n              pRipple\r\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n              [tooltipPosition]=\"'right'\"\r\n              class=\"{{verificarPaginaSelecionada(menu.link)}} menu-option flex align-items-center no-underline {{!expandMenu ? 'justify-content-center' : ''}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n            >\r\n\r\n              <i\r\n                class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}\"\r\n                *ngIf=\"menu.icone && menu.icone !== ''\"\r\n              >\r\n                {{ menu.icone }}\r\n              </i>\r\n              <span\r\n                class=\"text-base text-blue-900 font-medium\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ menu.descricaomenu }}</span>\r\n            </a>\r\n            <!-- menu com filho -->\r\n            <div *ngIf=\"menu.menupai\">\r\n              <a\r\n                pRipple\r\n                pStyleClass=\"@next\"\r\n                enterClass=\"hidden\"\r\n                enterActiveClass=\"slidedown\"\r\n                leaveToClass=\"hidden\"\r\n                leaveActiveClass=\"slideup\"\r\n                class=\"menu-option flex align-items-center {{!expandMenu ? 'justify-content-center' : 'justify-content-between'}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n                [tooltipPosition]=\"'right'\"\r\n                [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n                (click)=\"!expandMenu ? expandMenu = !expandMenu : ''\"\r\n              >\r\n                <div class=\"flex flex-row align-items-center\">\r\n\r\n                  <i\r\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}\"\r\n                    *ngIf=\"menu.icone && menu.icone !== ''\"\r\n                  >\r\n                    {{ menu.icone }}\r\n                  </i>\r\n                  <span\r\n                    class=\"text-base text-blue-900 font-medium\"\r\n                    *ngIf=\"expandMenu\"\r\n                  >{{ menu.descricaomenu }}</span>\r\n                </div>\r\n                <i\r\n                  class=\"pi pi-chevron-down text-blue-900 mr-1\"\r\n                  *ngIf=\"expandMenu\"\r\n                ></i>\r\n              </a>\r\n\r\n              <!-- filhos -->\r\n              <div\r\n                class=\"list-none py-0 pl-3 pr-0 m-0 hidden overflow-y-hidden transition-all transition-duration-400 transition-ease-in-out\"\r\n              >\r\n          <li *ngFor=\"\r\n              let filho of retornarMenuFilhos(menu.idsistema, menu.idmenu)\r\n            \">\r\n            <a\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"callRoute(filho.link)\"\r\n              pRipple\r\n              class=\"{{verificarPaginaSelecionada(filho.link)}} menu-option flex align-items-center no-underline cursor-pointer border-round text-700 hover:bg-green-600 transition-duration-150 transition-colors p-ripple p-2\"\r\n            >\r\n              <i\r\n                class=\"pi pi-chart-line mr-2 ml-1 adjust-icon-menu\"\r\n                *ngIf=\"filho.icone && filho.icone !== ''\"\r\n              ></i>\r\n              <span\r\n                class=\"text-base text-blue-900 ml-4\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ filho.descricaomenu }}</span>\r\n            </a>\r\n          </li>\r\n        </div>\r\n      </div>\r\n</div>\r\n</div>\r\n</ng-template>\r\n</p-sidebar>\r\n\r\n\r\n<div\r\n  class=\"w-auto h-screen page-content overflow-y-hidden\"\r\n  id=\"page-content\"\r\n>\r\n\r\n  <div class=\"flex flex-row align-items-center justify-content-between m-3\">\r\n    <div *ngIf=\"breadCrumbs\">\r\n      <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">{{breadCrumbItems[breadCrumbItems.length -\r\n        1]?.label}}</p>\r\n      <p-breadcrumb\r\n        *ngIf=\"widthCard > 400\"\r\n        styleClass=\"border-none p-0 flex align-items-center h-2rem !important;\"\r\n        [model]=\"breadCrumbItems\"\r\n        [style]=\"{backgroundColor: '#d4d3d3'}\"\r\n        (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n      ></p-breadcrumb>\r\n    </div>\r\n\r\n    <div *ngIf=\"!breadCrumbs\"></div>\r\n\r\n    <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n      <button\r\n        pButton\r\n        class=\"p-button-rounded p-button-text h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu padding-style\"\r\n        (click)=\"sistemasPanel.toggle($event)\"\r\n        [pTooltip]=\"'Sistemas'\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        <i class=\"material-symbols-outlined\">\r\n          apps\r\n        </i>\r\n      </button>\r\n      <button\r\n        pButton\r\n        class=\"p-button-rounded p-button-text h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu padding-style\"\r\n        (click)=\"meusDadosPanel.toggle($event)\"\r\n        [pTooltip]=\"'Menu do Usuário'\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        <i class=\"material-symbols-outlined\">\r\n          person\r\n        </i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p-card\r\n    class=\"card-container\"\r\n    styleClass=\"m-3 border-noround overflow-y-auto card-container\"\r\n    [style]=\"{height: heigthCard - ajustarHeigthCard() + 'px'}\"\r\n  >\r\n    <div class=\"card-container w-full\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n  </p-card>\r\n\r\n</div>\r\n\r\n\r\n</div>\r\n\r\n<p-overlayPanel\r\n  #sistemasPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n\r\n  <ng-template pTemplate=\"container\">\r\n\r\n    <p class=\"title-style mt-3\">Sistemas</p>\r\n    <div\r\n      class=\"flex flex-row flex-wrap gap-2 align-items-center justify-content-center mt-5 mb-3\"\r\n      style=\"width: 250px; height: 100%;\"\r\n    >\r\n      <button\r\n        *ngFor=\"let menu of menuCompleto\"\r\n        pButton\r\n        pRipple\r\n        class=\"btn-sistema-2 btn-sistema hover-btn-cor-padrao remove-focus h-4rem w-4rem\"\r\n        (click)=\"definirMenusPorSistema(menu.sistema.idsistema)\"\r\n        [pTooltip]=\"menu.sistema.descricaosistema\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        <!-- <img\r\n          alt=\"logo\"\r\n          style=\"width: 2rem; height: 2rem;\"\r\n        /> -->\r\n        {{ menu.sistema.nomesistema.charAt(0).toUpperCase() }}\r\n\r\n      </button>\r\n\r\n\r\n      <!-- <p-button styleClass=\"p-button-outlined\">\r\n        <img alt=\"logo\" src=\"https://primefaces.org/cdn/primeng/images/primeng-icon.svg\" style=\"width: 1.5rem\" />\r\n        <span class=\"ml-2 font-bold\">PrimeNG</span>\r\n    </p-button> -->\r\n\r\n    </div>\r\n  </ng-template>\r\n</p-overlayPanel>\r\n\r\n<p-overlayPanel\r\n  #meusDadosPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n\r\n  <ng-template pTemplate=\"container\">\r\n\r\n    <p class=\"title-style mt-3\">Olá, {{nomeUsuario ? nomeUsuario.split(' ')[0] : 'Usuário'}} !</p>\r\n    <div class=\"mt-5 mb-3\">\r\n\r\n    </div>\r\n\r\n    <p-button\r\n      icon=\"pi pi-lock\"\r\n      label=\"Gerênciar KeevoPass\"\r\n      (onClick)=\"gerenciarKeePass($event)\"\r\n      styleClass=\"border-noround w-full p-button-text text-blue-900\"\r\n      [disabled]=\"true\"\r\n    ></p-button>\r\n    <p-button\r\n      icon=\"pi pi-sign-out\"\r\n      label=\"Sair\"\r\n      (onClick)=\"sair($event)\"\r\n      styleClass=\"border-noround w-full p-button-text text-blue-900\"\r\n    ></p-button>\r\n  </ng-template>\r\n\r\n</p-overlayPanel>\r\n\r\n<p-dialog\r\n  [(visible)]=\"visibleDialogLicenca\"\r\n  [modal]=\"true\"\r\n  [draggable]=\"false\"\r\n  header=\"Trocar Licença\"\r\n  [style]=\"{width: '50vh' }\"\r\n>\r\n  <div class=\"flex flex-column align-items-end\">\r\n\r\n    <div class=\"w-full\">\r\n      <p-dropdown\r\n        styleClass=\"w-full\"\r\n        [options]=\"licencasOptions\"\r\n        [(ngModel)]=\"licencaSelected\"\r\n        optionLabel=\"descricao\"\r\n      ></p-dropdown>\r\n    </div>\r\n\r\n    <kv-button-success\r\n      [label]=\"'Salvar'\"\r\n      class=\"mt-2\"\r\n      (onClick)=\"setLicenca()\"\r\n    ></kv-button-success>\r\n\r\n  </div>\r\n\r\n</p-dialog>\r\n\r\n<!-- <p-confirmDialog\r\n  [style]=\"{width: '40vw'}\"\r\n  [baseZIndex]=\"10000\"\r\n  rejectButtonStyleClass=\"p-button-text\"\r\n>\r\n</p-confirmDialog>\r\n\r\n<p-toast></p-toast> -->"]}
|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/menu/menu.component.ts","../../../../../projects/keevo-components/src/lib/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { menuCompletoModel } from '../api/models/menu/menucompleto.model';\r\nimport { Sidebar } from 'primeng/sidebar';\r\nimport { menuModel } from '../api/models/menu/menu.model';\r\nimport { masterModel } from '../api/models/menu/master.model';\r\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\n\r\n@Component({\r\n  selector: 'kv-menu',\r\n  templateUrl: './menu.component.html',\r\n  styleUrls: ['./menu.component.scss'],\r\n})\r\nexport class MenuComponent implements OnInit {\r\n\r\n  @Input() menuCompleto: menuCompletoModel[] = [];\r\n  @Input() licencas: masterModel[] = []\r\n  @Input() licencaSelecionada!: masterModel;\r\n  @Input() logoImage!: any;\r\n  @Input() nomeUsuario!: string;\r\n  @Input() breadCrumbs: boolean = false;\r\n\r\n  @Output() licencaChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() gerenciarKeePassEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() sairEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() expandMenuEmit: EventEmitter<boolean> = new EventEmitter();\r\n\r\n  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\r\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\r\n  @ViewChild('meusDadosPanel') meusDadosPanel!: OverlayPanel;\r\n\r\n  licencasOptions: { id: number, descricao: string, cnpj: string }[] = []\r\n  licencaSelected!: { id: number, descricao: string, cnpj: string };\r\n\r\n  menusFiltrados: menuCompletoModel[] = [];\r\n  menus: menuModel[] = [];\r\n\r\n  breadCrumbItems: { label: string, routerLink: string }[] = [];\r\n\r\n  heigthCard!: number;\r\n  widthCard!: number;\r\n  expandMenu: boolean = true;\r\n\r\n  visibleDialogLicenca: boolean = false;\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  constructor(private cdr: ChangeDetectorRef, protected router: Router, private route: ActivatedRoute) { }\r\n\r\n  ngOnInit(): void {\r\n    this.configurarLicencas();\r\n\r\n    this.router.events.subscribe((event) => {\r\n      if (event instanceof NavigationEnd) {\r\n        // console.log('Evento de navegação:', event);\r\n        this.breadCrumbItems = this.getBreadcrumbs(event.url);\r\n        // console.log(\"breadCrumbItems ->\", this.breadCrumbItems);\r\n      }\r\n    });\r\n\r\n    this.heigthCard = Number(document.getElementById('page-content')?.offsetHeight);\r\n    this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n  }\r\n\r\n  configurarLicencas() {\r\n    setTimeout(() => this.setLicenca(), 1500)\r\n\r\n    this.licencas.forEach((x, i) => {\r\n      this.licencasOptions.push({\r\n        id: i,\r\n        descricao: x.razaosocial,\r\n        cnpj: x.cnpj\r\n      })\r\n    })\r\n\r\n    var licenca = this.licencasOptions.find((x) => x.cnpj == this.licencaSelecionada.cnpj);\r\n\r\n    if (licenca != undefined)\r\n      this.licencaSelected = licenca;\r\n  }\r\n\r\n\r\n  private getBreadcrumbs(url: string = '', breadcrumbs: { label: string, routerLink: string }[] = []): { label: string, routerLink: string }[] {\r\n\r\n    if (!url || url === '/') {\r\n      return breadcrumbs.length > 0 ? breadcrumbs : [{ label: 'Home', routerLink: '/' }];\r\n    }\r\n\r\n    const segments = url.split('/').filter(segment => segment !== '');\r\n\r\n    let currentUrl = '';\r\n    for (const segment of segments) {\r\n      currentUrl += `/${segment}`;\r\n      breadcrumbs.push({ label: segment, routerLink: currentUrl });\r\n    }\r\n\r\n    if (breadcrumbs.length > 0) {\r\n      breadcrumbs.forEach(item => {\r\n        let labelSegments = item.label.split('-');\r\n        labelSegments = labelSegments.map((segment, index) => {\r\n          return index === 0 ? segment.charAt(0).toUpperCase() + segment.slice(1).toLowerCase() : segment;\r\n        });\r\n        item.label = labelSegments.join(' ');\r\n      });\r\n    }\r\n    return breadcrumbs;\r\n  }\r\n\r\n  closeCallback(e: Event): void {\r\n    this.sidebarRef.close(e);\r\n  }\r\n\r\n  MascaraNomeLicenca(nomeLicenca: any): string {\r\n    if (nomeLicenca) {\r\n      if (nomeLicenca.length > 24)\r\n        return nomeLicenca.substring(0, 24) + '...';\r\n      else return nomeLicenca;\r\n    } else return '';\r\n  }\r\n\r\n  MascaraCnpj(cnpj: string): string {\r\n    const cnpjLimpo = cnpj.replace(/\\D/g, '');\r\n\r\n    return cnpjLimpo.replace(\r\n      /^(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{2})$/,\r\n      '$1.$2.$3/$4-$5'\r\n    );\r\n  }\r\n\r\n  definirMenusPorSistema(idsistema: number) {\r\n    this.menus =\r\n      this.menuCompleto.find((x) => x.sistema.idsistema == idsistema)?.menus ||\r\n      [];\r\n\r\n    // console.log(this.menus, 'menus')\r\n    // console.log(this.menuCompleto, 'menuCompleto')\r\n    // console.log(this.menus[0].menupai, 'menupai')\r\n\r\n    if (this.menus[0].menupai) {\r\n      var filhos = this.retornarMenuFilhos(this.menus[0].idsistema, this.menus[0].idmenu);\r\n      if (filhos != undefined)\r\n        this.callRoute(filhos[0].link, true)\r\n    } else this.callRoute(this.menus[0].link, true)\r\n\r\n    this.sistemasPanel.hide();\r\n  }\r\n\r\n  retornarMenuFilhos(idsistema: number, idmenu: number) {\r\n    return this.menuCompleto\r\n      .find((x) => x.sistema.idsistema == idsistema)\r\n      ?.menus.filter((x) => x.idmenupai == idmenu);\r\n  }\r\n\r\n  callRoute(e: any, expand?: boolean) {\r\n    if (!expand)\r\n      !this.expandMenu ? this.expandMenu = !this.expandMenu : ''\r\n    this.router.navigateByUrl(e)\r\n  }\r\n\r\n  toggleMenu() {\r\n    this.expandMenu = !this.expandMenu;\r\n    this.expandMenuEvent()\r\n  }\r\n\r\n  setLicenca() {\r\n    var licenca = this.licencas.find((licenca) => licenca.cnpj == this.licencaSelected.cnpj);\r\n    if (licenca) this.licencaSelecionada = licenca;\r\n\r\n    this.visibleDialogLicenca = false\r\n\r\n    this.licencaChange.emit(this.licencaSelecionada);\r\n\r\n    this.definirMenusPorSistema(this.menuCompleto[0]?.sistema.idsistema)\r\n  }\r\n\r\n  gerenciarKeePass(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.gerenciarKeePassEvent.emit(event)\r\n  }\r\n\r\n  sair(event: any) {\r\n    this.sistemasPanel.hide();\r\n    this.sairEvent.emit(event)\r\n  }\r\n\r\n  expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu);\r\n  }\r\n\r\n  ajustarHeigthCard(): number {\r\n    if (this.widthCard > 400) {\r\n      if (this.breadCrumbs) return 105\r\n      else return 85\r\n    } else return 83\r\n  }\r\n\r\n  verificarPaginaSelecionada(link: any): string {\r\n    if (this.router.url.includes(link)) return 'bg-green-600'\r\n    else return '';\r\n  }\r\n\r\n  // retornarTituloBreadCrumbs(label: any): string {\r\n  //   if (label)\r\n  //     return this.breadCrumbItems[this.breadCrumbItems.length - 1]?.label\r\n  //   else return '';\r\n  // }\r\n\r\n  retornarTituloBreadCrumbs(str: string) {\r\n\r\n    if (str.includes('-')) {\r\n      str = str.replace('-', ' ');\r\n    }\r\n\r\n    var primeiraLetra = str.charAt(0).toUpperCase() + str.slice(1);\r\n\r\n    str.slice(1);\r\n\r\n    return primeiraLetra;\r\n  }\r\n}\r\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\r\n\r\n  <div [style]=\"{minWidth: expandMenu ? '300px' : '60px'}\"></div>\r\n\r\n  <p-sidebar\r\n    #sidebarRef\r\n    [visible]=\"true\"\r\n    [showCloseIcon]=\"false\"\r\n    [modal]=\"false\"\r\n    [style]=\"{width: expandMenu ? '300px' : '60px'}\"\r\n  >\r\n    <ng-template pTemplate=\"headless\">\r\n      <div class=\"flex flex-column {{expandMenu ? 'mx-1' : 'mx-1'}}\">\r\n        <div class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2\">\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}} py-3\"\r\n          >\r\n            <img\r\n              *ngIf=\"expandMenu\"\r\n              alt=\"Card\"\r\n              [src]=\"logoImage\"\r\n              width=\"150\"\r\n            />\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"toggleMenu()\"\r\n              [pTooltip]=\"expandMenu ? 'Ocutar Menu' : 'Expandir Menu'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                menu\r\n              </i>\r\n            </button>\r\n          </div>\r\n\r\n          <div\r\n            class=\"flex flex-row align-items-center {{expandMenu ? 'justify-content-between' : 'justify-content-center'}}\"\r\n          >\r\n            <div\r\n              class=\"flex flex-column cursor-pointer\"\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"visibleDialogLicenca = !visibleDialogLicenca\"\r\n            >\r\n              <span\r\n                class=\"text-sm font-semibold mr-2\"\r\n                [pTooltip]=\"this.licencaSelecionada.razaosocial\"\r\n                [tooltipPosition]=\"'right'\"\r\n              >\r\n                {{MascaraNomeLicenca(this.licencaSelecionada.razaosocial)}}\r\n              </span>\r\n              <span class=\"text-sm mt-1\">{{MascaraCnpj(this.licencaSelecionada.cnpj)}}</span>\r\n            </div>\r\n\r\n            <button\r\n              pButton\r\n              class=\"p-button-rounded p-button-text padding-style h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu\"\r\n              (click)=\"visibleDialogLicenca = !visibleDialogLicenca\"\r\n              [pTooltip]=\"'Alterar Licença'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\">\r\n                sync_alt\r\n              </i>\r\n            </button>\r\n\r\n          </div>\r\n          <p-divider type=\"solid\"></p-divider>\r\n        </div>\r\n\r\n        <div\r\n          class=\"list-none m-0  card-container {{expandMenu ? 'mx-1' : ''}}\"\r\n          [style.max-height]=\"(heigthCard - 220) + 'px'\"\r\n          style=\"overflow-y: auto;\"\r\n        >\r\n          <!-- menus -->\r\n          <li *ngFor=\"let menu of menus\">\r\n            <!-- menu que não tem filho -->\r\n            <a\r\n              (click)=\"callRoute(menu.link)\"\r\n              *ngIf=\"!menu.menupai && menu.idmenupai == 0\"\r\n              pRipple\r\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n              [tooltipPosition]=\"'right'\"\r\n              class=\"{{verificarPaginaSelecionada(menu.link)}} menu-option flex align-items-center no-underline {{!expandMenu ? 'justify-content-center' : ''}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n            >\r\n\r\n              <i\r\n                class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}\"\r\n                *ngIf=\"menu.icone && menu.icone !== ''\"\r\n              >\r\n                {{ menu.icone }}\r\n              </i>\r\n              <span\r\n                class=\"text-base text-blue-900 font-medium\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ menu.descricaomenu }}</span>\r\n            </a>\r\n            <!-- menu com filho -->\r\n            <div *ngIf=\"menu.menupai\">\r\n              <a\r\n                pRipple\r\n                pStyleClass=\"@next\"\r\n                enterClass=\"hidden\"\r\n                enterActiveClass=\"slidedown\"\r\n                leaveToClass=\"hidden\"\r\n                leaveActiveClass=\"slideup\"\r\n                class=\"menu-option flex align-items-center {{!expandMenu ? 'justify-content-center' : 'justify-content-between'}} cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n                [tooltipPosition]=\"'right'\"\r\n                [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n                (click)=\"!expandMenu ? expandMenu = !expandMenu : ''\"\r\n              >\r\n                <div class=\"flex flex-row align-items-center\">\r\n\r\n                  <i\r\n                    class=\"material-symbols-outlined icon-menu {{expandMenu ? 'ml-1 mr-2' : ''}}\"\r\n                    *ngIf=\"menu.icone && menu.icone !== ''\"\r\n                  >\r\n                    {{ menu.icone }}\r\n                  </i>\r\n                  <span\r\n                    class=\"text-base text-blue-900 font-medium\"\r\n                    *ngIf=\"expandMenu\"\r\n                  >{{ menu.descricaomenu }}</span>\r\n                </div>\r\n                <i\r\n                  class=\"pi pi-chevron-down text-blue-900 mr-1\"\r\n                  *ngIf=\"expandMenu\"\r\n                ></i>\r\n              </a>\r\n\r\n              <!-- filhos -->\r\n              <div\r\n                class=\"list-none py-0 pl-3 pr-0 m-0 hidden overflow-y-hidden transition-all transition-duration-400 transition-ease-in-out\"\r\n              >\r\n          <li *ngFor=\"\r\n              let filho of retornarMenuFilhos(menu.idsistema, menu.idmenu)\r\n            \">\r\n            <a\r\n              *ngIf=\"expandMenu\"\r\n              (click)=\"callRoute(filho.link)\"\r\n              pRipple\r\n              class=\"{{verificarPaginaSelecionada(filho.link)}} menu-option flex align-items-center no-underline cursor-pointer border-round text-700 hover:bg-green-600 transition-duration-150 transition-colors p-ripple p-2\"\r\n            >\r\n              <i\r\n                class=\"pi pi-chart-line mr-2 ml-1 adjust-icon-menu\"\r\n                *ngIf=\"filho.icone && filho.icone !== ''\"\r\n              ></i>\r\n              <span\r\n                class=\"text-base text-blue-900 ml-4\"\r\n                *ngIf=\"expandMenu\"\r\n              >{{ filho.descricaomenu }}</span>\r\n            </a>\r\n          </li>\r\n        </div>\r\n      </div>\r\n</div>\r\n</div>\r\n</ng-template>\r\n</p-sidebar>\r\n\r\n\r\n<div\r\n  class=\"w-auto h-screen page-content overflow-y-hidden\"\r\n  id=\"page-content\"\r\n>\r\n\r\n  <div class=\"flex flex-row align-items-center justify-content-between m-3\">\r\n    <div *ngIf=\"breadCrumbs\">\r\n      <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">{{breadCrumbItems[breadCrumbItems.length -\r\n        1]?.label}}</p>\r\n      <p-breadcrumb\r\n        *ngIf=\"widthCard > 400\"\r\n        styleClass=\"border-none p-0 flex align-items-center h-2rem !important;\"\r\n        [model]=\"breadCrumbItems\"\r\n        [style]=\"{backgroundColor: '#d4d3d3'}\"\r\n        (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n      ></p-breadcrumb>\r\n    </div>\r\n\r\n    <div *ngIf=\"!breadCrumbs\"></div>\r\n\r\n    <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n      <button\r\n        pButton\r\n        class=\"p-button-rounded p-button-text h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu padding-style\"\r\n        (click)=\"sistemasPanel.toggle($event)\"\r\n        [pTooltip]=\"'Sistemas'\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        <i class=\"material-symbols-outlined\">\r\n          apps\r\n        </i>\r\n      </button>\r\n      <button\r\n        pButton\r\n        class=\"p-button-rounded p-button-text h-2rem w-2rem hover:bg-green-600 hover:text-white icon-menu padding-style\"\r\n        (click)=\"meusDadosPanel.toggle($event)\"\r\n        [pTooltip]=\"'Menu do Usuário'\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        <i class=\"material-symbols-outlined\">\r\n          person\r\n        </i>\r\n      </button>\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p-card\r\n    class=\"card-container\"\r\n    styleClass=\"m-3 border-noround overflow-y-auto card-container\"\r\n    [style]=\"{height: heigthCard - ajustarHeigthCard() + 'px'}\"\r\n  >\r\n    <div class=\"card-container w-full\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n  </p-card>\r\n\r\n</div>\r\n\r\n\r\n</div>\r\n\r\n<p-overlayPanel\r\n  #sistemasPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n\r\n  <ng-template pTemplate=\"container\">\r\n\r\n    <p class=\"title-style mt-3\">Sistemas</p>\r\n    <div\r\n      class=\"flex flex-row flex-wrap gap-2 align-items-center justify-content-center mt-5 mb-3\"\r\n      style=\"width: 250px; height: 100%;\"\r\n    >\r\n      <button\r\n        *ngFor=\"let menu of menuCompleto\"\r\n        pButton\r\n        pRipple\r\n        class=\"btn-sistema-2 btn-sistema hover-btn-cor-padrao remove-focus h-4rem w-4rem\"\r\n        (click)=\"definirMenusPorSistema(menu.sistema.idsistema)\"\r\n        [pTooltip]=\"menu.sistema.descricaosistema\"\r\n        [tooltipPosition]=\"'left'\"\r\n      >\r\n        <!-- <img\r\n          alt=\"logo\"\r\n          style=\"width: 2rem; height: 2rem;\"\r\n        /> -->\r\n        {{ menu.sistema.nomesistema.charAt(0).toUpperCase() }}\r\n\r\n      </button>\r\n\r\n\r\n      <!-- <p-button styleClass=\"p-button-outlined\">\r\n        <img alt=\"logo\" src=\"https://primefaces.org/cdn/primeng/images/primeng-icon.svg\" style=\"width: 1.5rem\" />\r\n        <span class=\"ml-2 font-bold\">PrimeNG</span>\r\n    </p-button> -->\r\n\r\n    </div>\r\n  </ng-template>\r\n</p-overlayPanel>\r\n\r\n<p-overlayPanel\r\n  #meusDadosPanel\r\n  [showTransitionOptions]=\"'350ms ease-out'\"\r\n  [hideTransitionOptions]=\"'250ms ease-in'\"\r\n>\r\n\r\n  <ng-template pTemplate=\"container\">\r\n\r\n    <p class=\"title-style mt-3\">Olá, {{nomeUsuario ? nomeUsuario.split(' ')[0] : 'Usuário'}} !</p>\r\n    <div class=\"mt-5 mb-3\">\r\n\r\n    </div>\r\n\r\n    <p-button\r\n      icon=\"pi pi-lock\"\r\n      label=\"Gerênciar KeevoPass\"\r\n      (onClick)=\"gerenciarKeePass($event)\"\r\n      styleClass=\"border-noround w-full p-button-text text-blue-900\"\r\n      [disabled]=\"true\"\r\n    ></p-button>\r\n    <p-button\r\n      icon=\"pi pi-sign-out\"\r\n      label=\"Sair\"\r\n      (onClick)=\"sair($event)\"\r\n      styleClass=\"border-noround w-full p-button-text text-blue-900\"\r\n    ></p-button>\r\n  </ng-template>\r\n\r\n</p-overlayPanel>\r\n\r\n<p-dialog\r\n  [(visible)]=\"visibleDialogLicenca\"\r\n  [modal]=\"true\"\r\n  [draggable]=\"false\"\r\n  header=\"Trocar Licença\"\r\n  [style]=\"{width: '50vh' }\"\r\n>\r\n  <div class=\"flex flex-column align-items-end\">\r\n\r\n    <div class=\"w-full\">\r\n      <p-dropdown\r\n        styleClass=\"w-full\"\r\n        [options]=\"licencasOptions\"\r\n        [(ngModel)]=\"licencaSelected\"\r\n        optionLabel=\"descricao\"\r\n      ></p-dropdown>\r\n    </div>\r\n\r\n    <kv-button-success\r\n      [label]=\"'Salvar'\"\r\n      class=\"mt-2\"\r\n      (onClick)=\"setLicenca()\"\r\n    ></kv-button-success>\r\n\r\n  </div>\r\n\r\n</p-dialog>\r\n\r\n<!-- <p-confirmDialog\r\n  [style]=\"{width: '40vw'}\"\r\n  [baseZIndex]=\"10000\"\r\n  rejectButtonStyleClass=\"p-button-text\"\r\n>\r\n</p-confirmDialog>\r\n\r\n<p-toast></p-toast> -->"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import { FormGroup } from '@angular/forms';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/forms";
|
|
@@ -98,10 +98,10 @@ export class PageFormComponent {
|
|
|
98
98
|
}
|
|
99
99
|
}
|
|
100
100
|
PageFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: PageFormComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
-
PageFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: PageFormComponent, selector: "kv-page-form", inputs: { formGroup: "formGroup", TituloForm: "TituloForm", SubTituloForm: "SubTituloForm", isSaveLoading: "isSaveLoading", popup: "popup", locationUseComponent: "locationUseComponent", iconBtnCancel: "iconBtnCancel", showBtnCancel: "showBtnCancel", txtBtnCancel: "txtBtnCancel", iconBtnSave: "iconBtnSave", showBtnSave: "showBtnSave", txtBtnSave: "txtBtnSave", actions: "actions", iconBtnSaveToogle: "iconBtnSaveToogle", showBtnSaveToogle: "showBtnSaveToogle", txtBtnSaveToogle: "txtBtnSaveToogle", disableBtnSair: "disableBtnSair" }, outputs: { onSave: "onSave", onCancel: "onCancel" }, ngImport: i0, template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i3.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i4.ButtonSecondaryComponent, selector: "kv-button-secondary" }, { kind: "component", type: i5.ButtonSuccessComponent, selector: "kv-button-success" }, { kind: "component", type: i6.ButtonPopupComponent, selector: "kv-button-popup", inputs: ["items"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
101
|
+
PageFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: PageFormComponent, selector: "kv-page-form", inputs: { formGroup: "formGroup", TituloForm: "TituloForm", SubTituloForm: "SubTituloForm", isSaveLoading: "isSaveLoading", popup: "popup", locationUseComponent: "locationUseComponent", iconBtnCancel: "iconBtnCancel", showBtnCancel: "showBtnCancel", txtBtnCancel: "txtBtnCancel", iconBtnSave: "iconBtnSave", showBtnSave: "showBtnSave", txtBtnSave: "txtBtnSave", actions: "actions", iconBtnSaveToogle: "iconBtnSaveToogle", showBtnSaveToogle: "showBtnSaveToogle", txtBtnSaveToogle: "txtBtnSaveToogle", disableBtnSair: "disableBtnSair" }, outputs: { onSave: "onSave", onCancel: "onCancel" }, ngImport: i0, template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i3.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i4.ButtonSecondaryComponent, selector: "kv-button-secondary" }, { kind: "component", type: i5.ButtonSuccessComponent, selector: "kv-button-success" }, { kind: "component", type: i6.ButtonPopupComponent, selector: "kv-button-popup", inputs: ["items"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
102
102
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: PageFormComponent, decorators: [{
|
|
103
103
|
type: Component,
|
|
104
|
-
args: [{ selector: 'kv-page-form', template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"] }]
|
|
104
|
+
args: [{ selector: 'kv-page-form', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"] }]
|
|
105
105
|
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { formGroup: [{
|
|
106
106
|
type: Input
|
|
107
107
|
}], TituloForm: [{
|
|
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
|
141
141
|
}], onCancel: [{
|
|
142
142
|
type: Output
|
|
143
143
|
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-form.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/page-form/page-form.component.ts","../../../../../projects/keevo-components/src/lib/page-form/page-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport { ActionItem } from '../api/components/table/action-item';\r\n\r\n@Component({\r\n  selector: 'kv-page-form',\r\n  templateUrl: './page-form.component.html',\r\n  styleUrls: ['./page-form.component.scss']\r\n})\r\nexport class PageFormComponent implements OnInit {\r\n\r\n  /**\r\n   * Configurações do formulário\r\n   */\r\n  @Input() formGroup: FormGroup = new FormGroup({});\r\n  @Input() TituloForm: string | undefined = '';\r\n  @Input() SubTituloForm: string | undefined = '';\r\n  @Input() isSaveLoading!: boolean;\r\n  @Input() popup: boolean = false;\r\n  @Input() locationUseComponent: 'page' | 'dialog' = 'dialog';\r\n  // @Input() expandMenu!: boolean;\r\n\r\n  /**\r\n   * Botão cancelar\r\n   */\r\n  @Input() iconBtnCancel: string = 'pi pi-fw pi-times';\r\n  @Input() showBtnCancel: boolean = true;\r\n  @Input() txtBtnCancel: string = \"Cancelar\";\r\n\r\n  /**\r\n   * Botão salvar\r\n   */\r\n  @Input() iconBtnSave: string = 'pi pi-save';\r\n  @Input() showBtnSave: boolean = true;\r\n  @Input() txtBtnSave: string = \"Salvar\";\r\n\r\n  /**\r\n   * Botão de opções\r\n   */\r\n  @Input() actions!: ActionItem[];\r\n  @Input() iconBtnSaveToogle: string = \"pi pi-chevron-down\";\r\n  @Input() showBtnSaveToogle: boolean = false;\r\n  @Input() txtBtnSaveToogle: string = \"Ações\";\r\n\r\n  /**\r\n   * Botão fechar\r\n   */\r\n  @Input() disableBtnSair: boolean = true;\r\n\r\n  /**\r\n   * Salvar dados\r\n   */\r\n  @Output() onSave: EventEmitter<any> = new EventEmitter();\r\n\r\n  /**\r\n   * Cancelar\r\n   */\r\n  @Output() onCancel: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(private fb: FormBuilder) { }\r\n\r\n  /**\r\n   * Adiciona sub-título à tela\r\n   */\r\n  addSubTitle() {\r\n    if (this.SubTituloForm) {\r\n      const headerElement = document.querySelector('.p-dialog .p-dialog-header');\r\n      if (headerElement) {\r\n        const subtitleElement = document.createElement('span');\r\n        subtitleElement.textContent = this.SubTituloForm;\r\n        subtitleElement.style.fontSize = '0.75rem'\r\n        subtitleElement.style.width = '100%'\r\n        subtitleElement.style.marginLeft = '2px'\r\n\r\n        headerElement.appendChild(subtitleElement);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n    this.addSubTitle();\r\n    this.setPageFormContainerAttributes();\r\n  }\r\n\r\n  /**\r\n   * Dispara o método de cancelamento da tela\r\n   * @param event evento\r\n   */\r\n  cancel(event: Event) {\r\n    this.onCancel.emit(event);\r\n  }\r\n\r\n  /**\r\n   * Dispara o método de salvar da tela\r\n   * @param event evento\r\n   */\r\n  save(event: Event) {\r\n    this.onSave.emit(event);\r\n  }\r\n\r\n  /**\r\n   * Ajusta o tamanho da tela considerando o menu lateral\r\n   */\r\n  setPageFormContainerAttributes() {\r\n    if (this.locationUseComponent == 'page') {\r\n      var form = document.getElementById('page-form-container');\r\n\r\n      if (form) {\r\n        var widthFull = form.clientWidth;\r\n        var widthAdjusted;\r\n\r\n        widthAdjusted = widthFull - 332\r\n\r\n        // if (this.expandMenu) widthAdjusted = widthFull - 332;\r\n        // else widthAdjusted = widthFull - 92;\r\n      }\r\n    }\r\n  }\r\n}","<div\r\n  [formGroup]=\"formGroup\"\r\n  class=\"grid-nogutter m-0\"\r\n  id=\"page-form-container\"\r\n>\r\n\r\n  <!-- Renderização do form -->\r\n  <div class=\"col-12 p-0\">\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n  <!-- Divider -->\r\n  <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n  <!-- Barra de ações -->\r\n  <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n    <kv-button-secondary\r\n      *ngIf=\"showBtnCancel\"\r\n      [label]=\"txtBtnCancel\"\r\n      [icon]=\"iconBtnCancel\"\r\n      (click)=\"cancel($event)\"\r\n      class=\"w-full lg:w-auto\"\r\n    >\r\n    </kv-button-secondary>\r\n\r\n    <kv-button-success\r\n      *ngIf=\"showBtnSave\"\r\n      [label]=\"txtBtnSave\"\r\n      [icon]=\"iconBtnSave\"\r\n      [loading]=\"isSaveLoading\"\r\n      (click)=\"save($event)\"\r\n      class=\"w-full lg:w-auto\"\r\n    />\r\n\r\n\r\n    <kv-button-popup\r\n      *ngIf=\"actions && showBtnSaveToogle\"\r\n      [label]=\"txtBtnSaveToogle\"\r\n      [icon]=\"iconBtnSaveToogle\"\r\n      (click)=\"menu.toggle($event)\"\r\n      [loading]=\"isSaveLoading\"\r\n      class=\"w-full lg:w-auto\"\r\n    >\r\n    </kv-button-popup>\r\n\r\n    <p-menu\r\n      #menu\r\n      [popup]=\"true\"\r\n      [model]=\"actions\"\r\n      appendTo=\"body\"\r\n      class=\"w-full lg:w-auto\"\r\n    ></p-menu>\r\n  </div>\r\n\r\n</div>"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-form.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/page-form/page-form.component.ts","../../../../../projects/keevo-components/src/lib/page-form/page-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport { ActionItem } from '../api/components/table/action-item';\r\n\r\n@Component({\r\n  selector: 'kv-page-form',\r\n  templateUrl: './page-form.component.html',\r\n  styleUrls: ['./page-form.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class PageFormComponent implements OnInit {\r\n\r\n  /**\r\n   * Configurações do formulário\r\n   */\r\n  @Input() formGroup: FormGroup = new FormGroup({});\r\n  @Input() TituloForm: string | undefined = '';\r\n  @Input() SubTituloForm: string | undefined = '';\r\n  @Input() isSaveLoading!: boolean;\r\n  @Input() popup: boolean = false;\r\n  @Input() locationUseComponent: 'page' | 'dialog' = 'dialog';\r\n  // @Input() expandMenu!: boolean;\r\n\r\n  /**\r\n   * Botão cancelar\r\n   */\r\n  @Input() iconBtnCancel: string = 'pi pi-fw pi-times';\r\n  @Input() showBtnCancel: boolean = true;\r\n  @Input() txtBtnCancel: string = \"Cancelar\";\r\n\r\n  /**\r\n   * Botão salvar\r\n   */\r\n  @Input() iconBtnSave: string = 'pi pi-save';\r\n  @Input() showBtnSave: boolean = true;\r\n  @Input() txtBtnSave: string = \"Salvar\";\r\n\r\n  /**\r\n   * Botão de opções\r\n   */\r\n  @Input() actions!: ActionItem[];\r\n  @Input() iconBtnSaveToogle: string = \"pi pi-chevron-down\";\r\n  @Input() showBtnSaveToogle: boolean = false;\r\n  @Input() txtBtnSaveToogle: string = \"Ações\";\r\n\r\n  /**\r\n   * Botão fechar\r\n   */\r\n  @Input() disableBtnSair: boolean = true;\r\n\r\n  /**\r\n   * Salvar dados\r\n   */\r\n  @Output() onSave: EventEmitter<any> = new EventEmitter();\r\n\r\n  /**\r\n   * Cancelar\r\n   */\r\n  @Output() onCancel: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(private fb: FormBuilder) { }\r\n\r\n  /**\r\n   * Adiciona sub-título à tela\r\n   */\r\n  addSubTitle() {\r\n    if (this.SubTituloForm) {\r\n      const headerElement = document.querySelector('.p-dialog .p-dialog-header');\r\n      if (headerElement) {\r\n        const subtitleElement = document.createElement('span');\r\n        subtitleElement.textContent = this.SubTituloForm;\r\n        subtitleElement.style.fontSize = '0.75rem'\r\n        subtitleElement.style.width = '100%'\r\n        subtitleElement.style.marginLeft = '2px'\r\n\r\n        headerElement.appendChild(subtitleElement);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n    this.addSubTitle();\r\n    this.setPageFormContainerAttributes();\r\n  }\r\n\r\n  /**\r\n   * Dispara o método de cancelamento da tela\r\n   * @param event evento\r\n   */\r\n  cancel(event: Event) {\r\n    this.onCancel.emit(event);\r\n  }\r\n\r\n  /**\r\n   * Dispara o método de salvar da tela\r\n   * @param event evento\r\n   */\r\n  save(event: Event) {\r\n    this.onSave.emit(event);\r\n  }\r\n\r\n  /**\r\n   * Ajusta o tamanho da tela considerando o menu lateral\r\n   */\r\n  setPageFormContainerAttributes() {\r\n    if (this.locationUseComponent == 'page') {\r\n      var form = document.getElementById('page-form-container');\r\n\r\n      if (form) {\r\n        var widthFull = form.clientWidth;\r\n        var widthAdjusted;\r\n\r\n        widthAdjusted = widthFull - 332\r\n\r\n        // if (this.expandMenu) widthAdjusted = widthFull - 332;\r\n        // else widthAdjusted = widthFull - 92;\r\n      }\r\n    }\r\n  }\r\n}","<div\r\n  [formGroup]=\"formGroup\"\r\n  class=\"grid-nogutter m-0\"\r\n  id=\"page-form-container\"\r\n>\r\n\r\n  <!-- Renderização do form -->\r\n  <div class=\"col-12 p-0\">\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n  <!-- Divider -->\r\n  <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n  <!-- Barra de ações -->\r\n  <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n    <kv-button-secondary\r\n      *ngIf=\"showBtnCancel\"\r\n      [label]=\"txtBtnCancel\"\r\n      [icon]=\"iconBtnCancel\"\r\n      (click)=\"cancel($event)\"\r\n      class=\"w-full lg:w-auto\"\r\n    >\r\n    </kv-button-secondary>\r\n\r\n    <kv-button-success\r\n      *ngIf=\"showBtnSave\"\r\n      [label]=\"txtBtnSave\"\r\n      [icon]=\"iconBtnSave\"\r\n      [loading]=\"isSaveLoading\"\r\n      (click)=\"save($event)\"\r\n      class=\"w-full lg:w-auto\"\r\n    />\r\n\r\n\r\n    <kv-button-popup\r\n      *ngIf=\"actions && showBtnSaveToogle\"\r\n      [label]=\"txtBtnSaveToogle\"\r\n      [icon]=\"iconBtnSaveToogle\"\r\n      (click)=\"menu.toggle($event)\"\r\n      [loading]=\"isSaveLoading\"\r\n      class=\"w-full lg:w-auto\"\r\n    >\r\n    </kv-button-popup>\r\n\r\n    <p-menu\r\n      #menu\r\n      [popup]=\"true\"\r\n      [model]=\"actions\"\r\n      appendTo=\"body\"\r\n      class=\"w-full lg:w-auto\"\r\n    ></p-menu>\r\n  </div>\r\n\r\n</div>"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Component, Input, EventEmitter, Output, ViewChild, Injectable, ViewChildren, ContentChildren, NgModule, forwardRef, Directive, Pipe, HostListener } from '@angular/core';
|
|
2
|
+
import { Component, Input, EventEmitter, Output, ViewChild, Injectable, ViewChildren, ContentChildren, NgModule, forwardRef, Directive, Pipe, HostListener, ChangeDetectionStrategy } from '@angular/core';
|
|
3
3
|
import { Subject, combineLatest, filter, finalize, of } from 'rxjs';
|
|
4
4
|
import * as i1 from '@angular/common';
|
|
5
5
|
import { CommonModule } from '@angular/common';
|
|
@@ -2978,9 +2978,9 @@ class MenuComponent {
|
|
|
2978
2978
|
this.configurarLicencas();
|
|
2979
2979
|
this.router.events.subscribe((event) => {
|
|
2980
2980
|
if (event instanceof NavigationEnd) {
|
|
2981
|
-
console.log('Evento de navegação:', event);
|
|
2981
|
+
// console.log('Evento de navegação:', event);
|
|
2982
2982
|
this.breadCrumbItems = this.getBreadcrumbs(event.url);
|
|
2983
|
-
console.log("breadCrumbItems ->", this.breadCrumbItems);
|
|
2983
|
+
// console.log("breadCrumbItems ->", this.breadCrumbItems);
|
|
2984
2984
|
}
|
|
2985
2985
|
});
|
|
2986
2986
|
this.heigthCard = Number((_a = document.getElementById('page-content')) === null || _a === void 0 ? void 0 : _a.offsetHeight);
|
|
@@ -3042,9 +3042,9 @@ class MenuComponent {
|
|
|
3042
3042
|
this.menus =
|
|
3043
3043
|
((_a = this.menuCompleto.find((x) => x.sistema.idsistema == idsistema)) === null || _a === void 0 ? void 0 : _a.menus) ||
|
|
3044
3044
|
[];
|
|
3045
|
-
console.log(this.menus, 'menus')
|
|
3046
|
-
console.log(this.menuCompleto, 'menuCompleto')
|
|
3047
|
-
console.log(this.menus[0].menupai, 'menupai')
|
|
3045
|
+
// console.log(this.menus, 'menus')
|
|
3046
|
+
// console.log(this.menuCompleto, 'menuCompleto')
|
|
3047
|
+
// console.log(this.menus[0].menupai, 'menupai')
|
|
3048
3048
|
if (this.menus[0].menupai) {
|
|
3049
3049
|
var filhos = this.retornarMenuFilhos(this.menus[0].idsistema, this.menus[0].idmenu);
|
|
3050
3050
|
if (filhos != undefined)
|
|
@@ -3989,10 +3989,10 @@ class PageFormComponent {
|
|
|
3989
3989
|
}
|
|
3990
3990
|
}
|
|
3991
3991
|
PageFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: PageFormComponent, deps: [{ token: i2$1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
3992
|
-
PageFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: PageFormComponent, selector: "kv-page-form", inputs: { formGroup: "formGroup", TituloForm: "TituloForm", SubTituloForm: "SubTituloForm", isSaveLoading: "isSaveLoading", popup: "popup", locationUseComponent: "locationUseComponent", iconBtnCancel: "iconBtnCancel", showBtnCancel: "showBtnCancel", txtBtnCancel: "txtBtnCancel", iconBtnSave: "iconBtnSave", showBtnSave: "showBtnSave", txtBtnSave: "txtBtnSave", actions: "actions", iconBtnSaveToogle: "iconBtnSaveToogle", showBtnSaveToogle: "showBtnSaveToogle", txtBtnSaveToogle: "txtBtnSaveToogle", disableBtnSair: "disableBtnSair" }, outputs: { onSave: "onSave", onCancel: "onCancel" }, ngImport: i0, template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i5.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "component", type: ButtonSecondaryComponent, selector: "kv-button-secondary" }, { kind: "component", type: ButtonSuccessComponent, selector: "kv-button-success" }, { kind: "component", type: ButtonPopupComponent, selector: "kv-button-popup", inputs: ["items"] }, { kind: "directive", type: i2$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
3992
|
+
PageFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: PageFormComponent, selector: "kv-page-form", inputs: { formGroup: "formGroup", TituloForm: "TituloForm", SubTituloForm: "SubTituloForm", isSaveLoading: "isSaveLoading", popup: "popup", locationUseComponent: "locationUseComponent", iconBtnCancel: "iconBtnCancel", showBtnCancel: "showBtnCancel", txtBtnCancel: "txtBtnCancel", iconBtnSave: "iconBtnSave", showBtnSave: "showBtnSave", txtBtnSave: "txtBtnSave", actions: "actions", iconBtnSaveToogle: "iconBtnSaveToogle", showBtnSaveToogle: "showBtnSaveToogle", txtBtnSaveToogle: "txtBtnSaveToogle", disableBtnSair: "disableBtnSair" }, outputs: { onSave: "onSave", onCancel: "onCancel" }, ngImport: i0, template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i5.Menu, selector: "p-menu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "component", type: ButtonSecondaryComponent, selector: "kv-button-secondary" }, { kind: "component", type: ButtonSuccessComponent, selector: "kv-button-success" }, { kind: "component", type: ButtonPopupComponent, selector: "kv-button-popup", inputs: ["items"] }, { kind: "directive", type: i2$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
3993
3993
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: PageFormComponent, decorators: [{
|
|
3994
3994
|
type: Component,
|
|
3995
|
-
args: [{ selector: 'kv-page-form', template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"] }]
|
|
3995
|
+
args: [{ selector: 'kv-page-form', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n [formGroup]=\"formGroup\"\r\n class=\"grid-nogutter m-0\"\r\n id=\"page-form-container\"\r\n>\r\n\r\n <!-- Renderiza\u00E7\u00E3o do form -->\r\n <div class=\"col-12 p-0\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n <!-- Divider -->\r\n <!-- <p-divider class=\"col-12\"></p-divider> -->\r\n\r\n <!-- Barra de a\u00E7\u00F5es -->\r\n <div class=\"flex flex-column lg:flex-row justify-content-end col-12 gap-2 barra-acoes grid grid-nogutter p-fluid\">\r\n\r\n\r\n <kv-button-secondary\r\n *ngIf=\"showBtnCancel\"\r\n [label]=\"txtBtnCancel\"\r\n [icon]=\"iconBtnCancel\"\r\n (click)=\"cancel($event)\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-secondary>\r\n\r\n <kv-button-success\r\n *ngIf=\"showBtnSave\"\r\n [label]=\"txtBtnSave\"\r\n [icon]=\"iconBtnSave\"\r\n [loading]=\"isSaveLoading\"\r\n (click)=\"save($event)\"\r\n class=\"w-full lg:w-auto\"\r\n />\r\n\r\n\r\n <kv-button-popup\r\n *ngIf=\"actions && showBtnSaveToogle\"\r\n [label]=\"txtBtnSaveToogle\"\r\n [icon]=\"iconBtnSaveToogle\"\r\n (click)=\"menu.toggle($event)\"\r\n [loading]=\"isSaveLoading\"\r\n class=\"w-full lg:w-auto\"\r\n >\r\n </kv-button-popup>\r\n\r\n <p-menu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"actions\"\r\n appendTo=\"body\"\r\n class=\"w-full lg:w-auto\"\r\n ></p-menu>\r\n </div>\r\n\r\n</div>", styles: ["::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}.sub-title{color:#ff0;position:relative;bottom:25px;z-index:1}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}*{padding-bottom:0rem;padding-top:0rem}.barra-acoes{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:10px;z-index:999}#page-form-container{padding-bottom:40px}@media screen and (max-width: 991px){#page-form-container{padding-bottom:130px}}\n"] }]
|
|
3996
3996
|
}], ctorParameters: function () { return [{ type: i2$1.FormBuilder }]; }, propDecorators: { formGroup: [{
|
|
3997
3997
|
type: Input
|
|
3998
3998
|
}], TituloForm: [{
|