@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
412 lines • 74.5 kB
JavaScript
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":";AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAIL,MAAM,EACP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EACL,eAAe,EAEf,mBAAmB,EACnB,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,OAAO,EACP,YAAY,EACZ,MAAM,EAEN,WAAW,EACZ,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACtD,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAIL,0BAA0B,EAC1B,qBAAqB,EAGrB,kBAAkB,EAClB,uCAAuC,EACxC,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAAkB,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;;;;;;;AAMpE,MAAM,OAAO,wBAAwB;IA6CnC,YACU,uBAAgD,EAChD,gBAAkC,EAClC,YAAiC,EACjC,cAA8B,EAC9B,WAAwB,EACxB,MAAc,EACd,SAA2B,EAC3B,KAAqB,EACrB,sBAA8C,EAC9C,QAAyB,EACzB,YAA0B,EAC1B,KAAmB,EACnB,gBAAkC;QAZlC,4BAAuB,GAAvB,uBAAuB,CAAyB;QAChD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,iBAAY,GAAZ,YAAY,CAAqB;QACjC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,gBAAW,GAAX,WAAW,CAAa;QACxB,WAAM,GAAN,MAAM,CAAQ;QACd,cAAS,GAAT,SAAS,CAAkB;QAC3B,UAAK,GAAL,KAAK,CAAgB;QACrB,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,aAAQ,GAAR,QAAQ,CAAiB;QACzB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,UAAK,GAAL,KAAK,CAAc;QACnB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAzD5C,gBAAW,GAAG,IAAI,CAAC;QASV,qBAAgB,GAAG,KAAK,CAAC;QAMlC,gBAAW,GAA0B,qBAAqB,CAAC,OAAO,CAAC;QAMzD,mBAAc,GAAG,IAAI,YAAY,EAAoB,CAAC;QACtD,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QAC3C,aAAQ,GAAkB,IAAI,OAAO,EAAE,CAAC;QAEvC,qBAAgB,GAAG,eAAe,CAAC;QACnC,SAAI,GAAyB;YACpC,OAAO,EAAE;gBACP,SAAS,EAAE,qBAAqB,CAAC,OAAO;gBACxC,QAAQ,EAAE,EAAE;gBACZ,KAAK,EAAE,OAAO,CAAC,SAAS,CAAC;aAC1B;YACD,UAAU,EAAE;gBACV,SAAS,EAAE,qBAAqB,CAAC,UAAU;gBAC3C,QAAQ,EAAE,EAAE;gBACZ,KAAK,EAAE,OAAO,CAAC,YAAY,CAAC;aAC7B;YACD,cAAc,EAAE;gBACd,SAAS,EAAE,qBAAqB,CAAC,cAAc;gBAC/C,QAAQ,EAAE,EAAE;gBACZ,KAAK,EAAE,OAAO,CAAC,iBAAiB,CAAC;aAClC;SACF,CAAC;IAgBC,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;QACrC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC5E,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC;QAC1C,IAAI,CAAC,sBAAsB;YACzB,IAAI,CAAC,OAAO;gBACZ,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;gBACvC,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC;gBACtC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBACjD,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;QAE3B,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACjC,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,IAAI;QACR,MAAM,YAAY,GAAG,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC/C,IAAI,CAAC,SAAS,GAAG;YACf,GAAG,IAAI,CAAC,SAAS;YACjB,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK;YACjC,GAAG,IAAI,CAAC,sBAAsB,CAAC,KAAK;SACrC,CAAC;QACF,MAAM,uBAAuB,GAAa,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;YACjF,IAAI,GAAG,KAAK,qBAAqB,EAAE,CAAC;gBAClC,OAAO,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YACvD,CAAC;YACD,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC;QACjE,IAAI,CAAC,SAAS,CAAC,mBAAmB,GAAG,IAAI,CAAC,SAAS,CAAC,mBAAmB;YACrE,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,IAAI,CAAC,gBAAgB;gBACrB,CAAC,CAAC,IAAI;gBACN,CAAC,CAAC,SAAS,CAAC;QAEhB,IAAI,CAAC,SAAS,CAAC,eAAe,KAAK,IAAI,CAAC,eAAe,CAAC;QACxD,IAAI,CAAC,SAAS,CAAC,kBAAkB;YAC/B,IAAI,CAAC,iCAAiC,CAAC,uBAAuB,CAAC,CAAC;QAClE,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnC,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClC,CAAC;aAAM,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzC,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;YAC7B,IAAI,CAAC,EAAE,CAAC,oBAAoB,GAAG;gBAC7B,IAAI,CAAC,SAAS;gBACd,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC;aACvE,CAAC;QACJ,CAAC;IACH,CAAC;IAED,iCAAiC,CAAC,gBAA0B;QAC1D,OAAO;YACL,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ;YAC7C,uBAAuB,EAAE,gBAAgB;iBACtC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,YAAY,CAAC;iBACvC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,0BAA0B,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC;YAC3D,UAAU,EAAE,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,YAAY,CAAC;gBAChE,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU;gBAC3B,CAAC,CAAC,SAAS;SACd,CAAC;IACJ,CAAC;IAED,SAAS,CAAC,WAAkC;QAC1C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAED,KAAK,CAAC,MAAM;QACV,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnC,oGAAoG;YACpG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,IAAW,EAAE,EAAE;gBAC9D,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,eAAe,CAAC,SAAS,CAAC,CAAC;gBACtE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE;oBACzE,UAAU,EAAE,IAAI;iBACjB,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;aAAM,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;YAClC,OAAO;QACT,CAAC;aAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,KAAK,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC,EAAE,CAAC;YAC7E,OAAO;QACT,CAAC;QACD,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,WAAW,GAAG,KAAK;QACrC,IAAI,aAAsB,CAAC;QAC3B,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,CAAC;YACzD,aAAa,GAAG,IAAI,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,IAAI,WAAW,EAAE,CAAC;gBAChB,aAAa,GAAG,KAAK,CAAC;YACxB,CAAC;iBAAM,CAAC;gBACN,aAAa,GAAG,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;YAC9C,CAAC;QACH,CAAC;QACD,IAAI,aAAa,EAAE,CAAC;YAClB,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAClC,CAAC;QACD,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,IAAI,CAAC,MAAe;QAClB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,CAAC;QACD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAA2B;QAC/C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,SAAS,CAAC,mBAAmB,GAAG,IAAI,CAAC,SAAS,CAAC,mBAAmB;YACrE,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,IAAI,CAAC,gBAAgB;gBACrB,CAAC,CAAC,IAAI;gBACN,CAAC,CAAC,SAAS,CAAC;QAChB,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,oBAAoB;QACxB,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,4BAA4B,CAAC,EAAE;YAC5F,aAAa,EAAE,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,IAAI;SACnD,CAAC,CAAC;QACH,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC;YAClC,UAAU,EAAE,KAAK;YACjB,IAAI,EAAE,gBAAgB;SACvB,CAAC,CAAC;QACH,kFAAkF;QAClF,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAEO,wBAAwB;QAC9B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,uBAAuB,CAAC,6BAA6B,CAClF,IAAI,CAAC,EAAE,EACP,IAAI,CAAC,cAAc,CACpB,CAAC;IACJ,CAAC;IAEO,QAAQ;QACd,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAC9D,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,kBAAkB,CACxB,CAAC;QACF,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,qBAAqB,CAAc,CAAC;QAC7F,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,oBAAoB,CAAC,GAAG,CACzD,wBAAwB,CACZ,CAAC;IACjB,CAAC;IAEO,KAAK,CAAC,cAAc;QAC1B,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CACtB,OAAO,CAAC,yBAAyB,CAAC,EAClC,OAAO,CACL,qFAAqF,CACtF,EACD,MAAM,CAAC,OAAO,EACd;gBACE,EAAE,EAAE,OAAO,CAAC,OAAO,CAAC;gBACpB,MAAM,EAAE,OAAO,CAAC,QAAQ,CAAC;aAC1B,CACF,CAAC;YACF,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,kBAAkB;QAC9B,MAAM,EAAE,GAAkC,MAAM,IAAI,CAAC,uBAAuB,CAAC,MAAM,CACjF,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,cAAc,CACpB,CAAC;QAEF,MAAM,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QAC/B,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,MAAM,IAAI,CAAC,uBAAuB,CAAC,mBAAmB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACnE,CAAC;IAEO,KAAK,CAAC,eAAe,CAAC,EAAiC;QAC7D,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACtE,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAE3E,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,kBAAkB,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE;YACjF,SAAS,EAAE,kBAAkB,CAAC,SAAS,CAAC,UAAU,CAAC,aAAa;YAChE,MAAM,EAAE,kBAAkB,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM;YACnD,IAAI,EAAE,aAAa;YACnB,EAAE,EAAE,EAAE,CAAC,EAAE;YACT,MAAM,EAAE,GAAG,aAAa,IAAI,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACxC,aAAa,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW;YAC/D,eAAe,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW;YAC5D,eAAe,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW;YACnE,iBAAiB,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW;YACtF,4BAA4B,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE;gBAC5C,CAAC,CAAC,GAAG,UAAU,IAAI,aAAa,EAAE;gBAClC,CAAC,CAAC,WAAW;YACf,wBAAwB,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW;YAC7F,0BAA0B,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,UAAU,IAAI,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW;YAC1F,gCAAgC,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE;gBAChD,CAAC,CAAC,GAAG,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,aAAa,IAAI,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;gBACnE,CAAC,CAAC,WAAW;YACf,aAAa,EAAE,EAAE,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI;YACpF,OAAO,EAAE,IAAI,CAAC,uBAAuB,CAAC,eAAe,CACnD,IAAI,CAAC,cAAc,CAAC,WAA6B,CAClD;SACF,CAAC,CAAC;IACL,CAAC;IAGa,AAAN,KAAK,CAAC,mBAAmB,CAAC,GAAW;QAC3C,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,CAAC,MAAM,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;YACtD,CAAC,CAAC,GAAG;YACL,CAAC,CAAC,MAAM,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IACrD,CAAC;IAEO,KAAK,CAAC,eAAe;QAC3B,IAAI,CAAC;YACH,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,mBAAmB,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC;YAClF,MAAM,MAAM,GAAG,CACb,MAAM,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC;gBAC9C,IAAI;gBACJ,IAAI;gBACJ,mBAAmB;gBACnB,QAAQ;gBACR,WAAW;aACe,CAAC,CAC9B,CAAC,IAAI,CAAC;YAEP,MAAM,IAAI,CAAC,uBAAuB,CAAC,MAAM,CACvC,IAAI,CAAC,SAAS,EACd,SAAS,EACT,GAAG,IAAI,CAAC,uBAAuB,CAAC,mBAAmB,GAAG,MAAM,CAAC,EAAE,EAAE,CAClE,CAAC;YACF,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,kBAAkB,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,EAAE;gBAC9E,SAAS,EAAE,kBAAkB,CAAC,SAAS,CAAC,UAAU,CAAC,UAAU;gBAC7D,MAAM,EAAE,kBAAkB,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM;gBACnD,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,EAAE,EAAE,MAAM,CAAC,EAAE;gBACb,OAAO,EAAE,kBAAkB,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM;aACrD,CAAC,CAAC;YACH,IAAI,MAAM,CAAC,mBAAmB,EAAE,CAAC;gBAC/B,IAAI,CAAC,uBAAuB,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;YAC9D,CAAC;YACD,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAChC,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QACrD,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,iBAAiB;QACnB,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,eAAe;QAC3B,IAAI,CAAC;YACH,MAAM,WAAW,GAAkC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACtE,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC;YAC3B,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,mBAAmB,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,GAAG,CAAC;gBACvE,WAAW,CAAC,aAAa,GAAG,GAAG,CAAC;gBAChC,MAAM,IAAI,CAAC,YAAY,CAAC;oBACtB,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;oBACnB,IAAI;oBACJ,IAAI;oBACJ,mBAAmB;oBACnB,QAAQ;oBACR,WAAW;iBACZ,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,WAAW,CAAC,aAAa,GAAG,GAAG,CAAC;YAClC,CAAC;YAED,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAClE,WAAW,EACX,IAAI,CAAC,cAAc,CACpB,CAAC;YACF,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAEhC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAC/C,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;YACZ,iBAAiB;QACnB,CAAC;IACH,CAAC;IAEO,IAAI;QACV,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,mBAAmB,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;YAChF,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,mBAAmB,EAAE,WAAW,EAAE,CAAC,CAAC;QAC5F,CAAC;QACD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACtE,IAAI,CAAC,WAAW;YACd,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,gBAAgB;gBAC5C,CAAC,CAAC,qBAAqB,CAAC,UAAU;gBAClC,CAAC,CAAC,qBAAqB,CAAC,OAAO,CAAC;QACpC,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAEO,uBAAuB;QAC7B,MAAM,mBAAmB,GAA8B;YACrD,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAC7F,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACrB,CAAC,CAAC,uCAAuC;gBACzC,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,0BAA0B;YAC1D,IAAI,EAAE,IAAI,CAAC,sBAAsB,CAAC,sBAAsB;YACxD,eAAe,EAAE,IAAI,CAAC,UAAU;YAChC,OAAO,EAAE,EAAE;SACZ,CAAC;QAEF,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAChD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,mBAAmB,CAAC;YACrC,IAAI,CAAC,oBAAoB,CAAC,WAAW,EAAE,CAAC;QAC1C,CAAC;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAClG,CAAC;IAEO,KAAK,CAAC,YAAY,CAAC,EAA2B;QACpD,EAAE,CAAC,mBAAmB,GAAG,EAAE,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QAC5D,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC;QACxB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YACtB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7D,CAAC;QACD,IAAI,CAAC,uBAAuB,CAAC,mBAAmB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC7D,CAAC;IAEO,wBAAwB;QAC9B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;YAC5D,yBAAyB;YACzB,MAAM,kBAAkB,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,IAAI,CACzD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,eAAe,CAAC,SAAS,CAC/C,CAAC;YACF,qGAAqG;YACrG,IAAI,CAAC,kBAAkB,IAAI,gBAAgB,EAAE,aAAa,EAAE,CAAC;gBAC3D,OAAO;YACT,CAAC;YACD,sEAAsE;YACtE,kBAAkB,CAAC,IAAI,GAAG,IAAI,CAAC;YAC/B,kBAAkB,CAAC,QAAQ,GAAG,CAAC,QAAQ,CAAC;YACxC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;QAC7B,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC3C,CAAC;+GA5aU,wBAAwB;mGAAxB,wBAAwB,gWChDrC,ywHAyGA;;AD2OgB;IADb,OAAO,EAAE;;;;mEAQT;4FA3SU,wBAAwB;kBAJpC,SAAS;+BACE,sBAAsB;6bAOvB,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAYI,cAAc;sBAAvB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBA6QO,mBAAmB","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