@c8y/ngx-components 1018.503.117 → 1018.503.118

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.
Files changed (34) hide show
  1. package/esm2020/core/navigator/navigator-node.component.mjs +7 -2
  2. package/esm2020/sub-assets/add-group/add-group.module.mjs +4 -16
  3. package/esm2020/sub-assets/groups.component.mjs +47 -9
  4. package/esm2020/sub-assets/sub-assets.component.mjs +42 -12
  5. package/esm2020/widgets/implementations/cockpit-welcome/welcome.component.mjs +11 -5
  6. package/esm2020/widgets/implementations/device-management-welcome/welcome.component.mjs +5 -4
  7. package/esm2020/widgets/implementations/help-and-service-widget/help-and-service-view/help-and-service-view.component.mjs +49 -11
  8. package/fesm2015/c8y-ngx-components-sub-assets.mjs +99 -49
  9. package/fesm2015/c8y-ngx-components-sub-assets.mjs.map +1 -1
  10. package/fesm2015/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs +10 -4
  11. package/fesm2015/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs.map +1 -1
  12. package/fesm2015/c8y-ngx-components-widgets-implementations-device-management-welcome.mjs +4 -3
  13. package/fesm2015/c8y-ngx-components-widgets-implementations-device-management-welcome.mjs.map +1 -1
  14. package/fesm2015/c8y-ngx-components-widgets-implementations-help-and-service-widget.mjs +43 -8
  15. package/fesm2015/c8y-ngx-components-widgets-implementations-help-and-service-widget.mjs.map +1 -1
  16. package/fesm2015/c8y-ngx-components.mjs +6 -1
  17. package/fesm2015/c8y-ngx-components.mjs.map +1 -1
  18. package/fesm2020/c8y-ngx-components-sub-assets.mjs +112 -62
  19. package/fesm2020/c8y-ngx-components-sub-assets.mjs.map +1 -1
  20. package/fesm2020/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs +10 -4
  21. package/fesm2020/c8y-ngx-components-widgets-implementations-cockpit-welcome.mjs.map +1 -1
  22. package/fesm2020/c8y-ngx-components-widgets-implementations-device-management-welcome.mjs +4 -3
  23. package/fesm2020/c8y-ngx-components-widgets-implementations-device-management-welcome.mjs.map +1 -1
  24. package/fesm2020/c8y-ngx-components-widgets-implementations-help-and-service-widget.mjs +45 -8
  25. package/fesm2020/c8y-ngx-components-widgets-implementations-help-and-service-widget.mjs.map +1 -1
  26. package/fesm2020/c8y-ngx-components.mjs +6 -1
  27. package/fesm2020/c8y-ngx-components.mjs.map +1 -1
  28. package/locales/fr.po +22 -22
  29. package/locales/ko.po +1 -1
  30. package/locales/pt_BR.po +2 -2
  31. package/package.json +1 -1
  32. package/sub-assets/groups.component.d.ts +16 -2
  33. package/sub-assets/sub-assets.component.d.ts +14 -3
  34. package/widgets/implementations/help-and-service-widget/help-and-service-view/help-and-service-view.component.d.ts +10 -3
@@ -41,7 +41,12 @@ export class NavigatorNodeComponent {
41
41
  if (isUndefined(this.node.path)) {
42
42
  return false;
43
43
  }
44
- return this.router.isActive(this.node.path, this.node.routerLinkExact);
44
+ return this.router.isActive(this.node.path, {
45
+ paths: this.node.routerLinkExact ? 'exact' : 'subset',
46
+ queryParams: 'ignored',
47
+ fragment: 'ignored',
48
+ matrixParams: 'ignored'
49
+ });
45
50
  }), distinctUntilChanged(), tap(isActive => {
46
51
  if (isActive) {
47
52
  this.expandCollapse(true);
@@ -185,4 +190,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
185
190
  type: ViewChild,
186
191
  args: [PopoverConfirmComponent, { static: false }]
187
192
  }] } });
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigator-node.component.js","sourceRoot":"","sources":["../../../../core/navigator/navigator-node.component.ts","../../../../core/navigator/navigator-node.component.html"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable-next-line:max-line-length\nimport {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { ActivationEnd, Router } from '@angular/router';\nimport { Subject, merge } from 'rxjs';\nimport { distinctUntilChanged, filter, map, tap } from 'rxjs/operators';\nimport { PopoverConfirmComponent } from '../modal/popover-confirm.component';\nimport { NavigatorIconComponent } from './navigator-icon.component';\nimport { ClickOptions, NavigatorNode } from './navigator-node';\nimport { isUndefined } from 'lodash-es';\n\nexport const enum ClickEventSource {\n  ICON = 'icon',\n  EXPANDER = 'expander',\n  LINK = 'link'\n}\n\n/**\n * Navigator node renderer.\n */\n@Component({\n  selector: 'c8y-navigator-node',\n  templateUrl: './navigator-node.component.html'\n})\nexport class NavigatorNodeComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @ignore\n   */\n  @ViewChild('icon', { read: ViewContainerRef, static: false }) iconSlot: ViewContainerRef;\n\n  /**\n   * Navigator node.\n   */\n  @Input() node: NavigatorNode;\n\n  /**\n   * Determines whether the navigator node is a root node (top node in the hierarchy).\n   */\n  @Input() isRoot: boolean;\n\n  /**\n   * Event emitter responsible for broadcasting one of the following events: \"icon\", \"expander\" or \"link\" as string value.\n   *\n   * The type of event depends on where you click on the navigator node:\n   * * clicking the icon will broadcast the event \"icon\",\n   * * clicking the expander will broadcast the event \"expander\",\n   * * clicking the label will broadcast the event \"link\".\n   */\n  @Output() nodeClick: EventEmitter<string> = new EventEmitter();\n\n  /**\n   * @ignore\n   */\n  @ViewChild(PopoverConfirmComponent, { static: false }) confirm: PopoverConfirmComponent;\n\n  private viewInitTimeout;\n\n  /**\n   * A subject that is triggered as soon as the navigator node is initialized.\n   */\n  nodeInit$ = new Subject<void>();\n\n  /**\n   * A observable which emits, as soon as the active state of the node changes.\n   */\n  isActive$ = merge(\n    this.nodeInit$,\n    this.router.events.pipe(filter(e => e instanceof ActivationEnd))\n  ).pipe(\n    map(() => {\n      if (isUndefined(this.node.path)) {\n        return false;\n      }\n      return this.router.isActive(this.node.path, this.node.routerLinkExact);\n    }),\n    distinctUntilChanged(),\n    tap(isActive => {\n      if (isActive) {\n        this.expandCollapse(true);\n        this.expandRecursiveParent(this.node.parents);\n      }\n    })\n  );\n\n  constructor(private router: Router) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (\n      changes.node &&\n      !changes.node.firstChange &&\n      changes.node.previousValue.icon !== changes.node.currentValue.icon\n    ) {\n      this.updateIcon();\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  ngAfterViewInit() {\n    if (!this.node.component) {\n      this.viewInitTimeout = setTimeout(() => {\n        this.updateIcon();\n        this.node.confirm = this.confirm;\n        this.nodeInit$.next();\n      });\n    }\n  }\n\n  /**\n   * Returns the expander title.\n   */\n  get expandTitle() {\n    return !this.node.open ? 'Expand' : 'Collapse';\n  }\n\n  /**\n   * Click event handler.\n   *\n   * @param {string} from Source of the click event.\n   * @param event DOM event.\n   */\n  click(from: 'icon' | 'expander' | 'link' = 'link', $event?: MouseEvent) {\n    let open: boolean;\n    switch (from) {\n      case ClickEventSource.EXPANDER:\n        if ($event) {\n          $event.preventDefault();\n          $event.stopPropagation();\n        }\n        open = !this.node.open;\n        break;\n      case ClickEventSource.ICON:\n      case ClickEventSource.LINK:\n        open = this.router.isActive(this.node.path, this.node.routerLinkExact)\n          ? true\n          : !this.node.open;\n        break;\n    }\n    this.handleExpandCollapse(open, from, $event);\n    this.nodeClick.emit(from);\n  }\n\n  /**\n   * Expands or collapses the navigator node and its children recursively.\n   *\n   * @param {boolean} open Open or close the node.\n   * @param {ClickOptions} forNode Click options.\n   */\n  expandCollapse(open, forNode: ClickOptions = {}) {\n    this.node.open = open;\n    forNode.open = open;\n    this.node.click(forNode);\n  }\n\n  /**\n   * @ignore\n   */\n  ngOnDestroy(): void {\n    clearTimeout(this.viewInitTimeout);\n\n    if (this.node) {\n      this.node.destroy();\n    }\n  }\n\n  /**\n   * Expands the parent nodes recursively.\n   * @param nodes The nodes that should be tried to get opened.\n   * @param clickOption The click options to perform on the parent nodes.\n   */\n  expandRecursiveParent(nodes: NavigatorNode[], clickOption: ClickOptions = { expander: true }) {\n    nodes.forEach(parentNode => {\n      if (!parentNode.open) {\n        parentNode.open = true;\n        parentNode.click(clickOption);\n      }\n      this.expandRecursiveParent(parentNode.parents, clickOption);\n    });\n  }\n\n  private handleExpandCollapse(open, from, $event) {\n    if (\n      open === this.node.open ||\n      (this.node.path && !open && from !== ClickEventSource.EXPANDER)\n    ) {\n      return;\n    }\n    this.expandCollapse(open, { [from]: true, $event });\n  }\n\n  private updateIcon() {\n    if (this.node.iconTemplate) {\n      this.updateIconTemplate();\n    } else {\n      this.updateIconComponent();\n    }\n  }\n\n  private updateIconComponent() {\n    let componentType = NavigatorIconComponent;\n    if (this.node && this.node.iconComponent) {\n      componentType = this.node.iconComponent;\n    }\n    this.iconSlot.clear();\n    const componentRef = this.iconSlot.createComponent(componentType, {\n      injector: this.node.injector\n    });\n    componentRef.instance.node = this.node;\n  }\n\n  private updateIconTemplate() {\n    this.iconSlot.clear();\n    this.iconSlot.createEmbeddedView(this.node.iconTemplate, undefined, {\n      injector: this.node.injector\n    });\n  }\n}\n","<ng-container *ngIf=\"node.component\">\n  <ng-container *c8yComponentOutlet=\"node.component; environmentInjector: node.injector\"></ng-container>\n</ng-container>\n\n<div\n  class=\"slot\"\n  *ngIf=\"!node.component\"\n  [hidden]=\"node.hidden\"\n  (dragstart)=\"node.dragStart($event)\"\n  (dragend)=\"node.dragEnd($event)\"\n  (drop)=\"node.drop($event)\"\n  [draggable]=\"node.draggable\"\n  [ngClass]=\"{ dragged: node.dragged, disabled: node.loading }\"\n>\n  <ng-container>\n    <div\n      class=\"link\"\n      tabindex=\"-1\"\n      [routerLink]=\"node.canNavigate ? node.path : undefined\"\n      [ngClass]=\"{\n        active: isActive$ | async,\n        'dragged-hover': node.draggedHover && !node.dragged\n      }\"\n      (dragover)=\"node.canDrop && $event.preventDefault()\"\n      (dragenter)=\"node.canDrop && node.dragEnter($event)\"\n      (dragleave)=\"node.canDrop && node.dragLeave($event)\"\n    >\n      <ng-container *ngTemplateOutlet=\"navicon\"></ng-container>\n      <button\n        class=\"btn-clean\"\n        title=\"{{ node.translateLabel ? (node.label | translate) : node.label }}\"\n        [attr.aria-expanded]=\"node.hasChildren ? node.open : null\"\n        type=\"button\"\n        draggable=\"false\"\n        [attr.data-cy]=\"node.label\"\n        [attr.id]=\"isRoot ? node.id : undefined\"\n        (click)=\"click(node.canNavigate ? 'link' : 'expander', $event)\"\n        [ngClass]=\"{\n          'root-link': isRoot,\n          open: node.open && node.hasChildren,\n          parent: node.hasChildren\n        }\"\n      >\n        <ng-container *ngTemplateOutlet=\"inner\"></ng-container>\n      </button>\n    </div>\n  </ng-container>\n\n  <div\n    class=\"children panel-expand expand\"\n    *ngIf=\"node.children.length\"\n    [collapse]=\"!node.open\"\n    [isAnimated]=\"true\"\n  >\n    <c8y-navigator-node\n      *ngFor=\"let childNode of node.children\"\n      [node]=\"childNode\"\n      (nodeClick)=\"nodeClick.emit($event)\"\n    ></c8y-navigator-node>\n  </div>\n</div>\n\n<!-- icon -->\n<ng-template #navicon>\n  <!-- loader -->\n  <i\n    class=\"icon-spin loadingIndicator\"\n    [c8yIcon]=\"'circle-o-notch'\"\n    style=\"{{ isRoot ? 'padding-left: 16px;' : null }}\"\n    *ngIf=\"node.loading && !isRoot\"\n  ></i>\n  <ng-container #icon></ng-container>\n</ng-template>\n\n<ng-template #inner>\n  <!--title  -->\n  <span>{{ node.translateLabel ? (node.label | translate) : node.label }}</span>\n\n  <!--expander  -->\n  <i\n    class=\"expander\"\n    [c8yIcon]=\"'chevron-down'\"\n    [attr.aria-label]=\"expandTitle\"\n    role=\"button\"\n    *ngIf=\"node.hasChildren\"\n    (click)=\"click('expander', $event)\"\n    data-cy=\"c8y-navigator-node--expander\"\n  ></i>\n\n  <!--  Popover confirm  -->\n  <c8y-popover-confirm\n    triggers=\"focus\"\n    containerClass=\"navigator-popover\"\n  ></c8y-popover-confirm>\n</ng-template>\n"]}
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigator-node.component.js","sourceRoot":"","sources":["../../../../core/navigator/navigator-node.component.ts","../../../../core/navigator/navigator-node.component.html"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable-next-line:max-line-length\nimport {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { ActivationEnd, IsActiveMatchOptions, Router } from '@angular/router';\nimport { Subject, merge } from 'rxjs';\nimport { distinctUntilChanged, filter, map, tap } from 'rxjs/operators';\nimport { PopoverConfirmComponent } from '../modal/popover-confirm.component';\nimport { NavigatorIconComponent } from './navigator-icon.component';\nimport { ClickOptions, NavigatorNode } from './navigator-node';\nimport { isUndefined } from 'lodash-es';\n\nexport const enum ClickEventSource {\n  ICON = 'icon',\n  EXPANDER = 'expander',\n  LINK = 'link'\n}\n\n/**\n * Navigator node renderer.\n */\n@Component({\n  selector: 'c8y-navigator-node',\n  templateUrl: './navigator-node.component.html'\n})\nexport class NavigatorNodeComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @ignore\n   */\n  @ViewChild('icon', { read: ViewContainerRef, static: false }) iconSlot: ViewContainerRef;\n\n  /**\n   * Navigator node.\n   */\n  @Input() node: NavigatorNode;\n\n  /**\n   * Determines whether the navigator node is a root node (top node in the hierarchy).\n   */\n  @Input() isRoot: boolean;\n\n  /**\n   * Event emitter responsible for broadcasting one of the following events: \"icon\", \"expander\" or \"link\" as string value.\n   *\n   * The type of event depends on where you click on the navigator node:\n   * * clicking the icon will broadcast the event \"icon\",\n   * * clicking the expander will broadcast the event \"expander\",\n   * * clicking the label will broadcast the event \"link\".\n   */\n  @Output() nodeClick: EventEmitter<string> = new EventEmitter();\n\n  /**\n   * @ignore\n   */\n  @ViewChild(PopoverConfirmComponent, { static: false }) confirm: PopoverConfirmComponent;\n\n  private viewInitTimeout;\n\n  /**\n   * A subject that is triggered as soon as the navigator node is initialized.\n   */\n  nodeInit$ = new Subject<void>();\n\n  /**\n   * A observable which emits, as soon as the active state of the node changes.\n   */\n  isActive$ = merge(\n    this.nodeInit$,\n    this.router.events.pipe(filter(e => e instanceof ActivationEnd))\n  ).pipe(\n    map(() => {\n      if (isUndefined(this.node.path)) {\n        return false;\n      }\n      return this.router.isActive(this.node.path, {\n        paths: this.node.routerLinkExact ? 'exact' : 'subset',\n        queryParams: 'ignored',\n        fragment: 'ignored',\n        matrixParams: 'ignored'\n      } as IsActiveMatchOptions);\n    }),\n    distinctUntilChanged(),\n    tap(isActive => {\n      if (isActive) {\n        this.expandCollapse(true);\n        this.expandRecursiveParent(this.node.parents);\n      }\n    })\n  );\n\n  constructor(private router: Router) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (\n      changes.node &&\n      !changes.node.firstChange &&\n      changes.node.previousValue.icon !== changes.node.currentValue.icon\n    ) {\n      this.updateIcon();\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  ngAfterViewInit() {\n    if (!this.node.component) {\n      this.viewInitTimeout = setTimeout(() => {\n        this.updateIcon();\n        this.node.confirm = this.confirm;\n        this.nodeInit$.next();\n      });\n    }\n  }\n\n  /**\n   * Returns the expander title.\n   */\n  get expandTitle() {\n    return !this.node.open ? 'Expand' : 'Collapse';\n  }\n\n  /**\n   * Click event handler.\n   *\n   * @param {string} from Source of the click event.\n   * @param event DOM event.\n   */\n  click(from: 'icon' | 'expander' | 'link' = 'link', $event?: MouseEvent) {\n    let open: boolean;\n    switch (from) {\n      case ClickEventSource.EXPANDER:\n        if ($event) {\n          $event.preventDefault();\n          $event.stopPropagation();\n        }\n        open = !this.node.open;\n        break;\n      case ClickEventSource.ICON:\n      case ClickEventSource.LINK:\n        open = this.router.isActive(this.node.path, this.node.routerLinkExact)\n          ? true\n          : !this.node.open;\n        break;\n    }\n    this.handleExpandCollapse(open, from, $event);\n    this.nodeClick.emit(from);\n  }\n\n  /**\n   * Expands or collapses the navigator node and its children recursively.\n   *\n   * @param {boolean} open Open or close the node.\n   * @param {ClickOptions} forNode Click options.\n   */\n  expandCollapse(open, forNode: ClickOptions = {}) {\n    this.node.open = open;\n    forNode.open = open;\n    this.node.click(forNode);\n  }\n\n  /**\n   * @ignore\n   */\n  ngOnDestroy(): void {\n    clearTimeout(this.viewInitTimeout);\n\n    if (this.node) {\n      this.node.destroy();\n    }\n  }\n\n  /**\n   * Expands the parent nodes recursively.\n   * @param nodes The nodes that should be tried to get opened.\n   * @param clickOption The click options to perform on the parent nodes.\n   */\n  expandRecursiveParent(nodes: NavigatorNode[], clickOption: ClickOptions = { expander: true }) {\n    nodes.forEach(parentNode => {\n      if (!parentNode.open) {\n        parentNode.open = true;\n        parentNode.click(clickOption);\n      }\n      this.expandRecursiveParent(parentNode.parents, clickOption);\n    });\n  }\n\n  private handleExpandCollapse(open, from, $event) {\n    if (\n      open === this.node.open ||\n      (this.node.path && !open && from !== ClickEventSource.EXPANDER)\n    ) {\n      return;\n    }\n    this.expandCollapse(open, { [from]: true, $event });\n  }\n\n  private updateIcon() {\n    if (this.node.iconTemplate) {\n      this.updateIconTemplate();\n    } else {\n      this.updateIconComponent();\n    }\n  }\n\n  private updateIconComponent() {\n    let componentType = NavigatorIconComponent;\n    if (this.node && this.node.iconComponent) {\n      componentType = this.node.iconComponent;\n    }\n    this.iconSlot.clear();\n    const componentRef = this.iconSlot.createComponent(componentType, {\n      injector: this.node.injector\n    });\n    componentRef.instance.node = this.node;\n  }\n\n  private updateIconTemplate() {\n    this.iconSlot.clear();\n    this.iconSlot.createEmbeddedView(this.node.iconTemplate, undefined, {\n      injector: this.node.injector\n    });\n  }\n}\n","<ng-container *ngIf=\"node.component\">\n  <ng-container *c8yComponentOutlet=\"node.component; environmentInjector: node.injector\"></ng-container>\n</ng-container>\n\n<div\n  class=\"slot\"\n  *ngIf=\"!node.component\"\n  [hidden]=\"node.hidden\"\n  (dragstart)=\"node.dragStart($event)\"\n  (dragend)=\"node.dragEnd($event)\"\n  (drop)=\"node.drop($event)\"\n  [draggable]=\"node.draggable\"\n  [ngClass]=\"{ dragged: node.dragged, disabled: node.loading }\"\n>\n  <ng-container>\n    <div\n      class=\"link\"\n      tabindex=\"-1\"\n      [routerLink]=\"node.canNavigate ? node.path : undefined\"\n      [ngClass]=\"{\n        active: isActive$ | async,\n        'dragged-hover': node.draggedHover && !node.dragged\n      }\"\n      (dragover)=\"node.canDrop && $event.preventDefault()\"\n      (dragenter)=\"node.canDrop && node.dragEnter($event)\"\n      (dragleave)=\"node.canDrop && node.dragLeave($event)\"\n    >\n      <ng-container *ngTemplateOutlet=\"navicon\"></ng-container>\n      <button\n        class=\"btn-clean\"\n        title=\"{{ node.translateLabel ? (node.label | translate) : node.label }}\"\n        [attr.aria-expanded]=\"node.hasChildren ? node.open : null\"\n        type=\"button\"\n        draggable=\"false\"\n        [attr.data-cy]=\"node.label\"\n        [attr.id]=\"isRoot ? node.id : undefined\"\n        (click)=\"click(node.canNavigate ? 'link' : 'expander', $event)\"\n        [ngClass]=\"{\n          'root-link': isRoot,\n          open: node.open && node.hasChildren,\n          parent: node.hasChildren\n        }\"\n      >\n        <ng-container *ngTemplateOutlet=\"inner\"></ng-container>\n      </button>\n    </div>\n  </ng-container>\n\n  <div\n    class=\"children panel-expand expand\"\n    *ngIf=\"node.children.length\"\n    [collapse]=\"!node.open\"\n    [isAnimated]=\"true\"\n  >\n    <c8y-navigator-node\n      *ngFor=\"let childNode of node.children\"\n      [node]=\"childNode\"\n      (nodeClick)=\"nodeClick.emit($event)\"\n    ></c8y-navigator-node>\n  </div>\n</div>\n\n<!-- icon -->\n<ng-template #navicon>\n  <!-- loader -->\n  <i\n    class=\"icon-spin loadingIndicator\"\n    [c8yIcon]=\"'circle-o-notch'\"\n    style=\"{{ isRoot ? 'padding-left: 16px;' : null }}\"\n    *ngIf=\"node.loading && !isRoot\"\n  ></i>\n  <ng-container #icon></ng-container>\n</ng-template>\n\n<ng-template #inner>\n  <!--title  -->\n  <span>{{ node.translateLabel ? (node.label | translate) : node.label }}</span>\n\n  <!--expander  -->\n  <i\n    class=\"expander\"\n    [c8yIcon]=\"'chevron-down'\"\n    [attr.aria-label]=\"expandTitle\"\n    role=\"button\"\n    *ngIf=\"node.hasChildren\"\n    (click)=\"click('expander', $event)\"\n    data-cy=\"c8y-navigator-node--expander\"\n  ></i>\n\n  <!--  Popover confirm  -->\n  <c8y-popover-confirm\n    triggers=\"focus\"\n    containerClass=\"navigator-popover\"\n  ></c8y-popover-confirm>\n</ng-template>\n"]}
@@ -1,5 +1,5 @@
1
1
  import { NgModule } from '@angular/core';
2
- import { CoreModule, hookRoute } from '@c8y/ngx-components';
2
+ import { CoreModule } from '@c8y/ngx-components';
3
3
  import { DeviceGridModule } from '@c8y/ngx-components/device-grid';
4
4
  import { AddGroupComponent } from './add-group.component';
5
5
  import { AddGroupService } from './add-group.service';
@@ -9,13 +9,7 @@ export class AddGroupModule {
9
9
  }
10
10
  AddGroupModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: AddGroupModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
11
  AddGroupModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: AddGroupModule, declarations: [AddGroupComponent], imports: [CoreModule, DeviceGridModule, FormsModule, ReactiveFormsModule], exports: [AddGroupComponent] });
12
- AddGroupModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: AddGroupModule, providers: [
13
- hookRoute({
14
- path: 'add-group',
15
- component: AddGroupComponent
16
- }),
17
- AddGroupService
18
- ], imports: [CoreModule, DeviceGridModule, FormsModule, ReactiveFormsModule] });
12
+ AddGroupModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: AddGroupModule, providers: [AddGroupService], imports: [CoreModule, DeviceGridModule, FormsModule, ReactiveFormsModule] });
19
13
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: AddGroupModule, decorators: [{
20
14
  type: NgModule,
21
15
  args: [{
@@ -23,13 +17,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
23
17
  imports: [CoreModule, DeviceGridModule, FormsModule, ReactiveFormsModule],
24
18
  entryComponents: [AddGroupComponent],
25
19
  exports: [AddGroupComponent],
26
- providers: [
27
- hookRoute({
28
- path: 'add-group',
29
- component: AddGroupComponent
30
- }),
31
- AddGroupService
32
- ]
20
+ providers: [AddGroupService]
33
21
  }]
34
22
  }] });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLWdyb3VwLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3N1Yi1hc3NldHMvYWRkLWdyb3VwL2FkZC1ncm91cC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzVELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7O0FBZWxFLE1BQU0sT0FBTyxjQUFjOzsyR0FBZCxjQUFjOzRHQUFkLGNBQWMsaUJBWlYsaUJBQWlCLGFBQ3RCLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsbUJBQW1CLGFBRTlELGlCQUFpQjs0R0FTaEIsY0FBYyxhQVJkO1FBQ1QsU0FBUyxDQUFDO1lBQ1IsSUFBSSxFQUFFLFdBQVc7WUFDakIsU0FBUyxFQUFFLGlCQUFpQjtTQUM3QixDQUFDO1FBQ0YsZUFBZTtLQUNoQixZQVRTLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsbUJBQW1COzJGQVc3RCxjQUFjO2tCQWIxQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGlCQUFpQixDQUFDO29CQUNqQyxPQUFPLEVBQUUsQ0FBQyxVQUFVLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixDQUFDO29CQUN6RSxlQUFlLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7b0JBQzVCLFNBQVMsRUFBRTt3QkFDVCxTQUFTLENBQUM7NEJBQ1IsSUFBSSxFQUFFLFdBQVc7NEJBQ2pCLFNBQVMsRUFBRSxpQkFBaUI7eUJBQzdCLENBQUM7d0JBQ0YsZUFBZTtxQkFDaEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29yZU1vZHVsZSwgaG9va1JvdXRlIH0gZnJvbSAnQGM4eS9uZ3gtY29tcG9uZW50cyc7XG5pbXBvcnQgeyBEZXZpY2VHcmlkTW9kdWxlIH0gZnJvbSAnQGM4eS9uZ3gtY29tcG9uZW50cy9kZXZpY2UtZ3JpZCc7XG5pbXBvcnQgeyBBZGRHcm91cENvbXBvbmVudCB9IGZyb20gJy4vYWRkLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBZGRHcm91cFNlcnZpY2UgfSBmcm9tICcuL2FkZC1ncm91cC5zZXJ2aWNlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtBZGRHcm91cENvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb3JlTW9kdWxlLCBEZXZpY2VHcmlkTW9kdWxlLCBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZV0sXG4gIGVudHJ5Q29tcG9uZW50czogW0FkZEdyb3VwQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0FkZEdyb3VwQ29tcG9uZW50XSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgaG9va1JvdXRlKHtcbiAgICAgIHBhdGg6ICdhZGQtZ3JvdXAnLFxuICAgICAgY29tcG9uZW50OiBBZGRHcm91cENvbXBvbmVudFxuICAgIH0pLFxuICAgIEFkZEdyb3VwU2VydmljZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEFkZEdyb3VwTW9kdWxlIHt9XG4iXX0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLWdyb3VwLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3N1Yi1hc3NldHMvYWRkLWdyb3VwL2FkZC1ncm91cC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFTbEUsTUFBTSxPQUFPLGNBQWM7OzJHQUFkLGNBQWM7NEdBQWQsY0FBYyxpQkFOVixpQkFBaUIsYUFDdEIsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFdBQVcsRUFBRSxtQkFBbUIsYUFFOUQsaUJBQWlCOzRHQUdoQixjQUFjLGFBRmQsQ0FBQyxlQUFlLENBQUMsWUFIbEIsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFdBQVcsRUFBRSxtQkFBbUI7MkZBSzdELGNBQWM7a0JBUDFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsaUJBQWlCLENBQUM7b0JBQ2pDLE9BQU8sRUFBRSxDQUFDLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsbUJBQW1CLENBQUM7b0JBQ3pFLGVBQWUsRUFBRSxDQUFDLGlCQUFpQixDQUFDO29CQUNwQyxPQUFPLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztvQkFDNUIsU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDO2lCQUM3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb3JlTW9kdWxlIH0gZnJvbSAnQGM4eS9uZ3gtY29tcG9uZW50cyc7XG5pbXBvcnQgeyBEZXZpY2VHcmlkTW9kdWxlIH0gZnJvbSAnQGM4eS9uZ3gtY29tcG9uZW50cy9kZXZpY2UtZ3JpZCc7XG5pbXBvcnQgeyBBZGRHcm91cENvbXBvbmVudCB9IGZyb20gJy4vYWRkLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBZGRHcm91cFNlcnZpY2UgfSBmcm9tICcuL2FkZC1ncm91cC5zZXJ2aWNlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtBZGRHcm91cENvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb3JlTW9kdWxlLCBEZXZpY2VHcmlkTW9kdWxlLCBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZV0sXG4gIGVudHJ5Q29tcG9uZW50czogW0FkZEdyb3VwQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0FkZEdyb3VwQ29tcG9uZW50XSxcbiAgcHJvdmlkZXJzOiBbQWRkR3JvdXBTZXJ2aWNlXVxufSlcbmV4cG9ydCBjbGFzcyBBZGRHcm91cE1vZHVsZSB7fVxuIl19
@@ -2,23 +2,31 @@ import { Component, EventEmitter, Inject } from '@angular/core';
2
2
  import { Permissions } from '@c8y/ngx-components';
3
3
  import { SUB_ASSETS_CONFIG } from './sub-assets.model';
4
4
  import { SubAssetsService } from './sub-assets.service';
5
+ import { Subject } from 'rxjs';
6
+ import { ActivatedRoute, Router } from '@angular/router';
7
+ import { delay, takeUntil, tap } from 'rxjs/operators';
5
8
  import * as i0 from "@angular/core";
6
9
  import * as i1 from "@c8y/ngx-components";
7
10
  import * as i2 from "./sub-assets.service";
8
- import * as i3 from "@angular/common";
9
- import * as i4 from "./add-group/add-group.component";
10
- import * as i5 from "./sub-assets-grid.component";
11
+ import * as i3 from "@angular/router";
12
+ import * as i4 from "@angular/common";
13
+ import * as i5 from "./add-group/add-group.component";
14
+ import * as i6 from "./sub-assets-grid.component";
11
15
  export class GroupsComponent {
12
- constructor(permissions, subAssetsService, moduleConfig) {
16
+ constructor(permissions, subAssetsService, moduleConfig, activeRoute, router) {
13
17
  this.permissions = permissions;
14
18
  this.subAssetsService = subAssetsService;
15
19
  this.moduleConfig = moduleConfig;
20
+ this.activeRoute = activeRoute;
21
+ this.router = router;
22
+ this.SHOW_ADD_GROUP = 'showAddGroup';
16
23
  this.refresh = new EventEmitter();
17
24
  this.showAddGroup = false;
18
25
  this.filterable = true;
19
26
  this.sortable = true;
20
27
  this.shouldDisableAddGroup = false;
21
28
  this.columns = [];
29
+ this.destroyed = new Subject();
22
30
  }
23
31
  ngOnInit() {
24
32
  if (!this.permissions.hasAnyRole([
@@ -31,15 +39,45 @@ export class GroupsComponent {
31
39
  this.columns = this.subAssetsService
32
40
  .getDefaultColumns()
33
41
  .filter(column => column.name !== 'alarms');
42
+ this.activeRoute.queryParamMap
43
+ .pipe(delay(50), // It allows seeing drawer animation.
44
+ takeUntil(this.destroyed), tap(params => (this.showAddGroup = params.has(this.SHOW_ADD_GROUP))))
45
+ .subscribe();
46
+ }
47
+ onAddGroupClick() {
48
+ this.showAddGroup = !this.showAddGroup;
49
+ this.handleShowAddGroupQueryParam();
50
+ }
51
+ ngOnDestroy() {
52
+ this.destroyed.next();
53
+ this.destroyed.complete();
54
+ }
55
+ /**
56
+ * Updates the query parameter `showAddGroup` based on the value of `showAddGroup` property.
57
+ * - If `showAddGroup` is `true`, adds `showAddGroup=true` to the query parameters.
58
+ * - If `showAddGroup` is `false`, removes `showAddGroup` from the query parameters.
59
+ */
60
+ handleShowAddGroupQueryParam() {
61
+ const currentParams = { ...this.activeRoute.snapshot.queryParams };
62
+ if (this.showAddGroup) {
63
+ currentParams[this.SHOW_ADD_GROUP] = true;
64
+ }
65
+ else {
66
+ delete currentParams[this.SHOW_ADD_GROUP];
67
+ }
68
+ this.router.navigate([], {
69
+ relativeTo: this.activeRoute,
70
+ queryParams: currentParams
71
+ });
34
72
  }
35
73
  }
36
- GroupsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: GroupsComponent, deps: [{ token: i1.Permissions }, { token: i2.SubAssetsService }, { token: SUB_ASSETS_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
37
- GroupsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: GroupsComponent, selector: "c8y-groups-name", ngImport: i0, template: "<c8y-title>\n {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n <c8y-breadcrumb-item\n icon=\"c8y-group-open\"\n label=\"{{ moduleConfig.name | translate }}\"\n ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"showAddGroup = !showAddGroup\"\n [disabled]=\"shouldDisableAddGroup\"\n [attr.data-cy]=\"'groups-add-group-button'\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n {{ 'Add group' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help\n src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [refresh]=\"refresh\"\n (onCancel)=\"showAddGroup = false\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n<c8y-sub-assets-grid\n class=\"content-fullpage d-flex d-col border-top border-bottom\"\n [refresh]=\"refresh\"\n [filterable]=\"filterable\"\n [sortable]=\"sortable\"\n [columns]=\"columns\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n", dependencies: [{ kind: "component", type: i1.ActionBarItemComponent, selector: "c8y-action-bar-item", inputs: ["placement", "priority", "itemClass", "injector", "groupId", "inGroupPriority"] }, { kind: "component", type: i1.BreadcrumbComponent, selector: "c8y-breadcrumb" }, { kind: "component", type: i1.BreadcrumbItemComponent, selector: "c8y-breadcrumb-item", inputs: ["icon", "translate", "label", "path", "injector"] }, { kind: "directive", type: i1.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.TitleComponent, selector: "c8y-title", inputs: ["pageTitleUpdate"] }, { kind: "component", type: i1.HelpComponent, selector: "c8y-help", inputs: ["src", "isCollapsed", "priority", "icon"] }, { kind: "component", type: i4.AddGroupComponent, selector: "c8y-add-group", inputs: ["currentGroupId", "refresh"], outputs: ["onDeviceQueryStringChange", "onCancel"] }, { kind: "component", type: i5.SubAssetsGridComponent, selector: "c8y-sub-assets-grid", inputs: ["parent-group", "refresh", "title", "emptyStateText", "loadingItemsLabel", "columnsConfigKey", "columns", "pagination", "actionControls", "selectable", "baseQuery", "bulkActionControls", "filterable", "sortable", "displayOptions"], outputs: ["onColumnsChange", "itemsSelect"] }, { kind: "pipe", type: i1.C8yTranslatePipe, name: "translate" }] });
74
+ GroupsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: GroupsComponent, deps: [{ token: i1.Permissions }, { token: i2.SubAssetsService }, { token: SUB_ASSETS_CONFIG }, { token: i3.ActivatedRoute }, { token: i3.Router }], target: i0.ɵɵFactoryTarget.Component });
75
+ GroupsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: GroupsComponent, selector: "c8y-groups-name", ngImport: i0, template: "<c8y-title>\n {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n <c8y-breadcrumb-item\n icon=\"c8y-group-open\"\n label=\"{{ moduleConfig.name | translate }}\"\n ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"onAddGroupClick()\"\n [disabled]=\"shouldDisableAddGroup\"\n [attr.data-cy]=\"'groups-add-group-button'\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n {{ 'Add group' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help\n src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [refresh]=\"refresh\"\n (onCancel)=\"onAddGroupClick()\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n<c8y-sub-assets-grid\n class=\"content-fullpage d-flex d-col border-top border-bottom\"\n [refresh]=\"refresh\"\n [filterable]=\"filterable\"\n [sortable]=\"sortable\"\n [columns]=\"columns\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n", dependencies: [{ kind: "component", type: i1.ActionBarItemComponent, selector: "c8y-action-bar-item", inputs: ["placement", "priority", "itemClass", "injector", "groupId", "inGroupPriority"] }, { kind: "component", type: i1.BreadcrumbComponent, selector: "c8y-breadcrumb" }, { kind: "component", type: i1.BreadcrumbItemComponent, selector: "c8y-breadcrumb-item", inputs: ["icon", "translate", "label", "path", "injector"] }, { kind: "directive", type: i1.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.TitleComponent, selector: "c8y-title", inputs: ["pageTitleUpdate"] }, { kind: "component", type: i1.HelpComponent, selector: "c8y-help", inputs: ["src", "isCollapsed", "priority", "icon"] }, { kind: "component", type: i5.AddGroupComponent, selector: "c8y-add-group", inputs: ["currentGroupId", "refresh"], outputs: ["onDeviceQueryStringChange", "onCancel"] }, { kind: "component", type: i6.SubAssetsGridComponent, selector: "c8y-sub-assets-grid", inputs: ["parent-group", "refresh", "title", "emptyStateText", "loadingItemsLabel", "columnsConfigKey", "columns", "pagination", "actionControls", "selectable", "baseQuery", "bulkActionControls", "filterable", "sortable", "displayOptions"], outputs: ["onColumnsChange", "itemsSelect"] }, { kind: "pipe", type: i1.C8yTranslatePipe, name: "translate" }] });
38
76
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: GroupsComponent, decorators: [{
39
77
  type: Component,
40
- args: [{ selector: 'c8y-groups-name', template: "<c8y-title>\n {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n <c8y-breadcrumb-item\n icon=\"c8y-group-open\"\n label=\"{{ moduleConfig.name | translate }}\"\n ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"showAddGroup = !showAddGroup\"\n [disabled]=\"shouldDisableAddGroup\"\n [attr.data-cy]=\"'groups-add-group-button'\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n {{ 'Add group' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help\n src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [refresh]=\"refresh\"\n (onCancel)=\"showAddGroup = false\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n<c8y-sub-assets-grid\n class=\"content-fullpage d-flex d-col border-top border-bottom\"\n [refresh]=\"refresh\"\n [filterable]=\"filterable\"\n [sortable]=\"sortable\"\n [columns]=\"columns\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n" }]
78
+ args: [{ selector: 'c8y-groups-name', template: "<c8y-title>\n {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n <c8y-breadcrumb-item\n icon=\"c8y-group-open\"\n label=\"{{ moduleConfig.name | translate }}\"\n ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"onAddGroupClick()\"\n [disabled]=\"shouldDisableAddGroup\"\n [attr.data-cy]=\"'groups-add-group-button'\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n {{ 'Add group' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help\n src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [refresh]=\"refresh\"\n (onCancel)=\"onAddGroupClick()\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n<c8y-sub-assets-grid\n class=\"content-fullpage d-flex d-col border-top border-bottom\"\n [refresh]=\"refresh\"\n [filterable]=\"filterable\"\n [sortable]=\"sortable\"\n [columns]=\"columns\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n" }]
41
79
  }], ctorParameters: function () { return [{ type: i1.Permissions }, { type: i2.SubAssetsService }, { type: undefined, decorators: [{
42
80
  type: Inject,
43
81
  args: [SUB_ASSETS_CONFIG]
44
- }] }]; } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXBzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3N1Yi1hc3NldHMvZ3JvdXBzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3N1Yi1hc3NldHMvZ3JvdXBzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN4RSxPQUFPLEVBQVUsV0FBVyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDMUQsT0FBTyxFQUFtQixpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7Ozs7O0FBTXhELE1BQU0sT0FBTyxlQUFlO0lBUTFCLFlBQ1UsV0FBd0IsRUFDeEIsZ0JBQWtDLEVBQ1IsWUFBNkI7UUFGdkQsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDeEIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUNSLGlCQUFZLEdBQVosWUFBWSxDQUFpQjtRQVZqRSxZQUFPLEdBQXNCLElBQUksWUFBWSxFQUFFLENBQUM7UUFDaEQsaUJBQVksR0FBRyxLQUFLLENBQUM7UUFDckIsZUFBVSxHQUFHLElBQUksQ0FBQztRQUNsQixhQUFRLEdBQUcsSUFBSSxDQUFDO1FBQ2hCLDBCQUFxQixHQUFHLEtBQUssQ0FBQztRQUM5QixZQUFPLEdBQWEsRUFBRSxDQUFDO0lBTXBCLENBQUM7SUFFSixRQUFRO1FBQ04sSUFDRSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDO1lBQzNCLFdBQVcsQ0FBQyxtQkFBbUI7WUFDL0IsV0FBVyxDQUFDLHdCQUF3QjtTQUNyQyxDQUFDLEVBQ0Y7WUFDQSxJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztTQUN2QjtRQUNELElBQUksQ0FBQyxxQkFBcUIsR0FBRyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUVyRSxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxnQkFBZ0I7YUFDakMsaUJBQWlCLEVBQUU7YUFDbkIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQztJQUNoRCxDQUFDOzs0R0E1QlUsZUFBZSw2RUFXaEIsaUJBQWlCO2dHQVhoQixlQUFlLHVEQ1Q1Qiw0NENBcURBOzJGRDVDYSxlQUFlO2tCQUozQixTQUFTOytCQUNFLGlCQUFpQjs7MEJBY3hCLE1BQU07MkJBQUMsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEluamVjdCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb2x1bW4sIFBlcm1pc3Npb25zIH0gZnJvbSAnQGM4eS9uZ3gtY29tcG9uZW50cyc7XG5pbXBvcnQgeyBTdWJBc3NldHNDb25maWcsIFNVQl9BU1NFVFNfQ09ORklHIH0gZnJvbSAnLi9zdWItYXNzZXRzLm1vZGVsJztcbmltcG9ydCB7IFN1YkFzc2V0c1NlcnZpY2UgfSBmcm9tICcuL3N1Yi1hc3NldHMuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2M4eS1ncm91cHMtbmFtZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9ncm91cHMuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEdyb3Vwc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHJlZnJlc2g6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICBzaG93QWRkR3JvdXAgPSBmYWxzZTtcbiAgZmlsdGVyYWJsZSA9IHRydWU7XG4gIHNvcnRhYmxlID0gdHJ1ZTtcbiAgc2hvdWxkRGlzYWJsZUFkZEdyb3VwID0gZmFsc2U7XG4gIGNvbHVtbnM6IENvbHVtbltdID0gW107XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBwZXJtaXNzaW9uczogUGVybWlzc2lvbnMsXG4gICAgcHJpdmF0ZSBzdWJBc3NldHNTZXJ2aWNlOiBTdWJBc3NldHNTZXJ2aWNlLFxuICAgIEBJbmplY3QoU1VCX0FTU0VUU19DT05GSUcpIHB1YmxpYyBtb2R1bGVDb25maWc6IFN1YkFzc2V0c0NvbmZpZ1xuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgaWYgKFxuICAgICAgIXRoaXMucGVybWlzc2lvbnMuaGFzQW55Um9sZShbXG4gICAgICAgIFBlcm1pc3Npb25zLlJPTEVfSU5WRU5UT1JZX1JFQUQsXG4gICAgICAgIFBlcm1pc3Npb25zLlJPTEVfTUFOQUdFRF9PQkpFQ1RfUkVBRFxuICAgICAgXSlcbiAgICApIHtcbiAgICAgIHRoaXMuc29ydGFibGUgPSBmYWxzZTtcbiAgICB9XG4gICAgdGhpcy5zaG91bGREaXNhYmxlQWRkR3JvdXAgPSAhdGhpcy5zdWJBc3NldHNTZXJ2aWNlLmNhbkNyZWF0ZUdyb3VwKCk7XG5cbiAgICB0aGlzLmNvbHVtbnMgPSB0aGlzLnN1YkFzc2V0c1NlcnZpY2VcbiAgICAgIC5nZXREZWZhdWx0Q29sdW1ucygpXG4gICAgICAuZmlsdGVyKGNvbHVtbiA9PiBjb2x1bW4ubmFtZSAhPT0gJ2FsYXJtcycpO1xuICB9XG59XG4iLCI8Yzh5LXRpdGxlPlxuICB7eyBtb2R1bGVDb25maWcubmFtZSB8IHRyYW5zbGF0ZSB9fVxuPC9jOHktdGl0bGU+XG5cbjxjOHktYnJlYWRjcnVtYj5cbiAgPGM4eS1icmVhZGNydW1iLWl0ZW1cbiAgICBpY29uPVwiYzh5LWdyb3VwLW9wZW5cIlxuICAgIGxhYmVsPVwie3sgbW9kdWxlQ29uZmlnLm5hbWUgfCB0cmFuc2xhdGUgfX1cIlxuICA+PC9jOHktYnJlYWRjcnVtYi1pdGVtPlxuPC9jOHktYnJlYWRjcnVtYj5cblxuPGM4eS1hY3Rpb24tYmFyLWl0ZW1cbiAgW3BsYWNlbWVudF09XCIncmlnaHQnXCJcbiAgKm5nSWY9XCJtb2R1bGVDb25maWcuc2hvd0FkZEdyb3VwQnRuXCJcbj5cbiAgPGJ1dHRvblxuICAgIGNsYXNzPVwiYnRuIGJ0bi1saW5rXCJcbiAgICB0aXRsZT1cInt7ICdBZGQgZ3JvdXAnIHwgdHJhbnNsYXRlIH19XCJcbiAgICAoY2xpY2spPVwic2hvd0FkZEdyb3VwID0gIXNob3dBZGRHcm91cFwiXG4gICAgW2Rpc2FibGVkXT1cInNob3VsZERpc2FibGVBZGRHcm91cFwiXG4gICAgW2F0dHIuZGF0YS1jeV09XCInZ3JvdXBzLWFkZC1ncm91cC1idXR0b24nXCJcbiAgPlxuICAgIDxpXG4gICAgICBjbGFzcz1cIm0tci00XCJcbiAgICAgIGM4eUljb249XCJwbHVzLWNpcmNsZVwiXG4gICAgPjwvaT5cbiAgICB7eyAnQWRkIGdyb3VwJyB8IHRyYW5zbGF0ZSB9fVxuICA8L2J1dHRvbj5cbjwvYzh5LWFjdGlvbi1iYXItaXRlbT5cblxuPGM4eS1oZWxwXG4gIHNyYz1cIi9kb2NzL2RldmljZS1tYW5hZ2VtZW50LWFwcGxpY2F0aW9uL2dyb3VwaW5nLWRldmljZXMvI2dyb3VwaW5nLWRldmljZXNcIlxuICAqbmdJZj1cIm1vZHVsZUNvbmZpZy5zaG93R3JvdXBzQ29udGV4dEhlbHBcIlxuPjwvYzh5LWhlbHA+XG5cbjxkaXYgW25nQ2xhc3NdPVwieyBkcmF3ZXJPcGVuOiBzaG93QWRkR3JvdXAgfVwiPlxuICA8ZGl2IGNsYXNzPVwiYm90dG9tLWRyYXdlclwiPlxuICAgIDxjOHktYWRkLWdyb3VwXG4gICAgICBbcmVmcmVzaF09XCJyZWZyZXNoXCJcbiAgICAgIChvbkNhbmNlbCk9XCJzaG93QWRkR3JvdXAgPSBmYWxzZVwiXG4gICAgICAqbmdJZj1cInNob3dBZGRHcm91cFwiXG4gICAgPjwvYzh5LWFkZC1ncm91cD5cbiAgPC9kaXY+XG48L2Rpdj5cbjxjOHktc3ViLWFzc2V0cy1ncmlkXG4gIGNsYXNzPVwiY29udGVudC1mdWxscGFnZSBkLWZsZXggZC1jb2wgYm9yZGVyLXRvcCBib3JkZXItYm90dG9tXCJcbiAgW3JlZnJlc2hdPVwicmVmcmVzaFwiXG4gIFtmaWx0ZXJhYmxlXT1cImZpbHRlcmFibGVcIlxuICBbc29ydGFibGVdPVwic29ydGFibGVcIlxuICBbY29sdW1uc109XCJjb2x1bW5zXCJcbiAgW2NvbHVtbnNDb25maWdLZXldPVwiJ3N1Yi1hc3NldHMtZ3JpZCdcIlxuICBbYmFzZVF1ZXJ5XT1cIm1vZHVsZUNvbmZpZy5iYXNlUXVlcnlcIlxuPjwvYzh5LXN1Yi1hc3NldHMtZ3JpZD5cbiJdfQ==
82
+ }] }, { type: i3.ActivatedRoute }, { type: i3.Router }]; } });
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"groups.component.js","sourceRoot":"","sources":["../../../sub-assets/groups.component.ts","../../../sub-assets/groups.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, OnInit } from '@angular/core';\nimport { Column, Permissions } from '@c8y/ngx-components';\nimport { SubAssetsConfig, SUB_ASSETS_CONFIG } from './sub-assets.model';\nimport { SubAssetsService } from './sub-assets.service';\nimport { Subject } from 'rxjs';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { delay, takeUntil, tap } from 'rxjs/operators';\n\n@Component({\n  selector: 'c8y-groups-name',\n  templateUrl: './groups.component.html'\n})\nexport class GroupsComponent implements OnInit {\n  private SHOW_ADD_GROUP = 'showAddGroup';\n  refresh: EventEmitter<void> = new EventEmitter();\n  showAddGroup = false;\n  filterable = true;\n  sortable = true;\n  shouldDisableAddGroup = false;\n  columns: Column[] = [];\n  destroyed: Subject<void> = new Subject();\n\n  constructor(\n    private permissions: Permissions,\n    private subAssetsService: SubAssetsService,\n    @Inject(SUB_ASSETS_CONFIG) public moduleConfig: SubAssetsConfig,\n    private activeRoute: ActivatedRoute,\n    private router: Router\n  ) {}\n\n  ngOnInit() {\n    if (\n      !this.permissions.hasAnyRole([\n        Permissions.ROLE_INVENTORY_READ,\n        Permissions.ROLE_MANAGED_OBJECT_READ\n      ])\n    ) {\n      this.sortable = false;\n    }\n    this.shouldDisableAddGroup = !this.subAssetsService.canCreateGroup();\n\n    this.columns = this.subAssetsService\n      .getDefaultColumns()\n      .filter(column => column.name !== 'alarms');\n\n    this.activeRoute.queryParamMap\n      .pipe(\n        delay(50), // It allows seeing drawer animation.\n        takeUntil(this.destroyed),\n        tap(params => (this.showAddGroup = params.has(this.SHOW_ADD_GROUP)))\n      )\n      .subscribe();\n  }\n\n  onAddGroupClick() {\n    this.showAddGroup = !this.showAddGroup;\n    this.handleShowAddGroupQueryParam();\n  }\n\n  ngOnDestroy() {\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n\n  /**\n   * Updates the query parameter `showAddGroup` based on the value of `showAddGroup` property.\n   * - If `showAddGroup` is `true`, adds `showAddGroup=true` to the query parameters.\n   * - If `showAddGroup` is `false`, removes `showAddGroup` from the query parameters.\n   */\n  private handleShowAddGroupQueryParam() {\n    const currentParams = { ...this.activeRoute.snapshot.queryParams };\n\n    if (this.showAddGroup) {\n      currentParams[this.SHOW_ADD_GROUP] = true;\n    } else {\n      delete currentParams[this.SHOW_ADD_GROUP];\n    }\n    this.router.navigate([], {\n      relativeTo: this.activeRoute,\n      queryParams: currentParams\n    });\n  }\n}\n","<c8y-title>\n  {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n  <c8y-breadcrumb-item\n    icon=\"c8y-group-open\"\n    label=\"{{ moduleConfig.name | translate }}\"\n  ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n  [placement]=\"'right'\"\n  *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Add group' | translate }}\"\n    (click)=\"onAddGroupClick()\"\n    [disabled]=\"shouldDisableAddGroup\"\n    [attr.data-cy]=\"'groups-add-group-button'\"\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"plus-circle\"\n    ></i>\n    {{ 'Add group' | translate }}\n  </button>\n</c8y-action-bar-item>\n\n<c8y-help\n  src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n  *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n  <div class=\"bottom-drawer\">\n    <c8y-add-group\n      [refresh]=\"refresh\"\n      (onCancel)=\"onAddGroupClick()\"\n      *ngIf=\"showAddGroup\"\n    ></c8y-add-group>\n  </div>\n</div>\n<c8y-sub-assets-grid\n  class=\"content-fullpage d-flex d-col border-top border-bottom\"\n  [refresh]=\"refresh\"\n  [filterable]=\"filterable\"\n  [sortable]=\"sortable\"\n  [columns]=\"columns\"\n  [columnsConfigKey]=\"'sub-assets-grid'\"\n  [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n"]}
@@ -1,8 +1,10 @@
1
1
  import { Component, EventEmitter, Inject } from '@angular/core';
2
- import { ActivatedRoute } from '@angular/router';
2
+ import { ActivatedRoute, Router } from '@angular/router';
3
3
  import { ContextRouteService, Permissions } from '@c8y/ngx-components';
4
+ import { Subject } from 'rxjs';
4
5
  import { SUB_ASSETS_CONFIG } from './sub-assets.model';
5
6
  import { SubAssetsService } from './sub-assets.service';
7
+ import { delay, takeUntil, tap } from 'rxjs/operators';
6
8
  import * as i0 from "@angular/core";
7
9
  import * as i1 from "@angular/router";
8
10
  import * as i2 from "./sub-assets.service";
@@ -15,12 +17,14 @@ import * as i8 from "./assign-devices/assign-devices.component";
15
17
  import * as i9 from "./assign-devices/assign-child-devices.component";
16
18
  import * as i10 from "./asset-properties.component";
17
19
  export class SubAssetsComponent {
18
- constructor(route, subAssetsService, contextRouteService, permissionsService, moduleConfig) {
19
- this.route = route;
20
+ constructor(activeRoute, subAssetsService, contextRouteService, permissionsService, moduleConfig, router) {
21
+ this.activeRoute = activeRoute;
20
22
  this.subAssetsService = subAssetsService;
21
23
  this.contextRouteService = contextRouteService;
22
24
  this.permissionsService = permissionsService;
23
25
  this.moduleConfig = moduleConfig;
26
+ this.router = router;
27
+ this.SHOW_ADD_GROUP = 'showAddGroup';
24
28
  this.toggle = false;
25
29
  this.showAddGroup = false;
26
30
  this.showAssignDevices = false;
@@ -31,7 +35,8 @@ export class SubAssetsComponent {
31
35
  this.shouldDisableAssignDevices = false;
32
36
  this.shouldShowAssetsProperties = false;
33
37
  this.customProperties = [];
34
- this.dataSub = this.route.parent.data.subscribe(({ contextData }) => {
38
+ this.destroyed = new Subject();
39
+ this.activeRoute.parent.data.pipe(takeUntil(this.destroyed)).subscribe(({ contextData }) => {
35
40
  this.init(contextData);
36
41
  });
37
42
  }
@@ -42,6 +47,10 @@ export class SubAssetsComponent {
42
47
  gridHeader: true,
43
48
  filter: true
44
49
  };
50
+ this.activeRoute.queryParamMap
51
+ .pipe(delay(50), // It allows seeing drawer animation.
52
+ takeUntil(this.destroyed), tap(params => (this.showAddGroup = params.has(this.SHOW_ADD_GROUP))))
53
+ .subscribe();
45
54
  }
46
55
  async init(contextData) {
47
56
  this.group = { ...contextData };
@@ -61,26 +70,47 @@ export class SubAssetsComponent {
61
70
  groupChange(group) {
62
71
  this.group = group;
63
72
  this.title = group.name;
64
- this.contextRouteService.setContext(this.route, group);
73
+ this.contextRouteService.setContext(this.activeRoute, group);
65
74
  this.contextRouteService.refreshContext();
66
75
  this.refresh.emit();
67
76
  }
68
77
  isSmartGroup() {
69
78
  return this.subAssetsService.isSmartGroup(this.group);
70
79
  }
80
+ onAddGroupClick() {
81
+ this.showAddGroup = !this.showAddGroup;
82
+ this.handleShowAddGroupQueryParam();
83
+ }
71
84
  ngOnDestroy() {
72
- if (this.dataSub) {
73
- this.dataSub.unsubscribe();
85
+ this.destroyed.next();
86
+ this.destroyed.complete();
87
+ }
88
+ /**
89
+ * Updates the query parameter `showAddGroup` based on the value of `showAddGroup` property.
90
+ * - If `showAddGroup` is `true`, adds `showAddGroup=true` to the query parameters.
91
+ * - If `showAddGroup` is `false`, removes `showAddGroup` from the query parameters.
92
+ */
93
+ handleShowAddGroupQueryParam() {
94
+ const currentParams = { ...this.activeRoute.snapshot.queryParams };
95
+ if (this.showAddGroup) {
96
+ currentParams[this.SHOW_ADD_GROUP] = true;
74
97
  }
98
+ else {
99
+ delete currentParams[this.SHOW_ADD_GROUP];
100
+ }
101
+ this.router.navigate([], {
102
+ relativeTo: this.activeRoute,
103
+ queryParams: currentParams
104
+ });
75
105
  }
76
106
  }
77
- SubAssetsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: SubAssetsComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.SubAssetsService }, { token: i3.ContextRouteService }, { token: i3.Permissions }, { token: SUB_ASSETS_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
78
- SubAssetsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: SubAssetsComponent, selector: "c8y-sub-assets", ngImport: i0, template: "<c8y-title>\n {{ title }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"showAddGroup = !showAddGroup\"\n [disabled]=\"shouldDisableAddGroup\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Add group</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAssignDeviceBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Assign devices' | translate }}\"\n (click)=\"showAssignDevices = !showAssignDevices\"\n [disabled]=\"shouldDisableAssignDevices\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Assign devices</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/managing-assets/#managing-assets\"></c8y-help>\n\n<div\n class=\"card content-fullpage\"\n [ngClass]=\"{\n 'card--grid grid__col--8-4--md grid__row--fit-auto': shouldShowAssetsProperties,\n 'd-flex d-col': !shouldShowAssetsProperties\n }\"\n>\n <c8y-group-info\n class=\"grid__col--fullspan\"\n *ngIf=\"moduleConfig.showDetails\"\n [group]=\"group\"\n (groupChange)=\"groupChange($event)\"\n ></c8y-group-info>\n <c8y-sub-assets-grid\n class=\"d-contents\"\n [refresh]=\"refresh\"\n [parent-group]=\"group\"\n [filterable]=\"filterable\"\n [displayOptions]=\"displayOptions\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n ></c8y-sub-assets-grid>\n <div\n class=\"inner-scroll bg-level-1\"\n *ngIf=\"shouldShowAssetsProperties\"\n >\n <c8y-asset-properties\n class=\"d-contents\"\n [properties]=\"customProperties\"\n [asset]=\"group\"\n (assetChange)=\"groupChange($event)\"\n ></c8y-asset-properties>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [currentGroupId]=\"currentGroupId\"\n [refresh]=\"refresh\"\n (onCancel)=\"showAddGroup = false\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignDevices }\">\n <div class=\"bottom-drawer\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-devices\n class=\"d-contents\"\n (onCancel)=\"showAssignDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n (onShowChildDevices)=\"showAssignChildDevices = $event\"\n (selectedDevice)=\"showChildrenForDevice = $event\"\n *ngIf=\"showAssignDevices\"\n ></c8y-assign-devices>\n </div>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignChildDevices }\">\n <div class=\"bottom-drawer m-t-40\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-child-devices\n class=\"d-contents\"\n *ngIf=\"showAssignChildDevices\"\n (onCancel)=\"showAssignChildDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n [parentDevice]=\"showChildrenForDevice\"\n ></c8y-assign-child-devices>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i3.ActionBarItemComponent, selector: "c8y-action-bar-item", inputs: ["placement", "priority", "itemClass", "injector", "groupId", "inGroupPriority"] }, { kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i3.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TitleComponent, selector: "c8y-title", inputs: ["pageTitleUpdate"] }, { kind: "component", type: i3.HelpComponent, selector: "c8y-help", inputs: ["src", "isCollapsed", "priority", "icon"] }, { kind: "component", type: i5.AddGroupComponent, selector: "c8y-add-group", inputs: ["currentGroupId", "refresh"], outputs: ["onDeviceQueryStringChange", "onCancel"] }, { kind: "component", type: i6.SubAssetsGridComponent, selector: "c8y-sub-assets-grid", inputs: ["parent-group", "refresh", "title", "emptyStateText", "loadingItemsLabel", "columnsConfigKey", "columns", "pagination", "actionControls", "selectable", "baseQuery", "bulkActionControls", "filterable", "sortable", "displayOptions"], outputs: ["onColumnsChange", "itemsSelect"] }, { kind: "component", type: i7.GroupInfoComponent, selector: "c8y-group-info", inputs: ["group"], outputs: ["groupChange"] }, { kind: "component", type: i8.AssignDevicesComponent, selector: "c8y-assign-devices", inputs: ["currentGroupId", "refresh"], outputs: ["onCancel", "onShowChildDevices", "selectedDevice"] }, { kind: "component", type: i9.AssignChildDevicesComponent, selector: "c8y-assign-child-devices", inputs: ["currentGroupId", "parentDevice", "refresh"], outputs: ["onCancel"] }, { kind: "component", type: i10.AssetPropertiesComponent, selector: "c8y-asset-properties", inputs: ["asset", "properties"], outputs: ["assetChange"] }, { kind: "pipe", type: i3.C8yTranslatePipe, name: "translate" }] });
107
+ SubAssetsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: SubAssetsComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.SubAssetsService }, { token: i3.ContextRouteService }, { token: i3.Permissions }, { token: SUB_ASSETS_CONFIG }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
108
+ SubAssetsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: SubAssetsComponent, selector: "c8y-sub-assets", ngImport: i0, template: "<c8y-title>\n {{ title }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"onAddGroupClick()\"\n [disabled]=\"shouldDisableAddGroup\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Add group</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAssignDeviceBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Assign devices' | translate }}\"\n (click)=\"showAssignDevices = !showAssignDevices\"\n [disabled]=\"shouldDisableAssignDevices\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Assign devices</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/managing-assets/#managing-assets\"></c8y-help>\n\n<div\n class=\"card content-fullpage\"\n [ngClass]=\"{\n 'card--grid grid__col--8-4--md grid__row--fit-auto': shouldShowAssetsProperties,\n 'd-flex d-col': !shouldShowAssetsProperties\n }\"\n>\n <c8y-group-info\n class=\"grid__col--fullspan\"\n *ngIf=\"moduleConfig.showDetails\"\n [group]=\"group\"\n (groupChange)=\"groupChange($event)\"\n ></c8y-group-info>\n <c8y-sub-assets-grid\n class=\"d-contents\"\n [refresh]=\"refresh\"\n [parent-group]=\"group\"\n [filterable]=\"filterable\"\n [displayOptions]=\"displayOptions\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n ></c8y-sub-assets-grid>\n <div\n class=\"inner-scroll bg-level-1\"\n *ngIf=\"shouldShowAssetsProperties\"\n >\n <c8y-asset-properties\n class=\"d-contents\"\n [properties]=\"customProperties\"\n [asset]=\"group\"\n (assetChange)=\"groupChange($event)\"\n ></c8y-asset-properties>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [currentGroupId]=\"currentGroupId\"\n [refresh]=\"refresh\"\n (onCancel)=\"onAddGroupClick()\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignDevices }\">\n <div class=\"bottom-drawer\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-devices\n class=\"d-contents\"\n (onCancel)=\"showAssignDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n (onShowChildDevices)=\"showAssignChildDevices = $event\"\n (selectedDevice)=\"showChildrenForDevice = $event\"\n *ngIf=\"showAssignDevices\"\n ></c8y-assign-devices>\n </div>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignChildDevices }\">\n <div class=\"bottom-drawer m-t-40\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-child-devices\n class=\"d-contents\"\n *ngIf=\"showAssignChildDevices\"\n (onCancel)=\"showAssignChildDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n [parentDevice]=\"showChildrenForDevice\"\n ></c8y-assign-child-devices>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i3.ActionBarItemComponent, selector: "c8y-action-bar-item", inputs: ["placement", "priority", "itemClass", "injector", "groupId", "inGroupPriority"] }, { kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i3.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TitleComponent, selector: "c8y-title", inputs: ["pageTitleUpdate"] }, { kind: "component", type: i3.HelpComponent, selector: "c8y-help", inputs: ["src", "isCollapsed", "priority", "icon"] }, { kind: "component", type: i5.AddGroupComponent, selector: "c8y-add-group", inputs: ["currentGroupId", "refresh"], outputs: ["onDeviceQueryStringChange", "onCancel"] }, { kind: "component", type: i6.SubAssetsGridComponent, selector: "c8y-sub-assets-grid", inputs: ["parent-group", "refresh", "title", "emptyStateText", "loadingItemsLabel", "columnsConfigKey", "columns", "pagination", "actionControls", "selectable", "baseQuery", "bulkActionControls", "filterable", "sortable", "displayOptions"], outputs: ["onColumnsChange", "itemsSelect"] }, { kind: "component", type: i7.GroupInfoComponent, selector: "c8y-group-info", inputs: ["group"], outputs: ["groupChange"] }, { kind: "component", type: i8.AssignDevicesComponent, selector: "c8y-assign-devices", inputs: ["currentGroupId", "refresh"], outputs: ["onCancel", "onShowChildDevices", "selectedDevice"] }, { kind: "component", type: i9.AssignChildDevicesComponent, selector: "c8y-assign-child-devices", inputs: ["currentGroupId", "parentDevice", "refresh"], outputs: ["onCancel"] }, { kind: "component", type: i10.AssetPropertiesComponent, selector: "c8y-asset-properties", inputs: ["asset", "properties"], outputs: ["assetChange"] }, { kind: "pipe", type: i3.C8yTranslatePipe, name: "translate" }] });
79
109
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: SubAssetsComponent, decorators: [{
80
110
  type: Component,
81
- args: [{ selector: 'c8y-sub-assets', template: "<c8y-title>\n {{ title }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"showAddGroup = !showAddGroup\"\n [disabled]=\"shouldDisableAddGroup\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Add group</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAssignDeviceBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Assign devices' | translate }}\"\n (click)=\"showAssignDevices = !showAssignDevices\"\n [disabled]=\"shouldDisableAssignDevices\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Assign devices</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/managing-assets/#managing-assets\"></c8y-help>\n\n<div\n class=\"card content-fullpage\"\n [ngClass]=\"{\n 'card--grid grid__col--8-4--md grid__row--fit-auto': shouldShowAssetsProperties,\n 'd-flex d-col': !shouldShowAssetsProperties\n }\"\n>\n <c8y-group-info\n class=\"grid__col--fullspan\"\n *ngIf=\"moduleConfig.showDetails\"\n [group]=\"group\"\n (groupChange)=\"groupChange($event)\"\n ></c8y-group-info>\n <c8y-sub-assets-grid\n class=\"d-contents\"\n [refresh]=\"refresh\"\n [parent-group]=\"group\"\n [filterable]=\"filterable\"\n [displayOptions]=\"displayOptions\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n ></c8y-sub-assets-grid>\n <div\n class=\"inner-scroll bg-level-1\"\n *ngIf=\"shouldShowAssetsProperties\"\n >\n <c8y-asset-properties\n class=\"d-contents\"\n [properties]=\"customProperties\"\n [asset]=\"group\"\n (assetChange)=\"groupChange($event)\"\n ></c8y-asset-properties>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [currentGroupId]=\"currentGroupId\"\n [refresh]=\"refresh\"\n (onCancel)=\"showAddGroup = false\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignDevices }\">\n <div class=\"bottom-drawer\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-devices\n class=\"d-contents\"\n (onCancel)=\"showAssignDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n (onShowChildDevices)=\"showAssignChildDevices = $event\"\n (selectedDevice)=\"showChildrenForDevice = $event\"\n *ngIf=\"showAssignDevices\"\n ></c8y-assign-devices>\n </div>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignChildDevices }\">\n <div class=\"bottom-drawer m-t-40\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-child-devices\n class=\"d-contents\"\n *ngIf=\"showAssignChildDevices\"\n (onCancel)=\"showAssignChildDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n [parentDevice]=\"showChildrenForDevice\"\n ></c8y-assign-child-devices>\n </div>\n </div>\n</div>\n" }]
111
+ args: [{ selector: 'c8y-sub-assets', template: "<c8y-title>\n {{ title }}\n</c8y-title>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"onAddGroupClick()\"\n [disabled]=\"shouldDisableAddGroup\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Add group</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"!isSmartGroup() && moduleConfig.showAssignDeviceBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Assign devices' | translate }}\"\n (click)=\"showAssignDevices = !showAssignDevices\"\n [disabled]=\"shouldDisableAssignDevices\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n <span translate>Assign devices</span>\n </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/managing-assets/#managing-assets\"></c8y-help>\n\n<div\n class=\"card content-fullpage\"\n [ngClass]=\"{\n 'card--grid grid__col--8-4--md grid__row--fit-auto': shouldShowAssetsProperties,\n 'd-flex d-col': !shouldShowAssetsProperties\n }\"\n>\n <c8y-group-info\n class=\"grid__col--fullspan\"\n *ngIf=\"moduleConfig.showDetails\"\n [group]=\"group\"\n (groupChange)=\"groupChange($event)\"\n ></c8y-group-info>\n <c8y-sub-assets-grid\n class=\"d-contents\"\n [refresh]=\"refresh\"\n [parent-group]=\"group\"\n [filterable]=\"filterable\"\n [displayOptions]=\"displayOptions\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n ></c8y-sub-assets-grid>\n <div\n class=\"inner-scroll bg-level-1\"\n *ngIf=\"shouldShowAssetsProperties\"\n >\n <c8y-asset-properties\n class=\"d-contents\"\n [properties]=\"customProperties\"\n [asset]=\"group\"\n (assetChange)=\"groupChange($event)\"\n ></c8y-asset-properties>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n <div class=\"bottom-drawer\">\n <c8y-add-group\n [currentGroupId]=\"currentGroupId\"\n [refresh]=\"refresh\"\n (onCancel)=\"onAddGroupClick()\"\n *ngIf=\"showAddGroup\"\n ></c8y-add-group>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignDevices }\">\n <div class=\"bottom-drawer\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-devices\n class=\"d-contents\"\n (onCancel)=\"showAssignDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n (onShowChildDevices)=\"showAssignChildDevices = $event\"\n (selectedDevice)=\"showChildrenForDevice = $event\"\n *ngIf=\"showAssignDevices\"\n ></c8y-assign-devices>\n </div>\n </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignChildDevices }\">\n <div class=\"bottom-drawer m-t-40\">\n <div class=\"d-flex d-col no-align-items fit-h\">\n <c8y-assign-child-devices\n class=\"d-contents\"\n *ngIf=\"showAssignChildDevices\"\n (onCancel)=\"showAssignChildDevices = false\"\n [refresh]=\"refresh\"\n [currentGroupId]=\"currentGroupId\"\n [parentDevice]=\"showChildrenForDevice\"\n ></c8y-assign-child-devices>\n </div>\n </div>\n</div>\n" }]
82
112
  }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.SubAssetsService }, { type: i3.ContextRouteService }, { type: i3.Permissions }, { type: undefined, decorators: [{
83
113
  type: Inject,
84
114
  args: [SUB_ASSETS_CONFIG]
85
- }] }]; } });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sub-assets.component.js","sourceRoot":"","sources":["../../../sub-assets/sub-assets.component.ts","../../../sub-assets/sub-assets.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, OnDestroy, OnInit } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { IManagedObject } from '@c8y/client';\nimport { ContextRouteService, DisplayOptions, Permissions } from '@c8y/ngx-components';\nimport { Subscription } from 'rxjs';\nimport { SUB_ASSETS_CONFIG, SubAssetsConfig } from './sub-assets.model';\nimport { SubAssetsService } from './sub-assets.service';\n\n@Component({\n  selector: 'c8y-sub-assets',\n  templateUrl: './sub-assets.component.html'\n})\nexport class SubAssetsComponent implements OnInit, OnDestroy {\n  group: IManagedObject;\n  currentGroupId: string;\n  showChildrenForDevice: IManagedObject;\n  title: string;\n  toggle = false;\n  showAddGroup = false;\n  showAssignDevices = false;\n  requestInProgress: boolean;\n  showAssignChildDevices = false;\n  refresh: EventEmitter<any> = new EventEmitter();\n  filterable = true;\n  shouldDisableAddGroup = false;\n  shouldDisableAssignDevices = false;\n  shouldShowAssetsProperties = false;\n  displayOptions: DisplayOptions;\n  customProperties: IManagedObject[] = [];\n\n  private dataSub: Subscription;\n\n  constructor(\n    private route: ActivatedRoute,\n    private subAssetsService: SubAssetsService,\n    private contextRouteService: ContextRouteService,\n    private permissionsService: Permissions,\n    @Inject(SUB_ASSETS_CONFIG) public moduleConfig: SubAssetsConfig\n  ) {\n    this.dataSub = this.route.parent.data.subscribe(({ contextData }) => {\n      this.init(contextData);\n    });\n  }\n\n  async ngOnInit() {\n    this.displayOptions = {\n      striped: true,\n      bordered: false,\n      gridHeader: true,\n      filter: true\n    };\n  }\n\n  async init(contextData) {\n    this.group = { ...contextData };\n    this.title = this.group.name;\n    this.currentGroupId = this.group.id;\n    this.shouldDisableAddGroup = !(await this.permissionsService.canEdit(\n      [\n        Permissions.ROLE_INVENTORY_ADMIN,\n        Permissions.ROLE_INVENTORY_CREATE,\n        Permissions.ROLE_MANAGED_OBJECT_ADMIN,\n        Permissions.ROLE_MANAGED_OBJECT_CREATE\n      ],\n      this.group\n    ));\n    this.shouldDisableAssignDevices = !(await this.subAssetsService.canAssignDevice(this.group));\n    this.customProperties = await this.subAssetsService.getCustomProperties(this.group);\n    this.shouldShowAssetsProperties =\n      this.moduleConfig.showProperties && this.customProperties.length > 0;\n  }\n\n  groupChange(group: IManagedObject): void {\n    this.group = group;\n    this.title = group.name;\n    this.contextRouteService.setContext(this.route, group);\n    this.contextRouteService.refreshContext();\n    this.refresh.emit();\n  }\n\n  isSmartGroup() {\n    return this.subAssetsService.isSmartGroup(this.group);\n  }\n\n  ngOnDestroy(): void {\n    if (this.dataSub) {\n      this.dataSub.unsubscribe();\n    }\n  }\n}\n","<c8y-title>\n  {{ title }}\n</c8y-title>\n\n<c8y-action-bar-item\n  [placement]=\"'right'\"\n  *ngIf=\"!isSmartGroup() && moduleConfig.showAddGroupBtn\"\n>\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Add group' | translate }}\"\n    (click)=\"showAddGroup = !showAddGroup\"\n    [disabled]=\"shouldDisableAddGroup\"\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"plus-circle\"\n    ></i>\n    <span translate>Add group</span>\n  </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item\n  [placement]=\"'right'\"\n  *ngIf=\"!isSmartGroup() && moduleConfig.showAssignDeviceBtn\"\n>\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Assign devices' | translate }}\"\n    (click)=\"showAssignDevices = !showAssignDevices\"\n    [disabled]=\"shouldDisableAssignDevices\"\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"plus-circle\"\n    ></i>\n    <span translate>Assign devices</span>\n  </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/managing-assets/#managing-assets\"></c8y-help>\n\n<div\n  class=\"card content-fullpage\"\n  [ngClass]=\"{\n    'card--grid grid__col--8-4--md grid__row--fit-auto': shouldShowAssetsProperties,\n    'd-flex d-col': !shouldShowAssetsProperties\n  }\"\n>\n  <c8y-group-info\n    class=\"grid__col--fullspan\"\n    *ngIf=\"moduleConfig.showDetails\"\n    [group]=\"group\"\n    (groupChange)=\"groupChange($event)\"\n  ></c8y-group-info>\n  <c8y-sub-assets-grid\n    class=\"d-contents\"\n    [refresh]=\"refresh\"\n    [parent-group]=\"group\"\n    [filterable]=\"filterable\"\n    [displayOptions]=\"displayOptions\"\n    [columnsConfigKey]=\"'sub-assets-grid'\"\n    [baseQuery]=\"moduleConfig.baseQuery\"\n  ></c8y-sub-assets-grid>\n  <div\n    class=\"inner-scroll bg-level-1\"\n    *ngIf=\"shouldShowAssetsProperties\"\n  >\n    <c8y-asset-properties\n      class=\"d-contents\"\n      [properties]=\"customProperties\"\n      [asset]=\"group\"\n      (assetChange)=\"groupChange($event)\"\n    ></c8y-asset-properties>\n  </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n  <div class=\"bottom-drawer\">\n    <c8y-add-group\n      [currentGroupId]=\"currentGroupId\"\n      [refresh]=\"refresh\"\n      (onCancel)=\"showAddGroup = false\"\n      *ngIf=\"showAddGroup\"\n    ></c8y-add-group>\n  </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignDevices }\">\n  <div class=\"bottom-drawer\">\n    <div class=\"d-flex d-col no-align-items fit-h\">\n      <c8y-assign-devices\n        class=\"d-contents\"\n        (onCancel)=\"showAssignDevices = false\"\n        [refresh]=\"refresh\"\n        [currentGroupId]=\"currentGroupId\"\n        (onShowChildDevices)=\"showAssignChildDevices = $event\"\n        (selectedDevice)=\"showChildrenForDevice = $event\"\n        *ngIf=\"showAssignDevices\"\n      ></c8y-assign-devices>\n    </div>\n  </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignChildDevices }\">\n  <div class=\"bottom-drawer m-t-40\">\n    <div class=\"d-flex d-col no-align-items fit-h\">\n      <c8y-assign-child-devices\n        class=\"d-contents\"\n        *ngIf=\"showAssignChildDevices\"\n        (onCancel)=\"showAssignChildDevices = false\"\n        [refresh]=\"refresh\"\n        [currentGroupId]=\"currentGroupId\"\n        [parentDevice]=\"showChildrenForDevice\"\n      ></c8y-assign-child-devices>\n    </div>\n  </div>\n</div>\n"]}
115
+ }] }, { type: i1.Router }]; } });
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sub-assets.component.js","sourceRoot":"","sources":["../../../sub-assets/sub-assets.component.ts","../../../sub-assets/sub-assets.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, OnDestroy, OnInit } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { IManagedObject } from '@c8y/client';\nimport { ContextRouteService, DisplayOptions, Permissions } from '@c8y/ngx-components';\nimport { Subject, Subscription } from 'rxjs';\nimport { SUB_ASSETS_CONFIG, SubAssetsConfig } from './sub-assets.model';\nimport { SubAssetsService } from './sub-assets.service';\nimport { delay, takeUntil, tap } from 'rxjs/operators';\n\n@Component({\n  selector: 'c8y-sub-assets',\n  templateUrl: './sub-assets.component.html'\n})\nexport class SubAssetsComponent implements OnInit, OnDestroy {\n  private SHOW_ADD_GROUP = 'showAddGroup';\n  group: IManagedObject;\n  currentGroupId: string;\n  showChildrenForDevice: IManagedObject;\n  title: string;\n  toggle = false;\n  showAddGroup = false;\n  showAssignDevices = false;\n  requestInProgress: boolean;\n  showAssignChildDevices = false;\n  refresh: EventEmitter<any> = new EventEmitter();\n  filterable = true;\n  shouldDisableAddGroup = false;\n  shouldDisableAssignDevices = false;\n  shouldShowAssetsProperties = false;\n  displayOptions: DisplayOptions;\n  customProperties: IManagedObject[] = [];\n  destroyed: Subject<void> = new Subject();\n\n  private dataSub: Subscription;\n\n  constructor(\n    private activeRoute: ActivatedRoute,\n    private subAssetsService: SubAssetsService,\n    private contextRouteService: ContextRouteService,\n    private permissionsService: Permissions,\n    @Inject(SUB_ASSETS_CONFIG) public moduleConfig: SubAssetsConfig,\n    private router: Router\n  ) {\n    this.activeRoute.parent.data.pipe(takeUntil(this.destroyed)).subscribe(({ contextData }) => {\n      this.init(contextData);\n    });\n  }\n\n  async ngOnInit() {\n    this.displayOptions = {\n      striped: true,\n      bordered: false,\n      gridHeader: true,\n      filter: true\n    };\n\n    this.activeRoute.queryParamMap\n      .pipe(\n        delay(50), // It allows seeing drawer animation.\n        takeUntil(this.destroyed),\n        tap(params => (this.showAddGroup = params.has(this.SHOW_ADD_GROUP)))\n      )\n      .subscribe();\n  }\n\n  async init(contextData) {\n    this.group = { ...contextData };\n    this.title = this.group.name;\n    this.currentGroupId = this.group.id;\n    this.shouldDisableAddGroup = !(await this.permissionsService.canEdit(\n      [\n        Permissions.ROLE_INVENTORY_ADMIN,\n        Permissions.ROLE_INVENTORY_CREATE,\n        Permissions.ROLE_MANAGED_OBJECT_ADMIN,\n        Permissions.ROLE_MANAGED_OBJECT_CREATE\n      ],\n      this.group\n    ));\n    this.shouldDisableAssignDevices = !(await this.subAssetsService.canAssignDevice(this.group));\n    this.customProperties = await this.subAssetsService.getCustomProperties(this.group);\n    this.shouldShowAssetsProperties =\n      this.moduleConfig.showProperties && this.customProperties.length > 0;\n  }\n\n  groupChange(group: IManagedObject): void {\n    this.group = group;\n    this.title = group.name;\n    this.contextRouteService.setContext(this.activeRoute, group);\n    this.contextRouteService.refreshContext();\n    this.refresh.emit();\n  }\n\n  isSmartGroup() {\n    return this.subAssetsService.isSmartGroup(this.group);\n  }\n\n  onAddGroupClick() {\n    this.showAddGroup = !this.showAddGroup;\n    this.handleShowAddGroupQueryParam();\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n\n  /**\n   * Updates the query parameter `showAddGroup` based on the value of `showAddGroup` property.\n   * - If `showAddGroup` is `true`, adds `showAddGroup=true` to the query parameters.\n   * - If `showAddGroup` is `false`, removes `showAddGroup` from the query parameters.\n   */\n  private handleShowAddGroupQueryParam() {\n    const currentParams = { ...this.activeRoute.snapshot.queryParams };\n\n    if (this.showAddGroup) {\n      currentParams[this.SHOW_ADD_GROUP] = true;\n    } else {\n      delete currentParams[this.SHOW_ADD_GROUP];\n    }\n    this.router.navigate([], {\n      relativeTo: this.activeRoute,\n      queryParams: currentParams\n    });\n  }\n}\n","<c8y-title>\n  {{ title }}\n</c8y-title>\n\n<c8y-action-bar-item\n  [placement]=\"'right'\"\n  *ngIf=\"!isSmartGroup() && moduleConfig.showAddGroupBtn\"\n>\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Add group' | translate }}\"\n    (click)=\"onAddGroupClick()\"\n    [disabled]=\"shouldDisableAddGroup\"\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"plus-circle\"\n    ></i>\n    <span translate>Add group</span>\n  </button>\n</c8y-action-bar-item>\n\n<c8y-action-bar-item\n  [placement]=\"'right'\"\n  *ngIf=\"!isSmartGroup() && moduleConfig.showAssignDeviceBtn\"\n>\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Assign devices' | translate }}\"\n    (click)=\"showAssignDevices = !showAssignDevices\"\n    [disabled]=\"shouldDisableAssignDevices\"\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"plus-circle\"\n    ></i>\n    <span translate>Assign devices</span>\n  </button>\n</c8y-action-bar-item>\n\n<c8y-help src=\"/docs/cockpit/managing-assets/#managing-assets\"></c8y-help>\n\n<div\n  class=\"card content-fullpage\"\n  [ngClass]=\"{\n    'card--grid grid__col--8-4--md grid__row--fit-auto': shouldShowAssetsProperties,\n    'd-flex d-col': !shouldShowAssetsProperties\n  }\"\n>\n  <c8y-group-info\n    class=\"grid__col--fullspan\"\n    *ngIf=\"moduleConfig.showDetails\"\n    [group]=\"group\"\n    (groupChange)=\"groupChange($event)\"\n  ></c8y-group-info>\n  <c8y-sub-assets-grid\n    class=\"d-contents\"\n    [refresh]=\"refresh\"\n    [parent-group]=\"group\"\n    [filterable]=\"filterable\"\n    [displayOptions]=\"displayOptions\"\n    [columnsConfigKey]=\"'sub-assets-grid'\"\n    [baseQuery]=\"moduleConfig.baseQuery\"\n  ></c8y-sub-assets-grid>\n  <div\n    class=\"inner-scroll bg-level-1\"\n    *ngIf=\"shouldShowAssetsProperties\"\n  >\n    <c8y-asset-properties\n      class=\"d-contents\"\n      [properties]=\"customProperties\"\n      [asset]=\"group\"\n      (assetChange)=\"groupChange($event)\"\n    ></c8y-asset-properties>\n  </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAddGroup }\">\n  <div class=\"bottom-drawer\">\n    <c8y-add-group\n      [currentGroupId]=\"currentGroupId\"\n      [refresh]=\"refresh\"\n      (onCancel)=\"onAddGroupClick()\"\n      *ngIf=\"showAddGroup\"\n    ></c8y-add-group>\n  </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignDevices }\">\n  <div class=\"bottom-drawer\">\n    <div class=\"d-flex d-col no-align-items fit-h\">\n      <c8y-assign-devices\n        class=\"d-contents\"\n        (onCancel)=\"showAssignDevices = false\"\n        [refresh]=\"refresh\"\n        [currentGroupId]=\"currentGroupId\"\n        (onShowChildDevices)=\"showAssignChildDevices = $event\"\n        (selectedDevice)=\"showChildrenForDevice = $event\"\n        *ngIf=\"showAssignDevices\"\n      ></c8y-assign-devices>\n    </div>\n  </div>\n</div>\n\n<div [ngClass]=\"{ drawerOpen: showAssignChildDevices }\">\n  <div class=\"bottom-drawer m-t-40\">\n    <div class=\"d-flex d-col no-align-items fit-h\">\n      <c8y-assign-child-devices\n        class=\"d-contents\"\n        *ngIf=\"showAssignChildDevices\"\n        (onCancel)=\"showAssignChildDevices = false\"\n        [refresh]=\"refresh\"\n        [currentGroupId]=\"currentGroupId\"\n        [parentDevice]=\"showChildrenForDevice\"\n      ></c8y-assign-child-devices>\n    </div>\n  </div>\n</div>\n"]}