@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
98 lines • 18.5 kB
JavaScript
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { UserGroupService } from '@c8y/client';
import { GainsightService, Permissions } from '@c8y/ngx-components';
import { ALL_GLOBAL_ROLES_SELECTED, PRODUCT_EXPERIENCE } from './context-dashboard.model';
import * as i0 from "@angular/core";
import * as i1 from "@c8y/client";
import * as i2 from "@c8y/ngx-components";
import * as i3 from "@angular/common";
import * as i4 from "ngx-bootstrap/popover";
export class DashboardAvailabilityComponent {
/**
* Ids of global roles assigned to the dashboard or a string "all" indicating the selection of all global roles.
* The value undefined is treated as equivalent to 'all'.
*/
get globalRolesIds() {
return this._globalRolesIds;
}
set globalRolesIds(ids) {
if (!ids || ids === ALL_GLOBAL_ROLES_SELECTED) {
this._globalRolesIds = ALL_GLOBAL_ROLES_SELECTED;
return;
}
this._globalRolesIds = [...ids];
}
constructor(userGroupService, gainsightService, permissions) {
this.userGroupService = userGroupService;
this.gainsightService = gainsightService;
this.permissions = permissions;
this.globalRolesIdsChange = new EventEmitter();
this.globalRolesItems = [];
this.globalRolesItemsSelected = [];
this.selectHidden = false;
this.globalRoles = [];
this.PAGE_SIZE = 100;
}
async ngOnInit() {
if (this.permissions.hasRole(Permissions.ROLE_USER_MANAGEMENT_READ)) {
this.globalRoles = await this.getGlobalRoles();
this.globalRolesItems = this.mapGlobalRolesToItems();
this.globalRolesItemsSelected = this.getSelectedGlobalRolesItems();
}
else {
this.selectHidden = true;
}
}
onSelected(items) {
if (!items || !Array.isArray(items)) {
return;
}
const allItemsSelected = items.length === this.globalRolesItems.length;
this.globalRolesItemsSelected = items;
if (allItemsSelected) {
this.globalRolesIdsChange.emit(ALL_GLOBAL_ROLES_SELECTED);
this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.DASHBOARDS, {
component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.DASHBOARD_AVAILABILITY,
action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.APPLY_GLOBAL_ROLES_CHANGES,
globalRoles: ALL_GLOBAL_ROLES_SELECTED
});
}
else {
const selectedGlobalRolesIds = items.map(i => i.id);
this.globalRolesIdsChange.emit([...selectedGlobalRolesIds]);
this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.DASHBOARDS, {
component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.DASHBOARD_AVAILABILITY,
action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.APPLY_GLOBAL_ROLES_CHANGES,
globalRoles: selectedGlobalRolesIds?.sort()?.join()
});
}
}
async getGlobalRoles() {
return (await this.userGroupService.list({ pageSize: this.PAGE_SIZE })).data;
}
mapGlobalRolesToItems() {
return this.globalRoles.map(({ name, id }) => ({
name,
id
}));
}
getSelectedGlobalRolesItems() {
if (!this.globalRolesIds || this.globalRolesIds === ALL_GLOBAL_ROLES_SELECTED) {
return this.globalRolesItems;
}
return this.globalRolesIds
.map(globalRoleId => this.globalRolesItems.find(gR => gR.id === globalRoleId))
.filter(Boolean);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DashboardAvailabilityComponent, deps: [{ token: i1.UserGroupService }, { token: i2.GainsightService }, { token: i2.Permissions }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DashboardAvailabilityComponent, selector: "c8y-dashboard-availability", inputs: { globalRolesIds: "globalRolesIds" }, outputs: { globalRolesIdsChange: "globalRolesIdsChange" }, ngImport: i0, template: "<fieldset class=\"c8y-fieldset c8y-fieldset--lg\">\n <legend>{{ 'Availability`of dashboard based on permissions`' | translate }}</legend>\n <c8y-form-group>\n <label for=\"availability\">\n <span\n class=\"m-r-4\"\n id=\"availability\"\n >\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n placement=\"right\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n ></button>\n </label>\n <c8y-select-legacy\n *ngIf=\"!selectHidden\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select-legacy>\n <p\n class=\"form-control-static\"\n *ngIf=\"selectHidden\"\n >\n {{ \"You don't have permission to change global roles.\" | translate }}\n </p>\n </c8y-form-group>\n</fieldset>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.SelectLegacyComponent, selector: "c8y-select-legacy", inputs: ["placeholder", "selectedLabel", "applyLabel", "items", "selected", "updateItems", "disableApplyOnNoSelection", "addDropdownContainerToBody"], outputs: ["onChange"] }, { kind: "component", type: i2.FormGroupComponent, selector: "c8y-form-group", inputs: ["hasError", "hasWarning", "hasSuccess", "novalidation", "status"] }, { kind: "directive", type: i4.PopoverDirective, selector: "[popover]", inputs: ["adaptivePosition", "boundariesElement", "popover", "popoverContext", "popoverTitle", "placement", "outsideClick", "triggers", "container", "containerClass", "isOpen", "delay"], outputs: ["onShown", "onHidden"], exportAs: ["bs-popover"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DashboardAvailabilityComponent, decorators: [{
type: Component,
args: [{ selector: 'c8y-dashboard-availability', template: "<fieldset class=\"c8y-fieldset c8y-fieldset--lg\">\n <legend>{{ 'Availability`of dashboard based on permissions`' | translate }}</legend>\n <c8y-form-group>\n <label for=\"availability\">\n <span\n class=\"m-r-4\"\n id=\"availability\"\n >\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n placement=\"right\"\n triggers=\"focus\"\n container=\"body\"\n type=\"button\"\n ></button>\n </label>\n <c8y-select-legacy\n *ngIf=\"!selectHidden\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select-legacy>\n <p\n class=\"form-control-static\"\n *ngIf=\"selectHidden\"\n >\n {{ \"You don't have permission to change global roles.\" | translate }}\n </p>\n </c8y-form-group>\n</fieldset>\n" }]
}], ctorParameters: () => [{ type: i1.UserGroupService }, { type: i2.GainsightService }, { type: i2.Permissions }], propDecorators: { globalRolesIds: [{
type: Input
}], globalRolesIdsChange: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-availability.component.js","sourceRoot":"","sources":["../../../context-dashboard/dashboard-availability.component.ts","../../../context-dashboard/dashboard-availability.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { IUserGroup, UserGroupService } from '@c8y/client';\nimport { GainsightService, Item, Permissions } from '@c8y/ngx-components';\nimport {\n  DashboardGlobalRoles,\n  ALL_GLOBAL_ROLES_SELECTED,\n  PRODUCT_EXPERIENCE\n} from './context-dashboard.model';\n\n@Component({\n  selector: 'c8y-dashboard-availability',\n  templateUrl: './dashboard-availability.component.html'\n})\nexport class DashboardAvailabilityComponent implements OnInit {\n  /**\n   * Ids of global roles assigned to the dashboard or a string \"all\" indicating the selection of all global roles.\n   * The value undefined is treated as equivalent to 'all'.\n   */\n  @Input()\n  get globalRolesIds(): DashboardGlobalRoles {\n    return this._globalRolesIds;\n  }\n  set globalRolesIds(ids: DashboardGlobalRoles) {\n    if (!ids || ids === ALL_GLOBAL_ROLES_SELECTED) {\n      this._globalRolesIds = ALL_GLOBAL_ROLES_SELECTED;\n      return;\n    }\n    this._globalRolesIds = [...ids];\n  }\n  @Output() globalRolesIdsChange = new EventEmitter<DashboardGlobalRoles>();\n  globalRolesItems: Item[] = [];\n  globalRolesItemsSelected: Item[] = [];\n  selectHidden = false;\n  private globalRoles: IUserGroup[] = [];\n  private PAGE_SIZE = 100;\n  private _globalRolesIds: DashboardGlobalRoles;\n\n  constructor(\n    private userGroupService: UserGroupService,\n    private gainsightService: GainsightService,\n    private permissions: Permissions\n  ) {}\n\n  async ngOnInit() {\n    if (this.permissions.hasRole(Permissions.ROLE_USER_MANAGEMENT_READ)) {\n      this.globalRoles = await this.getGlobalRoles();\n      this.globalRolesItems = this.mapGlobalRolesToItems();\n      this.globalRolesItemsSelected = this.getSelectedGlobalRolesItems();\n    } else {\n      this.selectHidden = true;\n    }\n  }\n\n  onSelected(items: Item[]) {\n    if (!items || !Array.isArray(items)) {\n      return;\n    }\n\n    const allItemsSelected = items.length === this.globalRolesItems.length;\n    this.globalRolesItemsSelected = items;\n\n    if (allItemsSelected) {\n      this.globalRolesIdsChange.emit(ALL_GLOBAL_ROLES_SELECTED);\n      this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.DASHBOARDS, {\n        component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.DASHBOARD_AVAILABILITY,\n        action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.APPLY_GLOBAL_ROLES_CHANGES,\n        globalRoles: ALL_GLOBAL_ROLES_SELECTED\n      });\n    } else {\n      const selectedGlobalRolesIds = items.map(i => i.id);\n      this.globalRolesIdsChange.emit([...selectedGlobalRolesIds]);\n\n      this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.DASHBOARD.EVENTS.DASHBOARDS, {\n        component: PRODUCT_EXPERIENCE.DASHBOARD.COMPONENTS.DASHBOARD_AVAILABILITY,\n        action: PRODUCT_EXPERIENCE.DASHBOARD.ACTIONS.APPLY_GLOBAL_ROLES_CHANGES,\n        globalRoles: selectedGlobalRolesIds?.sort()?.join()\n      });\n    }\n  }\n\n  private async getGlobalRoles() {\n    return (await this.userGroupService.list({ pageSize: this.PAGE_SIZE })).data;\n  }\n\n  private mapGlobalRolesToItems(): Item[] {\n    return this.globalRoles.map(({ name, id }) => ({\n      name,\n      id\n    }));\n  }\n\n  private getSelectedGlobalRolesItems(): Item[] {\n    if (!this.globalRolesIds || this.globalRolesIds === ALL_GLOBAL_ROLES_SELECTED) {\n      return this.globalRolesItems;\n    }\n    return this.globalRolesIds\n      .map(globalRoleId => this.globalRolesItems.find(gR => gR.id === globalRoleId))\n      .filter(Boolean);\n  }\n}\n","<fieldset class=\"c8y-fieldset c8y-fieldset--lg\">\n  <legend>{{ 'Availability`of dashboard based on permissions`' | translate }}</legend>\n  <c8y-form-group>\n    <label for=\"availability\">\n      <span\n        class=\"m-r-4\"\n        id=\"availability\"\n      >\n        {{ 'Global roles' | translate }}\n      </span>\n      <button\n        class=\"btn-help btn-help--sm\"\n        [attr.aria-label]=\"'Help' | translate\"\n        popover=\"{{\n          'Select the global roles for which the dashboard will be available' | translate\n        }}\"\n        placement=\"right\"\n        triggers=\"focus\"\n        container=\"body\"\n        type=\"button\"\n      ></button>\n    </label>\n    <c8y-select-legacy\n      *ngIf=\"!selectHidden\"\n      [items]=\"globalRolesItems\"\n      [selected]=\"globalRolesItemsSelected\"\n      (onChange)=\"onSelected($event)\"\n    ></c8y-select-legacy>\n    <p\n      class=\"form-control-static\"\n      *ngIf=\"selectHidden\"\n    >\n      {{ \"You don't have permission to change global roles.\" | translate }}\n    </p>\n  </c8y-form-group>\n</fieldset>\n"]}