UNPKG

@netgrif/components

Version:

Netgrif Application Engine frontend Angular components

193 lines 35.9 kB
import { Component, Inject, Optional, ViewChild } from '@angular/core'; import { AbstractCaseViewComponent, AllowedNetsService, AllowedNetsServiceFactory, CaseViewService, CategoryFactory, defaultCaseSearchCategoriesFactory, FilterType, NAE_CASE_REF_CREATE_CASE, NAE_CASE_REF_SEARCH, NAE_SEARCH_CATEGORIES, NAE_TAB_DATA, NAE_VIEW_ID_SEGMENT, OverflowService, SearchMode, SearchService, SimpleFilter, ViewIdService, DATA_FIELD_PORTAL_DATA, MultichoiceField, EnumerationField, NAE_DATAFIELD_ALLOWED_NETS, NAE_DEFAULT_HEADERS, NAE_CLICKABLE_CASES, NAE_OPEN_SINGLE_TASK, NAE_SINGLE_TASK_QUERY } from '@netgrif/components-core'; import { DefaultTabbedTaskViewComponent } from '../../tabbed/default-tabbed-task-view/default-tabbed-task-view.component'; import { DefaultTabbedSingleTaskViewComponent } from "../../tabbed/default-tabbed-single-task-view/default-tabbed-single-task-view.component"; import * as i0 from "@angular/core"; import * as i1 from "@netgrif/components-core"; import * as i2 from "@angular/common"; import * as i3 from "@ngbracket/ngx-layout"; import * as i4 from "@ngbracket/ngx-layout/extended"; import * as i5 from "../../../../../search/search-component/search.component"; import * as i6 from "../../../../../header/header.component"; import * as i7 from "../../../../../view/case-view/components/create-case-button/create-case-button.component"; import * as i8 from "../../../../../view/case-view/components/case-list-paginator/case-list-paginator.component"; const localAllowedNetsFactory = (factory, allowedNets) => { if (allowedNets?.length > 0) { return factory.createFromArray(allowedNets); } else { return factory.createWithAllNets(); } }; export class DefaultCaseRefListViewComponent extends AbstractCaseViewComponent { _injectedTabData; _dataFieldPortalData; _caseRefCreateCase; _caseRefSearch; _caseHeaders; _clickableCases; _openSingleTask; _singleTaskQuery; caseHeaderComponent; additionalFilterData; search; createCase; caseHeadersCount; constructor(caseViewService, overflowService, _injectedTabData, _dataFieldPortalData, _caseRefCreateCase = false, _caseRefSearch = false, _caseHeaders, _clickableCases = true, _openSingleTask = false, _singleTaskQuery) { super(caseViewService, overflowService, undefined, { enableCaseTitle: true, isCaseTitleRequired: true }); this._injectedTabData = _injectedTabData; this._dataFieldPortalData = _dataFieldPortalData; this._caseRefCreateCase = _caseRefCreateCase; this._caseRefSearch = _caseRefSearch; this._caseHeaders = _caseHeaders; this._clickableCases = _clickableCases; this._openSingleTask = _openSingleTask; this._singleTaskQuery = _singleTaskQuery; this.search = !!_caseRefSearch; this.createCase = !!_caseRefCreateCase; this.caseHeadersCount = this._caseHeaders?.length; } ngAfterViewInit() { this.initializeHeader(this.caseHeaderComponent); } isApproval() { return this._dataFieldPortalData?.dataField instanceof MultichoiceField || this._dataFieldPortalData?.dataField instanceof EnumerationField; } handleCaseClick(clickedCase) { if (this._injectedTabData !== null && this._clickableCases) { this.openTab(clickedCase); } } disabled() { return this._dataFieldPortalData?.dataField?.formControlRef.disabled; } openTab(openCase) { let baseFilter; if (this._singleTaskQuery !== undefined) { const query = JSON.parse(this._singleTaskQuery); if (query.query !== undefined) { query.query = query.query + ` AND caseId:${openCase.stringId}`; } else { if (query.case !== undefined) { query.case.id = openCase.stringId; } else { query.case = { id: `${openCase.stringId}` }; } } baseFilter = SimpleFilter.fromTaskQuery(query); } else { baseFilter = new SimpleFilter('', FilterType.TASK, { case: { id: `${openCase.stringId}` } }); } this._injectedTabData.tabViewRef.openTab({ label: { text: openCase.title, icon: openCase.icon ? openCase.icon : 'check_box' }, canBeClosed: true, tabContentComponent: this._openSingleTask ? DefaultTabbedSingleTaskViewComponent : DefaultTabbedTaskViewComponent, injectedObject: { baseFilter: baseFilter, allowedNets: [openCase.processIdentifier], navigationItemTaskData: this._injectedTabData.navigationItemTaskData, searchTypeConfiguration: { initialSearchMode: SearchMode.FULLTEXT, showSearchToggleButton: true }, showMoreMenu: true, headersChangeable: true, headersMode: ['sort', 'edit'], allowTableMode: true, defaultHeadersMode: 'sort' }, order: this._injectedTabData['tabViewOrder'], parentUniqueId: this._injectedTabData.tabUniqueId }, true, true); } createdCase(caze) { this.handleCaseClick(caze); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultCaseRefListViewComponent, deps: [{ token: i1.CaseViewService }, { token: i1.OverflowService, optional: true }, { token: NAE_TAB_DATA, optional: true }, { token: DATA_FIELD_PORTAL_DATA, optional: true }, { token: NAE_CASE_REF_CREATE_CASE, optional: true }, { token: NAE_CASE_REF_SEARCH, optional: true }, { token: NAE_DEFAULT_HEADERS, optional: true }, { token: NAE_CLICKABLE_CASES, optional: true }, { token: NAE_OPEN_SINGLE_TASK, optional: true }, { token: NAE_SINGLE_TASK_QUERY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DefaultCaseRefListViewComponent, selector: "nc-default-case-view", providers: [ CategoryFactory, CaseViewService, SearchService, OverflowService, { provide: AllowedNetsService, useFactory: localAllowedNetsFactory, deps: [AllowedNetsServiceFactory, NAE_DATAFIELD_ALLOWED_NETS] }, { provide: NAE_VIEW_ID_SEGMENT, useValue: 'case' }, ViewIdService, { provide: NAE_SEARCH_CATEGORIES, useFactory: defaultCaseSearchCategoriesFactory, deps: [CategoryFactory] }, ], viewQueries: [{ propertyName: "caseHeaderComponent", first: true, predicate: ["header"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"case-view-container\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n\n <div class=\"case-view-search-container\">\n <div fxLayout=\"row\" fxLayoutAlign=\"space-between\">\n <div fxLayoutAlign=\"start center\" fxFlex *ngIf=\"search\">\n <nc-search class=\"search-width\" [disabled]=\"disabled()\" [additionalFilterData]=\"additionalFilterData\"></nc-search>\n </div>\n <div fxLayoutAlign=\"end center\" *ngIf=\"createCase\">\n <nc-create-case-button [disabled]=\"disabled()\" [newCaseCreationConfig]=\"newCaseCreationConfig\" (caseCreatedEvent)=\"createdCase($event)\"></nc-create-case-button>\n </div>\n </div>\n </div>\n\n <div class=\"full-height transform-div custom-scrollbar\" [ngClass]=\"{'overflow-div': getOverflowStatus()}\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n <div class=\"full-height transform-div max-width-fix\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n <nc-header #header [type]=\"headerType\" [responsiveHeaders]=\"true\" class=\"case-header-padding\" [ngStyle]=\"{'width': getWidth()}\" [maxHeaderColumns]=\"caseHeadersCount\" [approval]=\"isApproval()\"></nc-header>\n\n <nc-case-list-paginator [selectedHeaders$]=\"selectedHeaders$\" [showDeleteMenu]=\"false\" [width]=\"getWidth()\" [approval]=\"isApproval()\" [disabled]=\"disabled()\"\n (caseClick)=\"handleCaseClick($event)\" [responsiveBody]=\"true\" fxFlex [textEllipsis]=\"true\"></nc-case-list-paginator>\n </div>\n </div>\n</div>\n\n", styles: [".case-view-container{margin:16px 24px;height:calc(100% - 32px);overflow:auto}@media screen and (max-width: 599.99px){.case-view-container{margin:12px}}.case-view-search-container{margin-top:16px;margin-bottom:2px;padding:0;max-height:50%}.case-header-padding{padding-top:16px;padding-left:1px;padding-right:1px}.font-size-20{font-size:20px}.search-width{width:100%}.search-fix{min-height:calc(100% + 2px);max-height:100%;overflow-y:auto}.full-height{height:100%}.overflow-div{overflow-x:scroll}.transform-div{transform:rotateX(180deg);-ms-transform:rotateX(180deg);-webkit-transform:rotateX(180deg)}.custom-scrollbar::-webkit-scrollbar{width:15px;height:15px;cursor:pointer}.max-width-fix{max-width:calc(100% - 8px)!important}.max-height{max-height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i3.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i3.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i4.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "directive", type: i4.DefaultStyleDirective, selector: " [ngStyle], [ngStyle.xs], [ngStyle.sm], [ngStyle.md], [ngStyle.lg], [ngStyle.xl], [ngStyle.lt-sm], [ngStyle.lt-md], [ngStyle.lt-lg], [ngStyle.lt-xl], [ngStyle.gt-xs], [ngStyle.gt-sm], [ngStyle.gt-md], [ngStyle.gt-lg]", inputs: ["ngStyle", "ngStyle.xs", "ngStyle.sm", "ngStyle.md", "ngStyle.lg", "ngStyle.xl", "ngStyle.lt-sm", "ngStyle.lt-md", "ngStyle.lt-lg", "ngStyle.lt-xl", "ngStyle.gt-xs", "ngStyle.gt-sm", "ngStyle.gt-md", "ngStyle.gt-lg"] }, { kind: "component", type: i5.SearchComponent, selector: "nc-search" }, { kind: "component", type: i6.HeaderComponent, selector: "nc-header" }, { kind: "component", type: i7.CreateCaseButtonComponent, selector: "nc-create-case-button", inputs: ["newCaseCreationConfig", "disabled"], outputs: ["caseCreatedEvent"] }, { kind: "component", type: i8.CaseListPaginatorComponent, selector: "nc-case-list-paginator" }] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultCaseRefListViewComponent, decorators: [{ type: Component, args: [{ selector: 'nc-default-case-view', providers: [ CategoryFactory, CaseViewService, SearchService, OverflowService, { provide: AllowedNetsService, useFactory: localAllowedNetsFactory, deps: [AllowedNetsServiceFactory, NAE_DATAFIELD_ALLOWED_NETS] }, { provide: NAE_VIEW_ID_SEGMENT, useValue: 'case' }, ViewIdService, { provide: NAE_SEARCH_CATEGORIES, useFactory: defaultCaseSearchCategoriesFactory, deps: [CategoryFactory] }, ], template: "<div class=\"case-view-container\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n\n <div class=\"case-view-search-container\">\n <div fxLayout=\"row\" fxLayoutAlign=\"space-between\">\n <div fxLayoutAlign=\"start center\" fxFlex *ngIf=\"search\">\n <nc-search class=\"search-width\" [disabled]=\"disabled()\" [additionalFilterData]=\"additionalFilterData\"></nc-search>\n </div>\n <div fxLayoutAlign=\"end center\" *ngIf=\"createCase\">\n <nc-create-case-button [disabled]=\"disabled()\" [newCaseCreationConfig]=\"newCaseCreationConfig\" (caseCreatedEvent)=\"createdCase($event)\"></nc-create-case-button>\n </div>\n </div>\n </div>\n\n <div class=\"full-height transform-div custom-scrollbar\" [ngClass]=\"{'overflow-div': getOverflowStatus()}\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n <div class=\"full-height transform-div max-width-fix\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n <nc-header #header [type]=\"headerType\" [responsiveHeaders]=\"true\" class=\"case-header-padding\" [ngStyle]=\"{'width': getWidth()}\" [maxHeaderColumns]=\"caseHeadersCount\" [approval]=\"isApproval()\"></nc-header>\n\n <nc-case-list-paginator [selectedHeaders$]=\"selectedHeaders$\" [showDeleteMenu]=\"false\" [width]=\"getWidth()\" [approval]=\"isApproval()\" [disabled]=\"disabled()\"\n (caseClick)=\"handleCaseClick($event)\" [responsiveBody]=\"true\" fxFlex [textEllipsis]=\"true\"></nc-case-list-paginator>\n </div>\n </div>\n</div>\n\n", styles: [".case-view-container{margin:16px 24px;height:calc(100% - 32px);overflow:auto}@media screen and (max-width: 599.99px){.case-view-container{margin:12px}}.case-view-search-container{margin-top:16px;margin-bottom:2px;padding:0;max-height:50%}.case-header-padding{padding-top:16px;padding-left:1px;padding-right:1px}.font-size-20{font-size:20px}.search-width{width:100%}.search-fix{min-height:calc(100% + 2px);max-height:100%;overflow-y:auto}.full-height{height:100%}.overflow-div{overflow-x:scroll}.transform-div{transform:rotateX(180deg);-ms-transform:rotateX(180deg);-webkit-transform:rotateX(180deg)}.custom-scrollbar::-webkit-scrollbar{width:15px;height:15px;cursor:pointer}.max-width-fix{max-width:calc(100% - 8px)!important}.max-height{max-height:100%}\n"] }] }], ctorParameters: () => [{ type: i1.CaseViewService }, { type: i1.OverflowService, decorators: [{ type: Optional }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_TAB_DATA] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DATA_FIELD_PORTAL_DATA] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_CASE_REF_CREATE_CASE] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_CASE_REF_SEARCH] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_DEFAULT_HEADERS] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_CLICKABLE_CASES] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_OPEN_SINGLE_TASK] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_SINGLE_TASK_QUERY] }] }], propDecorators: { caseHeaderComponent: [{ type: ViewChild, args: ['header'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-case-ref-list-view.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/refs/default-case-ref-list-view/default-case-ref-list-view.component.ts","../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/refs/default-case-ref-list-view/default-case-ref-list-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Inject, Optional, ViewChild} from '@angular/core';\nimport {\n    AbstractCaseViewComponent,\n    AllowedNetsService,\n    AllowedNetsServiceFactory,\n    Case,\n    CaseViewService,\n    CategoryFactory,\n    defaultCaseSearchCategoriesFactory,\n    FilterType,\n    NAE_CASE_REF_CREATE_CASE,\n    NAE_CASE_REF_SEARCH,\n    CaseRefField,\n    NAE_SEARCH_CATEGORIES,\n    NAE_TAB_DATA,\n    NAE_VIEW_ID_SEGMENT,\n    OverflowService,\n    SearchMode,\n    SearchService,\n    SimpleFilter,\n    TaskSetDataRequestFields,\n    ViewIdService,\n    DATA_FIELD_PORTAL_DATA,\n    DataFieldPortalData,\n    MultichoiceField,\n    EnumerationField,\n    NAE_DATAFIELD_ALLOWED_NETS,\n    NAE_DEFAULT_HEADERS,\n    NAE_CLICKABLE_CASES,\n    Filter,\n    NAE_OPEN_SINGLE_TASK,\n    NAE_SINGLE_TASK_QUERY\n} from '@netgrif/components-core';\nimport {HeaderComponent} from '../../../../../header/header.component'\nimport {DefaultTabbedTaskViewComponent} from '../../tabbed/default-tabbed-task-view/default-tabbed-task-view.component';\nimport {\n    InjectedTabbedTaskViewDataWithNavigationItemTaskData\n} from \"../../model/injected-tabbed-task-view-data-with-navigation-item-task-data\";\nimport {\n    DefaultTabbedSingleTaskViewComponent\n} from \"../../tabbed/default-tabbed-single-task-view/default-tabbed-single-task-view.component\";\n\nconst localAllowedNetsFactory = (factory: AllowedNetsServiceFactory, allowedNets: Array<string>) => {\n    if (allowedNets?.length > 0) {\n        return factory.createFromArray(allowedNets);\n    } else {\n        return factory.createWithAllNets();\n    }\n};\n\n@Component({\n    selector: 'nc-default-case-view',\n    templateUrl: './default-case-ref-list-view.component.html',\n    styleUrls: ['./default-case-ref-list-view.component.scss'],\n    providers: [\n        CategoryFactory,\n        CaseViewService,\n        SearchService,\n        OverflowService,\n        {\n            provide: AllowedNetsService,\n            useFactory: localAllowedNetsFactory,\n            deps: [AllowedNetsServiceFactory, NAE_DATAFIELD_ALLOWED_NETS]\n        },\n        {provide: NAE_VIEW_ID_SEGMENT, useValue: 'case'},\n        ViewIdService,\n        {provide: NAE_SEARCH_CATEGORIES, useFactory: defaultCaseSearchCategoriesFactory, deps: [CategoryFactory]},\n    ],\n})\nexport class DefaultCaseRefListViewComponent extends AbstractCaseViewComponent implements AfterViewInit {\n\n    @ViewChild('header') public caseHeaderComponent: HeaderComponent;\n\n    public additionalFilterData: TaskSetDataRequestFields;\n    public search: boolean;\n    public createCase: boolean;\n    public caseHeadersCount;\n\n    constructor(caseViewService: CaseViewService,\n                @Optional() overflowService: OverflowService,\n                @Optional() @Inject(NAE_TAB_DATA) protected _injectedTabData: InjectedTabbedTaskViewDataWithNavigationItemTaskData,\n                @Optional() @Inject(DATA_FIELD_PORTAL_DATA) protected _dataFieldPortalData: DataFieldPortalData<MultichoiceField | CaseRefField | EnumerationField>,\n                @Optional() @Inject(NAE_CASE_REF_CREATE_CASE) protected _caseRefCreateCase: boolean = false,\n                @Optional() @Inject(NAE_CASE_REF_SEARCH) protected _caseRefSearch: boolean = false,\n                @Optional() @Inject(NAE_DEFAULT_HEADERS) protected _caseHeaders: string[],\n                @Optional() @Inject(NAE_CLICKABLE_CASES) protected _clickableCases: boolean = true,\n                @Optional() @Inject(NAE_OPEN_SINGLE_TASK) protected _openSingleTask: boolean = false,\n                @Optional() @Inject(NAE_SINGLE_TASK_QUERY) protected _singleTaskQuery: string) {\n        super(caseViewService, overflowService, undefined, {\n            enableCaseTitle: true,\n            isCaseTitleRequired: true\n        });\n        this.search = !!_caseRefSearch;\n        this.createCase = !!_caseRefCreateCase;\n        this.caseHeadersCount = this._caseHeaders?.length;\n    }\n\n    ngAfterViewInit(): void {\n        this.initializeHeader(this.caseHeaderComponent);\n    }\n\n    public isApproval() {\n        return this._dataFieldPortalData?.dataField instanceof MultichoiceField || this._dataFieldPortalData?.dataField instanceof EnumerationField;\n    }\n\n    public handleCaseClick(clickedCase: Case): void {\n        if (this._injectedTabData !== null  && this._clickableCases) {\n            this.openTab(clickedCase);\n        }\n    }\n\n    public disabled(): boolean {\n        return this._dataFieldPortalData?.dataField?.formControlRef.disabled;\n    }\n\n    protected openTab(openCase: Case) {\n        let baseFilter: Filter;\n        if (this._singleTaskQuery !== undefined) {\n            const query = JSON.parse(this._singleTaskQuery);\n            if (query.query !== undefined) {\n                query.query = query.query + ` AND caseId:${openCase.stringId}`;\n            } else {\n                if (query.case !== undefined) {\n                    query.case.id = openCase.stringId\n                } else {\n                    query.case = {id: `${openCase.stringId}`};\n                }\n            }\n            baseFilter = SimpleFilter.fromTaskQuery(query);\n        } else {\n            baseFilter = new SimpleFilter('', FilterType.TASK, {case: {id: `${openCase.stringId}`}});\n        }\n        this._injectedTabData.tabViewRef.openTab({\n            label: {\n                text: openCase.title,\n                icon: openCase.icon ? openCase.icon : 'check_box'\n            },\n            canBeClosed: true,\n            tabContentComponent: this._openSingleTask ? DefaultTabbedSingleTaskViewComponent : DefaultTabbedTaskViewComponent,\n            injectedObject: {\n                baseFilter: baseFilter,\n                allowedNets: [openCase.processIdentifier],\n                navigationItemTaskData: this._injectedTabData.navigationItemTaskData,\n                searchTypeConfiguration: {\n                    initialSearchMode: SearchMode.FULLTEXT,\n                    showSearchToggleButton: true\n                },\n                showMoreMenu: true,\n                headersChangeable: true,\n                headersMode: ['sort', 'edit'],\n                allowTableMode: true,\n                defaultHeadersMode: 'sort'\n            },\n            order: this._injectedTabData['tabViewOrder'],\n            parentUniqueId: this._injectedTabData.tabUniqueId\n        }, true, true);\n    }\n\n    createdCase(caze: Case) {\n        this.handleCaseClick(caze);\n    }\n}\n","<div class=\"case-view-container\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n\n    <div class=\"case-view-search-container\">\n        <div fxLayout=\"row\" fxLayoutAlign=\"space-between\">\n            <div fxLayoutAlign=\"start center\" fxFlex *ngIf=\"search\">\n                <nc-search class=\"search-width\" [disabled]=\"disabled()\" [additionalFilterData]=\"additionalFilterData\"></nc-search>\n            </div>\n            <div fxLayoutAlign=\"end center\" *ngIf=\"createCase\">\n                <nc-create-case-button [disabled]=\"disabled()\" [newCaseCreationConfig]=\"newCaseCreationConfig\" (caseCreatedEvent)=\"createdCase($event)\"></nc-create-case-button>\n            </div>\n        </div>\n    </div>\n\n    <div class=\"full-height transform-div custom-scrollbar\" [ngClass]=\"{'overflow-div': getOverflowStatus()}\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n        <div class=\"full-height transform-div max-width-fix\" fxLayout=\"column\" fxLayoutAlign=\"start stretch\">\n            <nc-header #header [type]=\"headerType\" [responsiveHeaders]=\"true\" class=\"case-header-padding\" [ngStyle]=\"{'width': getWidth()}\" [maxHeaderColumns]=\"caseHeadersCount\" [approval]=\"isApproval()\"></nc-header>\n\n            <nc-case-list-paginator [selectedHeaders$]=\"selectedHeaders$\" [showDeleteMenu]=\"false\" [width]=\"getWidth()\" [approval]=\"isApproval()\" [disabled]=\"disabled()\"\n                                    (caseClick)=\"handleCaseClick($event)\" [responsiveBody]=\"true\" fxFlex [textEllipsis]=\"true\"></nc-case-list-paginator>\n        </div>\n    </div>\n</div>\n\n"]}