UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

412 lines 74.5 kB
import { __decorate, __metadata } from "tslib"; import { Component, EventEmitter, Input, Output } from '@angular/core'; import { ActivatedRoute, Router } from '@angular/router'; import { AppStateService, ContextRouteService, GainsightService, gettext, GroupService, memoize, ModalService, Status, TabsService } from '@c8y/ngx-components'; import { TranslateService } from '@ngx-translate/core'; import { clone, cloneDeep, isEqual } from 'lodash-es'; import { Subject } from 'rxjs'; import { DASHBOARD_SETTINGS_CHANGES, DashboardDetailsTabId, PRODUCT_EXPERIENCE, REPORT_DEFAULT_NAVIGATION_NODE_PRIORITY } from './context-dashboard.model'; import { ContextDashboardService } from './context-dashboard.service'; import { InventoryService } from '@c8y/client'; import { first } from 'rxjs/operators'; import { newDashboardTab } from './new-dashboard.guard'; import { DashboardDetailService } from './dashboard-detail.service'; import * as i0 from "@angular/core"; import * as i1 from "./context-dashboard.service"; import * as i2 from "@ngx-translate/core"; import * as i3 from "@c8y/ngx-components"; import * as i4 from "@angular/router"; import * as i5 from "@c8y/client"; import * as i6 from "./dashboard-detail.service"; import * as i7 from "@angular/common"; import * as i8 from "@angular/forms"; import * as i9 from "ngx-bootstrap/collapse"; import * as i10 from "./dashboard-settings/dashboard-general-settings.component"; import * as i11 from "./dashboard-settings/dashboard-appearance-settings.component"; import * as i12 from "./dashboard-settings/dashboard-version-history.component"; export class DashboardDetailComponent { constructor(contextDashboardService, translateService, contextRoute, activatedRoute, tabsService, router, inventory, route, dashboardDetailService, appState, groupService, modal, gainsightService) { this.contextDashboardService = contextDashboardService; this.translateService = translateService; this.contextRoute = contextRoute; this.activatedRoute = activatedRoute; this.tabsService = tabsService; this.router = router; this.inventory = inventory; this.route = route; this.dashboardDetailService = dashboardDetailService; this.appState = appState; this.groupService = groupService; this.modal = modal; this.gainsightService = gainsightService; this.isCollapsed = true; this.hideAvailability = false; this.selectedTab = DashboardDetailsTabId.GENERAL; this.dashboardSaved = new EventEmitter(); this.previewChanged = new EventEmitter(); this.destroy$ = new Subject(); this.TABS_OUTLET_NAME = 'dashboardTabs'; this.TABS = { general: { featureId: DashboardDetailsTabId.GENERAL, priority: 30, label: gettext('General') }, appearance: { featureId: DashboardDetailsTabId.APPEARANCE, priority: 20, label: gettext('Appearance') }, versionHistory: { featureId: DashboardDetailsTabId.VERSIONHISTORY, priority: 10, label: gettext('Version history') } }; } ngOnInit() { this.tabs$ = this.tabsService.items$; this.currentContext = this.contextRoute.getContextData(this.activatedRoute); this.deviceTypeValue = this.context?.type; this.displayDeviceTypeValue = this.context && this.groupService.isGroup(this.context) && !this.groupService.isAsset(this.context) ? this.translateService.instant(gettext('Group')) : this.deviceTypeValue; this.updateAllowTypeDashboard(); this.initForm(); } ngOnChanges() { this.updateAllowTypeDashboard(); } ngAfterContentInit() { if (!this.isEdit) { this.initializeConfiguration(); } } ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } async save() { const oldDashboard = cloneDeep(this.dashboard); this.dashboard = { ...this.dashboard, ...this.generalSettingsForm.value, ...this.appearanceSettingsForm.value }; const dashboardSettingChanges = Object.keys(this.dashboard).filter(key => { if (key === 'c8y_IsNavigatorNode') { return !!oldDashboard[key] !== !!this.dashboard[key]; } return !isEqual(oldDashboard[key], this.dashboard[key]); }); this.dashboard.author = this.appState.currentUser.value.userName; this.dashboard.c8y_IsNavigatorNode = this.dashboard.c8y_IsNavigatorNode ? {} : this.currentDashboard ? null : undefined; this.dashboard.deviceTypeValue ??= this.deviceTypeValue; this.dashboard.historyDescription = this.updateDashboardHistoryDescription(dashboardSettingChanges); if (!this.isEdit && !this.isReport) { await this.createNewDashboard(); } else if (!this.isEdit && this.isReport) { await this.createNewReport(); } else { await this.updateDashboard(); this.mo.c8y_DashboardHistory = [ this.dashboard, ...(this.mo?.c8y_DashboardHistory ? this.mo.c8y_DashboardHistory : []) ]; } } updateDashboardHistoryDescription(dashboardChanges) { return { changeType: this.isEdit ? 'update' : 'create', dashboardSettingChanges: dashboardChanges .filter(value => value !== 'deviceType') .map(value => DASHBOARD_SETTINGS_CHANGES[value] || value), deviceType: dashboardChanges.find(value => value === 'deviceType') ? this.dashboard.deviceType : undefined }; } selectTab(selectedTab) { this.selectedTab = selectedTab; this.tabsService.refresh(); } async cancel() { if (!this.isEdit && !this.isReport) { // dashboard creation in it's own tab- confirm and cleanup triggered in canDeactivate during routing this.tabsService.items$.pipe(first()).subscribe((tabs) => { const tab = tabs.find(t => t.featureId !== newDashboardTab.featureId); this.router.navigate(typeof tab.path === 'string' ? [tab.path] : tab.path, { replaceUrl: true }); }); return; } else if (!this.isEdit && this.isReport) { this.router.navigate(['reports']); return; } else if (this.dashboardDetailsForm.dirty && !(await this.confirmClosing())) { return; } this.cleanupAfterDetailsClose(); } async canDeactivate(omitConfirm = false) { let canDeactivate; if (this.isCollapsed || !this.dashboardDetailsForm.dirty) { canDeactivate = true; } else { if (omitConfirm) { canDeactivate = false; } else { canDeactivate = await this.confirmClosing(); } } if (canDeactivate) { this.cleanupAfterDetailsClose(); } return canDeactivate; } show(isEdit) { this.isEdit = isEdit; if (this.isEdit) { this.edit(); } this.initForm(); this.isCollapsed = false; } async revertDashboard(dashboard) { this.dashboard = dashboard; this.dashboard.c8y_IsNavigatorNode = this.dashboard.c8y_IsNavigatorNode ? {} : this.currentDashboard ? null : undefined; await this.updateDashboard(); } async duplicateWithoutType() { const newDashboardName = this.translateService.instant(gettext('{{ dashboardName }} (copy)'), { dashboardName: this.generalSettingsForm.value.name }); this.generalSettingsForm.patchValue({ deviceType: false, name: newDashboardName }); // setting edition to false so new dashboard can be created as copy of current one this.isEdit = false; await this.save(); } updateAllowTypeDashboard() { this.allowTypeDashboard = this.contextDashboardService.shouldAllowToSetDashboardType(this.mo, this.currentContext); } initForm() { this.dashboardDetailsForm = this.dashboardDetailService.initForm(this.dashboard, this.isReport, this.allowTypeDashboard); this.generalSettingsForm = this.dashboardDetailsForm.get('generalSettingsForm'); this.appearanceSettingsForm = this.dashboardDetailsForm.get('appearanceSettingsForm'); } async confirmClosing() { try { await this.modal.confirm(gettext('Close dashboard details'), gettext('Are you sure you want to close dashboard details? All unsaved changes will be lost.'), Status.WARNING, { ok: gettext('Close'), cancel: gettext('Cancel') }); return true; } catch (e) { return false; } } async createNewDashboard() { const mo = await this.contextDashboardService.create(this.dashboard, this.currentContext); await this.onCreateGSEvent(mo); this.cleanupAfterDetailsClose(); await this.contextDashboardService.navigateToDashboard(mo, true); } async onCreateGSEvent(mo) { const parentName = await this.convertStringToHash(this.context?.name); const dashboardName = await this.convertStringToHash(this.dashboard?.name); this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.DASHBOARDS, { component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.ADD_DASHBOARD, action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.CREATE, name: dashboardName, id: mo.id, nameId: `${dashboardName}_${this.mo.id}`, parentAssetId: this.context?.id ? this.context.id : 'noContext', parentAssetName: this.context?.id ? parentName : 'noContext', parentAssetType: this.context?.id ? this.context.type : 'noContext', parentAssetNameId: this.context?.id ? `${parentName}_${this.context.id}` : 'noContext', parentAssetNameDashboardName: this.context?.id ? `${parentName}_${dashboardName}` : 'noContext', parentAssetIdDashboardId: this.context?.id ? `${this.context.id}_${this.mo.id}` : 'noContext', parentAssetNameDashboardId: this.context?.id ? `${parentName}_${this.mo.id}` : 'noContext', parentAssetNameIdDashboardNameId: this.context?.id ? `${parentName}_${this.context.id}_${dashboardName}_${this.mo.id}` : 'noContext', dashboardType: mo.c8y_Dashboard.deviceType ? mo.c8y_Dashboard.deviceTypeValue : null, context: this.contextDashboardService.getContextForGS(this.currentContext.contextData) }); } async convertStringToHash(str) { if (!str) { return null; } return (await this.gainsightService.shouldSendPiiData()) ? str : await this.gainsightService.hashGroupName(str); } async createNewReport() { try { const { name, icon, c8y_IsNavigatorNode, priority, description } = this.dashboard; const report = (await this.contextDashboardService.createReport({ name, icon, c8y_IsNavigatorNode, priority, description })).data; await this.contextDashboardService.create(this.dashboard, undefined, `${this.contextDashboardService.REPORT_PARTIAL_NAME}${report.id}`); this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.REPORTS, { component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.ADD_REPORT, action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.CREATE, name: report.name, id: report.id, context: PRODUCT_EXPERIENCE.DASHBOARD.CONTEXT.REPORT }); if (report.c8y_IsNavigatorNode) { this.contextDashboardService.addReportNavigatorNode(report); } this.cleanupAfterDetailsClose(); await this.router.navigate(['reports', report.id]); } catch (ex) { // intended empty } } async updateDashboard() { try { const dashboardMO = cloneDeep(this.mo); const cfg = this.dashboard; if (this.isReport) { const { name, icon, c8y_IsNavigatorNode, priority, description } = cfg; dashboardMO.c8y_Dashboard = cfg; await this.updateReport({ id: this.context.id, name, icon, c8y_IsNavigatorNode, priority, description }); } else { dashboardMO.c8y_Dashboard = cfg; } const updatedDashboardMo = await this.contextDashboardService.update(dashboardMO, this.currentContext); this.cleanupAfterDetailsClose(); this.dashboardSaved.emit(updatedDashboardMo); } catch (ex) { // intended empty } } edit() { if (this.isReport) { const { name, icon, priority, c8y_IsNavigatorNode, description } = this.context; Object.assign(this.dashboard, { name, icon, priority, c8y_IsNavigatorNode, description }); } this.isNamedDashboard = this.contextDashboardService.isNamed(this.mo); this.selectedTab = this.hideAvailability && this.isNamedDashboard ? DashboardDetailsTabId.APPEARANCE : DashboardDetailsTabId.GENERAL; this.initializeConfiguration(); } initializeConfiguration() { const defaultDashboardCfg = { name: this.translateService.instant(this.isReport ? gettext('Report') : gettext('Dashboard')), priority: this.isReport ? REPORT_DEFAULT_NAVIGATION_NODE_PRIORITY : this.dashboardDetailService.DEFAULT_DASHBOARD_PRIORITY, icon: this.dashboardDetailService.DEFAULT_DASHBOARD_ICON, deviceTypeValue: this.deviceType, columns: 24 }; if (this.dashboard) { this.currentDashboard = clone(this.dashboard); } else { this.dashboard = defaultDashboardCfg; this.dashboardDetailsForm.markAsDirty(); } this.namePlaceholder = this.isReport ? gettext('e.g. My report') : gettext('e.g. My dashboard'); } async updateReport(mo) { mo.c8y_IsNavigatorNode = mo.c8y_IsNavigatorNode ? {} : null; const res = await this.inventory.update(mo); this.context = res.data; if (this.route.parent) { this.route.parent.snapshot.data.contextData = this.context; } this.contextDashboardService.updateNavigatorItem(res.data); } cleanupAfterDetailsClose() { this.isCollapsed = true; if (!this.isEdit) { const dashboardContext = this.route.snapshot.data.dashboard; // hide New dashboard tab const tmpNewDashboardTab = [...this.tabsService.state].find(t => t.featureId === newDashboardTab.featureId); // don't hide the new dashboard tab when clicking on the add dashboard button from another dashboard. if (!tmpNewDashboardTab || dashboardContext?.c8y_Dashboard) { return; } // hide tab and make it appear as last one to prevent navigating to it tmpNewDashboardTab.hide = true; tmpNewDashboardTab.priority = -Infinity; this.tabsService.refresh(); } this.previewChanged.emit(this.dashboard); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DashboardDetailComponent, deps: [{ token: i1.ContextDashboardService }, { token: i2.TranslateService }, { token: i3.ContextRouteService }, { token: i4.ActivatedRoute }, { token: i3.TabsService }, { token: i4.Router }, { token: i5.InventoryService }, { token: i4.ActivatedRoute }, { token: i6.DashboardDetailService }, { token: i3.AppStateService }, { token: i3.GroupService }, { token: i3.ModalService }, { token: i3.GainsightService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DashboardDetailComponent, selector: "c8y-dashboard-detail", inputs: { isReport: "isReport", deviceType: "deviceType", context: "context", mo: "mo", dashboard: "dashboard", isNamedDashboard: "isNamedDashboard", hideAvailability: "hideAvailability" }, outputs: { dashboardSaved: "dashboardSaved", previewChanged: "previewChanged" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"collapse c8y-top-drawer\"\n [collapse]=\"isCollapsed\"\n [isAnimated]=\"true\"\n>\n <div class=\"p-t-16 p-b-16 p-l-24 p-r-24 separator-bottom\">\n <span class=\"h4\">{{ 'Dashboard settings' | translate }}</span>\n </div>\n\n <div\n class=\"d-flex\"\n [formGroup]=\"dashboardDetailsForm\"\n *ngIf=\"!isCollapsed\"\n >\n <c8y-tabs-outlet\n [tabs]=\"tabs$ | async\"\n [outletName]=\"TABS_OUTLET_NAME\"\n [orientation]=\"'vertical'\"\n class=\"c8y-top-drawer--tabs\"\n ></c8y-tabs-outlet>\n <div class=\"inner-scroll c8y-top-drawer__tabs-container flex-grow p-l-24 p-r-lg-32 p-r-xs-24 p-r-sm-24\">\n <c8y-tab\n *ngIf=\"(!isNamedDashboard && !hideAvailability) || isReport\"\n [label]=\"TABS.general.label\"\n [icon]=\"'imac-settings'\"\n [priority]=\"100\"\n [tabsOutlet]=\"TABS_OUTLET_NAME\"\n (onSelect)=\"selectTab(TABS.general.featureId)\"\n [isActive]=\"selectedTab === TABS.general.featureId\"\n ></c8y-tab>\n <c8y-tab\n [label]=\"TABS.appearance.label\"\n [priority]=\"50\"\n [icon]=\"'web-design'\"\n [tabsOutlet]=\"TABS_OUTLET_NAME\"\n (onSelect)=\"selectTab(TABS.appearance.featureId)\"\n [isActive]=\"selectedTab === TABS.appearance.featureId\"\n ></c8y-tab>\n <c8y-tab\n *ngIf=\"mo?.c8y_DashboardHistory\"\n [label]=\"TABS.versionHistory.label\"\n [icon]=\"'versions'\"\n [priority]=\"10\"\n [tabsOutlet]=\"TABS_OUTLET_NAME\"\n (onSelect)=\"selectTab(TABS.versionHistory.featureId)\"\n [isActive]=\"selectedTab === TABS.versionHistory.featureId\"\n ></c8y-tab>\n <ng-container [ngSwitch]=\"selectedTab\">\n <c8y-dashboard-general-settings\n *ngSwitchCase=\"TABS.general.featureId\"\n [isReport]=\"isReport\"\n [isNamedDashboard]=\"isNamedDashboard\"\n [hideAvailability]=\"hideAvailability\"\n [dashboard]=\"dashboard\"\n [generalSettingsForm]=\"generalSettingsForm\"\n [deviceTypeValue]=\"deviceTypeValue\"\n [displayDeviceTypeValue]=\"displayDeviceTypeValue\"\n [mo]=\"mo\"\n [allowTypeDashboard]=\"allowTypeDashboard\"\n [isDevice]=\"!!context?.c8y_IsDevice\"\n class=\"animated fadeIn\"\n (onDuplicateWithoutType)=\"duplicateWithoutType()\"\n ></c8y-dashboard-general-settings>\n <c8y-dashboard-appearance-settings\n *ngSwitchCase=\"TABS.appearance.featureId\"\n [dashboard]=\"dashboard\"\n [appearanceSettingsForm]=\"appearanceSettingsForm\"\n (previewChanged)=\"previewChanged.emit($event)\"\n class=\"animated fadeIn\"\n ></c8y-dashboard-appearance-settings>\n <c8y-dashboard-version-history\n *ngSwitchCase=\"TABS.versionHistory.featureId\"\n [dashboardHistory]=\"mo.c8y_DashboardHistory\"\n [isReport]=\"isReport\"\n (onRevert)=\"revertDashboard($event)\"\n class=\"animated fadeIn\"\n ></c8y-dashboard-version-history>\n </ng-container>\n </div>\n </div>\n\n <div class=\"c8y-top-drawer--footer\">\n <button\n class=\"btn btn-default\"\n title=\"{{ 'Cancel' | translate }}\"\n type=\"button\"\n data-cy=\"dashboard-detail--cancel-dashboard\"\n (click)=\"cancel()\"\n >\n {{ 'Cancel' | translate }}\n </button>\n <button\n class=\"btn btn-primary\"\n title=\"{{ 'Save' | translate }}\"\n type=\"button\"\n data-cy=\"dashboard-detail--save-dashboard\"\n (click)=\"save()\"\n [disabled]=\"\n (dashboardDetailsForm?.invalid || dashboardDetailsForm?.pristine) && this.isEdit\n \"\n >\n {{ 'Save' | translate }}\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.TabsOutletComponent, selector: "c8y-tabs-outlet,c8y-ui-tabs", inputs: ["tabs", "orientation", "navigatorOpen", "outletName", "context", "openFirstTab", "hasHeader"] }, { kind: "component", type: i3.TabComponent, selector: "c8y-tab", inputs: ["path", "label", "icon", "priority", "orientation", "injector", "tabsOutlet", "isActive"], outputs: ["onSelect"] }, { kind: "directive", type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i9.CollapseDirective, selector: "[collapse]", inputs: ["display", "isAnimated", "collapse"], outputs: ["collapsed", "collapses", "expanded", "expands"], exportAs: ["bs-collapse"] }, { kind: "component", type: i10.DashboardGeneralSettingsComponent, selector: "c8y-dashboard-general-settings", inputs: ["isReport", "isNamedDashboard", "hideAvailability", "dashboard", "generalSettingsForm", "deviceTypeValue", "displayDeviceTypeValue", "allowTypeDashboard", "isDevice", "mo"], outputs: ["onDuplicateWithoutType"] }, { kind: "component", type: i11.DashboardAppearanceSettingsComponent, selector: "c8y-dashboard-appearance-settings", inputs: ["dashboard", "appearanceSettingsForm"], outputs: ["previewChanged"] }, { kind: "component", type: i12.DashboardVersionHistoryComponent, selector: "c8y-dashboard-version-history", inputs: ["dashboardHistory", "isReport"], outputs: ["onRevert"] }, { kind: "pipe", type: i3.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }] }); } } __decorate([ memoize(), __metadata("design:type", Function), __metadata("design:paramtypes", [String]), __metadata("design:returntype", Promise) ], DashboardDetailComponent.prototype, "convertStringToHash", null); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DashboardDetailComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-dashboard-detail', template: "<div\n class=\"collapse c8y-top-drawer\"\n [collapse]=\"isCollapsed\"\n [isAnimated]=\"true\"\n>\n <div class=\"p-t-16 p-b-16 p-l-24 p-r-24 separator-bottom\">\n <span class=\"h4\">{{ 'Dashboard settings' | translate }}</span>\n </div>\n\n <div\n class=\"d-flex\"\n [formGroup]=\"dashboardDetailsForm\"\n *ngIf=\"!isCollapsed\"\n >\n <c8y-tabs-outlet\n [tabs]=\"tabs$ | async\"\n [outletName]=\"TABS_OUTLET_NAME\"\n [orientation]=\"'vertical'\"\n class=\"c8y-top-drawer--tabs\"\n ></c8y-tabs-outlet>\n <div class=\"inner-scroll c8y-top-drawer__tabs-container flex-grow p-l-24 p-r-lg-32 p-r-xs-24 p-r-sm-24\">\n <c8y-tab\n *ngIf=\"(!isNamedDashboard && !hideAvailability) || isReport\"\n [label]=\"TABS.general.label\"\n [icon]=\"'imac-settings'\"\n [priority]=\"100\"\n [tabsOutlet]=\"TABS_OUTLET_NAME\"\n (onSelect)=\"selectTab(TABS.general.featureId)\"\n [isActive]=\"selectedTab === TABS.general.featureId\"\n ></c8y-tab>\n <c8y-tab\n [label]=\"TABS.appearance.label\"\n [priority]=\"50\"\n [icon]=\"'web-design'\"\n [tabsOutlet]=\"TABS_OUTLET_NAME\"\n (onSelect)=\"selectTab(TABS.appearance.featureId)\"\n [isActive]=\"selectedTab === TABS.appearance.featureId\"\n ></c8y-tab>\n <c8y-tab\n *ngIf=\"mo?.c8y_DashboardHistory\"\n [label]=\"TABS.versionHistory.label\"\n [icon]=\"'versions'\"\n [priority]=\"10\"\n [tabsOutlet]=\"TABS_OUTLET_NAME\"\n (onSelect)=\"selectTab(TABS.versionHistory.featureId)\"\n [isActive]=\"selectedTab === TABS.versionHistory.featureId\"\n ></c8y-tab>\n <ng-container [ngSwitch]=\"selectedTab\">\n <c8y-dashboard-general-settings\n *ngSwitchCase=\"TABS.general.featureId\"\n [isReport]=\"isReport\"\n [isNamedDashboard]=\"isNamedDashboard\"\n [hideAvailability]=\"hideAvailability\"\n [dashboard]=\"dashboard\"\n [generalSettingsForm]=\"generalSettingsForm\"\n [deviceTypeValue]=\"deviceTypeValue\"\n [displayDeviceTypeValue]=\"displayDeviceTypeValue\"\n [mo]=\"mo\"\n [allowTypeDashboard]=\"allowTypeDashboard\"\n [isDevice]=\"!!context?.c8y_IsDevice\"\n class=\"animated fadeIn\"\n (onDuplicateWithoutType)=\"duplicateWithoutType()\"\n ></c8y-dashboard-general-settings>\n <c8y-dashboard-appearance-settings\n *ngSwitchCase=\"TABS.appearance.featureId\"\n [dashboard]=\"dashboard\"\n [appearanceSettingsForm]=\"appearanceSettingsForm\"\n (previewChanged)=\"previewChanged.emit($event)\"\n class=\"animated fadeIn\"\n ></c8y-dashboard-appearance-settings>\n <c8y-dashboard-version-history\n *ngSwitchCase=\"TABS.versionHistory.featureId\"\n [dashboardHistory]=\"mo.c8y_DashboardHistory\"\n [isReport]=\"isReport\"\n (onRevert)=\"revertDashboard($event)\"\n class=\"animated fadeIn\"\n ></c8y-dashboard-version-history>\n </ng-container>\n </div>\n </div>\n\n <div class=\"c8y-top-drawer--footer\">\n <button\n class=\"btn btn-default\"\n title=\"{{ 'Cancel' | translate }}\"\n type=\"button\"\n data-cy=\"dashboard-detail--cancel-dashboard\"\n (click)=\"cancel()\"\n >\n {{ 'Cancel' | translate }}\n </button>\n <button\n class=\"btn btn-primary\"\n title=\"{{ 'Save' | translate }}\"\n type=\"button\"\n data-cy=\"dashboard-detail--save-dashboard\"\n (click)=\"save()\"\n [disabled]=\"\n (dashboardDetailsForm?.invalid || dashboardDetailsForm?.pristine) && this.isEdit\n \"\n >\n {{ 'Save' | translate }}\n </button>\n </div>\n</div>\n" }] }], ctorParameters: () => [{ type: i1.ContextDashboardService }, { type: i2.TranslateService }, { type: i3.ContextRouteService }, { type: i4.ActivatedRoute }, { type: i3.TabsService }, { type: i4.Router }, { type: i5.InventoryService }, { type: i4.ActivatedRoute }, { type: i6.DashboardDetailService }, { type: i3.AppStateService }, { type: i3.GroupService }, { type: i3.ModalService }, { type: i3.GainsightService }], propDecorators: { isReport: [{ type: Input }], deviceType: [{ type: Input }], context: [{ type: Input }], mo: [{ type: Input }], dashboard: [{ type: Input }], isNamedDashboard: [{ type: Input }], hideAvailability: [{ type: Input }], dashboardSaved: [{ type: Output }], previewChanged: [{ type: Output }], convertStringToHash: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-detail.component.js","sourceRoot":"","sources":["../../../context-dashboard/dashboard-detail.component.ts","../../../context-dashboard/dashboard-detail.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output\n} from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport {\n  AppStateService,\n  ContextData,\n  ContextRouteService,\n  GainsightService,\n  gettext,\n  GroupService,\n  memoize,\n  ModalService,\n  Status,\n  Tab,\n  TabsService\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { clone, cloneDeep, isEqual } from 'lodash-es';\nimport { Observable, Subject } from 'rxjs';\nimport {\n  AllowTypeDashboard,\n  ContextDashboard,\n  ContextDashboardManagedObject,\n  DASHBOARD_SETTINGS_CHANGES,\n  DashboardDetailsTabId,\n  DashboardDetailsTabs,\n  DashboardHistoryDescription,\n  PRODUCT_EXPERIENCE,\n  REPORT_DEFAULT_NAVIGATION_NODE_PRIORITY\n} from './context-dashboard.model';\nimport { ContextDashboardService } from './context-dashboard.service';\nimport { IManagedObject, InventoryService } from '@c8y/client';\nimport { first } from 'rxjs/operators';\nimport { newDashboardTab } from './new-dashboard.guard';\nimport { DashboardDetailService } from './dashboard-detail.service';\n\n@Component({\n  selector: 'c8y-dashboard-detail',\n  templateUrl: './dashboard-detail.component.html'\n})\nexport class DashboardDetailComponent implements OnInit, OnChanges, OnDestroy {\n  isCollapsed = true;\n  currentContext: ContextData;\n  currentDashboard: ContextDashboard;\n  @Input() isReport: boolean;\n  @Input() deviceType: string;\n  @Input() context: any;\n  @Input() mo: ContextDas