UNPKG

@netgrif/components

Version:

Netgrif Application Engine frontend Angular components

178 lines 36.9 kB
import { Component, Inject, Optional } from '@angular/core'; import { GroupNavigationConstants, LoadingEmitter, SETTINGS_TRANSITION_ID, extractFilterFieldFromData, DoubleDrawerUtils, NAE_TAB_DATA, SimpleFilter, FilterType, NAE_AUTOSWITCH_TAB_TOKEN, NAE_OPEN_EXISTING_TAB, extractFieldValueFromData } from '@netgrif/components-core'; import { FormControl } from "@angular/forms"; import { forkJoin } from "rxjs"; import { map } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "@netgrif/components-core"; import * as i2 from "@angular/router"; import * as i3 from "@ngx-translate/core"; import * as i4 from "@angular/common"; import * as i5 from "@ngbracket/ngx-layout"; import * as i6 from "@angular/material/card"; import * as i7 from "@angular/material/icon"; import * as i8 from "@angular/material/input"; import * as i9 from "@angular/material/form-field"; import * as i10 from "@angular/material/progress-spinner"; import * as i11 from "@angular/forms"; export class DefaultTicketViewComponent { _caseResourceService; _permissionService; _snackbar; _router; _log; _translateService; _navigationService; _taskResourceService; _processService; _injectedTabData; _autoswitchToTaskTab; _openExistingTab; loading$ = new LoadingEmitter(); createCaseLoading$ = new LoadingEmitter(); dashboardItems; filteredDashboardItems; search; constructor(_caseResourceService, _permissionService, _snackbar, _router, _log, _translateService, _navigationService, _taskResourceService, _processService, _injectedTabData, _autoswitchToTaskTab = true, _openExistingTab = true) { this._caseResourceService = _caseResourceService; this._permissionService = _permissionService; this._snackbar = _snackbar; this._router = _router; this._log = _log; this._translateService = _translateService; this._navigationService = _navigationService; this._taskResourceService = _taskResourceService; this._processService = _processService; this._injectedTabData = _injectedTabData; this._autoswitchToTaskTab = _autoswitchToTaskTab; this._openExistingTab = _openExistingTab; this.search = new FormControl(''); } ngOnInit() { if (this._autoswitchToTaskTab === null) { this._autoswitchToTaskTab = true; } if (this._openExistingTab === null) { this._openExistingTab = true; } this.loadTicketCreateContent(); this.search.valueChanges.subscribe(value => this.searchItems(value)); } loadTicketCreateContent() { this.loading$.on(); this._navigationService.rightItems$.pipe(map(navItems => this.transformItemCases(navItems).filter(itm => !!itm && !!itm.resource))).subscribe(items => { forkJoin(items.map(item => { const taskId = DoubleDrawerUtils.findTaskIdInCase(item.resource, SETTINGS_TRANSITION_ID); if (taskId === undefined) { return; } return this._taskResourceService.getData(taskId).pipe(map(dataGroups => { return { caseId: item.resource.stringId, dataGroups }; })); })).subscribe(dataGroups => { dataGroups.forEach(dataGroupPair => { if (dataGroupPair.dataGroups === undefined) { return; } let net = undefined; try { net = extractFilterFieldFromData(dataGroupPair.dataGroups)?.allowedNets[0]; } catch (error) { this._log.warn("View doesn't have a filter, skipping..."); } items.find(itm => itm.resource.stringId === dataGroupPair.caseId).petriNetId = net; }); this.dashboardItems = items.filter(item => item.petriNetId !== undefined); this.searchItems(this.search.value); this.loading$.off(); }, error => { this._log.error(error.message); this.loading$.off(); }); }, error => { this._log.error(error.message); this.loading$.off(); }); } transformItemCases(navItems) { return navItems.map(item => this.resolveItemCaseToNavigationItem(item)); } // copied from DoubleDrawerNavigationService resolveItemCaseToNavigationItem(navItem) { if (navItem.resource === undefined) { return undefined; } return { id: navItem.resource.stringId, icon: navItem.resource.immediateData.find(f => f.stringId === GroupNavigationConstants.ITEM_FIELD_ID_MENU_ICON)?.value || "add", title: navItem.navigation.title, petriNetId: undefined, resource: navItem.resource, }; } createCase(item) { if (this.isCardLoading()) { return; } this.createCaseLoading$.on(); this._processService.getNet(item.petriNetId).subscribe(petriNet => { this._caseResourceService.createCase({ netId: petriNet.stringId, title: item.title }).subscribe((caseResult) => { this.createCaseLoading$.off(); if (caseResult?.outcome?.aCase) { this.openTab(caseResult.outcome.aCase); } }, (error) => { this._snackbar.openErrorSnackBar(error); this.createCaseLoading$.off(); }); }); } isCardLoading() { return this.createCaseLoading$.isActive; } searchItems(val) { if (val && val.length === 0) { this.filteredDashboardItems = this.dashboardItems; } this.filteredDashboardItems = this.dashboardItems.filter(value => value.title.toLowerCase().includes(val.toLowerCase())); } openTab(openCase) { const transId = extractFieldValueFromData(this._injectedTabData.navigationItemTaskData, "transition_id"); this._injectedTabData.tabViewRef.openTab({ label: { text: openCase.title, icon: openCase.icon ? openCase.icon : 'check_box' }, canBeClosed: true, tabContentComponent: this._injectedTabData.tabViewComponent, injectedObject: { baseFilter: new SimpleFilter('', FilterType.TASK, { case: { id: `${openCase.stringId}` }, transitionId: transId }), allowedNets: [openCase.processIdentifier] }, order: this._injectedTabData.tabViewOrder, parentUniqueId: this._injectedTabData.tabUniqueId }, this._autoswitchToTaskTab, this._openExistingTab); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultTicketViewComponent, deps: [{ token: i1.CaseResourceService }, { token: i1.PermissionService }, { token: i1.SnackBarService }, { token: i2.Router }, { token: i1.LoggerService }, { token: i3.TranslateService }, { token: i1.DoubleDrawerNavigationService }, { token: i1.TaskResourceService }, { token: i1.ProcessService }, { token: NAE_TAB_DATA }, { token: NAE_AUTOSWITCH_TAB_TOKEN, optional: true }, { token: NAE_OPEN_EXISTING_TAB, optional: true }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DefaultTicketViewComponent, selector: "nc-default-ticket-view", ngImport: i0, template: "<div fxLayout=\"column\" fxFlex=\"100\">\n <div class=\"cards-container\" fxLayout=\"row wrap\" fxLayoutAlign=\"start center\" fxFlex=\"100\">\n\n <div *ngIf=\"(loading$ | async) || isCardLoading()\" fxLayout=\"column\" fxLayoutAlign=\"center center\"\n class=\"margin-top-default\" fxFlex=\"100\">\n <mat-spinner color=\"primary\" diameter=\"60\" mode=\"indeterminate\"></mat-spinner>\n </div>\n\n <div fxLayout=\"column\" fxFlex=\"100\" fxLayoutAlign=\"center center\" *ngIf=\"!isCardLoading()\">\n <mat-form-field appearance=\"outline\" class=\"width-search\">\n <mat-label>Search</mat-label>\n <mat-icon matSuffix>search</mat-icon>\n <input matInput type=\"search\" [formControl]=\"search\">\n </mat-form-field>\n <div fxLayout=\"row wrap\" fxLayoutAlign=\"center center\" class=\"width-80\">\n <div fxLayout=\"column\" *ngFor=\"let item of filteredDashboardItems\" class=\"dashboard-card\"\n (click)=\"createCase(item)\">\n <mat-card fxLayout=\"row\" fxFlex fxLayoutAlign=\"center center\"\n (click)=\"createCase(item)\">\n <mat-icon class=\"card-icon\">{{ item.icon }}</mat-icon>\n <div class=\"card-main-text\">{{ item.title }}</div>\n </mat-card>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".dashboard-card{min-width:46%;margin:1% 2%}.card-content{text-align:center;margin-bottom:0!important}.card-main-text{font-weight:400;font-size:24px;line-height:60px;letter-spacing:.5px;text-align:center}.card-icon{height:25px;width:25px;font-size:25px}.cards-container{padding:1% 0 5% 1%}.width-80{width:80%}.width-search{width:77%}.margin-top-default{margin-top:16px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.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: i5.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: i5.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: "component", type: i6.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i8.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i9.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i9.MatLabel, selector: "mat-label" }, { kind: "directive", type: i9.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i10.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i11.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i11.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i11.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultTicketViewComponent, decorators: [{ type: Component, args: [{ selector: 'nc-default-ticket-view', template: "<div fxLayout=\"column\" fxFlex=\"100\">\n <div class=\"cards-container\" fxLayout=\"row wrap\" fxLayoutAlign=\"start center\" fxFlex=\"100\">\n\n <div *ngIf=\"(loading$ | async) || isCardLoading()\" fxLayout=\"column\" fxLayoutAlign=\"center center\"\n class=\"margin-top-default\" fxFlex=\"100\">\n <mat-spinner color=\"primary\" diameter=\"60\" mode=\"indeterminate\"></mat-spinner>\n </div>\n\n <div fxLayout=\"column\" fxFlex=\"100\" fxLayoutAlign=\"center center\" *ngIf=\"!isCardLoading()\">\n <mat-form-field appearance=\"outline\" class=\"width-search\">\n <mat-label>Search</mat-label>\n <mat-icon matSuffix>search</mat-icon>\n <input matInput type=\"search\" [formControl]=\"search\">\n </mat-form-field>\n <div fxLayout=\"row wrap\" fxLayoutAlign=\"center center\" class=\"width-80\">\n <div fxLayout=\"column\" *ngFor=\"let item of filteredDashboardItems\" class=\"dashboard-card\"\n (click)=\"createCase(item)\">\n <mat-card fxLayout=\"row\" fxFlex fxLayoutAlign=\"center center\"\n (click)=\"createCase(item)\">\n <mat-icon class=\"card-icon\">{{ item.icon }}</mat-icon>\n <div class=\"card-main-text\">{{ item.title }}</div>\n </mat-card>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".dashboard-card{min-width:46%;margin:1% 2%}.card-content{text-align:center;margin-bottom:0!important}.card-main-text{font-weight:400;font-size:24px;line-height:60px;letter-spacing:.5px;text-align:center}.card-icon{height:25px;width:25px;font-size:25px}.cards-container{padding:1% 0 5% 1%}.width-80{width:80%}.width-search{width:77%}.margin-top-default{margin-top:16px}\n"] }] }], ctorParameters: () => [{ type: i1.CaseResourceService }, { type: i1.PermissionService }, { type: i1.SnackBarService }, { type: i2.Router }, { type: i1.LoggerService }, { type: i3.TranslateService }, { type: i1.DoubleDrawerNavigationService }, { type: i1.TaskResourceService }, { type: i1.ProcessService }, { type: undefined, decorators: [{ type: Inject, args: [NAE_TAB_DATA] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_AUTOSWITCH_TAB_TOKEN] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_OPEN_EXISTING_TAB] }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-ticket-view.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/tabbed/default-ticket-view/default-ticket-view.component.ts","../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/tabbed/default-ticket-view/default-ticket-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, OnInit, Optional} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {\n    Case,\n    CaseResourceService,\n    GroupNavigationConstants,\n    LoadingEmitter,\n    PermissionService,\n    SnackBarService,\n    DoubleDrawerNavigationService,\n    NavigationItem,\n    TaskResourceService,\n    SETTINGS_TRANSITION_ID,\n    extractFilterFieldFromData,\n    DoubleDrawerUtils,\n    DataGroup,\n    NAE_TAB_DATA,\n    SimpleFilter,\n    FilterType, CaseEventOutcome,\n    NAE_AUTOSWITCH_TAB_TOKEN, NAE_OPEN_EXISTING_TAB, LoggerService, ProcessService, extractFieldValueFromData\n} from '@netgrif/components-core';\nimport {TranslateService} from \"@ngx-translate/core\";\nimport {FormControl} from \"@angular/forms\";\nimport {forkJoin} from \"rxjs\";\nimport {map} from 'rxjs/operators';\nimport {\n    InjectedTabbedTicketViewDataWithNavigationItemTaskData\n} from \"../../model/injected-tabbed-ticket-view-data-with-navigation-item-task-data\";\n\nexport interface TicketItem {\n    id: string;\n    petriNetId: string;\n    title: string;\n    icon: string;\n    resource?: Case;\n}\n\nexport interface DataGroupCaseIdPair {\n    caseId: string;\n    dataGroups: DataGroup[];\n}\n\n@Component({\n    selector: 'nc-default-ticket-view',\n    templateUrl: './default-ticket-view.component.html',\n    styleUrls: ['./default-ticket-view.component.scss']\n})\nexport class DefaultTicketViewComponent implements OnInit {\n\n    public loading$: LoadingEmitter = new LoadingEmitter();\n    public createCaseLoading$: LoadingEmitter = new LoadingEmitter();\n\n    public dashboardItems: Array<TicketItem>;\n    public filteredDashboardItems: Array<TicketItem>;\n    public search: FormControl;\n\n    constructor(protected _caseResourceService: CaseResourceService,\n                protected _permissionService: PermissionService,\n                protected _snackbar: SnackBarService,\n                protected _router: Router,\n                protected _log: LoggerService,\n                protected _translateService: TranslateService,\n                protected _navigationService: DoubleDrawerNavigationService,\n                protected _taskResourceService: TaskResourceService,\n                protected _processService: ProcessService,\n                @Inject(NAE_TAB_DATA) protected _injectedTabData: InjectedTabbedTicketViewDataWithNavigationItemTaskData,\n                @Optional() @Inject(NAE_AUTOSWITCH_TAB_TOKEN) protected _autoswitchToTaskTab = true,\n                @Optional() @Inject(NAE_OPEN_EXISTING_TAB) protected _openExistingTab = true) {\n        this.search = new FormControl('');\n    }\n\n    ngOnInit(): void {\n        if (this._autoswitchToTaskTab === null) {\n            this._autoswitchToTaskTab = true;\n        }\n        if (this._openExistingTab === null) {\n            this._openExistingTab = true;\n        }\n        this.loadTicketCreateContent();\n        this.search.valueChanges.subscribe(value => this.searchItems(value))\n    }\n\n    public loadTicketCreateContent() {\n        this.loading$.on();\n        this._navigationService.rightItems$.pipe(\n            map(navItems => this.transformItemCases(navItems).filter(itm => !!itm && !!itm.resource))\n        ).subscribe(items => {\n            forkJoin(items.map(item => {\n                const taskId = DoubleDrawerUtils.findTaskIdInCase(item.resource, SETTINGS_TRANSITION_ID);\n                if (taskId === undefined) {\n                    return;\n                }\n                return this._taskResourceService.getData(taskId).pipe(map(dataGroups => {return {caseId: item.resource.stringId, dataGroups} as DataGroupCaseIdPair}));\n            })).subscribe(dataGroups => {\n                dataGroups.forEach(dataGroupPair => {\n                    if (dataGroupPair.dataGroups === undefined) {\n                        return;\n                    }\n                    let net = undefined;\n                    try {\n                        net = extractFilterFieldFromData(dataGroupPair.dataGroups)?.allowedNets[0];\n                    } catch (error) {\n                        this._log.warn(\"View doesn't have a filter, skipping...\");\n                    }\n                    items.find(itm => itm.resource.stringId === dataGroupPair.caseId).petriNetId = net;\n                });\n                this.dashboardItems = items.filter(item => item.petriNetId !== undefined);\n                this.searchItems(this.search.value);\n                this.loading$.off()\n            }, error => {\n                this._log.error(error.message);\n                this.loading$.off()\n            });\n        }, error => {\n            this._log.error(error.message);\n            this.loading$.off()\n        })\n\n    }\n\n    protected transformItemCases(navItems: NavigationItem[]) {\n        return navItems.map(item => this.resolveItemCaseToNavigationItem(item));\n    }\n    // copied from DoubleDrawerNavigationService\n    protected resolveItemCaseToNavigationItem(navItem: NavigationItem): TicketItem | undefined {\n        if (navItem.resource === undefined) {\n            return undefined;\n        }\n        return {\n            id: navItem.resource.stringId,\n            icon: navItem.resource.immediateData.find(f => f.stringId === GroupNavigationConstants.ITEM_FIELD_ID_MENU_ICON)?.value || \"add\",\n            title: (navItem.navigation as any).title,\n            petriNetId: undefined,\n            resource: navItem.resource,\n        }\n    }\n\n    public createCase(item: TicketItem) {\n        if (this.isCardLoading()) {\n            return;\n        }\n        this.createCaseLoading$.on();\n        this._processService.getNet(item.petriNetId).subscribe(petriNet => {\n            this._caseResourceService.createCase({\n                netId: petriNet.stringId,\n                title: item.title\n            }).subscribe((caseResult) => {\n                this.createCaseLoading$.off();\n                if ((caseResult?.outcome as CaseEventOutcome)?.aCase) {\n                    this.openTab((caseResult.outcome as CaseEventOutcome).aCase);\n                }\n            }, (error) => {\n                this._snackbar.openErrorSnackBar(error);\n                this.createCaseLoading$.off();\n            });\n        })\n    }\n\n    public isCardLoading() {\n        return this.createCaseLoading$.isActive;\n    }\n\n    protected searchItems(val: string) {\n        if (val && val.length === 0) {\n            this.filteredDashboardItems = this.dashboardItems;\n        }\n        this.filteredDashboardItems = this.dashboardItems.filter(value => value.title.toLowerCase().includes(val.toLowerCase()));\n    }\n\n    protected openTab(openCase: Case) {\n        const transId: string = extractFieldValueFromData(this._injectedTabData.navigationItemTaskData, \"transition_id\")\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._injectedTabData.tabViewComponent,\n            injectedObject: {\n                baseFilter: new SimpleFilter('', FilterType.TASK, {case: {id: `${openCase.stringId}`}, transitionId: transId}),\n                allowedNets: [openCase.processIdentifier]\n            },\n            order: this._injectedTabData.tabViewOrder,\n            parentUniqueId: this._injectedTabData.tabUniqueId\n        }, this._autoswitchToTaskTab, this._openExistingTab);\n    }\n}\n","<div fxLayout=\"column\" fxFlex=\"100\">\n    <div class=\"cards-container\" fxLayout=\"row wrap\" fxLayoutAlign=\"start center\" fxFlex=\"100\">\n\n        <div *ngIf=\"(loading$ | async) || isCardLoading()\" fxLayout=\"column\" fxLayoutAlign=\"center center\"\n             class=\"margin-top-default\" fxFlex=\"100\">\n            <mat-spinner color=\"primary\" diameter=\"60\" mode=\"indeterminate\"></mat-spinner>\n        </div>\n\n        <div fxLayout=\"column\" fxFlex=\"100\" fxLayoutAlign=\"center center\" *ngIf=\"!isCardLoading()\">\n            <mat-form-field appearance=\"outline\" class=\"width-search\">\n                <mat-label>Search</mat-label>\n                <mat-icon matSuffix>search</mat-icon>\n                <input matInput type=\"search\" [formControl]=\"search\">\n            </mat-form-field>\n            <div fxLayout=\"row wrap\" fxLayoutAlign=\"center center\" class=\"width-80\">\n                <div fxLayout=\"column\" *ngFor=\"let item of filteredDashboardItems\" class=\"dashboard-card\"\n                     (click)=\"createCase(item)\">\n                    <mat-card fxLayout=\"row\" fxFlex fxLayoutAlign=\"center center\"\n                                      (click)=\"createCase(item)\">\n                        <mat-icon class=\"card-icon\">{{ item.icon }}</mat-icon>\n                        <div class=\"card-main-text\">{{ item.title }}</div>\n                    </mat-card>\n                </div>\n            </div>\n        </div>\n    </div>\n</div>\n"]}