@mediusinc/mng-commons 0.3.3 → 0.4.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 (65) hide show
  1. package/esm2020/lib/api/models/builders/query-param.builder.mjs +7 -2
  2. package/esm2020/lib/api/services/api.abstract.service.mjs +21 -10
  3. package/esm2020/lib/api/utils/object-serializer.util.mjs +7 -1
  4. package/esm2020/lib/components/action/action.component.mjs +3 -3
  5. package/esm2020/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +3 -3
  6. package/esm2020/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +3 -3
  7. package/esm2020/lib/components/layout/main-layout.component.mjs +1 -1
  8. package/esm2020/lib/components/layout/topbar.component.mjs +1 -1
  9. package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +17 -5
  10. package/esm2020/lib/components/tableview/table/column-filter/column-filter.component.mjs +1 -10
  11. package/esm2020/lib/components/tableview/table/column-value/column-value.component.mjs +21 -7
  12. package/esm2020/lib/components/tableview/table/table.component.mjs +3 -3
  13. package/esm2020/lib/components/tableview/tableview.component.mjs +3 -3
  14. package/esm2020/lib/descriptors/column.descriptor.mjs +197 -0
  15. package/esm2020/lib/descriptors/editor.descriptor.mjs +3 -755
  16. package/esm2020/lib/descriptors/field.descriptor.interface.mjs +2 -0
  17. package/esm2020/lib/descriptors/field.descriptor.mjs +755 -0
  18. package/esm2020/lib/descriptors/filter.descriptor.mjs +237 -0
  19. package/esm2020/lib/descriptors/index.mjs +5 -1
  20. package/esm2020/lib/descriptors/table.descriptor.mjs +4 -403
  21. package/esm2020/lib/descriptors/tableview.descriptor.mjs +3 -3
  22. package/esm2020/lib/directives/component.directive.mjs +18 -2
  23. package/esm2020/lib/mng-commons.module.mjs +5 -5
  24. package/esm2020/lib/models/column-value.model.mjs +2 -0
  25. package/esm2020/lib/models/index.mjs +2 -1
  26. package/esm2020/lib/pipes/index.mjs +2 -2
  27. package/esm2020/lib/pipes/json-path.pipe.mjs +80 -0
  28. package/esm2020/lib/utils/model.util.mjs +16 -15
  29. package/esm2020/public-api.mjs +2 -1
  30. package/fesm2015/mediusinc-mng-commons.mjs +1416 -1282
  31. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  32. package/fesm2020/mediusinc-mng-commons.mjs +1411 -1279
  33. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  34. package/lib/api/models/builders/query-param.builder.d.ts +2 -1
  35. package/lib/api/services/api.abstract.service.d.ts +10 -5
  36. package/lib/api/utils/object-serializer.util.d.ts +4 -2
  37. package/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.d.ts +1 -2
  38. package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +5 -1
  39. package/lib/components/tableview/table/column-value/column-value.component.d.ts +5 -1
  40. package/lib/descriptors/column.descriptor.d.ts +66 -0
  41. package/lib/descriptors/editor.descriptor.d.ts +1 -299
  42. package/lib/descriptors/field.descriptor.d.ts +301 -0
  43. package/lib/descriptors/{editor.descriptor.interface.d.ts → field.descriptor.interface.d.ts} +0 -0
  44. package/lib/descriptors/filter.descriptor.d.ts +108 -0
  45. package/lib/descriptors/index.d.ts +4 -0
  46. package/lib/descriptors/table.descriptor.d.ts +5 -164
  47. package/lib/descriptors/tableview.descriptor.d.ts +4 -2
  48. package/lib/directives/component.directive.d.ts +5 -1
  49. package/lib/mng-commons.module.d.ts +2 -2
  50. package/lib/models/column-value.model.d.ts +4 -0
  51. package/lib/models/index.d.ts +1 -0
  52. package/lib/pipes/index.d.ts +1 -1
  53. package/lib/pipes/json-path.pipe.d.ts +13 -0
  54. package/lib/utils/model.util.d.ts +1 -0
  55. package/package.json +1 -1
  56. package/public-api.d.ts +1 -0
  57. package/scss/mng-overrides/_layout_action.scss +7 -0
  58. package/scss/mng-overrides/_layout_dialog.scss +17 -6
  59. package/scss/mng-overrides/_mixins.scss +60 -0
  60. package/scss/theme/default/_mng-variables-theme-dark.scss +2 -3
  61. package/scss/theme/default/_mng-variables-theme-light.scss +2 -3
  62. package/scss/theme/default/_mng-variables.scss +12 -0
  63. package/esm2020/lib/descriptors/editor.descriptor.interface.mjs +0 -2
  64. package/esm2020/lib/pipes/property-path.pipe.mjs +0 -36
  65. package/lib/pipes/property-path.pipe.d.ts +0 -7
@@ -168,12 +168,12 @@ export class MngFormlyFieldLookupDialogComponent extends FieldType {
168
168
  }
169
169
  }
170
170
  MngFormlyFieldLookupDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldLookupDialogComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
171
- MngFormlyFieldLookupDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngFormlyFieldLookupDialogComponent, selector: "mng-formly-field-lookup-dialog", viewQueries: [{ propertyName: "mngTable", first: true, predicate: MngTableComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!to.required && formControl?.value\"></i>\n <button pButton pRipple class=\"mng-dropdown-dialog-search-button\" type=\"button\" [label]=\"'general.search' | translate: {item: ''}\" (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: to?.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-formly-field-table-multiselect-dialog\">\n <ng-template pTemplate=\"content\">\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config?.table?.captionComponent\"\n [columnActionComponent]=\"config?.table?.columnActionComponent\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n", components: [{ type: i1.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"] }, { type: i2.MngTableComponent, selector: "mng-table", inputs: ["descriptor", "items", "queryResult", "loading", "dataProvider", "useQueryParams", "selectionMode", "selectionEnabled", "isColumnClickable", "captionComponent", "columnActionComponent"], outputs: ["tableLoad", "cellClick", "selectionChange", "captionComponentInstance", "columnActionComponentInstance"] }, { type: i3.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }], directives: [{ type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.InputText, selector: "[pInputText]" }, { type: i6.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i9.Ripple, selector: "[pRipple]" }, { type: i10.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }], pipes: { "translate": i11.TranslatePipe, "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
171
+ MngFormlyFieldLookupDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngFormlyFieldLookupDialogComponent, selector: "mng-formly-field-lookup-dialog", viewQueries: [{ propertyName: "mngTable", first: true, predicate: MngTableComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!to.required && formControl?.value\"></i>\n <button pButton pRipple class=\"mng-dropdown-dialog-search-button\" type=\"button\" [label]=\"'general.search' | translate: {item: ''}\" (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: to?.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-formly-field-lookup-dialog\">\n <ng-template pTemplate=\"content\">\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config?.table?.captionComponent\"\n [columnActionComponent]=\"config?.table?.columnActionComponent\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n", components: [{ type: i1.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"] }, { type: i2.MngTableComponent, selector: "mng-table", inputs: ["descriptor", "items", "queryResult", "loading", "dataProvider", "useQueryParams", "selectionMode", "selectionEnabled", "isColumnClickable", "captionComponent", "columnActionComponent"], outputs: ["tableLoad", "cellClick", "selectionChange", "captionComponentInstance", "columnActionComponentInstance"] }, { type: i3.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }], directives: [{ type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.InputText, selector: "[pInputText]" }, { type: i6.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i9.Ripple, selector: "[pRipple]" }, { type: i10.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }], pipes: { "translate": i11.TranslatePipe, "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
172
172
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldLookupDialogComponent, decorators: [{
173
173
  type: Component,
174
- args: [{ selector: 'mng-formly-field-lookup-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!to.required && formControl?.value\"></i>\n <button pButton pRipple class=\"mng-dropdown-dialog-search-button\" type=\"button\" [label]=\"'general.search' | translate: {item: ''}\" (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: to?.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-formly-field-table-multiselect-dialog\">\n <ng-template pTemplate=\"content\">\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config?.table?.captionComponent\"\n [columnActionComponent]=\"config?.table?.columnActionComponent\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n" }]
174
+ args: [{ selector: 'mng-formly-field-lookup-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!to.required && formControl?.value\"></i>\n <button pButton pRipple class=\"mng-dropdown-dialog-search-button\" type=\"button\" [label]=\"'general.search' | translate: {item: ''}\" (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n [(visible)]=\"isDialogVisible\"\n [draggable]=\"false\"\n [header]=\"'general.search' | translate: {item: to?.label!}\"\n [modal]=\"true\"\n appendTo=\"body\"\n styleClass=\"p-fluid mng-formly-field-lookup-dialog\">\n <ng-template pTemplate=\"content\">\n <mng-table\n [descriptor]=\"descriptor.dialogTableDescriptor!\"\n [dataProvider]=\"descriptor.dialogTableDataProvider\"\n [queryResult]=\"addItemsAsync\"\n [selectionEnabled]=\"true\"\n [selectionMode]=\"'single'\"\n [loading]=\"dialogIsLoading$\"\n [captionComponent]=\"config?.table?.captionComponent\"\n [columnActionComponent]=\"config?.table?.columnActionComponent\"\n (selectionChange)=\"onSelectionChange($event)\"\n (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n </mng-table>\n <p-messages [value]=\"dialogMessages\"></p-messages>\n </ng-template>\n\n <ng-template pTemplate=\"footer\">\n <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n <button\n pButton\n pRipple\n type=\"button\"\n [label]=\"'general.select' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"addItem()\"\n [loading]=\"(dialogIsLoading$ | async) ?? false\"\n [disabled]=\"form.disabled\"></button>\n </ng-template>\n</p-dialog>\n" }]
175
175
  }], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { mngTable: [{
176
176
  type: ViewChild,
177
177
  args: [MngTableComponent]
178
178
  }] } });
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-lookup-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.ts","../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {Observable, ReplaySubject, Subject, Subscription, distinctUntilChanged} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder, MediusQueryResult} from '../../../../../api/models';\nimport {FieldLookupDescriptor} from '../../../../../descriptors';\nimport {FieldLookupConfig} from '../../../../../descriptors/editor.descriptor.interface';\nimport {MngTableComponent} from '../../../../tableview';\nimport {MngFormFieldEventComponentSubtype, MngFormFieldEventDialogSubtype, MngFormFieldEventTypeEnum} from '../../../models';\n\n@Component({\n    selector: 'mng-formly-field-lookup-dialog',\n    templateUrl: 'formly-field-lookup-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldLookupDialogComponent<T, ET> extends FieldType implements OnInit, AfterViewInit, OnDestroy {\n    @ViewChild(MngTableComponent) public mngTable?: MngTableComponent<any, any>;\n\n    public descriptor!: FieldLookupDescriptor<T, ET>;\n    public config!: FieldLookupConfig;\n    public fieldLabelFormControl: FormControl = new FormControl();\n\n    public itemsSubject: Subject<T> = new ReplaySubject(1);\n    public itemsAsync: Observable<T> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<MediusQueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<MediusQueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedItem: any = null;\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    private lookupDataProviderSubscription?: Subscription;\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.descriptor = this.to['descriptor'];\n\n        // emit lifecycle event\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Component, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this.config = this.descriptor.config as FieldLookupConfig;\n        if (!this.descriptor.dialogTableDataProvider && this.descriptor.dataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.dataProvider.serviceType);\n        }\n\n        // init values\n        this.setFieldLabelValue(this.formControl!.value);\n        const subscription = this.formControl!.valueChanges.pipe(\n            startWith(this.formControl!.value),\n            distinctUntilChanged((prev, curr) => {\n                const compareProp = this.descriptor.dialogTableDescriptor!.dataKeyProperty ?? this.descriptor.dialogTableDescriptor!.model.idPropertyName;\n                if (compareProp && typeof prev === 'object' && typeof curr === 'object') {\n                    return prev[compareProp] === curr[compareProp];\n                } else {\n                    return prev === curr;\n                }\n            })\n        ).subscribe(v => {\n            this.setFieldLabelValue(v);\n            this.itemsSubject.next(v);\n            this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ValueChange, MngFormlyFieldLookupDialogComponent, this, {\n                value: v\n            });\n        });\n        this.subscriptions.push(subscription);\n    }\n\n    ngAfterViewInit() {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Component, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_VIEW_INIT\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.lookupDataProviderSubscription?.unsubscribe();\n        this.subscriptions.forEach(s => s.unsubscribe());\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormFieldEventTypeEnum.Component, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    openSelectDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = MediusQueryParamBuilder.create(50);\n            if (this.descriptor.dialogTableDescriptor!.hasDefaultSort) {\n                this.descriptor.dialogTableDescriptor!.defaultSortProperty.forEach((p, idx) =>\n                    queryParamBuilder.withSort(p, this.descriptor.dialogTableDescriptor!.defaultSortAsc[idx])\n                );\n            }\n            this.lookupDataProviderSubscription = this.descriptor.dataProvider?.lookup(queryParamBuilder.build(), this.dialogDataProviderService).subscribe({\n                next: res => {\n                    const mqr = new MediusQueryResult<T>();\n                    mqr.pageData = res;\n                    mqr.allDataCount = res.length;\n                    this.addItemsSubject.next(mqr);\n                    this.dialogAreItemsLoaded = true;\n                    this.dialogIsLoadingSubject.next(false);\n\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupNext',\n                        queryResult: mqr\n                    });\n                },\n                error: err => {\n                    this.dialogIsLoadingSubject.next(false);\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupError',\n                        queryResult: err\n                    });\n                }\n            });\n        }\n        this.dialogSelectedItem = null;\n        this.isDialogVisible = true;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: true\n        });\n    }\n\n    onSelectionChange(item: any) {\n        this.dialogSelectedItem = item;\n    }\n\n    onCaptionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_CAPTION_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    onColumnActionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_COLUMN_ACTIONS_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    clear() {\n        this.formControl!.setValue(undefined);\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: false\n        });\n    }\n\n    addItem() {\n        this.formControl!.setValue(this.dialogSelectedItem);\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    private setFieldLabelValue(value: T) {\n        if (!value) {\n            this.fieldLabelFormControl.setValue('');\n            return;\n        }\n        if (typeof value === 'object') {\n            const labelProperty = this.descriptor.itemsLabelProperty ?? this.descriptor.dialogTableDescriptor?.model.titlePropertyName;\n            if (!labelProperty) {\n                throw new Error('Could not determine label property.');\n            }\n            this.fieldLabelFormControl.setValue(value[labelProperty as keyof object]);\n        } else {\n            this.fieldLabelFormControl.setValue(value);\n        }\n    }\n}\n","<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n    <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n    <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!to.required && formControl?.value\"></i>\n    <button pButton pRipple class=\"mng-dropdown-dialog-search-button\" type=\"button\" [label]=\"'general.search' | translate: {item: ''}\" (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n    [(visible)]=\"isDialogVisible\"\n    [draggable]=\"false\"\n    [header]=\"'general.search' | translate: {item: to?.label!}\"\n    [modal]=\"true\"\n    appendTo=\"body\"\n    styleClass=\"p-fluid mng-formly-field-table-multiselect-dialog\">\n    <ng-template pTemplate=\"content\">\n        <mng-table\n            [descriptor]=\"descriptor.dialogTableDescriptor!\"\n            [dataProvider]=\"descriptor.dialogTableDataProvider\"\n            [queryResult]=\"addItemsAsync\"\n            [selectionEnabled]=\"true\"\n            [selectionMode]=\"'single'\"\n            [loading]=\"dialogIsLoading$\"\n            [captionComponent]=\"config?.table?.captionComponent\"\n            [columnActionComponent]=\"config?.table?.columnActionComponent\"\n            (selectionChange)=\"onSelectionChange($event)\"\n            (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n            (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [label]=\"'general.select' | translate\"\n            icon=\"pi pi-check\"\n            class=\"p-button-text\"\n            (click)=\"addItem()\"\n            [loading]=\"(dialogIsLoading$ | async) ?? false\"\n            [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-field-lookup-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.ts","../../../../../../../../src/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectionStrategy, Component, Injector, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {FormControl} from '@angular/forms';\n\nimport {FieldType} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {Observable, ReplaySubject, Subject, Subscription, distinctUntilChanged} from 'rxjs';\nimport {startWith} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder, MediusQueryResult} from '../../../../../api/models';\nimport {FieldLookupConfig, FieldLookupDescriptor} from '../../../../../descriptors';\nimport {MngTableComponent} from '../../../../tableview';\nimport {MngFormFieldEventComponentSubtype, MngFormFieldEventDialogSubtype, MngFormFieldEventTypeEnum} from '../../../models';\n\n@Component({\n    selector: 'mng-formly-field-lookup-dialog',\n    templateUrl: 'formly-field-lookup-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngFormlyFieldLookupDialogComponent<T, ET> extends FieldType implements OnInit, AfterViewInit, OnDestroy {\n    @ViewChild(MngTableComponent) public mngTable?: MngTableComponent<any, any>;\n\n    public descriptor!: FieldLookupDescriptor<T, ET>;\n    public config!: FieldLookupConfig;\n    public fieldLabelFormControl: FormControl = new FormControl();\n\n    public itemsSubject: Subject<T> = new ReplaySubject(1);\n    public itemsAsync: Observable<T> = this.itemsSubject.asObservable();\n    public addItemsSubject: Subject<MediusQueryResult<T>> = new ReplaySubject(1);\n    public addItemsAsync: Observable<MediusQueryResult<T>> = this.addItemsSubject.asObservable();\n\n    public dialogUseDataProvider = false;\n    private dialogDataProviderService: any = null;\n    private dialogIsLoadingSubject = new ReplaySubject<boolean>(1);\n\n    public isDialogVisible = false;\n    public dialogAreItemsLoaded = false;\n    public dialogSelectedItem: any = null;\n    public dialogMessages: Message[] = [];\n    public dialogIsLoading$ = this.dialogIsLoadingSubject.asObservable();\n\n    private lookupDataProviderSubscription?: Subscription;\n    private subscriptions: Subscription[] = [];\n\n    constructor(private injector: Injector) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.descriptor = this.to['descriptor'];\n\n        // emit lifecycle event\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Component, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_INIT\n        });\n\n        this.config = this.descriptor.config as FieldLookupConfig;\n        if (!this.descriptor.dialogTableDataProvider && this.descriptor.dataProvider?.serviceType) {\n            this.dialogUseDataProvider = true;\n            this.dialogDataProviderService = this.injector.get<any>(this.descriptor.dataProvider.serviceType);\n        }\n\n        // init values\n        this.setFieldLabelValue(this.formControl!.value);\n        const subscription = this.formControl!.valueChanges.pipe(\n            startWith(this.formControl!.value),\n            distinctUntilChanged((prev, curr) => {\n                const compareProp = this.descriptor.dialogTableDescriptor!.dataKeyProperty ?? this.descriptor.dialogTableDescriptor!.model.idPropertyName;\n                if (compareProp && typeof prev === 'object' && typeof curr === 'object') {\n                    return prev[compareProp] === curr[compareProp];\n                } else {\n                    return prev === curr;\n                }\n            })\n        ).subscribe(v => {\n            this.setFieldLabelValue(v);\n            this.itemsSubject.next(v);\n            this.descriptor.nextEvent(MngFormFieldEventTypeEnum.ValueChange, MngFormlyFieldLookupDialogComponent, this, {\n                value: v\n            });\n        });\n        this.subscriptions.push(subscription);\n    }\n\n    ngAfterViewInit() {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Component, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_VIEW_INIT\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.lookupDataProviderSubscription?.unsubscribe();\n        this.subscriptions.forEach(s => s.unsubscribe());\n\n        // emit lifecycle event\n        this.descriptor?.nextEvent(MngFormFieldEventTypeEnum.Component, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY\n        });\n    }\n\n    openSelectDialog() {\n        if (!this.dialogAreItemsLoaded && this.dialogUseDataProvider) {\n            this.dialogIsLoadingSubject.next(true);\n            const queryParamBuilder = MediusQueryParamBuilder.create(50);\n            if (this.descriptor.dialogTableDescriptor!.hasDefaultSort) {\n                this.descriptor.dialogTableDescriptor!.defaultSortProperty.forEach((p, idx) =>\n                    queryParamBuilder.withSort(p, this.descriptor.dialogTableDescriptor!.defaultSortAsc[idx])\n                );\n            }\n            this.lookupDataProviderSubscription = this.descriptor.dataProvider?.lookup(queryParamBuilder.build(), this.dialogDataProviderService).subscribe({\n                next: res => {\n                    const mqr = new MediusQueryResult<T>();\n                    mqr.pageData = res;\n                    mqr.allDataCount = res.length;\n                    this.addItemsSubject.next(mqr);\n                    this.dialogAreItemsLoaded = true;\n                    this.dialogIsLoadingSubject.next(false);\n\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupNext',\n                        queryResult: mqr\n                    });\n                },\n                error: err => {\n                    this.dialogIsLoadingSubject.next(false);\n                    this.descriptor.nextEvent(MngFormFieldEventTypeEnum.DataProvider, MngFormlyFieldLookupDialogComponent, this, {\n                        eventSubtype: 'LookupError',\n                        queryResult: err\n                    });\n                }\n            });\n        }\n        this.dialogSelectedItem = null;\n        this.isDialogVisible = true;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: true\n        });\n    }\n\n    onSelectionChange(item: any) {\n        this.dialogSelectedItem = item;\n    }\n\n    onCaptionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_CAPTION_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    onColumnActionCmpInst(instance: any) {\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.TABLE_COLUMN_ACTIONS_COMPONENT_INSTANCE,\n            captionComponentInstance: instance\n        });\n    }\n\n    clear() {\n        this.formControl!.setValue(undefined);\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    hideDialog() {\n        this.isDialogVisible = false;\n\n        this.descriptor.nextEvent(MngFormFieldEventTypeEnum.Dialog, MngFormlyFieldLookupDialogComponent, this, {\n            eventSubtype: MngFormFieldEventDialogSubtype.VISIBILITY,\n            dialogVisible: false\n        });\n    }\n\n    addItem() {\n        this.formControl!.setValue(this.dialogSelectedItem);\n        this.dialogSelectedItem = null;\n        this.dialogAreItemsLoaded = false;\n        this.hideDialog();\n    }\n\n    private setFieldLabelValue(value: T) {\n        if (!value) {\n            this.fieldLabelFormControl.setValue('');\n            return;\n        }\n        if (typeof value === 'object') {\n            const labelProperty = this.descriptor.itemsLabelProperty ?? this.descriptor.dialogTableDescriptor?.model.titlePropertyName;\n            if (!labelProperty) {\n                throw new Error('Could not determine label property.');\n            }\n            this.fieldLabelFormControl.setValue(value[labelProperty as keyof object]);\n        } else {\n            this.fieldLabelFormControl.setValue(value);\n        }\n    }\n}\n","<div [class]=\"'p-inputgroup mng-dropdown-dialog' + descriptor.inputClassName\" [class.p-inputtext-sm]=\"descriptor.isSizeSmall\" [class.p-inputtext-lg]=\"descriptor.isSizeLarge\">\n    <input pInputText type=\"text\" [id]=\"$any(key)\" [readonly]=\"true\" [formlyAttributes]=\"field\" [formControl]=\"fieldLabelFormControl\" />\n    <i class=\"mng-dropdown-clear-icon pi pi-times\" (click)=\"clear()\" *ngIf=\"!to.required && formControl?.value\"></i>\n    <button pButton pRipple class=\"mng-dropdown-dialog-search-button\" type=\"button\" [label]=\"'general.search' | translate: {item: ''}\" (click)=\"openSelectDialog()\"></button>\n</div>\n\n<p-dialog\n    [(visible)]=\"isDialogVisible\"\n    [draggable]=\"false\"\n    [header]=\"'general.search' | translate: {item: to?.label!}\"\n    [modal]=\"true\"\n    appendTo=\"body\"\n    styleClass=\"p-fluid mng-formly-field-lookup-dialog\">\n    <ng-template pTemplate=\"content\">\n        <mng-table\n            [descriptor]=\"descriptor.dialogTableDescriptor!\"\n            [dataProvider]=\"descriptor.dialogTableDataProvider\"\n            [queryResult]=\"addItemsAsync\"\n            [selectionEnabled]=\"true\"\n            [selectionMode]=\"'single'\"\n            [loading]=\"dialogIsLoading$\"\n            [captionComponent]=\"config?.table?.captionComponent\"\n            [columnActionComponent]=\"config?.table?.columnActionComponent\"\n            (selectionChange)=\"onSelectionChange($event)\"\n            (captionComponentInstance)=\"onCaptionCmpInst($event)\"\n            (columnActionComponentInstance)=\"onColumnActionCmpInst($event)\">\n        </mng-table>\n        <p-messages [value]=\"dialogMessages\"></p-messages>\n    </ng-template>\n\n    <ng-template pTemplate=\"footer\">\n        <button pButton pRipple type=\"button\" [label]=\"'general.cancel' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"hideDialog()\"></button>\n        <button\n            pButton\n            pRipple\n            type=\"button\"\n            [label]=\"'general.select' | translate\"\n            icon=\"pi pi-check\"\n            class=\"p-button-text\"\n            (click)=\"addItem()\"\n            [loading]=\"(dialogIsLoading$ | async) ?? false\"\n            [disabled]=\"form.disabled\"></button>\n    </ng-template>\n</p-dialog>\n"]}
@@ -38,7 +38,7 @@ export class MngMainLayoutComponent {
38
38
  }
39
39
  }
40
40
  MngMainLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngMainLayoutComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.MngCommonsService }, { token: i3.MngMainLayoutComponentService }], target: i0.ɵɵFactoryTarget.Component });
41
- MngMainLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngMainLayoutComponent, selector: "mng-main-layout", host: { listeners: { "window:resize": "onWindowResize($event)" } }, providers: [MngMainLayoutComponentService], viewQueries: [{ propertyName: "templates", predicate: MngTemplateDirective, descendants: true }], ngImport: i0, template: "<div\n class=\"layout-wrapper\"\n (click)=\"mainLayoutService.onLayoutClick()\"\n [ngClass]=\"{\n 'layout-static': mngCommons.menuModeIsStatic$ | async,\n 'layout-overlay': mngCommons.menuModeIsOverlay$ | async,\n 'layout-slim': mngCommons.menuModeIsSlim$ | async,\n 'layout-sidebar': mngCommons.menuModeIsSidebar$ | async,\n 'layout-sidebar-static': (mngCommons.menuModeIsSidebar$ | async) && (mainLayoutService.sidebarStatic$ | async),\n 'layout-overlay-active': mainLayoutService.overlayMenuActive$ | async,\n 'layout-mobile-active': mainLayoutService.staticMenuMobileActive$ | async,\n 'layout-static-inactive': (mainLayoutService.staticMenuDesktopInactive$ | async) && (mngCommons.menuModeIsStatic$ | async)\n }\">\n <div class=\"layout-main\">\n <ng-container [mngComponent]=\"topbarComponent\"></ng-container>\n\n <ng-container\n *ngIf=\"\n (mainLayoutService.isMobile$ | async) === false &&\n ((mngCommons.menuModeIsStatic$ | async) || (mngCommons.menuModeIsSlim$ | async) || (mngCommons.menuModeIsSidebar$ | async))\n \"\n [mngComponent]=\"menuComponent\">\n </ng-container>\n\n <div class=\"layout-main-content\">\n <router-outlet></router-outlet>\n </div>\n\n <ng-container [mngComponent]=\"footerComponent\"></ng-container>\n </div>\n</div>\n", directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent"], outputs: ["instanceCreated"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], pipes: { "async": i4.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
41
+ MngMainLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngMainLayoutComponent, selector: "mng-main-layout", host: { listeners: { "window:resize": "onWindowResize($event)" } }, providers: [MngMainLayoutComponentService], viewQueries: [{ propertyName: "templates", predicate: MngTemplateDirective, descendants: true }], ngImport: i0, template: "<div\n class=\"layout-wrapper\"\n (click)=\"mainLayoutService.onLayoutClick()\"\n [ngClass]=\"{\n 'layout-static': mngCommons.menuModeIsStatic$ | async,\n 'layout-overlay': mngCommons.menuModeIsOverlay$ | async,\n 'layout-slim': mngCommons.menuModeIsSlim$ | async,\n 'layout-sidebar': mngCommons.menuModeIsSidebar$ | async,\n 'layout-sidebar-static': (mngCommons.menuModeIsSidebar$ | async) && (mainLayoutService.sidebarStatic$ | async),\n 'layout-overlay-active': mainLayoutService.overlayMenuActive$ | async,\n 'layout-mobile-active': mainLayoutService.staticMenuMobileActive$ | async,\n 'layout-static-inactive': (mainLayoutService.staticMenuDesktopInactive$ | async) && (mngCommons.menuModeIsStatic$ | async)\n }\">\n <div class=\"layout-main\">\n <ng-container [mngComponent]=\"topbarComponent\"></ng-container>\n\n <ng-container\n *ngIf=\"\n (mainLayoutService.isMobile$ | async) === false &&\n ((mngCommons.menuModeIsStatic$ | async) || (mngCommons.menuModeIsSlim$ | async) || (mngCommons.menuModeIsSidebar$ | async))\n \"\n [mngComponent]=\"menuComponent\">\n </ng-container>\n\n <div class=\"layout-main-content\">\n <router-outlet></router-outlet>\n </div>\n\n <ng-container [mngComponent]=\"footerComponent\"></ng-container>\n </div>\n</div>\n", directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }], pipes: { "async": i4.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
42
42
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngMainLayoutComponent, decorators: [{
43
43
  type: Component,
44
44
  args: [{ selector: 'mng-main-layout', providers: [MngMainLayoutComponentService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"layout-wrapper\"\n (click)=\"mainLayoutService.onLayoutClick()\"\n [ngClass]=\"{\n 'layout-static': mngCommons.menuModeIsStatic$ | async,\n 'layout-overlay': mngCommons.menuModeIsOverlay$ | async,\n 'layout-slim': mngCommons.menuModeIsSlim$ | async,\n 'layout-sidebar': mngCommons.menuModeIsSidebar$ | async,\n 'layout-sidebar-static': (mngCommons.menuModeIsSidebar$ | async) && (mainLayoutService.sidebarStatic$ | async),\n 'layout-overlay-active': mainLayoutService.overlayMenuActive$ | async,\n 'layout-mobile-active': mainLayoutService.staticMenuMobileActive$ | async,\n 'layout-static-inactive': (mainLayoutService.staticMenuDesktopInactive$ | async) && (mngCommons.menuModeIsStatic$ | async)\n }\">\n <div class=\"layout-main\">\n <ng-container [mngComponent]=\"topbarComponent\"></ng-container>\n\n <ng-container\n *ngIf=\"\n (mainLayoutService.isMobile$ | async) === false &&\n ((mngCommons.menuModeIsStatic$ | async) || (mngCommons.menuModeIsSlim$ | async) || (mngCommons.menuModeIsSidebar$ | async))\n \"\n [mngComponent]=\"menuComponent\">\n </ng-container>\n\n <div class=\"layout-main-content\">\n <router-outlet></router-outlet>\n </div>\n\n <ng-container [mngComponent]=\"footerComponent\"></ng-container>\n </div>\n</div>\n" }]
@@ -47,7 +47,7 @@ export class MngTopbarComponent {
47
47
  }
48
48
  }
49
49
  MngTopbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTopbarComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.MngCommonsService }, { token: i3.MngMainLayoutComponentService }], target: i0.ɵɵFactoryTarget.Component });
50
- MngTopbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTopbarComponent, selector: "mng-topbar", viewQueries: [{ propertyName: "templates", predicate: MngTemplateDirective, descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\n <div class=\"layout-topbar-left\">\n <a\n href=\"#\"\n class=\"topbar-menu-button\"\n (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n <i class=\"pi pi-bars\"></i>\n </a>\n\n <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n </div>\n\n <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n <div class=\"layout-topbar-right\">\n <ul class=\"layout-topbar-right-items\">\n <li #profile class=\"profile-item\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n <a href=\"#\" (click)=\"mainLayoutService.onTopbarItemClick($event, profile)\">\n <i class=\"pi pi-fw pi-user\"></i>\n </a>\n <ul class=\"fadeInDown\" *ngIf=\"user\">\n <li role=\"menuitem\">\n <a>\n {{ user?.displayName ?? user?.username }}\n </a>\n </li>\n <li role=\"menuitem\" *ngIf=\"user?.logout || user?.logoutUrl\">\n <a [href]=\"user?.logoutUrl\" (click)=\"logout(user, $event)\">\n <i class=\"pi pi-fw pi-sign-out\"></i>\n <span>{{ 'mngTopbar.logout' | translate }}</span>\n </a>\n </li>\n </ul>\n </li>\n <li *ngIf=\"languages.length > 1\" class=\"profile-item\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n <i class=\"pi pi-fw pi-globe\"></i>\n <p-dropdown [ngModel]=\"selectedLanguage\" [options]=\"languages\" (onChange)=\"switchLanguage($event.value)\"></p-dropdown>\n </li>\n </ul>\n </div>\n</div>\n", components: [{ type: i4.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent"], outputs: ["instanceCreated"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "async": i5.AsyncPipe, "translate": i8.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
50
+ MngTopbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTopbarComponent, selector: "mng-topbar", viewQueries: [{ propertyName: "templates", predicate: MngTemplateDirective, descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\n <div class=\"layout-topbar-left\">\n <a\n href=\"#\"\n class=\"topbar-menu-button\"\n (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n <i class=\"pi pi-bars\"></i>\n </a>\n\n <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n </div>\n\n <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n <div class=\"layout-topbar-right\">\n <ul class=\"layout-topbar-right-items\">\n <li #profile class=\"profile-item\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n <a href=\"#\" (click)=\"mainLayoutService.onTopbarItemClick($event, profile)\">\n <i class=\"pi pi-fw pi-user\"></i>\n </a>\n <ul class=\"fadeInDown\" *ngIf=\"user\">\n <li role=\"menuitem\">\n <a>\n {{ user?.displayName ?? user?.username }}\n </a>\n </li>\n <li role=\"menuitem\" *ngIf=\"user?.logout || user?.logoutUrl\">\n <a [href]=\"user?.logoutUrl\" (click)=\"logout(user, $event)\">\n <i class=\"pi pi-fw pi-sign-out\"></i>\n <span>{{ 'mngTopbar.logout' | translate }}</span>\n </a>\n </li>\n </ul>\n </li>\n <li *ngIf=\"languages.length > 1\" class=\"profile-item\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n <i class=\"pi pi-fw pi-globe\"></i>\n <p-dropdown [ngModel]=\"selectedLanguage\" [options]=\"languages\" (onChange)=\"switchLanguage($event.value)\"></p-dropdown>\n </li>\n </ul>\n </div>\n</div>\n", components: [{ type: i4.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "async": i5.AsyncPipe, "translate": i8.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
51
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTopbarComponent, decorators: [{
52
52
  type: Component,
53
53
  args: [{ selector: 'mng-topbar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-topbar\">\n <div class=\"layout-topbar-left\">\n <a\n href=\"#\"\n class=\"topbar-menu-button\"\n (click)=\"mainLayoutService.onMenuButtonClick($event)\"\n *ngIf=\"(mngCommons.menuModeIsOverlay$ | async) || (mainLayoutService.isMobile$ | async)\">\n <i class=\"pi pi-bars\"></i>\n </a>\n\n <ng-container [mngComponent]=\"breadcrumbComponent\"></ng-container>\n </div>\n\n <ng-container [mngComponent]=\"menuComponent\"></ng-container>\n\n <div class=\"layout-topbar-right\">\n <ul class=\"layout-topbar-right-items\">\n <li #profile class=\"profile-item\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n <a href=\"#\" (click)=\"mainLayoutService.onTopbarItemClick($event, profile)\">\n <i class=\"pi pi-fw pi-user\"></i>\n </a>\n <ul class=\"fadeInDown\" *ngIf=\"user\">\n <li role=\"menuitem\">\n <a>\n {{ user?.displayName ?? user?.username }}\n </a>\n </li>\n <li role=\"menuitem\" *ngIf=\"user?.logout || user?.logoutUrl\">\n <a [href]=\"user?.logoutUrl\" (click)=\"logout(user, $event)\">\n <i class=\"pi pi-fw pi-sign-out\"></i>\n <span>{{ 'mngTopbar.logout' | translate }}</span>\n </a>\n </li>\n </ul>\n </li>\n <li *ngIf=\"languages.length > 1\" class=\"profile-item\" [ngClass]=\"{'active-topmenuitem': (mainLayoutService.activeTopbarItem$ | async) === profile}\">\n <i class=\"pi pi-fw pi-globe\"></i>\n <p-dropdown [ngModel]=\"selectedLanguage\" [options]=\"languages\" (onChange)=\"switchLanguage($event.value)\"></p-dropdown>\n </li>\n </ul>\n </div>\n</div>\n" }]
@@ -9,16 +9,28 @@ export class AMngTableviewRouteComponent {
9
9
  }
10
10
  createActionDescriptors() {
11
11
  const actions = [];
12
- actions.push(new ActionEditorDetailsDescriptor(this.descriptor.viewEditor));
13
- actions.push(new ActionEditorAddDescriptor(this.descriptor.addEditor));
14
- actions.push(new ActionEditorEditDescriptor(this.descriptor.editEditor));
15
- actions.push(new ActionDeleteDescriptor(this.descriptor.model));
12
+ actions.push(this.createActionDescriptorForDetails());
13
+ actions.push(this.createActionDescriptorForAdd());
14
+ actions.push(this.createActionDescriptorForEdit());
15
+ actions.push(this.createActionDescriptorForDelete());
16
16
  return actions;
17
17
  }
18
+ createActionDescriptorForDetails(descriptor = this.descriptor.viewEditor) {
19
+ return new ActionEditorDetailsDescriptor(descriptor);
20
+ }
21
+ createActionDescriptorForAdd(descriptor = this.descriptor.addEditor) {
22
+ return new ActionEditorAddDescriptor(descriptor);
23
+ }
24
+ createActionDescriptorForEdit(descriptor = this.descriptor.editEditor) {
25
+ return new ActionEditorEditDescriptor(descriptor);
26
+ }
27
+ createActionDescriptorForDelete(descriptor = this.descriptor.model) {
28
+ return new ActionDeleteDescriptor(descriptor);
29
+ }
18
30
  }
19
31
  AMngTableviewRouteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: AMngTableviewRouteComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
20
32
  AMngTableviewRouteComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.3", type: AMngTableviewRouteComponent, ngImport: i0 });
21
33
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: AMngTableviewRouteComponent, decorators: [{
22
34
  type: Directive
23
35
  }] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGV2aWV3LXJvdXRlLmFic3RyYWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXZpZXcvcm91dGUvdGFibGV2aWV3LXJvdXRlLmFic3RyYWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBR2hELE9BQU8sRUFDSCxzQkFBc0IsRUFFdEIseUJBQXlCLEVBQ3pCLDZCQUE2QixFQUM3QiwwQkFBMEIsRUFFN0IsTUFBTSxzQkFBc0IsQ0FBQzs7QUFHOUIsTUFBTSxPQUFnQiwyQkFBMkI7SUFLdEMsUUFBUTtRQUNYLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixFQUFFLENBQUM7UUFDbkQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsMkJBQTJCLEVBQUUsQ0FBQztRQUN2RCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO0lBQ2xELENBQUM7SUFLUyx1QkFBdUI7UUFDN0IsTUFBTSxPQUFPLEdBQStCLEVBQUUsQ0FBQztRQUMvQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksNkJBQTZCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQzVFLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDdkUsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLDBCQUEwQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztRQUN6RSxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksc0JBQXNCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ2hFLE9BQU8sT0FBTyxDQUFDO0lBQ25CLENBQUM7O3dIQXJCaUIsMkJBQTJCOzRHQUEzQiwyQkFBMkI7MkZBQTNCLDJCQUEyQjtrQkFEaEQsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge0lUYWJsZXZpZXdEYXRhUHJvdmlkZXJ9IGZyb20gJy4uLy4uLy4uL2RhdGEtcHJvdmlkZXJzJztcbmltcG9ydCB7XG4gICAgQWN0aW9uRGVsZXRlRGVzY3JpcHRvcixcbiAgICBBY3Rpb25EZXNjcmlwdG9yLFxuICAgIEFjdGlvbkVkaXRvckFkZERlc2NyaXB0b3IsXG4gICAgQWN0aW9uRWRpdG9yRGV0YWlsc0Rlc2NyaXB0b3IsXG4gICAgQWN0aW9uRWRpdG9yRWRpdERlc2NyaXB0b3IsXG4gICAgVGFibGV2aWV3RGVzY3JpcHRvclxufSBmcm9tICcuLi8uLi8uLi9kZXNjcmlwdG9ycyc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFNbmdUYWJsZXZpZXdSb3V0ZUNvbXBvbmVudDxULCBTPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgcHVibGljIGRlc2NyaXB0b3IhOiBUYWJsZXZpZXdEZXNjcmlwdG9yPFQ+O1xuICAgIHB1YmxpYyBkYXRhUHJvdmlkZXIhOiBJVGFibGV2aWV3RGF0YVByb3ZpZGVyPFQsIFM+O1xuICAgIHB1YmxpYyBhY3Rpb25zITogQXJyYXk8QWN0aW9uRGVzY3JpcHRvcjxUPj47XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuZGVzY3JpcHRvciA9IHRoaXMuY3JlYXRlVGFibGV2aWV3RGVzY3JpcHRvcigpO1xuICAgICAgICB0aGlzLmRhdGFQcm92aWRlciA9IHRoaXMuY3JlYXRlVGFibGV2aWV3RGF0YVByb3ZpZGVyKCk7XG4gICAgICAgIHRoaXMuYWN0aW9ucyA9IHRoaXMuY3JlYXRlQWN0aW9uRGVzY3JpcHRvcnMoKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgY3JlYXRlVGFibGV2aWV3RGVzY3JpcHRvcigpOiBUYWJsZXZpZXdEZXNjcmlwdG9yPFQ+O1xuICAgIHByb3RlY3RlZCBhYnN0cmFjdCBjcmVhdGVUYWJsZXZpZXdEYXRhUHJvdmlkZXIoKTogSVRhYmxldmlld0RhdGFQcm92aWRlcjxULCBTPjtcblxuICAgIHByb3RlY3RlZCBjcmVhdGVBY3Rpb25EZXNjcmlwdG9ycygpOiBBcnJheTxBY3Rpb25EZXNjcmlwdG9yPFQ+PiB7XG4gICAgICAgIGNvbnN0IGFjdGlvbnM6IEFycmF5PEFjdGlvbkRlc2NyaXB0b3I8VD4+ID0gW107XG4gICAgICAgIGFjdGlvbnMucHVzaChuZXcgQWN0aW9uRWRpdG9yRGV0YWlsc0Rlc2NyaXB0b3IodGhpcy5kZXNjcmlwdG9yLnZpZXdFZGl0b3IpKTtcbiAgICAgICAgYWN0aW9ucy5wdXNoKG5ldyBBY3Rpb25FZGl0b3JBZGREZXNjcmlwdG9yKHRoaXMuZGVzY3JpcHRvci5hZGRFZGl0b3IpKTtcbiAgICAgICAgYWN0aW9ucy5wdXNoKG5ldyBBY3Rpb25FZGl0b3JFZGl0RGVzY3JpcHRvcih0aGlzLmRlc2NyaXB0b3IuZWRpdEVkaXRvcikpO1xuICAgICAgICBhY3Rpb25zLnB1c2gobmV3IEFjdGlvbkRlbGV0ZURlc2NyaXB0b3IodGhpcy5kZXNjcmlwdG9yLm1vZGVsKSk7XG4gICAgICAgIHJldHVybiBhY3Rpb25zO1xuICAgIH1cbn1cbiJdfQ==
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGV2aWV3LXJvdXRlLmFic3RyYWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXZpZXcvcm91dGUvdGFibGV2aWV3LXJvdXRlLmFic3RyYWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBR2hELE9BQU8sRUFDSCxzQkFBc0IsRUFFdEIseUJBQXlCLEVBQ3pCLDZCQUE2QixFQUM3QiwwQkFBMEIsRUFJN0IsTUFBTSxzQkFBc0IsQ0FBQzs7QUFHOUIsTUFBTSxPQUFnQiwyQkFBMkI7SUFLdEMsUUFBUTtRQUNYLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixFQUFFLENBQUM7UUFDbkQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsMkJBQTJCLEVBQUUsQ0FBQztRQUN2RCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO0lBQ2xELENBQUM7SUFNUyx1QkFBdUI7UUFDN0IsTUFBTSxPQUFPLEdBQStCLEVBQUUsQ0FBQztRQUMvQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxnQ0FBZ0MsRUFBRSxDQUFDLENBQUM7UUFDdEQsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsNEJBQTRCLEVBQUUsQ0FBQyxDQUFDO1FBQ2xELE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLDZCQUE2QixFQUFFLENBQUMsQ0FBQztRQUNuRCxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQywrQkFBK0IsRUFBRSxDQUFDLENBQUM7UUFDckQsT0FBTyxPQUFPLENBQUM7SUFDbkIsQ0FBQztJQUVTLGdDQUFnQyxDQUFDLGFBQWtDLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVTtRQUNuRyxPQUFPLElBQUksNkJBQTZCLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVTLDRCQUE0QixDQUFDLGFBQWtDLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUztRQUM5RixPQUFPLElBQUkseUJBQXlCLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVTLDZCQUE2QixDQUFDLGFBQWtDLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVTtRQUNoRyxPQUFPLElBQUksMEJBQTBCLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVTLCtCQUErQixDQUFDLGFBQWlDLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSztRQUM1RixPQUFPLElBQUksc0JBQXNCLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDbEQsQ0FBQzs7d0hBdENpQiwyQkFBMkI7NEdBQTNCLDJCQUEyQjsyRkFBM0IsMkJBQTJCO2tCQURoRCxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7SVRhYmxldmlld0RhdGFQcm92aWRlcn0gZnJvbSAnLi4vLi4vLi4vZGF0YS1wcm92aWRlcnMnO1xuaW1wb3J0IHtcbiAgICBBY3Rpb25EZWxldGVEZXNjcmlwdG9yLFxuICAgIEFjdGlvbkRlc2NyaXB0b3IsXG4gICAgQWN0aW9uRWRpdG9yQWRkRGVzY3JpcHRvcixcbiAgICBBY3Rpb25FZGl0b3JEZXRhaWxzRGVzY3JpcHRvcixcbiAgICBBY3Rpb25FZGl0b3JFZGl0RGVzY3JpcHRvcixcbiAgICBFZGl0b3JEZXNjcmlwdG9yLFxuICAgIE1vZGVsRGVzY3JpcHRvcixcbiAgICBUYWJsZXZpZXdEZXNjcmlwdG9yXG59IGZyb20gJy4uLy4uLy4uL2Rlc2NyaXB0b3JzJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQU1uZ1RhYmxldmlld1JvdXRlQ29tcG9uZW50PFQsIFM+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBwdWJsaWMgZGVzY3JpcHRvciE6IFRhYmxldmlld0Rlc2NyaXB0b3I8VD47XG4gICAgcHVibGljIGRhdGFQcm92aWRlciE6IElUYWJsZXZpZXdEYXRhUHJvdmlkZXI8VCwgUz47XG4gICAgcHVibGljIGFjdGlvbnMhOiBBcnJheTxBY3Rpb25EZXNjcmlwdG9yPFQ+PjtcblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5kZXNjcmlwdG9yID0gdGhpcy5jcmVhdGVUYWJsZXZpZXdEZXNjcmlwdG9yKCk7XG4gICAgICAgIHRoaXMuZGF0YVByb3ZpZGVyID0gdGhpcy5jcmVhdGVUYWJsZXZpZXdEYXRhUHJvdmlkZXIoKTtcbiAgICAgICAgdGhpcy5hY3Rpb25zID0gdGhpcy5jcmVhdGVBY3Rpb25EZXNjcmlwdG9ycygpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBhYnN0cmFjdCBjcmVhdGVUYWJsZXZpZXdEZXNjcmlwdG9yKCk6IFRhYmxldmlld0Rlc2NyaXB0b3I8VD47XG5cbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgY3JlYXRlVGFibGV2aWV3RGF0YVByb3ZpZGVyKCk6IElUYWJsZXZpZXdEYXRhUHJvdmlkZXI8VCwgUz47XG5cbiAgICBwcm90ZWN0ZWQgY3JlYXRlQWN0aW9uRGVzY3JpcHRvcnMoKTogQXJyYXk8QWN0aW9uRGVzY3JpcHRvcjxUPj4ge1xuICAgICAgICBjb25zdCBhY3Rpb25zOiBBcnJheTxBY3Rpb25EZXNjcmlwdG9yPFQ+PiA9IFtdO1xuICAgICAgICBhY3Rpb25zLnB1c2godGhpcy5jcmVhdGVBY3Rpb25EZXNjcmlwdG9yRm9yRGV0YWlscygpKTtcbiAgICAgICAgYWN0aW9ucy5wdXNoKHRoaXMuY3JlYXRlQWN0aW9uRGVzY3JpcHRvckZvckFkZCgpKTtcbiAgICAgICAgYWN0aW9ucy5wdXNoKHRoaXMuY3JlYXRlQWN0aW9uRGVzY3JpcHRvckZvckVkaXQoKSk7XG4gICAgICAgIGFjdGlvbnMucHVzaCh0aGlzLmNyZWF0ZUFjdGlvbkRlc2NyaXB0b3JGb3JEZWxldGUoKSk7XG4gICAgICAgIHJldHVybiBhY3Rpb25zO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBjcmVhdGVBY3Rpb25EZXNjcmlwdG9yRm9yRGV0YWlscyhkZXNjcmlwdG9yOiBFZGl0b3JEZXNjcmlwdG9yPFQ+ID0gdGhpcy5kZXNjcmlwdG9yLnZpZXdFZGl0b3IpOiBBY3Rpb25FZGl0b3JEZXRhaWxzRGVzY3JpcHRvcjxUPiB7XG4gICAgICAgIHJldHVybiBuZXcgQWN0aW9uRWRpdG9yRGV0YWlsc0Rlc2NyaXB0b3IoZGVzY3JpcHRvcik7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGNyZWF0ZUFjdGlvbkRlc2NyaXB0b3JGb3JBZGQoZGVzY3JpcHRvcjogRWRpdG9yRGVzY3JpcHRvcjxUPiA9IHRoaXMuZGVzY3JpcHRvci5hZGRFZGl0b3IpOiBBY3Rpb25FZGl0b3JBZGREZXNjcmlwdG9yPFQ+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBBY3Rpb25FZGl0b3JBZGREZXNjcmlwdG9yKGRlc2NyaXB0b3IpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBjcmVhdGVBY3Rpb25EZXNjcmlwdG9yRm9yRWRpdChkZXNjcmlwdG9yOiBFZGl0b3JEZXNjcmlwdG9yPFQ+ID0gdGhpcy5kZXNjcmlwdG9yLmVkaXRFZGl0b3IpOiBBY3Rpb25FZGl0b3JFZGl0RGVzY3JpcHRvcjxUPiB7XG4gICAgICAgIHJldHVybiBuZXcgQWN0aW9uRWRpdG9yRWRpdERlc2NyaXB0b3IoZGVzY3JpcHRvcik7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGNyZWF0ZUFjdGlvbkRlc2NyaXB0b3JGb3JEZWxldGUoZGVzY3JpcHRvcjogTW9kZWxEZXNjcmlwdG9yPFQ+ID0gdGhpcy5kZXNjcmlwdG9yLm1vZGVsKTogQWN0aW9uRGVsZXRlRGVzY3JpcHRvcjxUPiB7XG4gICAgICAgIHJldHVybiBuZXcgQWN0aW9uRGVsZXRlRGVzY3JpcHRvcihkZXNjcmlwdG9yKTtcbiAgICB9XG59XG4iXX0=
@@ -62,15 +62,6 @@ export class MngTableColumnFilterComponent {
62
62
  // eslint-disable-next-line @typescript-eslint/ban-types
63
63
  autocompleteFilter(value, filterCallback) {
64
64
  filterCallback(value);
65
- // if (value) {
66
- // let filterValue: any = value;
67
- // if (this.lookupDescriptor!.itemsValueProperty) {
68
- // filterValue = filterValue[this.lookupDescriptor!.itemsValueProperty];
69
- // }
70
- // filterCallback(filterValue);
71
- // } else {
72
- // filterCallback(value);
73
- // }
74
65
  }
75
66
  // eslint-disable-next-line @typescript-eslint/ban-types
76
67
  dropdownFilter(value, filterCallback) {
@@ -91,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
91
82
  }], display: [{
92
83
  type: Input
93
84
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-filter.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.ts","../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from '@angular/core';\n\nimport {FilterMatchMode, PrimeNGConfig, SelectItem} from 'primeng/api';\n\nimport {FilterDescriptor, FilterLookupDescriptor, TableDescriptor} from '../../../../descriptors';\n\n/**\n * Cannot be on push change detection strategy because of filter updates triggered from route which causes to force update values in force metadata\n * and these must be propagated through to this component and beyond to primeNG.\n */\n@Component({\n    selector: 'mng-table-column-filter',\n    templateUrl: './column-filter.component.html'\n})\nexport class MngTableColumnFilterComponent<T> implements OnInit {\n    public readonly lookupTypeDropdown: FilterLookupDescriptor.LookupTypeEnum = FilterLookupDescriptor.LookupTypeEnum.Dropdown;\n    public readonly lookupTypeAutocomplete: FilterLookupDescriptor.LookupTypeEnum = FilterLookupDescriptor.LookupTypeEnum.Autocomplete;\n\n    @Input() descriptor!: FilterDescriptor<T>;\n    @Input() display!: TableDescriptor.FilterDisplayEnum;\n\n    public lookupDescriptor?: FilterLookupDescriptor<T>;\n\n    public primeField!: string;\n    public primeType = 'text';\n    public primeShowMatchMode = true;\n    public primeDefaultMatchMode: string = FilterMatchMode.EQUALS;\n    public primeDisplay = 'row';\n    public primeMatchModes: SelectItem[] | null = null;\n\n    constructor(private primeConfig: PrimeNGConfig) {}\n\n    ngOnInit() {\n        switch (this.descriptor.filterType) {\n            case FilterDescriptor.TypeEnum.Boolean:\n                this.primeType = 'boolean';\n                this.primeShowMatchMode = false;\n                break;\n            case FilterDescriptor.TypeEnum.Number:\n                this.primeType = 'numeric';\n                break;\n            case FilterDescriptor.TypeEnum.Date:\n                this.primeType = 'date';\n                break;\n            case FilterDescriptor.TypeEnum.Lookup:\n                this.primeType = 'lookup';\n                this.primeShowMatchMode = false;\n                this.lookupDescriptor = this.descriptor as FilterLookupDescriptor<T>;\n                this.primeField = `${this.descriptor.property}${this.lookupDescriptor.itemsValueProperty ? `.${this.lookupDescriptor.itemsValueProperty}` : ''}`;\n                this.primeMatchModes = [{value: FilterDescriptor.MatchModeEnum.Equals, label: this.primeConfig.getTranslation(FilterDescriptor.MatchModeEnum.Equals)}];\n                break;\n            case FilterDescriptor.TypeEnum.String:\n                this.primeType = 'text';\n                this.primeDefaultMatchMode = FilterMatchMode.CONTAINS;\n                break;\n        }\n\n        if (this.descriptor.matchModes) {\n            this.primeMatchModes = this.descriptor.matchModes.map(mm => <SelectItem>{value: mm, label: this.primeConfig.getTranslation(mm)});\n            this.primeDefaultMatchMode = this.descriptor.matchModes[0];\n            this.primeShowMatchMode = this.primeMatchModes?.length > 1;\n        }\n\n        switch (this.display) {\n            case TableDescriptor.FilterDisplayEnum.Menu:\n                this.primeDisplay = 'menu';\n                break;\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    autocompleteFilter(value: T, filterCallback: Function) {\n        filterCallback(value);\n        // if (value) {\n        //     let filterValue: any = value;\n        //     if (this.lookupDescriptor!.itemsValueProperty) {\n        //         filterValue = filterValue[this.lookupDescriptor!.itemsValueProperty];\n        //     }\n        //     filterCallback(filterValue);\n        // } else {\n        //     filterCallback(value);\n        // }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    dropdownFilter(value: T, filterCallback: Function) {\n        filterCallback(value);\n    }\n\n    toLookupFilterValue(value?: any) {\n        console.log(this.descriptor.property, value);\n        return this.lookupDescriptor!.dataKeyProperty && value ? {[this.lookupDescriptor!.dataKeyProperty]: value} : value;\n    }\n}\n","<p-columnFilter\n    class=\"ml-auto\"\n    [type]=\"primeType\"\n    matchMode=\"equals\"\n    [field]=\"descriptor.property\"\n    [display]=\"primeDisplay\"\n    [matchMode]=\"primeDefaultMatchMode\"\n    [matchModeOptions]=\"$any(primeMatchModes)\"\n    [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n    [showMatchModes]=\"true\"\n    [showOperator]=\"false\"\n    [showAddButton]=\"false\"\n    [hideOnClear]=\"true\">\n    <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n        <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n            <mng-autocomplete\n                *ngSwitchCase=\"lookupTypeAutocomplete\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n                [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n            </mng-autocomplete>\n            <mng-dropdown\n                *ngSwitchCase=\"lookupTypeDropdown\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                [showClear]=\"true\"\n                (valueChange)=\"dropdownFilter($event, filterCallback)\">\n            </mng-dropdown>\n        </ng-container>\n    </ng-template>\n</p-columnFilter>\n"]}
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-filter.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.ts","../../../../../../../src/lib/components/tableview/table/column-filter/column-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from '@angular/core';\n\nimport {FilterMatchMode, PrimeNGConfig, SelectItem} from 'primeng/api';\n\nimport {FilterDescriptor, FilterLookupDescriptor, TableDescriptor} from '../../../../descriptors';\n\n/**\n * Cannot be on push change detection strategy because of filter updates triggered from route which causes to force update values in force metadata\n * and these must be propagated through to this component and beyond to primeNG.\n */\n@Component({\n    selector: 'mng-table-column-filter',\n    templateUrl: './column-filter.component.html'\n})\nexport class MngTableColumnFilterComponent<T> implements OnInit {\n    public readonly lookupTypeDropdown: FilterLookupDescriptor.LookupTypeEnum = FilterLookupDescriptor.LookupTypeEnum.Dropdown;\n    public readonly lookupTypeAutocomplete: FilterLookupDescriptor.LookupTypeEnum = FilterLookupDescriptor.LookupTypeEnum.Autocomplete;\n\n    @Input() descriptor!: FilterDescriptor<T>;\n    @Input() display!: TableDescriptor.FilterDisplayEnum;\n\n    public lookupDescriptor?: FilterLookupDescriptor<T>;\n\n    public primeField!: string;\n    public primeType = 'text';\n    public primeShowMatchMode = true;\n    public primeDefaultMatchMode: string = FilterMatchMode.EQUALS;\n    public primeDisplay = 'row';\n    public primeMatchModes: SelectItem[] | null = null;\n\n    constructor(private primeConfig: PrimeNGConfig) {}\n\n    ngOnInit() {\n        switch (this.descriptor.filterType) {\n            case FilterDescriptor.TypeEnum.Boolean:\n                this.primeType = 'boolean';\n                this.primeShowMatchMode = false;\n                break;\n            case FilterDescriptor.TypeEnum.Number:\n                this.primeType = 'numeric';\n                break;\n            case FilterDescriptor.TypeEnum.Date:\n                this.primeType = 'date';\n                break;\n            case FilterDescriptor.TypeEnum.Lookup:\n                this.primeType = 'lookup';\n                this.primeShowMatchMode = false;\n                this.lookupDescriptor = this.descriptor as FilterLookupDescriptor<T>;\n                this.primeField = `${this.descriptor.property}${this.lookupDescriptor.itemsValueProperty ? `.${this.lookupDescriptor.itemsValueProperty}` : ''}`;\n                this.primeMatchModes = [{value: FilterDescriptor.MatchModeEnum.Equals, label: this.primeConfig.getTranslation(FilterDescriptor.MatchModeEnum.Equals)}];\n                break;\n            case FilterDescriptor.TypeEnum.String:\n                this.primeType = 'text';\n                this.primeDefaultMatchMode = FilterMatchMode.CONTAINS;\n                break;\n        }\n\n        if (this.descriptor.matchModes) {\n            this.primeMatchModes = this.descriptor.matchModes.map(mm => <SelectItem>{value: mm, label: this.primeConfig.getTranslation(mm)});\n            this.primeDefaultMatchMode = this.descriptor.matchModes[0];\n            this.primeShowMatchMode = this.primeMatchModes?.length > 1;\n        }\n\n        switch (this.display) {\n            case TableDescriptor.FilterDisplayEnum.Menu:\n                this.primeDisplay = 'menu';\n                break;\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    autocompleteFilter(value: T, filterCallback: Function) {\n        filterCallback(value);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    dropdownFilter(value: T, filterCallback: Function) {\n        filterCallback(value);\n    }\n\n    toLookupFilterValue(value?: any) {\n        console.log(this.descriptor.property, value);\n        return this.lookupDescriptor!.dataKeyProperty && value ? {[this.lookupDescriptor!.dataKeyProperty]: value} : value;\n    }\n}\n","<p-columnFilter\n    class=\"ml-auto\"\n    [type]=\"primeType\"\n    matchMode=\"equals\"\n    [field]=\"descriptor.property\"\n    [display]=\"primeDisplay\"\n    [matchMode]=\"primeDefaultMatchMode\"\n    [matchModeOptions]=\"$any(primeMatchModes)\"\n    [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n    [showMatchModes]=\"true\"\n    [showOperator]=\"false\"\n    [showAddButton]=\"false\"\n    [hideOnClear]=\"true\">\n    <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n        <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n            <mng-autocomplete\n                *ngSwitchCase=\"lookupTypeAutocomplete\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n                [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n            </mng-autocomplete>\n            <mng-dropdown\n                *ngSwitchCase=\"lookupTypeDropdown\"\n                [ngModel]=\"value\"\n                [dataProvider]=\"lookupDescriptor.dataProvider\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                [showClear]=\"true\"\n                (valueChange)=\"dropdownFilter($event, filterCallback)\">\n            </mng-dropdown>\n        </ng-container>\n    </ng-template>\n</p-columnFilter>\n"]}
@@ -2,10 +2,11 @@ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
2
  import { ColumnDescriptor } from '../../../../descriptors';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
5
- import * as i2 from "../../../../pipes/property-path.pipe";
6
- import * as i3 from "../../../../pipes/boolean.pipe";
7
- import * as i4 from "@ngx-translate/core";
8
- import * as i5 from "../../../../pipes/enum.pipe";
5
+ import * as i2 from "../../../../directives/component.directive";
6
+ import * as i3 from "../../../../pipes/json-path.pipe";
7
+ import * as i4 from "../../../../pipes/boolean.pipe";
8
+ import * as i5 from "@ngx-translate/core";
9
+ import * as i6 from "../../../../pipes/enum.pipe";
9
10
  export class MngTableColumnValueComponent {
10
11
  constructor() {
11
12
  this.columnTypeString = ColumnDescriptor.TypeEnum.String;
@@ -13,16 +14,29 @@ export class MngTableColumnValueComponent {
13
14
  this.columnTypeBoolean = ColumnDescriptor.TypeEnum.Boolean;
14
15
  this.columnTypeDate = ColumnDescriptor.TypeEnum.Date;
15
16
  this.columnTypeEnum = ColumnDescriptor.TypeEnum.Enum;
17
+ this.columnTypeCustom = ColumnDescriptor.TypeEnum.Custom;
18
+ this.jsonPath = '$';
19
+ }
20
+ ngOnInit() {
21
+ if (this.descriptor.jsonPath) {
22
+ this.jsonPath = this.descriptor.jsonPath;
23
+ }
24
+ else {
25
+ this.jsonPath = `$.${this.descriptor.property}`;
26
+ if (this.descriptor.objectModelType) {
27
+ this.jsonPath = `$.${this.descriptor.property}.${this.descriptor.objectTitleProperty}`;
28
+ }
29
+ }
16
30
  }
17
31
  }
18
32
  MngTableColumnValueComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnValueComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
19
- MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnValueComponent, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property] }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | number: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | 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[descriptor.property] | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n <ng-template #booleanText>\n {{\n (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property])\n | boolean: descriptor.booleanYes:descriptor.booleanNo\n | translate\n }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{\n (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property])\n | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue\n | translate\n }}\n </ng-container>\n</ng-container>\n", directives: [{ type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "propertyPath": i2.MngPropertyPathPipe, "number": i1.DecimalPipe, "date": i1.DatePipe, "boolean": i3.MngBooleanPipe, "translate": i4.TranslatePipe, "enum": i5.MngEnumPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
33
+ MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnValueComponent, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, 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 }}\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", directives: [{ type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }], pipes: { "jsonPath": i3.JsonPathPipe, "number": i1.DecimalPipe, "date": i1.DatePipe, "boolean": i4.MngBooleanPipe, "translate": i5.TranslatePipe, "enum": i6.MngEnumPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
20
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnValueComponent, decorators: [{
21
35
  type: Component,
22
- args: [{ selector: 'mng-table-column-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property] }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | number: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | 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[descriptor.property] | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n <ng-template #booleanText>\n {{\n (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property])\n | boolean: descriptor.booleanYes:descriptor.booleanNo\n | translate\n }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{\n (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property])\n | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue\n | translate\n }}\n </ng-container>\n</ng-container>\n" }]
36
+ 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 }}\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" }]
23
37
  }], propDecorators: { descriptor: [{
24
38
  type: Input
25
39
  }], item: [{
26
40
  type: Input
27
41
  }] } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLXZhbHVlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXZpZXcvdGFibGUvY29sdW1uLXZhbHVlL2NvbHVtbi12YWx1ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdGFibGV2aWV3L3RhYmxlL2NvbHVtbi12YWx1ZS9jb2x1bW4tdmFsdWUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFeEUsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0seUJBQXlCLENBQUM7Ozs7Ozs7QUFPekQsTUFBTSxPQUFPLDRCQUE0QjtJQUx6QztRQU1vQixxQkFBZ0IsR0FBOEIsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQztRQUMvRSxxQkFBZ0IsR0FBOEIsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQztRQUMvRSxzQkFBaUIsR0FBOEIsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQztRQUNqRixtQkFBYyxHQUE4QixnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQzNFLG1CQUFjLEdBQThCLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7S0FJOUY7O3lIQVRZLDRCQUE0Qjs2R0FBNUIsNEJBQTRCLGtIQ1R6Qyxtc0RBNkJBOzJGRHBCYSw0QkFBNEI7a0JBTHhDLFNBQVM7K0JBQ0ksd0JBQXdCLG1CQUVqQix1QkFBdUIsQ0FBQyxNQUFNOzhCQVN0QyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge0NvbHVtbkRlc2NyaXB0b3J9IGZyb20gJy4uLy4uLy4uLy4uL2Rlc2NyaXB0b3JzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdtbmctdGFibGUtY29sdW1uLXZhbHVlJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY29sdW1uLXZhbHVlLmNvbXBvbmVudC5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBNbmdUYWJsZUNvbHVtblZhbHVlQ29tcG9uZW50PFQsIFRUPiB7XG4gICAgcHVibGljIHJlYWRvbmx5IGNvbHVtblR5cGVTdHJpbmc6IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0gPSBDb2x1bW5EZXNjcmlwdG9yLlR5cGVFbnVtLlN0cmluZztcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29sdW1uVHlwZU51bWJlcjogQ29sdW1uRGVzY3JpcHRvci5UeXBlRW51bSA9IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0uTnVtYmVyO1xuICAgIHB1YmxpYyByZWFkb25seSBjb2x1bW5UeXBlQm9vbGVhbjogQ29sdW1uRGVzY3JpcHRvci5UeXBlRW51bSA9IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0uQm9vbGVhbjtcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29sdW1uVHlwZURhdGU6IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0gPSBDb2x1bW5EZXNjcmlwdG9yLlR5cGVFbnVtLkRhdGU7XG4gICAgcHVibGljIHJlYWRvbmx5IGNvbHVtblR5cGVFbnVtOiBDb2x1bW5EZXNjcmlwdG9yLlR5cGVFbnVtID0gQ29sdW1uRGVzY3JpcHRvci5UeXBlRW51bS5FbnVtO1xuXG4gICAgQElucHV0KCkgZGVzY3JpcHRvciE6IENvbHVtbkRlc2NyaXB0b3I8VCwgVFQ+O1xuICAgIEBJbnB1dCgpIGl0ZW0hOiBhbnk7XG59XG4iLCI8bmctY29udGFpbmVyIFtuZ1N3aXRjaF09XCJkZXNjcmlwdG9yLmNvbHVtblR5cGVcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJjb2x1bW5UeXBlU3RyaW5nXCI+XG4gICAgICAgIHt7IGRlc2NyaXB0b3IuZGlzcGxheVByb3BlcnR5UGF0aCA/IChpdGVtIHwgcHJvcGVydHlQYXRoOiBkZXNjcmlwdG9yLmRpc3BsYXlQcm9wZXJ0eVBhdGgpIDogaXRlbVtkZXNjcmlwdG9yLnByb3BlcnR5XSB9fVxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cImNvbHVtblR5cGVOdW1iZXJcIj5cbiAgICAgICAge3sgKGRlc2NyaXB0b3IuZGlzcGxheVByb3BlcnR5UGF0aCA/IChpdGVtIHwgcHJvcGVydHlQYXRoOiBkZXNjcmlwdG9yLmRpc3BsYXlQcm9wZXJ0eVBhdGgpIDogaXRlbVtkZXNjcmlwdG9yLnByb3BlcnR5XSkgfCBudW1iZXI6IGRlc2NyaXB0b3IuZGlzcGxheUZvcm1hdCB9fVxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cImNvbHVtblR5cGVEYXRlXCI+XG4gICAgICAgIHt7IChkZXNjcmlwdG9yLmRpc3BsYXlQcm9wZXJ0eVBhdGggPyAoaXRlbSB8IHByb3BlcnR5UGF0aDogZGVzY3JpcHRvci5kaXNwbGF5UHJvcGVydHlQYXRoKSA6IGl0ZW1bZGVzY3JpcHRvci5wcm9wZXJ0eV0pIHwgZGF0ZTogZGVzY3JpcHRvci5kaXNwbGF5Rm9ybWF0IH19XG4gICAgPC9uZy1jb250YWluZXI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiY29sdW1uVHlwZUJvb2xlYW5cIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImRlc2NyaXB0b3IuYm9vbGVhbkFzSWNvbjsgZWxzZSBib29sZWFuVGV4dFwiPjwvbmctY29udGFpbmVyPlxuICAgICAgICA8aSBbY2xhc3NdPVwiaXRlbVtkZXNjcmlwdG9yLnByb3BlcnR5XSB8IGJvb2xlYW46IGRlc2NyaXB0b3IuYm9vbGVhblllczpkZXNjcmlwdG9yLmJvb2xlYW5Obzp0cnVlXCI+PC9pPlxuICAgICAgICA8bmctdGVtcGxhdGUgI2Jvb2xlYW5UZXh0PlxuICAgICAgICAgICAge3tcbiAgICAgICAgICAgICAgICAoZGVzY3JpcHRvci5kaXNwbGF5UHJvcGVydHlQYXRoID8gKGl0ZW0gfCBwcm9wZXJ0eVBhdGg6IGRlc2NyaXB0b3IuZGlzcGxheVByb3BlcnR5UGF0aCkgOiBpdGVtW2Rlc2NyaXB0b3IucHJvcGVydHldKVxuICAgICAgICAgICAgICAgICAgICB8IGJvb2xlYW46IGRlc2NyaXB0b3IuYm9vbGVhblllczpkZXNjcmlwdG9yLmJvb2xlYW5Ob1xuICAgICAgICAgICAgICAgICAgICB8IHRyYW5zbGF0ZVxuICAgICAgICAgICAgfX1cbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJjb2x1bW5UeXBlRW51bVwiPlxuICAgICAgICB7e1xuICAgICAgICAgICAgKGRlc2NyaXB0b3IuZGlzcGxheVByb3BlcnR5UGF0aCA/IChpdGVtIHwgcHJvcGVydHlQYXRoOiBkZXNjcmlwdG9yLmRpc3BsYXlQcm9wZXJ0eVBhdGgpIDogaXRlbVtkZXNjcmlwdG9yLnByb3BlcnR5XSlcbiAgICAgICAgICAgICAgICB8IGVudW06IGRlc2NyaXB0b3IuZW51bVR5cGU6ZGVzY3JpcHRvci5lbnVtVGl0bGVQYXRoOmRlc2NyaXB0b3IuZW51bU5hbWVBc1ZhbHVlXG4gICAgICAgICAgICAgICAgfCB0cmFuc2xhdGVcbiAgICAgICAgfX1cbiAgICA8L25nLWNvbnRhaW5lcj5cbjwvbmctY29udGFpbmVyPlxuIl19
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLXZhbHVlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXZpZXcvdGFibGUvY29sdW1uLXZhbHVlL2NvbHVtbi12YWx1ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdGFibGV2aWV3L3RhYmxlL2NvbHVtbi12YWx1ZS9jb2x1bW4tdmFsdWUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFFaEYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0seUJBQXlCLENBQUM7Ozs7Ozs7O0FBT3pELE1BQU0sT0FBTyw0QkFBNEI7SUFMekM7UUFNb0IscUJBQWdCLEdBQThCLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUM7UUFDL0UscUJBQWdCLEdBQThCLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUM7UUFDL0Usc0JBQWlCLEdBQThCLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7UUFDakYsbUJBQWMsR0FBOEIsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQztRQUMzRSxtQkFBYyxHQUE4QixnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQzNFLHFCQUFnQixHQUE4QixnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDO1FBS3hGLGFBQVEsR0FBRyxHQUFHLENBQUM7S0FZekI7SUFWVSxRQUFRO1FBQ1gsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRTtZQUMxQixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDO1NBQzVDO2FBQU07WUFDSCxJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNoRCxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsZUFBZSxFQUFFO2dCQUNqQyxJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO2FBQzFGO1NBQ0o7SUFDTCxDQUFDOzt5SEF0QlEsNEJBQTRCOzZHQUE1Qiw0QkFBNEIsa0hDVHpDLG85Q0E4QkE7MkZEckJhLDRCQUE0QjtrQkFMeEMsU0FBUzsrQkFDSSx3QkFBd0IsbUJBRWpCLHVCQUF1QixDQUFDLE1BQU07OEJBVXRDLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtDb2x1bW5EZXNjcmlwdG9yfSBmcm9tICcuLi8uLi8uLi8uLi9kZXNjcmlwdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbW5nLXRhYmxlLWNvbHVtbi12YWx1ZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NvbHVtbi12YWx1ZS5jb21wb25lbnQuaHRtbCcsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgTW5nVGFibGVDb2x1bW5WYWx1ZUNvbXBvbmVudDxULCBUVD4gaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHB1YmxpYyByZWFkb25seSBjb2x1bW5UeXBlU3RyaW5nOiBDb2x1bW5EZXNjcmlwdG9yLlR5cGVFbnVtID0gQ29sdW1uRGVzY3JpcHRvci5UeXBlRW51bS5TdHJpbmc7XG4gICAgcHVibGljIHJlYWRvbmx5IGNvbHVtblR5cGVOdW1iZXI6IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0gPSBDb2x1bW5EZXNjcmlwdG9yLlR5cGVFbnVtLk51bWJlcjtcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29sdW1uVHlwZUJvb2xlYW46IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0gPSBDb2x1bW5EZXNjcmlwdG9yLlR5cGVFbnVtLkJvb2xlYW47XG4gICAgcHVibGljIHJlYWRvbmx5IGNvbHVtblR5cGVEYXRlOiBDb2x1bW5EZXNjcmlwdG9yLlR5cGVFbnVtID0gQ29sdW1uRGVzY3JpcHRvci5UeXBlRW51bS5EYXRlO1xuICAgIHB1YmxpYyByZWFkb25seSBjb2x1bW5UeXBlRW51bTogQ29sdW1uRGVzY3JpcHRvci5UeXBlRW51bSA9IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0uRW51bTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29sdW1uVHlwZUN1c3RvbTogQ29sdW1uRGVzY3JpcHRvci5UeXBlRW51bSA9IENvbHVtbkRlc2NyaXB0b3IuVHlwZUVudW0uQ3VzdG9tO1xuXG4gICAgQElucHV0KCkgZGVzY3JpcHRvciE6IENvbHVtbkRlc2NyaXB0b3I8VCwgVFQ+O1xuICAgIEBJbnB1dCgpIGl0ZW0hOiBhbnk7XG5cbiAgICBwdWJsaWMganNvblBhdGggPSAnJCc7XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKSB7XG4gICAgICAgIGlmICh0aGlzLmRlc2NyaXB0b3IuanNvblBhdGgpIHtcbiAgICAgICAgICAgIHRoaXMuanNvblBhdGggPSB0aGlzLmRlc2NyaXB0b3IuanNvblBhdGg7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmpzb25QYXRoID0gYCQuJHt0aGlzLmRlc2NyaXB0b3IucHJvcGVydHl9YDtcbiAgICAgICAgICAgIGlmICh0aGlzLmRlc2NyaXB0b3Iub2JqZWN0TW9kZWxUeXBlKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5qc29uUGF0aCA9IGAkLiR7dGhpcy5kZXNjcmlwdG9yLnByb3BlcnR5fS4ke3RoaXMuZGVzY3JpcHRvci5vYmplY3RUaXRsZVByb3BlcnR5fWA7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8bmctY29udGFpbmVyIFtuZ1N3aXRjaF09XCJkZXNjcmlwdG9yLmNvbHVtblR5cGVcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJjb2x1bW5UeXBlU3RyaW5nXCI+XG4gICAgICAgIHt7IGl0ZW0gfCBqc29uUGF0aDoganNvblBhdGggfX1cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJjb2x1bW5UeXBlTnVtYmVyXCI+XG4gICAgICAgIHt7IGl0ZW0gfCBqc29uUGF0aDoganNvblBhdGggfCBudW1iZXI6IGRlc2NyaXB0b3IuZGlzcGxheUZvcm1hdCB9fVxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cImNvbHVtblR5cGVEYXRlXCI+XG4gICAgICAgIHt7IGl0ZW0gfCBqc29uUGF0aDoganNvblBhdGggfCBkYXRlOiBkZXNjcmlwdG9yLmRpc3BsYXlGb3JtYXQgfX1cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJjb2x1bW5UeXBlQm9vbGVhblwiPlxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiZGVzY3JpcHRvci5ib29sZWFuQXNJY29uOyBlbHNlIGJvb2xlYW5UZXh0XCI+PC9uZy1jb250YWluZXI+XG4gICAgICAgIDxpIFtjbGFzc109XCJpdGVtIHwganNvblBhdGg6IGpzb25QYXRoIHwgYm9vbGVhbjogZGVzY3JpcHRvci5ib29sZWFuWWVzOmRlc2NyaXB0b3IuYm9vbGVhbk5vOnRydWVcIj48L2k+XG4gICAgICAgIDxuZy10ZW1wbGF0ZSAjYm9vbGVhblRleHQ+XG4gICAgICAgICAgICB7eyBpdGVtIHwganNvblBhdGg6IGpzb25QYXRoIHwgYm9vbGVhbjogZGVzY3JpcHRvci5ib29sZWFuWWVzOmRlc2NyaXB0b3IuYm9vbGVhbk5vIHwgdHJhbnNsYXRlIH19XG4gICAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgPC9uZy1jb250YWluZXI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiY29sdW1uVHlwZUVudW1cIj5cbiAgICAgICAge3sgaXRlbSB8IGpzb25QYXRoOiBqc29uUGF0aCB8IGVudW06IGRlc2NyaXB0b3IuZW51bVR5cGU6ZGVzY3JpcHRvci5lbnVtVGl0bGVQYXRoOmRlc2NyaXB0b3IuZW51bU5hbWVBc1ZhbHVlIHwgdHJhbnNsYXRlIH19XG4gICAgPC9uZy1jb250YWluZXI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiY29sdW1uVHlwZUN1c3RvbVwiPlxuICAgICAgICA8bmctY29udGFpbmVyXG4gICAgICAgICAgICBbbW5nQ29tcG9uZW50XT1cImRlc2NyaXB0b3IuY3VzdG9tQ29tcG9uZW50VHlwZSFcIlxuICAgICAgICAgICAgW2lucHV0c109XCJ7XG4gICAgICAgICAgICAgICAgdmFsdWU6IGl0ZW0gfCBqc29uUGF0aDoganNvblBhdGgsXG4gICAgICAgICAgICAgICAgaXRlbTogaXRlbSxcbiAgICAgICAgICAgICAgICBkZXNjcmlwdG9yOiBkZXNjcmlwdG9yXG4gICAgICAgICAgICB9XCI+PC9uZy1jb250YWluZXI+XG4gICAgPC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==