UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

103 lines 15.5 kB
import { Component, Inject, Injector, Optional } from "@angular/core"; import { NAE_BASE_FILTER } from "../../../search/models/base-filter-injection-token"; import { SimpleFilter } from "../../../filter/models/simple-filter"; import { NAE_VIEW_ID_SEGMENT } from "../../../user/models/view-id-injection-tokens"; import { ViewIdService } from "../../../user/services/view-id.service"; import { AbstractBaseDataFieldComponent } from "../../base-component/abstract-base-data-field.component"; import { DATA_FIELD_PORTAL_DATA } from "../../models/data-field-portal-data-injection-token"; import { ComponentPortal } from "@angular/cdk/portal"; import { NAE_DEFAULT_HEADERS } from "../../../header/models/default-headers-token"; import { NAE_CLICKABLE_TASKS } from "../model/task-ref-injection-tokens"; import { NAE_DATAFIELD_ALLOWED_NETS } from "../../case-ref-field/model/case-ref-injection-tokens"; import * as i0 from "@angular/core"; export class AbstractTaskRefListFieldComponent extends AbstractBaseDataFieldComponent { injector; taskViewType; componentPortal; _sub; _subComp; constructor(injector, taskViewType, dataFieldPortalData) { super(dataFieldPortalData); this.injector = injector; this.taskViewType = taskViewType; } ngAfterViewInit() { this.createFilter(); this._sub = this.dataField.valueChanges().subscribe(() => { this.callCreateFilter(); }); this._subComp = this.dataField.componentChange$().subscribe(() => { this.callCreateFilter(); }); } callCreateFilter() { this.createFilter(); } createFilter() { let portalInjector; const filterProperty = this.dataField?.component?.properties?.filter === 'true'; let query; if (filterProperty) { try { query = JSON.parse(this.dataField?.component?.properties?.filterQuery); } catch { console.warn('Invalid filterQuery JSON on TaskRef field ', this.dataField?.stringId); query = undefined; } } let providers = [ { provide: NAE_DEFAULT_HEADERS, useValue: this.dataField.component?.properties?.headers?.split(',') }, { provide: NAE_CLICKABLE_TASKS, useValue: this.dataField.component?.properties?.clickable === undefined ? true : this.dataField.component?.properties?.clickable === "true" }, { provide: NAE_DATAFIELD_ALLOWED_NETS, useValue: this.dataField.component?.properties?.allowedNets === undefined ? [] : this.dataField.component?.properties?.allowedNets.split(',') }, { provide: NAE_BASE_FILTER, useValue: { filter: SimpleFilter.fromTaskQuery((filterProperty && query ? query : { stringId: this.dataField.value.length > 0 ? this.dataField.value : '' })) } }, { provide: NAE_VIEW_ID_SEGMENT, useValue: this.dataField.parentCaseId + '_' + this.dataField.parentTaskId + '_' + this.dataField.stringId }, { provide: ViewIdService, useClass: ViewIdService } ]; portalInjector = Injector.create({ providers, parent: this.injector }); this.componentPortal = new ComponentPortal(this.taskViewType, null, portalInjector); } ngOnDestroy() { super.ngOnDestroy(); if (this._sub) { this._sub.unsubscribe(); } if (this._subComp) { this._subComp.unsubscribe(); } } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractTaskRefListFieldComponent, deps: [{ token: i0.Injector }, { token: i0.Type }, { token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractTaskRefListFieldComponent, selector: "ncc-abstract-task-ref-list-field", usesInheritance: true, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractTaskRefListFieldComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-task-ref-list-field', template: '' }] }], ctorParameters: () => [{ type: i0.Injector }, { type: i0.Type }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DATA_FIELD_PORTAL_DATA] }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-task-ref-list-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/task-ref-field/task-ref-list-field/abstract-task-ref-list-field.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAa,QAAQ,EAAO,MAAM,eAAe,CAAC;AAEpG,OAAO,EAAC,eAAe,EAAC,MAAM,oDAAoD,CAAC;AACnF,OAAO,EAAC,YAAY,EAAC,MAAM,sCAAsC,CAAC;AAElE,OAAO,EAAC,mBAAmB,EAAC,MAAM,+CAA+C,CAAC;AAClF,OAAO,EAAC,aAAa,EAAC,MAAM,wCAAwC,CAAC;AACrE,OAAO,EAAC,8BAA8B,EAAC,MAAM,yDAAyD,CAAC;AACvG,OAAO,EAAC,sBAAsB,EAAsB,MAAM,qDAAqD,CAAC;AAChH,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAC,mBAAmB,EAAC,MAAM,8CAA8C,CAAC;AACjF,OAAO,EAAC,mBAAmB,EAAC,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAC,0BAA0B,EAAC,MAAM,sDAAsD,CAAC;;AAOhG,MAAM,OAAgB,iCAAkC,SAAQ,8BAA4C;IAMxE;IACA;IALzB,eAAe,CAAuB;IACnC,IAAI,CAAe;IACnB,QAAQ,CAAe;IAEjC,YAAgC,QAAkB,EAClB,YAAuB,EACW,mBAAsD;QACpH,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAHC,aAAQ,GAAR,QAAQ,CAAU;QAClB,iBAAY,GAAZ,YAAY,CAAW;IAGvD,CAAC;IAED,eAAe;QACX,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACrD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7D,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACP,CAAC;IAES,gBAAgB;QACtB,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAED,YAAY;QACR,IAAI,cAAc,CAAC;QACnB,MAAM,cAAc,GAAY,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,KAAK,MAAM,CAAC;QACzF,IAAI,KAA4B,CAAC;QACjC,IAAI,cAAc,EAAE;YAChB,IAAI;gBACA,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,CAA0B,CAAC;aACnG;YAAC,MAAM;gBACJ,OAAO,CAAC,IAAI,CAAC,4CAA4C,EAAE,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;gBACrF,KAAK,GAAG,SAAS,CAAC;aACrB;SACJ;QACD,IAAI,SAAS,GAAG;YACZ;gBACI,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,CAAC,GAAG,CAAC;aACpG;YACD;gBACI,OAAO,EAAE,mBAAmB;gBAC5B,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,UAAU,EAAE,SAAS,KAAK,SAAS,CAAC,CAAC;oBACrE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,UAAU,EAAE,SAAS,KAAK,MAAM;aACxE;YACD;gBACI,OAAO,EAAE,0BAA0B;gBACnC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,UAAU,EAAE,WAAW,KAAK,SAAS,CAAC,CAAC;oBACvE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,UAAU,EAAE,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC;aACxE;YACD;gBACI,OAAO,EAAE,eAAe;gBACxB,QAAQ,EAAE,EAAE,MAAM,EAAE,YAAY,CAAC,aAAa,CACtC,CAAC,cAAc,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAC,CAAC,CAC9G,EAAe;aACvB;YACD;gBACI,OAAO,EAAE,mBAAmB;gBAC5B,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ;aAC5G;YACD,EAAE,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,aAAa,EAAE;SACtD,CAAC;QACF,cAAc,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC7B,SAAS;YACT,MAAM,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC;IACxF,CAAC;IAED,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;SAC3B;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAA;SAC9B;IACL,CAAC;wGA/EiB,iCAAiC,8DAQT,sBAAsB;4FAR9C,iCAAiC,+FAFzC,EAAE;;4FAEM,iCAAiC;kBAJtD,SAAS;mBAAC;oBACP,QAAQ,EAAE,kCAAkC;oBAC5C,QAAQ,EAAE,EAAE;iBACf;;0BAS0B,QAAQ;;0BAAI,MAAM;2BAAC,sBAAsB","sourcesContent":["import {AfterViewInit, Component, Inject, Injector, OnDestroy, Optional, Type} from \"@angular/core\";\nimport {TaskRefField} from \"../model/task-ref-field\";\nimport {NAE_BASE_FILTER} from \"../../../search/models/base-filter-injection-token\";\nimport {SimpleFilter} from \"../../../filter/models/simple-filter\";\nimport {BaseFilter} from \"../../../search/models/base-filter\";\nimport {NAE_VIEW_ID_SEGMENT} from \"../../../user/models/view-id-injection-tokens\";\nimport {ViewIdService} from \"../../../user/services/view-id.service\";\nimport {AbstractBaseDataFieldComponent} from \"../../base-component/abstract-base-data-field.component\";\nimport {DATA_FIELD_PORTAL_DATA, DataFieldPortalData} from \"../../models/data-field-portal-data-injection-token\";\nimport {ComponentPortal} from \"@angular/cdk/portal\";\nimport {Subscription} from \"rxjs\";\nimport {NAE_DEFAULT_HEADERS} from \"../../../header/models/default-headers-token\";\nimport {NAE_CLICKABLE_TASKS} from \"../model/task-ref-injection-tokens\";\nimport {NAE_DATAFIELD_ALLOWED_NETS} from \"../../case-ref-field/model/case-ref-injection-tokens\";\nimport {TaskSearchRequestBody} from \"../../../filter/models/task-search-request-body\";\n\n@Component({\n    selector: 'ncc-abstract-task-ref-list-field',\n    template: ''\n})\nexport abstract class AbstractTaskRefListFieldComponent extends AbstractBaseDataFieldComponent<TaskRefField> implements AfterViewInit, OnDestroy {\n\n    public componentPortal: ComponentPortal<any>;\n    protected _sub: Subscription;\n    protected _subComp: Subscription;\n\n    protected constructor(protected injector: Injector,\n                          protected taskViewType: Type<any>,\n                          @Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<TaskRefField>) {\n        super(dataFieldPortalData);\n    }\n\n    ngAfterViewInit(): void {\n        this.createFilter();\n        this._sub = this.dataField.valueChanges().subscribe(() => {\n            this.callCreateFilter();\n        });\n        this._subComp = this.dataField.componentChange$().subscribe(() => {\n            this.callCreateFilter();\n        });\n    }\n\n    protected callCreateFilter() {\n        this.createFilter();\n    }\n\n    createFilter() {\n        let portalInjector;\n        const filterProperty: boolean = this.dataField?.component?.properties?.filter === 'true';\n        let query: TaskSearchRequestBody;\n        if (filterProperty) {\n            try {\n                query = JSON.parse(this.dataField?.component?.properties?.filterQuery) as TaskSearchRequestBody;\n            } catch {\n                console.warn('Invalid filterQuery JSON on TaskRef field ', this.dataField?.stringId);\n                query = undefined;\n            }\n        }\n        let providers = [\n            {\n                provide: NAE_DEFAULT_HEADERS, useValue: this.dataField.component?.properties?.headers?.split(',')\n            },\n            {\n                provide: NAE_CLICKABLE_TASKS,\n                useValue: this.dataField.component?.properties?.clickable === undefined ?\n                    true : this.dataField.component?.properties?.clickable === \"true\"\n            },\n            {\n                provide: NAE_DATAFIELD_ALLOWED_NETS,\n                useValue: this.dataField.component?.properties?.allowedNets === undefined ?\n                    [] : this.dataField.component?.properties?.allowedNets.split(',')\n            },\n            {\n                provide: NAE_BASE_FILTER,\n                useValue: { filter: SimpleFilter.fromTaskQuery(\n                        (filterProperty && query ? query : {stringId: this.dataField.value.length > 0 ? this.dataField.value : ''})\n                    )} as BaseFilter\n            },\n            {\n                provide: NAE_VIEW_ID_SEGMENT,\n                useValue: this.dataField.parentCaseId + '_' + this.dataField.parentTaskId + '_' + this.dataField.stringId\n            },\n            { provide: ViewIdService, useClass: ViewIdService }\n        ];\n        portalInjector = Injector.create({\n            providers,\n            parent: this.injector\n        });\n        this.componentPortal = new ComponentPortal(this.taskViewType, null, portalInjector);\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n        if (this._sub) {\n            this._sub.unsubscribe();\n        }\n        if (this._subComp) {\n            this._subComp.unsubscribe()\n        }\n    }\n}\n"]}