@c8y/ngx-components 1018.0.249 → 1018.0.255

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,11 +1,12 @@
1
1
  import { EventEmitter, OnInit } from '@angular/core';
2
2
  import { UserGroupService } from '@c8y/client';
3
- import { GainsightService, Item } from '@c8y/ngx-components';
3
+ import { GainsightService, Item, Permissions } from '@c8y/ngx-components';
4
4
  import { DashboardGlobalRoles } from './context-dashboard.model';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class DashboardAvailabilityComponent implements OnInit {
7
7
  private userGroupService;
8
8
  private gainsightService;
9
+ private permissions;
9
10
  /**
10
11
  * Ids of global roles assigned to the dashboard or a string "all" indicating the selection of all global roles.
11
12
  * The value undefined is treated as equivalent to 'all'.
@@ -15,10 +16,11 @@ export declare class DashboardAvailabilityComponent implements OnInit {
15
16
  globalRolesIdsChange: EventEmitter<DashboardGlobalRoles>;
16
17
  globalRolesItems: Item[];
17
18
  globalRolesItemsSelected: Item[];
19
+ selectHidden: boolean;
18
20
  private globalRoles;
19
21
  private PAGE_SIZE;
20
22
  private _globalRolesIds;
21
- constructor(userGroupService: UserGroupService, gainsightService: GainsightService);
23
+ constructor(userGroupService: UserGroupService, gainsightService: GainsightService, permissions: Permissions);
22
24
  ngOnInit(): Promise<void>;
23
25
  onSelected(items: Item[]): void;
24
26
  private getGlobalRoles;
@@ -1,18 +1,21 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { UserGroupService } from '@c8y/client';
3
- import { GainsightService } from '@c8y/ngx-components';
3
+ import { GainsightService, Permissions } from '@c8y/ngx-components';
4
4
  import { ALL_GLOBAL_ROLES_SELECTED, PRODUCT_EXPERIENCE } from './context-dashboard.model';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@c8y/client";
7
7
  import * as i2 from "@c8y/ngx-components";
8
- import * as i3 from "ngx-bootstrap/popover";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "ngx-bootstrap/popover";
9
10
  export class DashboardAvailabilityComponent {
10
- constructor(userGroupService, gainsightService) {
11
+ constructor(userGroupService, gainsightService, permissions) {
11
12
  this.userGroupService = userGroupService;
12
13
  this.gainsightService = gainsightService;
14
+ this.permissions = permissions;
13
15
  this.globalRolesIdsChange = new EventEmitter();
14
16
  this.globalRolesItems = [];
15
17
  this.globalRolesItemsSelected = [];
18
+ this.selectHidden = false;
16
19
  this.globalRoles = [];
17
20
  this.PAGE_SIZE = 100;
18
21
  }
@@ -31,9 +34,14 @@ export class DashboardAvailabilityComponent {
31
34
  this._globalRolesIds = [...ids];
32
35
  }
33
36
  async ngOnInit() {
34
- this.globalRoles = await this.getGlobalRoles();
35
- this.globalRolesItems = this.mapGlobalRolesToItems();
36
- this.globalRolesItemsSelected = this.getSelectedGlobalRolesItems();
37
+ if (this.permissions.hasRole(Permissions.ROLE_USER_MANAGEMENT_READ)) {
38
+ this.globalRoles = await this.getGlobalRoles();
39
+ this.globalRolesItems = this.mapGlobalRolesToItems();
40
+ this.globalRolesItemsSelected = this.getSelectedGlobalRolesItems();
41
+ }
42
+ else {
43
+ this.selectHidden = true;
44
+ }
37
45
  }
38
46
  onSelected(items) {
39
47
  if (!items || !Array.isArray(items)) {
@@ -77,14 +85,14 @@ export class DashboardAvailabilityComponent {
77
85
  .filter(Boolean);
78
86
  }
79
87
  }
80
- DashboardAvailabilityComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DashboardAvailabilityComponent, deps: [{ token: i1.UserGroupService }, { token: i2.GainsightService }], target: i0.ɵɵFactoryTarget.Component });
81
- DashboardAvailabilityComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: DashboardAvailabilityComponent, selector: "c8y-dashboard-availability", inputs: { globalRolesIds: "globalRolesIds" }, outputs: { globalRolesIdsChange: "globalRolesIdsChange" }, ngImport: i0, template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\n</c8y-form-group>\n", dependencies: [{ kind: "component", type: i2.SelectComponent, selector: "c8y-select", inputs: ["placeholder", "selectedLabel", "applyLabel", "items", "selected", "updateItems", "disableApplyOnNoSelection"], outputs: ["onChange"] }, { kind: "component", type: i2.FormGroupComponent, selector: "c8y-form-group", inputs: ["hasError", "hasWarning", "hasSuccess", "novalidation", "status"] }, { kind: "directive", type: i3.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" }] });
88
+ DashboardAvailabilityComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DashboardAvailabilityComponent, deps: [{ token: i1.UserGroupService }, { token: i2.GainsightService }, { token: i2.Permissions }], target: i0.ɵɵFactoryTarget.Component });
89
+ DashboardAvailabilityComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: DashboardAvailabilityComponent, selector: "c8y-dashboard-availability", inputs: { globalRolesIds: "globalRolesIds" }, outputs: { globalRolesIdsChange: "globalRolesIdsChange" }, ngImport: i0, template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n *ngIf=\"!selectHidden\"\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\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", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.SelectComponent, selector: "c8y-select", inputs: ["placeholder", "selectedLabel", "applyLabel", "items", "selected", "updateItems", "disableApplyOnNoSelection"], 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" }] });
82
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DashboardAvailabilityComponent, decorators: [{
83
91
  type: Component,
84
- args: [{ selector: 'c8y-dashboard-availability', template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\n</c8y-form-group>\n" }]
85
- }], ctorParameters: function () { return [{ type: i1.UserGroupService }, { type: i2.GainsightService }]; }, propDecorators: { globalRolesIds: [{
92
+ args: [{ selector: 'c8y-dashboard-availability', template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n *ngIf=\"!selectHidden\"\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\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" }]
93
+ }], ctorParameters: function () { return [{ type: i1.UserGroupService }, { type: i2.GainsightService }, { type: i2.Permissions }]; }, propDecorators: { globalRolesIds: [{
86
94
  type: Input
87
95
  }], globalRolesIdsChange: [{
88
96
  type: Output
89
97
  }] } });
90
- //# 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 } 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  private globalRoles: IUserGroup[] = [];\n  private PAGE_SIZE = 100;\n  private _globalRolesIds: DashboardGlobalRoles;\n\n  constructor(\n    private userGroupService: UserGroupService,\n    private gainsightService: GainsightService\n  ) {}\n\n  async ngOnInit() {\n    this.globalRoles = await this.getGlobalRoles();\n    this.globalRolesItems = this.mapGlobalRolesToItems();\n    this.globalRolesItemsSelected = this.getSelectedGlobalRolesItems();\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","<c8y-form-group class=\"p-b-24 m-b-0\">\n  <div class=\"legend form-block\">\n    <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n  </div>\n  <label for=\"availability\">\n    <span class=\"m-r-4\" id=\"availability\">\n      {{ 'Global roles' | translate }}\n    </span>\n    <button\n      class=\"btn-help btn-help--sm\"\n      type=\"button\"\n      [attr.aria-label]=\"'Help' | translate\"\n      popover=\"{{\n        'Select the global roles for which the dashboard will be available' | translate\n      }}\"\n      triggers=\"focus\"\n      placement=\"right\"\n      container=\"body\"\n    >\n    </button>\n  </label>\n  <c8y-select\n    style=\"width: 180px\"\n    [items]=\"globalRolesItems\"\n    [selected]=\"globalRolesItemsSelected\"\n    (onChange)=\"onSelected($event)\"\n  ></c8y-select>\n</c8y-form-group>\n"]}
98
+ //# 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","<c8y-form-group class=\"p-b-24 m-b-0\">\n  <div class=\"legend form-block\">\n    <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n  </div>\n  <label for=\"availability\">\n    <span class=\"m-r-4\" id=\"availability\">\n      {{ 'Global roles' | translate }}\n    </span>\n    <button\n      class=\"btn-help btn-help--sm\"\n      type=\"button\"\n      [attr.aria-label]=\"'Help' | translate\"\n      popover=\"{{\n        'Select the global roles for which the dashboard will be available' | translate\n      }}\"\n      triggers=\"focus\"\n      placement=\"right\"\n      container=\"body\"\n    >\n    </button>\n  </label>\n  <c8y-select\n    *ngIf=\"!selectHidden\"\n    style=\"width: 180px\"\n    [items]=\"globalRolesItems\"\n    [selected]=\"globalRolesItemsSelected\"\n    (onChange)=\"onSelected($event)\"\n  ></c8y-select>\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"]}
@@ -22,7 +22,7 @@ export function c8yValidationConfigFactory(translate) {
22
22
  }
23
23
  },
24
24
  {
25
- name: 'minlength',
25
+ name: 'minLength',
26
26
  message(_error, field) {
27
27
  return translate.stream(ValidationPattern.messages.minLength, field.templateOptions);
28
28
  }
@@ -60,4 +60,4 @@ export function c8yValidationConfigFactory(translate) {
60
60
  ]
61
61
  };
62
62
  }
63
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1jb25maWcuZmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2NvcmUvZHluYW1pYy1mb3Jtcy92YWxpZGF0aW9uL3ZhbGlkYXRpb24tY29uZmlnLmZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbkUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRTdDLE1BQU0sVUFBVSwwQkFBMEIsQ0FBQyxTQUEyQjtJQUNwRSxPQUFPO1FBQ0wsa0JBQWtCLEVBQUU7WUFDbEI7Z0JBQ0UsSUFBSSxFQUFFLFVBQVU7Z0JBQ2hCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDL0QsQ0FBQzthQUNGO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLGFBQWE7Z0JBQ25CLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDO2dCQUNuRCxDQUFDO2FBQ0Y7WUFDRDtnQkFDRSxJQUFJLEVBQUUsU0FBUztnQkFDZixPQUFPLENBQUMsS0FBVSxFQUFFLE1BQXlCO29CQUMzQyxPQUFPLFNBQVMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDckUsQ0FBQzthQUNGO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLFdBQVc7Z0JBQ2pCLE9BQU8sQ0FBQyxNQUFXLEVBQUUsS0FBd0I7b0JBQzNDLE9BQU8sU0FBUyxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztnQkFDdkYsQ0FBQzthQUNGO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLEtBQUs7Z0JBQ1gsT0FBTyxDQUFDLE1BQVcsRUFBRSxLQUF3QjtvQkFDM0MsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO2dCQUNqRixDQUFDO2FBQ0Y7WUFDRDtnQkFDRSxJQUFJLEVBQUUsS0FBSztnQkFDWCxPQUFPLENBQUMsTUFBVyxFQUFFLEtBQXdCO29CQUMzQyxPQUFPLFNBQVMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsZUFBZSxDQUFDLENBQUM7Z0JBQ2pGLENBQUM7YUFDRjtZQUNEO2dCQUNFLElBQUksRUFBRSxpQkFBaUI7Z0JBQ3ZCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUM7Z0JBQzVELENBQUM7YUFDRjtZQUNEO2dCQUNFLElBQUksRUFBRSxvQkFBb0I7Z0JBQzFCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDLENBQUM7Z0JBQ3JGLENBQUM7YUFDRjtZQUNEO2dCQUNFLElBQUksRUFBRSxtQkFBbUI7Z0JBQ3pCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyw2Q0FBNkMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2xGLENBQUM7YUFDRjtTQUNGO0tBQ0YsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgVmFsaWRhdGlvblBhdHRlcm4gfSBmcm9tICcuLi8uLi9mb3Jtcy92YWxpZGF0aW9uLXBhdHRlcm4nO1xuaW1wb3J0IHsgZ2V0dGV4dCB9IGZyb20gJy4uLy4uL2kxOG4vZ2V0dGV4dCc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjOHlWYWxpZGF0aW9uQ29uZmlnRmFjdG9yeSh0cmFuc2xhdGU6IFRyYW5zbGF0ZVNlcnZpY2UpIHtcbiAgcmV0dXJuIHtcbiAgICB2YWxpZGF0aW9uTWVzc2FnZXM6IFtcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ3JlcXVpcmVkJyxcbiAgICAgICAgbWVzc2FnZSgpIHtcbiAgICAgICAgICByZXR1cm4gdHJhbnNsYXRlLnN0cmVhbShWYWxpZGF0aW9uUGF0dGVybi5tZXNzYWdlcy5yZXF1aXJlZCk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIG5hbWU6ICdub3RFeGlzdGluZycsXG4gICAgICAgIG1lc3NhZ2UoKSB7XG4gICAgICAgICAgcmV0dXJuIHRyYW5zbGF0ZS5zdHJlYW0oZ2V0dGV4dCgnTm8gc2VsZWN0aW9uJykpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBuYW1lOiAncGF0dGVybicsXG4gICAgICAgIG1lc3NhZ2UoZXJyb3I6IGFueSwgX2ZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLnBhdHRlcm4sIGVycm9yKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ21pbmxlbmd0aCcsXG4gICAgICAgIG1lc3NhZ2UoX2Vycm9yOiBhbnksIGZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLm1pbkxlbmd0aCwgZmllbGQudGVtcGxhdGVPcHRpb25zKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ21pbicsXG4gICAgICAgIG1lc3NhZ2UoX2Vycm9yOiBhbnksIGZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLm1pbiwgZmllbGQudGVtcGxhdGVPcHRpb25zKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ21heCcsXG4gICAgICAgIG1lc3NhZ2UoX2Vycm9yOiBhbnksIGZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLm1heCwgZmllbGQudGVtcGxhdGVPcHRpb25zKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ2ludmFsaWREYXRlVGltZScsXG4gICAgICAgIG1lc3NhZ2UoKSB7XG4gICAgICAgICAgcmV0dXJuIHRyYW5zbGF0ZS5zdHJlYW0oZ2V0dGV4dCgnVGhpcyBkYXRlIGlzIGludmFsaWQuJykpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBuYW1lOiAnZGF0ZUJlZm9yZVJhbmdlTWluJyxcbiAgICAgICAgbWVzc2FnZSgpIHtcbiAgICAgICAgICByZXR1cm4gdHJhbnNsYXRlLnN0cmVhbShnZXR0ZXh0KCdUaGlzIGRhdGUgaXMgYmVmb3JlIHRoZSBlYXJsaWVzdCBhbGxvd2VkIGRhdGUuJykpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBuYW1lOiAnZGF0ZUFmdGVyUmFuZ2VNYXgnLFxuICAgICAgICBtZXNzYWdlKCkge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKGdldHRleHQoJ1RoaXMgZGF0ZSBpcyBhZnRlciB0aGUgbGF0ZXN0IGFsbG93ZWQgZGF0ZS4nKSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICBdXG4gIH07XG59XG4iXX0=
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1jb25maWcuZmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2NvcmUvZHluYW1pYy1mb3Jtcy92YWxpZGF0aW9uL3ZhbGlkYXRpb24tY29uZmlnLmZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbkUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRTdDLE1BQU0sVUFBVSwwQkFBMEIsQ0FBQyxTQUEyQjtJQUNwRSxPQUFPO1FBQ0wsa0JBQWtCLEVBQUU7WUFDbEI7Z0JBQ0UsSUFBSSxFQUFFLFVBQVU7Z0JBQ2hCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDL0QsQ0FBQzthQUNGO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLGFBQWE7Z0JBQ25CLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDO2dCQUNuRCxDQUFDO2FBQ0Y7WUFDRDtnQkFDRSxJQUFJLEVBQUUsU0FBUztnQkFDZixPQUFPLENBQUMsS0FBVSxFQUFFLE1BQXlCO29CQUMzQyxPQUFPLFNBQVMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDckUsQ0FBQzthQUNGO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLFdBQVc7Z0JBQ2pCLE9BQU8sQ0FBQyxNQUFXLEVBQUUsS0FBd0I7b0JBQzNDLE9BQU8sU0FBUyxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztnQkFDdkYsQ0FBQzthQUNGO1lBQ0Q7Z0JBQ0UsSUFBSSxFQUFFLEtBQUs7Z0JBQ1gsT0FBTyxDQUFDLE1BQVcsRUFBRSxLQUF3QjtvQkFDM0MsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO2dCQUNqRixDQUFDO2FBQ0Y7WUFDRDtnQkFDRSxJQUFJLEVBQUUsS0FBSztnQkFDWCxPQUFPLENBQUMsTUFBVyxFQUFFLEtBQXdCO29CQUMzQyxPQUFPLFNBQVMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsZUFBZSxDQUFDLENBQUM7Z0JBQ2pGLENBQUM7YUFDRjtZQUNEO2dCQUNFLElBQUksRUFBRSxpQkFBaUI7Z0JBQ3ZCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUM7Z0JBQzVELENBQUM7YUFDRjtZQUNEO2dCQUNFLElBQUksRUFBRSxvQkFBb0I7Z0JBQzFCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDLENBQUM7Z0JBQ3JGLENBQUM7YUFDRjtZQUNEO2dCQUNFLElBQUksRUFBRSxtQkFBbUI7Z0JBQ3pCLE9BQU87b0JBQ0wsT0FBTyxTQUFTLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyw2Q0FBNkMsQ0FBQyxDQUFDLENBQUM7Z0JBQ2xGLENBQUM7YUFDRjtTQUNGO0tBQ0YsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgVmFsaWRhdGlvblBhdHRlcm4gfSBmcm9tICcuLi8uLi9mb3Jtcy92YWxpZGF0aW9uLXBhdHRlcm4nO1xuaW1wb3J0IHsgZ2V0dGV4dCB9IGZyb20gJy4uLy4uL2kxOG4vZ2V0dGV4dCc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjOHlWYWxpZGF0aW9uQ29uZmlnRmFjdG9yeSh0cmFuc2xhdGU6IFRyYW5zbGF0ZVNlcnZpY2UpIHtcbiAgcmV0dXJuIHtcbiAgICB2YWxpZGF0aW9uTWVzc2FnZXM6IFtcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ3JlcXVpcmVkJyxcbiAgICAgICAgbWVzc2FnZSgpIHtcbiAgICAgICAgICByZXR1cm4gdHJhbnNsYXRlLnN0cmVhbShWYWxpZGF0aW9uUGF0dGVybi5tZXNzYWdlcy5yZXF1aXJlZCk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIG5hbWU6ICdub3RFeGlzdGluZycsXG4gICAgICAgIG1lc3NhZ2UoKSB7XG4gICAgICAgICAgcmV0dXJuIHRyYW5zbGF0ZS5zdHJlYW0oZ2V0dGV4dCgnTm8gc2VsZWN0aW9uJykpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBuYW1lOiAncGF0dGVybicsXG4gICAgICAgIG1lc3NhZ2UoZXJyb3I6IGFueSwgX2ZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLnBhdHRlcm4sIGVycm9yKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ21pbkxlbmd0aCcsXG4gICAgICAgIG1lc3NhZ2UoX2Vycm9yOiBhbnksIGZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLm1pbkxlbmd0aCwgZmllbGQudGVtcGxhdGVPcHRpb25zKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ21pbicsXG4gICAgICAgIG1lc3NhZ2UoX2Vycm9yOiBhbnksIGZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLm1pbiwgZmllbGQudGVtcGxhdGVPcHRpb25zKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ21heCcsXG4gICAgICAgIG1lc3NhZ2UoX2Vycm9yOiBhbnksIGZpZWxkOiBGb3JtbHlGaWVsZENvbmZpZykge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKFZhbGlkYXRpb25QYXR0ZXJuLm1lc3NhZ2VzLm1heCwgZmllbGQudGVtcGxhdGVPcHRpb25zKTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgbmFtZTogJ2ludmFsaWREYXRlVGltZScsXG4gICAgICAgIG1lc3NhZ2UoKSB7XG4gICAgICAgICAgcmV0dXJuIHRyYW5zbGF0ZS5zdHJlYW0oZ2V0dGV4dCgnVGhpcyBkYXRlIGlzIGludmFsaWQuJykpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBuYW1lOiAnZGF0ZUJlZm9yZVJhbmdlTWluJyxcbiAgICAgICAgbWVzc2FnZSgpIHtcbiAgICAgICAgICByZXR1cm4gdHJhbnNsYXRlLnN0cmVhbShnZXR0ZXh0KCdUaGlzIGRhdGUgaXMgYmVmb3JlIHRoZSBlYXJsaWVzdCBhbGxvd2VkIGRhdGUuJykpO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBuYW1lOiAnZGF0ZUFmdGVyUmFuZ2VNYXgnLFxuICAgICAgICBtZXNzYWdlKCkge1xuICAgICAgICAgIHJldHVybiB0cmFuc2xhdGUuc3RyZWFtKGdldHRleHQoJ1RoaXMgZGF0ZSBpcyBhZnRlciB0aGUgbGF0ZXN0IGFsbG93ZWQgZGF0ZS4nKSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICBdXG4gIH07XG59XG4iXX0=
@@ -743,12 +743,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImpor
743
743
  }] } });
744
744
 
745
745
  class DashboardAvailabilityComponent {
746
- constructor(userGroupService, gainsightService) {
746
+ constructor(userGroupService, gainsightService, permissions) {
747
747
  this.userGroupService = userGroupService;
748
748
  this.gainsightService = gainsightService;
749
+ this.permissions = permissions;
749
750
  this.globalRolesIdsChange = new EventEmitter();
750
751
  this.globalRolesItems = [];
751
752
  this.globalRolesItemsSelected = [];
753
+ this.selectHidden = false;
752
754
  this.globalRoles = [];
753
755
  this.PAGE_SIZE = 100;
754
756
  }
@@ -768,9 +770,14 @@ class DashboardAvailabilityComponent {
768
770
  }
769
771
  ngOnInit() {
770
772
  return __awaiter(this, void 0, void 0, function* () {
771
- this.globalRoles = yield this.getGlobalRoles();
772
- this.globalRolesItems = this.mapGlobalRolesToItems();
773
- this.globalRolesItemsSelected = this.getSelectedGlobalRolesItems();
773
+ if (this.permissions.hasRole(Permissions.ROLE_USER_MANAGEMENT_READ)) {
774
+ this.globalRoles = yield this.getGlobalRoles();
775
+ this.globalRolesItems = this.mapGlobalRolesToItems();
776
+ this.globalRolesItemsSelected = this.getSelectedGlobalRolesItems();
777
+ }
778
+ else {
779
+ this.selectHidden = true;
780
+ }
774
781
  });
775
782
  }
776
783
  onSelected(items) {
@@ -818,12 +825,12 @@ class DashboardAvailabilityComponent {
818
825
  .filter(Boolean);
819
826
  }
820
827
  }
821
- DashboardAvailabilityComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DashboardAvailabilityComponent, deps: [{ token: i1.UserGroupService }, { token: i5.GainsightService }], target: i0.ɵɵFactoryTarget.Component });
822
- DashboardAvailabilityComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: DashboardAvailabilityComponent, selector: "c8y-dashboard-availability", inputs: { globalRolesIds: "globalRolesIds" }, outputs: { globalRolesIdsChange: "globalRolesIdsChange" }, ngImport: i0, template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\n</c8y-form-group>\n", dependencies: [{ kind: "component", type: i5.SelectComponent, selector: "c8y-select", inputs: ["placeholder", "selectedLabel", "applyLabel", "items", "selected", "updateItems", "disableApplyOnNoSelection"], outputs: ["onChange"] }, { kind: "component", type: i5.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: i5.C8yTranslatePipe, name: "translate" }] });
828
+ DashboardAvailabilityComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DashboardAvailabilityComponent, deps: [{ token: i1.UserGroupService }, { token: i5.GainsightService }, { token: i5.Permissions }], target: i0.ɵɵFactoryTarget.Component });
829
+ DashboardAvailabilityComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: DashboardAvailabilityComponent, selector: "c8y-dashboard-availability", inputs: { globalRolesIds: "globalRolesIds" }, outputs: { globalRolesIdsChange: "globalRolesIdsChange" }, ngImport: i0, template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n *ngIf=\"!selectHidden\"\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\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", dependencies: [{ kind: "directive", type: i5$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.SelectComponent, selector: "c8y-select", inputs: ["placeholder", "selectedLabel", "applyLabel", "items", "selected", "updateItems", "disableApplyOnNoSelection"], outputs: ["onChange"] }, { kind: "component", type: i5.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: i5.C8yTranslatePipe, name: "translate" }] });
823
830
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DashboardAvailabilityComponent, decorators: [{
824
831
  type: Component,
825
- args: [{ selector: 'c8y-dashboard-availability', template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\n</c8y-form-group>\n" }]
826
- }], ctorParameters: function () { return [{ type: i1.UserGroupService }, { type: i5.GainsightService }]; }, propDecorators: { globalRolesIds: [{
832
+ args: [{ selector: 'c8y-dashboard-availability', template: "<c8y-form-group class=\"p-b-24 m-b-0\">\n <div class=\"legend form-block\">\n <span>{{ 'Availability`of dashboard based on permissions`' | translate }}</span>\n </div>\n <label for=\"availability\">\n <span class=\"m-r-4\" id=\"availability\">\n {{ 'Global roles' | translate }}\n </span>\n <button\n class=\"btn-help btn-help--sm\"\n type=\"button\"\n [attr.aria-label]=\"'Help' | translate\"\n popover=\"{{\n 'Select the global roles for which the dashboard will be available' | translate\n }}\"\n triggers=\"focus\"\n placement=\"right\"\n container=\"body\"\n >\n </button>\n </label>\n <c8y-select\n *ngIf=\"!selectHidden\"\n style=\"width: 180px\"\n [items]=\"globalRolesItems\"\n [selected]=\"globalRolesItemsSelected\"\n (onChange)=\"onSelected($event)\"\n ></c8y-select>\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" }]
833
+ }], ctorParameters: function () { return [{ type: i1.UserGroupService }, { type: i5.GainsightService }, { type: i5.Permissions }]; }, propDecorators: { globalRolesIds: [{
827
834
  type: Input
828
835
  }], globalRolesIdsChange: [{
829
836
  type: Output