@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
142 lines • 26.5 kB
JavaScript
import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
import { gettext, InterAppService, SupportedApps } from '@c8y/ngx-components';
import { InventoryService } from '@c8y/client';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { ActivatedRoute } from '@angular/router';
import * as i0 from "@angular/core";
import * as i1 from "@c8y/client";
import * as i2 from "@c8y/ngx-components";
import * as i3 from "@angular/router";
import * as i4 from "@angular/common";
import * as i5 from "../type-dashboard-info/type-dashboard-info.component";
export class TypedDashboardSettingsComponent {
constructor(inventory, interAppService, route) {
this.inventory = inventory;
this.interAppService = interAppService;
this.route = route;
this.touched = false;
this.disabled = false;
this.onDuplicateWithoutType = new EventEmitter();
this.deviceManagementAppKey = SupportedApps.devicemanagement;
this.deviceManagementLinkTitle = gettext('Device Info page in {{ deviceManagementAppName }}');
// eslint-disable-next-line @typescript-eslint/no-empty-function
this.onChange = _ => { };
// eslint-disable-next-line @typescript-eslint/no-empty-function
this.onTouched = () => { };
}
async ngOnInit() {
this.userDeviceManagementApp$ = this.interAppService.getApp$(this.deviceManagementAppKey);
this.context = this.route.parent.snapshot.data.contextData;
this.showSourceNavigationLink$ = this.interAppService.shouldShowAppLink$(this.deviceManagementAppKey);
}
async goToDeviceView() {
await this.interAppService.navigateToApp(this.deviceManagementAppKey, `#/device/${this.context.id}/device-info`);
}
writeValue(value) {
this.value = value;
this.updateTexts();
if (value) {
this.updateDeviceTypeCount();
}
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(onTouched) {
this.onTouched = onTouched;
}
markAsTouched() {
if (!this.touched) {
this.onTouched();
this.touched = true;
}
}
setDisabledState(disabled) {
this.disabled = disabled;
}
async toggle() {
this.value = !this.value;
this.onChange(this.value);
if (this.value && this.deviceTypeInstancesCount == null) {
this.setDisabledState(true);
await this.updateDeviceTypeCount();
}
this.updateTexts();
this.setDisabledState(false);
}
updateTexts() {
this.typedDashboardStatus = this.value
? gettext('Enabled`typed dashboard`')
: gettext('Disabled`typed dashboard`');
if (this.allowTypeDashboard === 'allow_if_type_filled') {
this.infoText = gettext(`<p class="p-b-8">Enabling this option uses the layout and configuration of this dashboard to create dashboard instances for all devices based on the device type.</p>
<p class="p-b-16">The current device doesn't have a device type assigned to it. Assign a device type to the device via the "Asset properties" widget in the <strong>Info</strong> tab of the device.</p>`);
return;
}
if (this.value) {
if (this.isDevice) {
this.infoText = gettext(`<p class="p-b-8">
The layout and configuration of this dashboard is used by all devices based on device type <span class="tag tag--info text-12">{{ displayDeviceTypeValue }}</span>.
</p>
<p class="p-b-16">
Disabling this option removes it from all devices based on the same type and makes it available only for the current instance.
</p>`);
}
else {
this.infoText = gettext(`<p class="p-b-8">
The layout and configuration of this dashboard is used by all assets based on asset model <span class="tag tag--info text-12">{{ displayDeviceTypeValue }}</span>.
</p>
<p class="p-b-16">
Disabling this option removes it from all assets based on the same model and makes it available only for the current instance.
</p>`);
}
}
else {
if (this.isDevice) {
this.infoText = gettext(`<p>Enabling this option uses the layout and configuration of this dashboard to create dashboard instances for all devices based on the type <span class="tag tag--info text-12">{{ displayDeviceTypeValue }}</span>.</p>`);
}
else {
this.infoText = gettext(`<p>Enabling this option uses the layout and configuration of this dashboard to create dashboard instances for all assets based on the model <span class="tag tag--info text-12">{{ displayDeviceTypeValue }}</span>.</p>`);
}
}
}
async updateDeviceTypeCount() {
const count = await this.inventory.count({
type: this.deviceTypeValue
});
this.deviceTypeInstancesCount = count.data;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TypedDashboardSettingsComponent, deps: [{ token: i1.InventoryService }, { token: i2.InterAppService }, { token: i3.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TypedDashboardSettingsComponent, selector: "c8y-typed-dashboard-settings", inputs: { deviceTypeValue: "deviceTypeValue", displayDeviceTypeValue: "displayDeviceTypeValue", formInvalid: "formInvalid", mo: "mo", isDevice: "isDevice", allowTypeDashboard: "allowTypeDashboard" }, outputs: { onDuplicateWithoutType: "onDuplicateWithoutType" }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => TypedDashboardSettingsComponent),
multi: true
}
], ngImport: i0, template: "<fieldset class=\"c8y-fieldset c8y-fieldset--lg\">\n <legend>{{ 'Dashboard template' | translate }}</legend>\n <div class=\"d-flex p-b-16 gap-16\">\n <label class=\"c8y-switch flex-no-shrink\">\n <input\n type=\"checkbox\"\n [checked]=\"value\"\n [disabled]=\"disabled\"\n (click)=\"toggle()\"\n />\n <span></span>\n <span>{{ typedDashboardStatus | translate }}</span>\n </label>\n <div class=\"flex-grow d-flex d-col\">\n <div\n class=\"flex-grow\"\n [innerHtml]=\"infoText | translate: { displayDeviceTypeValue: displayDeviceTypeValue }\"\n ></div>\n <button\n class=\"btn-link p-0 m-r-auto\"\n type=\"button\"\n *ngIf=\"allowTypeDashboard === 'allow_if_type_filled' && showSourceNavigationLink$ | async\"\n (click)=\"goToDeviceView()\"\n >\n {{\n deviceManagementLinkTitle\n | translate\n : {\n deviceManagementAppName:\n userDeviceManagementApp$ | async | humanizeAppName | async\n }\n }}\n <i c8yIcon=\"external-link\"></i>\n </button>\n </div>\n </div>\n\n <c8y-type-dashboard-info\n *ngIf=\"allowTypeDashboard === 'allow'\"\n [context]=\"mo\"\n [deviceTypeValue]=\"deviceTypeValue\"\n [displayDeviceTypeValue]=\"displayDeviceTypeValue\"\n ></c8y-type-dashboard-info>\n\n <div\n class=\"p-t-8 p-b-16\"\n *ngIf=\"mo?.c8y_Dashboard && value\"\n >\n <button\n class=\"btn btn-default btn-sm\"\n type=\"button\"\n (click)=\"onDuplicateWithoutType.emit()\"\n [disabled]=\"formInvalid\"\n >\n {{ 'Duplicate as regular dashboard' | translate }}\n </button>\n </div>\n</fieldset>\n", dependencies: [{ kind: "directive", type: i2.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.TypeDashboardInfoComponent, selector: "c8y-type-dashboard-info", inputs: ["deviceTypeValue", "displayDeviceTypeValue", "context", "asyncRenderSuccess", "asyncRenderFail"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.HumanizeAppNamePipe, name: "humanizeAppName" }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TypedDashboardSettingsComponent, decorators: [{
type: Component,
args: [{ selector: 'c8y-typed-dashboard-settings', providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => TypedDashboardSettingsComponent),
multi: true
}
], template: "<fieldset class=\"c8y-fieldset c8y-fieldset--lg\">\n <legend>{{ 'Dashboard template' | translate }}</legend>\n <div class=\"d-flex p-b-16 gap-16\">\n <label class=\"c8y-switch flex-no-shrink\">\n <input\n type=\"checkbox\"\n [checked]=\"value\"\n [disabled]=\"disabled\"\n (click)=\"toggle()\"\n />\n <span></span>\n <span>{{ typedDashboardStatus | translate }}</span>\n </label>\n <div class=\"flex-grow d-flex d-col\">\n <div\n class=\"flex-grow\"\n [innerHtml]=\"infoText | translate: { displayDeviceTypeValue: displayDeviceTypeValue }\"\n ></div>\n <button\n class=\"btn-link p-0 m-r-auto\"\n type=\"button\"\n *ngIf=\"allowTypeDashboard === 'allow_if_type_filled' && showSourceNavigationLink$ | async\"\n (click)=\"goToDeviceView()\"\n >\n {{\n deviceManagementLinkTitle\n | translate\n : {\n deviceManagementAppName:\n userDeviceManagementApp$ | async | humanizeAppName | async\n }\n }}\n <i c8yIcon=\"external-link\"></i>\n </button>\n </div>\n </div>\n\n <c8y-type-dashboard-info\n *ngIf=\"allowTypeDashboard === 'allow'\"\n [context]=\"mo\"\n [deviceTypeValue]=\"deviceTypeValue\"\n [displayDeviceTypeValue]=\"displayDeviceTypeValue\"\n ></c8y-type-dashboard-info>\n\n <div\n class=\"p-t-8 p-b-16\"\n *ngIf=\"mo?.c8y_Dashboard && value\"\n >\n <button\n class=\"btn btn-default btn-sm\"\n type=\"button\"\n (click)=\"onDuplicateWithoutType.emit()\"\n [disabled]=\"formInvalid\"\n >\n {{ 'Duplicate as regular dashboard' | translate }}\n </button>\n </div>\n</fieldset>\n" }]
}], ctorParameters: () => [{ type: i1.InventoryService }, { type: i2.InterAppService }, { type: i3.ActivatedRoute }], propDecorators: { deviceTypeValue: [{
type: Input
}], displayDeviceTypeValue: [{
type: Input
}], formInvalid: [{
type: Input
}], mo: [{
type: Input
}], isDevice: [{
type: Input
}], allowTypeDashboard: [{
type: Input
}], onDuplicateWithoutType: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typed-dashboard-settings.component.js","sourceRoot":"","sources":["../../../../context-dashboard/dashboard-settings/typed-dashboard-settings.component.ts","../../../../context-dashboard/dashboard-settings/typed-dashboard-settings.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, OnInit, Output } from '@angular/core';\nimport { gettext, InterAppService, SupportedApps, SupportedAppKey } from '@c8y/ngx-components';\nimport { IApplication, InventoryService } from '@c8y/client';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { AllowTypeDashboard, ContextDashboardManagedObject } from '../context-dashboard.model';\nimport { Observable } from 'rxjs';\nimport { ActivatedRoute } from '@angular/router';\n\n@Component({\n  selector: 'c8y-typed-dashboard-settings',\n  templateUrl: './typed-dashboard-settings.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TypedDashboardSettingsComponent),\n      multi: true\n    }\n  ]\n})\nexport class TypedDashboardSettingsComponent implements ControlValueAccessor, OnInit {\n  value: boolean;\n  touched = false;\n  disabled = false;\n\n  @Input() deviceTypeValue: string;\n  @Input() displayDeviceTypeValue: string;\n  @Input() formInvalid: boolean;\n  @Input() mo: ContextDashboardManagedObject;\n  @Input() isDevice: boolean;\n  @Input() allowTypeDashboard: AllowTypeDashboard;\n  @Output() onDuplicateWithoutType = new EventEmitter<void>();\n  typedDashboardStatus: string;\n  infoText: string;\n  deviceTypeInstancesCount: number;\n  showSourceNavigationLink$: Observable<boolean>;\n  userDeviceManagementApp$: Observable<IApplication>;\n  context: any;\n  deviceManagementAppKey: SupportedAppKey = SupportedApps.devicemanagement;\n  deviceManagementLinkTitle = gettext('Device Info page in {{ deviceManagementAppName }}');\n\n  constructor(\n    private inventory: InventoryService,\n    private interAppService: InterAppService,\n    private route: ActivatedRoute\n  ) {}\n\n  async ngOnInit() {\n    this.userDeviceManagementApp$ = this.interAppService.getApp$(this.deviceManagementAppKey);\n    this.context = this.route.parent.snapshot.data.contextData;\n    this.showSourceNavigationLink$ = this.interAppService.shouldShowAppLink$(\n      this.deviceManagementAppKey\n    );\n  }\n\n  async goToDeviceView(): Promise<void> {\n    await this.interAppService.navigateToApp(\n      this.deviceManagementAppKey,\n      `#/device/${this.context.id}/device-info`\n    );\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = _ => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  writeValue(value: boolean): void {\n    this.value = value;\n    this.updateTexts();\n    if (value) {\n      this.updateDeviceTypeCount();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(onTouched: any): void {\n    this.onTouched = onTouched;\n  }\n\n  markAsTouched(): void {\n    if (!this.touched) {\n      this.onTouched();\n      this.touched = true;\n    }\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n  }\n\n  async toggle(): Promise<void> {\n    this.value = !this.value;\n    this.onChange(this.value);\n    if (this.value && this.deviceTypeInstancesCount == null) {\n      this.setDisabledState(true);\n      await this.updateDeviceTypeCount();\n    }\n    this.updateTexts();\n    this.setDisabledState(false);\n  }\n\n  private updateTexts(): void {\n    this.typedDashboardStatus = this.value\n      ? gettext('Enabled`typed dashboard`')\n      : gettext('Disabled`typed dashboard`');\n\n    if (this.allowTypeDashboard === 'allow_if_type_filled') {\n      this.infoText = gettext(\n        `<p class=\"p-b-8\">Enabling this option uses the layout and configuration of this dashboard to create dashboard instances for all devices based on the device type.</p>\n             <p class=\"p-b-16\">The current device doesn't have a device type assigned to it. Assign a device type to the device via the \"Asset properties\" widget in the <strong>Info</strong> tab of the device.</p>`\n      );\n      return;\n    }\n\n    if (this.value) {\n      if (this.isDevice) {\n        this.infoText = gettext(\n          `<p class=\"p-b-8\">\n            The layout and configuration of this dashboard is used by all devices based on device type <span class=\"tag tag--info text-12\">{{ displayDeviceTypeValue }}</span>.\n          </p>\n          <p class=\"p-b-16\">\n            Disabling this option removes it from all devices based on the same type and makes it available only for the current instance.\n          </p>`\n        );\n      } else {\n        this.infoText = gettext(\n          `<p class=\"p-b-8\">\n              The layout and configuration of this dashboard is used by all assets based on asset model <span class=\"tag tag--info text-12\">{{ displayDeviceTypeValue }}</span>.\n            </p>\n            <p class=\"p-b-16\">\n              Disabling this option removes it from all assets based on the same model and makes it available only for the current instance.\n            </p>`\n        );\n      }\n    } else {\n      if (this.isDevice) {\n        this.infoText = gettext(\n          `<p>Enabling this option uses the layout and configuration of this dashboard to create dashboard instances for all devices based on the type <span class=\"tag tag--info text-12\">{{ displayDeviceTypeValue }}</span>.</p>`\n        );\n      } else {\n        this.infoText = gettext(\n          `<p>Enabling this option uses the layout and configuration of this dashboard to create dashboard instances for all assets based on the model <span class=\"tag tag--info text-12\">{{ displayDeviceTypeValue }}</span>.</p>`\n        );\n      }\n    }\n  }\n\n  private async updateDeviceTypeCount(): Promise<void> {\n    const count = await this.inventory.count({\n      type: this.deviceTypeValue\n    });\n    this.deviceTypeInstancesCount = count.data;\n  }\n}\n","<fieldset class=\"c8y-fieldset c8y-fieldset--lg\">\n  <legend>{{ 'Dashboard template' | translate }}</legend>\n  <div class=\"d-flex p-b-16 gap-16\">\n    <label class=\"c8y-switch flex-no-shrink\">\n      <input\n        type=\"checkbox\"\n        [checked]=\"value\"\n        [disabled]=\"disabled\"\n        (click)=\"toggle()\"\n      />\n      <span></span>\n      <span>{{ typedDashboardStatus | translate }}</span>\n    </label>\n    <div class=\"flex-grow d-flex d-col\">\n      <div\n        class=\"flex-grow\"\n        [innerHtml]=\"infoText | translate: { displayDeviceTypeValue: displayDeviceTypeValue }\"\n      ></div>\n      <button\n        class=\"btn-link p-0 m-r-auto\"\n        type=\"button\"\n        *ngIf=\"allowTypeDashboard === 'allow_if_type_filled' && showSourceNavigationLink$ | async\"\n        (click)=\"goToDeviceView()\"\n      >\n        {{\n          deviceManagementLinkTitle\n            | translate\n              : {\n                  deviceManagementAppName:\n                    userDeviceManagementApp$ | async | humanizeAppName | async\n                }\n        }}\n        <i c8yIcon=\"external-link\"></i>\n      </button>\n    </div>\n  </div>\n\n  <c8y-type-dashboard-info\n    *ngIf=\"allowTypeDashboard === 'allow'\"\n    [context]=\"mo\"\n    [deviceTypeValue]=\"deviceTypeValue\"\n    [displayDeviceTypeValue]=\"displayDeviceTypeValue\"\n  ></c8y-type-dashboard-info>\n\n  <div\n    class=\"p-t-8 p-b-16\"\n    *ngIf=\"mo?.c8y_Dashboard && value\"\n  >\n    <button\n      class=\"btn btn-default btn-sm\"\n      type=\"button\"\n      (click)=\"onDuplicateWithoutType.emit()\"\n      [disabled]=\"formInvalid\"\n    >\n      {{ 'Duplicate as regular dashboard' | translate }}\n    </button>\n  </div>\n</fieldset>\n"]}