@eo-sdk/client 11.1.0-rc.2 → 11.2.0-rc.1

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.
@@ -60,10 +60,12 @@ export class TreeComponent {
60
60
  switch (event.key) {
61
61
  case 'ArrowUp': {
62
62
  this.focusNode(false);
63
+ this._ensureVisible();
63
64
  break;
64
65
  }
65
66
  case 'ArrowDown': {
66
67
  this.focusNode(true);
68
+ this._ensureVisible();
67
69
  break;
68
70
  }
69
71
  case 'ArrowRight': {
@@ -198,20 +200,29 @@ export class TreeComponent {
198
200
  this.visibleNodes.forEach(n => (n.focused = false));
199
201
  }
200
202
  if (node) {
201
- const nodes = document.querySelectorAll('eo-tree-node');
202
- nodes.forEach(n => {
203
- if (n.querySelector('.label span').textContent === node.name) {
204
- n.scrollIntoView({
205
- behavior: "smooth",
206
- block: "start",
207
- inline: "nearest"
208
- });
209
- }
210
- });
211
203
  node.focused = true;
212
204
  this.focusedNode = node;
213
205
  }
214
206
  }
207
+ _ensureVisible() {
208
+ setTimeout(() => {
209
+ const container = this.elementRef.nativeElement;
210
+ const el = container.querySelector('eo-tree-node .label.focused');
211
+ const containerRect = container.getBoundingClientRect();
212
+ const elRect = el.getBoundingClientRect();
213
+ /* The first one checks the structure tree for scroll down
214
+ * The second one checks the structure tree for scroll up
215
+ * The third one checks the trees in selection dialogs for scroll down
216
+ * The fourth one checks the trees in selection dialogs for scroll up
217
+ */
218
+ if (elRect.bottom >= window.innerHeight
219
+ || elRect.top < 50
220
+ || elRect.bottom >= containerRect.height
221
+ || elRect.top - containerRect.top <= 30) {
222
+ el.scrollIntoView();
223
+ }
224
+ }, 200);
225
+ }
215
226
  focusNode(next) {
216
227
  if (this.visibleNodes.length) {
217
228
  let index = 0, shift = next ? 1 : -1;
@@ -278,4 +289,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
278
289
  type: HostListener,
279
290
  args: ['keydown', ['$event']]
280
291
  }] } });
281
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../../../src/app/eo-framework/tree/tree.component.ts","../../../../../../../src/app/eo-framework/tree/tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  HostListener,\n  forwardRef,\n  ViewEncapsulation,\n  Input,\n  Output,\n  EventEmitter,\n  HostBinding, ElementRef, OnInit\n} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {TreeNode, TreeOptions} from './tree.component.interface';\n\n\n\n@Component({\n  selector: 'eo-tree',\n  templateUrl: './tree.component.html',\n  styleUrls: ['./tree.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TreeComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class TreeComponent implements ControlValueAccessor, OnInit {\n\n  @HostBinding('attr.tabindex') _tabIndex = 0;\n\n  private _expandedNodes: string[] = [];\n  private _highlightedNodes: string[] = [];\n  private selectedNodes: any[] = [];\n  private visibleNodes: any[] = [];\n  private focusedNode: TreeNode;\n\n  tree: TreeNode[];\n\n  @Input() options: TreeOptions = {};\n  @Input() isDisplayed: boolean;\n  @Input() readonly: boolean;\n  @Input() emptyMessage = 'eo.error.structure.tree.not.available';\n\n  @Input() selectionKey = ' '; // default is Space\n\n  // the nodes that are selected. In case of `multiselect` set to true, this will be an\n  @Output() expandedNodesChanged = new EventEmitter();\n  @Output() onSelected = new EventEmitter();\n\n  propagateChange = (_: any) => {\n  }\n\n  constructor(public elementRef: ElementRef) {\n  }\n\n  ngOnInit() {\n  }\n\n  @Input('highlightedNodes')\n  set highlightedNodes(nodes: string[]) {\n    this._highlightedNodes = nodes || [];\n    this.visibleNodes.forEach(n => (n.highlighted = !!this._highlightedNodes.find(id => id === n.id)));\n  }\n\n  @Input('tree')\n  set treeInput(tree: TreeNode[]) {\n    // this.tree = tree;\n    this.selectedNodes = [];\n    this._expandedNodes = [];\n    this.focusedNode = null;\n    this.updateTree(tree);\n  }\n\n  @Input('treeUpdate')\n  set treeUpdate(tree: TreeNode[]) {\n    if (tree) {\n      this.updateTree(tree);\n    }\n  }\n\n\n  @HostListener('focusin', ['$event.target'])\n  onFocusIn(target: any) {\n    if (!this.focusedNode || !this.focusedNode.focused) {\n      let node = this.selectedNodes[0] || this.visibleNodes[0];\n      this.updateFocus(node);\n    }\n  }\n\n    @HostListener('focusout')\n    onFocusOut() {\n      this.updateFocus();\n    }\n\n  onFocus(evt) {\n  }\n\n  onBlur(evt) {\n  }\n\n  onToggle(evt) {\n\n  }\n\n  @HostListener('keydown', ['$event'])\n  onKey(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'ArrowUp': {\n        this.focusNode(false);\n        break;\n      }\n      case 'ArrowDown': {\n        this.focusNode(true);\n        break;\n      }\n      case 'ArrowRight': {\n        this.toggleExpanded(this.focusedNode);\n        break;\n      }\n      case 'ArrowLeft': {\n        this.toggleExpanded(this.focusedNode);\n        break;\n      }\n      case this.selectionKey: {\n        // toggle selection of the focused node\n        if (this.focusedNode.selectable) {\n          // this.focusedNode.selected = !this.focusedNode.selected;\n          this.onNodeSelected(this.focusedNode);\n        }\n        break;\n      }\n      case 'Enter': {\n        // toggle selection of the focused node\n        if (this.focusedNode.selectable) {\n          // this.focusedNode.selected = !this.focusedNode.selected;\n          this.onNodeSelected(this.focusedNode);\n        }\n        break;\n      }\n    }\n\n    if (['ArrowUp', 'ArrowDown', 'ArrowRight', 'ArrowLeft'].includes(event.key)) {\n      event.stopPropagation();\n      event.preventDefault();\n    }\n  }\n\n\n  writeValue(selectedNodes: TreeNode[]): void {\n    let _selectedNodes = !selectedNodes || Array.isArray(selectedNodes) ? selectedNodes || [] : [selectedNodes];\n\n    if (this.selectedNodes.length !== _selectedNodes.length || this.selectedNodes.some((n, i) => n.id !== _selectedNodes[i].id)) {\n      this.selectedNodes = _selectedNodes;\n      this.updateTree(this.tree);\n    }\n\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  onNodeSelected(node) {\n    // if the selected node isn't allowed to be selected, we'll instead try to\n    // toggle expanded flag for parent nodes\n    this.onSelected.emit(node);\n    this.updateFocus(node, this.focusedNode);\n\n    if (!node.selectable) {\n      this.toggleExpanded(node);\n    } else {\n      node.selected = !node.selected;\n      if (node.selected) {\n        if (!this.options.multiselect && this.selectedNodes.length) {\n          this.selectedNodes[0].selected = false;\n          this.selectedNodes = [];\n        }\n        this.selectedNodes.push(node);\n      } else {\n        if (!this.options.disableDeselection) {\n          this.selectedNodes = this.selectedNodes.filter(\n            n => n.id !== node.id\n          );\n        } else {\n          node.selected = true;\n        }\n      }\n      this.propagateChange(this.options.multiselect ? this.selectedNodes : this.selectedNodes[0]);\n    }\n  }\n\n\n  public onNodeExpanded(node: TreeNode) {\n    this.collectVisibleNodes(node);\n    this.expandedNodesChanged.emit(this._expandedNodes);\n  }\n\n\n  public toggleExpanded(node: TreeNode) {\n    if (node.children && node.children.length) {\n      node.expanded = !node.expanded;\n      this.onNodeExpanded(node);\n    }\n  }\n\n\n  // Update the tree according to the selected nodes\n  private updateTree(tree?: any) {\n    if (tree || this.tree) {\n      this.tree = (tree || this.tree).map(node => this.updateTreeNode(node, []));\n      this.collectVisibleNodes();\n    }\n  }\n\n\n  // Recursive function walking the tree nodes and setting the nodes `selected` flags\n  private updateTreeNode(node: TreeNode, parents: TreeNode[]) {\n    node.selected = !!this.selectedNodes.find(n => node.id === n.id || (!n.id && node.data?.value === n.value));\n    node.expanded = this._expandedNodes.length ? !!this._expandedNodes.find(id => id === node.id) : node.expanded;\n    node.highlighted = !!this._highlightedNodes.find(id => id === node.id);\n    node.focused = this.focusedNode && this.focusedNode.id === node.id ? this.focusedNode.focused : false;\n    // node.level = parents.length;\n\n    // expand all parent nodes as well\n    if (node.selected && parents.length) {\n      parents.forEach(p => (p.expanded = true));\n    }\n    if (node.children) {\n      node.children.forEach(n => this.updateTreeNode(n, parents.concat([node])));\n    }\n    return node;\n  }\n\n  // Collect all visible nodes in the right order to be used to fetch the previous or\n  // next node using keyboard navigation.\n  private collectVisibleNodes(node?: TreeNode) {\n    this.visibleNodes = this.collectVisibleChildren(this.tree);\n    this.selectedNodes = this.visibleNodes.filter(n => n.selected);\n  }\n\n  // recursive part of collectChildNodes()\n  private collectVisibleChildren(nodes: TreeNode[] = []) {\n    let flat = [];\n    this._expandedNodes = [];\n    nodes.forEach(node => {\n      flat.push(node);\n      if (node.expanded) {\n        this._expandedNodes.push(node.id);\n        flat = flat.concat(this.collectVisibleChildren(node.children));\n      }\n    });\n    return flat;\n  }\n\n  private updateFocus(node?: TreeNode, old?: TreeNode) {\n    if (old) {\n      if (node !== old) {\n        old.focused = false;\n      }\n    } else {\n      this.visibleNodes.forEach(n => (n.focused = false));\n    }\n    if (node) {\n      const nodes = document.querySelectorAll('eo-tree-node');\n      nodes.forEach(n => {\n        if (n.querySelector('.label span').textContent === node.name) {\n          n.scrollIntoView({\n            behavior: \"smooth\",\n            block: \"start\",\n            inline: \"nearest\"\n          });\n        }\n      });\n      node.focused = true;\n      this.focusedNode = node;\n    }\n  }\n\n  private focusNode(next?: boolean) {\n    if (this.visibleNodes.length) {\n      let index = 0, shift = next ? 1 : -1;\n      const node = this.visibleNodes.find((n, i) => {\n        index = i;\n        return n.focused;\n      });\n\n      const nextIdx = node ? index + shift : 0;\n      const idx = nextIdx >= this.visibleNodes.length ? 0 : (nextIdx < 0 ? this.visibleNodes.length - 1 : nextIdx);\n      this.updateFocus(this.visibleNodes[idx], node);\n    }\n  }\n}\n","<div class=\"eo-tree\" eoRtlAware *ngIf=\"tree.length; else noTrees\">\n  <eo-tree-node *ngFor=\"let node of tree\" [node]=\"node\"\n                (onNodeExpandedChanged)=\"toggleExpanded($event)\"\n                (onNodeSelected)=\"onNodeSelected($event)\"></eo-tree-node>\n</div>\n\n<ng-template #noTrees>\n  <div class=\"tree tree-panel-error eo-body error\">\n    <eo-icon class=\"error error__icon\" [iconSrc]=\"'ic_error.svg'\"></eo-icon>\n    <p translate>{{emptyMessage}}</p>\n  </div>\n</ng-template>\n"]}
292
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../../../src/app/eo-framework/tree/tree.component.ts","../../../../../../../src/app/eo-framework/tree/tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  HostListener,\n  forwardRef,\n  ViewEncapsulation,\n  Input,\n  Output,\n  EventEmitter,\n  HostBinding, ElementRef, OnInit\n} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {TreeNode, TreeOptions} from './tree.component.interface';\n\n\n\n@Component({\n  selector: 'eo-tree',\n  templateUrl: './tree.component.html',\n  styleUrls: ['./tree.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TreeComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class TreeComponent implements ControlValueAccessor, OnInit {\n\n  @HostBinding('attr.tabindex') _tabIndex = 0;\n\n  private _expandedNodes: string[] = [];\n  private _highlightedNodes: string[] = [];\n  private selectedNodes: any[] = [];\n  private visibleNodes: any[] = [];\n  private focusedNode: TreeNode;\n\n  tree: TreeNode[];\n\n  @Input() options: TreeOptions = {};\n  @Input() isDisplayed: boolean;\n  @Input() readonly: boolean;\n  @Input() emptyMessage = 'eo.error.structure.tree.not.available';\n\n  @Input() selectionKey = ' '; // default is Space\n\n  // the nodes that are selected. In case of `multiselect` set to true, this will be an\n  @Output() expandedNodesChanged = new EventEmitter();\n  @Output() onSelected = new EventEmitter();\n\n  propagateChange = (_: any) => {\n  }\n\n  constructor(public elementRef: ElementRef) {\n  }\n\n  ngOnInit() {\n  }\n\n  @Input('highlightedNodes')\n  set highlightedNodes(nodes: string[]) {\n    this._highlightedNodes = nodes || [];\n    this.visibleNodes.forEach(n => (n.highlighted = !!this._highlightedNodes.find(id => id === n.id)));\n  }\n\n  @Input('tree')\n  set treeInput(tree: TreeNode[]) {\n    // this.tree = tree;\n    this.selectedNodes = [];\n    this._expandedNodes = [];\n    this.focusedNode = null;\n    this.updateTree(tree);\n  }\n\n  @Input('treeUpdate')\n  set treeUpdate(tree: TreeNode[]) {\n    if (tree) {\n      this.updateTree(tree);\n    }\n  }\n\n\n  @HostListener('focusin', ['$event.target'])\n  onFocusIn(target: any) {\n    if (!this.focusedNode || !this.focusedNode.focused) {\n      let node = this.selectedNodes[0] || this.visibleNodes[0];\n      this.updateFocus(node);\n    }\n  }\n\n    @HostListener('focusout')\n    onFocusOut() {\n      this.updateFocus();\n    }\n\n  onFocus(evt) {\n  }\n\n  onBlur(evt) {\n  }\n\n  onToggle(evt) {\n\n  }\n\n  @HostListener('keydown', ['$event'])\n  onKey(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'ArrowUp': {\n        this.focusNode(false);\n        this._ensureVisible();\n        break;\n      }\n      case 'ArrowDown': {\n        this.focusNode(true);\n        this._ensureVisible();\n        break;\n      }\n      case 'ArrowRight': {\n        this.toggleExpanded(this.focusedNode);\n        break;\n      }\n      case 'ArrowLeft': {\n        this.toggleExpanded(this.focusedNode);\n        break;\n      }\n      case this.selectionKey: {\n        // toggle selection of the focused node\n        if (this.focusedNode.selectable) {\n          // this.focusedNode.selected = !this.focusedNode.selected;\n          this.onNodeSelected(this.focusedNode);\n        }\n        break;\n      }\n      case 'Enter': {\n        // toggle selection of the focused node\n        if (this.focusedNode.selectable) {\n          // this.focusedNode.selected = !this.focusedNode.selected;\n          this.onNodeSelected(this.focusedNode);\n        }\n        break;\n      }\n    }\n\n    if (['ArrowUp', 'ArrowDown', 'ArrowRight', 'ArrowLeft'].includes(event.key)) {\n      event.stopPropagation();\n      event.preventDefault();\n    }\n  }\n\n\n  writeValue(selectedNodes: TreeNode[]): void {\n    let _selectedNodes = !selectedNodes || Array.isArray(selectedNodes) ? selectedNodes || [] : [selectedNodes];\n\n    if (this.selectedNodes.length !== _selectedNodes.length || this.selectedNodes.some((n, i) => n.id !== _selectedNodes[i].id)) {\n      this.selectedNodes = _selectedNodes;\n      this.updateTree(this.tree);\n    }\n\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  onNodeSelected(node) {\n    // if the selected node isn't allowed to be selected, we'll instead try to\n    // toggle expanded flag for parent nodes\n    this.onSelected.emit(node);\n    this.updateFocus(node, this.focusedNode);\n\n    if (!node.selectable) {\n      this.toggleExpanded(node);\n    } else {\n      node.selected = !node.selected;\n      if (node.selected) {\n        if (!this.options.multiselect && this.selectedNodes.length) {\n          this.selectedNodes[0].selected = false;\n          this.selectedNodes = [];\n        }\n        this.selectedNodes.push(node);\n      } else {\n        if (!this.options.disableDeselection) {\n          this.selectedNodes = this.selectedNodes.filter(\n            n => n.id !== node.id\n          );\n        } else {\n          node.selected = true;\n        }\n      }\n      this.propagateChange(this.options.multiselect ? this.selectedNodes : this.selectedNodes[0]);\n    }\n  }\n\n\n  public onNodeExpanded(node: TreeNode) {\n    this.collectVisibleNodes(node);\n    this.expandedNodesChanged.emit(this._expandedNodes);\n  }\n\n\n  public toggleExpanded(node: TreeNode) {\n    if (node.children && node.children.length) {\n      node.expanded = !node.expanded;\n      this.onNodeExpanded(node);\n    }\n  }\n\n\n  // Update the tree according to the selected nodes\n  private updateTree(tree?: any) {\n    if (tree || this.tree) {\n      this.tree = (tree || this.tree).map(node => this.updateTreeNode(node, []));\n      this.collectVisibleNodes();\n    }\n  }\n\n\n  // Recursive function walking the tree nodes and setting the nodes `selected` flags\n  private updateTreeNode(node: TreeNode, parents: TreeNode[]) {\n    node.selected = !!this.selectedNodes.find(n => node.id === n.id || (!n.id && node.data?.value === n.value));\n    node.expanded = this._expandedNodes.length ? !!this._expandedNodes.find(id => id === node.id) : node.expanded;\n    node.highlighted = !!this._highlightedNodes.find(id => id === node.id);\n    node.focused = this.focusedNode && this.focusedNode.id === node.id ? this.focusedNode.focused : false;\n    // node.level = parents.length;\n\n    // expand all parent nodes as well\n    if (node.selected && parents.length) {\n      parents.forEach(p => (p.expanded = true));\n    }\n    if (node.children) {\n      node.children.forEach(n => this.updateTreeNode(n, parents.concat([node])));\n    }\n    return node;\n  }\n\n  // Collect all visible nodes in the right order to be used to fetch the previous or\n  // next node using keyboard navigation.\n  private collectVisibleNodes(node?: TreeNode) {\n    this.visibleNodes = this.collectVisibleChildren(this.tree);\n    this.selectedNodes = this.visibleNodes.filter(n => n.selected);\n  }\n\n  // recursive part of collectChildNodes()\n  private collectVisibleChildren(nodes: TreeNode[] = []) {\n    let flat = [];\n    this._expandedNodes = [];\n    nodes.forEach(node => {\n      flat.push(node);\n      if (node.expanded) {\n        this._expandedNodes.push(node.id);\n        flat = flat.concat(this.collectVisibleChildren(node.children));\n      }\n    });\n    return flat;\n  }\n\n  private updateFocus(node?: TreeNode, old?: TreeNode) {\n    if (old) {\n      if (node !== old) {\n        old.focused = false;\n      }\n    } else {\n      this.visibleNodes.forEach(n => (n.focused = false));\n    }\n    if (node) {\n      node.focused = true;\n      this.focusedNode = node;\n    }\n  }\n\n  private _ensureVisible() {\n    setTimeout(() => {\n      const container: HTMLElement = this.elementRef.nativeElement;\n      const el = container.querySelector('eo-tree-node .label.focused');\n      const containerRect = container.getBoundingClientRect();\n      const elRect = el.getBoundingClientRect();\n      /* The first one checks the structure tree for scroll down\n       * The second one checks the structure tree for scroll up\n       * The third one checks the trees in selection dialogs for scroll down\n       * The fourth one checks the trees in selection dialogs for scroll up\n       */\n      if (elRect.bottom >= window.innerHeight\n        || elRect.top < 50\n        || elRect.bottom >= containerRect.height\n        || elRect.top - containerRect.top <= 30) {\n        el.scrollIntoView();\n      }\n    },  200)\n  }\n\n  private focusNode(next?: boolean) {\n    if (this.visibleNodes.length) {\n      let index = 0, shift = next ? 1 : -1;\n      const node = this.visibleNodes.find((n, i) => {\n        index = i;\n        return n.focused;\n      });\n\n      const nextIdx = node ? index + shift : 0;\n      const idx = nextIdx >= this.visibleNodes.length ? 0 : (nextIdx < 0 ? this.visibleNodes.length - 1 : nextIdx);\n      this.updateFocus(this.visibleNodes[idx], node);\n    }\n  }\n}\n","<div class=\"eo-tree\" eoRtlAware *ngIf=\"tree.length; else noTrees\">\n  <eo-tree-node *ngFor=\"let node of tree\" [node]=\"node\"\n                (onNodeExpandedChanged)=\"toggleExpanded($event)\"\n                (onNodeSelected)=\"onNodeSelected($event)\"></eo-tree-node>\n</div>\n\n<ng-template #noTrees>\n  <div class=\"tree tree-panel-error eo-body error\">\n    <eo-icon class=\"error error__icon\" [iconSrc]=\"'ic_error.svg'\"></eo-icon>\n    <p translate>{{emptyMessage}}</p>\n  </div>\n</ng-template>\n"]}