@mediusinc/mng-commons 2.0.0-rc.0-08f92864 → 2.0.0-rc.1-b808fba6
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/components/action/action.component.mjs +2 -2
- package/esm2020/lib/components/form/dropdown/dropdown.component.mjs +18 -5
- package/esm2020/lib/components/layout/index.mjs +2 -1
- package/esm2020/lib/components/layout/main-layout.component.mjs +17 -13
- package/esm2020/lib/components/layout/topbar-user.component.mjs +41 -0
- package/esm2020/lib/components/layout/topbar.component.mjs +28 -31
- package/esm2020/lib/components/tableview/table/column-value/column-value.component.mjs +2 -2
- package/esm2020/lib/components/tableview/table/table.component.mjs +2 -2
- package/esm2020/lib/directives/component.directive.mjs +27 -10
- package/esm2020/lib/mng-commons.module.mjs +6 -1
- package/esm2020/lib/models/config.model.mjs +1 -1
- package/esm2020/lib/router/models/router.model.mjs +1 -1
- package/esm2020/lib/router/route-builder.mjs +9 -29
- package/esm2020/lib/router/routes-builder.mjs +7 -7
- package/esm2020/lib/router/tableview-route-builder.mjs +70 -73
- package/fesm2015/mediusinc-mng-commons.mjs +209 -159
- package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
- package/fesm2020/mediusinc-mng-commons.mjs +202 -159
- package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
- package/lib/components/form/dropdown/dropdown.component.d.ts +7 -0
- package/lib/components/layout/index.d.ts +1 -0
- package/lib/components/layout/main-layout.component.d.ts +3 -1
- package/lib/components/layout/topbar-user.component.d.ts +21 -0
- package/lib/components/layout/topbar.component.d.ts +8 -10
- package/lib/directives/component.directive.d.ts +7 -3
- package/lib/mng-commons.module.d.ts +27 -26
- package/lib/models/config.model.d.ts +10 -0
- package/lib/router/models/router.model.d.ts +0 -5
- package/lib/router/route-builder.d.ts +6 -8
- package/lib/router/routes-builder.d.ts +4 -5
- package/lib/router/tableview-route-builder.d.ts +16 -10
- package/package.json +1 -1
- package/scss/theme/default/_mng-variables-theme-light.scss +2 -0
- package/version-info.json +5 -5
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { AsyncPipe, NgClass, NgIf } from '@angular/common';
|
|
2
|
+
import { Component } from '@angular/core';
|
|
3
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
4
|
+
import { MngEnumerateAsyncPipe } from '../../pipes';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services";
|
|
7
|
+
import * as i2 from "./services";
|
|
8
|
+
import * as i3 from "@ngx-translate/core";
|
|
9
|
+
export class MngTopbarUserComponent {
|
|
10
|
+
constructor(mngCommons, mainLayoutService, elementRef) {
|
|
11
|
+
this.mngCommons = mngCommons;
|
|
12
|
+
this.mainLayoutService = mainLayoutService;
|
|
13
|
+
this.elementRef = elementRef;
|
|
14
|
+
this.subscriptions = [];
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.subscriptions.push(this.mngCommons.user$.subscribe(u => {
|
|
18
|
+
this.user = u;
|
|
19
|
+
}));
|
|
20
|
+
this.userRoles$ = this.mngCommons.userRoles$;
|
|
21
|
+
}
|
|
22
|
+
ngOnDestroy() {
|
|
23
|
+
this.subscriptions.forEach(value => value.unsubscribe());
|
|
24
|
+
}
|
|
25
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
26
|
+
logout(user, event) {
|
|
27
|
+
if (typeof user?.logout === 'function') {
|
|
28
|
+
user.logout();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
click(event) {
|
|
32
|
+
this.mainLayoutService.onTopbarItemClick(event, this.elementRef.nativeElement);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
MngTopbarUserComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: MngTopbarUserComponent, deps: [{ token: i1.MngCommonsService }, { token: i2.MngMainLayoutComponentService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
36
|
+
MngTopbarUserComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: MngTopbarUserComponent, isStandalone: true, selector: "mng-topbar-user-component", ngImport: i0, template: "<a href=\"#\" class=\"user-block\" (click)=\"click($event)\">\n <i class=\"pi pi-fw pi-user\"></i>\n <span class=\"profile-item-username hidden sm:inline-block\"> {{ user?.displayName ?? user?.username }}</span>\n</a>\n<ul class=\"fadeInDown dropdown-window\">\n <li role=\"menuitem\">\n <a>\n <div class=\"flex\">\n <div class=\"flex-grow-0\">\n <i class=\"pi pi-fw pi-user\"></i>\n </div>\n <div class=\"flex-grow-1\">\n <strong>{{ user?.displayName ?? user?.username }}</strong>\n <small *ngIf=\"((userRoles$ | async)?.length ?? 0) > 0\">\n <br />\n {{ userRoles$ | mgnEnumerateAsync : undefined : undefined : undefined : 'roles' | async }}\n </small>\n </div>\n </div>\n </a>\n </li>\n <li role=\"menuitem\" *ngIf=\"user?.logout || user?.logoutUrl\">\n <a [href]=\"user?.logoutUrl\" (click)=\"logout(user, $event)\">\n <i class=\"pi pi-fw pi-sign-out\"></i>\n <span>{{ 'mngTopbar.logout' | translate }}</span>\n </a>\n </li>\n</ul>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: MngEnumerateAsyncPipe, name: "mgnEnumerateAsync" }] });
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: MngTopbarUserComponent, decorators: [{
|
|
38
|
+
type: Component,
|
|
39
|
+
args: [{ standalone: true, selector: 'mng-topbar-user-component', imports: [NgClass, NgIf, AsyncPipe, TranslateModule, MngEnumerateAsyncPipe], template: "<a href=\"#\" class=\"user-block\" (click)=\"click($event)\">\n <i class=\"pi pi-fw pi-user\"></i>\n <span class=\"profile-item-username hidden sm:inline-block\"> {{ user?.displayName ?? user?.username }}</span>\n</a>\n<ul class=\"fadeInDown dropdown-window\">\n <li role=\"menuitem\">\n <a>\n <div class=\"flex\">\n <div class=\"flex-grow-0\">\n <i class=\"pi pi-fw pi-user\"></i>\n </div>\n <div class=\"flex-grow-1\">\n <strong>{{ user?.displayName ?? user?.username }}</strong>\n <small *ngIf=\"((userRoles$ | async)?.length ?? 0) > 0\">\n <br />\n {{ userRoles$ | mgnEnumerateAsync : undefined : undefined : undefined : 'roles' | async }}\n </small>\n </div>\n </div>\n </a>\n </li>\n <li role=\"menuitem\" *ngIf=\"user?.logout || user?.logoutUrl\">\n <a [href]=\"user?.logoutUrl\" (click)=\"logout(user, $event)\">\n <i class=\"pi pi-fw pi-sign-out\"></i>\n <span>{{ 'mngTopbar.logout' | translate }}</span>\n </a>\n </li>\n</ul>\n" }]
|
|
40
|
+
}], ctorParameters: function () { return [{ type: i1.MngCommonsService }, { type: i2.MngMainLayoutComponentService }, { type: i0.ElementRef }]; } });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9wYmFyLXVzZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2xheW91dC90b3BiYXItdXNlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L3RvcGJhci11c2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ3pELE9BQU8sRUFBQyxTQUFTLEVBQWdDLE1BQU0sZUFBZSxDQUFDO0FBRXZFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUlwRCxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxhQUFhLENBQUM7Ozs7O0FBVWxELE1BQU0sT0FBTyxzQkFBc0I7SUFNL0IsWUFBbUIsVUFBNkIsRUFBUyxpQkFBZ0QsRUFBUyxVQUFzQjtRQUFySCxlQUFVLEdBQVYsVUFBVSxDQUFtQjtRQUFTLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBK0I7UUFBUyxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBRmhJLGtCQUFhLEdBQW1CLEVBQUUsQ0FBQztJQUVnRyxDQUFDO0lBRTVJLFFBQVE7UUFDSixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDbkIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ2xCLENBQUMsQ0FBQyxDQUNMLENBQUM7UUFDRixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDO0lBQ2pELENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRUQsNkRBQTZEO0lBQ3RELE1BQU0sQ0FBQyxJQUF1QixFQUFFLEtBQVk7UUFDL0MsSUFBSSxPQUFPLElBQUksRUFBRSxNQUFNLEtBQUssVUFBVSxFQUFFO1lBQ3BDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztTQUNqQjtJQUNMLENBQUM7SUFFTSxLQUFLLENBQUMsS0FBVTtRQUNuQixJQUFJLENBQUMsaUJBQWlCLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDbkYsQ0FBQzs7bUhBOUJRLHNCQUFzQjt1R0FBdEIsc0JBQXNCLHFGQ2pCbkMsaXNDQTRCQSw0Q0RkdUIsSUFBSSx3RkFBRSxTQUFTLDZDQUFFLGVBQWUsdUZBQUUscUJBQXFCOzJGQUdqRSxzQkFBc0I7a0JBTmxDLFNBQVM7aUNBQ00sSUFBSSxZQUNOLDJCQUEyQixXQUM1QixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLGVBQWUsRUFBRSxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXN5bmNQaXBlLCBOZ0NsYXNzLCBOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtDb21wb25lbnQsIEVsZW1lbnRSZWYsIE9uRGVzdHJveSwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHtPYnNlcnZhYmxlLCBTdWJzY3JpcHRpb259IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge0lVc2VyfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuaW1wb3J0IHtNbmdFbnVtZXJhdGVBc3luY1BpcGV9IGZyb20gJy4uLy4uL3BpcGVzJztcbmltcG9ydCB7TW5nQ29tbW9uc1NlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2VzJztcbmltcG9ydCB7TW5nTWFpbkxheW91dENvbXBvbmVudFNlcnZpY2V9IGZyb20gJy4vc2VydmljZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnbW5nLXRvcGJhci11c2VyLWNvbXBvbmVudCcsXG4gICAgaW1wb3J0czogW05nQ2xhc3MsIE5nSWYsIEFzeW5jUGlwZSwgVHJhbnNsYXRlTW9kdWxlLCBNbmdFbnVtZXJhdGVBc3luY1BpcGVdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi90b3BiYXItdXNlci5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgTW5nVG9wYmFyVXNlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBwdWJsaWMgdXNlcj86IElVc2VyO1xuICAgIHB1YmxpYyB1c2VyUm9sZXMkITogT2JzZXJ2YWJsZTxzdHJpbmdbXT47XG5cbiAgICBwcml2YXRlIHN1YnNjcmlwdGlvbnM6IFN1YnNjcmlwdGlvbltdID0gW107XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgbW5nQ29tbW9uczogTW5nQ29tbW9uc1NlcnZpY2UsIHB1YmxpYyBtYWluTGF5b3V0U2VydmljZTogTW5nTWFpbkxheW91dENvbXBvbmVudFNlcnZpY2UsIHB1YmxpYyBlbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7fVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5wdXNoKFxuICAgICAgICAgICAgdGhpcy5tbmdDb21tb25zLnVzZXIkLnN1YnNjcmliZSh1ID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLnVzZXIgPSB1O1xuICAgICAgICAgICAgfSlcbiAgICAgICAgKTtcbiAgICAgICAgdGhpcy51c2VyUm9sZXMkID0gdGhpcy5tbmdDb21tb25zLnVzZXJSb2xlcyQ7XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKSB7XG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5mb3JFYWNoKHZhbHVlID0+IHZhbHVlLnVuc3Vic2NyaWJlKCkpO1xuICAgIH1cblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgICBwdWJsaWMgbG9nb3V0KHVzZXI6IElVc2VyIHwgdW5kZWZpbmVkLCBldmVudDogRXZlbnQpIHtcbiAgICAgICAgaWYgKHR5cGVvZiB1c2VyPy5sb2dvdXQgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgICAgIHVzZXIubG9nb3V0KCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgY2xpY2soZXZlbnQ6IGFueSkge1xuICAgICAgICB0aGlzLm1haW5MYXlvdXRTZXJ2aWNlLm9uVG9wYmFySXRlbUNsaWNrKGV2ZW50LCB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCk7XG4gICAgfVxufVxuIiwiPGEgaHJlZj1cIiNcIiBjbGFzcz1cInVzZXItYmxvY2tcIiAoY2xpY2spPVwiY2xpY2soJGV2ZW50KVwiPlxuICAgIDxpIGNsYXNzPVwicGkgcGktZncgcGktdXNlclwiPjwvaT5cbiAgICA8c3BhbiBjbGFzcz1cInByb2ZpbGUtaXRlbS11c2VybmFtZSBoaWRkZW4gc206aW5saW5lLWJsb2NrXCI+Jm5ic3A7IHt7IHVzZXI/LmRpc3BsYXlOYW1lID8/IHVzZXI/LnVzZXJuYW1lIH19PC9zcGFuPlxuPC9hPlxuPHVsIGNsYXNzPVwiZmFkZUluRG93biBkcm9wZG93bi13aW5kb3dcIj5cbiAgICA8bGkgcm9sZT1cIm1lbnVpdGVtXCI+XG4gICAgICAgIDxhPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImZsZXhcIj5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleC1ncm93LTBcIj5cbiAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJwaSBwaS1mdyBwaS11c2VyXCI+PC9pPlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJmbGV4LWdyb3ctMVwiPlxuICAgICAgICAgICAgICAgICAgICA8c3Ryb25nPnt7IHVzZXI/LmRpc3BsYXlOYW1lID8/IHVzZXI/LnVzZXJuYW1lIH19PC9zdHJvbmc+XG4gICAgICAgICAgICAgICAgICAgIDxzbWFsbCAqbmdJZj1cIigodXNlclJvbGVzJCB8IGFzeW5jKT8ubGVuZ3RoID8/IDApID4gMFwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGJyIC8+XG4gICAgICAgICAgICAgICAgICAgICAgICB7eyB1c2VyUm9sZXMkIHwgbWduRW51bWVyYXRlQXN5bmMgOiB1bmRlZmluZWQgOiB1bmRlZmluZWQgOiB1bmRlZmluZWQgOiAncm9sZXMnIHwgYXN5bmMgfX1cbiAgICAgICAgICAgICAgICAgICAgPC9zbWFsbD5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2E+XG4gICAgPC9saT5cbiAgICA8bGkgcm9sZT1cIm1lbnVpdGVtXCIgKm5nSWY9XCJ1c2VyPy5sb2dvdXQgfHwgdXNlcj8ubG9nb3V0VXJsXCI+XG4gICAgICAgIDxhIFtocmVmXT1cInVzZXI/LmxvZ291dFVybFwiIChjbGljayk9XCJsb2dvdXQodXNlciwgJGV2ZW50KVwiPlxuICAgICAgICAgICAgPGkgY2xhc3M9XCJwaSBwaS1mdyBwaS1zaWduLW91dFwiPjwvaT5cbiAgICAgICAgICAgIDxzcGFuPnt7ICdtbmdUb3BiYXIubG9nb3V0JyB8IHRyYW5zbGF0ZSB9fTwvc3Bhbj5cbiAgICAgICAgPC9hPlxuICAgIDwvbGk+XG48L3VsPlxuIl19
|
|
@@ -1,67 +1,64 @@
|
|
|
1
1
|
import { AsyncPipe, NgClass, NgIf } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ViewChildren } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Inject, ViewChild, ViewChildren } from '@angular/core';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { RouterModule } from '@angular/router';
|
|
4
5
|
import { TranslateModule } from '@ngx-translate/core';
|
|
5
6
|
import { DropdownModule } from 'primeng/dropdown';
|
|
6
7
|
import { MngComponentDirective, MngTemplateDirective } from '../../directives';
|
|
7
8
|
import { MngEnumerateAsyncPipe } from '../../pipes';
|
|
9
|
+
import { MNG_MODULE_CONFIG_IT } from '../../services/tokens';
|
|
8
10
|
import { MngBreadcrumbComponent } from './breadcrumb.component';
|
|
9
11
|
import { MngMenuComponent } from './menu.component';
|
|
12
|
+
import { MngTopbarUserComponent } from './topbar-user.component';
|
|
10
13
|
import * as i0 from "@angular/core";
|
|
11
14
|
import * as i1 from "@angular/router";
|
|
12
15
|
import * as i2 from "../../services";
|
|
13
16
|
import * as i3 from "./services";
|
|
14
|
-
import * as i4 from "
|
|
15
|
-
import * as i5 from "
|
|
16
|
-
import * as i6 from "@angular/forms";
|
|
17
|
+
import * as i4 from "primeng/dropdown";
|
|
18
|
+
import * as i5 from "@angular/forms";
|
|
17
19
|
export class MngTopbarComponent {
|
|
18
|
-
constructor(route, mngCommons, mainLayoutService) {
|
|
20
|
+
constructor(applicationRef, route, mngCommons, mainLayoutService, config) {
|
|
21
|
+
this.applicationRef = applicationRef;
|
|
19
22
|
this.route = route;
|
|
20
23
|
this.mngCommons = mngCommons;
|
|
21
24
|
this.mainLayoutService = mainLayoutService;
|
|
25
|
+
this.config = config;
|
|
22
26
|
this.breadcrumbComponent = MngBreadcrumbComponent;
|
|
23
27
|
this.menuComponent = MngMenuComponent;
|
|
28
|
+
this.topbarUserComponent = MngTopbarUserComponent;
|
|
24
29
|
this.languages = ['en'];
|
|
25
30
|
this.selectedLanguage = 'en';
|
|
26
|
-
this.subscriptions = [];
|
|
27
31
|
}
|
|
28
32
|
ngOnInit() {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
this.breadcrumbComponent = routeData.breadcrumbComponent;
|
|
33
|
+
if (this.config.components?.layout?.topbarUser) {
|
|
34
|
+
this.topbarUserComponent = this.config.components.layout.topbarUser;
|
|
32
35
|
}
|
|
33
|
-
if (
|
|
34
|
-
this.
|
|
36
|
+
if (this.config.components?.layout?.breadcrumb) {
|
|
37
|
+
this.breadcrumbComponent = this.config.components.layout.breadcrumb;
|
|
38
|
+
}
|
|
39
|
+
if (this.config.components?.layout?.menu) {
|
|
40
|
+
this.menuComponent = this.config.components.layout.menu;
|
|
35
41
|
}
|
|
36
42
|
this.languages = this.mngCommons.appLanguages;
|
|
37
43
|
this.selectedLanguage = this.mngCommons.getOrInitLanguage();
|
|
38
|
-
const userSubscription = this.mngCommons.user$.subscribe(u => {
|
|
39
|
-
this.user = u;
|
|
40
|
-
});
|
|
41
|
-
this.userRoles$ = this.mngCommons.userRoles$;
|
|
42
|
-
this.mainLayoutService.innerWidth = window.innerWidth;
|
|
43
|
-
this.subscriptions.push(userSubscription);
|
|
44
|
-
}
|
|
45
|
-
ngOnDestroy() {
|
|
46
|
-
this.subscriptions.forEach(s => s.unsubscribe());
|
|
47
44
|
}
|
|
48
45
|
switchLanguage(language) {
|
|
49
46
|
this.mngCommons.appLanguage = language;
|
|
50
47
|
}
|
|
51
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
52
|
-
logout(user, event) {
|
|
53
|
-
if (typeof user.logout === 'function') {
|
|
54
|
-
user.logout();
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
48
|
}
|
|
58
|
-
MngTopbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: MngTopbarComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.MngCommonsService }, { token: i3.MngMainLayoutComponentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
-
MngTopbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: MngTopbarComponent, isStandalone: true, selector: "mng-topbar", viewQueries: [{ propertyName: "templates", predicate: MngTemplateDirective, descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\n <div class=\"layout-topbar-left\">\n <a\n href=\"#\"\n class=\"topbar-menu-button\"\n (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n <i class=\"pi pi-bars\"></i>\n </a>\n\n <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n </div>\n\n <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n <div class=\"layout-topbar-right\">\n <ul class=\"layout-topbar-right-items\">\n <li
|
|
49
|
+
MngTopbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: MngTopbarComponent, deps: [{ token: i0.ApplicationRef }, { token: i1.ActivatedRoute }, { token: i2.MngCommonsService }, { token: i3.MngMainLayoutComponentService }, { token: MNG_MODULE_CONFIG_IT }], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
+
MngTopbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: MngTopbarComponent, isStandalone: true, selector: "mng-topbar", viewQueries: [{ propertyName: "topbarInjectionRef", first: true, predicate: ["userMenuItem"], descendants: true }, { propertyName: "templates", predicate: MngTemplateDirective, descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\n <div class=\"layout-topbar-left\">\n <a\n href=\"#\"\n class=\"topbar-menu-button\"\n (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n <i class=\"pi pi-bars\"></i>\n </a>\n\n <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n </div>\n\n <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n <div class=\"layout-topbar-right\">\n <ul class=\"layout-topbar-right-items\">\n <li\n #userMenuItem\n class=\"profile-item profile-item-extended\"\n [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === userMenuItem}\"\n [mngComponent]=\"topbarUserComponent\"\n [attachToHost]=\"true\"></li>\n <li *ngIf=\"languages.length > 1\" class=\"profile-item\">\n <i class=\"pi pi-fw pi-globe\"></i>\n <p-dropdown [ngModel]=\"selectedLanguage\" [options]=\"languages\" (onChange)=\"switchLanguage($event.value)\"></p-dropdown>\n </li>\n </ul>\n </div>\n</div>\n", dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs", "attachToHost"], outputs: ["instanceCreated"] }, { kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i4.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "overlayDirection", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: RouterModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
60
51
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: MngTopbarComponent, decorators: [{
|
|
61
52
|
type: Component,
|
|
62
|
-
args: [{ standalone: true, selector: 'mng-topbar', imports: [AsyncPipe, NgClass, TranslateModule, NgIf, MngComponentDirective, MngEnumerateAsyncPipe, DropdownModule, FormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-topbar\">\n <div class=\"layout-topbar-left\">\n <a\n href=\"#\"\n class=\"topbar-menu-button\"\n (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n <i class=\"pi pi-bars\"></i>\n </a>\n\n <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n </div>\n\n <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n <div class=\"layout-topbar-right\">\n <ul class=\"layout-topbar-right-items\">\n <li
|
|
63
|
-
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.MngCommonsService }, { type: i3.MngMainLayoutComponentService }
|
|
53
|
+
args: [{ standalone: true, selector: 'mng-topbar', imports: [AsyncPipe, NgClass, TranslateModule, NgIf, MngComponentDirective, MngEnumerateAsyncPipe, DropdownModule, FormsModule, RouterModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-topbar\">\n <div class=\"layout-topbar-left\">\n <a\n href=\"#\"\n class=\"topbar-menu-button\"\n (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n <i class=\"pi pi-bars\"></i>\n </a>\n\n <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n </div>\n\n <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n <div class=\"layout-topbar-right\">\n <ul class=\"layout-topbar-right-items\">\n <li\n #userMenuItem\n class=\"profile-item profile-item-extended\"\n [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === userMenuItem}\"\n [mngComponent]=\"topbarUserComponent\"\n [attachToHost]=\"true\"></li>\n <li *ngIf=\"languages.length > 1\" class=\"profile-item\">\n <i class=\"pi pi-fw pi-globe\"></i>\n <p-dropdown [ngModel]=\"selectedLanguage\" [options]=\"languages\" (onChange)=\"switchLanguage($event.value)\"></p-dropdown>\n </li>\n </ul>\n </div>\n</div>\n" }]
|
|
54
|
+
}], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i1.ActivatedRoute }, { type: i2.MngCommonsService }, { type: i3.MngMainLayoutComponentService }, { type: undefined, decorators: [{
|
|
55
|
+
type: Inject,
|
|
56
|
+
args: [MNG_MODULE_CONFIG_IT]
|
|
57
|
+
}] }]; }, propDecorators: { templates: [{
|
|
64
58
|
type: ViewChildren,
|
|
65
59
|
args: [MngTemplateDirective]
|
|
60
|
+
}], topbarInjectionRef: [{
|
|
61
|
+
type: ViewChild,
|
|
62
|
+
args: ['userMenuItem']
|
|
66
63
|
}] } });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"topbar.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/layout/topbar.component.ts","../../../../../src/lib/components/layout/topbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgClass, NgIf} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, OnDestroy, OnInit, QueryList, Type, ViewChildren} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {TranslateModule} from '@ngx-translate/core';\nimport {DropdownModule} from 'primeng/dropdown';\nimport {Observable, Subscription} from 'rxjs';\n\nimport {MngComponentDirective, MngTemplateDirective} from '../../directives';\nimport {IUser} from '../../models';\nimport {MngEnumerateAsyncPipe} from '../../pipes';\nimport {MngRouterData} from '../../router/models';\nimport {MngCommonsService} from '../../services';\nimport {MngBreadcrumbComponent} from './breadcrumb.component';\nimport {MngMenuComponent} from './menu.component';\nimport {MngMainLayoutComponentService} from './services';\n\n@Component({\n    standalone: true,\n    selector: 'mng-topbar',\n    templateUrl: './topbar.component.html',\n    imports: [AsyncPipe, NgClass, TranslateModule, NgIf, MngComponentDirective, MngEnumerateAsyncPipe, DropdownModule, FormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTopbarComponent implements OnInit, OnDestroy {\n    @ViewChildren(MngTemplateDirective) templates!: QueryList<MngTemplateDirective>;\n\n    public breadcrumbComponent: Type<any> = MngBreadcrumbComponent;\n    public menuComponent: Type<any> = MngMenuComponent;\n\n    public languages: Array<string> = ['en'];\n    public selectedLanguage = 'en';\n    public user?: IUser;\n    public userRoles$!: Observable<string[]>;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private route: ActivatedRoute, public mngCommons: MngCommonsService, public mainLayoutService: MngMainLayoutComponentService) {}\n\n    ngOnInit(): void {\n        const routeData = this.route.snapshot.data as MngRouterData;\n        if (routeData?.breadcrumbComponent) {\n            this.breadcrumbComponent = routeData.breadcrumbComponent;\n        }\n        if (routeData?.menuComponent) {\n            this.menuComponent = routeData.menuComponent;\n        }\n\n        this.languages = this.mngCommons.appLanguages;\n        this.selectedLanguage = this.mngCommons.getOrInitLanguage();\n        const userSubscription = this.mngCommons.user$.subscribe(u => {\n            this.user = u;\n        });\n        this.userRoles$ = this.mngCommons.userRoles$;\n\n        this.mainLayoutService.innerWidth = window.innerWidth;\n\n        this.subscriptions.push(userSubscription);\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public switchLanguage(language: string) {\n        this.mngCommons.appLanguage = language;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    public logout(user: IUser, event: Event) {\n        if (typeof user.logout === 'function') {\n            user.logout();\n        }\n    }\n}\n","<div class=\"layout-topbar\">\n    <div class=\"layout-topbar-left\">\n        <a\n            href=\"#\"\n            class=\"topbar-menu-button\"\n            (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n            *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n            <i class=\"pi pi-bars\"></i>\n        </a>\n\n        <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n    </div>\n\n    <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n    <div class=\"layout-topbar-right\">\n        <ul class=\"layout-topbar-right-items\">\n            <li #profile class=\"profile-item profile-item-extended\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n                <a href=\"#\" (click)=\"mainLayoutService.onTopbarItemClick($event, profile)\">\n                    <i class=\"pi pi-fw pi-user\"></i>\n                    <span class=\"profile-item-username hidden sm:inline-block\">&nbsp; {{ user?.displayName ?? user?.username }}</span>\n                </a>\n                <ul class=\"fadeInDown\" *ngIf=\"user\">\n                    <li role=\"menuitem\">\n                        <a>\n                            <div class=\"flex\">\n                                <div class=\"flex-grow-0\">\n                                    <i class=\"pi pi-fw pi-user\"></i>\n                                </div>\n                                <div class=\"flex-grow-1\">\n                                    <strong>{{ user?.displayName ?? user?.username }}</strong>\n                                    <small *ngIf=\"((userRoles$ | async)?.length ?? 0) > 0\">\n                                        <br />\n                                        {{ userRoles$ | mgnEnumerateAsync : undefined : undefined : undefined : 'roles' | async }}\n                                    </small>\n                                </div>\n                            </div>\n                        </a>\n                    </li>\n                    <li role=\"menuitem\" *ngIf=\"user?.logout || user?.logoutUrl\">\n                        <a [href]=\"user?.logoutUrl\" (click)=\"logout(user, $event)\">\n                            <i class=\"pi pi-fw pi-sign-out\"></i>\n                            <span>{{ 'mngTopbar.logout' | translate }}</span>\n                        </a>\n                    </li>\n                </ul>\n            </li>\n            <li *ngIf=\"languages.length > 1\" class=\"profile-item\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n                <i class=\"pi pi-fw pi-globe\"></i>\n                <p-dropdown [ngModel]=\"selectedLanguage\" [options]=\"languages\" (onChange)=\"switchLanguage($event.value)\"></p-dropdown>\n            </li>\n        </ul>\n    </div>\n</div>\n"]}
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"topbar.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/layout/topbar.component.ts","../../../../../src/lib/components/layout/topbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgClass, NgIf} from '@angular/common';\nimport {ApplicationRef, ChangeDetectionStrategy, Component, ElementRef, Inject, OnInit, QueryList, Type, ViewChild, ViewChildren} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport {ActivatedRoute, RouterModule} from '@angular/router';\n\nimport {TranslateModule} from '@ngx-translate/core';\nimport {DropdownModule} from 'primeng/dropdown';\n\nimport {MngComponentDirective, MngTemplateDirective} from '../../directives';\nimport {MngModuleConfig} from '../../models';\nimport {MngEnumerateAsyncPipe} from '../../pipes';\nimport {MngCommonsService} from '../../services';\nimport {MNG_MODULE_CONFIG_IT} from '../../services/tokens';\nimport {MngBreadcrumbComponent} from './breadcrumb.component';\nimport {MngMenuComponent} from './menu.component';\nimport {MngMainLayoutComponentService} from './services';\nimport {MngTopbarUserComponent} from './topbar-user.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-topbar',\n    templateUrl: './topbar.component.html',\n    imports: [AsyncPipe, NgClass, TranslateModule, NgIf, MngComponentDirective, MngEnumerateAsyncPipe, DropdownModule, FormsModule, RouterModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTopbarComponent implements OnInit {\n    @ViewChildren(MngTemplateDirective) templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('userMenuItem') topbarInjectionRef!: ElementRef;\n\n    public breadcrumbComponent: Type<any> = MngBreadcrumbComponent;\n    public menuComponent: Type<any> = MngMenuComponent;\n    public topbarUserComponent: Type<any> = MngTopbarUserComponent;\n\n    public languages: Array<string> = ['en'];\n    public selectedLanguage = 'en';\n\n    constructor(\n        private applicationRef: ApplicationRef,\n        private route: ActivatedRoute,\n        public mngCommons: MngCommonsService,\n        public mainLayoutService: MngMainLayoutComponentService,\n        @Inject(MNG_MODULE_CONFIG_IT) private config: MngModuleConfig\n    ) {}\n\n    ngOnInit(): void {\n        if (this.config.components?.layout?.topbarUser) {\n            this.topbarUserComponent = this.config.components.layout.topbarUser;\n        }\n        if (this.config.components?.layout?.breadcrumb) {\n            this.breadcrumbComponent = this.config.components.layout.breadcrumb;\n        }\n        if (this.config.components?.layout?.menu) {\n            this.menuComponent = this.config.components.layout.menu;\n        }\n\n        this.languages = this.mngCommons.appLanguages;\n        this.selectedLanguage = this.mngCommons.getOrInitLanguage();\n    }\n\n    public switchLanguage(language: string) {\n        this.mngCommons.appLanguage = language;\n    }\n}\n","<div class=\"layout-topbar\">\n    <div class=\"layout-topbar-left\">\n        <a\n            href=\"#\"\n            class=\"topbar-menu-button\"\n            (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n            *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n            <i class=\"pi pi-bars\"></i>\n        </a>\n\n        <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n    </div>\n\n    <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n    <div class=\"layout-topbar-right\">\n        <ul class=\"layout-topbar-right-items\">\n            <li\n                #userMenuItem\n                class=\"profile-item profile-item-extended\"\n                [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === userMenuItem}\"\n                [mngComponent]=\"topbarUserComponent\"\n                [attachToHost]=\"true\"></li>\n            <li *ngIf=\"languages.length > 1\" class=\"profile-item\">\n                <i class=\"pi pi-fw pi-globe\"></i>\n                <p-dropdown [ngModel]=\"selectedLanguage\" [options]=\"languages\" (onChange)=\"switchLanguage($event.value)\"></p-dropdown>\n            </li>\n        </ul>\n    </div>\n</div>\n"]}
|
|
@@ -69,7 +69,7 @@ export class MngTableColumnValueComponent {
|
|
|
69
69
|
}
|
|
70
70
|
}
|
|
71
71
|
MngTableColumnValueComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: MngTableColumnValueComponent, deps: [{ token: i0.ElementRef }, { token: i1.MessageService }, { token: i2.TranslateService }, { token: i3.JsonPathPipe }, { token: i3.MngGetterPipe }, { token: i3.MngTemplatePipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
72
|
-
MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: MngTableColumnValueComponent, isStandalone: true, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, host: { properties: { "style.max-width.px": "this.styleMaxWidth", "class": "this.className" } }, ngImport: i0, template: "<ng-container [ngSwitch]=\"descriptor.columnDisplayType\">\n <i\n *ngIf=\"descriptor.localizationExistsProperty && !item[descriptor.localizationExistsProperty]\"\n class=\"pi pi-exclamation-circle\"\n [pTooltip]=\"'mngTable.translationMissing' | translate\"></i>\n <ng-container *ngSwitchCase=\"columnDisplayTypeString\">\n {{ value }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeHtml\">\n <span [innerHTML]=\"value\"></span>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeNumber\">\n {{ value | number : descriptor.displayFormat : descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeCurrency\">\n {{ value | currency : currency : descriptor.currencyDisplay : descriptor.displayFormat : descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeDate\">\n {{ value | date : descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\">\n <i [class]=\"value | boolean : descriptor.booleanYes : descriptor.booleanNo : true\"></i>\n </ng-container>\n <ng-template #booleanText>\n {{ value | boolean : descriptor.booleanYes : descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeEnum\">\n {{ value | enum : descriptor.enumType : descriptor.enumTitlePath : descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeComponent\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: value,\n item: item,\n descriptor: descriptor\n }\"></ng-container>\n </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\n <button pButton pRipple type=\"button\" icon=\"pi pi-copy\" class=\"p-button-rounded p-button-info p-button-sm\" (click)=\"copyToClipboard($event)\"></button>\n</div>\n", styles: [":host{display:inline-block;overflow:hidden}:host.nowrap{white-space:nowrap;text-overflow:ellipsis}.help-buttons{display:none;position:absolute;right:0;top:50%;transform:translateY(-50%)}.help-buttons .p-button{height:1.9rem;width:1.9rem;padding:0}\n"], dependencies: [{ kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i4.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: DecimalPipe, name: "number" }, { kind: "pipe", type: CurrencyPipe, name: "currency" }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "pipe", type: MngBooleanPipe, name: "boolean" }, { kind: "pipe", type: MngEnumPipe, name: "enum" }, { kind: "directive", type: MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
72
|
+
MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.1", type: MngTableColumnValueComponent, isStandalone: true, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, host: { properties: { "style.max-width.px": "this.styleMaxWidth", "class": "this.className" } }, ngImport: i0, template: "<ng-container [ngSwitch]=\"descriptor.columnDisplayType\">\n <i\n *ngIf=\"descriptor.localizationExistsProperty && !item[descriptor.localizationExistsProperty]\"\n class=\"pi pi-exclamation-circle\"\n [pTooltip]=\"'mngTable.translationMissing' | translate\"></i>\n <ng-container *ngSwitchCase=\"columnDisplayTypeString\">\n {{ value }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeHtml\">\n <span [innerHTML]=\"value\"></span>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeNumber\">\n {{ value | number : descriptor.displayFormat : descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeCurrency\">\n {{ value | currency : currency : descriptor.currencyDisplay : descriptor.displayFormat : descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeDate\">\n {{ value | date : descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\">\n <i [class]=\"value | boolean : descriptor.booleanYes : descriptor.booleanNo : true\"></i>\n </ng-container>\n <ng-template #booleanText>\n {{ value | boolean : descriptor.booleanYes : descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeEnum\">\n {{ value | enum : descriptor.enumType : descriptor.enumTitlePath : descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeComponent\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: value,\n item: item,\n descriptor: descriptor\n }\"></ng-container>\n </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\n <button pButton pRipple type=\"button\" icon=\"pi pi-copy\" class=\"p-button-rounded p-button-info p-button-sm\" (click)=\"copyToClipboard($event)\"></button>\n</div>\n", styles: [":host{display:inline-block;overflow:hidden}:host.nowrap{white-space:nowrap;text-overflow:ellipsis}.help-buttons{display:none;position:absolute;right:0;top:50%;transform:translateY(-50%)}.help-buttons .p-button{height:1.9rem;width:1.9rem;padding:0}\n"], dependencies: [{ kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i4.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: DecimalPipe, name: "number" }, { kind: "pipe", type: CurrencyPipe, name: "currency" }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "pipe", type: MngBooleanPipe, name: "boolean" }, { kind: "pipe", type: MngEnumPipe, name: "enum" }, { kind: "directive", type: MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs", "attachToHost"], outputs: ["instanceCreated"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
73
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImport: i0, type: MngTableColumnValueComponent, decorators: [{
|
|
74
74
|
type: Component,
|
|
75
75
|
args: [{ standalone: true, selector: 'mng-table-column-value', imports: [
|
|
@@ -98,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.1", ngImpor
|
|
|
98
98
|
type: HostBinding,
|
|
99
99
|
args: ['class']
|
|
100
100
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-value.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.ts","../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CurrencyPipe, DatePipe, DecimalPipe, NgIf, NgSwitch, NgSwitchCase} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, OnInit} from '@angular/core';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {MessageService} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {RippleModule} from 'primeng/ripple';\nimport {TooltipModule} from 'primeng/tooltip';\n\nimport {ColumnDescriptor} from '../../../../descriptors/table';\nimport {ColumnDisplayTypeEnum} from '../../../../descriptors/types';\nimport {MngComponentDirective} from '../../../../directives';\nimport {JsonPathPipe, MngBooleanPipe, MngEnumPipe, MngGetterPipe, MngTemplatePipe} from '../../../../pipes';\n\n@Component({\n    standalone: true,\n    selector: 'mng-table-column-value',\n    templateUrl: './column-value.component.html',\n    styleUrls: ['./column-value.component.scss'],\n    imports: [\n        NgSwitch,\n        NgIf,\n        TooltipModule,\n        TranslateModule,\n        NgSwitchCase,\n        DecimalPipe,\n        CurrencyPipe,\n        DatePipe,\n        MngBooleanPipe,\n        MngEnumPipe,\n        MngComponentDirective,\n        ButtonModule,\n        RippleModule\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTableColumnValueComponent<T, TT> implements OnInit {\n    public readonly columnDisplayTypeString: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.String;\n    public readonly columnDisplayTypeNumber: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Number;\n    public readonly columnDisplayTypeCurrency: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Currency;\n    public readonly columnDisplayTypeBoolean: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Boolean;\n    public readonly columnDisplayTypeDate: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Date;\n    public readonly columnDisplayTypeEnum: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Enum;\n    public readonly columnDisplayTypeComponent: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Component;\n    public readonly columnDisplayTypeHtml: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Html;\n\n    @Input() descriptor!: ColumnDescriptor<T, TT>;\n    @Input() item!: any;\n\n    @HostBinding('style.max-width.px') public styleMaxWidth: number | null = null;\n    @HostBinding('class') public className = 'nowrap';\n\n    public currency?: string;\n\n    public jsonPath = '$';\n\n    public value: any;\n\n    constructor(\n        private elementRef: ElementRef,\n        private messageService: MessageService,\n        private translate: TranslateService,\n        private jsonPathPipe: JsonPathPipe,\n        private getterPipe: MngGetterPipe,\n        private templatePipe: MngTemplatePipe\n    ) {}\n\n    public ngOnInit() {\n        if (this.descriptor.columnDisplayType === ColumnDisplayTypeEnum.Currency) {\n            this.currency = this.descriptor.currencyFromProperty ? this.item[this.descriptor.currencyFromProperty] : this.descriptor.currencyCode ?? 'EUR';\n        }\n\n        if (this.descriptor.maxWidth) {\n            this.styleMaxWidth = this.descriptor.maxWidth;\n        }\n\n        if (this.descriptor.jsonPath) {\n            this.jsonPath = this.descriptor.jsonPath;\n        } else {\n            this.jsonPath = `$.${this.descriptor.property}`;\n            if (this.descriptor.objectModelType) {\n                this.jsonPath = `$.${this.descriptor.property}.${this.descriptor.objectTitleProperty}`;\n            }\n        }\n\n        let value = this.jsonPathPipe.transform(this.item, this.jsonPath);\n\n        if (typeof this.descriptor.getter === 'function') {\n            value = this.getterPipe.transform(this.item, this.descriptor.getter, value);\n        }\n        if (this.descriptor.template) {\n            value = this.templatePipe.transform(value, this.descriptor.template);\n        }\n\n        this.value = value;\n    }\n\n    public copyToClipboard(event: Event) {\n        event.stopPropagation();\n        const value = this.elementRef.nativeElement.innerText.trim();\n        navigator.clipboard.writeText(value);\n        const title = this.translate.instant('mngTable.copyNotificationTitle');\n        const message = this.translate.instant('mngTable.copyNotificationMessage', {value});\n        this.messageService.add({severity: 'info', summary: title, detail: message});\n    }\n}\n","<ng-container [ngSwitch]=\"descriptor.columnDisplayType\">\n    <i\n        *ngIf=\"descriptor.localizationExistsProperty && !item[descriptor.localizationExistsProperty]\"\n        class=\"pi pi-exclamation-circle\"\n        [pTooltip]=\"'mngTable.translationMissing' | translate\"></i>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeString\">\n        {{ value }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeHtml\">\n        <span [innerHTML]=\"value\"></span>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeNumber\">\n        {{ value | number : descriptor.displayFormat : descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeCurrency\">\n        {{ value | currency : currency : descriptor.currencyDisplay : descriptor.displayFormat : descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeDate\">\n        {{ value | date : descriptor.displayFormat }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeBoolean\">\n        <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\">\n            <i [class]=\"value | boolean : descriptor.booleanYes : descriptor.booleanNo : true\"></i>\n        </ng-container>\n        <ng-template #booleanText>\n            {{ value | boolean : descriptor.booleanYes : descriptor.booleanNo | translate }}\n        </ng-template>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeEnum\">\n        {{ value | enum : descriptor.enumType : descriptor.enumTitlePath : descriptor.enumNameAsValue | translate }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeComponent\">\n        <ng-container\n            [mngComponent]=\"descriptor.customComponentType!\"\n            [inputs]=\"{\n                value: value,\n                item: item,\n                descriptor: descriptor\n            }\"></ng-container>\n    </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\n    <button pButton pRipple type=\"button\" icon=\"pi pi-copy\" class=\"p-button-rounded p-button-info p-button-sm\" (click)=\"copyToClipboard($event)\"></button>\n</div>\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-value.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.ts","../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CurrencyPipe, DatePipe, DecimalPipe, NgIf, NgSwitch, NgSwitchCase} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, OnInit} from '@angular/core';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {MessageService} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {RippleModule} from 'primeng/ripple';\nimport {TooltipModule} from 'primeng/tooltip';\n\nimport {ColumnDescriptor} from '../../../../descriptors/table';\nimport {ColumnDisplayTypeEnum} from '../../../../descriptors/types';\nimport {MngComponentDirective} from '../../../../directives';\nimport {JsonPathPipe, MngBooleanPipe, MngEnumPipe, MngGetterPipe, MngTemplatePipe} from '../../../../pipes';\n\n@Component({\n    standalone: true,\n    selector: 'mng-table-column-value',\n    templateUrl: './column-value.component.html',\n    styleUrls: ['./column-value.component.scss'],\n    imports: [\n        NgSwitch,\n        NgIf,\n        TooltipModule,\n        TranslateModule,\n        NgSwitchCase,\n        DecimalPipe,\n        CurrencyPipe,\n        DatePipe,\n        MngBooleanPipe,\n        MngEnumPipe,\n        MngComponentDirective,\n        ButtonModule,\n        RippleModule\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTableColumnValueComponent<T, TT> implements OnInit {\n    public readonly columnDisplayTypeString: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.String;\n    public readonly columnDisplayTypeNumber: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Number;\n    public readonly columnDisplayTypeCurrency: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Currency;\n    public readonly columnDisplayTypeBoolean: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Boolean;\n    public readonly columnDisplayTypeDate: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Date;\n    public readonly columnDisplayTypeEnum: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Enum;\n    public readonly columnDisplayTypeComponent: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Component;\n    public readonly columnDisplayTypeHtml: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Html;\n\n    @Input() descriptor!: ColumnDescriptor<T, TT>;\n    @Input() item!: any;\n\n    @HostBinding('style.max-width.px') public styleMaxWidth: number | null = null;\n    @HostBinding('class') public className = 'nowrap';\n\n    public currency?: string;\n\n    public jsonPath = '$';\n\n    public value: any;\n\n    constructor(\n        private elementRef: ElementRef,\n        private messageService: MessageService,\n        private translate: TranslateService,\n        private jsonPathPipe: JsonPathPipe,\n        private getterPipe: MngGetterPipe,\n        private templatePipe: MngTemplatePipe\n    ) {}\n\n    public ngOnInit() {\n        if (this.descriptor.columnDisplayType === ColumnDisplayTypeEnum.Currency) {\n            this.currency = this.descriptor.currencyFromProperty ? this.item[this.descriptor.currencyFromProperty] : this.descriptor.currencyCode ?? 'EUR';\n        }\n\n        if (this.descriptor.maxWidth) {\n            this.styleMaxWidth = this.descriptor.maxWidth;\n        }\n\n        if (this.descriptor.jsonPath) {\n            this.jsonPath = this.descriptor.jsonPath;\n        } else {\n            this.jsonPath = `$.${this.descriptor.property}`;\n            if (this.descriptor.objectModelType) {\n                this.jsonPath = `$.${this.descriptor.property}.${this.descriptor.objectTitleProperty}`;\n            }\n        }\n\n        let value = this.jsonPathPipe.transform(this.item, this.jsonPath);\n\n        if (typeof this.descriptor.getter === 'function') {\n            value = this.getterPipe.transform(this.item, this.descriptor.getter, value);\n        }\n        if (this.descriptor.template) {\n            value = this.templatePipe.transform(value, this.descriptor.template);\n        }\n\n        this.value = value;\n    }\n\n    public copyToClipboard(event: Event) {\n        event.stopPropagation();\n        const value = this.elementRef.nativeElement.innerText.trim();\n        navigator.clipboard.writeText(value);\n        const title = this.translate.instant('mngTable.copyNotificationTitle');\n        const message = this.translate.instant('mngTable.copyNotificationMessage', {value});\n        this.messageService.add({severity: 'info', summary: title, detail: message});\n    }\n}\n","<ng-container [ngSwitch]=\"descriptor.columnDisplayType\">\n    <i\n        *ngIf=\"descriptor.localizationExistsProperty && !item[descriptor.localizationExistsProperty]\"\n        class=\"pi pi-exclamation-circle\"\n        [pTooltip]=\"'mngTable.translationMissing' | translate\"></i>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeString\">\n        {{ value }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeHtml\">\n        <span [innerHTML]=\"value\"></span>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeNumber\">\n        {{ value | number : descriptor.displayFormat : descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeCurrency\">\n        {{ value | currency : currency : descriptor.currencyDisplay : descriptor.displayFormat : descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeDate\">\n        {{ value | date : descriptor.displayFormat }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeBoolean\">\n        <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\">\n            <i [class]=\"value | boolean : descriptor.booleanYes : descriptor.booleanNo : true\"></i>\n        </ng-container>\n        <ng-template #booleanText>\n            {{ value | boolean : descriptor.booleanYes : descriptor.booleanNo | translate }}\n        </ng-template>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeEnum\">\n        {{ value | enum : descriptor.enumType : descriptor.enumTitlePath : descriptor.enumNameAsValue | translate }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeComponent\">\n        <ng-container\n            [mngComponent]=\"descriptor.customComponentType!\"\n            [inputs]=\"{\n                value: value,\n                item: item,\n                descriptor: descriptor\n            }\"></ng-container>\n    </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\n    <button pButton pRipple type=\"button\" icon=\"pi pi-copy\" class=\"p-button-rounded p-button-info p-button-sm\" (click)=\"copyToClipboard($event)\"></button>\n</div>\n"]}
|