@mediusinc/mng-commons 0.12.2 → 0.13.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.
Files changed (56) hide show
  1. package/esm2020/lib/components/action/action.component.mjs +8 -8
  2. package/esm2020/lib/components/action/editor/action-editor.component.mjs +5 -5
  3. package/esm2020/lib/components/button/button.component.mjs +46 -0
  4. package/esm2020/lib/components/button/index.mjs +2 -0
  5. package/esm2020/lib/components/form/dropdown/dropdown.component.mjs +8 -3
  6. package/esm2020/lib/components/form/editor/form-editor.component.mjs +3 -2
  7. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +10 -13
  8. package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +27 -11
  9. package/esm2020/lib/components/tableview/table/column-value/column-value.component.mjs +5 -3
  10. package/esm2020/lib/data-providers/index.mjs +2 -1
  11. package/esm2020/lib/data-providers/tableview-crud.data-provider.mjs +24 -0
  12. package/esm2020/lib/descriptors/action/action-confirmation.descriptor.mjs +106 -0
  13. package/esm2020/lib/descriptors/action.descriptor.mjs +53 -154
  14. package/esm2020/lib/descriptors/button.descriptor.mjs +111 -0
  15. package/esm2020/lib/descriptors/column.descriptor.mjs +17 -1
  16. package/esm2020/lib/descriptors/field.descriptor.mjs +1 -1
  17. package/esm2020/lib/descriptors/index.mjs +3 -1
  18. package/esm2020/lib/mng-commons.module.mjs +24 -9
  19. package/esm2020/lib/pipes/getter.pipe.mjs +20 -0
  20. package/esm2020/lib/pipes/index.mjs +4 -2
  21. package/esm2020/lib/pipes/json-path.pipe.mjs +1 -2
  22. package/esm2020/lib/pipes/parametrize.pipe.mjs +85 -0
  23. package/esm2020/lib/pipes/template.pipe.mjs +24 -0
  24. package/esm2020/lib/services/action-executor.service.mjs +34 -23
  25. package/esm2020/lib/styles/button-style.builder.mjs +59 -8
  26. package/esm2020/lib/styles/styles.util.mjs +2 -2
  27. package/esm2020/lib/utils/string.util.mjs +4 -1
  28. package/esm2020/public-api.mjs +2 -1
  29. package/fesm2015/mediusinc-mng-commons.mjs +627 -266
  30. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  31. package/fesm2020/mediusinc-mng-commons.mjs +628 -262
  32. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  33. package/lib/components/button/button.component.d.ts +16 -0
  34. package/lib/components/button/index.d.ts +1 -0
  35. package/lib/components/form/dropdown/dropdown.component.d.ts +2 -0
  36. package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +1 -0
  37. package/lib/data-providers/index.d.ts +1 -0
  38. package/lib/data-providers/tableview-crud.data-provider.d.ts +8 -0
  39. package/lib/descriptors/action/action-confirmation.descriptor.d.ts +48 -0
  40. package/lib/descriptors/action.descriptor.d.ts +26 -83
  41. package/lib/descriptors/button.descriptor.d.ts +40 -0
  42. package/lib/descriptors/column.descriptor.d.ts +6 -0
  43. package/lib/descriptors/field.descriptor.d.ts +9 -9
  44. package/lib/descriptors/index.d.ts +2 -0
  45. package/lib/mng-commons.module.d.ts +74 -71
  46. package/lib/pipes/getter.pipe.d.ts +7 -0
  47. package/lib/pipes/index.d.ts +3 -1
  48. package/lib/pipes/parametrize.pipe.d.ts +13 -0
  49. package/lib/pipes/template.pipe.d.ts +10 -0
  50. package/lib/services/action-executor.service.d.ts +3 -3
  51. package/lib/styles/button-style.builder.d.ts +43 -2
  52. package/package.json +3 -3
  53. package/public-api.d.ts +1 -0
  54. package/version-info.json +5 -5
  55. package/esm2020/lib/pipes/link-formatter.pipe.mjs +0 -39
  56. package/lib/pipes/link-formatter.pipe.d.ts +0 -11
@@ -1,9 +1,11 @@
1
1
  import { Directive } from '@angular/core';
2
2
  import * as FileSaver from 'file-saver';
3
+ import { of } from 'rxjs';
3
4
  import { map } from 'rxjs/operators';
4
5
  import { MediusQueryParamBuilder } from '../../../api/models/builders/query-param.builder';
5
6
  import { ActionDeleteDescriptor, ActionDescriptor, ActionEditorAddDescriptor, ActionEditorDetailsDescriptor, ActionEditorEditDescriptor } from '../../../descriptors';
6
- import { ActionPositionEnum } from '../../../descriptors/types';
7
+ import { ActionLevelEnum, ActionPositionEnum } from '../../../descriptors/types';
8
+ import { Permissions } from '../../../security/model';
7
9
  import { ActionDataProviderUtil } from '../../../utils';
8
10
  import * as i0 from "@angular/core";
9
11
  export class AMngTableviewRouteComponent {
@@ -13,13 +15,14 @@ export class AMngTableviewRouteComponent {
13
15
  this.actions = this.createActionDescriptors();
14
16
  }
15
17
  createActionDescriptors() {
16
- const actions = [];
17
- actions.push(this.createActionDescriptorForDetails());
18
- actions.push(this.createActionDescriptorForAdd());
19
- actions.push(this.createActionDescriptorForEdit());
20
- actions.push(this.createActionDescriptorForDelete());
21
- actions.push(this.createActionDescriptorForExport());
22
- return actions;
18
+ return [
19
+ this.createActionDescriptorForDetails(),
20
+ this.createActionDescriptorForAdd(),
21
+ this.createActionDescriptorForEdit(),
22
+ this.createActionDescriptorForDelete(),
23
+ this.createActionDescriptorForRefresh(),
24
+ this.createActionDescriptorForExport()
25
+ ];
23
26
  }
24
27
  createActionDescriptorForDetails(descriptor = this.descriptor.viewEditor) {
25
28
  return new ActionEditorDetailsDescriptor(descriptor);
@@ -34,7 +37,7 @@ export class AMngTableviewRouteComponent {
34
37
  return new ActionDeleteDescriptor(descriptor);
35
38
  }
36
39
  createActionDescriptorForExport(descriptor = this.descriptor.model) {
37
- return new ActionDescriptor(descriptor, 'export')
40
+ const action = new ActionDescriptor(descriptor, 'export')
38
41
  .withRunFunction(ctx => {
39
42
  const queryParamBuilder = ctx.parameters.queryParam ? MediusQueryParamBuilder.createFromExisting(ctx.parameters.queryParam) : MediusQueryParamBuilder.create();
40
43
  queryParamBuilder.withItemsOffset(0).withItemsPerPage(1000);
@@ -46,8 +49,21 @@ export class AMngTableviewRouteComponent {
46
49
  return undefined;
47
50
  }));
48
51
  })
52
+ .withPosition(ActionPositionEnum.ToolbarRight);
53
+ action.buttonDescriptor.withIcon('pi pi-upload');
54
+ return action;
55
+ }
56
+ createActionDescriptorForRefresh(descriptor = this.descriptor.model) {
57
+ const action = new ActionDescriptor(descriptor, 'refresh')
49
58
  .withPosition(ActionPositionEnum.ToolbarRight)
50
- .withIcon('pi pi-upload');
59
+ .withPermissionsRouteType(Permissions.ActionTypes.READ)
60
+ .withRunNotificationSuccess(undefined, undefined, false)
61
+ .withRunFunction(ctx => {
62
+ ctx.parameters.viewContainer.triggerTableReload({});
63
+ return of(null);
64
+ });
65
+ action.buttonDescriptor.withIcon('pi pi-refresh').styleClass.withActionLevel(ActionLevelEnum.Secondary);
66
+ return action;
51
67
  }
52
68
  }
53
69
  AMngTableviewRouteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AMngTableviewRouteComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
@@ -55,4 +71,4 @@ AMngTableviewRouteComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.
55
71
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AMngTableviewRouteComponent, decorators: [{
56
72
  type: Directive
57
73
  }] });
58
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableview-route.abstract.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/tableview/route/tableview-route.abstract.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, OnInit} from '@angular/core';\n\nimport * as FileSaver from 'file-saver';\nimport {map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models/builders/query-param.builder';\nimport {ITableviewDataProvider} from '../../../data-providers';\nimport {\n    ActionDeleteDescriptor,\n    ActionDescriptor,\n    ActionEditorAddDescriptor,\n    ActionEditorDetailsDescriptor,\n    ActionEditorEditDescriptor,\n    EditorDescriptor,\n    ModelDescriptor,\n    TableviewDescriptor\n} from '../../../descriptors';\nimport {ActionPositionEnum} from '../../../descriptors/types';\nimport {ActionDataProviderUtil} from '../../../utils';\n\n@Directive()\nexport abstract class AMngTableviewRouteComponent<T, S> implements OnInit {\n    public descriptor!: TableviewDescriptor<T>;\n    public dataProvider!: ITableviewDataProvider<T, S>;\n    public actions!: Array<ActionDescriptor<T>>;\n\n    public ngOnInit() {\n        this.descriptor = this.createTableviewDescriptor();\n        this.dataProvider = this.createTableviewDataProvider();\n        this.actions = this.createActionDescriptors();\n    }\n\n    protected abstract createTableviewDescriptor(): TableviewDescriptor<T>;\n\n    protected abstract createTableviewDataProvider(): ITableviewDataProvider<T, S>;\n\n    protected createActionDescriptors(): Array<ActionDescriptor<T>> {\n        const actions: Array<ActionDescriptor<T>> = [];\n        actions.push(this.createActionDescriptorForDetails());\n        actions.push(this.createActionDescriptorForAdd());\n        actions.push(this.createActionDescriptorForEdit());\n        actions.push(this.createActionDescriptorForDelete());\n        actions.push(this.createActionDescriptorForExport());\n        return actions;\n    }\n\n    protected createActionDescriptorForDetails(descriptor: EditorDescriptor<T> = this.descriptor.viewEditor): ActionEditorDetailsDescriptor<T> {\n        return new ActionEditorDetailsDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForAdd(descriptor: EditorDescriptor<T> = this.descriptor.addEditor): ActionEditorAddDescriptor<T> {\n        return new ActionEditorAddDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForEdit(descriptor: EditorDescriptor<T> = this.descriptor.editEditor): ActionEditorEditDescriptor<T> {\n        return new ActionEditorEditDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForDelete(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDeleteDescriptor<T> {\n        return new ActionDeleteDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForExport(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> {\n        return new ActionDescriptor(descriptor, 'export')\n            .withRunFunction(ctx => {\n                const queryParamBuilder = ctx.parameters.queryParam ? MediusQueryParamBuilder.createFromExisting(ctx.parameters.queryParam) : MediusQueryParamBuilder.create();\n                queryParamBuilder.withItemsOffset(0).withItemsPerPage(1000);\n                ctx.parameters.withQueryParam(queryParamBuilder.build());\n                return ActionDataProviderUtil.runGetAllOrFail(ctx).pipe(\n                    map(res => {\n                        const blob = new Blob([JSON.stringify(res.pageData, undefined, 4)], {type: 'application/json;charset=utf-8'});\n                        const typeName = ctx.instance.action.model?.typeName ?? '';\n                        FileSaver.saveAs(blob, `${typeName ? typeName + '_' : ''}${ctx.instance.action.actionName}.json`);\n                        return undefined;\n                    })\n                );\n            })\n            .withPosition(ActionPositionEnum.ToolbarRight)\n            .withIcon('pi pi-upload');\n    }\n}\n"]}
74
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableview-route.abstract.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/tableview/route/tableview-route.abstract.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, OnInit} from '@angular/core';\n\nimport * as FileSaver from 'file-saver';\nimport {of} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models/builders/query-param.builder';\nimport {ITableviewDataProvider} from '../../../data-providers';\nimport {\n    ActionDeleteDescriptor,\n    ActionDescriptor,\n    ActionEditorAddDescriptor,\n    ActionEditorDetailsDescriptor,\n    ActionEditorEditDescriptor,\n    EditorDescriptor,\n    ModelDescriptor,\n    TableviewDescriptor\n} from '../../../descriptors';\nimport {ActionLevelEnum, ActionPositionEnum} from '../../../descriptors/types';\nimport {Permissions} from '../../../security/model';\nimport {MngViewContainerComponentService} from '../../../services';\nimport {ActionDataProviderUtil} from '../../../utils';\n\n@Directive()\nexport abstract class AMngTableviewRouteComponent<T, S> implements OnInit {\n    public descriptor!: TableviewDescriptor<T>;\n    public dataProvider!: ITableviewDataProvider<T, S>;\n    public actions!: Array<ActionDescriptor<T>>;\n\n    public ngOnInit() {\n        this.descriptor = this.createTableviewDescriptor();\n        this.dataProvider = this.createTableviewDataProvider();\n        this.actions = this.createActionDescriptors();\n    }\n\n    protected abstract createTableviewDescriptor(): TableviewDescriptor<T>;\n\n    protected abstract createTableviewDataProvider(): ITableviewDataProvider<T, S>;\n\n    protected createActionDescriptors(): Array<ActionDescriptor<T>> {\n        return [\n            this.createActionDescriptorForDetails(),\n            this.createActionDescriptorForAdd(),\n            this.createActionDescriptorForEdit(),\n            this.createActionDescriptorForDelete(),\n            this.createActionDescriptorForRefresh(),\n            this.createActionDescriptorForExport()\n        ];\n    }\n\n    protected createActionDescriptorForDetails(descriptor: EditorDescriptor<T> = this.descriptor.viewEditor): ActionEditorDetailsDescriptor<T> {\n        return new ActionEditorDetailsDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForAdd(descriptor: EditorDescriptor<T> = this.descriptor.addEditor): ActionEditorAddDescriptor<T> {\n        return new ActionEditorAddDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForEdit(descriptor: EditorDescriptor<T> = this.descriptor.editEditor): ActionEditorEditDescriptor<T> {\n        return new ActionEditorEditDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForDelete(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDeleteDescriptor<T> {\n        return new ActionDeleteDescriptor(descriptor);\n    }\n\n    protected createActionDescriptorForExport(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> {\n        const action = new ActionDescriptor(descriptor, 'export')\n            .withRunFunction(ctx => {\n                const queryParamBuilder = ctx.parameters.queryParam ? MediusQueryParamBuilder.createFromExisting(ctx.parameters.queryParam) : MediusQueryParamBuilder.create();\n                queryParamBuilder.withItemsOffset(0).withItemsPerPage(1000);\n                ctx.parameters.withQueryParam(queryParamBuilder.build());\n                return ActionDataProviderUtil.runGetAllOrFail(ctx).pipe(\n                    map(res => {\n                        const blob = new Blob([JSON.stringify(res.pageData, undefined, 4)], {type: 'application/json;charset=utf-8'});\n                        const typeName = ctx.instance.action.model?.typeName ?? '';\n                        FileSaver.saveAs(blob, `${typeName ? typeName + '_' : ''}${ctx.instance.action.actionName}.json`);\n                        return undefined;\n                    })\n                );\n            })\n            .withPosition(ActionPositionEnum.ToolbarRight);\n        action.buttonDescriptor.withIcon('pi pi-upload');\n        return action;\n    }\n\n    protected createActionDescriptorForRefresh(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> {\n        const action = new ActionDescriptor<T>(descriptor, 'refresh')\n            .withPosition(ActionPositionEnum.ToolbarRight)\n            .withPermissionsRouteType(Permissions.ActionTypes.READ)\n            .withRunNotificationSuccess(undefined, undefined, false)\n            .withRunFunction(ctx => {\n                (ctx.parameters.viewContainer as MngViewContainerComponentService<T, any>).triggerTableReload({});\n                return of(null);\n            });\n        action.buttonDescriptor.withIcon('pi pi-refresh').styleClass.withActionLevel(ActionLevelEnum.Secondary);\n        return action;\n    }\n}\n"]}
@@ -10,6 +10,8 @@ import * as i6 from "../../../../directives/component.directive";
10
10
  import * as i7 from "../../../../pipes/json-path.pipe";
11
11
  import * as i8 from "../../../../pipes/enum.pipe";
12
12
  import * as i9 from "../../../../pipes/boolean.pipe";
13
+ import * as i10 from "../../../../pipes/getter.pipe";
14
+ import * as i11 from "../../../../pipes/template.pipe";
13
15
  export class MngTableColumnValueComponent {
14
16
  constructor(elementRef, messageService, translate) {
15
17
  this.elementRef = elementRef;
@@ -53,10 +55,10 @@ export class MngTableColumnValueComponent {
53
55
  }
54
56
  }
55
57
  MngTableColumnValueComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnValueComponent, deps: [{ token: i0.ElementRef }, { token: i1.MessageService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
56
- MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnValueComponent, 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.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ item | jsonPath: jsonPath }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ item | jsonPath: jsonPath | number: descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCurrency\">\n {{ item | jsonPath: jsonPath | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ item | jsonPath: jsonPath | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\"></ng-container>\n <i [class]=\"item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n <ng-template #booleanText>\n {{ item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{ item | jsonPath: jsonPath | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCustom\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: item | jsonPath: jsonPath,\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}:host:hover .help-buttons{display:block}.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: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i5.Ripple, selector: "[pRipple]" }, { kind: "directive", type: i6.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }, { kind: "pipe", type: i3.DecimalPipe, name: "number" }, { kind: "pipe", type: i3.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i3.DatePipe, name: "date" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.JsonPathPipe, name: "jsonPath" }, { kind: "pipe", type: i8.MngEnumPipe, name: "enum" }, { kind: "pipe", type: i9.MngBooleanPipe, name: "boolean" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
58
+ MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnValueComponent, 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.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ item | jsonPath: jsonPath | getter: descriptor.getter | template: descriptor.template }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ item | jsonPath: jsonPath | number: descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCurrency\">\n {{ item | jsonPath: jsonPath | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ item | jsonPath: jsonPath | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\"></ng-container>\n <i [class]=\"item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n <ng-template #booleanText>\n {{ item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{ item | jsonPath: jsonPath | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCustom\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: item | jsonPath: jsonPath,\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}:host:hover .help-buttons{display:block}.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: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i5.Ripple, selector: "[pRipple]" }, { kind: "directive", type: i6.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }, { kind: "pipe", type: i3.DecimalPipe, name: "number" }, { kind: "pipe", type: i3.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i3.DatePipe, name: "date" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.JsonPathPipe, name: "jsonPath" }, { kind: "pipe", type: i8.MngEnumPipe, name: "enum" }, { kind: "pipe", type: i9.MngBooleanPipe, name: "boolean" }, { kind: "pipe", type: i10.MngGetterPipe, name: "getter" }, { kind: "pipe", type: i11.MngTemplatePipe, name: "template" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
57
59
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnValueComponent, decorators: [{
58
60
  type: Component,
59
- args: [{ selector: 'mng-table-column-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ item | jsonPath: jsonPath }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ item | jsonPath: jsonPath | number: descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCurrency\">\n {{ item | jsonPath: jsonPath | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ item | jsonPath: jsonPath | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\"></ng-container>\n <i [class]=\"item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n <ng-template #booleanText>\n {{ item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{ item | jsonPath: jsonPath | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCustom\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: item | jsonPath: jsonPath,\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}:host:hover .help-buttons{display:block}.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"] }]
61
+ args: [{ selector: 'mng-table-column-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ item | jsonPath: jsonPath | getter: descriptor.getter | template: descriptor.template }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ item | jsonPath: jsonPath | number: descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCurrency\">\n {{ item | jsonPath: jsonPath | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ item | jsonPath: jsonPath | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\"></ng-container>\n <i [class]=\"item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n <ng-template #booleanText>\n {{ item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{ item | jsonPath: jsonPath | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeCustom\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: item | jsonPath: jsonPath,\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}:host:hover .help-buttons{display:block}.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"] }]
60
62
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.MessageService }, { type: i2.TranslateService }]; }, propDecorators: { descriptor: [{
61
63
  type: Input
62
64
  }], item: [{
@@ -68,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
68
70
  type: HostBinding,
69
71
  args: ['class']
70
72
  }] } });
71
- //# 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":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAc,WAAW,EAAE,KAAK,EAAS,MAAM,eAAe,CAAC;AAMzG,OAAO,EAAC,cAAc,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;;;AAQ7D,MAAM,OAAO,4BAA4B;IAmBrC,YAAoB,UAAsB,EAAU,cAA8B,EAAU,SAA2B;QAAnG,eAAU,GAAV,UAAU,CAAY;QAAU,mBAAc,GAAd,cAAc,CAAgB;QAAU,cAAS,GAAT,SAAS,CAAkB;QAlBvG,qBAAgB,GAAmB,cAAc,CAAC,MAAM,CAAC;QACzD,qBAAgB,GAAmB,cAAc,CAAC,MAAM,CAAC;QACzD,uBAAkB,GAAmB,cAAc,CAAC,QAAQ,CAAC;QAC7D,sBAAiB,GAAmB,cAAc,CAAC,OAAO,CAAC;QAC3D,mBAAc,GAAmB,cAAc,CAAC,IAAI,CAAC;QACrD,mBAAc,GAAmB,cAAc,CAAC,IAAI,CAAC;QACrD,qBAAgB,GAAmB,cAAc,CAAC,MAAM,CAAC;QAK/B,kBAAa,GAAkB,IAAI,CAAC;QACjD,cAAS,GAAG,QAAQ,CAAC;QAI3C,aAAQ,GAAG,GAAG,CAAC;IAEoG,CAAC;IAEpH,QAAQ;QACX,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,KAAK,cAAc,CAAC,QAAQ,EAAE;YACxD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,IAAI,KAAK,CAAC;SAClJ;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;SACjD;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;SAC5C;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,KAAK,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;YAChD,IAAI,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE;gBACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,IAAI,CAAC,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;aAC1F;SACJ;IACL,CAAC;IAEM,eAAe,CAAC,KAAY;QAC/B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QAC7D,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,gCAAgC,CAAC,CAAC;QACvE,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,kCAAkC,EAAE,EAAC,KAAK,EAAC,CAAC,CAAC;QACpF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAC,CAAC,CAAC;IACjF,CAAC;;yHA/CQ,4BAA4B;6GAA5B,4BAA4B,mNCdzC,06DAoCA;2FDtBa,4BAA4B;kBANxC,SAAS;+BACI,wBAAwB,mBAGjB,uBAAuB,CAAC,MAAM;6JAWtC,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEoC,aAAa;sBAAtD,WAAW;uBAAC,oBAAoB;gBACJ,SAAS;sBAArC,WAAW;uBAAC,OAAO","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, OnInit} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {MessageService} from 'primeng/api';\n\nimport {ColumnDescriptor} from '../../../../descriptors';\nimport {ColumnTypeEnum} from '../../../../descriptors/types';\n\n@Component({\n    selector: 'mng-table-column-value',\n    templateUrl: './column-value.component.html',\n    styleUrls: ['./column-value.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTableColumnValueComponent<T, TT> implements OnInit {\n    public readonly columnTypeString: ColumnTypeEnum = ColumnTypeEnum.String;\n    public readonly columnTypeNumber: ColumnTypeEnum = ColumnTypeEnum.Number;\n    public readonly columnTypeCurrency: ColumnTypeEnum = ColumnTypeEnum.Currency;\n    public readonly columnTypeBoolean: ColumnTypeEnum = ColumnTypeEnum.Boolean;\n    public readonly columnTypeDate: ColumnTypeEnum = ColumnTypeEnum.Date;\n    public readonly columnTypeEnum: ColumnTypeEnum = ColumnTypeEnum.Enum;\n    public readonly columnTypeCustom: ColumnTypeEnum = ColumnTypeEnum.Custom;\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    constructor(private elementRef: ElementRef, private messageService: MessageService, private translate: TranslateService) {}\n\n    public ngOnInit() {\n        if (this.descriptor.columnType === ColumnTypeEnum.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\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.columnType\">\n    <ng-container *ngSwitchCase=\"columnTypeString\">\n        {{ item | jsonPath: jsonPath }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeNumber\">\n        {{ item | jsonPath: jsonPath | number: descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeCurrency\">\n        {{ item | jsonPath: jsonPath | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeDate\">\n        {{ item | jsonPath: jsonPath | date: descriptor.displayFormat }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n        <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\"></ng-container>\n        <i [class]=\"item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n        <ng-template #booleanText>\n            {{ item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n        </ng-template>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeEnum\">\n        {{ item | jsonPath: jsonPath | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeCustom\">\n        <ng-container\n            [mngComponent]=\"descriptor.customComponentType!\"\n            [inputs]=\"{\n                value: item | jsonPath: jsonPath,\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"]}
73
+ //# 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":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAc,WAAW,EAAE,KAAK,EAAS,MAAM,eAAe,CAAC;AAMzG,OAAO,EAAC,cAAc,EAAC,MAAM,+BAA+B,CAAC;;;;;;;;;;;;;AAQ7D,MAAM,OAAO,4BAA4B;IAmBrC,YAAoB,UAAsB,EAAU,cAA8B,EAAU,SAA2B;QAAnG,eAAU,GAAV,UAAU,CAAY;QAAU,mBAAc,GAAd,cAAc,CAAgB;QAAU,cAAS,GAAT,SAAS,CAAkB;QAlBvG,qBAAgB,GAAmB,cAAc,CAAC,MAAM,CAAC;QACzD,qBAAgB,GAAmB,cAAc,CAAC,MAAM,CAAC;QACzD,uBAAkB,GAAmB,cAAc,CAAC,QAAQ,CAAC;QAC7D,sBAAiB,GAAmB,cAAc,CAAC,OAAO,CAAC;QAC3D,mBAAc,GAAmB,cAAc,CAAC,IAAI,CAAC;QACrD,mBAAc,GAAmB,cAAc,CAAC,IAAI,CAAC;QACrD,qBAAgB,GAAmB,cAAc,CAAC,MAAM,CAAC;QAK/B,kBAAa,GAAkB,IAAI,CAAC;QACjD,cAAS,GAAG,QAAQ,CAAC;QAI3C,aAAQ,GAAG,GAAG,CAAC;IAEoG,CAAC;IAEpH,QAAQ;QACX,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,KAAK,cAAc,CAAC,QAAQ,EAAE;YACxD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,IAAI,KAAK,CAAC;SAClJ;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;SACjD;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;SAC5C;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,KAAK,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;YAChD,IAAI,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE;gBACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,IAAI,CAAC,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;aAC1F;SACJ;IACL,CAAC;IAEM,eAAe,CAAC,KAAY;QAC/B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QAC7D,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,gCAAgC,CAAC,CAAC;QACvE,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,kCAAkC,EAAE,EAAC,KAAK,EAAC,CAAC,CAAC;QACpF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAC,CAAC,CAAC;IACjF,CAAC;;yHA/CQ,4BAA4B;6GAA5B,4BAA4B,mNCdzC,s+DAoCA;2FDtBa,4BAA4B;kBANxC,SAAS;+BACI,wBAAwB,mBAGjB,uBAAuB,CAAC,MAAM;6JAWtC,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEoC,aAAa;sBAAtD,WAAW;uBAAC,oBAAoB;gBACJ,SAAS;sBAArC,WAAW;uBAAC,OAAO","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, OnInit} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {MessageService} from 'primeng/api';\n\nimport {ColumnDescriptor} from '../../../../descriptors';\nimport {ColumnTypeEnum} from '../../../../descriptors/types';\n\n@Component({\n    selector: 'mng-table-column-value',\n    templateUrl: './column-value.component.html',\n    styleUrls: ['./column-value.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTableColumnValueComponent<T, TT> implements OnInit {\n    public readonly columnTypeString: ColumnTypeEnum = ColumnTypeEnum.String;\n    public readonly columnTypeNumber: ColumnTypeEnum = ColumnTypeEnum.Number;\n    public readonly columnTypeCurrency: ColumnTypeEnum = ColumnTypeEnum.Currency;\n    public readonly columnTypeBoolean: ColumnTypeEnum = ColumnTypeEnum.Boolean;\n    public readonly columnTypeDate: ColumnTypeEnum = ColumnTypeEnum.Date;\n    public readonly columnTypeEnum: ColumnTypeEnum = ColumnTypeEnum.Enum;\n    public readonly columnTypeCustom: ColumnTypeEnum = ColumnTypeEnum.Custom;\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    constructor(private elementRef: ElementRef, private messageService: MessageService, private translate: TranslateService) {}\n\n    public ngOnInit() {\n        if (this.descriptor.columnType === ColumnTypeEnum.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\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.columnType\">\n    <ng-container *ngSwitchCase=\"columnTypeString\">\n        {{ item | jsonPath: jsonPath | getter: descriptor.getter | template: descriptor.template }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeNumber\">\n        {{ item | jsonPath: jsonPath | number: descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeCurrency\">\n        {{ item | jsonPath: jsonPath | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeDate\">\n        {{ item | jsonPath: jsonPath | date: descriptor.displayFormat }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n        <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\"></ng-container>\n        <i [class]=\"item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n        <ng-template #booleanText>\n            {{ item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n        </ng-template>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeEnum\">\n        {{ item | jsonPath: jsonPath | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeCustom\">\n        <ng-container\n            [mngComponent]=\"descriptor.customComponentType!\"\n            [inputs]=\"{\n                value: item | jsonPath: jsonPath,\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"]}
@@ -3,4 +3,5 @@ export * from './editor.data-provider';
3
3
  export * from './lookup.data-provider';
4
4
  export * from './table.data-provider';
5
5
  export * from './tableview.data-provider';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2RhdGEtcHJvdmlkZXJzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFzZS5kYXRhLXByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZWRpdG9yLmRhdGEtcHJvdmlkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9sb29rdXAuZGF0YS1wcm92aWRlcic7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLmRhdGEtcHJvdmlkZXInO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZXZpZXcuZGF0YS1wcm92aWRlcic7XG4iXX0=
6
+ export * from './tableview-crud.data-provider';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2RhdGEtcHJvdmlkZXJzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGdDQUFnQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9iYXNlLmRhdGEtcHJvdmlkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9lZGl0b3IuZGF0YS1wcm92aWRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xvb2t1cC5kYXRhLXByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUuZGF0YS1wcm92aWRlcic7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxldmlldy5kYXRhLXByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGV2aWV3LWNydWQuZGF0YS1wcm92aWRlcic7XG4iXX0=
@@ -0,0 +1,24 @@
1
+ import { map } from 'rxjs/operators';
2
+ import { MediusFilterMatchType, MediusQueryParamBuilder } from '../api/models';
3
+ import { ModelUtil } from '../utils';
4
+ import { TableviewDataProvider } from './tableview.data-provider';
5
+ export class TableviewCrudDataProvider extends TableviewDataProvider {
6
+ constructor(modelType, serviceType, idPropertyName, useGetAllForFetch = false) {
7
+ super(modelType, serviceType);
8
+ this.withGetAll((queryParam, service) => service.getAllPost(queryParam));
9
+ if (useGetAllForFetch) {
10
+ const selectedIdPropertyName = idPropertyName ?? ModelUtil.findIdAttribute(modelType) ?? 'id';
11
+ this.withFetch((id, service) => {
12
+ const qp = MediusQueryParamBuilder.create(10, 0).withFilter(selectedIdPropertyName, id, id, MediusFilterMatchType.Equals, true).build();
13
+ return service.getAllPost(qp).pipe(map(res => res.pageData[0]));
14
+ });
15
+ }
16
+ else {
17
+ this.withFetch((id, service) => service.getByIdGet(id));
18
+ }
19
+ this.withCreate((item, service) => service.createPost(item));
20
+ this.withUpdate((id, item, service) => service.updatePut(id, item));
21
+ this.withDelete((id, item, service) => service.removeDelete(id, item));
22
+ }
23
+ }
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGV2aWV3LWNydWQuZGF0YS1wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvZGF0YS1wcm92aWRlcnMvdGFibGV2aWV3LWNydWQuZGF0YS1wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsR0FBRyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFbkMsT0FBTyxFQUFDLHFCQUFxQixFQUFvQix1QkFBdUIsRUFBb0IsTUFBTSxlQUFlLENBQUM7QUFHbEgsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLFVBQVUsQ0FBQztBQUNuQyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUVoRSxNQUFNLE9BQU8seUJBQTJHLFNBQVEscUJBQTJCO0lBQ3ZKLFlBQVksU0FBdUIsRUFBRSxXQUFxQixFQUFFLGNBQXVCLEVBQUUsaUJBQWlCLEdBQUcsS0FBSztRQUMxRyxLQUFLLENBQUMsU0FBUyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFRLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFFMUUsSUFBSSxpQkFBaUIsRUFBRTtZQUNuQixNQUFNLHNCQUFzQixHQUFHLGNBQWMsSUFBSSxTQUFTLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxJQUFJLElBQUksQ0FBQztZQUM5RixJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFO2dCQUMzQixNQUFNLEVBQUUsR0FBcUIsdUJBQXVCLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsc0JBQXNCLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxxQkFBcUIsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7Z0JBQzFKLE9BQU8sT0FBUSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLFFBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEUsQ0FBQyxDQUFDLENBQUM7U0FDTjthQUFNO1lBQ0gsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLE9BQVEsQ0FBQyxVQUFXLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztTQUM3RDtRQUNELElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFRLENBQUMsVUFBVyxDQUFDLElBQUssQ0FBQyxDQUFDLENBQUM7UUFDaEUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFRLENBQUMsU0FBVSxDQUFDLEVBQUUsRUFBRSxJQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ3ZFLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxFQUFFLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBUSxDQUFDLFlBQWEsQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUM3RSxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1R5cGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge21hcH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge01lZGl1c0ZpbHRlck1hdGNoVHlwZSwgTWVkaXVzUXVlcnlQYXJhbSwgTWVkaXVzUXVlcnlQYXJhbUJ1aWxkZXIsIE1lZGl1c1F1ZXJ5UmVzdWx0fSBmcm9tICcuLi9hcGkvbW9kZWxzJztcbmltcG9ydCB7SU1uZ0NydWRBcGlTZXJ2aWNlLCBJTW5nR2V0QWxsQXBpU2VydmljZX0gZnJvbSAnLi4vYXBpL3NlcnZpY2VzJztcbmltcG9ydCB7Q2xhc3NUeXBlfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQge01vZGVsVXRpbH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHtUYWJsZXZpZXdEYXRhUHJvdmlkZXJ9IGZyb20gJy4vdGFibGV2aWV3LmRhdGEtcHJvdmlkZXInO1xuXG5leHBvcnQgY2xhc3MgVGFibGV2aWV3Q3J1ZERhdGFQcm92aWRlcjxULCBTIGV4dGVuZHMgSU1uZ0NydWRBcGlTZXJ2aWNlPFQ+ICYgSU1uZ0dldEFsbEFwaVNlcnZpY2U8TWVkaXVzUXVlcnlSZXN1bHQ8VD4+PiBleHRlbmRzIFRhYmxldmlld0RhdGFQcm92aWRlcjxULCBTPiB7XG4gICAgY29uc3RydWN0b3IobW9kZWxUeXBlOiBDbGFzc1R5cGU8VD4sIHNlcnZpY2VUeXBlPzogVHlwZTxTPiwgaWRQcm9wZXJ0eU5hbWU/OiBzdHJpbmcsIHVzZUdldEFsbEZvckZldGNoID0gZmFsc2UpIHtcbiAgICAgICAgc3VwZXIobW9kZWxUeXBlLCBzZXJ2aWNlVHlwZSk7XG4gICAgICAgIHRoaXMud2l0aEdldEFsbCgocXVlcnlQYXJhbSwgc2VydmljZSkgPT4gc2VydmljZSEuZ2V0QWxsUG9zdChxdWVyeVBhcmFtKSk7XG5cbiAgICAgICAgaWYgKHVzZUdldEFsbEZvckZldGNoKSB7XG4gICAgICAgICAgICBjb25zdCBzZWxlY3RlZElkUHJvcGVydHlOYW1lID0gaWRQcm9wZXJ0eU5hbWUgPz8gTW9kZWxVdGlsLmZpbmRJZEF0dHJpYnV0ZShtb2RlbFR5cGUpID8/ICdpZCc7XG4gICAgICAgICAgICB0aGlzLndpdGhGZXRjaCgoaWQsIHNlcnZpY2UpID0+IHtcbiAgICAgICAgICAgICAgICBjb25zdCBxcDogTWVkaXVzUXVlcnlQYXJhbSA9IE1lZGl1c1F1ZXJ5UGFyYW1CdWlsZGVyLmNyZWF0ZSgxMCwgMCkud2l0aEZpbHRlcihzZWxlY3RlZElkUHJvcGVydHlOYW1lLCBpZCwgaWQsIE1lZGl1c0ZpbHRlck1hdGNoVHlwZS5FcXVhbHMsIHRydWUpLmJ1aWxkKCk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHNlcnZpY2UhLmdldEFsbFBvc3QocXApLnBpcGUobWFwKHJlcyA9PiByZXMucGFnZURhdGEhWzBdKSk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRoaXMud2l0aEZldGNoKChpZCwgc2VydmljZSkgPT4gc2VydmljZSEuZ2V0QnlJZEdldCEoaWQpKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLndpdGhDcmVhdGUoKGl0ZW0sIHNlcnZpY2UpID0+IHNlcnZpY2UhLmNyZWF0ZVBvc3QhKGl0ZW0hKSk7XG4gICAgICAgIHRoaXMud2l0aFVwZGF0ZSgoaWQsIGl0ZW0sIHNlcnZpY2UpID0+IHNlcnZpY2UhLnVwZGF0ZVB1dCEoaWQsIGl0ZW0hKSk7XG4gICAgICAgIHRoaXMud2l0aERlbGV0ZSgoaWQsIGl0ZW0sIHNlcnZpY2UpID0+IHNlcnZpY2UhLnJlbW92ZURlbGV0ZSEoaWQsIGl0ZW0pKTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,106 @@
1
+ import { ButtonStyleBuilder } from '../../styles';
2
+ import { ActionLevelEnum } from '../types';
3
+ export class ActionConfirmationDialogDescriptor {
4
+ constructor() {
5
+ this._closeOnEscape = true; // Defines if dialog closes when esc key is pressed.
6
+ this._closable = true; // Defines if dialog is closable.
7
+ this._acceptButtonStyle = new ButtonStyleBuilder(ActionLevelEnum.Default);
8
+ this._rejectButtonStyle = new ButtonStyleBuilder(ActionLevelEnum.Default).withTextButton();
9
+ this._icon = 'pi pi-exclamation-triangle';
10
+ this._acceptIcon = 'pi pi-check';
11
+ this._rejectIcon = 'pi pi-times';
12
+ }
13
+ withIcon(icon) {
14
+ this._icon = icon;
15
+ return this;
16
+ }
17
+ withTitle(title) {
18
+ this._title = title;
19
+ return this;
20
+ }
21
+ withMessage(message) {
22
+ this._message = message;
23
+ return this;
24
+ }
25
+ withAcceptLabel(acceptLabel) {
26
+ this._acceptLabel = acceptLabel;
27
+ return this;
28
+ }
29
+ withAcceptIcon(acceptIcon) {
30
+ this._acceptIcon = acceptIcon;
31
+ return this;
32
+ }
33
+ withAcceptButtonStyle(buttonStyle) {
34
+ this._acceptButtonStyle = buttonStyle;
35
+ return this;
36
+ }
37
+ withRejectLabel(rejectLabel) {
38
+ this._rejectLabel = rejectLabel;
39
+ return this;
40
+ }
41
+ withRejectIcon(rejectIcon) {
42
+ this._rejectIcon = rejectIcon;
43
+ return this;
44
+ }
45
+ withRejectButtonStyle(buttonStyle) {
46
+ this._rejectButtonStyle = buttonStyle;
47
+ return this;
48
+ }
49
+ /**
50
+ * set if dialog can be closed on escaped pressed
51
+ * if true, then closable is also set to true
52
+ * @param closeOnEscape
53
+ */
54
+ withCloseOnEscape(closeOnEscape) {
55
+ if (closeOnEscape) {
56
+ this._closable = true;
57
+ }
58
+ this._closeOnEscape = closeOnEscape;
59
+ return this;
60
+ }
61
+ withClosable(closable) {
62
+ this._closable = closable;
63
+ return this;
64
+ }
65
+ withRunConfirmationConfigMapFn(runConfirmationConfigMapFn) {
66
+ this._runConfirmationConfigMapFn = runConfirmationConfigMapFn;
67
+ return this;
68
+ }
69
+ get icon() {
70
+ return this._icon;
71
+ }
72
+ get title() {
73
+ return this._title;
74
+ }
75
+ get message() {
76
+ return this._message;
77
+ }
78
+ get acceptLabel() {
79
+ return this._acceptLabel;
80
+ }
81
+ get acceptIcon() {
82
+ return this._acceptIcon;
83
+ }
84
+ get acceptButtonStyle() {
85
+ return this._acceptButtonStyle;
86
+ }
87
+ get rejectLabel() {
88
+ return this._rejectLabel;
89
+ }
90
+ get rejectIcon() {
91
+ return this._rejectIcon;
92
+ }
93
+ get rejectButtonStyle() {
94
+ return this._rejectButtonStyle;
95
+ }
96
+ get closeOnEscape() {
97
+ return this._closeOnEscape;
98
+ }
99
+ get closable() {
100
+ return this._closable;
101
+ }
102
+ get runConfirmationConfigMapFn() {
103
+ return this._runConfirmationConfigMapFn;
104
+ }
105
+ }
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-confirmation.descriptor.js","sourceRoot":"","sources":["../../../../../src/lib/descriptors/action/action-confirmation.descriptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {Confirmation} from 'primeng/api';\n\nimport {ActionContext} from '../../components/action/models';\nimport {ButtonStyleBuilder} from '../../styles';\nimport {ActionLevelEnum} from '../types';\n\nexport class ActionConfirmationDialogDescriptor<T> {\n    private _icon?: string; // Icon to display next to message.\n    private _title?: string | null; // Translation for title text of the dialog.\n    private _message?: string | null; // Translation for body text of the dialog.\n\n    private _acceptButtonStyle: ButtonStyleBuilder;\n    private _acceptLabel?: string | null; // Translation for label on accept button.\n    private _acceptIcon: string | null; // Icon on accept button;\n\n    private _rejectButtonStyle: ButtonStyleBuilder;\n    private _rejectLabel?: string | null; // Translation for label on reject button.\n    private _rejectIcon: string | null; // Icon on reject button.\n\n    private _closeOnEscape = true; // Defines if dialog closes when esc key is pressed.\n    private _closable = true; // Defines if dialog is closable.\n    private _runConfirmationConfigMapFn?: ConfigurationConfigMapFn<T>; //function used to generate the confirmation dialogue. **WARNING** changing the *accept* and *reject* methods of the *confirmConfig* parameter may lead to unexpected behaviour\n\n    constructor() {\n        this._acceptButtonStyle = new ButtonStyleBuilder(ActionLevelEnum.Default);\n        this._rejectButtonStyle = new ButtonStyleBuilder(ActionLevelEnum.Default).withTextButton();\n        this._icon = 'pi pi-exclamation-triangle';\n        this._acceptIcon = 'pi pi-check';\n        this._rejectIcon = 'pi pi-times';\n    }\n\n    public withIcon(icon?: string): this {\n        this._icon = icon;\n        return this;\n    }\n\n    public withTitle(title?: string | null): this {\n        this._title = title;\n        return this;\n    }\n\n    public withMessage(message?: string | null): this {\n        this._message = message;\n        return this;\n    }\n\n    public withAcceptLabel(acceptLabel?: string | null): this {\n        this._acceptLabel = acceptLabel;\n        return this;\n    }\n\n    public withAcceptIcon(acceptIcon: string | null): this {\n        this._acceptIcon = acceptIcon;\n        return this;\n    }\n\n    public withAcceptButtonStyle(buttonStyle: ButtonStyleBuilder): this {\n        this._acceptButtonStyle = buttonStyle;\n        return this;\n    }\n\n    public withRejectLabel(rejectLabel?: string | null): this {\n        this._rejectLabel = rejectLabel;\n        return this;\n    }\n\n    public withRejectIcon(rejectIcon: string | null): this {\n        this._rejectIcon = rejectIcon;\n        return this;\n    }\n\n    public withRejectButtonStyle(buttonStyle: ButtonStyleBuilder): this {\n        this._rejectButtonStyle = buttonStyle;\n        return this;\n    }\n\n    /**\n     * set if dialog can be closed on escaped pressed\n     * if true, then closable is also set to true\n     * @param closeOnEscape\n     */\n    public withCloseOnEscape(closeOnEscape: boolean): this {\n        if (closeOnEscape) {\n            this._closable = true;\n        }\n        this._closeOnEscape = closeOnEscape;\n        return this;\n    }\n\n    public withClosable(closable: boolean): this {\n        this._closable = closable;\n        return this;\n    }\n\n    public withRunConfirmationConfigMapFn(runConfirmationConfigMapFn?: ConfigurationConfigMapFn<T>): this {\n        this._runConfirmationConfigMapFn = runConfirmationConfigMapFn;\n        return this;\n    }\n\n    public get icon() {\n        return this._icon;\n    }\n\n    public get title() {\n        return this._title;\n    }\n\n    public get message() {\n        return this._message;\n    }\n\n    public get acceptLabel() {\n        return this._acceptLabel;\n    }\n\n    public get acceptIcon() {\n        return this._acceptIcon;\n    }\n\n    public get acceptButtonStyle() {\n        return this._acceptButtonStyle;\n    }\n\n    public get rejectLabel() {\n        return this._rejectLabel;\n    }\n\n    public get rejectIcon() {\n        return this._rejectIcon;\n    }\n\n    public get rejectButtonStyle() {\n        return this._rejectButtonStyle;\n    }\n\n    public get closeOnEscape() {\n        return this._closeOnEscape;\n    }\n\n    public get closable() {\n        return this._closable;\n    }\n\n    public get runConfirmationConfigMapFn() {\n        return this._runConfirmationConfigMapFn;\n    }\n}\n\nexport type ConfigurationConfigMapFn<T> = (ctx: ActionContext<T, any>, confirmConfig: Confirmation) => Confirmation;\n"]}