@mediusinc/mng-commons 2.4.2 → 2.5.0
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/assets/i18n/en.json +14 -0
- package/assets/i18n/sl.json +14 -0
- package/esm2020/index.mjs +2 -1
- package/esm2020/lib/api/utils/medius-rest.util.mjs +8 -1
- package/esm2020/lib/components/action/editor/action-editor.component.mjs +1 -1
- package/esm2020/lib/components/form/autocomplete/autocomplete.component.mjs +3 -2
- package/esm2020/lib/components/form/dropdown/dropdown.component.mjs +3 -2
- package/esm2020/lib/components/form/editor/form-editor.component.mjs +4 -11
- package/esm2020/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +4 -3
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +7 -6
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +22 -8
- package/esm2020/lib/components/pages/error/error-page.component.mjs +21 -0
- package/esm2020/lib/components/pages/index.mjs +3 -0
- package/esm2020/lib/components/pages/not-found/not-found-page.component.mjs +21 -0
- package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +18 -10
- package/esm2020/lib/components/tableview/table/column-value/column-value.component.mjs +8 -3
- package/esm2020/lib/components/tableview/table/table.component.mjs +14 -3
- package/esm2020/lib/components/tableview/tableview.component.mjs +36 -4
- package/esm2020/lib/descriptors/action/action-button.descriptor.mjs +2 -2
- package/esm2020/lib/descriptors/action/action.descriptor.mjs +55 -6
- package/esm2020/lib/descriptors/editor/editor.descriptor.mjs +3 -2
- package/esm2020/lib/descriptors/editor/field.descriptor.mjs +13 -1
- package/esm2020/lib/descriptors/filter/filter.descriptor.mjs +5 -4
- package/esm2020/lib/descriptors/table/column.descriptor.mjs +27 -3
- package/esm2020/lib/descriptors/tableview/tableview.descriptor.mjs +3 -2
- package/esm2020/lib/mng-commons.module.mjs +18 -5
- package/esm2020/lib/models/error-internal.model.mjs +27 -0
- package/esm2020/lib/models/index.mjs +2 -1
- package/esm2020/lib/router/route-builder.mjs +4 -3
- package/esm2020/lib/router/routes-builder.mjs +3 -2
- package/esm2020/lib/services/action-executor.service.mjs +4 -3
- package/esm2020/lib/services/configuration.service.mjs +9 -4
- package/esm2020/lib/styles/button-style.builder.mjs +10 -1
- package/esm2020/lib/utils/action-data-provider.util.mjs +7 -6
- package/esm2020/lib/utils/file.util.mjs +18 -0
- package/esm2020/lib/utils/index.mjs +2 -1
- package/esm2020/lib/utils/route.util.mjs +3 -2
- package/esm2020/lib/utils/tableview.util.mjs +3 -2
- package/esm2020/lib/utils/type.util.mjs +3 -2
- package/fesm2015/mediusinc-mng-commons.mjs +322 -75
- package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
- package/fesm2020/mediusinc-mng-commons.mjs +313 -72
- package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/api/utils/medius-rest.util.d.ts +2 -0
- package/lib/components/form/editor/form-editor.component.d.ts +1 -3
- package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +4 -0
- package/lib/components/pages/error/error-page.component.d.ts +8 -0
- package/lib/components/pages/index.d.ts +2 -0
- package/lib/components/pages/not-found/not-found-page.component.d.ts +8 -0
- package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +1 -1
- package/lib/components/tableview/table/table.component.d.ts +3 -1
- package/lib/components/tableview/tableview.component.d.ts +4 -1
- package/lib/descriptors/action/action.descriptor.d.ts +2 -0
- package/lib/descriptors/editor/field.descriptor.d.ts +5 -0
- package/lib/descriptors/table/column.descriptor.d.ts +9 -1
- package/lib/mng-commons.module.d.ts +3 -1
- package/lib/models/error-internal.model.d.ts +29 -0
- package/lib/models/index.d.ts +1 -0
- package/lib/styles/button-style.builder.d.ts +1 -0
- package/lib/utils/file.util.d.ts +3 -0
- package/lib/utils/index.d.ts +1 -0
- package/package.json +1 -2
- package/scss/mng-overrides/_layout_styles.scss +4 -0
- package/scss/mng-overrides/_theme_dialog.scss +35 -0
|
@@ -3,6 +3,7 @@ import { Component, ContentChildren, Input, QueryList, ViewChild } from '@angula
|
|
|
3
3
|
import { ActivatedRoute, RouterOutlet } from '@angular/router';
|
|
4
4
|
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
5
5
|
import { ConfirmationService, MessageService } from 'primeng/api';
|
|
6
|
+
import { DialogModule } from 'primeng/dialog';
|
|
6
7
|
import { ToastModule } from 'primeng/toast';
|
|
7
8
|
import { ToolbarModule } from 'primeng/toolbar';
|
|
8
9
|
import { TableviewDescriptor } from '../../descriptors/tableview';
|
|
@@ -18,7 +19,8 @@ import * as i2 from "primeng/api";
|
|
|
18
19
|
import * as i3 from "@ngx-translate/core";
|
|
19
20
|
import * as i4 from "../../services";
|
|
20
21
|
import * as i5 from "primeng/toast";
|
|
21
|
-
import * as i6 from "primeng/
|
|
22
|
+
import * as i6 from "primeng/dialog";
|
|
23
|
+
import * as i7 from "primeng/toolbar";
|
|
22
24
|
export class MngTableviewComponent {
|
|
23
25
|
constructor(route, messageService, translateService, confirmationService, actionExecutor, viewContainerService) {
|
|
24
26
|
this.route = route;
|
|
@@ -34,6 +36,8 @@ export class MngTableviewComponent {
|
|
|
34
36
|
this.subscriptions = [];
|
|
35
37
|
this.hasItemSelectionAction = false;
|
|
36
38
|
this.selectedItems = [];
|
|
39
|
+
this.showingNotification = null;
|
|
40
|
+
this.notificationCutoff = 70;
|
|
37
41
|
}
|
|
38
42
|
ngOnInit() {
|
|
39
43
|
this.viewContainerService.setActions(this.actions);
|
|
@@ -92,12 +96,40 @@ export class MngTableviewComponent {
|
|
|
92
96
|
selectionChange(selectedItems) {
|
|
93
97
|
this.selectedItems = selectedItems;
|
|
94
98
|
}
|
|
99
|
+
getNotificationIconClass(message) {
|
|
100
|
+
if (message?.icon)
|
|
101
|
+
return message.icon;
|
|
102
|
+
switch (message?.severity) {
|
|
103
|
+
case 'info':
|
|
104
|
+
return 'pi-info-circle';
|
|
105
|
+
case 'warning':
|
|
106
|
+
return 'pi-exclamation-triangle';
|
|
107
|
+
case 'error':
|
|
108
|
+
return 'pi-times-circle';
|
|
109
|
+
case 'success':
|
|
110
|
+
return 'pi-check';
|
|
111
|
+
default:
|
|
112
|
+
return '';
|
|
113
|
+
}
|
|
114
|
+
}
|
|
95
115
|
}
|
|
96
116
|
MngTableviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.6", ngImport: i0, type: MngTableviewComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.MessageService }, { token: i3.TranslateService }, { token: i2.ConfirmationService }, { token: i4.MngActionExecutorService }, { token: i4.MngViewContainerComponentService }], target: i0.ɵɵFactoryTarget.Component });
|
|
97
|
-
MngTableviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.6", type: MngTableviewComponent, isStandalone: true, selector: "mng-tableview", inputs: { descriptor: "descriptor", dataProvider: "dataProvider", actions: "actions" }, providers: [MessageService, ConfirmationService, MngViewContainerComponentService], queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "tableComponent", first: true, predicate: MngTableComponent, descendants: true }], ngImport: i0, template: "<div class=\"mng-tableview\">\n <p-toast></p-toast>\n\n <div class=\"card\">\n <p-toolbar styleClass=\"mb-4\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n <ng-template pTemplate=\"left\">\n <mng-action\n *ngFor=\"let action of toolbarLeftActions\"\n [action]=\"action\"\n [queryParam]=\"tableQueryParam\"\n [hostComponent]=\"this\"\n [selectedItems]=\"selectedItems\"></mng-action>\n </ng-template>\n\n <ng-template pTemplate=\"right\">\n <mng-action\n *ngFor=\"let action of toolbarRightActions\"\n [action]=\"action\"\n [queryParam]=\"tableQueryParam\"\n [hostComponent]=\"this\"\n [selectedItems]=\"selectedItems\"></mng-action>\n </ng-template>\n </p-toolbar>\n\n <mng-table\n [descriptor]=\"descriptor.table\"\n [dataProvider]=\"dataProvider\"\n [useQueryParams]=\"true\"\n [actions]=\"tableActions\"\n [selectionEnabled]=\"hasItemSelectionAction\"\n [selectionMode]=\"'multiple'\"\n (tableLoad)=\"onTableLoad($event)\"\n (selectionChange)=\"selectionChange($event)\">\n <ng-template mngTemplate=\"caption\">\n <div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n <h5 class=\"p-0 m-0\">{{ descriptor.tableTitle ?? '' | translate }}</h5>\n </div>\n </ng-template>\n\n <ng-template let-queryResult=\"queryResult\" mngTemplate=\"footer\">\n <ng-container *ngIf=\"footerTemplate\" [ngTemplateOutlet]=\"footerTemplate\" [ngTemplateOutletContext]=\"{queryResult: queryResult}\"></ng-container>\n </ng-template>\n </mng-table>\n </div>\n\n <router-outlet></router-outlet>\n</div>\n", dependencies: [{ kind: "ngmodule", type: ToastModule }, { kind: "component", type: i5.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type:
|
|
117
|
+
MngTableviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.6", type: MngTableviewComponent, isStandalone: true, selector: "mng-tableview", inputs: { descriptor: "descriptor", dataProvider: "dataProvider", actions: "actions" }, providers: [MessageService, ConfirmationService, MngViewContainerComponentService], queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "tableComponent", first: true, predicate: MngTableComponent, descendants: true }], ngImport: i0, template: "<div class=\"mng-tableview\">\n <p-toast>\n <ng-template let-message pTemplate=\"message\">\n <span [class]=\"'p-toast-message-icon pi ' + getNotificationIconClass(message)\"></span>\n <div class=\"p-toast-message-text\">\n <div class=\"p-toast-summary\">{{ message.summary }}</div>\n <div class=\"p-toast-detail\">{{ message.detail.slice(0, notificationCutoff) + (message.detail.length > notificationCutoff ? '...' : '') }}</div>\n <div *ngIf=\"message.detail.length > notificationCutoff\" (click)=\"showingNotification = message\" class=\"p-link font-semibold text-sm mt-2 flex align-items-center\">\n <i class=\"pi pi-chevron-down mr-1\"></i>{{ 'notification.details' | translate }}\n </div>\n </div>\n </ng-template>\n </p-toast>\n <p-dialog\n [(visible)]=\"showingNotification\"\n [styleClass]=\"'p-fluid mng-dialog mng-dialog-xs ' + 'mng-message-detail-dialog mng-message-detail-dialog-' + (showingNotification?.severity ?? '')\">\n <ng-template pTemplate=\"header\">\n <span class=\"p-dialog-title font-bold mng-dialog-success\">\n <span [class]=\"'mr-2 pi ' + getNotificationIconClass(showingNotification)\"></span>\n {{ showingNotification?.summary ?? '' }}\n </span>\n </ng-template>\n <div>\n {{ showingNotification?.detail ?? '' }}\n </div>\n </p-dialog>\n\n <div class=\"card\">\n <p-toolbar styleClass=\"mb-4\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n <ng-template pTemplate=\"left\">\n <mng-action\n *ngFor=\"let action of toolbarLeftActions\"\n [action]=\"action\"\n [queryParam]=\"tableQueryParam\"\n [hostComponent]=\"this\"\n [selectedItems]=\"selectedItems\"></mng-action>\n </ng-template>\n\n <ng-template pTemplate=\"right\">\n <mng-action\n *ngFor=\"let action of toolbarRightActions\"\n [action]=\"action\"\n [queryParam]=\"tableQueryParam\"\n [hostComponent]=\"this\"\n [selectedItems]=\"selectedItems\"></mng-action>\n </ng-template>\n </p-toolbar>\n\n <mng-table\n [descriptor]=\"descriptor.table\"\n [dataProvider]=\"dataProvider\"\n [useQueryParams]=\"true\"\n [actions]=\"tableActions\"\n [selectionEnabled]=\"hasItemSelectionAction\"\n [selectionMode]=\"'multiple'\"\n (tableLoad)=\"onTableLoad($event)\"\n (selectionChange)=\"selectionChange($event)\">\n <ng-template mngTemplate=\"caption\">\n <div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n <h5 class=\"p-0 m-0\">{{ descriptor.tableTitle ?? '' | translate }}</h5>\n </div>\n </ng-template>\n\n <ng-template let-queryResult=\"queryResult\" mngTemplate=\"footer\">\n <ng-container *ngIf=\"footerTemplate\" [ngTemplateOutlet]=\"footerTemplate\" [ngTemplateOutletContext]=\"{queryResult: queryResult}\"></ng-container>\n </ng-template>\n </mng-table>\n </div>\n\n <router-outlet></router-outlet>\n</div>\n", dependencies: [{ kind: "ngmodule", type: ToastModule }, { kind: "component", type: i5.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "ngmodule", type: DialogModule }, { kind: "component", type: i6.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { kind: "ngmodule", type: ToolbarModule }, { kind: "component", type: i7.Toolbar, selector: "p-toolbar", inputs: ["style", "styleClass"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: MngActionComponent, selector: "mng-action", inputs: ["action", "item", "itemId", "actionData", "queryParam", "dataProvider", "hostComponent", "route", "disabled", "loading", "viewContainer", "selectedItems"], outputs: ["finish"] }, { kind: "component", type: MngTableComponent, selector: "mng-table", inputs: ["descriptor", "items", "queryResult", "loading", "dataProvider", "useQueryParams", "selectionMode", "selectionEnabled", "actions", "isColumnClickable", "viewContainer", "captionComponent", "columnActionComponent", "columnActionMinWidth", "globalFilterFields"], outputs: ["tableLoad", "cellClick", "selectionChange", "captionComponentInstance", "columnActionComponentInstance"] }, { kind: "directive", type: MngTemplateDirective, selector: "[mngTemplate]", inputs: ["type", "mngTemplate"] }, { kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] });
|
|
98
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.6", ngImport: i0, type: MngTableviewComponent, decorators: [{
|
|
99
119
|
type: Component,
|
|
100
|
-
args: [{ standalone: true, selector: 'mng-tableview', imports: [
|
|
120
|
+
args: [{ standalone: true, selector: 'mng-tableview', imports: [
|
|
121
|
+
ToastModule,
|
|
122
|
+
DialogModule,
|
|
123
|
+
ToolbarModule,
|
|
124
|
+
NgForOf,
|
|
125
|
+
TranslateModule,
|
|
126
|
+
NgTemplateOutlet,
|
|
127
|
+
NgIf,
|
|
128
|
+
MngActionComponent,
|
|
129
|
+
MngTableComponent,
|
|
130
|
+
MngTemplateDirective,
|
|
131
|
+
RouterOutlet
|
|
132
|
+
], providers: [MessageService, ConfirmationService, MngViewContainerComponentService], template: "<div class=\"mng-tableview\">\n <p-toast>\n <ng-template let-message pTemplate=\"message\">\n <span [class]=\"'p-toast-message-icon pi ' + getNotificationIconClass(message)\"></span>\n <div class=\"p-toast-message-text\">\n <div class=\"p-toast-summary\">{{ message.summary }}</div>\n <div class=\"p-toast-detail\">{{ message.detail.slice(0, notificationCutoff) + (message.detail.length > notificationCutoff ? '...' : '') }}</div>\n <div *ngIf=\"message.detail.length > notificationCutoff\" (click)=\"showingNotification = message\" class=\"p-link font-semibold text-sm mt-2 flex align-items-center\">\n <i class=\"pi pi-chevron-down mr-1\"></i>{{ 'notification.details' | translate }}\n </div>\n </div>\n </ng-template>\n </p-toast>\n <p-dialog\n [(visible)]=\"showingNotification\"\n [styleClass]=\"'p-fluid mng-dialog mng-dialog-xs ' + 'mng-message-detail-dialog mng-message-detail-dialog-' + (showingNotification?.severity ?? '')\">\n <ng-template pTemplate=\"header\">\n <span class=\"p-dialog-title font-bold mng-dialog-success\">\n <span [class]=\"'mr-2 pi ' + getNotificationIconClass(showingNotification)\"></span>\n {{ showingNotification?.summary ?? '' }}\n </span>\n </ng-template>\n <div>\n {{ showingNotification?.detail ?? '' }}\n </div>\n </p-dialog>\n\n <div class=\"card\">\n <p-toolbar styleClass=\"mb-4\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n <ng-template pTemplate=\"left\">\n <mng-action\n *ngFor=\"let action of toolbarLeftActions\"\n [action]=\"action\"\n [queryParam]=\"tableQueryParam\"\n [hostComponent]=\"this\"\n [selectedItems]=\"selectedItems\"></mng-action>\n </ng-template>\n\n <ng-template pTemplate=\"right\">\n <mng-action\n *ngFor=\"let action of toolbarRightActions\"\n [action]=\"action\"\n [queryParam]=\"tableQueryParam\"\n [hostComponent]=\"this\"\n [selectedItems]=\"selectedItems\"></mng-action>\n </ng-template>\n </p-toolbar>\n\n <mng-table\n [descriptor]=\"descriptor.table\"\n [dataProvider]=\"dataProvider\"\n [useQueryParams]=\"true\"\n [actions]=\"tableActions\"\n [selectionEnabled]=\"hasItemSelectionAction\"\n [selectionMode]=\"'multiple'\"\n (tableLoad)=\"onTableLoad($event)\"\n (selectionChange)=\"selectionChange($event)\">\n <ng-template mngTemplate=\"caption\">\n <div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n <h5 class=\"p-0 m-0\">{{ descriptor.tableTitle ?? '' | translate }}</h5>\n </div>\n </ng-template>\n\n <ng-template let-queryResult=\"queryResult\" mngTemplate=\"footer\">\n <ng-container *ngIf=\"footerTemplate\" [ngTemplateOutlet]=\"footerTemplate\" [ngTemplateOutletContext]=\"{queryResult: queryResult}\"></ng-container>\n </ng-template>\n </mng-table>\n </div>\n\n <router-outlet></router-outlet>\n</div>\n" }]
|
|
101
133
|
}], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.MessageService }, { type: i3.TranslateService }, { type: i2.ConfirmationService }, { type: i4.MngActionExecutorService }, { type: i4.MngViewContainerComponentService }]; }, propDecorators: { descriptor: [{
|
|
102
134
|
type: Input
|
|
103
135
|
}], dataProvider: [{
|
|
@@ -111,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.6", ngImpor
|
|
|
111
143
|
type: ContentChildren,
|
|
112
144
|
args: [MngTemplateDirective]
|
|
113
145
|
}] } });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableview.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/tableview/tableview.component.ts","../../../../../src/lib/components/tableview/tableview.component.html"],"names":[],"mappings":"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","sourcesContent":["import {NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\nimport {AfterContentInit, Component, ContentChildren, Input, OnDestroy, OnInit, QueryList, TemplateRef, ViewChild} from '@angular/core';\nimport {ActivatedRoute, RouterOutlet} from '@angular/router';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {ConfirmationService, MessageService} from 'primeng/api';\nimport {ToastModule} from 'primeng/toast';\nimport {ToolbarModule} from 'primeng/toolbar';\nimport {Subscription} from 'rxjs';\n\nimport {MediusQueryParam} from '../../api/models';\nimport {IDataProvider, ITableviewDataProvider} from '../../data-providers';\nimport {ActionDescriptor} from '../../descriptors/action';\nimport {TableviewDescriptor} from '../../descriptors/tableview';\nimport {ActionPositionEnum} from '../../descriptors/types';\nimport {MngTemplateDirective} from '../../directives';\nimport {IViewContainer} from '../../models';\nimport {MngActionExecutorService, MngViewContainerComponentService} from '../../services';\nimport {MngActionComponent} from '../action';\nimport {TableviewActionDefaultCategories} from '../action/models';\nimport {MngTableLoadEvent} from './models';\nimport {MngTableComponent} from './table/table.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-tableview',\n    templateUrl: './tableview.component.html',\n    imports: [ToastModule, ToolbarModule, NgForOf, TranslateModule, NgTemplateOutlet, NgIf, MngActionComponent, MngTableComponent, MngTemplateDirective, RouterOutlet],\n    providers: [MessageService, ConfirmationService, MngViewContainerComponentService]\n})\nexport class MngTableviewComponent<T, S> implements OnInit, OnDestroy, AfterContentInit, IViewContainer<T, S> {\n    @Input() public descriptor!: TableviewDescriptor<T>;\n    @Input() public dataProvider?: ITableviewDataProvider<T, S>;\n    @Input() public actions: Array<ActionDescriptor<T>> = [];\n\n    @ViewChild(MngTableComponent) public tableComponent?: MngTableComponent<T, S>;\n\n    public tableActions: ActionDescriptor<T>[] = [];\n    public toolbarLeftActions: ActionDescriptor<T>[] = [];\n    public toolbarRightActions: ActionDescriptor<T>[] = [];\n\n    public tableQueryParam?: MediusQueryParam;\n\n    private subscriptions: Subscription[] = [];\n\n    public hasItemSelectionAction = false;\n    public selectedItems: T[] = [];\n\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    public footerTemplate?: TemplateRef<any>;\n\n    constructor(\n        private route: ActivatedRoute,\n        private messageService: MessageService,\n        private translateService: TranslateService,\n        private confirmationService: ConfirmationService,\n        private actionExecutor: MngActionExecutorService,\n        private viewContainerService: MngViewContainerComponentService<T, S>\n    ) {}\n\n    ngOnInit() {\n        this.viewContainerService.setActions(this.actions);\n\n        if (this.dataProvider) {\n            this.viewContainerService.dataProvider = this.dataProvider;\n        }\n        const reloadTableSubscription = this.viewContainerService.getTableReload$().subscribe(() => {\n            this.reloadTable();\n        });\n        this.subscriptions.push(reloadTableSubscription);\n\n        for (const action of this.actions.filter(value => value.positionTableviewCategories?.includes(TableviewActionDefaultCategories.READ) ?? true)) {\n            switch (action.position) {\n                case ActionPositionEnum.ToolbarLeft:\n                    this.toolbarLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarRight:\n                    this.toolbarRightActions.push(action);\n                    break;\n                case ActionPositionEnum.TableHeader:\n                case ActionPositionEnum.RowInline:\n                case ActionPositionEnum.RowClick:\n                    this.tableActions.push(action);\n                    break;\n            }\n        }\n\n        this.toolbarRightActions = this.toolbarRightActions.reverse();\n\n        this.hasItemSelectionAction = [...this.toolbarLeftActions, ...this.toolbarRightActions].some(e => e.hasItemsSelection);\n    }\n\n    ngAfterContentInit() {\n        this.templates.forEach(template => {\n            switch (template.getType()) {\n                case 'footer':\n                    this.footerTemplate = template.template;\n                    break;\n            }\n        });\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    getMessageService(): MessageService {\n        return this.messageService;\n    }\n\n    getDataProvider(): IDataProvider<T, S> | undefined {\n        return this.dataProvider;\n    }\n\n    getActions() {\n        return this.actions;\n    }\n\n    public reloadTable() {\n        this.tableComponent?.reload();\n    }\n\n    public onTableLoad(event: MngTableLoadEvent) {\n        this.tableQueryParam = event.queryParam;\n    }\n\n    public selectionChange(selectedItems: Array<T>): void {\n        this.selectedItems = selectedItems;\n    }\n}\n","<div class=\"mng-tableview\">\n    <p-toast></p-toast>\n\n    <div class=\"card\">\n        <p-toolbar styleClass=\"mb-4\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n            <ng-template pTemplate=\"left\">\n                <mng-action\n                    *ngFor=\"let action of toolbarLeftActions\"\n                    [action]=\"action\"\n                    [queryParam]=\"tableQueryParam\"\n                    [hostComponent]=\"this\"\n                    [selectedItems]=\"selectedItems\"></mng-action>\n            </ng-template>\n\n            <ng-template pTemplate=\"right\">\n                <mng-action\n                    *ngFor=\"let action of toolbarRightActions\"\n                    [action]=\"action\"\n                    [queryParam]=\"tableQueryParam\"\n                    [hostComponent]=\"this\"\n                    [selectedItems]=\"selectedItems\"></mng-action>\n            </ng-template>\n        </p-toolbar>\n\n        <mng-table\n            [descriptor]=\"descriptor.table\"\n            [dataProvider]=\"dataProvider\"\n            [useQueryParams]=\"true\"\n            [actions]=\"tableActions\"\n            [selectionEnabled]=\"hasItemSelectionAction\"\n            [selectionMode]=\"'multiple'\"\n            (tableLoad)=\"onTableLoad($event)\"\n            (selectionChange)=\"selectionChange($event)\">\n            <ng-template mngTemplate=\"caption\">\n                <div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n                    <h5 class=\"p-0 m-0\">{{ descriptor.tableTitle ?? '' | translate }}</h5>\n                </div>\n            </ng-template>\n\n            <ng-template let-queryResult=\"queryResult\" mngTemplate=\"footer\">\n                <ng-container *ngIf=\"footerTemplate\" [ngTemplateOutlet]=\"footerTemplate\" [ngTemplateOutletContext]=\"{queryResult: queryResult}\"></ng-container>\n            </ng-template>\n        </mng-table>\n    </div>\n\n    <router-outlet></router-outlet>\n</div>\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableview.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/tableview/tableview.component.ts","../../../../../src/lib/components/tableview/tableview.component.html"],"names":[],"mappings":"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","sourcesContent":["import {NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\nimport {AfterContentInit, Component, ContentChildren, Input, OnDestroy, OnInit, QueryList, TemplateRef, ViewChild} from '@angular/core';\nimport {ActivatedRoute, RouterOutlet} from '@angular/router';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {ConfirmationService, Message, MessageService} from 'primeng/api';\nimport {DialogModule} from 'primeng/dialog';\nimport {ToastModule} from 'primeng/toast';\nimport {ToolbarModule} from 'primeng/toolbar';\nimport {Subscription} from 'rxjs';\n\nimport {MediusQueryParam} from '../../api/models';\nimport {IDataProvider, ITableviewDataProvider} from '../../data-providers';\nimport {ActionDescriptor} from '../../descriptors/action';\nimport {TableviewDescriptor} from '../../descriptors/tableview';\nimport {ActionPositionEnum} from '../../descriptors/types';\nimport {MngTemplateDirective} from '../../directives';\nimport {IViewContainer} from '../../models';\nimport {MngActionExecutorService, MngViewContainerComponentService} from '../../services';\nimport {MngActionComponent} from '../action';\nimport {TableviewActionDefaultCategories} from '../action/models';\nimport {MngTableLoadEvent} from './models';\nimport {MngTableComponent} from './table/table.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-tableview',\n    templateUrl: './tableview.component.html',\n    imports: [\n        ToastModule,\n        DialogModule,\n        ToolbarModule,\n        NgForOf,\n        TranslateModule,\n        NgTemplateOutlet,\n        NgIf,\n        MngActionComponent,\n        MngTableComponent,\n        MngTemplateDirective,\n        RouterOutlet\n    ],\n    providers: [MessageService, ConfirmationService, MngViewContainerComponentService]\n})\nexport class MngTableviewComponent<T, S> implements OnInit, OnDestroy, AfterContentInit, IViewContainer<T, S> {\n    @Input() public descriptor!: TableviewDescriptor<T>;\n    @Input() public dataProvider?: ITableviewDataProvider<T, S>;\n    @Input() public actions: Array<ActionDescriptor<T>> = [];\n\n    @ViewChild(MngTableComponent) public tableComponent?: MngTableComponent<T, S>;\n\n    public tableActions: ActionDescriptor<T>[] = [];\n    public toolbarLeftActions: ActionDescriptor<T>[] = [];\n    public toolbarRightActions: ActionDescriptor<T>[] = [];\n\n    public tableQueryParam?: MediusQueryParam;\n\n    private subscriptions: Subscription[] = [];\n\n    public hasItemSelectionAction = false;\n    public selectedItems: T[] = [];\n\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    public footerTemplate?: TemplateRef<any>;\n\n    public showingNotification: Message | null = null;\n    public readonly notificationCutoff = 70;\n\n    constructor(\n        private route: ActivatedRoute,\n        private messageService: MessageService,\n        private translateService: TranslateService,\n        private confirmationService: ConfirmationService,\n        private actionExecutor: MngActionExecutorService,\n        private viewContainerService: MngViewContainerComponentService<T, S>\n    ) {}\n\n    ngOnInit() {\n        this.viewContainerService.setActions(this.actions);\n\n        if (this.dataProvider) {\n            this.viewContainerService.dataProvider = this.dataProvider;\n        }\n        const reloadTableSubscription = this.viewContainerService.getTableReload$().subscribe(() => {\n            this.reloadTable();\n        });\n        this.subscriptions.push(reloadTableSubscription);\n\n        for (const action of this.actions.filter(value => value.positionTableviewCategories?.includes(TableviewActionDefaultCategories.READ) ?? true)) {\n            switch (action.position) {\n                case ActionPositionEnum.ToolbarLeft:\n                    this.toolbarLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarRight:\n                    this.toolbarRightActions.push(action);\n                    break;\n                case ActionPositionEnum.TableHeader:\n                case ActionPositionEnum.RowInline:\n                case ActionPositionEnum.RowClick:\n                    this.tableActions.push(action);\n                    break;\n            }\n        }\n\n        this.toolbarRightActions = this.toolbarRightActions.reverse();\n\n        this.hasItemSelectionAction = [...this.toolbarLeftActions, ...this.toolbarRightActions].some(e => e.hasItemsSelection);\n    }\n\n    ngAfterContentInit() {\n        this.templates.forEach(template => {\n            switch (template.getType()) {\n                case 'footer':\n                    this.footerTemplate = template.template;\n                    break;\n            }\n        });\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    getMessageService(): MessageService {\n        return this.messageService;\n    }\n\n    getDataProvider(): IDataProvider<T, S> | undefined {\n        return this.dataProvider;\n    }\n\n    getActions() {\n        return this.actions;\n    }\n\n    public reloadTable() {\n        this.tableComponent?.reload();\n    }\n\n    public onTableLoad(event: MngTableLoadEvent) {\n        this.tableQueryParam = event.queryParam;\n    }\n\n    public selectionChange(selectedItems: Array<T>): void {\n        this.selectedItems = selectedItems;\n    }\n\n    public getNotificationIconClass(message: Message | null): string {\n        if (message?.icon) return message.icon;\n\n        switch (message?.severity) {\n            case 'info':\n                return 'pi-info-circle';\n            case 'warning':\n                return 'pi-exclamation-triangle';\n            case 'error':\n                return 'pi-times-circle';\n            case 'success':\n                return 'pi-check';\n            default:\n                return '';\n        }\n    }\n}\n","<div class=\"mng-tableview\">\n    <p-toast>\n        <ng-template let-message pTemplate=\"message\">\n            <span [class]=\"'p-toast-message-icon pi ' + getNotificationIconClass(message)\"></span>\n            <div class=\"p-toast-message-text\">\n                <div class=\"p-toast-summary\">{{ message.summary }}</div>\n                <div class=\"p-toast-detail\">{{ message.detail.slice(0, notificationCutoff) + (message.detail.length > notificationCutoff ? '...' : '') }}</div>\n                <div *ngIf=\"message.detail.length > notificationCutoff\" (click)=\"showingNotification = message\" class=\"p-link font-semibold text-sm mt-2 flex align-items-center\">\n                    <i class=\"pi pi-chevron-down mr-1\"></i>{{ 'notification.details' | translate }}\n                </div>\n            </div>\n        </ng-template>\n    </p-toast>\n    <p-dialog\n        [(visible)]=\"showingNotification\"\n        [styleClass]=\"'p-fluid mng-dialog mng-dialog-xs ' + 'mng-message-detail-dialog mng-message-detail-dialog-' + (showingNotification?.severity ?? '')\">\n        <ng-template pTemplate=\"header\">\n            <span class=\"p-dialog-title font-bold mng-dialog-success\">\n                <span [class]=\"'mr-2 pi ' + getNotificationIconClass(showingNotification)\"></span>\n                {{ showingNotification?.summary ?? '' }}\n            </span>\n        </ng-template>\n        <div>\n            {{ showingNotification?.detail ?? '' }}\n        </div>\n    </p-dialog>\n\n    <div class=\"card\">\n        <p-toolbar styleClass=\"mb-4\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n            <ng-template pTemplate=\"left\">\n                <mng-action\n                    *ngFor=\"let action of toolbarLeftActions\"\n                    [action]=\"action\"\n                    [queryParam]=\"tableQueryParam\"\n                    [hostComponent]=\"this\"\n                    [selectedItems]=\"selectedItems\"></mng-action>\n            </ng-template>\n\n            <ng-template pTemplate=\"right\">\n                <mng-action\n                    *ngFor=\"let action of toolbarRightActions\"\n                    [action]=\"action\"\n                    [queryParam]=\"tableQueryParam\"\n                    [hostComponent]=\"this\"\n                    [selectedItems]=\"selectedItems\"></mng-action>\n            </ng-template>\n        </p-toolbar>\n\n        <mng-table\n            [descriptor]=\"descriptor.table\"\n            [dataProvider]=\"dataProvider\"\n            [useQueryParams]=\"true\"\n            [actions]=\"tableActions\"\n            [selectionEnabled]=\"hasItemSelectionAction\"\n            [selectionMode]=\"'multiple'\"\n            (tableLoad)=\"onTableLoad($event)\"\n            (selectionChange)=\"selectionChange($event)\">\n            <ng-template mngTemplate=\"caption\">\n                <div class=\"flex flex-column md:flex-row md:justify-content-between table-header\">\n                    <h5 class=\"p-0 m-0\">{{ descriptor.tableTitle ?? '' | translate }}</h5>\n                </div>\n            </ng-template>\n\n            <ng-template let-queryResult=\"queryResult\" mngTemplate=\"footer\">\n                <ng-container *ngIf=\"footerTemplate\" [ngTemplateOutlet]=\"footerTemplate\" [ngTemplateOutletContext]=\"{queryResult: queryResult}\"></ng-container>\n            </ng-template>\n        </mng-table>\n    </div>\n\n    <router-outlet></router-outlet>\n</div>\n"]}
|
|
@@ -51,10 +51,10 @@ export class ActionButtonDescriptor {
|
|
|
51
51
|
descriptor._label = this._label;
|
|
52
52
|
descriptor._icon = this._icon;
|
|
53
53
|
descriptor._iconPosition = this._iconPosition;
|
|
54
|
-
descriptor._styleClass = this._styleClass;
|
|
54
|
+
descriptor._styleClass = this._styleClass.copy();
|
|
55
55
|
descriptor._badge = this._badge;
|
|
56
56
|
descriptor._tooltip = this._tooltip;
|
|
57
57
|
return descriptor;
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWJ1dHRvbi5kZXNjcmlwdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9kZXNjcmlwdG9ycy9hY3Rpb24vYWN0aW9uLWJ1dHRvbi5kZXNjcmlwdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLGNBQWMsQ0FBQztBQUVoRCxNQUFNLE9BQU8sc0JBQXNCO0lBQW5DO1FBSVksa0JBQWEsR0FBcUIsTUFBTSxDQUFDO1FBRXpDLGdCQUFXLEdBQUcsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO0lBcUVuRCxDQUFDO0lBaEVVLFNBQVMsQ0FBQyxLQUFxQjtRQUNsQyxJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztRQUNwQixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRU0sUUFBUSxDQUFDLElBQW1CO1FBQy9CLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxZQUE4QjtRQUNsRCxJQUFJLENBQUMsYUFBYSxHQUFHLFlBQVksQ0FBQztRQUNsQyxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRU0sY0FBYyxDQUFDLEtBQXlCO1FBQzNDLElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDO1FBQ3pCLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFTSxTQUFTLENBQUMsS0FBYTtRQUMxQixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztRQUNwQixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRU0sV0FBVyxDQUFDLE9BQWU7UUFDOUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxPQUFPLENBQUM7UUFDeEIsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUVELElBQVcsS0FBSztRQUNaLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBRUQsSUFBVyxJQUFJO1FBQ1gsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDbkIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUFXLFVBQVU7UUFDakIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFXLEtBQUs7UUFDWixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQVcsT0FBTztRQUNkLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBRU0sSUFBSTtRQUNQLE1BQU0sVUFBVSxHQUFHLElBQUksc0JBQXNCLEVBQUUsQ0FBQztRQUNoRCxVQUFVLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDaEMsVUFBVSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBQzlCLFVBQVUsQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQztRQUM5QyxVQUFVLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDakQsVUFBVSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQ2hDLFVBQVUsQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUNwQyxPQUFPLFVBQVUsQ0FBQztJQUN0QixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0J1dHRvblN0eWxlQnVpbGRlcn0gZnJvbSAnLi4vLi4vc3R5bGVzJztcblxuZXhwb3J0IGNsYXNzIEFjdGlvbkJ1dHRvbkRlc2NyaXB0b3Ige1xuICAgIHByaXZhdGUgX2xhYmVsPzogc3RyaW5nIHwgbnVsbDtcblxuICAgIHByaXZhdGUgX2ljb24/OiBzdHJpbmcgfCBudWxsO1xuICAgIHByaXZhdGUgX2ljb25Qb3NpdGlvbjogJ2xlZnQnIHwgJ3JpZ2h0JyA9ICdsZWZ0JztcblxuICAgIHByaXZhdGUgX3N0eWxlQ2xhc3MgPSBuZXcgQnV0dG9uU3R5bGVCdWlsZGVyKCk7XG5cbiAgICBwcml2YXRlIF9iYWRnZT86IHN0cmluZztcbiAgICBwcml2YXRlIF90b29sdGlwPzogc3RyaW5nO1xuXG4gICAgcHVibGljIHdpdGhMYWJlbChsYWJlbD86IHN0cmluZyB8IG51bGwpOiB0aGlzIHtcbiAgICAgICAgdGhpcy5fbGFiZWwgPSBsYWJlbDtcbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgcHVibGljIHdpdGhJY29uKGljb246IHN0cmluZyB8IG51bGwpOiB0aGlzIHtcbiAgICAgICAgdGhpcy5faWNvbiA9IGljb247XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHB1YmxpYyB3aXRoSWNvblBvc2l0aW9uKGljb25Qb3NpdGlvbjogJ2xlZnQnIHwgJ3JpZ2h0Jyk6IHRoaXMge1xuICAgICAgICB0aGlzLl9pY29uUG9zaXRpb24gPSBpY29uUG9zaXRpb247XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHB1YmxpYyB3aXRoU3R5bGVDbGFzcyhzdHlsZTogQnV0dG9uU3R5bGVCdWlsZGVyKTogdGhpcyB7XG4gICAgICAgIHRoaXMuX3N0eWxlQ2xhc3MgPSBzdHlsZTtcbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgcHVibGljIHdpdGhCYWRnZShiYWRnZTogc3RyaW5nKTogdGhpcyB7XG4gICAgICAgIHRoaXMuX2JhZGdlID0gYmFkZ2U7XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHB1YmxpYyB3aXRoVG9vbHRpcCh0b29sdGlwOiBzdHJpbmcpOiB0aGlzIHtcbiAgICAgICAgdGhpcy5fdG9vbHRpcCA9IHRvb2x0aXA7XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgbGFiZWwoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9sYWJlbDtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGljb24oKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9pY29uO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgaWNvblBvc2l0aW9uKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5faWNvblBvc2l0aW9uO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgc3R5bGVDbGFzcygpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX3N0eWxlQ2xhc3M7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBiYWRnZSgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2JhZGdlO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgdG9vbHRpcCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX3Rvb2x0aXA7XG4gICAgfVxuXG4gICAgcHVibGljIGNvcHkoKTogQWN0aW9uQnV0dG9uRGVzY3JpcHRvciB7XG4gICAgICAgIGNvbnN0IGRlc2NyaXB0b3IgPSBuZXcgQWN0aW9uQnV0dG9uRGVzY3JpcHRvcigpO1xuICAgICAgICBkZXNjcmlwdG9yLl9sYWJlbCA9IHRoaXMuX2xhYmVsO1xuICAgICAgICBkZXNjcmlwdG9yLl9pY29uID0gdGhpcy5faWNvbjtcbiAgICAgICAgZGVzY3JpcHRvci5faWNvblBvc2l0aW9uID0gdGhpcy5faWNvblBvc2l0aW9uO1xuICAgICAgICBkZXNjcmlwdG9yLl9zdHlsZUNsYXNzID0gdGhpcy5fc3R5bGVDbGFzcy5jb3B5KCk7XG4gICAgICAgIGRlc2NyaXB0b3IuX2JhZGdlID0gdGhpcy5fYmFkZ2U7XG4gICAgICAgIGRlc2NyaXB0b3IuX3Rvb2x0aXAgPSB0aGlzLl90b29sdGlwO1xuICAgICAgICByZXR1cm4gZGVzY3JpcHRvcjtcbiAgICB9XG59XG4iXX0=
|