@netgrif/components
Version:
Netgrif Application Engine frontend Angular components
186 lines • 40.7 kB
JavaScript
import { Component, Inject } from '@angular/core';
import { extractIconAndTitle, extractSearchTypeFromData, extractFieldValueFromData, groupNavigationViewIdSegmentFactory, NAE_NAVIGATION_ITEM_TASK_DATA, NAE_VIEW_ID_SEGMENT, SearchMode, ViewIdService, GroupNavigationConstants, hasView } from '@netgrif/components-core';
import { DefaultTabbedCaseViewComponent } from '../default-tabbed-case-view/default-tabbed-case-view.component';
import { DefaultTabbedTaskViewComponent } from '../default-tabbed-task-view/default-tabbed-task-view.component';
import { ActivatedRoute } from '@angular/router';
import { DefaultTicketViewComponent } from "../default-ticket-view/default-ticket-view.component";
import { DefaultTabbedSingleTaskViewComponent } from "../default-tabbed-single-task-view/default-tabbed-single-task-view.component";
import * as i0 from "@angular/core";
import * as i1 from "@ngx-translate/core";
import * as i2 from "@netgrif/components-core";
import * as i3 from "@angular/router";
import * as i4 from "@ngbracket/ngx-layout";
import * as i5 from "../../../../../tabs/tab-view/tab-view.component";
export class DefaultTabViewComponent {
_navigationItemTaskData;
translationService;
extractionService;
activatedRoute;
tabs;
constructor(_navigationItemTaskData, translationService, extractionService, activatedRoute) {
this._navigationItemTaskData = _navigationItemTaskData;
this.translationService = translationService;
this.extractionService = extractionService;
this.activatedRoute = activatedRoute;
this.tabs = this.getTabs();
}
getTabs() {
const menuItemDataGroups = this._navigationItemTaskData.slice(0, 4);
const viewDataGroups = this._navigationItemTaskData.slice(4, this._navigationItemTaskData.length);
const viewType = extractFieldValueFromData(menuItemDataGroups, "view_configuration_type");
switch (viewType) {
case "tabbed_case_view":
return this.getCaseTabs(menuItemDataGroups, viewDataGroups);
case "tabbed_task_view":
return this.getTaskTabs(menuItemDataGroups, viewDataGroups);
case "tabbed_ticket_view":
return this.getTicketTabs(menuItemDataGroups, viewDataGroups);
default:
throw new Error(`Cannot resolve tabs for '${viewType}' view type`);
}
}
getCaseTabs(menuItemDataGroups, viewDataGroups) {
const labelData = extractIconAndTitle(menuItemDataGroups, this.translationService);
const blockNetsString = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_BANNED_PROCESS_CREATION);
const blockNets = blockNetsString === undefined ? [] : blockNetsString.split(',');
const createCaseButtonTitle = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CREATE_CASE_BUTTON_TITLE);
const createCaseButtonIcon = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CREATE_CASE_BUTTON_ICON);
const requireTitle = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_TITLE_IN_CREATION);
const showCreateCaseButton = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_SHOW_CREATE_CASE_BUTTON);
const chainedViewType = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_CHAINED_VIEW_CONFIGURATION_TYPE);
const newCaseButtonConfig = {
enableCaseTitle: requireTitle,
isCaseTitleRequired: requireTitle,
newCaseButtonConfig: {
createCaseButtonTitle,
createCaseButtonIcon,
showCreateCaseButton: showCreateCaseButton,
},
blockNets: blockNets
};
const caseSearchType = extractSearchTypeFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_VIEW_SEARCH_TYPE);
const caseSearchTypeConfig = {
showSearchIcon: true,
showSearchToggleButton: caseSearchType === SearchMode.ADVANCED,
initialSearchMode: (caseSearchType === undefined) ? undefined : SearchMode.FULLTEXT,
};
const caseShowMoreMenu = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_SHOW_MORE_MENU);
const caseViewHeadersChangeable = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_HEADERS_CHANGEABLE);
const caseViewHeadersMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_HEADERS_MODE);
const caseViewAllowTableMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_ALLOW_TABLE_MODE);
const caseViewDefaultHeadersMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_DEFAULT_HEADERS_MODE);
if (!hasView(viewDataGroups)) {
throw new Error(`Case view has missing configuration for task view.`);
}
const taskSearchType = extractSearchTypeFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_VIEW_SEARCH_TYPE);
const taskShowMoreMenu = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_SHOW_MORE_MENU);
const taskSearchTypeConfig = {
showSearchIcon: true,
showSearchToggleButton: taskSearchType === SearchMode.ADVANCED,
initialSearchMode: (taskSearchType === undefined) ? undefined : SearchMode.FULLTEXT,
};
const taskViewHeadersChangeable = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_CHANGEABLE);
const taskViewHeadersMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_MODE);
const taskViewAllowTableMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_ALLOW_TABLE_MODE);
const taskViewDefaultHeadersMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_DEFAULT_HEADERS_MODE);
const taskViewAdditionalFilter = this.extractionService.extractCompleteAdditionalFilterFromData(viewDataGroups);
let mergeWithBaseFilter = (chainedViewType === "tabbed_task_view_configuration") ? extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_MERGE_FILTERS) : true;
const additionalAllowedNets = this.extractionService.extractAdditionalFilterAllowedNets(viewDataGroups)?.allowedNetsIdentifiers;
const chainedViewComponent = chainedViewType === "tabbed_single_task_view_configuration" ? DefaultTabbedSingleTaskViewComponent : DefaultTabbedTaskViewComponent;
return [
{
label: { text: labelData.name, icon: labelData.icon },
canBeClosed: false,
tabContentComponent: DefaultTabbedCaseViewComponent,
injectedObject: {
tabViewComponent: chainedViewComponent,
tabViewOrder: 0,
navigationItemTaskData: this._navigationItemTaskData,
newCaseButtonConfiguration: newCaseButtonConfig,
caseViewSearchTypeConfiguration: caseSearchTypeConfig,
caseViewShowMoreMenu: caseShowMoreMenu,
caseViewHeadersChangeable: caseViewHeadersChangeable,
caseViewHeadersMode: caseViewHeadersMode,
caseViewAllowTableMode: caseViewAllowTableMode,
caseViewDefaultHeadersMode: caseViewDefaultHeadersMode,
taskViewSearchTypeConfiguration: taskSearchTypeConfig,
taskViewShowMoreMenu: taskShowMoreMenu,
taskViewHeadersChangeable: taskViewHeadersChangeable,
taskViewHeadersMode: taskViewHeadersMode,
taskViewAllowTableMode: taskViewAllowTableMode,
taskViewDefaultHeadersMode: taskViewDefaultHeadersMode,
taskViewMergeWithBaseFilter: mergeWithBaseFilter,
taskViewAdditionalFilter: taskViewAdditionalFilter,
taskViewAdditionalAllowedNets: additionalAllowedNets
}
}
];
}
getTaskTabs(menuItemDataGroups, viewDataGroups) {
const labelData = extractIconAndTitle(menuItemDataGroups, this.translationService);
const taskSearchType = extractSearchTypeFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_VIEW_SEARCH_TYPE);
const headersChangeable = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_CHANGEABLE);
const headersMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_MODE);
const allowTableMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_ALLOW_TABLE_MODE);
const defaultHeadersMode = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_DEFAULT_HEADERS_MODE);
const showToggleButton = taskSearchType === SearchMode.ADVANCED;
const searchTypeConfig = {
showSearchIcon: true,
showSearchToggleButton: showToggleButton,
initialSearchMode: (taskSearchType === undefined) ? undefined : SearchMode.FULLTEXT,
};
const showMoreMenu = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_SHOW_MORE_MENU);
const filter = this.extractionService.extractCompleteFilterFromData(viewDataGroups);
return [
{
label: { text: labelData.name, icon: labelData.icon },
canBeClosed: false,
tabContentComponent: DefaultTabbedTaskViewComponent,
injectedObject: {
navigationItemTaskData: this._navigationItemTaskData,
baseFilter: filter,
searchTypeConfiguration: searchTypeConfig,
showMoreMenu: showMoreMenu,
headersChangeable: headersChangeable,
headersMode: headersMode,
allowTableMode: allowTableMode,
defaultHeadersMode: defaultHeadersMode
}
}
];
}
getTicketTabs(menuItemDataGroups, viewDataGroups) {
const labelData = extractIconAndTitle(menuItemDataGroups, this.translationService);
if (!hasView(viewDataGroups)) {
throw new Error(`Ticket view has missing configuration for single task view.`);
}
return [
{
label: { text: labelData.name, icon: labelData.icon },
canBeClosed: false,
tabContentComponent: DefaultTicketViewComponent,
injectedObject: {
navigationItemTaskData: this._navigationItemTaskData,
tabViewComponent: DefaultTabbedSingleTaskViewComponent,
tabViewOrder: 0,
}
}
];
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultTabViewComponent, deps: [{ token: NAE_NAVIGATION_ITEM_TASK_DATA }, { token: i1.TranslateService }, { token: i2.FilterExtractionService }, { token: i3.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DefaultTabViewComponent, selector: "nc-default-tab-view", providers: [
ViewIdService,
{ provide: NAE_VIEW_ID_SEGMENT, useFactory: groupNavigationViewIdSegmentFactory, deps: [ActivatedRoute] }
], ngImport: i0, template: "<div fxLayout=\"column\" fxLayoutAlign=\"start stretch\" class=\"full-height\">\n <nc-tab-view [initialTabs]=\"tabs\" stretch=\"false\" class=\"full-height block\"></nc-tab-view>\n</div>\n", styles: [".full-height{height:100%}.block{display:block!important}\n"], dependencies: [{ kind: "directive", type: i4.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: i4.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: "component", type: i5.TabViewComponent, selector: "nc-tab-view" }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultTabViewComponent, decorators: [{
type: Component,
args: [{ selector: 'nc-default-tab-view', providers: [
ViewIdService,
{ provide: NAE_VIEW_ID_SEGMENT, useFactory: groupNavigationViewIdSegmentFactory, deps: [ActivatedRoute] }
], template: "<div fxLayout=\"column\" fxLayoutAlign=\"start stretch\" class=\"full-height\">\n <nc-tab-view [initialTabs]=\"tabs\" stretch=\"false\" class=\"full-height block\"></nc-tab-view>\n</div>\n", styles: [".full-height{height:100%}.block{display:block!important}\n"] }]
}], ctorParameters: () => [{ type: Array, decorators: [{
type: Inject,
args: [NAE_NAVIGATION_ITEM_TASK_DATA]
}] }, { type: i1.TranslateService }, { type: i2.FilterExtractionService }, { type: i3.ActivatedRoute }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-tab-view.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/tabbed/default-tab-view/default-tab-view.component.ts","../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/tabbed/default-tab-view/default-tab-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {\n    DataGroup,\n    extractIconAndTitle,\n    extractSearchTypeFromData,\n    extractFieldValueFromData,\n    groupNavigationViewIdSegmentFactory,\n    NAE_NAVIGATION_ITEM_TASK_DATA,\n    NAE_VIEW_ID_SEGMENT,\n    NewCaseCreationConfigurationData,\n    SearchComponentConfiguration,\n    SearchMode,\n    TabContent,\n    ViewIdService,\n    FilterExtractionService,\n    GroupNavigationConstants,\n    hasView,\n    I18nFieldValue\n} from '@netgrif/components-core';\nimport {DefaultTabbedCaseViewComponent} from '../default-tabbed-case-view/default-tabbed-case-view.component';\nimport {DefaultTabbedTaskViewComponent} from '../default-tabbed-task-view/default-tabbed-task-view.component';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateService} from \"@ngx-translate/core\";\nimport {DefaultTicketViewComponent} from \"../default-ticket-view/default-ticket-view.component\";\nimport {\n    DefaultTabbedSingleTaskViewComponent\n} from \"../default-tabbed-single-task-view/default-tabbed-single-task-view.component\";\n\n@Component({\n    selector: 'nc-default-tab-view',\n    templateUrl: './default-tab-view.component.html',\n    styleUrls: ['./default-tab-view.component.scss'],\n    providers: [\n        ViewIdService,\n        {provide: NAE_VIEW_ID_SEGMENT, useFactory: groupNavigationViewIdSegmentFactory, deps: [ActivatedRoute]}\n    ]\n})\nexport class DefaultTabViewComponent {\n\n    tabs: Array<TabContent>;\n\n    constructor(@Inject(NAE_NAVIGATION_ITEM_TASK_DATA) protected _navigationItemTaskData: Array<DataGroup>,\n                protected translationService: TranslateService,\n                protected extractionService: FilterExtractionService,\n                protected activatedRoute: ActivatedRoute) {\n        this.tabs = this.getTabs();\n    }\n\n    protected getTabs(): TabContent[] {\n        const menuItemDataGroups: Array<DataGroup> = this._navigationItemTaskData.slice(0, 4)\n        const viewDataGroups: Array<DataGroup> = this._navigationItemTaskData.slice(4, this._navigationItemTaskData.length);\n\n        const viewType: string = extractFieldValueFromData(menuItemDataGroups, \"view_configuration_type\")\n        switch (viewType) {\n            case \"tabbed_case_view\":\n                return this.getCaseTabs(menuItemDataGroups, viewDataGroups);\n            case \"tabbed_task_view\":\n                return this.getTaskTabs(menuItemDataGroups, viewDataGroups);\n            case \"tabbed_ticket_view\":\n                return this.getTicketTabs(menuItemDataGroups, viewDataGroups);\n            default:\n                throw new Error(`Cannot resolve tabs for '${viewType}' view type`);\n        }\n    }\n\n    protected getCaseTabs(menuItemDataGroups: Array<DataGroup>, viewDataGroups: Array<DataGroup>): TabContent[] {\n        const labelData = extractIconAndTitle(menuItemDataGroups, this.translationService);\n\n        const blockNetsString = extractFieldValueFromData<string>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_BANNED_PROCESS_CREATION);\n        const blockNets = blockNetsString === undefined ? [] : blockNetsString.split(',')\n        const createCaseButtonTitle: I18nFieldValue = extractFieldValueFromData<I18nFieldValue>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CREATE_CASE_BUTTON_TITLE);\n        const createCaseButtonIcon: string = extractFieldValueFromData<string>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CREATE_CASE_BUTTON_ICON);\n        const requireTitle: boolean = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_TITLE_IN_CREATION);\n        const showCreateCaseButton: boolean = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_SHOW_CREATE_CASE_BUTTON);\n        const chainedViewType: string = extractFieldValueFromData(viewDataGroups, GroupNavigationConstants.ITEM_CHAINED_VIEW_CONFIGURATION_TYPE);\n\n        const newCaseButtonConfig: NewCaseCreationConfigurationData = {\n            enableCaseTitle: requireTitle,\n            isCaseTitleRequired: requireTitle,\n            newCaseButtonConfig: {\n                createCaseButtonTitle,\n                createCaseButtonIcon,\n                showCreateCaseButton: showCreateCaseButton,\n            },\n            blockNets: blockNets\n        };\n        const caseSearchType = extractSearchTypeFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_VIEW_SEARCH_TYPE);\n        const caseSearchTypeConfig: SearchComponentConfiguration = {\n            showSearchIcon: true,\n            showSearchToggleButton: caseSearchType === SearchMode.ADVANCED,\n            initialSearchMode: (caseSearchType === undefined) ? undefined : SearchMode.FULLTEXT,\n        }\n        const caseShowMoreMenu = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_SHOW_MORE_MENU);\n        const caseViewHeadersChangeable = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_HEADERS_CHANGEABLE);\n        const caseViewHeadersMode = extractFieldValueFromData<string[]>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_HEADERS_MODE);\n        const caseViewAllowTableMode = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_ALLOW_TABLE_MODE);\n        const caseViewDefaultHeadersMode = extractFieldValueFromData<string[]>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_CASE_DEFAULT_HEADERS_MODE);\n\n        if (!hasView(viewDataGroups)) {\n            throw new Error(`Case view has missing configuration for task view.`);\n        }\n\n        const taskSearchType = extractSearchTypeFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_VIEW_SEARCH_TYPE);\n        const taskShowMoreMenu = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_SHOW_MORE_MENU);\n        const taskSearchTypeConfig: SearchComponentConfiguration = {\n            showSearchIcon: true,\n            showSearchToggleButton: taskSearchType === SearchMode.ADVANCED,\n            initialSearchMode: (taskSearchType === undefined) ? undefined : SearchMode.FULLTEXT,\n        }\n        const taskViewHeadersChangeable = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_CHANGEABLE);\n        const taskViewHeadersMode = extractFieldValueFromData<string[]>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_MODE);\n        const taskViewAllowTableMode = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_ALLOW_TABLE_MODE);\n        const taskViewDefaultHeadersMode = extractFieldValueFromData<string[]>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_DEFAULT_HEADERS_MODE);\n        const taskViewAdditionalFilter = this.extractionService.extractCompleteAdditionalFilterFromData(viewDataGroups);\n        let mergeWithBaseFilter: boolean = (chainedViewType === \"tabbed_task_view_configuration\") ? extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_MERGE_FILTERS) : true;\n        const additionalAllowedNets = this.extractionService.extractAdditionalFilterAllowedNets(viewDataGroups)?.allowedNetsIdentifiers;\n        const chainedViewComponent = chainedViewType === \"tabbed_single_task_view_configuration\" ? DefaultTabbedSingleTaskViewComponent : DefaultTabbedTaskViewComponent;\n\n        return [\n            {\n                label: {text: labelData.name, icon: labelData.icon},\n                canBeClosed: false,\n                tabContentComponent: DefaultTabbedCaseViewComponent,\n                injectedObject: {\n                    tabViewComponent: chainedViewComponent,\n                    tabViewOrder: 0,\n                    navigationItemTaskData: this._navigationItemTaskData,\n\n                    newCaseButtonConfiguration: newCaseButtonConfig,\n                    caseViewSearchTypeConfiguration: caseSearchTypeConfig,\n                    caseViewShowMoreMenu: caseShowMoreMenu,\n                    caseViewHeadersChangeable: caseViewHeadersChangeable,\n                    caseViewHeadersMode: caseViewHeadersMode,\n                    caseViewAllowTableMode: caseViewAllowTableMode,\n                    caseViewDefaultHeadersMode: caseViewDefaultHeadersMode,\n\n                    taskViewSearchTypeConfiguration: taskSearchTypeConfig,\n                    taskViewShowMoreMenu: taskShowMoreMenu,\n                    taskViewHeadersChangeable: taskViewHeadersChangeable,\n                    taskViewHeadersMode: taskViewHeadersMode,\n                    taskViewAllowTableMode: taskViewAllowTableMode,\n                    taskViewDefaultHeadersMode: taskViewDefaultHeadersMode,\n                    taskViewMergeWithBaseFilter: mergeWithBaseFilter,\n                    taskViewAdditionalFilter: taskViewAdditionalFilter,\n                    taskViewAdditionalAllowedNets: additionalAllowedNets\n                }\n            }\n        ];\n    }\n\n    protected getTaskTabs(menuItemDataGroups: Array<DataGroup>, viewDataGroups: Array<DataGroup>): TabContent[] {\n        const labelData = extractIconAndTitle(menuItemDataGroups, this.translationService);\n        const taskSearchType = extractSearchTypeFromData(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_VIEW_SEARCH_TYPE);\n        const headersChangeable = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_CHANGEABLE);\n        const headersMode = extractFieldValueFromData<string[]>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_HEADERS_MODE);\n        const allowTableMode = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_ALLOW_TABLE_MODE);\n        const defaultHeadersMode = extractFieldValueFromData<string[]>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_DEFAULT_HEADERS_MODE);\n        const showToggleButton = taskSearchType === SearchMode.ADVANCED\n        const searchTypeConfig: SearchComponentConfiguration = {\n            showSearchIcon: true,\n            showSearchToggleButton: showToggleButton,\n            initialSearchMode: (taskSearchType === undefined) ? undefined : SearchMode.FULLTEXT,\n        }\n        const showMoreMenu = extractFieldValueFromData<boolean>(viewDataGroups, GroupNavigationConstants.ITEM_FIELD_ID_TASK_SHOW_MORE_MENU);\n\n        const filter = this.extractionService.extractCompleteFilterFromData(viewDataGroups);\n        return [\n            {\n                label: {text: labelData.name, icon: labelData.icon},\n                canBeClosed: false,\n                tabContentComponent: DefaultTabbedTaskViewComponent,\n                injectedObject: {\n                    navigationItemTaskData: this._navigationItemTaskData,\n                    baseFilter: filter,\n                    searchTypeConfiguration: searchTypeConfig,\n                    showMoreMenu: showMoreMenu,\n                    headersChangeable: headersChangeable,\n                    headersMode: headersMode,\n                    allowTableMode: allowTableMode,\n                    defaultHeadersMode: defaultHeadersMode\n                }\n            }\n        ];\n    }\n\n    protected getTicketTabs(menuItemDataGroups: Array<DataGroup>, viewDataGroups: Array<DataGroup>): TabContent[] {\n        const labelData = extractIconAndTitle(menuItemDataGroups, this.translationService);\n\n        if (!hasView(viewDataGroups)) {\n            throw new Error(`Ticket view has missing configuration for single task view.`);\n        }\n\n        return [\n            {\n                label: {text: labelData.name, icon: labelData.icon},\n                canBeClosed: false,\n                tabContentComponent: DefaultTicketViewComponent,\n                injectedObject: {\n                    navigationItemTaskData: this._navigationItemTaskData,\n                    tabViewComponent: DefaultTabbedSingleTaskViewComponent,\n                    tabViewOrder: 0,\n                }\n            }\n        ];\n    }\n\n}\n","<div fxLayout=\"column\" fxLayoutAlign=\"start stretch\" class=\"full-height\">\n    <nc-tab-view [initialTabs]=\"tabs\" stretch=\"false\" class=\"full-height block\"></nc-tab-view>\n</div>\n"]}