UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

120 lines 29.5 kB
import { Component, EventEmitter, Input, Output } from '@angular/core'; import { gettext } from '@c8y/ngx-components'; import { TranslateService } from '@ngx-translate/core'; import { cloneDeep } from 'lodash-es'; import { ContextDashboardService } from '../context-dashboard.service'; import * as i0 from "@angular/core"; import * as i1 from "@ngx-translate/core"; import * as i2 from "../context-dashboard.service"; import * as i3 from "@c8y/ngx-components"; import * as i4 from "@angular/common"; export class DashboardVersionHistoryComponent { constructor(translateService, contextDashboardService) { this.translateService = translateService; this.contextDashboardService = contextDashboardService; this.dashboardHistory = []; this.onRevert = new EventEmitter(); this.dashboardHistoryExtended = []; this.restoredDashboardMessage = gettext('Restored dashboard state from {{ restoredStateCreationDate }}'); this.versionHistoryLimitMessage = gettext('Store up to {{ versionHistoryLimit }} dashboard versions. Any additional versions will replace/delete older ones'); } ngOnInit() { this.generateDashboardHistoryDescription(); } generateDashboardHistoryDescription() { for (const dashboard of this.dashboardHistory) { const copiedDashboard = { ...dashboard }; let settingChangesMessage = ''; let assetModelMessage = ''; let widgetChanges = ''; if (dashboard.historyDescription.changeType === 'create') { copiedDashboard.descriptionText = this.translateService.instant(this.isReport ? gettext('Report created.') : gettext('Dashboard created.')); this.dashboardHistoryExtended.push(copiedDashboard); continue; } if (dashboard.historyDescription.changeType === 'reset') { copiedDashboard.descriptionText = this.translateService.instant(gettext('Reset widgets')); this.dashboardHistoryExtended.push(copiedDashboard); continue; } const isDashboardUpdated = dashboard.historyDescription.dashboardSettingChanges?.length > 0; if (isDashboardUpdated) { const translatedValuesChanged = dashboard.historyDescription.dashboardSettingChanges .map(val => this.translateService.instant(val)) .join(', '); settingChangesMessage = this.translateService.instant(this.isReport ? gettext('Report updated: {{ values }}.') : gettext('Dashboard updated: {{ values }}.'), { values: translatedValuesChanged }); } const isDeviceDashboard = dashboard.historyDescription.deviceType != null && !this.isReport; if (isDeviceDashboard) { assetModelMessage = this.translateService.instant(dashboard.historyDescription.deviceType ? gettext('Dashboard asset model has been enabled.') : gettext('Dashboard asset model has been disabled.')); } if (dashboard.historyDescription.widgetChanges) { for (const change in dashboard.historyDescription.widgetChanges) { const widgetList = dashboard.historyDescription.widgetChanges[change]; if (!widgetList) { continue; } const translatedWidgetList = dashboard.translateWidgetTitle ? widgetList.map(widget => this.translateService.instant(widget)) : widgetList; switch (change) { case 'added': widgetChanges = widgetChanges + this.translateService.instant(gettext('Added widgets: {{ widgetList }}. '), { widgetList: `"${translatedWidgetList.join('", "')}"` }); break; case 'removed': widgetChanges = widgetChanges + this.translateService.instant(gettext('Removed widgets: {{ widgetList }}. '), { widgetList: `"${translatedWidgetList.join('", "')}"` }); break; case 'config': widgetChanges = widgetChanges + this.translateService.instant(gettext('Updated widgets: {{ widgetList }}. '), { widgetList: `"${translatedWidgetList.join('", "')}"` }); break; case 'arrangement': widgetChanges = widgetChanges + this.translateService.instant(gettext('Rearranged widgets: {{ widgetList }}. '), { widgetList: `"${translatedWidgetList.join('", "')}"` }); break; default: break; } } } copiedDashboard.descriptionText = `${settingChangesMessage} ${assetModelMessage} ${widgetChanges}`; this.dashboardHistoryExtended.push(copiedDashboard); } } revertDashboard(dashboard) { const newDashboard = cloneDeep(dashboard); newDashboard.historyDescription.restored = dashboard.created; this.onRevert.emit(newDashboard); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DashboardVersionHistoryComponent, deps: [{ token: i1.TranslateService }, { token: i2.ContextDashboardService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DashboardVersionHistoryComponent, selector: "c8y-dashboard-version-history", inputs: { dashboardHistory: "dashboardHistory", isReport: "isReport" }, outputs: { onRevert: "onRevert" }, ngImport: i0, template: "<div class=\"bg-component p-t-8 p-b-8 separator-bottom text-center\">\n <i\n class=\"text-info m-r-4\"\n c8yIcon=\"info\"\n ></i>\n {{\n versionHistoryLimitMessage\n | translate: { versionHistoryLimit: contextDashboardService.VERSION_HISTORY_SIZE_LIMIT }\n }}\n</div>\n<c8y-list-group class=\"p-t-24 p-b-24\">\n <c8y-li-timeline\n *ngFor=\"let dashboard of dashboardHistoryExtended; index as i\"\n [ngClass]=\"{ active: i === 0 }\"\n >\n {{ dashboard.created | date: 'mediumDate' }}\n {{ dashboard.created | date: 'shortTime' }}\n <c8y-li data-cy=\"c8y-dashboard-version-history--history-row\">\n <c8y-li-body>\n <div class=\"d-flex a-i-start\">\n <div class=\"flex-grow\">\n <span\n class=\"text-truncate-wrap\"\n title=\"{{ dashboard.descriptionText }}\"\n data-cy=\"c8y-dashboard-version-history--history-title\"\n >\n {{ dashboard.descriptionText }}\n {{\n dashboard.historyDescription.restored\n ? (restoredDashboardMessage\n | translate\n : {\n restoredStateCreationDate: dashboard.historyDescription.restored | c8yDate\n })\n : ''\n }}\n </span>\n <small\n class=\"text-muted\"\n title=\"{{ 'by`user`' | translate }} {{ dashboard.author }}\"\n *ngIf=\"dashboard.author\"\n >\n <div class=\"icon-flex\">\n <i c8yIcon=\"c8y-user\"></i>\n {{ dashboard.author }}\n </div>\n </small>\n </div>\n\n <span\n class=\"label label-primary m-l-auto\"\n title=\"{{ 'The last saved status of the dashboard' | translate }}\"\n *ngIf=\"i === 0\"\n >\n {{ 'Current`dashboard status`' | translate }}\n </span>\n <span\n class=\"m-l-auto showOnHover\"\n *ngIf=\"dashboardHistoryExtended.length > 1 && i > 0\"\n >\n <button\n class=\"btn btn-default btn-sm\"\n title=\"{{ 'Restore the dashboard to this status' | translate }}\"\n type=\"button\"\n (click)=\"revertDashboard(dashboard)\"\n >\n {{ 'Restore' | translate }}\n </button>\n </span>\n </div>\n </c8y-li-body>\n </c8y-li>\n </c8y-li-timeline>\n</c8y-list-group>\n", dependencies: [{ kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ListGroupComponent, selector: "c8y-list-group" }, { kind: "component", type: i3.ListItemComponent, selector: "c8y-list-item, c8y-li", inputs: ["active", "highlighted", "emptyActions", "dense", "collapsed", "selectable"], outputs: ["collapsedChange"] }, { kind: "component", type: i3.ListItemBodyComponent, selector: "c8y-list-item-body, c8y-li-body", inputs: ["body"] }, { kind: "component", type: i3.ListItemTimelineComponent, selector: "c8y-list-item-timeline, c8y-li-timeline" }, { kind: "pipe", type: i3.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i4.DatePipe, name: "date" }, { kind: "pipe", type: i3.DatePipe, name: "c8yDate" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DashboardVersionHistoryComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-dashboard-version-history', template: "<div class=\"bg-component p-t-8 p-b-8 separator-bottom text-center\">\n <i\n class=\"text-info m-r-4\"\n c8yIcon=\"info\"\n ></i>\n {{\n versionHistoryLimitMessage\n | translate: { versionHistoryLimit: contextDashboardService.VERSION_HISTORY_SIZE_LIMIT }\n }}\n</div>\n<c8y-list-group class=\"p-t-24 p-b-24\">\n <c8y-li-timeline\n *ngFor=\"let dashboard of dashboardHistoryExtended; index as i\"\n [ngClass]=\"{ active: i === 0 }\"\n >\n {{ dashboard.created | date: 'mediumDate' }}\n {{ dashboard.created | date: 'shortTime' }}\n <c8y-li data-cy=\"c8y-dashboard-version-history--history-row\">\n <c8y-li-body>\n <div class=\"d-flex a-i-start\">\n <div class=\"flex-grow\">\n <span\n class=\"text-truncate-wrap\"\n title=\"{{ dashboard.descriptionText }}\"\n data-cy=\"c8y-dashboard-version-history--history-title\"\n >\n {{ dashboard.descriptionText }}\n {{\n dashboard.historyDescription.restored\n ? (restoredDashboardMessage\n | translate\n : {\n restoredStateCreationDate: dashboard.historyDescription.restored | c8yDate\n })\n : ''\n }}\n </span>\n <small\n class=\"text-muted\"\n title=\"{{ 'by`user`' | translate }} {{ dashboard.author }}\"\n *ngIf=\"dashboard.author\"\n >\n <div class=\"icon-flex\">\n <i c8yIcon=\"c8y-user\"></i>\n {{ dashboard.author }}\n </div>\n </small>\n </div>\n\n <span\n class=\"label label-primary m-l-auto\"\n title=\"{{ 'The last saved status of the dashboard' | translate }}\"\n *ngIf=\"i === 0\"\n >\n {{ 'Current`dashboard status`' | translate }}\n </span>\n <span\n class=\"m-l-auto showOnHover\"\n *ngIf=\"dashboardHistoryExtended.length > 1 && i > 0\"\n >\n <button\n class=\"btn btn-default btn-sm\"\n title=\"{{ 'Restore the dashboard to this status' | translate }}\"\n type=\"button\"\n (click)=\"revertDashboard(dashboard)\"\n >\n {{ 'Restore' | translate }}\n </button>\n </span>\n </div>\n </c8y-li-body>\n </c8y-li>\n </c8y-li-timeline>\n</c8y-list-group>\n" }] }], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.ContextDashboardService }], propDecorators: { dashboardHistory: [{ type: Input }], isReport: [{ type: Input }], onRevert: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-version-history.component.js","sourceRoot":"","sources":["../../../../context-dashboard/dashboard-settings/dashboard-version-history.component.ts","../../../../context-dashboard/dashboard-settings/dashboard-version-history.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { gettext } from '@c8y/ngx-components';\nimport { ContextDashboard } from '../context-dashboard.model';\nimport { TranslateService } from '@ngx-translate/core';\nimport { cloneDeep } from 'lodash-es';\nimport { ContextDashboardService } from '../context-dashboard.service';\n\n@Component({\n  selector: 'c8y-dashboard-version-history',\n  templateUrl: './dashboard-version-history.component.html'\n})\nexport class DashboardVersionHistoryComponent {\n  @Input() dashboardHistory: ContextDashboard[] = [];\n  @Input() isReport: boolean;\n  @Output() onRevert: EventEmitter<ContextDashboard> = new EventEmitter();\n  dashboardHistoryExtended: (ContextDashboard & { descriptionText?: string })[] = [];\n  restoredDashboardMessage = gettext(\n    'Restored dashboard state from {{ restoredStateCreationDate }}'\n  );\n  versionHistoryLimitMessage = gettext(\n    'Store up to {{ versionHistoryLimit }} dashboard versions. Any additional versions will replace/delete older ones'\n  );\n\n  constructor(\n    private translateService: TranslateService,\n    public contextDashboardService: ContextDashboardService\n  ) {}\n\n  ngOnInit() {\n    this.generateDashboardHistoryDescription();\n  }\n\n  generateDashboardHistoryDescription() {\n    for (const dashboard of this.dashboardHistory) {\n      const copiedDashboard: ContextDashboard & { descriptionText?: string } = { ...dashboard };\n\n      let settingChangesMessage = '';\n      let assetModelMessage = '';\n      let widgetChanges = '';\n\n      if (dashboard.historyDescription.changeType === 'create') {\n        copiedDashboard.descriptionText = this.translateService.instant(\n          this.isReport ? gettext('Report created.') : gettext('Dashboard created.')\n        );\n        this.dashboardHistoryExtended.push(copiedDashboard);\n        continue;\n      }\n      if (dashboard.historyDescription.changeType === 'reset') {\n        copiedDashboard.descriptionText = this.translateService.instant(gettext('Reset widgets'));\n        this.dashboardHistoryExtended.push(copiedDashboard);\n        continue;\n      }\n\n      const isDashboardUpdated = dashboard.historyDescription.dashboardSettingChanges?.length > 0;\n      if (isDashboardUpdated) {\n        const translatedValuesChanged = dashboard.historyDescription.dashboardSettingChanges\n          .map(val => this.translateService.instant(val))\n          .join(', ');\n        settingChangesMessage = this.translateService.instant(\n          this.isReport\n            ? gettext('Report updated: {{ values }}.')\n            : gettext('Dashboard updated: {{ values }}.'),\n          { values: translatedValuesChanged }\n        );\n      }\n\n      const isDeviceDashboard = dashboard.historyDescription.deviceType != null && !this.isReport;\n      if (isDeviceDashboard) {\n        assetModelMessage = this.translateService.instant(\n          dashboard.historyDescription.deviceType\n            ? gettext('Dashboard asset model has been enabled.')\n            : gettext('Dashboard asset model has been disabled.')\n        );\n      }\n\n      if (dashboard.historyDescription.widgetChanges) {\n        for (const change in dashboard.historyDescription.widgetChanges) {\n          const widgetList = dashboard.historyDescription.widgetChanges[change];\n          if (!widgetList) {\n            continue;\n          }\n          const translatedWidgetList = dashboard.translateWidgetTitle\n            ? widgetList.map(widget => this.translateService.instant(widget))\n            : widgetList;\n          switch (change) {\n            case 'added':\n              widgetChanges =\n                widgetChanges +\n                this.translateService.instant(gettext('Added widgets: {{ widgetList }}. '), {\n                  widgetList: `\"${translatedWidgetList.join('\", \"')}\"`\n                });\n              break;\n            case 'removed':\n              widgetChanges =\n                widgetChanges +\n                this.translateService.instant(gettext('Removed widgets: {{ widgetList }}. '), {\n                  widgetList: `\"${translatedWidgetList.join('\", \"')}\"`\n                });\n              break;\n            case 'config':\n              widgetChanges =\n                widgetChanges +\n                this.translateService.instant(gettext('Updated widgets: {{ widgetList }}. '), {\n                  widgetList: `\"${translatedWidgetList.join('\", \"')}\"`\n                });\n              break;\n            case 'arrangement':\n              widgetChanges =\n                widgetChanges +\n                this.translateService.instant(gettext('Rearranged widgets: {{ widgetList }}. '), {\n                  widgetList: `\"${translatedWidgetList.join('\", \"')}\"`\n                });\n              break;\n            default:\n              break;\n          }\n        }\n      }\n\n      copiedDashboard.descriptionText = `${settingChangesMessage} ${assetModelMessage} ${widgetChanges}`;\n      this.dashboardHistoryExtended.push(copiedDashboard);\n    }\n  }\n\n  revertDashboard(dashboard: ContextDashboard): void {\n    const newDashboard = cloneDeep(dashboard);\n    newDashboard.historyDescription.restored = dashboard.created;\n    this.onRevert.emit(newDashboard);\n  }\n}\n","<div class=\"bg-component p-t-8 p-b-8 separator-bottom text-center\">\n  <i\n    class=\"text-info m-r-4\"\n    c8yIcon=\"info\"\n  ></i>\n  {{\n    versionHistoryLimitMessage\n      | translate: { versionHistoryLimit: contextDashboardService.VERSION_HISTORY_SIZE_LIMIT }\n  }}\n</div>\n<c8y-list-group class=\"p-t-24 p-b-24\">\n  <c8y-li-timeline\n    *ngFor=\"let dashboard of dashboardHistoryExtended; index as i\"\n    [ngClass]=\"{ active: i === 0 }\"\n  >\n    {{ dashboard.created | date: 'mediumDate' }}\n    {{ dashboard.created | date: 'shortTime' }}\n    <c8y-li data-cy=\"c8y-dashboard-version-history--history-row\">\n      <c8y-li-body>\n        <div class=\"d-flex a-i-start\">\n          <div class=\"flex-grow\">\n            <span\n              class=\"text-truncate-wrap\"\n              title=\"{{ dashboard.descriptionText }}\"\n              data-cy=\"c8y-dashboard-version-history--history-title\"\n            >\n              {{ dashboard.descriptionText }}\n              {{\n                dashboard.historyDescription.restored\n                  ? (restoredDashboardMessage\n                    | translate\n                      : {\n                          restoredStateCreationDate: dashboard.historyDescription.restored | c8yDate\n                        })\n                  : ''\n              }}\n            </span>\n            <small\n              class=\"text-muted\"\n              title=\"{{ 'by`user`' | translate }} {{ dashboard.author }}\"\n              *ngIf=\"dashboard.author\"\n            >\n              <div class=\"icon-flex\">\n                <i c8yIcon=\"c8y-user\"></i>\n                {{ dashboard.author }}\n              </div>\n            </small>\n          </div>\n\n          <span\n            class=\"label label-primary m-l-auto\"\n            title=\"{{ 'The last saved status of the dashboard' | translate }}\"\n            *ngIf=\"i === 0\"\n          >\n            {{ 'Current`dashboard status`' | translate }}\n          </span>\n          <span\n            class=\"m-l-auto showOnHover\"\n            *ngIf=\"dashboardHistoryExtended.length > 1 && i > 0\"\n          >\n            <button\n              class=\"btn btn-default btn-sm\"\n              title=\"{{ 'Restore the dashboard to this status' | translate }}\"\n              type=\"button\"\n              (click)=\"revertDashboard(dashboard)\"\n            >\n              {{ 'Restore' | translate }}\n            </button>\n          </span>\n        </div>\n      </c8y-li-body>\n    </c8y-li>\n  </c8y-li-timeline>\n</c8y-list-group>\n"]}