UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

118 lines 15.3 kB
import { Component, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core'; import { Router } from '@angular/router'; import { InventoryService } from '@c8y/client'; import { gettext, ViewContext } from '@c8y/ngx-components'; import { ContextDashboardService } from './context-dashboard.service'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "./context-dashboard.service"; import * as i3 from "@c8y/client"; import * as i4 from "@c8y/ngx-components"; export class PasteDashboardActionComponent { constructor(vcRef, router, contextDashboardService, inventoryService) { this.vcRef = vcRef; this.router = router; this.contextDashboardService = contextDashboardService; this.inventoryService = inventoryService; this.pasteDisabled = false; this.dashboardName = ''; } async ngOnInit() { this.currentUrl = this.router.url; this.contextId = this.currentUrl.match(/\d+/)[0]; const isDevice = new RegExp(/device\/\d+/).test(this.currentUrl); const isGroup = new RegExp(/group\/\d+/).test(this.currentUrl); this.currentViewContext = isDevice ? ViewContext.Device : isGroup ? ViewContext.Group : null; await this.checkIfPasteIsAllowed(); this.vcRef.createEmbeddedView(this.templatePaste); const clipboard = this.contextDashboardService.copyClipboard; if (clipboard) { this.dashboardName = clipboard.dashboard.name; } } async pasteDashboard() { if (!this.contextMO) { this.contextMO = await this.getContextMo(this.contextId); } const context = { context: this.currentViewContext, contextData: this.contextMO }; await this.contextDashboardService.pasteDashboard(context); } async getContextMo(id) { return (await this.inventoryService.detail(id)).data; } async checkIfPasteIsAllowed() { const clipboardViewContext = this.contextDashboardService.copyClipboard.context.context; const isTypeDashboard = this.contextDashboardService.copyClipboard?.dashboard?.deviceType; if (this.currentViewContext !== clipboardViewContext) { if (clipboardViewContext === ViewContext.Device) { this.buttonTitle = gettext('Device dashboards can only be copied into a device.'); } else if (clipboardViewContext === ViewContext.Group) { this.buttonTitle = gettext('Group dashboards can only be copied into a group.'); } this.pasteDisabled = true; return; } else if (isTypeDashboard) { this.contextMO = await this.getContextMo(this.contextId); const dashboardDeviceType = this.contextDashboardService.copyClipboard.dashboard.deviceTypeValue; if (dashboardDeviceType === this.contextMO.type) { this.buttonTitle = gettext('Dashboard template can only be copied into assets of a different type.'); this.pasteDisabled = true; return; } } this.buttonTitle = gettext('Paste dashboard'); this.pasteDisabled = false; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PasteDashboardActionComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.Router }, { token: i2.ContextDashboardService }, { token: i3.InventoryService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PasteDashboardActionComponent, selector: "c8y-paste-dashboard-action", viewQueries: [{ propertyName: "templatePaste", first: true, predicate: ["templatePaste"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: ` <ng-template #templatePaste> <li> <button class="btn btn-link" title="{{ buttonTitle | translate }}" type="button" (click)="pasteDashboard()" [disabled]="pasteDisabled" > <i class="m-r-4" c8yIcon="clipboard"></i> <span ngNonBindable translate [translateParams]="{ dashboardName: dashboardName }"> Paste dashboard "{{ dashboardName }}" </span> </button> </li> </ng-template> `, isInline: true, dependencies: [{ kind: "directive", type: i4.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i4.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "pipe", type: i4.C8yTranslatePipe, name: "translate" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PasteDashboardActionComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-paste-dashboard-action', template: ` <ng-template #templatePaste> <li> <button class="btn btn-link" title="{{ buttonTitle | translate }}" type="button" (click)="pasteDashboard()" [disabled]="pasteDisabled" > <i class="m-r-4" c8yIcon="clipboard"></i> <span ngNonBindable translate [translateParams]="{ dashboardName: dashboardName }"> Paste dashboard "{{ dashboardName }}" </span> </button> </li> </ng-template> ` }] }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i1.Router }, { type: i2.ContextDashboardService }, { type: i3.InventoryService }], propDecorators: { templatePaste: [{ type: ViewChild, args: ['templatePaste', { read: TemplateRef, static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paste-dashboard-action.component.js","sourceRoot":"","sources":["../../../context-dashboard/paste-dashboard-action.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IManagedObject, InventoryService } from '@c8y/client';\nimport { gettext, ViewContext } from '@c8y/ngx-components';\nimport { DashboardContext } from './context-dashboard.model';\nimport { ContextDashboardService } from './context-dashboard.service';\n\n@Component({\n  selector: 'c8y-paste-dashboard-action',\n  template: `\n    <ng-template #templatePaste>\n      <li>\n        <button\n          class=\"btn btn-link\"\n          title=\"{{ buttonTitle | translate }}\"\n          type=\"button\"\n          (click)=\"pasteDashboard()\"\n          [disabled]=\"pasteDisabled\"\n        >\n          <i class=\"m-r-4\" c8yIcon=\"clipboard\"></i>\n          <span ngNonBindable translate [translateParams]=\"{ dashboardName: dashboardName }\">\n            Paste dashboard \"{{ dashboardName }}\"\n          </span>\n        </button>\n      </li>\n    </ng-template>\n  `\n})\nexport class PasteDashboardActionComponent implements OnInit {\n  pasteDisabled = false;\n  @ViewChild('templatePaste', { read: TemplateRef, static: true }) templatePaste;\n  dashboardName = '';\n  buttonTitle: string;\n  private currentViewContext: ViewContext;\n  private currentUrl: string;\n  private contextMO: IManagedObject;\n  private contextId: string;\n\n  constructor(\n    private vcRef: ViewContainerRef,\n    private router: Router,\n    private contextDashboardService: ContextDashboardService,\n    private inventoryService: InventoryService\n  ) {}\n\n  async ngOnInit() {\n    this.currentUrl = this.router.url;\n    this.contextId = this.currentUrl.match(/\\d+/)[0];\n\n    const isDevice: boolean = new RegExp(/device\\/\\d+/).test(this.currentUrl);\n    const isGroup: boolean = new RegExp(/group\\/\\d+/).test(this.currentUrl);\n    this.currentViewContext = isDevice ? ViewContext.Device : isGroup ? ViewContext.Group : null;\n    await this.checkIfPasteIsAllowed();\n\n    this.vcRef.createEmbeddedView(this.templatePaste);\n    const clipboard = this.contextDashboardService.copyClipboard;\n    if (clipboard) {\n      this.dashboardName = clipboard.dashboard.name;\n    }\n  }\n\n  async pasteDashboard() {\n    if (!this.contextMO) {\n      this.contextMO = await this.getContextMo(this.contextId);\n    }\n    const context: DashboardContext = {\n      context: this.currentViewContext,\n      contextData: this.contextMO\n    };\n\n    await this.contextDashboardService.pasteDashboard(context);\n  }\n\n  private async getContextMo(id: string): Promise<IManagedObject> {\n    return (await this.inventoryService.detail(id)).data;\n  }\n\n  private async checkIfPasteIsAllowed(): Promise<void> {\n    const clipboardViewContext = this.contextDashboardService.copyClipboard.context.context;\n    const isTypeDashboard = this.contextDashboardService.copyClipboard?.dashboard?.deviceType;\n\n    if (this.currentViewContext !== clipboardViewContext) {\n      if (clipboardViewContext === ViewContext.Device) {\n        this.buttonTitle = gettext('Device dashboards can only be copied into a device.');\n      } else if (clipboardViewContext === ViewContext.Group) {\n        this.buttonTitle = gettext('Group dashboards can only be copied into a group.');\n      }\n      this.pasteDisabled = true;\n      return;\n    } else if (isTypeDashboard) {\n      this.contextMO = await this.getContextMo(this.contextId);\n      const dashboardDeviceType =\n        this.contextDashboardService.copyClipboard.dashboard.deviceTypeValue;\n      if (dashboardDeviceType === this.contextMO.type) {\n        this.buttonTitle = gettext(\n          'Dashboard template can only be copied into assets of a different type.'\n        );\n        this.pasteDisabled = true;\n        return;\n      }\n    }\n\n    this.buttonTitle = gettext('Paste dashboard');\n    this.pasteDisabled = false;\n  }\n}\n"]}