keevo-components 1.8.293 → 1.8.295
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-filter-card/kv-filter-card.component.mjs +6 -3
- package/esm2022/lib/components/kv-layout/layout/kv-layout.component.mjs +7 -8
- package/fesm2022/keevo-components.mjs +11 -9
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-filter-card/kv-filter-card.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -5,13 +5,14 @@ import * as i2 from "../kv-g-icon/kv-g-icon.component";
|
|
|
5
5
|
export class KvFilterCardComponent {
|
|
6
6
|
constructor() {
|
|
7
7
|
this.cardState = "normal";
|
|
8
|
+
this.spaceNowrap = false;
|
|
8
9
|
}
|
|
9
10
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFilterCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvFilterCardComponent, selector: "kv-filter-card", inputs: { cardState: "cardState", color: "color", title: "title", amount: "amount", gIcon: "gIcon" }, ngImport: i0, template: "<div
|
|
11
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvFilterCardComponent, selector: "kv-filter-card", inputs: { cardState: "cardState", color: "color", title: "title", amount: "amount", gIcon: "gIcon", spaceNowrap: "spaceNowrap" }, ngImport: i0, template: "<div\r\n [style]=\"{ '--accent-color': color }\"\r\n [ngClass]=\"[\r\n cardState == 'inactive' ? 'card-disabled' : 'card',\r\n cardState == 'selected' ? 'clickable-selected' : 'clickable'\r\n ]\"\r\n>\r\n <div class=\"filter-card-content\">\r\n <div class=\"flex-row-center\">\r\n @if (gIcon) {\r\n <kv-g-icon>{{ gIcon }}</kv-g-icon>\r\n }\r\n <ng-content select=\"[icon]\"></ng-content>\r\n <p class=\"{{spaceNowrap && 'white-space-nowrap'}} font-bold\">{{ title }}</p>\r\n </div>\r\n <p style=\"font-size: 2em\" class=\"font-bold\">{{ amount }}</p>\r\n </div>\r\n</div>\r\n", styles: [".card{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem var(--accent-color);border-radius:10px}.card *{margin:0;color:var(--accent-color)}p{font-size:14px}.card-disabled{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem lightgrey;transition:border-left .2s ease;border-radius:10px}.card-disabled:hover{border-left:solid .4rem var(--accent-color);transition:border-left .2s ease}.card-disabled:hover *{color:var(--accent-color);transition:color .2s ease}.card-disabled *{margin:0;color:#d3d3d3;transition:color .2s ease}.clickable-selected{cursor:pointer;background-color:#eafaff}.clickable-selected:hover{background-color:#deeeff}.clickable{cursor:pointer}.clickable:hover{background-color:#f0f0f0}.filter-card-content{width:180px;display:flex;flex-direction:column;padding:1rem .6rem .6rem;gap:1.2rem}.select-none{-webkit-user-select:none;user-select:none}.flex-row-center{display:flex;flex-direction:row;align-items:center;gap:.4rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.KvGIconComponent, selector: "kv-g-icon" }] }); }
|
|
11
12
|
}
|
|
12
13
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFilterCardComponent, decorators: [{
|
|
13
14
|
type: Component,
|
|
14
|
-
args: [{ selector: 'kv-filter-card', template: "<div
|
|
15
|
+
args: [{ selector: 'kv-filter-card', template: "<div\r\n [style]=\"{ '--accent-color': color }\"\r\n [ngClass]=\"[\r\n cardState == 'inactive' ? 'card-disabled' : 'card',\r\n cardState == 'selected' ? 'clickable-selected' : 'clickable'\r\n ]\"\r\n>\r\n <div class=\"filter-card-content\">\r\n <div class=\"flex-row-center\">\r\n @if (gIcon) {\r\n <kv-g-icon>{{ gIcon }}</kv-g-icon>\r\n }\r\n <ng-content select=\"[icon]\"></ng-content>\r\n <p class=\"{{spaceNowrap && 'white-space-nowrap'}} font-bold\">{{ title }}</p>\r\n </div>\r\n <p style=\"font-size: 2em\" class=\"font-bold\">{{ amount }}</p>\r\n </div>\r\n</div>\r\n", styles: [".card{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem var(--accent-color);border-radius:10px}.card *{margin:0;color:var(--accent-color)}p{font-size:14px}.card-disabled{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem lightgrey;transition:border-left .2s ease;border-radius:10px}.card-disabled:hover{border-left:solid .4rem var(--accent-color);transition:border-left .2s ease}.card-disabled:hover *{color:var(--accent-color);transition:color .2s ease}.card-disabled *{margin:0;color:#d3d3d3;transition:color .2s ease}.clickable-selected{cursor:pointer;background-color:#eafaff}.clickable-selected:hover{background-color:#deeeff}.clickable{cursor:pointer}.clickable:hover{background-color:#f0f0f0}.filter-card-content{width:180px;display:flex;flex-direction:column;padding:1rem .6rem .6rem;gap:1.2rem}.select-none{-webkit-user-select:none;user-select:none}.flex-row-center{display:flex;flex-direction:row;align-items:center;gap:.4rem}\n"] }]
|
|
15
16
|
}], propDecorators: { cardState: [{
|
|
16
17
|
type: Input
|
|
17
18
|
}], color: [{
|
|
@@ -22,5 +23,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
22
23
|
type: Input
|
|
23
24
|
}], gIcon: [{
|
|
24
25
|
type: Input
|
|
26
|
+
}], spaceNowrap: [{
|
|
27
|
+
type: Input
|
|
25
28
|
}] } });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtZmlsdGVyLWNhcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtZmlsdGVyLWNhcmQva3YtZmlsdGVyLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtZmlsdGVyLWNhcmQva3YtZmlsdGVyLWNhcmQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFPakQsTUFBTSxPQUFPLHFCQUFxQjtJQUxsQztRQU1XLGNBQVMsR0FBYyxRQUFRLENBQUM7UUFLaEMsZ0JBQVcsR0FBWSxLQUFLLENBQUM7S0FDdkM7OEdBUFkscUJBQXFCO2tHQUFyQixxQkFBcUIsd0xDUGxDLDhtQkFrQkE7OzJGRFhhLHFCQUFxQjtrQkFMakMsU0FBUzsrQkFDRSxnQkFBZ0I7OEJBS2pCLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2t2LWZpbHRlci1jYXJkJyxcclxuICB0ZW1wbGF0ZVVybDogJy4va3YtZmlsdGVyLWNhcmQuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9rdi1maWx0ZXItY2FyZC5jb21wb25lbnQuc2NzcycsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkZpbHRlckNhcmRDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIGNhcmRTdGF0ZTogQ2FyZFN0YXRlID0gXCJub3JtYWxcIjtcclxuICBASW5wdXQoKSBjb2xvciE6IHN0cmluZztcclxuICBASW5wdXQoKSB0aXRsZSE6IHN0cmluZztcclxuICBASW5wdXQoKSBhbW91bnQ/OiBudW1iZXI7XHJcbiAgQElucHV0KCkgZ0ljb24/OiBzdHJpbmc7XHJcbiAgQElucHV0KCkgc3BhY2VOb3dyYXA6IGJvb2xlYW4gPSBmYWxzZTtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgQ2FyZFN0YXRlID0gXCJub3JtYWxcIiB8IFwic2VsZWN0ZWRcIiB8IFwiaW5hY3RpdmVcIjtcclxuZXhwb3J0IHR5cGUgQ2FyZFN0YXRlQ2xhc3MgPSBcImNhcmRcIiB8IFwiUExBQ0VIT0xERVJcIiB8IFwiY2FyZC1kaXNhYmxlZFwiOyIsIjxkaXZcclxuICBbc3R5bGVdPVwieyAnLS1hY2NlbnQtY29sb3InOiBjb2xvciB9XCJcclxuICBbbmdDbGFzc109XCJbXHJcbiAgICBjYXJkU3RhdGUgPT0gJ2luYWN0aXZlJyA/ICdjYXJkLWRpc2FibGVkJyA6ICdjYXJkJyxcclxuICAgIGNhcmRTdGF0ZSA9PSAnc2VsZWN0ZWQnID8gJ2NsaWNrYWJsZS1zZWxlY3RlZCcgOiAnY2xpY2thYmxlJ1xyXG4gIF1cIlxyXG4+XHJcbiAgPGRpdiBjbGFzcz1cImZpbHRlci1jYXJkLWNvbnRlbnRcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJmbGV4LXJvdy1jZW50ZXJcIj5cclxuICAgICAgQGlmIChnSWNvbikge1xyXG4gICAgICA8a3YtZy1pY29uPnt7IGdJY29uIH19PC9rdi1nLWljb24+XHJcbiAgICAgIH1cclxuICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2ljb25dXCI+PC9uZy1jb250ZW50PlxyXG4gICAgICA8cCBjbGFzcz1cInt7c3BhY2VOb3dyYXAgJiYgJ3doaXRlLXNwYWNlLW5vd3JhcCd9fSBmb250LWJvbGRcIj57eyB0aXRsZSB9fTwvcD5cclxuICAgIDwvZGl2PlxyXG4gICAgPHAgc3R5bGU9XCJmb250LXNpemU6IDJlbVwiIGNsYXNzPVwiZm9udC1ib2xkXCI+e3sgYW1vdW50IH19PC9wPlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -161,19 +161,18 @@ export class KvLayoutComponent {
|
|
|
161
161
|
const url = new URL(this.router.url, window.origin);
|
|
162
162
|
const currentPath = url.pathname;
|
|
163
163
|
const purePath = currentPath.match(/^[^;]*/i);
|
|
164
|
-
const paths = purePath[0]
|
|
165
|
-
|
|
166
|
-
const truePath = '/' + paths.slice(0, paths?.length).join('/');
|
|
167
|
-
console.log(truePath, 'truePath');
|
|
164
|
+
const paths = purePath[0];
|
|
165
|
+
console.log(paths, 'paths lá em cima');
|
|
168
166
|
this.menus = this.menus.map((menu) => {
|
|
167
|
+
console.log(paths.includes(menu.link), paths, menu.link, 'paths comparacoes');
|
|
169
168
|
return {
|
|
170
169
|
...menu,
|
|
171
|
-
bgColor: menu.link
|
|
172
|
-
textColor: menu.link
|
|
170
|
+
bgColor: paths.includes(menu.link) ? 'bg-green-600' : '',
|
|
171
|
+
textColor: paths.includes(menu.link) ? 'text-white' : '',
|
|
173
172
|
};
|
|
174
173
|
});
|
|
175
174
|
this.menuSelecionado = this.menus.find((menu) => {
|
|
176
|
-
return menu.link
|
|
175
|
+
return paths.includes(menu.link);
|
|
177
176
|
});
|
|
178
177
|
}
|
|
179
178
|
returnMenuChild(idmenu) {
|
|
@@ -262,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
262
261
|
type: HostListener,
|
|
263
262
|
args: ['window:resize', ['$event']]
|
|
264
263
|
}] } });
|
|
265
|
-
//# 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  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\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\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  // animations: [\r\n  //   trigger('sidebarWidthTrigger', [\r\n  //     state('collapsed', style({\r\n  //       width: '60px'\r\n  //     })),\r\n  //     state('expanded', style({\r\n  //       width: '359px'\r\n  //     })),\r\n  //     transition('collapsed <=> expanded', animate('100ms ease-out'))\r\n  //   ])\r\n  // ]\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    urliconehidemenu?: string;\r\n  }[] = [];\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  @Input() menus: {\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  @Input() expandMenu: boolean = true;\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() userName: string = 'Usuário';\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  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\r\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\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  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  public accessKeePass(event: any) {\r\n    this.sistemasPanel.hide();\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.breadCrumbItems.length > 0) return 105;\r\n      else return 85;\r\n    } else return 83;\r\n  }\r\n\r\n  private adjustWidthCard() {\r\n    this.heightCard = Number(\r\n      document.getElementById('page-content')?.offsetHeight\r\n    );\r\n    if (this.showMenu)\r\n      this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n    else this.widthCard = Number(window.innerWidth);\r\n  }\r\n\r\n  public callRoute(e: any, expand?: boolean) {\r\n    if (!expand) !this.expandMenu ? (this.expandMenu = !this.expandMenu) : '';\r\n\r\n    this.router.navigateByUrl(e);\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 expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu);\r\n  }\r\n\r\n  public logout(event: any) {\r\n    this.sistemasPanel.hide();\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    if (this.sistemasPanel) {\r\n      this.sistemasPanel.hide();\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: any;\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  public ngOnInit(): void {\r\n    \r\n    this.formGroup = this.fb.group({\r\n      idmaster: [this.selectedMaster, []],\r\n    });\r\n\r\n    this.adjustWidthCard();\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  public onMouseEnter(index: number) {\r\n    this.mouseOverIndex = index;\r\n  }\r\n\r\n  public onMouseEnterChild(index: number) {\r\n    this.mouseOverFilhoIndex = index;\r\n  }\r\n\r\n  public onMouseLeave() {\r\n    this.mouseOverIndex = null;\r\n    this.mouseOverFilhoIndex = null;\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  public onWindowResize() {\r\n    this.adjustWidthCard();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  selecionarMenu() {\r\n\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].split('/');\r\n    \r\n    \r\n    paths.shift();\r\n\r\n    const truePath = '/' + paths.slice(0, paths?.length).join('/');\r\n\r\n    console.log(truePath, 'truePath')\r\n\r\n    this.menus = this.menus.map((menu) => {\r\n      return {\r\n        ...menu,\r\n        bgColor: menu.link == truePath ? 'bg-green-600' : '',\r\n        textColor: menu.link == truePath ? 'text-white' : '',\r\n      };\r\n    });\r\n\r\n    this.menuSelecionado = this.menus.find((menu: any) => {\r\n      return menu.link == truePath;\r\n    });\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  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 = !this.expandMenu;\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  navigateToDefaultRoute() {\r\n    this.navigateToDefaultRouteEmit.emit();\r\n  }\r\n\r\n  getSidebarState() {\r\n    return this.expandMenu ? 'expanded' : 'collapsed';\r\n  }\r\n}\r\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\r\n  @if (showMenu) {\r\n  <div [style]=\"{ minWidth: expandMenu ? '300px' : '60px' }\"></div>\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 ? '300px' : '60px' }\"\r\n    class=\"sidebar-animation\"\r\n  >\r\n    <ng-template pTemplate=\"headless\">\r\n      <div class=\"flex flex-column overflow-hidden\">\r\n        <div\r\n          class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2 overflow-hidden\"\r\n        >\r\n          <div\r\n            class=\"flex {{\r\n              expandMenu ? 'flex-row' : 'flex-column'\r\n            }} align-items-center {{\r\n              expandMenu ? 'justify-content-between' : 'justify-content-center'\r\n            }} py-3\"\r\n          >\r\n            <!-- Logo para o menu expandido -->\r\n            <img\r\n              *ngIf=\"expandMenu && logoMenuExpand\"\r\n              alt=\"Card\"\r\n              [src]=\"logoMenuExpand\"\r\n              width=\"150\"\r\n              class=\"cursor-pointer\"\r\n              (click)=\"navigateToDefaultRoute()\"\r\n            />\r\n\r\n            <!-- Logo para o menu minimizado-->\r\n            <img\r\n              *ngIf=\"!expandMenu && logoMenuHide\"\r\n              alt=\"Card\"\r\n              [src]=\"logoMenuHide\"\r\n              width=\"50\"\r\n              class=\"mb-2\"\r\n              (click)=\"navigateToDefaultRoute()\"\r\n            />\r\n\r\n            <!-- Toggle menu -->\r\n            <button\r\n              *ngIf=\"showExpandMenu\"\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 ? 'Ocultar Menu' : 'Expandir Menu'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\"> menu </i>\r\n            </button>\r\n          </div>\r\n\r\n          @if(showTrocaEmpresa){\r\n          <div\r\n            class=\"flex flex-row align-items-center {{\r\n              expandMenu ? 'justify-content-between' : 'justify-content-center'\r\n            }}\"\r\n          >\r\n            <div\r\n              class=\"flex flex-column cursor-pointer\"\r\n              *ngIf=\"expandMenu && selectedEmpresa\"\r\n              (click)=\"changeEmpresa($event)\"\r\n            >\r\n              <span\r\n                class=\"text-sm font-semibold mr-2\"\r\n                [pTooltip]=\"this.selectedEmpresa.razaosocial\"\r\n                [tooltipPosition]=\"'right'\"\r\n              >\r\n                {{ nameEmpresa(this.selectedEmpresa.razaosocial) }}\r\n              </span>\r\n              <span class=\"text-sm mt-1\">{{\r\n                this.selectedEmpresa.cpfcnpj | cpfCnpj\r\n              }}</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)=\"changeEmpresa($event)\"\r\n              [pTooltip]=\"'Trocar de empresa'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\"> sync_alt </i>\r\n            </button>\r\n          </div>\r\n          <p-divider type=\"solid\"></p-divider>\r\n          }\r\n        </div>\r\n\r\n        <div class=\"list-none m-0 card-container overflow-y-auto max-h-full\">\r\n          <!-- menus -->\r\n          <li *ngFor=\"let menu of menus; let i = index\" class=\"px-2\">\r\n            <!-- menu que não tem filho -->\r\n            <a\r\n              (mouseenter)=\"onMouseEnter(i)\"\r\n              (mouseleave)=\"onMouseLeave()\"\r\n              [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n              (click)=\"callRoute(menu.link)\"\r\n              *ngIf=\"\r\n                !menu.indmenupai && (!menu.idmenupai || menu.idmenupai == 0)\r\n              \"\r\n              pRipple\r\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n              [tooltipPosition]=\"'right'\"\r\n              class=\"{{\r\n                menu.bgColor\r\n              }} menu-option flex align-items-center no-underline cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n              [class.justify-content-center]=\"!expandMenu\"\r\n            >\r\n              <i\r\n                class=\"material-symbols-outlined icon-menu {{\r\n                  expandMenu ? 'ml-1 mr-2' : ''\r\n                }}  icon-hover-color {{ menu.textColor }}\"\r\n                *ngIf=\"menu.icone\"\r\n              >\r\n                {{ menu.icone }}\r\n              </i>\r\n              <span\r\n                class=\"text-base text-blue-900 font-medium {{ menu.textColor }}\"\r\n                *ngIf=\"expandMenu\"\r\n                >{{ menu.descricaomenu }}</span\r\n              >\r\n            </a>\r\n            <!-- menu com filho -->\r\n            <div *ngIf=\"menu.indmenupai\">\r\n              <a\r\n                (mouseenter)=\"onMouseEnter(i)\"\r\n                (mouseleave)=\"onMouseLeave()\"\r\n                [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                pRipple\r\n                pStyleClass=\"@next\"\r\n                enterClass=\"hidden\"\r\n                enterActiveClass=\"slidedown\"\r\n                leaveToClass=\"hidden\"\r\n                leaveActiveClass=\"slideup\"\r\n                class=\"menu-option flex align-items-center {{\r\n                  !expandMenu\r\n                    ? 'justify-content-center'\r\n                    : 'justify-content-between'\r\n                }} 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                  <i\r\n                    class=\"material-symbols-outlined icon-menu {{\r\n                      expandMenu ? 'ml-1 mr-2' : ''\r\n                    }} icon-hover-color\"\r\n                    *ngIf=\"menu.icone\"\r\n                    [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                  >\r\n                    {{ menu.icone }}\r\n                  </i>\r\n                  <span\r\n                    class=\"text-base text-blue-900 font-medium\"\r\n                    *ngIf=\"expandMenu\"\r\n                    >{{ menu.descricaomenu }}</span\r\n                  >\r\n                </div>\r\n                <i\r\n                  class=\"pi pi-chevron-down text-blue-900 mr-1 icon-hover-color\"\r\n                  *ngIf=\"expandMenu\"\r\n                  [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                ></i>\r\n              </a>\r\n\r\n              <!-- filhos -->\r\n              <div\r\n                class=\"list-none py-0 pl-3 pr-0 m-0 {{\r\n                  !(menuSelecionado?.idmenupai == menu.idmenu) && 'hidden'\r\n                }} overflow-y-hidden transition-all transition-duration-400 transition-ease-in-out\"\r\n              >\r\n                <li\r\n                  *ngFor=\"\r\n                    let filho of returnMenuChild(menu.idmenu);\r\n                    let iFilho = index\r\n                  \"\r\n                >\r\n                  <a\r\n                    (mouseenter)=\"onMouseEnterChild(filho.idmenu)\"\r\n                    (mouseleave)=\"onMouseLeave()\"\r\n                    [ngClass]=\"{\r\n                      'hover-color': mouseOverFilhoIndex === filho.idmenu\r\n                    }\"\r\n                    *ngIf=\"expandMenu\"\r\n                    (click)=\"callRoute(filho.link)\"\r\n                    pRipple\r\n                    class=\"{{\r\n                      filho.bgColor\r\n                    }} 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=\"material-symbols-outlined icon-menu {{\r\n                        expandMenu ? 'ml-1 mr-2' : ''\r\n                      }} icon-hover-color\"\r\n                      *ngIf=\"filho.icone\"\r\n                      [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                    >\r\n                      {{ filho.icone }}\r\n                    </i>\r\n                    <span\r\n                      class=\"text-base text-blue-900 ml-4 {{ filho.textColor }}\"\r\n                      *ngIf=\"expandMenu\"\r\n                      >{{ filho.descricaomenu }}</span\r\n                    >\r\n                  </a>\r\n                </li>\r\n              </div>\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  <!-- Topbar -->\r\n  <div\r\n    class=\"w-auto h-screen page-content overflow-y-hidden\"\r\n    id=\"page-content\"\r\n    style=\"width: 100vw !important\"\r\n  >\r\n    <div class=\"flex flex-row align-items-center justify-content-between m-3\">\r\n      @if(!showMenu) {\r\n      <!-- Logo home -->\r\n      <div>\r\n        <img [src]=\"logoMenuExpand\" width=\"150\" />\r\n      </div>\r\n      } @else {\r\n      <!-- Breadcrumbs -->\r\n      <div>\r\n        <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">\r\n          {{ breadCrumbItems[breadCrumbItems.length - 1]?.label }}\r\n        </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: '#eaeaea' }\"\r\n          (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n        ></p-breadcrumb>\r\n      </div>\r\n      }\r\n\r\n      <!-- dropdown para seleção de empresa/licenca -->\r\n      <dropdown-master\r\n        *ngIf=\"showLicencas()\"\r\n        class=\"w-40rem\"\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      <!-- Navegação de sistemas e usuários -->\r\n      <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n        <p-button\r\n          *ngIf=\"showButtonApps\"\r\n          styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n          icon=\"pi pi-th-large\"\r\n          [rounded]=\"true\"\r\n          [text]=\"true\"\r\n          (click)=\"sistemasPanel.toggle($event)\"\r\n          [pTooltip]=\"'Sistemas'\"\r\n          [tooltipPosition]=\"'left'\"\r\n        ></p-button>\r\n\r\n        <p-button\r\n          *ngIf=\"showButtonUser\"\r\n          styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n          icon=\"pi pi-user\"\r\n          [rounded]=\"true\"\r\n          [text]=\"true\"\r\n          [pTooltip]=\"'Menu do Usuário'\"\r\n          [tooltipPosition]=\"'left'\"\r\n          (click)=\"meusDadosPanel.toggle($event)\"\r\n        ></p-button>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Container -->\r\n    <p-card\r\n      styleClass=\"m-3 overflow-y-auto {{\r\n        !showMenu && 'sm:overflow-y-hidden'\r\n      }} card-container\"\r\n      [style]=\"{ height: heightCard - adjustHeightCard() + 'px' }\"\r\n    >\r\n      <div\r\n        class=\"{{ widthCard < 992 && 'card-container' }} w-full h-full\"\r\n        [style]=\"{ width: widthCard + 'px' }\"\r\n      >\r\n        <ng-content></ng-content>\r\n      </div>\r\n    </p-card>\r\n  </div>\r\n\r\n  <!-- Painel de aplicativos -->\r\n  <p-overlayPanel\r\n    #sistemasPanel\r\n    [showTransitionOptions]=\"'350ms ease-out'\"\r\n    [hideTransitionOptions]=\"'250ms ease-in'\"\r\n  >\r\n    <ng-template pTemplate=\"container\">\r\n      <p class=\"title-style mt-3\">Sistemas</p>\r\n\r\n      <div\r\n        class=\"flex flex-row flex-wrap gap-3 align-items-center justify-content-center mt-5 mb-3\"\r\n        style=\"width: 270px; height: 100%\"\r\n      >\r\n        @for (aplicativo of apps; track $index) {\r\n\r\n          @if(aplicativo.urliconehidemenu == \"https://work-assets.keevo.com.br/img/icone-keevocenter.png\") {\r\n          <div\r\n            class=\"btn-sistema text-xl md:text-3xl flex align-items-center justify-content-center\"\r\n            (click)=\"selectApp(aplicativo.idaplicativo)\"\r\n            [pTooltip]=\"aplicativo?.descricaoaplicativo\"\r\n            [tooltipPosition]=\"'left'\"\r\n          >\r\n            {{ aplicativo.descricaoaplicativo.charAt(0).toLocaleUpperCase() }}\r\n          </div>\r\n          } @else {\r\n          <img\r\n            [src]=\"aplicativo.urliconehidemenu\"\r\n            class=\"btn-sistema flex align-items-center justify-content-center\"\r\n            [pTooltip]=\"aplicativo?.descricaoaplicativo\"\r\n            [tooltipPosition]=\"'left'\"\r\n          />\r\n          }\r\n      }\r\n\r\n        <!-- <button\r\n          *ngFor=\"let aplicativo of apps\"\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          [pTooltip]=\"aplicativo?.descricaoaplicativo\"\r\n          [tooltipPosition]=\"'left'\"\r\n          (click)=\"selectApp(aplicativo.idaplicativo)\"\r\n        >\r\n          {{ aplicativo.nomeaplicativo.charAt(0).toUpperCase() }}\r\n        </button> -->\r\n      </div>\r\n    </ng-template>\r\n  </p-overlayPanel>\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=\"title-style mt-3\">\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      <p-button\r\n        icon=\"pi pi-lock\"\r\n        label=\"Acessar Keepass\"\r\n        (onClick)=\"accessKeePass($event)\"\r\n        styleClass=\"border-noround w-full text-blue-900\"\r\n        [text]=\"true\"\r\n      >\r\n      </p-button>\r\n\r\n      <p-button\r\n        icon=\"pi pi-sign-out\"\r\n        label=\"Sair\"\r\n        (onClick)=\"logout($event)\"\r\n        styleClass=\"border-noround w-full text-blue-900\"\r\n        [text]=\"true\"\r\n      >\r\n      </p-button>\r\n    </ng-template>\r\n  </p-overlayPanel>\r\n</div>\r\n"]}
|
|
264
|
+
//# 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  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\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\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  // animations: [\r\n  //   trigger('sidebarWidthTrigger', [\r\n  //     state('collapsed', style({\r\n  //       width: '60px'\r\n  //     })),\r\n  //     state('expanded', style({\r\n  //       width: '359px'\r\n  //     })),\r\n  //     transition('collapsed <=> expanded', animate('100ms ease-out'))\r\n  //   ])\r\n  // ]\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    urliconehidemenu?: string;\r\n  }[] = [];\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  @Input() menus: {\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  @Input() expandMenu: boolean = true;\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() userName: string = 'Usuário';\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  @ViewChild('sidebarRef') sidebarRef!: Sidebar;\r\n  @ViewChild('sistemasPanel') sistemasPanel!: OverlayPanel;\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  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  public accessKeePass(event: any) {\r\n    this.sistemasPanel.hide();\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.breadCrumbItems.length > 0) return 105;\r\n      else return 85;\r\n    } else return 83;\r\n  }\r\n\r\n  private adjustWidthCard() {\r\n    this.heightCard = Number(\r\n      document.getElementById('page-content')?.offsetHeight\r\n    );\r\n    if (this.showMenu)\r\n      this.widthCard = Number(window.innerWidth) - (this.expandMenu ? 333 : 93);\r\n    else this.widthCard = Number(window.innerWidth);\r\n  }\r\n\r\n  public callRoute(e: any, expand?: boolean) {\r\n    if (!expand) !this.expandMenu ? (this.expandMenu = !this.expandMenu) : '';\r\n\r\n    this.router.navigateByUrl(e);\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 expandMenuEvent() {\r\n    this.expandMenuEmit.emit(this.expandMenu);\r\n  }\r\n\r\n  public logout(event: any) {\r\n    this.sistemasPanel.hide();\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    if (this.sistemasPanel) {\r\n      this.sistemasPanel.hide();\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: any;\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  public ngOnInit(): void {\r\n    this.formGroup = this.fb.group({\r\n      idmaster: [this.selectedMaster, []],\r\n    });\r\n\r\n    this.adjustWidthCard();\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  public onMouseEnter(index: number) {\r\n    this.mouseOverIndex = index;\r\n  }\r\n\r\n  public onMouseEnterChild(index: number) {\r\n    this.mouseOverFilhoIndex = index;\r\n  }\r\n\r\n  public onMouseLeave() {\r\n    this.mouseOverIndex = null;\r\n    this.mouseOverFilhoIndex = null;\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  public onWindowResize() {\r\n    this.adjustWidthCard();\r\n    this.cdr.detectChanges();\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    console.log(paths, 'paths lá em cima')\r\n\r\n\r\n    this.menus = this.menus.map((menu) => {\r\n      console.log(paths.includes(menu.link!), paths, menu.link, 'paths comparacoes')\r\n      return {\r\n        ...menu,\r\n        bgColor: paths.includes(menu.link!) ? 'bg-green-600' : '',\r\n        textColor: paths.includes(menu.link!) ? 'text-white' : '',\r\n      };\r\n    });\r\n\r\n    this.menuSelecionado = this.menus.find((menu: any) => {\r\n      return paths.includes(menu.link!);\r\n    });\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  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 = !this.expandMenu;\r\n    this.expandMenuEvent();\r\n  }\r\n\r\n  navigateToDefaultRoute() {\r\n    this.navigateToDefaultRouteEmit.emit();\r\n  }\r\n\r\n  getSidebarState() {\r\n    return this.expandMenu ? 'expanded' : 'collapsed';\r\n  }\r\n}\r\n","<div class=\"flex flex-row overflow-y-hidden w- full-container\">\r\n  @if (showMenu) {\r\n  <div [style]=\"{ minWidth: expandMenu ? '300px' : '60px' }\"></div>\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 ? '300px' : '60px' }\"\r\n    class=\"sidebar-animation\"\r\n  >\r\n    <ng-template pTemplate=\"headless\">\r\n      <div class=\"flex flex-column overflow-hidden\">\r\n        <div\r\n          class=\"flex flex-column gap-2 justify-content-between flex-shrink-0 mx-2 overflow-hidden\"\r\n        >\r\n          <div\r\n            class=\"flex {{\r\n              expandMenu ? 'flex-row' : 'flex-column'\r\n            }} align-items-center {{\r\n              expandMenu ? 'justify-content-between' : 'justify-content-center'\r\n            }} py-3\"\r\n          >\r\n            <!-- Logo para o menu expandido -->\r\n            <img\r\n              *ngIf=\"expandMenu && logoMenuExpand\"\r\n              alt=\"Card\"\r\n              [src]=\"logoMenuExpand\"\r\n              width=\"150\"\r\n              class=\"cursor-pointer\"\r\n              (click)=\"navigateToDefaultRoute()\"\r\n            />\r\n\r\n            <!-- Logo para o menu minimizado-->\r\n            <img\r\n              *ngIf=\"!expandMenu && logoMenuHide\"\r\n              alt=\"Card\"\r\n              [src]=\"logoMenuHide\"\r\n              width=\"50\"\r\n              class=\"mb-2\"\r\n              (click)=\"navigateToDefaultRoute()\"\r\n            />\r\n\r\n            <!-- Toggle menu -->\r\n            <button\r\n              *ngIf=\"showExpandMenu\"\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 ? 'Ocultar Menu' : 'Expandir Menu'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\"> menu </i>\r\n            </button>\r\n          </div>\r\n\r\n          @if(showTrocaEmpresa){\r\n          <div\r\n            class=\"flex flex-row align-items-center {{\r\n              expandMenu ? 'justify-content-between' : 'justify-content-center'\r\n            }}\"\r\n          >\r\n            <div\r\n              class=\"flex flex-column cursor-pointer\"\r\n              *ngIf=\"expandMenu && selectedEmpresa\"\r\n              (click)=\"changeEmpresa($event)\"\r\n            >\r\n              <span\r\n                class=\"text-sm font-semibold mr-2\"\r\n                [pTooltip]=\"this.selectedEmpresa.razaosocial\"\r\n                [tooltipPosition]=\"'right'\"\r\n              >\r\n                {{ nameEmpresa(this.selectedEmpresa.razaosocial) }}\r\n              </span>\r\n              <span class=\"text-sm mt-1\">{{\r\n                this.selectedEmpresa.cpfcnpj | cpfCnpj\r\n              }}</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)=\"changeEmpresa($event)\"\r\n              [pTooltip]=\"'Trocar de empresa'\"\r\n              [tooltipPosition]=\"'right'\"\r\n            >\r\n              <i class=\"material-symbols-outlined\"> sync_alt </i>\r\n            </button>\r\n          </div>\r\n          <p-divider type=\"solid\"></p-divider>\r\n          }\r\n        </div>\r\n\r\n        <div class=\"list-none m-0 card-container overflow-y-auto max-h-full\">\r\n          <!-- menus -->\r\n          <li *ngFor=\"let menu of menus; let i = index\" class=\"px-2\">\r\n            <!-- menu que não tem filho -->\r\n            <a\r\n              (mouseenter)=\"onMouseEnter(i)\"\r\n              (mouseleave)=\"onMouseLeave()\"\r\n              [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n              (click)=\"callRoute(menu.link)\"\r\n              *ngIf=\"\r\n                !menu.indmenupai && (!menu.idmenupai || menu.idmenupai == 0)\r\n              \"\r\n              pRipple\r\n              [pTooltip]=\"!expandMenu ? menu.descricaomenu : ''\"\r\n              [tooltipPosition]=\"'right'\"\r\n              class=\"{{\r\n                menu.bgColor\r\n              }} menu-option flex align-items-center no-underline cursor-pointer border-round text-700 hover:bg-green-600 hover:text-white transition-duration-150 transition-colors p-ripple\"\r\n              [class.justify-content-center]=\"!expandMenu\"\r\n            >\r\n              <i\r\n                class=\"material-symbols-outlined icon-menu {{\r\n                  expandMenu ? 'ml-1 mr-2' : ''\r\n                }}  icon-hover-color {{ menu.textColor }}\"\r\n                *ngIf=\"menu.icone\"\r\n              >\r\n                {{ menu.icone }}\r\n              </i>\r\n              <span\r\n                class=\"text-base text-blue-900 font-medium {{ menu.textColor }}\"\r\n                *ngIf=\"expandMenu\"\r\n                >{{ menu.descricaomenu }}</span\r\n              >\r\n            </a>\r\n            <!-- menu com filho -->\r\n            <div *ngIf=\"menu.indmenupai\">\r\n              <a\r\n                (mouseenter)=\"onMouseEnter(i)\"\r\n                (mouseleave)=\"onMouseLeave()\"\r\n                [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                pRipple\r\n                pStyleClass=\"@next\"\r\n                enterClass=\"hidden\"\r\n                enterActiveClass=\"slidedown\"\r\n                leaveToClass=\"hidden\"\r\n                leaveActiveClass=\"slideup\"\r\n                class=\"menu-option flex align-items-center {{\r\n                  !expandMenu\r\n                    ? 'justify-content-center'\r\n                    : 'justify-content-between'\r\n                }} 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                  <i\r\n                    class=\"material-symbols-outlined icon-menu {{\r\n                      expandMenu ? 'ml-1 mr-2' : ''\r\n                    }} icon-hover-color\"\r\n                    *ngIf=\"menu.icone\"\r\n                    [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                  >\r\n                    {{ menu.icone }}\r\n                  </i>\r\n                  <span\r\n                    class=\"text-base text-blue-900 font-medium\"\r\n                    *ngIf=\"expandMenu\"\r\n                    >{{ menu.descricaomenu }}</span\r\n                  >\r\n                </div>\r\n                <i\r\n                  class=\"pi pi-chevron-down text-blue-900 mr-1 icon-hover-color\"\r\n                  *ngIf=\"expandMenu\"\r\n                  [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                ></i>\r\n              </a>\r\n\r\n              <!-- filhos -->\r\n              <div\r\n                class=\"list-none py-0 pl-3 pr-0 m-0 {{\r\n                  !(menuSelecionado?.idmenupai == menu.idmenu) && 'hidden'\r\n                }} overflow-y-hidden transition-all transition-duration-400 transition-ease-in-out\"\r\n              >\r\n                <li\r\n                  *ngFor=\"\r\n                    let filho of returnMenuChild(menu.idmenu);\r\n                    let iFilho = index\r\n                  \"\r\n                >\r\n                  <a\r\n                    (mouseenter)=\"onMouseEnterChild(filho.idmenu)\"\r\n                    (mouseleave)=\"onMouseLeave()\"\r\n                    [ngClass]=\"{\r\n                      'hover-color': mouseOverFilhoIndex === filho.idmenu\r\n                    }\"\r\n                    *ngIf=\"expandMenu\"\r\n                    (click)=\"callRoute(filho.link)\"\r\n                    pRipple\r\n                    class=\"{{\r\n                      filho.bgColor\r\n                    }} 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=\"material-symbols-outlined icon-menu {{\r\n                        expandMenu ? 'ml-1 mr-2' : ''\r\n                      }} icon-hover-color\"\r\n                      *ngIf=\"filho.icone\"\r\n                      [ngClass]=\"{ 'hover-color': mouseOverIndex === i }\"\r\n                    >\r\n                      {{ filho.icone }}\r\n                    </i>\r\n                    <span\r\n                      class=\"text-base text-blue-900 ml-4 {{ filho.textColor }}\"\r\n                      *ngIf=\"expandMenu\"\r\n                      >{{ filho.descricaomenu }}</span\r\n                    >\r\n                  </a>\r\n                </li>\r\n              </div>\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  <!-- Topbar -->\r\n  <div\r\n    class=\"w-auto h-screen page-content overflow-y-hidden\"\r\n    id=\"page-content\"\r\n    style=\"width: 100vw !important\"\r\n  >\r\n    <div class=\"flex flex-row align-items-center justify-content-between m-3\">\r\n      @if(!showMenu) {\r\n      <!-- Logo home -->\r\n      <div>\r\n        <img [src]=\"logoMenuExpand\" width=\"150\" />\r\n      </div>\r\n      } @else {\r\n      <!-- Breadcrumbs -->\r\n      <div>\r\n        <p class=\"text-xl font-semibold text-blue-900 breadcrumb-title\">\r\n          {{ breadCrumbItems[breadCrumbItems.length - 1]?.label }}\r\n        </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: '#eaeaea' }\"\r\n          (onItemClick)=\"callRoute($event.item.routerLink, true)\"\r\n        ></p-breadcrumb>\r\n      </div>\r\n      }\r\n\r\n      <!-- dropdown para seleção de empresa/licenca -->\r\n      <dropdown-master\r\n        *ngIf=\"showLicencas()\"\r\n        class=\"w-40rem\"\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      <!-- Navegação de sistemas e usuários -->\r\n      <div class=\"w-auto flex flex-row align-items-center gap-2\">\r\n        <p-button\r\n          *ngIf=\"showButtonApps\"\r\n          styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n          icon=\"pi pi-th-large\"\r\n          [rounded]=\"true\"\r\n          [text]=\"true\"\r\n          (click)=\"sistemasPanel.toggle($event)\"\r\n          [pTooltip]=\"'Sistemas'\"\r\n          [tooltipPosition]=\"'left'\"\r\n        ></p-button>\r\n\r\n        <p-button\r\n          *ngIf=\"showButtonUser\"\r\n          styleClass=\"w-2rem h-2rem text-blue-900 hover:bg-green-600 hover:text-white\"\r\n          icon=\"pi pi-user\"\r\n          [rounded]=\"true\"\r\n          [text]=\"true\"\r\n          [pTooltip]=\"'Menu do Usuário'\"\r\n          [tooltipPosition]=\"'left'\"\r\n          (click)=\"meusDadosPanel.toggle($event)\"\r\n        ></p-button>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Container -->\r\n    <p-card\r\n      styleClass=\"m-3 overflow-y-auto {{\r\n        !showMenu && 'sm:overflow-y-hidden'\r\n      }} card-container\"\r\n      [style]=\"{ height: heightCard - adjustHeightCard() + 'px' }\"\r\n    >\r\n      <div\r\n        class=\"{{ widthCard < 992 && 'card-container' }} w-full h-full\"\r\n        [style]=\"{ width: widthCard + 'px' }\"\r\n      >\r\n        <ng-content></ng-content>\r\n      </div>\r\n    </p-card>\r\n  </div>\r\n\r\n  <!-- Painel de aplicativos -->\r\n  <p-overlayPanel\r\n    #sistemasPanel\r\n    [showTransitionOptions]=\"'350ms ease-out'\"\r\n    [hideTransitionOptions]=\"'250ms ease-in'\"\r\n  >\r\n    <ng-template pTemplate=\"container\">\r\n      <p class=\"title-style mt-3\">Sistemas</p>\r\n\r\n      <div\r\n        class=\"flex flex-row flex-wrap gap-3 align-items-center justify-content-center mt-5 mb-3\"\r\n        style=\"width: 270px; height: 100%\"\r\n      >\r\n        @for (aplicativo of apps; track $index) {\r\n\r\n          @if(aplicativo.urliconehidemenu == \"https://work-assets.keevo.com.br/img/icone-keevocenter.png\") {\r\n          <div\r\n            class=\"btn-sistema text-xl md:text-3xl flex align-items-center justify-content-center\"\r\n            (click)=\"selectApp(aplicativo.idaplicativo)\"\r\n            [pTooltip]=\"aplicativo?.descricaoaplicativo\"\r\n            [tooltipPosition]=\"'left'\"\r\n          >\r\n            {{ aplicativo.descricaoaplicativo.charAt(0).toLocaleUpperCase() }}\r\n          </div>\r\n          } @else {\r\n          <img\r\n            [src]=\"aplicativo.urliconehidemenu\"\r\n            class=\"btn-sistema flex align-items-center justify-content-center\"\r\n            [pTooltip]=\"aplicativo?.descricaoaplicativo\"\r\n            [tooltipPosition]=\"'left'\"\r\n          />\r\n          }\r\n      }\r\n\r\n        <!-- <button\r\n          *ngFor=\"let aplicativo of apps\"\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          [pTooltip]=\"aplicativo?.descricaoaplicativo\"\r\n          [tooltipPosition]=\"'left'\"\r\n          (click)=\"selectApp(aplicativo.idaplicativo)\"\r\n        >\r\n          {{ aplicativo.nomeaplicativo.charAt(0).toUpperCase() }}\r\n        </button> -->\r\n      </div>\r\n    </ng-template>\r\n  </p-overlayPanel>\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=\"title-style mt-3\">\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      <p-button\r\n        icon=\"pi pi-lock\"\r\n        label=\"Acessar Keepass\"\r\n        (onClick)=\"accessKeePass($event)\"\r\n        styleClass=\"border-noround w-full text-blue-900\"\r\n        [text]=\"true\"\r\n      >\r\n      </p-button>\r\n\r\n      <p-button\r\n        icon=\"pi pi-sign-out\"\r\n        label=\"Sair\"\r\n        (onClick)=\"logout($event)\"\r\n        styleClass=\"border-noround w-full text-blue-900\"\r\n        [text]=\"true\"\r\n      >\r\n      </p-button>\r\n    </ng-template>\r\n  </p-overlayPanel>\r\n</div>\r\n"]}
|
|
@@ -5088,19 +5088,18 @@ class KvLayoutComponent {
|
|
|
5088
5088
|
const url = new URL(this.router.url, window.origin);
|
|
5089
5089
|
const currentPath = url.pathname;
|
|
5090
5090
|
const purePath = currentPath.match(/^[^;]*/i);
|
|
5091
|
-
const paths = purePath[0]
|
|
5092
|
-
|
|
5093
|
-
const truePath = '/' + paths.slice(0, paths?.length).join('/');
|
|
5094
|
-
console.log(truePath, 'truePath');
|
|
5091
|
+
const paths = purePath[0];
|
|
5092
|
+
console.log(paths, 'paths lá em cima');
|
|
5095
5093
|
this.menus = this.menus.map((menu) => {
|
|
5094
|
+
console.log(paths.includes(menu.link), paths, menu.link, 'paths comparacoes');
|
|
5096
5095
|
return {
|
|
5097
5096
|
...menu,
|
|
5098
|
-
bgColor: menu.link
|
|
5099
|
-
textColor: menu.link
|
|
5097
|
+
bgColor: paths.includes(menu.link) ? 'bg-green-600' : '',
|
|
5098
|
+
textColor: paths.includes(menu.link) ? 'text-white' : '',
|
|
5100
5099
|
};
|
|
5101
5100
|
});
|
|
5102
5101
|
this.menuSelecionado = this.menus.find((menu) => {
|
|
5103
|
-
return menu.link
|
|
5102
|
+
return paths.includes(menu.link);
|
|
5104
5103
|
});
|
|
5105
5104
|
}
|
|
5106
5105
|
returnMenuChild(idmenu) {
|
|
@@ -7219,13 +7218,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
7219
7218
|
class KvFilterCardComponent {
|
|
7220
7219
|
constructor() {
|
|
7221
7220
|
this.cardState = "normal";
|
|
7221
|
+
this.spaceNowrap = false;
|
|
7222
7222
|
}
|
|
7223
7223
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFilterCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
7224
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvFilterCardComponent, selector: "kv-filter-card", inputs: { cardState: "cardState", color: "color", title: "title", amount: "amount", gIcon: "gIcon" }, ngImport: i0, template: "<div
|
|
7224
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvFilterCardComponent, selector: "kv-filter-card", inputs: { cardState: "cardState", color: "color", title: "title", amount: "amount", gIcon: "gIcon", spaceNowrap: "spaceNowrap" }, ngImport: i0, template: "<div\r\n [style]=\"{ '--accent-color': color }\"\r\n [ngClass]=\"[\r\n cardState == 'inactive' ? 'card-disabled' : 'card',\r\n cardState == 'selected' ? 'clickable-selected' : 'clickable'\r\n ]\"\r\n>\r\n <div class=\"filter-card-content\">\r\n <div class=\"flex-row-center\">\r\n @if (gIcon) {\r\n <kv-g-icon>{{ gIcon }}</kv-g-icon>\r\n }\r\n <ng-content select=\"[icon]\"></ng-content>\r\n <p class=\"{{spaceNowrap && 'white-space-nowrap'}} font-bold\">{{ title }}</p>\r\n </div>\r\n <p style=\"font-size: 2em\" class=\"font-bold\">{{ amount }}</p>\r\n </div>\r\n</div>\r\n", styles: [".card{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem var(--accent-color);border-radius:10px}.card *{margin:0;color:var(--accent-color)}p{font-size:14px}.card-disabled{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem lightgrey;transition:border-left .2s ease;border-radius:10px}.card-disabled:hover{border-left:solid .4rem var(--accent-color);transition:border-left .2s ease}.card-disabled:hover *{color:var(--accent-color);transition:color .2s ease}.card-disabled *{margin:0;color:#d3d3d3;transition:color .2s ease}.clickable-selected{cursor:pointer;background-color:#eafaff}.clickable-selected:hover{background-color:#deeeff}.clickable{cursor:pointer}.clickable:hover{background-color:#f0f0f0}.filter-card-content{width:180px;display:flex;flex-direction:column;padding:1rem .6rem .6rem;gap:1.2rem}.select-none{-webkit-user-select:none;user-select:none}.flex-row-center{display:flex;flex-direction:row;align-items:center;gap:.4rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: KvGIconComponent, selector: "kv-g-icon" }] }); }
|
|
7225
7225
|
}
|
|
7226
7226
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFilterCardComponent, decorators: [{
|
|
7227
7227
|
type: Component,
|
|
7228
|
-
args: [{ selector: 'kv-filter-card', template: "<div
|
|
7228
|
+
args: [{ selector: 'kv-filter-card', template: "<div\r\n [style]=\"{ '--accent-color': color }\"\r\n [ngClass]=\"[\r\n cardState == 'inactive' ? 'card-disabled' : 'card',\r\n cardState == 'selected' ? 'clickable-selected' : 'clickable'\r\n ]\"\r\n>\r\n <div class=\"filter-card-content\">\r\n <div class=\"flex-row-center\">\r\n @if (gIcon) {\r\n <kv-g-icon>{{ gIcon }}</kv-g-icon>\r\n }\r\n <ng-content select=\"[icon]\"></ng-content>\r\n <p class=\"{{spaceNowrap && 'white-space-nowrap'}} font-bold\">{{ title }}</p>\r\n </div>\r\n <p style=\"font-size: 2em\" class=\"font-bold\">{{ amount }}</p>\r\n </div>\r\n</div>\r\n", styles: [".card{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem var(--accent-color);border-radius:10px}.card *{margin:0;color:var(--accent-color)}p{font-size:14px}.card-disabled{--accent-color: #5289B4;border:1px solid lightgrey;border-left:solid .4rem lightgrey;transition:border-left .2s ease;border-radius:10px}.card-disabled:hover{border-left:solid .4rem var(--accent-color);transition:border-left .2s ease}.card-disabled:hover *{color:var(--accent-color);transition:color .2s ease}.card-disabled *{margin:0;color:#d3d3d3;transition:color .2s ease}.clickable-selected{cursor:pointer;background-color:#eafaff}.clickable-selected:hover{background-color:#deeeff}.clickable{cursor:pointer}.clickable:hover{background-color:#f0f0f0}.filter-card-content{width:180px;display:flex;flex-direction:column;padding:1rem .6rem .6rem;gap:1.2rem}.select-none{-webkit-user-select:none;user-select:none}.flex-row-center{display:flex;flex-direction:row;align-items:center;gap:.4rem}\n"] }]
|
|
7229
7229
|
}], propDecorators: { cardState: [{
|
|
7230
7230
|
type: Input
|
|
7231
7231
|
}], color: [{
|
|
@@ -7236,6 +7236,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
7236
7236
|
type: Input
|
|
7237
7237
|
}], gIcon: [{
|
|
7238
7238
|
type: Input
|
|
7239
|
+
}], spaceNowrap: [{
|
|
7240
|
+
type: Input
|
|
7239
7241
|
}] } });
|
|
7240
7242
|
|
|
7241
7243
|
class KvGIconModule {
|