UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

254 lines 45.6 kB
import { Component } from '@angular/core'; import { HttpParams } from '@angular/common/http'; import { PaginationParams } from '../../utility/pagination/pagination-params'; import { SimpleFilter } from '../../filter/models/simple-filter'; import { LoadingEmitter } from '../../utility/loading-emitter'; import { GroupNavigationConstants } from "../model/group-navigation-constants"; import * as i0 from "@angular/core"; import * as i1 from "../../resources/engine-endpoint/case-resource.service"; import * as i2 from "../../logger/services/logger.service"; import * as i3 from "../service/path.service"; import * as i4 from "@angular/router"; import * as i5 from "../../translate/language.service"; import * as i6 from "../navigation-double-drawer/service/double-drawer-navigation.service"; export class AbstractDashboardComponent { _caseResource; _log; _pathService; _router; _languageService; _doubleDrawerNavigationService; static MAIN_DASHBOARD = 'main_dashboard'; static DASHBOARD_MANAGEMENT_IDENTIFIER = 'dashboard_management'; static DASHBOARD_MANAGEMENT_ID_DATAFIELD = 'dashboard_id'; static DASHBOARD_MANAGEMENT_ITEM_TO_MENU_ITEM_DATAFIELD = 'dashboard_item_to_menu_item'; static DASHBOARD_MANAGEMENT_SIMPLE_TOOLBAR_DATAFIELD = 'simple_dashboard_toolbar'; static DASHBOARD_MANAGEMENT_PROFILE_TOOLBAR_DATAFIELD = 'profile_dashboard_toolbar'; static DASHBOARD_MANAGEMENT_LANGUAGE_TOOLBAR_DATAFIELD = 'language_dashboard_toolbar'; static DASHBOARD_MANAGEMENT_LOGOUT_TOOLBAR_DATAFIELD = 'logout_dashboard_toolbar'; static DASHBOARD_MANAGEMENT_NAME_DATAFIELD = 'dashboard_name'; static DASHBOARD_MANAGEMENT_LOGO_DATAFIELD = 'dashboard_logo'; static DASHBOARD_MANAGEMENT_ITEMS_ORDER_DATAFIELD = "items_order"; static DASHBOARD_MANAGEMENT_PROFILE_URL_DATAFIELD = "profile_url"; static DASHBOARD_MANAGEMENT_LOGIN_URL_DATAFIELD = "login_url"; static DASHBOARD_ITEM_ICON_DATAFIELD = 'item_icon'; static DASHBOARD_ITEM_NAME_DATAFIELD = 'item_name'; static DASHBOARD_ITEM_URL_DATAFIELD = 'external_url'; static DASHBOARD_ITEM_INTERNAL_DATAFIELD = 'is_internal'; static DASHBOARD_ITEM_EXTERNAL_ICON_DATAFIELD = 'external_icon'; static DASHBOARD_ITEM_FONT_COLOR_DATAFIELD = 'font_color'; static DASHBOARD_ITEM_FONT_WEIGHT_DATAFIELD = 'font_weight'; static DASHBOARD_ITEM_ICON_COLOR_DATAFIELD = 'icon_color'; toolbarConfig = { profileEnabled: false, languageEnabled: false, logoutEnabled: false, simpleToolbar: true, toolbarName: { defaultValue: 'Netgrif', translations: {} }, toolbarLogo: 'assets/img/netgrif_full_white.svg', profileUrl: 'profile', loginUrl: '' }; dashboardId = AbstractDashboardComponent.MAIN_DASHBOARD; dashboardCase; dashboardItems; dashboardItemsMapping; itemsLoaded = 0; loading$ = new LoadingEmitter(); constructor(_caseResource, _log, _pathService, _router, _languageService, _doubleDrawerNavigationService) { this._caseResource = _caseResource; this._log = _log; this._pathService = _pathService; this._router = _router; this._languageService = _languageService; this._doubleDrawerNavigationService = _doubleDrawerNavigationService; this.dashboardItemsMapping = {}; this.dashboardItems = []; this.loading$.on(); const dashboardManagementSearchBody = { process: { identifier: AbstractDashboardComponent.DASHBOARD_MANAGEMENT_IDENTIFIER }, data: { [AbstractDashboardComponent.DASHBOARD_MANAGEMENT_ID_DATAFIELD]: this.dashboardId } }; let dashboardManagementParams = new HttpParams() .set(PaginationParams.PAGE_SIZE, 1); this._caseResource.searchCases(SimpleFilter.fromCaseQuery(dashboardManagementSearchBody), dashboardManagementParams).subscribe(resultDashboard => { const dashboardContent = resultDashboard.content; if (!dashboardContent || !dashboardContent.length || dashboardContent.length < 1) { this.loading$.off(); this._log.error('Dashboard management case not found.'); return; } this.dashboardCase = dashboardContent[0]; this.toolbarConfig = { profileEnabled: this.getManagementProfileToolbar(this.dashboardCase), languageEnabled: this.getManagementLanguageToolbar(this.dashboardCase), logoutEnabled: this.getManagementLogoutToolbar(this.dashboardCase), simpleToolbar: this.getManagementSimpleToolbar(this.dashboardCase), toolbarName: this.getManagementName(this.dashboardCase), toolbarLogo: this.getManagementLogo(this.dashboardCase), profileUrl: this.getManagementProfileUrl(this.dashboardCase), loginUrl: this.getManagementLoginUrl(this.dashboardCase) }; const dashboardItemsOptions = this.dashboardCase.immediateData .find(immediateField => immediateField['importId'] === AbstractDashboardComponent.DASHBOARD_MANAGEMENT_ITEM_TO_MENU_ITEM_DATAFIELD).options; if (!dashboardItemsOptions || Object.keys(dashboardItemsOptions).length === 0) { this.loading$.off(); return; } const dashboardMenuToItems = Object.entries(dashboardItemsOptions) .filter(([key, value]) => value.defaultValue != null) .reduce((accum, [key, value]) => { accum[value.defaultValue] = key; return accum; }, {}); let dashboardItemsParams = new HttpParams() .set(PaginationParams.PAGE_SIZE, 100); this.getDashboardItems(dashboardItemsOptions, dashboardItemsParams); this.getMenuItems(dashboardMenuToItems, dashboardItemsParams); }); } getMenuItems(dashboardMenuToItems, dashboardItemsParams) { let menuItemsSearchBody = { id: Object.keys(dashboardMenuToItems) }; this._caseResource.searchCases(SimpleFilter.fromCaseQuery(menuItemsSearchBody), dashboardItemsParams).subscribe(resultItems => { const itemsContent = resultItems.content; itemsContent.forEach(menuItemCase => { const navigationItem = this._doubleDrawerNavigationService.resolveItemCaseToNavigationItem(menuItemCase); const dashboardItemId = dashboardMenuToItems[menuItemCase.stringId]; if (!navigationItem) { this.dashboardItems = this.dashboardItems.filter(dashItem => dashItem.stringId !== dashboardItemId); return; } this.dashboardItemsMapping[dashboardItemId] = menuItemCase; }); this.itemsLoaded += 1; if (this.itemsLoaded == 2) { this.loading$.off(); } }); } getDashboardItems(dashboardItemsOptions, dashboardItemsParams) { const itemsOrder = this.getManagementItemsOrder(this.dashboardCase)?.split(","); let dashboardItemsSearchBody = { id: Object.keys(dashboardItemsOptions) }; this._caseResource.searchCases(SimpleFilter.fromCaseQuery(dashboardItemsSearchBody), dashboardItemsParams).subscribe(resultItems => { const itemsContent = resultItems.content; if (!itemsContent || !itemsContent.length || itemsContent.length < 1) { this.loading$.off(); this._log.error('No dashboard items found.'); } itemsContent.forEach(item => { const itemIndex = itemsOrder?.indexOf(item.stringId); this.dashboardItems[itemIndex] = item; }); this.itemsLoaded += 1; if (this.itemsLoaded == 2) { this.loading$.off(); } }); } // GET item fields getItemName(itemCase) { const i18nFieldValue = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_NAME_DATAFIELD); return this._languageService.getLanguage() in i18nFieldValue.translations ? i18nFieldValue.translations[this._languageService.getLanguage()] : i18nFieldValue.defaultValue; } getItemIcon(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_ICON_DATAFIELD); } getItemInternal(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_INTERNAL_DATAFIELD); } getItemExternalIcon(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_EXTERNAL_ICON_DATAFIELD); } getItemURL(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_URL_DATAFIELD); } getItemFontColor(itemCase) { const fontColor = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_FONT_COLOR_DATAFIELD); return !!fontColor && fontColor !== '' ? fontColor : 'black'; } getItemFontWeight(itemCase) { const fontWeight = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_FONT_WEIGHT_DATAFIELD); return !!fontWeight && fontWeight !== '' ? fontWeight : 'normal'; } getItemIconColor(itemCase) { const iconColor = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_ICON_COLOR_DATAFIELD); return !!iconColor && iconColor !== '' ? iconColor : 'black'; } // GET management fields getManagementSimpleToolbar(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_SIMPLE_TOOLBAR_DATAFIELD); } getManagementProfileToolbar(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_PROFILE_TOOLBAR_DATAFIELD); } getManagementLanguageToolbar(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LANGUAGE_TOOLBAR_DATAFIELD); } getManagementLogoutToolbar(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LOGOUT_TOOLBAR_DATAFIELD); } getManagementName(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_NAME_DATAFIELD); } getManagementLogo(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LOGO_DATAFIELD); } getManagementItemsOrder(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_ITEMS_ORDER_DATAFIELD); } getManagementProfileUrl(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_PROFILE_URL_DATAFIELD); } getManagementLoginUrl(itemCase) { return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LOGIN_URL_DATAFIELD); } getFieldValue(itemCase, fieldId) { return itemCase.immediateData.find(immediateField => immediateField["importId"] === fieldId).value; } navigate(itemCase) { if (this.getItemInternal(itemCase)) { const menuItemCase = this.dashboardItemsMapping[itemCase.stringId]; if (!menuItemCase) { this._log.warn(`No mapped menu item for dashboard item ${itemCase.stringId}`); return; } const itemRoute = this._doubleDrawerNavigationService.getItemRoutingPath(menuItemCase); const nodePath = this.getFieldValue(menuItemCase, GroupNavigationConstants.ITEM_FIELD_ID_NODE_PATH); const menuItem = this._doubleDrawerNavigationService.resolveItemCaseToNavigationItem(menuItemCase); if (menuItem) { this._doubleDrawerNavigationService.currentNavigationItem = menuItem; } if (menuItemCase.immediateData.find(f => f.stringId === GroupNavigationConstants.ITEM_FIELD_ID_HAS_CHILDREN)?.value && nodePath) { this._pathService.activePath = nodePath; } else if (nodePath) { this._pathService.activePath = this._doubleDrawerNavigationService.extractParentPath(nodePath); } this._router.navigate([itemRoute]); } else { window.open(this.getItemURL(itemCase), "_blank"); } } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractDashboardComponent, deps: [{ token: i1.CaseResourceService }, { token: i2.LoggerService }, { token: i3.PathService }, { token: i4.Router }, { token: i5.LanguageService }, { token: i6.DoubleDrawerNavigationService }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractDashboardComponent, selector: "ncc-dashboard", ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractDashboardComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-dashboard', template: '' }] }], ctorParameters: () => [{ type: i1.CaseResourceService }, { type: i2.LoggerService }, { type: i3.PathService }, { type: i4.Router }, { type: i5.LanguageService }, { type: i6.DoubleDrawerNavigationService }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-dashboard.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/navigation/dashboard/abstract-dashboard.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {HttpParams} from '@angular/common/http';\nimport {PaginationParams} from '../../utility/pagination/pagination-params';\nimport {ToolbarConfig} from '../../toolbar/toolbar-config';\nimport {Case} from '../../resources/interface/case';\nimport {CaseResourceService} from '../../resources/engine-endpoint/case-resource.service';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {DoubleDrawerNavigationService} from '../navigation-double-drawer/service/double-drawer-navigation.service';\nimport {CaseSearchRequestBody} from '../../filter/models/case-search-request-body';\nimport {SimpleFilter} from '../../filter/models/simple-filter';\nimport {I18nFieldValue} from '../../data-fields/i18n-field/models/i18n-field-value';\nimport {LanguageService} from '../../translate/language.service';\nimport {LoadingEmitter} from '../../utility/loading-emitter';\nimport {PathService} from \"../service/path.service\";\nimport {GroupNavigationConstants} from \"../model/group-navigation-constants\";\n\n\n@Component({\n    selector: 'ncc-dashboard',\n    template: ''\n})\nexport abstract class AbstractDashboardComponent {\n\n    public static readonly MAIN_DASHBOARD = 'main_dashboard';\n\n    public static readonly DASHBOARD_MANAGEMENT_IDENTIFIER = 'dashboard_management';\n\n    public static readonly DASHBOARD_MANAGEMENT_ID_DATAFIELD = 'dashboard_id';\n    public static readonly DASHBOARD_MANAGEMENT_ITEM_TO_MENU_ITEM_DATAFIELD = 'dashboard_item_to_menu_item';\n    public static readonly DASHBOARD_MANAGEMENT_SIMPLE_TOOLBAR_DATAFIELD = 'simple_dashboard_toolbar';\n    public static readonly DASHBOARD_MANAGEMENT_PROFILE_TOOLBAR_DATAFIELD = 'profile_dashboard_toolbar';\n    public static readonly DASHBOARD_MANAGEMENT_LANGUAGE_TOOLBAR_DATAFIELD = 'language_dashboard_toolbar';\n    public static readonly DASHBOARD_MANAGEMENT_LOGOUT_TOOLBAR_DATAFIELD = 'logout_dashboard_toolbar';\n    public static readonly DASHBOARD_MANAGEMENT_NAME_DATAFIELD = 'dashboard_name';\n    public static readonly DASHBOARD_MANAGEMENT_LOGO_DATAFIELD = 'dashboard_logo';\n    public static readonly DASHBOARD_MANAGEMENT_ITEMS_ORDER_DATAFIELD = \"items_order\";\n    public static readonly DASHBOARD_MANAGEMENT_PROFILE_URL_DATAFIELD = \"profile_url\";\n    public static readonly DASHBOARD_MANAGEMENT_LOGIN_URL_DATAFIELD = \"login_url\";\n\n    public static readonly DASHBOARD_ITEM_ICON_DATAFIELD = 'item_icon';\n    public static readonly DASHBOARD_ITEM_NAME_DATAFIELD = 'item_name';\n    public static readonly DASHBOARD_ITEM_URL_DATAFIELD = 'external_url';\n    public static readonly DASHBOARD_ITEM_INTERNAL_DATAFIELD = 'is_internal';\n    public static readonly DASHBOARD_ITEM_EXTERNAL_ICON_DATAFIELD = 'external_icon';\n    public static readonly DASHBOARD_ITEM_FONT_COLOR_DATAFIELD = 'font_color';\n    public static readonly DASHBOARD_ITEM_FONT_WEIGHT_DATAFIELD = 'font_weight';\n    public static readonly DASHBOARD_ITEM_ICON_COLOR_DATAFIELD = 'icon_color';\n\n    public toolbarConfig: ToolbarConfig = {\n        profileEnabled: false,\n        languageEnabled: false,\n        logoutEnabled: false,\n        simpleToolbar: true,\n        toolbarName: {\n            defaultValue: 'Netgrif',\n            translations: {}\n        },\n        toolbarLogo: 'assets/img/netgrif_full_white.svg',\n        profileUrl: 'profile',\n        loginUrl: ''\n    };\n\n    public dashboardId: string = AbstractDashboardComponent.MAIN_DASHBOARD;\n    public dashboardCase: Case;\n    public dashboardItems: Array<Case>;\n    public dashboardItemsMapping: {\n        [key: string]: Case\n    };\n    private itemsLoaded: number = 0;\n\n    public loading$: LoadingEmitter = new LoadingEmitter();\n\n    constructor(\n        protected _caseResource: CaseResourceService,\n        protected _log: LoggerService,\n        protected _pathService: PathService,\n        protected _router: Router,\n        protected _languageService: LanguageService,\n        protected _doubleDrawerNavigationService: DoubleDrawerNavigationService\n    ) {\n        this.dashboardItemsMapping = {};\n        this.dashboardItems = [];\n        this.loading$.on();\n        const dashboardManagementSearchBody: CaseSearchRequestBody = {\n            process: {identifier: AbstractDashboardComponent.DASHBOARD_MANAGEMENT_IDENTIFIER},\n            data: {\n                [AbstractDashboardComponent.DASHBOARD_MANAGEMENT_ID_DATAFIELD]: this.dashboardId\n            }\n        };\n        let dashboardManagementParams = new HttpParams()\n            .set(PaginationParams.PAGE_SIZE, 1);\n        this._caseResource.searchCases(SimpleFilter.fromCaseQuery(dashboardManagementSearchBody), dashboardManagementParams).subscribe(resultDashboard => {\n            const dashboardContent = resultDashboard.content;\n            if (!dashboardContent || !dashboardContent.length || dashboardContent.length < 1) {\n                this.loading$.off();\n                this._log.error('Dashboard management case not found.');\n                return;\n            }\n            this.dashboardCase = dashboardContent[0];\n            this.toolbarConfig = {\n                profileEnabled: this.getManagementProfileToolbar(this.dashboardCase),\n                languageEnabled: this.getManagementLanguageToolbar(this.dashboardCase),\n                logoutEnabled: this.getManagementLogoutToolbar(this.dashboardCase),\n                simpleToolbar: this.getManagementSimpleToolbar(this.dashboardCase),\n                toolbarName: this.getManagementName(this.dashboardCase),\n                toolbarLogo: this.getManagementLogo(this.dashboardCase),\n                profileUrl: this.getManagementProfileUrl(this.dashboardCase),\n                loginUrl: this.getManagementLoginUrl(this.dashboardCase)\n            }\n\n            const dashboardItemsOptions = this.dashboardCase.immediateData\n                .find(immediateField => immediateField['importId'] === AbstractDashboardComponent.DASHBOARD_MANAGEMENT_ITEM_TO_MENU_ITEM_DATAFIELD).options;\n            if (!dashboardItemsOptions || Object.keys(dashboardItemsOptions).length === 0) {\n                this.loading$.off();\n                return;\n            }\n\n            const dashboardMenuToItems = Object.entries(dashboardItemsOptions)\n                .filter(([key, value]) => (value as any as I18nFieldValue).defaultValue != null)\n                .reduce((accum, [key, value]) => {\n                    accum[(value as any as I18nFieldValue).defaultValue] = key;\n                    return accum;\n                }, {});\n\n            let dashboardItemsParams = new HttpParams()\n                .set(PaginationParams.PAGE_SIZE, 100);\n            this.getDashboardItems(dashboardItemsOptions, dashboardItemsParams);\n            this.getMenuItems(dashboardMenuToItems, dashboardItemsParams);\n        });\n    }\n\n    private getMenuItems(dashboardMenuToItems: {}, dashboardItemsParams: HttpParams) {\n        let menuItemsSearchBody = {\n            id: Object.keys(dashboardMenuToItems)\n        };\n        this._caseResource.searchCases(SimpleFilter.fromCaseQuery(menuItemsSearchBody), dashboardItemsParams).subscribe(resultItems => {\n            const itemsContent = resultItems.content;\n            itemsContent.forEach(menuItemCase => {\n                const navigationItem = this._doubleDrawerNavigationService.resolveItemCaseToNavigationItem(menuItemCase);\n                const dashboardItemId = dashboardMenuToItems[menuItemCase.stringId];\n                if (!navigationItem) {\n                    this.dashboardItems = this.dashboardItems.filter(dashItem => dashItem.stringId !== dashboardItemId);\n                    return;\n                }\n                this.dashboardItemsMapping[dashboardItemId] = menuItemCase;\n            });\n            this.itemsLoaded += 1;\n            if (this.itemsLoaded == 2) {\n                this.loading$.off();\n            }\n        });\n    }\n\n    private getDashboardItems(dashboardItemsOptions: {\n        defaultValue?: string\n    }, dashboardItemsParams: HttpParams) {\n        const itemsOrder = this.getManagementItemsOrder(this.dashboardCase)?.split(\",\");\n        let dashboardItemsSearchBody: CaseSearchRequestBody = {\n            id: Object.keys(dashboardItemsOptions)\n        };\n        this._caseResource.searchCases(SimpleFilter.fromCaseQuery(dashboardItemsSearchBody), dashboardItemsParams).subscribe(resultItems => {\n            const itemsContent = resultItems.content;\n            if (!itemsContent || !itemsContent.length || itemsContent.length < 1) {\n                this.loading$.off();\n                this._log.error('No dashboard items found.');\n            }\n            itemsContent.forEach(item => {\n                const itemIndex = itemsOrder?.indexOf(item.stringId);\n                this.dashboardItems[itemIndex] = item;\n            });\n            this.itemsLoaded += 1;\n            if (this.itemsLoaded == 2) {\n                this.loading$.off();\n            }\n        });\n    }\n\n    // GET item fields\n    public getItemName(itemCase: Case): string {\n        const i18nFieldValue = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_NAME_DATAFIELD) as I18nFieldValue;\n        return this._languageService.getLanguage() in i18nFieldValue.translations\n            ? i18nFieldValue.translations[this._languageService.getLanguage()]\n            : i18nFieldValue.defaultValue;\n    }\n\n    public getItemIcon(itemCase: Case): string {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_ICON_DATAFIELD) as string;\n    }\n\n    public getItemInternal(itemCase: Case): boolean {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_INTERNAL_DATAFIELD) as boolean;\n    }\n\n    public getItemExternalIcon(itemCase: Case): boolean {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_EXTERNAL_ICON_DATAFIELD) as boolean;\n    }\n\n    public getItemURL(itemCase: Case): string {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_URL_DATAFIELD) as string;\n    }\n\n    public getItemFontColor(itemCase: Case): string {\n        const fontColor = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_FONT_COLOR_DATAFIELD) as string;\n        return !!fontColor && fontColor !== '' ? fontColor : 'black';\n    }\n\n    public getItemFontWeight(itemCase: Case): string {\n        const fontWeight = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_FONT_WEIGHT_DATAFIELD) as string;\n        return !!fontWeight && fontWeight !== '' ? fontWeight : 'normal';\n    }\n\n    public getItemIconColor(itemCase: Case): string {\n        const iconColor = this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_ITEM_ICON_COLOR_DATAFIELD);\n        return !!iconColor && iconColor !== '' ? iconColor : 'black';\n    }\n\n    // GET management fields\n    protected getManagementSimpleToolbar(itemCase: Case): boolean {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_SIMPLE_TOOLBAR_DATAFIELD) as boolean;\n    }\n\n    protected getManagementProfileToolbar(itemCase: Case): boolean {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_PROFILE_TOOLBAR_DATAFIELD) as boolean;\n    }\n\n    protected getManagementLanguageToolbar(itemCase: Case): boolean {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LANGUAGE_TOOLBAR_DATAFIELD) as boolean;\n    }\n\n    protected getManagementLogoutToolbar(itemCase: Case): boolean {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LOGOUT_TOOLBAR_DATAFIELD) as boolean;\n    }\n\n    protected getManagementName(itemCase: Case): I18nFieldValue {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_NAME_DATAFIELD) as I18nFieldValue;\n    }\n\n    protected getManagementLogo(itemCase: Case): string {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LOGO_DATAFIELD) as string;\n    }\n\n    protected getManagementItemsOrder(itemCase: Case): string {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_ITEMS_ORDER_DATAFIELD) as string;\n    }\n\n    protected getManagementProfileUrl(itemCase: Case): string {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_PROFILE_URL_DATAFIELD) as string;\n    }\n\n    protected getManagementLoginUrl(itemCase: Case): string {\n        return this.getFieldValue(itemCase, AbstractDashboardComponent.DASHBOARD_MANAGEMENT_LOGIN_URL_DATAFIELD) as string;\n    }\n\n    protected getFieldValue(itemCase: Case, fieldId: string): any {\n        return itemCase.immediateData.find(immediateField => immediateField[\"importId\"] === fieldId).value;\n    }\n\n    public navigate(itemCase: Case) {\n        if (this.getItemInternal(itemCase)) {\n            const menuItemCase = this.dashboardItemsMapping[itemCase.stringId];\n            if (!menuItemCase) {\n                this._log.warn(`No mapped menu item for dashboard item ${itemCase.stringId}`);\n                return;\n            }\n            const itemRoute = this._doubleDrawerNavigationService.getItemRoutingPath(menuItemCase);\n            const nodePath = this.getFieldValue(menuItemCase, GroupNavigationConstants.ITEM_FIELD_ID_NODE_PATH);\n            const menuItem = this._doubleDrawerNavigationService.resolveItemCaseToNavigationItem(menuItemCase);\n            if (menuItem) {\n                this._doubleDrawerNavigationService.currentNavigationItem = menuItem;\n            }\n            if (menuItemCase.immediateData.find(f => f.stringId === GroupNavigationConstants.ITEM_FIELD_ID_HAS_CHILDREN)?.value && nodePath) {\n                this._pathService.activePath = nodePath;\n            } else if (nodePath) {\n                this._pathService.activePath = this._doubleDrawerNavigationService.extractParentPath(nodePath);\n            }\n            this._router.navigate([itemRoute]);\n        } else {\n            window.open(this.getItemURL(itemCase), \"_blank\");\n        }\n    }\n}\n"]}