@mediusinc/mng-commons 0.2.21 → 0.3.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 (40) hide show
  1. package/esm2020/lib/api/models/filter-param.model.mjs +1 -2
  2. package/esm2020/lib/api/models/mappers.mjs +2 -6
  3. package/esm2020/lib/api/models/query-mode.model.mjs +1 -2
  4. package/esm2020/lib/api/models/query-param.model.mjs +3 -4
  5. package/esm2020/lib/api/models/query-result.model.mjs +6 -34
  6. package/esm2020/lib/api/services/api.abstract.service.mjs +34 -0
  7. package/esm2020/lib/api/services/crud-api.abstract.service.mjs +15 -32
  8. package/esm2020/lib/api/services/get-all-api.abstract.service.mjs +23 -0
  9. package/esm2020/lib/api/services/index.mjs +3 -1
  10. package/esm2020/lib/components/action/action.component.mjs +3 -3
  11. package/esm2020/lib/components/action/editor/action-editor.component.mjs +3 -3
  12. package/esm2020/lib/components/form/dropdown/dropdown.component.mjs +64 -15
  13. package/esm2020/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +3 -3
  14. package/esm2020/lib/components/tableview/route/tableview-route.component.mjs +22 -4
  15. package/esm2020/lib/components/tableview/table/column-filter/column-filter.component.mjs +16 -3
  16. package/esm2020/lib/config/models/mng-config.model.mjs +1 -1
  17. package/esm2020/lib/descriptors/editor.descriptor.mjs +19 -14
  18. package/esm2020/lib/descriptors/table.descriptor.mjs +14 -3
  19. package/esm2020/lib/descriptors/tableview.descriptor.mjs +5 -5
  20. package/esm2020/lib/pipes/enum.pipe.mjs +4 -1
  21. package/esm2020/lib/router/route-builder.mjs +31 -25
  22. package/esm2020/lib/services/commons.service.mjs +1 -2
  23. package/fesm2015/mediusinc-mng-commons.mjs +259 -153
  24. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  25. package/fesm2020/mediusinc-mng-commons.mjs +259 -153
  26. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  27. package/lib/api/models/query-result.model.d.ts +4 -17
  28. package/lib/api/services/api.abstract.service.d.ts +19 -0
  29. package/lib/api/services/crud-api.abstract.service.d.ts +3 -11
  30. package/lib/api/services/get-all-api.abstract.service.d.ts +11 -0
  31. package/lib/api/services/index.d.ts +2 -0
  32. package/lib/components/form/dropdown/dropdown.component.d.ts +9 -4
  33. package/lib/components/tableview/route/tableview-route.component.d.ts +4 -1
  34. package/lib/components/tableview/table/column-filter/column-filter.component.d.ts +1 -0
  35. package/lib/descriptors/editor.descriptor.d.ts +7 -7
  36. package/lib/descriptors/table.descriptor.d.ts +3 -1
  37. package/lib/descriptors/tableview.descriptor.d.ts +2 -2
  38. package/lib/router/route-builder.d.ts +2 -0
  39. package/package.json +1 -1
  40. /package/{assets/templates → templates}/tableview-route.component.html +0 -0
@@ -86,13 +86,13 @@ export class MngActionEditorComponent {
86
86
  // assign run operations
87
87
  action.withRunNotificationSuccess(undefined, undefined, false);
88
88
  if (action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit) {
89
- action.withRunFunction(ctx => {
89
+ action.withRunFunction(() => {
90
90
  this.triggerSubmit();
91
91
  return of(undefined);
92
92
  });
93
93
  }
94
94
  else {
95
- action.withRunFunction(ctx => {
95
+ action.withRunFunction(() => {
96
96
  this.cancel();
97
97
  return of(undefined);
98
98
  });
@@ -236,4 +236,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
236
236
  type: ViewChild,
237
237
  args: [MngFormEditorComponent]
238
238
  }] } });
239
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/action/editor/action-editor.component.ts","../../../../../../src/lib/components/action/editor/action-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    ViewChild\n} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {DynamicDialogConfig, DynamicDialogRef} from 'primeng/dynamicdialog';\nimport {Observable, ReplaySubject, Subscription, of} from 'rxjs';\nimport {catchError, finalize, first, mergeMap} from 'rxjs/operators';\n\nimport {IDataProvider, IEditorDataProvider} from '../../../data-providers';\nimport {ActionDescriptor, ActionEditorDescriptor, ActionEditorSubmitDescriptor, ActionPositionEnum} from '../../../descriptors';\nimport {MngTemplateDirective} from '../../../directives';\nimport {IViewContainer} from '../../../models';\nimport {MngActionExecutorService, MngCommonsService, MngNavigationService, MngViewContainerComponentService} from '../../../services';\nimport {IdType} from '../../../types';\nimport {I18nUtil, ToastUtil} from '../../../utils';\nimport {MngFormEditorComponent} from '../../form';\nimport {MngFormEditorSubmitEvent} from '../../form/models';\nimport {ActionData, ActionError, ActionRunResult} from '../models';\n\n@Component({\n    selector: 'mng-action-editor',\n    templateUrl: './action-editor.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngActionEditorComponent<T, S> implements OnInit, OnDestroy {\n    // metadata and editor mode input\n    @Input() public action!: ActionEditorDescriptor<T>;\n\n    // data source inputs\n    @Input() public itemId?: IdType;\n    @Input() public item?: T;\n    @Input() public actionData?: ActionData;\n    @Input() public dataProvider?: IEditorDataProvider<T, S>;\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    @Output('actionSubmit') public actionRunEventEmitter = new EventEmitter<ActionRunResult<T, S, IDataProvider<T, S>>>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') public submitButtonElementRef!: ElementRef;\n    @ViewChild(MngFormEditorComponent) public editorComponent!: MngFormEditorComponent<T>;\n\n    public cmpId: string = Math.random().toString(36).substring(2);\n    public title?: string;\n    public isDialog = true;\n    public isSaveButton = true;\n\n    // actions\n    public toolbarLeftActions: ActionDescriptor<T>[] = [];\n    public toolbarRightActions: ActionDescriptor<T>[] = [];\n    public footerLeftActions: ActionDescriptor<T>[] = [];\n    public footerRightActions: ActionDescriptor<T>[] = [];\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public loading$: Observable<boolean> = this.loadingSubject.asObservable();\n    private submitLoadingSubject = new ReplaySubject<boolean>(1);\n    public submitLoading$: Observable<boolean> = this.submitLoadingSubject.asObservable();\n    public viewContainer?: IViewContainer<T, S>;\n    private sourceComponent: any = this;\n    private subscriptions: Array<Subscription> = [];\n\n    constructor(\n        private injector: Injector,\n        private translate: TranslateService,\n        private actionExecutor: MngActionExecutorService,\n        private mngCommonsService: MngCommonsService,\n        private navigationService: MngNavigationService,\n        @Optional() private dialogRef: DynamicDialogRef | null,\n        @Optional() private dialogConfig: DynamicDialogConfig | null,\n        @Optional() private viewContainerService: MngViewContainerComponentService<T, S> | null\n    ) {}\n\n    public ngOnInit() {\n        if (this.dialogConfig?.data) {\n            if (this.dialogConfig.data.action) {\n                this.action = this.dialogConfig.data.action;\n            }\n            if (this.dialogConfig.data.item) {\n                this.item = this.dialogConfig.data.item;\n            }\n            if (this.dialogConfig.data.itemId) {\n                this.itemId = this.dialogConfig.data.itemId;\n            }\n            if (this.dialogConfig.data.actionData) {\n                this.actionData = this.dialogConfig.data.actionData;\n            }\n            if (this.dialogConfig.data.viewContainer) {\n                this.viewContainer = this.dialogConfig.data.viewContainer;\n                if (!this.dataProvider && this.viewContainer) {\n                    const dataProvider = this.viewContainer.getDataProvider();\n                    if (dataProvider && typeof dataProvider['fetch' as keyof object] === 'function') {\n                        this.dataProvider = dataProvider as IEditorDataProvider<T, S>;\n                    }\n                }\n            }\n            if (this.dialogConfig.data.sourceComponent) {\n                this.sourceComponent = this.dialogConfig.data.sourceComponent;\n            }\n        } else {\n            this.isDialog = false;\n            this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;\n        }\n\n        this.isSaveButton = typeof this.action.submitFunction === 'function';\n        this.setTitle();\n\n        for (const action of this.action.editorActions) {\n            if (action instanceof ActionEditorSubmitDescriptor) {\n                if (typeof action.icon === 'undefined') {\n                    action.withIcon(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'pi pi-check' : 'pi pi-times');\n                }\n                if (typeof action.title === 'undefined') {\n                    action.withTitle(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'general.save' : this.isDialog ? 'general.close' : 'general.cancel');\n                }\n\n                // assign run operations\n                action.withRunNotificationSuccess(undefined, undefined, false);\n                if (action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit) {\n                    action.withRunFunction(ctx => {\n                        this.triggerSubmit();\n                        return of(undefined);\n                    });\n                } else {\n                    action.withRunFunction(ctx => {\n                        this.cancel();\n                        return of(undefined);\n                    });\n                }\n            }\n            switch (action.position) {\n                case ActionPositionEnum.ToolbarLeft:\n                    this.toolbarLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarRight:\n                    this.toolbarRightActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterLeft:\n                    this.footerLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterRight:\n                    this.footerRightActions.push(action);\n                    break;\n            }\n        }\n\n        this.toolbarRightActions = this.toolbarRightActions.reverse();\n        this.footerRightActions = this.footerRightActions.reverse();\n\n        this.loadItemWithDataProvider();\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public onSubmit(event: MngFormEditorSubmitEvent<T>) {\n        if (event.success) {\n            if (typeof this.action.submitFunction !== 'function') {\n                return;\n            }\n            this.submitLoadingSubject.next(true);\n            this.actionExecutor\n                .runEditorSave(this.action, this.itemId, event.formItem, this.dataProvider, this.sourceComponent, this.viewContainer, this.actionData)\n                .pipe(first())\n                .subscribe({\n                    next: res => {\n                        this.submitLoadingSubject.next(false);\n                        this.cancel(res);\n                    },\n                    error: () => {\n                        this.submitLoadingSubject.next(false);\n                    }\n                });\n        }\n    }\n\n    public cancel(result?: ActionRunResult<T, S, IDataProvider<T, S>>) {\n        if (!result) {\n            result = new ActionRunResult<T, S, IDataProvider<T, S>>(undefined, undefined, new ActionError(null, true));\n        }\n        if (this.isDialog) {\n            this.dialogRef?.close(result);\n        }\n        this.actionRunEventEmitter.next(result);\n    }\n\n    public triggerSubmit() {\n        this.editorComponent.submit();\n    }\n\n    private loadItemWithDataProvider() {\n        if (typeof this.action.fetchFunction !== 'function') {\n            return;\n        }\n        this.loadingSubject.next(true);\n        this.actionExecutor\n            .runEditorFetch(this.action, this.item, this.itemId, this.dataProvider, this.sourceComponent, this.viewContainer)\n            .pipe(\n                first(),\n                catchError(err => {\n                    if (this.action.hasRunNotificationError) {\n                        ToastUtil.actionNotificationError(this.translate, this.action, err, 'fetch', this.viewContainer, this.item);\n                    }\n                    throw err;\n                }),\n                finalize(() => this.loadingSubject.next(false))\n            )\n            .subscribe(res => {\n                this.item = res.result;\n                if (this.action.hasFetchNotificationSuccess) {\n                    ToastUtil.actionNotificationSuccess(\n                        this.translate,\n                        this.action,\n                        'fetch',\n                        this.action.fetchNotificationSuccessTitle,\n                        this.action.fetchNotificationSuccessMessage,\n                        this.viewContainer,\n                        this.item\n                    );\n                }\n                this.setTitle();\n            });\n    }\n\n    private setTitle() {\n        if (this.action.editorTitle === null) {\n            this.title = undefined;\n            if (this.dialogConfig) {\n                requestAnimationFrame(() => {\n                    this.dialogConfig!.header = undefined;\n                });\n            }\n            return;\n        }\n        const subscription = I18nUtil.streamActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'editor.title', this.action.editorTitle, this.item)\n            .pipe(\n                mergeMap(i18nDialogTitle =>\n                    i18nDialogTitle === null\n                        ? I18nUtil.getActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'title', undefined, this.item)\n                        : of(i18nDialogTitle)\n                )\n            )\n            .subscribe(t => {\n                this.title = t ?? undefined;\n                if (this.dialogConfig) {\n                    requestAnimationFrame(() => {\n                        this.dialogConfig!.header = t ?? undefined;\n                        this.mngCommonsService.setPageTitle(t ?? undefined);\n                    });\n                }\n            });\n        this.subscriptions.push(subscription);\n    }\n}\n","<h2 *ngIf=\"!isDialog && title\">{{ title }}</h2>\n<div class=\"h-full flex flex-column\">\n    <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n        <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n            <ng-template pTemplate=\"left\">\n                <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n            <ng-template pTemplate=\"right\">\n                <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n        </p-toolbar>\n    </div>\n\n    <div class=\"flex-grow-1\">\n        <div class=\"text-center\" *ngIf=\"loading$ | async\">\n            <p-progressSpinner [style]=\"{width: '3rem', height: '3rem'}\" strokeWidth=\"3\"></p-progressSpinner>\n        </div>\n        <mng-form-editor *ngIf=\"action.editorDescriptor && (loading$ | async) === false\" [descriptor]=\"action.editorDescriptor\" [item]=\"item\" (formSubmit)=\"onSubmit($event)\">\n        </mng-form-editor>\n    </div>\n\n    <div class=\"flex flex-row justify-content-between\">\n        <div>\n            <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n        <div>\n            <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n    </div>\n</div>\n"]}
239
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/action/editor/action-editor.component.ts","../../../../../../src/lib/components/action/editor/action-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    ViewChild\n} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {DynamicDialogConfig, DynamicDialogRef} from 'primeng/dynamicdialog';\nimport {Observable, ReplaySubject, Subscription, of} from 'rxjs';\nimport {catchError, finalize, first, mergeMap} from 'rxjs/operators';\n\nimport {IDataProvider, IEditorDataProvider} from '../../../data-providers';\nimport {ActionDescriptor, ActionEditorDescriptor, ActionEditorSubmitDescriptor, ActionPositionEnum} from '../../../descriptors';\nimport {MngTemplateDirective} from '../../../directives';\nimport {IViewContainer} from '../../../models';\nimport {MngActionExecutorService, MngCommonsService, MngNavigationService, MngViewContainerComponentService} from '../../../services';\nimport {IdType} from '../../../types';\nimport {I18nUtil, ToastUtil} from '../../../utils';\nimport {MngFormEditorComponent} from '../../form';\nimport {MngFormEditorSubmitEvent} from '../../form/models';\nimport {ActionData, ActionError, ActionRunResult} from '../models';\n\n@Component({\n    selector: 'mng-action-editor',\n    templateUrl: './action-editor.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngActionEditorComponent<T, S> implements OnInit, OnDestroy {\n    // metadata and editor mode input\n    @Input() public action!: ActionEditorDescriptor<T>;\n\n    // data source inputs\n    @Input() public itemId?: IdType;\n    @Input() public item?: T;\n    @Input() public actionData?: ActionData;\n    @Input() public dataProvider?: IEditorDataProvider<T, S>;\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    @Output('actionSubmit') public actionRunEventEmitter = new EventEmitter<ActionRunResult<T, S, IDataProvider<T, S>>>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') public submitButtonElementRef!: ElementRef;\n    @ViewChild(MngFormEditorComponent) public editorComponent!: MngFormEditorComponent<T>;\n\n    public cmpId: string = Math.random().toString(36).substring(2);\n    public title?: string;\n    public isDialog = true;\n    public isSaveButton = true;\n\n    // actions\n    public toolbarLeftActions: ActionDescriptor<T>[] = [];\n    public toolbarRightActions: ActionDescriptor<T>[] = [];\n    public footerLeftActions: ActionDescriptor<T>[] = [];\n    public footerRightActions: ActionDescriptor<T>[] = [];\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public loading$: Observable<boolean> = this.loadingSubject.asObservable();\n    private submitLoadingSubject = new ReplaySubject<boolean>(1);\n    public submitLoading$: Observable<boolean> = this.submitLoadingSubject.asObservable();\n    public viewContainer?: IViewContainer<T, S>;\n    private sourceComponent: any = this;\n    private subscriptions: Array<Subscription> = [];\n\n    constructor(\n        private injector: Injector,\n        private translate: TranslateService,\n        private actionExecutor: MngActionExecutorService,\n        private mngCommonsService: MngCommonsService,\n        private navigationService: MngNavigationService,\n        @Optional() private dialogRef: DynamicDialogRef | null,\n        @Optional() private dialogConfig: DynamicDialogConfig | null,\n        @Optional() private viewContainerService: MngViewContainerComponentService<T, S> | null\n    ) {}\n\n    public ngOnInit() {\n        if (this.dialogConfig?.data) {\n            if (this.dialogConfig.data.action) {\n                this.action = this.dialogConfig.data.action;\n            }\n            if (this.dialogConfig.data.item) {\n                this.item = this.dialogConfig.data.item;\n            }\n            if (this.dialogConfig.data.itemId) {\n                this.itemId = this.dialogConfig.data.itemId;\n            }\n            if (this.dialogConfig.data.actionData) {\n                this.actionData = this.dialogConfig.data.actionData;\n            }\n            if (this.dialogConfig.data.viewContainer) {\n                this.viewContainer = this.dialogConfig.data.viewContainer;\n                if (!this.dataProvider && this.viewContainer) {\n                    const dataProvider = this.viewContainer.getDataProvider();\n                    if (dataProvider && typeof dataProvider['fetch' as keyof object] === 'function') {\n                        this.dataProvider = dataProvider as IEditorDataProvider<T, S>;\n                    }\n                }\n            }\n            if (this.dialogConfig.data.sourceComponent) {\n                this.sourceComponent = this.dialogConfig.data.sourceComponent;\n            }\n        } else {\n            this.isDialog = false;\n            this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;\n        }\n\n        this.isSaveButton = typeof this.action.submitFunction === 'function';\n        this.setTitle();\n\n        for (const action of this.action.editorActions) {\n            if (action instanceof ActionEditorSubmitDescriptor) {\n                if (typeof action.icon === 'undefined') {\n                    action.withIcon(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'pi pi-check' : 'pi pi-times');\n                }\n                if (typeof action.title === 'undefined') {\n                    action.withTitle(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'general.save' : this.isDialog ? 'general.close' : 'general.cancel');\n                }\n\n                // assign run operations\n                action.withRunNotificationSuccess(undefined, undefined, false);\n                if (action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit) {\n                    action.withRunFunction(() => {\n                        this.triggerSubmit();\n                        return of(undefined);\n                    });\n                } else {\n                    action.withRunFunction(() => {\n                        this.cancel();\n                        return of(undefined);\n                    });\n                }\n            }\n            switch (action.position) {\n                case ActionPositionEnum.ToolbarLeft:\n                    this.toolbarLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarRight:\n                    this.toolbarRightActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterLeft:\n                    this.footerLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterRight:\n                    this.footerRightActions.push(action);\n                    break;\n            }\n        }\n\n        this.toolbarRightActions = this.toolbarRightActions.reverse();\n        this.footerRightActions = this.footerRightActions.reverse();\n\n        this.loadItemWithDataProvider();\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public onSubmit(event: MngFormEditorSubmitEvent<T>) {\n        if (event.success) {\n            if (typeof this.action.submitFunction !== 'function') {\n                return;\n            }\n            this.submitLoadingSubject.next(true);\n            this.actionExecutor\n                .runEditorSave(this.action, this.itemId, event.formItem, this.dataProvider, this.sourceComponent, this.viewContainer, this.actionData)\n                .pipe(first())\n                .subscribe({\n                    next: res => {\n                        this.submitLoadingSubject.next(false);\n                        this.cancel(res);\n                    },\n                    error: () => {\n                        this.submitLoadingSubject.next(false);\n                    }\n                });\n        }\n    }\n\n    public cancel(result?: ActionRunResult<T, S, IDataProvider<T, S>>) {\n        if (!result) {\n            result = new ActionRunResult<T, S, IDataProvider<T, S>>(undefined, undefined, new ActionError(null, true));\n        }\n        if (this.isDialog) {\n            this.dialogRef?.close(result);\n        }\n        this.actionRunEventEmitter.next(result);\n    }\n\n    public triggerSubmit() {\n        this.editorComponent.submit();\n    }\n\n    private loadItemWithDataProvider() {\n        if (typeof this.action.fetchFunction !== 'function') {\n            return;\n        }\n        this.loadingSubject.next(true);\n        this.actionExecutor\n            .runEditorFetch(this.action, this.item, this.itemId, this.dataProvider, this.sourceComponent, this.viewContainer)\n            .pipe(\n                first(),\n                catchError(err => {\n                    if (this.action.hasRunNotificationError) {\n                        ToastUtil.actionNotificationError(this.translate, this.action, err, 'fetch', this.viewContainer, this.item);\n                    }\n                    throw err;\n                }),\n                finalize(() => this.loadingSubject.next(false))\n            )\n            .subscribe(res => {\n                this.item = res.result;\n                if (this.action.hasFetchNotificationSuccess) {\n                    ToastUtil.actionNotificationSuccess(\n                        this.translate,\n                        this.action,\n                        'fetch',\n                        this.action.fetchNotificationSuccessTitle,\n                        this.action.fetchNotificationSuccessMessage,\n                        this.viewContainer,\n                        this.item\n                    );\n                }\n                this.setTitle();\n            });\n    }\n\n    private setTitle() {\n        if (this.action.editorTitle === null) {\n            this.title = undefined;\n            if (this.dialogConfig) {\n                requestAnimationFrame(() => {\n                    this.dialogConfig!.header = undefined;\n                });\n            }\n            return;\n        }\n        const subscription = I18nUtil.streamActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'editor.title', this.action.editorTitle, this.item)\n            .pipe(\n                mergeMap(i18nDialogTitle =>\n                    i18nDialogTitle === null\n                        ? I18nUtil.getActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'title', undefined, this.item)\n                        : of(i18nDialogTitle)\n                )\n            )\n            .subscribe(t => {\n                this.title = t ?? undefined;\n                if (this.dialogConfig) {\n                    requestAnimationFrame(() => {\n                        this.dialogConfig!.header = t ?? undefined;\n                        this.mngCommonsService.setPageTitle(t ?? undefined);\n                    });\n                }\n            });\n        this.subscriptions.push(subscription);\n    }\n}\n","<h2 *ngIf=\"!isDialog && title\">{{ title }}</h2>\n<div class=\"h-full flex flex-column\">\n    <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n        <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n            <ng-template pTemplate=\"left\">\n                <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n            <ng-template pTemplate=\"right\">\n                <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n        </p-toolbar>\n    </div>\n\n    <div class=\"flex-grow-1\">\n        <div class=\"text-center\" *ngIf=\"loading$ | async\">\n            <p-progressSpinner [style]=\"{width: '3rem', height: '3rem'}\" strokeWidth=\"3\"></p-progressSpinner>\n        </div>\n        <mng-form-editor *ngIf=\"action.editorDescriptor && (loading$ | async) === false\" [descriptor]=\"action.editorDescriptor\" [item]=\"item\" (formSubmit)=\"onSubmit($event)\">\n        </mng-form-editor>\n    </div>\n\n    <div class=\"flex flex-row justify-content-between\">\n        <div>\n            <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n        <div>\n            <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n    </div>\n</div>\n"]}
@@ -1,22 +1,25 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild, forwardRef } from '@angular/core';
2
2
  import { FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { Dropdown } from 'primeng/dropdown';
4
- import { ReplaySubject } from 'rxjs';
5
- import { first } from 'rxjs/operators';
4
+ import { ReplaySubject, of, switchMap } from 'rxjs';
5
+ import { first, map } from 'rxjs/operators';
6
6
  import { MediusQueryParamBuilder } from '../../../api/models';
7
7
  import * as i0 from "@angular/core";
8
- import * as i1 from "primeng/dropdown";
9
- import * as i2 from "primeng/multiselect";
10
- import * as i3 from "@angular/common";
11
- import * as i4 from "@angular/forms";
8
+ import * as i1 from "@ngx-translate/core";
9
+ import * as i2 from "primeng/dropdown";
10
+ import * as i3 from "primeng/multiselect";
11
+ import * as i4 from "@angular/common";
12
+ import * as i5 from "@angular/forms";
12
13
  export const MNG_DROPDOWN_VALUE_ACCESSOR = {
13
14
  provide: NG_VALUE_ACCESSOR,
14
15
  useExisting: forwardRef(() => MngDropdownComponent),
15
16
  multi: true
16
17
  };
17
18
  export class MngDropdownComponent {
18
- constructor(injector) {
19
+ constructor(injector, translate) {
19
20
  this.injector = injector;
21
+ this.translate = translate;
22
+ this.itemsLabelTranslate = false;
20
23
  this.multiselect = false;
21
24
  this.showClear = true;
22
25
  this.selectFirstItem = false;
@@ -37,10 +40,52 @@ export class MngDropdownComponent {
37
40
  this.onChangeFn(v);
38
41
  this.valueChangeEventEmitter.next(v);
39
42
  });
43
+ this.itemsLabelProperty = this.itemsLabelPropertyInit;
44
+ this.itemsValueProperty = this.itemsValuePropertyInit;
40
45
  if (this.dataProvider) {
41
46
  this.dataProviderService = this.dataProvider.serviceType ? this.injector.get(this.dataProvider.serviceType) : null;
42
47
  const queryParamBuilder = MediusQueryParamBuilder.create();
43
- this.itemsSubscription = this.dataProvider.lookup(queryParamBuilder.build(), this.dataProviderService).subscribe(res => {
48
+ if (this.itemsLabelTranslate) {
49
+ // setup translation properties
50
+ if (this.itemsLabelPropertyInit) {
51
+ this.itemsLabelProperty = `${this.itemsLabelPropertyInit}_i18n`;
52
+ }
53
+ else if (!this.itemsLabelProperty && !this.itemsValuePropertyInit) {
54
+ this.itemsLabelProperty = 'title_i18n';
55
+ this.itemsValueProperty = 'value';
56
+ }
57
+ else {
58
+ throw new Error(`Invalid use with value (${this.itemsLabelPropertyInit}) and label (${this.itemsLabelPropertyInit}) property setup.`);
59
+ }
60
+ }
61
+ this.itemsSubscription = this.dataProvider
62
+ .lookup(queryParamBuilder.build(), this.dataProviderService)
63
+ .pipe(switchMap(items => {
64
+ if (this.itemsLabelTranslate) {
65
+ const translationKeys = items.map(item => (typeof item === 'object' && this.itemsLabelPropertyInit ? item[this.itemsLabelPropertyInit] : item));
66
+ return this.translate.stream(translationKeys).pipe(map(translations => items.map(item => {
67
+ if (typeof item === 'object' && this.itemsLabelPropertyInit) {
68
+ const label = item[this.itemsLabelPropertyInit];
69
+ const translation = translations[label];
70
+ if (translation) {
71
+ return { ...item, [this.itemsLabelProperty]: translation };
72
+ }
73
+ return { ...item };
74
+ }
75
+ else {
76
+ const translation = translations[item];
77
+ return {
78
+ [this.itemsLabelProperty]: translation ?? item,
79
+ [this.itemsValueProperty]: item
80
+ };
81
+ }
82
+ })));
83
+ }
84
+ else {
85
+ return of(items);
86
+ }
87
+ }))
88
+ .subscribe(res => {
44
89
  this.itemsSubject.next(res);
45
90
  });
46
91
  if (this.selectFirstItem && !this.dropdownFormControl?.value) {
@@ -75,19 +120,23 @@ export class MngDropdownComponent {
75
120
  this.dropdownFormControl.setValue(obj, { emitEvent: false });
76
121
  }
77
122
  }
78
- MngDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngDropdownComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
79
- MngDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngDropdownComponent, selector: "mng-dropdown", inputs: { dataProvider: "dataProvider", dataKeyProperty: "dataKeyProperty", itemsLabelProperty: "itemsLabelProperty", itemsValueProperty: "itemsValueProperty", itemsDisabledProperty: "itemsDisabledProperty", multiselect: "multiselect", placeholder: "placeholder", showClear: "showClear", selectFirstItem: "selectFirstItem", className: "className", dropdownClassName: "dropdownClassName" }, outputs: { valueChangeEventEmitter: "valueChange" }, providers: [MNG_DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true }], ngImport: i0, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [optionDisabled]=\"$any(itemsDisabledProperty)\"\n [options]=\"$any(items$ | async)\"\n [showClear]=\"showClear\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n <p-multiSelect\n display=\"chip\"\n [formControl]=\"dropdownFormControl\"\n [defaultLabel]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [optionDisabled]=\"$any(itemsDisabledProperty)\"\n [options]=\"(items$ | async) ?? []\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n [filter]=\"false\"\n appendTo=\"body\">\n </p-multiSelect>\n</ng-template>\n", components: [{ type: i1.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"] }, { type: i2.MultiSelect, selector: "p-multiSelect", inputs: ["style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "autoZIndex", "baseZIndex", "filterBy", "virtualScroll", "itemSize", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "scrollHeight", "defaultLabel", "placeholder", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onPanelShow", "onPanelHide"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], pipes: { "async": i3.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
123
+ MngDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngDropdownComponent, deps: [{ token: i0.Injector }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
124
+ MngDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngDropdownComponent, selector: "mng-dropdown", inputs: { dataProvider: "dataProvider", dataKeyProperty: "dataKeyProperty", itemsLabelPropertyInit: ["itemsLabelProperty", "itemsLabelPropertyInit"], itemsLabelTranslate: "itemsLabelTranslate", itemsValuePropertyInit: ["itemsValueProperty", "itemsValuePropertyInit"], itemsDisabledProperty: "itemsDisabledProperty", multiselect: "multiselect", placeholder: "placeholder", showClear: "showClear", selectFirstItem: "selectFirstItem", className: "className", dropdownClassName: "dropdownClassName" }, outputs: { valueChangeEventEmitter: "valueChange" }, providers: [MNG_DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true }], ngImport: i0, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [optionDisabled]=\"$any(itemsDisabledProperty)\"\n [options]=\"$any(items$ | async)\"\n [showClear]=\"showClear\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n <p-multiSelect\n display=\"chip\"\n [formControl]=\"dropdownFormControl\"\n [defaultLabel]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [optionDisabled]=\"$any(itemsDisabledProperty)\"\n [options]=\"(items$ | async) ?? []\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n [filter]=\"false\"\n appendTo=\"body\">\n </p-multiSelect>\n</ng-template>\n", components: [{ type: i2.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"] }, { type: i3.MultiSelect, selector: "p-multiSelect", inputs: ["style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "autoZIndex", "baseZIndex", "filterBy", "virtualScroll", "itemSize", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "scrollHeight", "defaultLabel", "placeholder", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onPanelShow", "onPanelHide"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], pipes: { "async": i4.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
80
125
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngDropdownComponent, decorators: [{
81
126
  type: Component,
82
127
  args: [{ selector: 'mng-dropdown', providers: [MNG_DROPDOWN_VALUE_ACCESSOR], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [optionDisabled]=\"$any(itemsDisabledProperty)\"\n [options]=\"$any(items$ | async)\"\n [showClear]=\"showClear\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n <p-multiSelect\n display=\"chip\"\n [formControl]=\"dropdownFormControl\"\n [defaultLabel]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [optionDisabled]=\"$any(itemsDisabledProperty)\"\n [options]=\"(items$ | async) ?? []\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n [filter]=\"false\"\n appendTo=\"body\">\n </p-multiSelect>\n</ng-template>\n" }]
83
- }], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { dataProvider: [{
128
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.TranslateService }]; }, propDecorators: { dataProvider: [{
84
129
  type: Input
85
130
  }], dataKeyProperty: [{
86
131
  type: Input
87
- }], itemsLabelProperty: [{
88
- type: Input
89
- }], itemsValueProperty: [{
132
+ }], itemsLabelPropertyInit: [{
133
+ type: Input,
134
+ args: ['itemsLabelProperty']
135
+ }], itemsLabelTranslate: [{
90
136
  type: Input
137
+ }], itemsValuePropertyInit: [{
138
+ type: Input,
139
+ args: ['itemsValueProperty']
91
140
  }], itemsDisabledProperty: [{
92
141
  type: Input
93
142
  }], multiselect: [{
@@ -109,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
109
158
  type: ViewChild,
110
159
  args: [Dropdown]
111
160
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/dropdown/dropdown.component.ts","../../../../../../src/lib/components/form/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, ExistingProvider, Injector, Input, OnDestroy, OnInit, Output, ViewChild, forwardRef} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {Dropdown} from 'primeng/dropdown';\nimport {Observable, ReplaySubject, Subject, Subscription} from 'rxjs';\nimport {first} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\n\nexport const MNG_DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngDropdownComponent),\n    multi: true\n};\n\n@Component({\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [MNG_DROPDOWN_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngDropdownComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public dataKeyProperty?: string;\n    @Input() public itemsLabelProperty?: string;\n    @Input() public itemsValueProperty?: string;\n    @Input() public itemsDisabledProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public showClear = true;\n    @Input() public selectFirstItem = false;\n    @Input() public className: string | null = null;\n    @Input() public dropdownClassName: string | null = null;\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(Dropdown) public primeDropdown?: Dropdown;\n\n    private itemsSubject: Subject<Array<any>> = new ReplaySubject<Array<any>>(1);\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public dropdownFormControl: FormControl = new FormControl();\n    public items$: Observable<Array<any>> = this.itemsSubject.asObservable();\n    private itemsSubscription?: Subscription;\n\n    constructor(private injector: Injector) {}\n\n    ngOnInit(): void {\n        this.dropdownFormControl.valueChanges.subscribe(v => {\n            this.onChangeFn(v);\n            this.valueChangeEventEmitter.next(v);\n        });\n\n        if (this.dataProvider) {\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n            this.itemsSubscription = this.dataProvider.lookup(queryParamBuilder.build(), this.dataProviderService).subscribe(res => {\n                this.itemsSubject.next(res);\n            });\n\n            if (this.selectFirstItem && !this.dropdownFormControl?.value) {\n                this.items$.pipe(first()).subscribe(res => {\n                    const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];\n                    this.dropdownFormControl?.setValue(value);\n                });\n            }\n        } else {\n            console.warn(`Data provider should be provided for MngDropdownComponent.`);\n        }\n    }\n\n    ngOnDestroy() {\n        this.itemsSubscription?.unsubscribe();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n    }\n}\n","<p-dropdown\n    *ngIf=\"!multiselect; else pMultiselect\"\n    [formControl]=\"dropdownFormControl\"\n    [placeholder]=\"$any(placeholder)\"\n    [dataKey]=\"$any(dataKeyProperty)\"\n    [optionLabel]=\"$any(itemsLabelProperty)\"\n    [optionValue]=\"$any(itemsValueProperty)\"\n    [optionDisabled]=\"$any(itemsDisabledProperty)\"\n    [options]=\"$any(items$ | async)\"\n    [showClear]=\"showClear\"\n    [autoDisplayFirst]=\"false\"\n    [styleClass]=\"$any(className)\"\n    [panelStyleClass]=\"$any(dropdownClassName)\"\n    appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n    <p-multiSelect\n        display=\"chip\"\n        [formControl]=\"dropdownFormControl\"\n        [defaultLabel]=\"$any(placeholder)\"\n        [dataKey]=\"$any(dataKeyProperty)\"\n        [optionLabel]=\"$any(itemsLabelProperty)\"\n        [optionValue]=\"$any(itemsValueProperty)\"\n        [optionDisabled]=\"$any(itemsDisabledProperty)\"\n        [options]=\"(items$ | async) ?? []\"\n        [styleClass]=\"$any(className)\"\n        [panelStyleClass]=\"$any(dropdownClassName)\"\n        [filter]=\"false\"\n        appendTo=\"body\">\n    </p-multiSelect>\n</ng-template>\n"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/dropdown/dropdown.component.ts","../../../../../../src/lib/components/form/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, ExistingProvider, Injector, Input, OnDestroy, OnInit, Output, ViewChild, forwardRef} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {Dropdown} from 'primeng/dropdown';\nimport {Observable, ReplaySubject, Subject, Subscription, of, switchMap} from 'rxjs';\nimport {first, map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\n\nexport const MNG_DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngDropdownComponent),\n    multi: true\n};\n\n@Component({\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [MNG_DROPDOWN_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngDropdownComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public dataKeyProperty?: string;\n    @Input('itemsLabelProperty') public itemsLabelPropertyInit?: string;\n    @Input() public itemsLabelTranslate = false;\n    @Input('itemsValueProperty') public itemsValuePropertyInit?: string;\n    @Input() public itemsDisabledProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public showClear = true;\n    @Input() public selectFirstItem = false;\n    @Input() public className: string | null = null;\n    @Input() public dropdownClassName: string | null = null;\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(Dropdown) public primeDropdown?: Dropdown;\n\n    public itemsLabelProperty?: string;\n    public itemsValueProperty?: string;\n    private itemsSubject: Subject<Array<any>> = new ReplaySubject<Array<any>>(1);\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public dropdownFormControl: FormControl = new FormControl();\n    public items$: Observable<Array<any>> = this.itemsSubject.asObservable();\n    private itemsSubscription?: Subscription;\n\n    constructor(private injector: Injector, private translate: TranslateService) {}\n\n    ngOnInit(): void {\n        this.dropdownFormControl.valueChanges.subscribe(v => {\n            this.onChangeFn(v);\n            this.valueChangeEventEmitter.next(v);\n        });\n\n        this.itemsLabelProperty = this.itemsLabelPropertyInit;\n        this.itemsValueProperty = this.itemsValuePropertyInit;\n\n        if (this.dataProvider) {\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n\n            if (this.itemsLabelTranslate) {\n                // setup translation properties\n                if (this.itemsLabelPropertyInit) {\n                    this.itemsLabelProperty = `${this.itemsLabelPropertyInit}_i18n`;\n                } else if (!this.itemsLabelProperty && !this.itemsValuePropertyInit) {\n                    this.itemsLabelProperty = 'title_i18n';\n                    this.itemsValueProperty = 'value';\n                } else {\n                    throw new Error(`Invalid use with value (${this.itemsLabelPropertyInit}) and label (${this.itemsLabelPropertyInit}) property setup.`);\n                }\n            }\n\n            this.itemsSubscription = this.dataProvider\n                .lookup(queryParamBuilder.build(), this.dataProviderService)\n                .pipe(\n                    switchMap(items => {\n                        if (this.itemsLabelTranslate) {\n                            const translationKeys: string[] = items.map(\n                                item => (typeof item === 'object' && this.itemsLabelPropertyInit ? (item[this.itemsLabelPropertyInit as keyof object] as string) : item) as string\n                            );\n                            return this.translate.stream(translationKeys).pipe(\n                                map(translations =>\n                                    items.map(item => {\n                                        if (typeof item === 'object' && this.itemsLabelPropertyInit) {\n                                            const label = item[this.itemsLabelPropertyInit as keyof object] as string;\n                                            const translation: string | undefined = translations[label];\n                                            if (translation) {\n                                                return {...item, [this.itemsLabelProperty!]: translation};\n                                            }\n                                            return {...item};\n                                        } else {\n                                            const translation = translations[item];\n                                            return {\n                                                [this.itemsLabelProperty!]: translation ?? item,\n                                                [this.itemsValueProperty!]: item\n                                            };\n                                        }\n                                    })\n                                )\n                            );\n                        } else {\n                            return of(items);\n                        }\n                    })\n                )\n                .subscribe(res => {\n                    this.itemsSubject.next(res);\n                });\n\n            if (this.selectFirstItem && !this.dropdownFormControl?.value) {\n                this.items$.pipe(first()).subscribe(res => {\n                    const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];\n                    this.dropdownFormControl?.setValue(value);\n                });\n            }\n        } else {\n            console.warn(`Data provider should be provided for MngDropdownComponent.`);\n        }\n    }\n\n    ngOnDestroy() {\n        this.itemsSubscription?.unsubscribe();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n    }\n}\n","<p-dropdown\n    *ngIf=\"!multiselect; else pMultiselect\"\n    [formControl]=\"dropdownFormControl\"\n    [placeholder]=\"$any(placeholder)\"\n    [dataKey]=\"$any(dataKeyProperty)\"\n    [optionLabel]=\"$any(itemsLabelProperty)\"\n    [optionValue]=\"$any(itemsValueProperty)\"\n    [optionDisabled]=\"$any(itemsDisabledProperty)\"\n    [options]=\"$any(items$ | async)\"\n    [showClear]=\"showClear\"\n    [autoDisplayFirst]=\"false\"\n    [styleClass]=\"$any(className)\"\n    [panelStyleClass]=\"$any(dropdownClassName)\"\n    appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n    <p-multiSelect\n        display=\"chip\"\n        [formControl]=\"dropdownFormControl\"\n        [defaultLabel]=\"$any(placeholder)\"\n        [dataKey]=\"$any(dataKeyProperty)\"\n        [optionLabel]=\"$any(itemsLabelProperty)\"\n        [optionValue]=\"$any(itemsValueProperty)\"\n        [optionDisabled]=\"$any(itemsDisabledProperty)\"\n        [options]=\"(items$ | async) ?? []\"\n        [styleClass]=\"$any(className)\"\n        [panelStyleClass]=\"$any(dropdownClassName)\"\n        [filter]=\"false\"\n        appendTo=\"body\">\n    </p-multiSelect>\n</ng-template>\n"]}
@@ -11,9 +11,9 @@ export class MngFormlyFieldDropdownComponent extends FieldType {
11
11
  }
12
12
  }
13
13
  MngFormlyFieldDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldDropdownComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
14
- MngFormlyFieldDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngFormlyFieldDropdownComponent, selector: "mng-formly-field-dropdown", usesInheritance: true, ngImport: i0, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"descriptor.placeholder\"\n [dataProvider]=\"descriptor.dataProvider\"\n [itemsLabelProperty]=\"descriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"descriptor.itemsValueProperty\"\n [itemsDisabledProperty]=\"descriptor.itemsDisabledProperty\"\n [dataKeyProperty]=\"descriptor.dataKeyProperty\"\n [showClear]=\"!to.required\"\n [className]=\"descriptor.inputClassName\">\n</mng-dropdown>\n", components: [{ type: i1.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsValueProperty", "itemsDisabledProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
14
+ MngFormlyFieldDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngFormlyFieldDropdownComponent, selector: "mng-formly-field-dropdown", usesInheritance: true, ngImport: i0, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"descriptor.placeholder\"\n [dataProvider]=\"descriptor.dataProvider\"\n [itemsLabelProperty]=\"descriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"descriptor.itemsLabelTranslate\"\n [itemsValueProperty]=\"descriptor.itemsValueProperty\"\n [itemsDisabledProperty]=\"descriptor.itemsDisabledProperty\"\n [dataKeyProperty]=\"descriptor.dataKeyProperty\"\n [showClear]=\"!to.required\"\n [className]=\"descriptor.inputClassName\">\n</mng-dropdown>\n", components: [{ type: i1.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsLabelTranslate", "itemsValueProperty", "itemsDisabledProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
15
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldDropdownComponent, decorators: [{
16
16
  type: Component,
17
- args: [{ selector: 'mng-formly-field-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"descriptor.placeholder\"\n [dataProvider]=\"descriptor.dataProvider\"\n [itemsLabelProperty]=\"descriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"descriptor.itemsValueProperty\"\n [itemsDisabledProperty]=\"descriptor.itemsDisabledProperty\"\n [dataKeyProperty]=\"descriptor.dataKeyProperty\"\n [showClear]=\"!to.required\"\n [className]=\"descriptor.inputClassName\">\n</mng-dropdown>\n" }]
17
+ args: [{ selector: 'mng-formly-field-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"descriptor.placeholder\"\n [dataProvider]=\"descriptor.dataProvider\"\n [itemsLabelProperty]=\"descriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"descriptor.itemsLabelTranslate\"\n [itemsValueProperty]=\"descriptor.itemsValueProperty\"\n [itemsDisabledProperty]=\"descriptor.itemsDisabledProperty\"\n [dataKeyProperty]=\"descriptor.dataKeyProperty\"\n [showClear]=\"!to.required\"\n [className]=\"descriptor.inputClassName\">\n</mng-dropdown>\n" }]
18
18
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LWZpZWxkLWRyb3Bkb3duLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2Zvcm1seS9maWVsZHMvZm9ybWx5LWZpZWxkLWRyb3Bkb3duL2Zvcm1seS1maWVsZC1kcm9wZG93bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvZmllbGRzL2Zvcm1seS1maWVsZC1kcm9wZG93bi9mb3JtbHktZmllbGQtZHJvcGRvd24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUd6RSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7Ozs7O0FBUzNDLE1BQU0sT0FBTywrQkFBbUMsU0FBUSxTQUFTO0lBSXRELFFBQVE7UUFDWCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxXQUEwQixDQUFDO1FBQ3BELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1QyxDQUFDOzs0SEFQUSwrQkFBK0I7Z0hBQS9CLCtCQUErQix3RkNaNUMsZ2lCQWFBOzJGRERhLCtCQUErQjtrQkFMM0MsU0FBUzsrQkFDSSwyQkFBMkIsbUJBRXBCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1Db250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7RmllbGRUeXBlfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcblxuaW1wb3J0IHtGaWVsZExvb2t1cERlc2NyaXB0b3J9IGZyb20gJy4uLy4uLy4uLy4uLy4uL2Rlc2NyaXB0b3JzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdtbmctZm9ybWx5LWZpZWxkLWRyb3Bkb3duJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZm9ybWx5LWZpZWxkLWRyb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBNbmdGb3JtbHlGaWVsZERyb3Bkb3duQ29tcG9uZW50PFQ+IGV4dGVuZHMgRmllbGRUeXBlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBwdWJsaWMgZEZvcm1Db250cm9sITogRm9ybUNvbnRyb2w7XG4gICAgcHVibGljIGRlc2NyaXB0b3IhOiBGaWVsZExvb2t1cERlc2NyaXB0b3I8VCwgYW55PjtcblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5kRm9ybUNvbnRyb2wgPSB0aGlzLmZvcm1Db250cm9sIGFzIEZvcm1Db250cm9sO1xuICAgICAgICB0aGlzLmRlc2NyaXB0b3IgPSB0aGlzLnRvWydkZXNjcmlwdG9yJ107XG4gICAgfVxufVxuIiwiPG1uZy1kcm9wZG93blxuICAgIFtpZF09XCIkYW55KGtleSlcIlxuICAgIFtmb3JtQ29udHJvbF09XCJkRm9ybUNvbnRyb2xcIlxuICAgIFtmb3JtbHlBdHRyaWJ1dGVzXT1cImZpZWxkXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwiZGVzY3JpcHRvci5wbGFjZWhvbGRlclwiXG4gICAgW2RhdGFQcm92aWRlcl09XCJkZXNjcmlwdG9yLmRhdGFQcm92aWRlclwiXG4gICAgW2l0ZW1zTGFiZWxQcm9wZXJ0eV09XCJkZXNjcmlwdG9yLml0ZW1zTGFiZWxQcm9wZXJ0eVwiXG4gICAgW2l0ZW1zVmFsdWVQcm9wZXJ0eV09XCJkZXNjcmlwdG9yLml0ZW1zVmFsdWVQcm9wZXJ0eVwiXG4gICAgW2l0ZW1zRGlzYWJsZWRQcm9wZXJ0eV09XCJkZXNjcmlwdG9yLml0ZW1zRGlzYWJsZWRQcm9wZXJ0eVwiXG4gICAgW2RhdGFLZXlQcm9wZXJ0eV09XCJkZXNjcmlwdG9yLmRhdGFLZXlQcm9wZXJ0eVwiXG4gICAgW3Nob3dDbGVhcl09XCIhdG8ucmVxdWlyZWRcIlxuICAgIFtjbGFzc05hbWVdPVwiZGVzY3JpcHRvci5pbnB1dENsYXNzTmFtZVwiPlxuPC9tbmctZHJvcGRvd24+XG4iXX0=
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LWZpZWxkLWRyb3Bkb3duLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2Zvcm1seS9maWVsZHMvZm9ybWx5LWZpZWxkLWRyb3Bkb3duL2Zvcm1seS1maWVsZC1kcm9wZG93bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvZmllbGRzL2Zvcm1seS1maWVsZC1kcm9wZG93bi9mb3JtbHktZmllbGQtZHJvcGRvd24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUd6RSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7Ozs7O0FBUzNDLE1BQU0sT0FBTywrQkFBbUMsU0FBUSxTQUFTO0lBSXRELFFBQVE7UUFDWCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxXQUEwQixDQUFDO1FBQ3BELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1QyxDQUFDOzs0SEFQUSwrQkFBK0I7Z0hBQS9CLCtCQUErQix3RkNaNUMsOGxCQWNBOzJGREZhLCtCQUErQjtrQkFMM0MsU0FBUzsrQkFDSSwyQkFBMkIsbUJBRXBCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1Db250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7RmllbGRUeXBlfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcblxuaW1wb3J0IHtGaWVsZExvb2t1cERlc2NyaXB0b3J9IGZyb20gJy4uLy4uLy4uLy4uLy4uL2Rlc2NyaXB0b3JzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdtbmctZm9ybWx5LWZpZWxkLWRyb3Bkb3duJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZm9ybWx5LWZpZWxkLWRyb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBNbmdGb3JtbHlGaWVsZERyb3Bkb3duQ29tcG9uZW50PFQ+IGV4dGVuZHMgRmllbGRUeXBlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBwdWJsaWMgZEZvcm1Db250cm9sITogRm9ybUNvbnRyb2w7XG4gICAgcHVibGljIGRlc2NyaXB0b3IhOiBGaWVsZExvb2t1cERlc2NyaXB0b3I8VCwgYW55PjtcblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5kRm9ybUNvbnRyb2wgPSB0aGlzLmZvcm1Db250cm9sIGFzIEZvcm1Db250cm9sO1xuICAgICAgICB0aGlzLmRlc2NyaXB0b3IgPSB0aGlzLnRvWydkZXNjcmlwdG9yJ107XG4gICAgfVxufVxuIiwiPG1uZy1kcm9wZG93blxuICAgIFtpZF09XCIkYW55KGtleSlcIlxuICAgIFtmb3JtQ29udHJvbF09XCJkRm9ybUNvbnRyb2xcIlxuICAgIFtmb3JtbHlBdHRyaWJ1dGVzXT1cImZpZWxkXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwiZGVzY3JpcHRvci5wbGFjZWhvbGRlclwiXG4gICAgW2RhdGFQcm92aWRlcl09XCJkZXNjcmlwdG9yLmRhdGFQcm92aWRlclwiXG4gICAgW2l0ZW1zTGFiZWxQcm9wZXJ0eV09XCJkZXNjcmlwdG9yLml0ZW1zTGFiZWxQcm9wZXJ0eVwiXG4gICAgW2l0ZW1zTGFiZWxUcmFuc2xhdGVdPVwiZGVzY3JpcHRvci5pdGVtc0xhYmVsVHJhbnNsYXRlXCJcbiAgICBbaXRlbXNWYWx1ZVByb3BlcnR5XT1cImRlc2NyaXB0b3IuaXRlbXNWYWx1ZVByb3BlcnR5XCJcbiAgICBbaXRlbXNEaXNhYmxlZFByb3BlcnR5XT1cImRlc2NyaXB0b3IuaXRlbXNEaXNhYmxlZFByb3BlcnR5XCJcbiAgICBbZGF0YUtleVByb3BlcnR5XT1cImRlc2NyaXB0b3IuZGF0YUtleVByb3BlcnR5XCJcbiAgICBbc2hvd0NsZWFyXT1cIiF0by5yZXF1aXJlZFwiXG4gICAgW2NsYXNzTmFtZV09XCJkZXNjcmlwdG9yLmlucHV0Q2xhc3NOYW1lXCI+XG48L21uZy1kcm9wZG93bj5cbiJdfQ==
@@ -1,4 +1,4 @@
1
- import { Component } from '@angular/core';
1
+ import { Component, Input } from '@angular/core';
2
2
  import { AMngTableviewRouteComponent } from './tableview-route.abstract.component';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/router";
@@ -9,25 +9,43 @@ export class MngTableviewRouteComponent extends AMngTableviewRouteComponent {
9
9
  this.route = route;
10
10
  }
11
11
  createTableviewDescriptor() {
12
+ if (this.descriptorInit) {
13
+ return this.descriptorInit;
14
+ }
12
15
  if (!this.route.snapshot.data['tableviewData'].descriptor) {
13
16
  throw Error('Tableview requires a descriptor.');
14
17
  }
15
18
  return this.route.snapshot.data['tableviewData'].descriptor;
16
19
  }
17
20
  createTableviewDataProvider() {
21
+ if (this.dataProviderInit) {
22
+ return this.dataProviderInit;
23
+ }
18
24
  if (!this.route.snapshot.data['tableviewData'].dataProvider) {
19
25
  throw Error('Tableview requires a data provider.');
20
26
  }
21
27
  return this.route.snapshot.data['tableviewData'].dataProvider;
22
28
  }
23
29
  createActionDescriptors() {
30
+ if (this.actionsInit) {
31
+ return this.actionsInit;
32
+ }
24
33
  return this.route.snapshot.data['tableviewData'].fieldActions ?? super.createActionDescriptors();
25
34
  }
26
35
  }
27
36
  MngTableviewRouteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableviewRouteComponent, deps: [{ token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
28
- MngTableviewRouteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableviewRouteComponent, selector: "mng-tableview-route", usesInheritance: true, ngImport: i0, template: "<div class=\"grid\">\n <div class=\"col-12\">\n <mng-tableview [descriptor]=\"descriptor\" [dataProvider]=\"dataProvider\" [actions]=\"actions\"></mng-tableview>\n </div>\n</div>\n", components: [{ type: i2.MngTableviewComponent, selector: "mng-tableview", inputs: ["descriptor", "dataProvider", "actions"] }] });
37
+ MngTableviewRouteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableviewRouteComponent, selector: "mng-tableview-route", inputs: { descriptorInit: ["descriptor", "descriptorInit"], dataProviderInit: ["dataProvider", "dataProviderInit"], actionsInit: ["actions", "actionsInit"] }, usesInheritance: true, ngImport: i0, template: "<div class=\"grid\">\n <div class=\"col-12\">\n <mng-tableview [descriptor]=\"descriptor\" [dataProvider]=\"dataProvider\" [actions]=\"actions\"></mng-tableview>\n </div>\n</div>\n", components: [{ type: i2.MngTableviewComponent, selector: "mng-tableview", inputs: ["descriptor", "dataProvider", "actions"] }] });
29
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableviewRouteComponent, decorators: [{
30
39
  type: Component,
31
40
  args: [{ selector: 'mng-tableview-route', template: "<div class=\"grid\">\n <div class=\"col-12\">\n <mng-tableview [descriptor]=\"descriptor\" [dataProvider]=\"dataProvider\" [actions]=\"actions\"></mng-tableview>\n </div>\n</div>\n" }]
32
- }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }]; } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGV2aWV3LXJvdXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXZpZXcvcm91dGUvdGFibGV2aWV3LXJvdXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2Fzc2V0cy90ZW1wbGF0ZXMvdGFibGV2aWV3LXJvdXRlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFLaEQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sc0NBQXNDLENBQUM7Ozs7QUFNakYsTUFBTSxPQUFPLDBCQUFpQyxTQUFRLDJCQUFpQztJQUNuRixZQUFvQixLQUFxQjtRQUNyQyxLQUFLLEVBQUUsQ0FBQztRQURRLFVBQUssR0FBTCxLQUFLLENBQWdCO0lBRXpDLENBQUM7SUFFUyx5QkFBeUI7UUFDL0IsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxVQUFVLEVBQUU7WUFDdkQsTUFBTSxLQUFLLENBQUMsa0NBQWtDLENBQUMsQ0FBQztTQUNuRDtRQUNELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLFVBQVUsQ0FBQztJQUNoRSxDQUFDO0lBRVMsMkJBQTJCO1FBQ2pDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsWUFBWSxFQUFFO1lBQ3pELE1BQU0sS0FBSyxDQUFDLHFDQUFxQyxDQUFDLENBQUM7U0FDdEQ7UUFDRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxZQUFZLENBQUM7SUFDbEUsQ0FBQztJQUVrQix1QkFBdUI7UUFDdEMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsWUFBWSxJQUFJLEtBQUssQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO0lBQ3JHLENBQUM7O3VIQXJCUSwwQkFBMEI7MkdBQTFCLDBCQUEwQixrRkNYdkMsbU1BS0E7MkZETWEsMEJBQTBCO2tCQUp0QyxTQUFTOytCQUNJLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcblxuaW1wb3J0IHtJVGFibGV2aWV3RGF0YVByb3ZpZGVyfSBmcm9tICcuLi8uLi8uLi9kYXRhLXByb3ZpZGVycyc7XG5pbXBvcnQge0FjdGlvbkRlc2NyaXB0b3IsIFRhYmxldmlld0Rlc2NyaXB0b3J9IGZyb20gJy4uLy4uLy4uL2Rlc2NyaXB0b3JzJztcbmltcG9ydCB7QU1uZ1RhYmxldmlld1JvdXRlQ29tcG9uZW50fSBmcm9tICcuL3RhYmxldmlldy1yb3V0ZS5hYnN0cmFjdC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ21uZy10YWJsZXZpZXctcm91dGUnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi4vLi4vLi4vLi4vLi4vYXNzZXRzL3RlbXBsYXRlcy90YWJsZXZpZXctcm91dGUuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIE1uZ1RhYmxldmlld1JvdXRlQ29tcG9uZW50PFQsIFM+IGV4dGVuZHMgQU1uZ1RhYmxldmlld1JvdXRlQ29tcG9uZW50PFQsIFM+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBjcmVhdGVUYWJsZXZpZXdEZXNjcmlwdG9yKCk6IFRhYmxldmlld0Rlc2NyaXB0b3I8VD4ge1xuICAgICAgICBpZiAoIXRoaXMucm91dGUuc25hcHNob3QuZGF0YVsndGFibGV2aWV3RGF0YSddLmRlc2NyaXB0b3IpIHtcbiAgICAgICAgICAgIHRocm93IEVycm9yKCdUYWJsZXZpZXcgcmVxdWlyZXMgYSBkZXNjcmlwdG9yLicpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzLnJvdXRlLnNuYXBzaG90LmRhdGFbJ3RhYmxldmlld0RhdGEnXS5kZXNjcmlwdG9yO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBjcmVhdGVUYWJsZXZpZXdEYXRhUHJvdmlkZXIoKTogSVRhYmxldmlld0RhdGFQcm92aWRlcjxULCBTPiB7XG4gICAgICAgIGlmICghdGhpcy5yb3V0ZS5zbmFwc2hvdC5kYXRhWyd0YWJsZXZpZXdEYXRhJ10uZGF0YVByb3ZpZGVyKSB7XG4gICAgICAgICAgICB0aHJvdyBFcnJvcignVGFibGV2aWV3IHJlcXVpcmVzIGEgZGF0YSBwcm92aWRlci4nKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy5yb3V0ZS5zbmFwc2hvdC5kYXRhWyd0YWJsZXZpZXdEYXRhJ10uZGF0YVByb3ZpZGVyO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBvdmVycmlkZSBjcmVhdGVBY3Rpb25EZXNjcmlwdG9ycygpOiBBcnJheTxBY3Rpb25EZXNjcmlwdG9yPFQ+PiB7XG4gICAgICAgIHJldHVybiB0aGlzLnJvdXRlLnNuYXBzaG90LmRhdGFbJ3RhYmxldmlld0RhdGEnXS5maWVsZEFjdGlvbnMgPz8gc3VwZXIuY3JlYXRlQWN0aW9uRGVzY3JpcHRvcnMoKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZ3JpZFwiPlxuICAgIDxkaXYgY2xhc3M9XCJjb2wtMTJcIj5cbiAgICAgICAgPG1uZy10YWJsZXZpZXcgW2Rlc2NyaXB0b3JdPVwiZGVzY3JpcHRvclwiIFtkYXRhUHJvdmlkZXJdPVwiZGF0YVByb3ZpZGVyXCIgW2FjdGlvbnNdPVwiYWN0aW9uc1wiPjwvbW5nLXRhYmxldmlldz5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
41
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }]; }, propDecorators: { descriptorInit: [{
42
+ type: Input,
43
+ args: ['descriptor']
44
+ }], dataProviderInit: [{
45
+ type: Input,
46
+ args: ['dataProvider']
47
+ }], actionsInit: [{
48
+ type: Input,
49
+ args: ['actions']
50
+ }] } });
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGV2aWV3LXJvdXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy90YWJsZXZpZXcvcm91dGUvdGFibGV2aWV3LXJvdXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3RlbXBsYXRlcy90YWJsZXZpZXctcm91dGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFLdkQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sc0NBQXNDLENBQUM7Ozs7QUFNakYsTUFBTSxPQUFPLDBCQUFpQyxTQUFRLDJCQUFpQztJQUtuRixZQUFvQixLQUFxQjtRQUNyQyxLQUFLLEVBQUUsQ0FBQztRQURRLFVBQUssR0FBTCxLQUFLLENBQWdCO0lBRXpDLENBQUM7SUFFUyx5QkFBeUI7UUFDL0IsSUFBSSxJQUFJLENBQUMsY0FBYyxFQUFFO1lBQ3JCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztTQUM5QjtRQUNELElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsVUFBVSxFQUFFO1lBQ3ZELE1BQU0sS0FBSyxDQUFDLGtDQUFrQyxDQUFDLENBQUM7U0FDbkQ7UUFDRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxVQUFVLENBQUM7SUFDaEUsQ0FBQztJQUVTLDJCQUEyQjtRQUNqQyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtZQUN2QixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztTQUNoQztRQUNELElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsWUFBWSxFQUFFO1lBQ3pELE1BQU0sS0FBSyxDQUFDLHFDQUFxQyxDQUFDLENBQUM7U0FDdEQ7UUFDRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxZQUFZLENBQUM7SUFDbEUsQ0FBQztJQUVrQix1QkFBdUI7UUFDdEMsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ2xCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztTQUMzQjtRQUNELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLFlBQVksSUFBSSxLQUFLLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztJQUNyRyxDQUFDOzt1SEFsQ1EsMEJBQTBCOzJHQUExQiwwQkFBMEIsaVBDWHZDLG1NQUtBOzJGRE1hLDBCQUEwQjtrQkFKdEMsU0FBUzsrQkFDSSxxQkFBcUI7cUdBSUgsY0FBYztzQkFBekMsS0FBSzt1QkFBQyxZQUFZO2dCQUNXLGdCQUFnQjtzQkFBN0MsS0FBSzt1QkFBQyxjQUFjO2dCQUNJLFdBQVc7c0JBQW5DLEtBQUs7dUJBQUMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbmltcG9ydCB7SVRhYmxldmlld0RhdGFQcm92aWRlcn0gZnJvbSAnLi4vLi4vLi4vZGF0YS1wcm92aWRlcnMnO1xuaW1wb3J0IHtBY3Rpb25EZXNjcmlwdG9yLCBUYWJsZXZpZXdEZXNjcmlwdG9yfSBmcm9tICcuLi8uLi8uLi9kZXNjcmlwdG9ycyc7XG5pbXBvcnQge0FNbmdUYWJsZXZpZXdSb3V0ZUNvbXBvbmVudH0gZnJvbSAnLi90YWJsZXZpZXctcm91dGUuYWJzdHJhY3QuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdtbmctdGFibGV2aWV3LXJvdXRlJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4uLy4uLy4uLy4uLy4uL3RlbXBsYXRlcy90YWJsZXZpZXctcm91dGUuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIE1uZ1RhYmxldmlld1JvdXRlQ29tcG9uZW50PFQsIFM+IGV4dGVuZHMgQU1uZ1RhYmxldmlld1JvdXRlQ29tcG9uZW50PFQsIFM+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoJ2Rlc2NyaXB0b3InKSBwdWJsaWMgZGVzY3JpcHRvckluaXQ/OiBUYWJsZXZpZXdEZXNjcmlwdG9yPFQ+O1xuICAgIEBJbnB1dCgnZGF0YVByb3ZpZGVyJykgcHVibGljIGRhdGFQcm92aWRlckluaXQ/OiBJVGFibGV2aWV3RGF0YVByb3ZpZGVyPFQsIFM+O1xuICAgIEBJbnB1dCgnYWN0aW9ucycpIHB1YmxpYyBhY3Rpb25zSW5pdD86IEFycmF5PEFjdGlvbkRlc2NyaXB0b3I8VD4+O1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByb3V0ZTogQWN0aXZhdGVkUm91dGUpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgY3JlYXRlVGFibGV2aWV3RGVzY3JpcHRvcigpOiBUYWJsZXZpZXdEZXNjcmlwdG9yPFQ+IHtcbiAgICAgICAgaWYgKHRoaXMuZGVzY3JpcHRvckluaXQpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmRlc2NyaXB0b3JJbml0O1xuICAgICAgICB9XG4gICAgICAgIGlmICghdGhpcy5yb3V0ZS5zbmFwc2hvdC5kYXRhWyd0YWJsZXZpZXdEYXRhJ10uZGVzY3JpcHRvcikge1xuICAgICAgICAgICAgdGhyb3cgRXJyb3IoJ1RhYmxldmlldyByZXF1aXJlcyBhIGRlc2NyaXB0b3IuJyk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMucm91dGUuc25hcHNob3QuZGF0YVsndGFibGV2aWV3RGF0YSddLmRlc2NyaXB0b3I7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGNyZWF0ZVRhYmxldmlld0RhdGFQcm92aWRlcigpOiBJVGFibGV2aWV3RGF0YVByb3ZpZGVyPFQsIFM+IHtcbiAgICAgICAgaWYgKHRoaXMuZGF0YVByb3ZpZGVySW5pdCkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMuZGF0YVByb3ZpZGVySW5pdDtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIXRoaXMucm91dGUuc25hcHNob3QuZGF0YVsndGFibGV2aWV3RGF0YSddLmRhdGFQcm92aWRlcikge1xuICAgICAgICAgICAgdGhyb3cgRXJyb3IoJ1RhYmxldmlldyByZXF1aXJlcyBhIGRhdGEgcHJvdmlkZXIuJyk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMucm91dGUuc25hcHNob3QuZGF0YVsndGFibGV2aWV3RGF0YSddLmRhdGFQcm92aWRlcjtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb3ZlcnJpZGUgY3JlYXRlQWN0aW9uRGVzY3JpcHRvcnMoKTogQXJyYXk8QWN0aW9uRGVzY3JpcHRvcjxUPj4ge1xuICAgICAgICBpZiAodGhpcy5hY3Rpb25zSW5pdCkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMuYWN0aW9uc0luaXQ7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRoaXMucm91dGUuc25hcHNob3QuZGF0YVsndGFibGV2aWV3RGF0YSddLmZpZWxkQWN0aW9ucyA/PyBzdXBlci5jcmVhdGVBY3Rpb25EZXNjcmlwdG9ycygpO1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJncmlkXCI+XG4gICAgPGRpdiBjbGFzcz1cImNvbC0xMlwiPlxuICAgICAgICA8bW5nLXRhYmxldmlldyBbZGVzY3JpcHRvcl09XCJkZXNjcmlwdG9yXCIgW2RhdGFQcm92aWRlcl09XCJkYXRhUHJvdmlkZXJcIiBbYWN0aW9uc109XCJhY3Rpb25zXCI+PC9tbmctdGFibGV2aWV3PlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -72,15 +72,28 @@ export class MngTableColumnFilterComponent {
72
72
  filterCallback(value);
73
73
  }
74
74
  }
75
+ // eslint-disable-next-line @typescript-eslint/ban-types
76
+ dropdownFilter(value, filterCallback) {
77
+ if (value) {
78
+ let filterValue = value;
79
+ if (this.lookupDescriptor.itemsValueProperty) {
80
+ filterValue = filterValue[this.lookupDescriptor.itemsValueProperty];
81
+ }
82
+ filterCallback(filterValue);
83
+ }
84
+ else {
85
+ filterCallback(value);
86
+ }
87
+ }
75
88
  }
76
89
  MngTableColumnFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnFilterComponent, deps: [{ token: i1.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Component });
77
- MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, ngImport: i0, template: "<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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"true\"\n (valueChange)=\"filterCallback($event)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n", components: [{ type: i2.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping"] }, { type: i3.MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "multiselect", "placeholder", "className", "dropdownClassName"], outputs: ["valueChange"] }, { type: i4.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsValueProperty", "itemsDisabledProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i7.TranslatePipe } });
90
+ MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, ngImport: i0, template: "<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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\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", components: [{ type: i2.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping"] }, { type: i3.MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "multiselect", "placeholder", "className", "dropdownClassName"], outputs: ["valueChange"] }, { type: i4.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsLabelTranslate", "itemsValueProperty", "itemsDisabledProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i7.TranslatePipe } });
78
91
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnFilterComponent, decorators: [{
79
92
  type: Component,
80
- args: [{ selector: 'mng-table-column-filter', template: "<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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"true\"\n (valueChange)=\"filterCallback($event)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n" }]
93
+ args: [{ selector: 'mng-table-column-filter', template: "<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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\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" }]
81
94
  }], ctorParameters: function () { return [{ type: i1.PrimeNGConfig }]; }, propDecorators: { descriptor: [{
82
95
  type: Input
83
96
  }], display: [{
84
97
  type: Input
85
98
  }] } });
86
- //# 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        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","<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                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\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                [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\n                [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n                [className]=\"lookupDescriptor.className\"\n                [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n                [showClear]=\"true\"\n                (valueChange)=\"filterCallback($event)\">\n            </mng-dropdown>\n        </ng-container>\n    </ng-template>\n</p-columnFilter>\n"]}
99
+ //# 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        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        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","<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                [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n                [multiselect]=\"lookupDescriptor.multiselect\"\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                [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\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"]}