ngssm-tree 15.3.13 → 16.0.0

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 (102) hide show
  1. package/esm2022/lib/ngssm-expression-tree/components/ngssm-expression-tree/ngssm-expression-tree.component.mjs +122 -0
  2. package/esm2022/lib/ngssm-expression-tree/components/ngssm-expression-tree-node/ngssm-expression-tree-node.component.mjs +87 -0
  3. package/esm2022/lib/ngssm-expression-tree/components/ngssm-expression-tree-node-details/ngssm-expression-tree-node-details.component.mjs +68 -0
  4. package/esm2022/lib/ngssm-expression-tree/reducers/tree-node-edition.reducer.mjs +133 -0
  5. package/esm2022/lib/ngssm-expression-tree/reducers/tree-node-expand.reducer.mjs +97 -0
  6. package/esm2022/lib/ngssm-expression-tree/reducers/trees.reducer.mjs +49 -0
  7. package/esm2022/lib/ngssm-expression-tree/state/ngssm-expression-tree.state.mjs +22 -0
  8. package/esm2022/lib/ngssm-tree/components/ngssm-breadcrumb/ngssm-breadcrumb.component.mjs +64 -0
  9. package/esm2022/lib/ngssm-tree/components/ngssm-tree/ngssm-tree.component.mjs +129 -0
  10. package/esm2022/lib/ngssm-tree/components/ngssm-tree-search-dialog/ngssm-tree-search-dialog.component.mjs +125 -0
  11. package/esm2022/lib/ngssm-tree/effects/tree-node-loading.effect.mjs +60 -0
  12. package/esm2022/lib/ngssm-tree/effects/tree-nodes-searching.effect.mjs +90 -0
  13. package/esm2022/lib/ngssm-tree/reducers/tree-node-expand.reducer.mjs +138 -0
  14. package/esm2022/lib/ngssm-tree/reducers/tree-node-selection.reducer.mjs +37 -0
  15. package/esm2022/lib/ngssm-tree/reducers/tree-nodes-search.reducer.mjs +96 -0
  16. package/esm2022/lib/ngssm-tree/reducers/tree-nodes.reducer.mjs +60 -0
  17. package/esm2022/lib/ngssm-tree/reducers/trees.reducer.mjs +54 -0
  18. package/esm2022/lib/ngssm-tree/state/ngssm-tree.state.mjs +24 -0
  19. package/{fesm2020 → fesm2022}/ngssm-tree.mjs +57 -57
  20. package/{fesm2020 → fesm2022}/ngssm-tree.mjs.map +1 -1
  21. package/lib/ngssm-expression-tree/components/ngssm-expression-tree/ngssm-expression-tree.component.d.ts +1 -1
  22. package/lib/ngssm-expression-tree/components/ngssm-expression-tree-node/ngssm-expression-tree-node.component.d.ts +1 -1
  23. package/lib/ngssm-expression-tree/components/ngssm-expression-tree-node-details/ngssm-expression-tree-node-details.component.d.ts +1 -1
  24. package/lib/ngssm-tree/components/ngssm-breadcrumb/ngssm-breadcrumb.component.d.ts +1 -1
  25. package/lib/ngssm-tree/components/ngssm-tree/ngssm-tree.component.d.ts +1 -1
  26. package/package.json +5 -11
  27. package/esm2020/lib/ngssm-expression-tree/components/ngssm-expression-tree/ngssm-expression-tree.component.mjs +0 -121
  28. package/esm2020/lib/ngssm-expression-tree/components/ngssm-expression-tree-node/ngssm-expression-tree-node.component.mjs +0 -86
  29. package/esm2020/lib/ngssm-expression-tree/components/ngssm-expression-tree-node-details/ngssm-expression-tree-node-details.component.mjs +0 -67
  30. package/esm2020/lib/ngssm-expression-tree/reducers/tree-node-edition.reducer.mjs +0 -132
  31. package/esm2020/lib/ngssm-expression-tree/reducers/tree-node-expand.reducer.mjs +0 -96
  32. package/esm2020/lib/ngssm-expression-tree/reducers/trees.reducer.mjs +0 -48
  33. package/esm2020/lib/ngssm-expression-tree/state/ngssm-expression-tree.state.mjs +0 -22
  34. package/esm2020/lib/ngssm-tree/components/ngssm-breadcrumb/ngssm-breadcrumb.component.mjs +0 -63
  35. package/esm2020/lib/ngssm-tree/components/ngssm-tree/ngssm-tree.component.mjs +0 -128
  36. package/esm2020/lib/ngssm-tree/components/ngssm-tree-search-dialog/ngssm-tree-search-dialog.component.mjs +0 -124
  37. package/esm2020/lib/ngssm-tree/effects/tree-node-loading.effect.mjs +0 -59
  38. package/esm2020/lib/ngssm-tree/effects/tree-nodes-searching.effect.mjs +0 -89
  39. package/esm2020/lib/ngssm-tree/reducers/tree-node-expand.reducer.mjs +0 -137
  40. package/esm2020/lib/ngssm-tree/reducers/tree-node-selection.reducer.mjs +0 -36
  41. package/esm2020/lib/ngssm-tree/reducers/tree-nodes-search.reducer.mjs +0 -95
  42. package/esm2020/lib/ngssm-tree/reducers/tree-nodes.reducer.mjs +0 -59
  43. package/esm2020/lib/ngssm-tree/reducers/trees.reducer.mjs +0 -53
  44. package/esm2020/lib/ngssm-tree/state/ngssm-tree.state.mjs +0 -24
  45. package/fesm2015/ngssm-tree.mjs +0 -1609
  46. package/fesm2015/ngssm-tree.mjs.map +0 -1
  47. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/index.mjs +0 -0
  48. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-add-expression-tree-node.action.mjs +0 -0
  49. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-add-expression-tree-nodes.action.mjs +0 -0
  50. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-clear-expression-tree.action.mjs +0 -0
  51. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-collapse-all-expression-tree-nodes.action.mjs +0 -0
  52. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-collapse-expression-tree-node.action.mjs +0 -0
  53. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-delete-expression-tree-node.action.mjs +0 -0
  54. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-expand-all-expression-tree-nodes.action.mjs +0 -0
  55. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-expand-expression-tree-node.action.mjs +0 -0
  56. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-expression-tree-action-type.mjs +0 -0
  57. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-expression-tree-node.action.mjs +0 -0
  58. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-expression-tree.action.mjs +0 -0
  59. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-init-expression-tree.action.mjs +0 -0
  60. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/actions/ngssm-update-expression-tree-node.action.mjs +0 -0
  61. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/components/index.mjs +0 -0
  62. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/model/index.mjs +0 -0
  63. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/model/ngssm-expression-tree-config.mjs +0 -0
  64. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/model/ngssm-expression-tree-custom-component.mjs +0 -0
  65. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/model/ngssm-expression-tree-data.mjs +0 -0
  66. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/model/ngssm-expression-tree-node.mjs +0 -0
  67. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/model/ngssm-expression-tree.mjs +0 -0
  68. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/model/ngssm-node.mjs +0 -0
  69. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/ngssm-expression-tree-routes.mjs +0 -0
  70. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/provide-ngssm-expression-tree.mjs +0 -0
  71. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/public-api.mjs +0 -0
  72. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/reducers/index.mjs +0 -0
  73. /package/{esm2020 → esm2022}/lib/ngssm-expression-tree/state/index.mjs +0 -0
  74. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/collapse-node.action.mjs +0 -0
  75. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/delete-ngssm-tree.action.mjs +0 -0
  76. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/display-search-dialog.action.mjs +0 -0
  77. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/expand-node.action.mjs +0 -0
  78. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/index.mjs +0 -0
  79. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/init-ngssm-tree.action.mjs +0 -0
  80. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/load-children-of-node.action.mjs +0 -0
  81. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/ngssm-tree-action-type.mjs +0 -0
  82. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/register-nodes.action.mjs +0 -0
  83. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/register-partial-search-results.action.mjs +0 -0
  84. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/search-tree-nodes.action.mjs +0 -0
  85. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/select-node.action.mjs +0 -0
  86. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/tree-action.mjs +0 -0
  87. /package/{esm2020 → esm2022}/lib/ngssm-tree/actions/tree-node-action.mjs +0 -0
  88. /package/{esm2020 → esm2022}/lib/ngssm-tree/components/index.mjs +0 -0
  89. /package/{esm2020 → esm2022}/lib/ngssm-tree/model/index.mjs +0 -0
  90. /package/{esm2020 → esm2022}/lib/ngssm-tree/model/ngssm-tree-config.mjs +0 -0
  91. /package/{esm2020 → esm2022}/lib/ngssm-tree/model/ngssm-tree-data-service.mjs +0 -0
  92. /package/{esm2020 → esm2022}/lib/ngssm-tree/model/ngssm-tree-node.mjs +0 -0
  93. /package/{esm2020 → esm2022}/lib/ngssm-tree/model/ngssm-tree.mjs +0 -0
  94. /package/{esm2020 → esm2022}/lib/ngssm-tree/model/node-data.mjs +0 -0
  95. /package/{esm2020 → esm2022}/lib/ngssm-tree/model/search-status.mjs +0 -0
  96. /package/{esm2020 → esm2022}/lib/ngssm-tree/provide-ngssm-tree.mjs +0 -0
  97. /package/{esm2020 → esm2022}/lib/ngssm-tree/public-api.mjs +0 -0
  98. /package/{esm2020 → esm2022}/lib/ngssm-tree/state/index.mjs +0 -0
  99. /package/{esm2020 → esm2022}/lib/ngssm-tree/state/selectors.mjs +0 -0
  100. /package/{esm2020 → esm2022}/lib/ngssm-tree/state/tree-nodes-search.mjs +0 -0
  101. /package/{esm2020 → esm2022}/ngssm-tree.mjs +0 -0
  102. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
@@ -0,0 +1,122 @@
1
+ import { Component, ChangeDetectionStrategy, Input } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { ScrollingModule } from '@angular/cdk/scrolling';
4
+ import { MatCardModule } from '@angular/material/card';
5
+ import { MatDividerModule } from '@angular/material/divider';
6
+ import { MatIconModule } from '@angular/material/icon';
7
+ import { CdkMenuModule } from '@angular/cdk/menu';
8
+ import { BehaviorSubject, takeUntil } from 'rxjs';
9
+ import { NgSsmComponent } from 'ngssm-store';
10
+ import { selectNgssmExpressionTreeState } from '../../state';
11
+ import { NgssmCollapseAllExpressionTreeNodesAction, NgssmCollapseExpressionTreeNodeAction, NgssmExpandAllExpressionTreeNodesAction, NgssmExpandExpressionTreeNodeAction } from '../../actions';
12
+ import { NgssmExpressionTreeNodeComponent } from '../ngssm-expression-tree-node/ngssm-expression-tree-node.component';
13
+ import { NgssmExpressionTreeNodeDetailsComponent } from '../ngssm-expression-tree-node-details/ngssm-expression-tree-node-details.component';
14
+ import * as i0 from "@angular/core";
15
+ import * as i1 from "ngssm-store";
16
+ import * as i2 from "@angular/common";
17
+ import * as i3 from "@angular/cdk/scrolling";
18
+ import * as i4 from "@angular/material/card";
19
+ import * as i5 from "@angular/material/divider";
20
+ import * as i6 from "@angular/material/icon";
21
+ import * as i7 from "@angular/cdk/menu";
22
+ class NgssmExpressionTreeComponent extends NgSsmComponent {
23
+ constructor(store, changeDetectorRef) {
24
+ super(store);
25
+ this.changeDetectorRef = changeDetectorRef;
26
+ this._tree$ = new BehaviorSubject(undefined);
27
+ this._displayedNodes$ = new BehaviorSubject([]);
28
+ this._treeConfig$ = new BehaviorSubject(undefined);
29
+ this._tree$.pipe(takeUntil(this.unsubscribeAll$)).subscribe((tree) => {
30
+ const displayedNodes = [];
31
+ const collapsedNodes = new Set();
32
+ (tree?.nodes ?? []).forEach((node) => {
33
+ if (node.data.isExpandable === true && node.isExpanded === false) {
34
+ collapsedNodes.add(node.data.id);
35
+ }
36
+ if (!node.data.parentId || node.path.findIndex((p) => collapsedNodes.has(p)) === -1) {
37
+ displayedNodes.push(node);
38
+ }
39
+ });
40
+ this._displayedNodes$.next(displayedNodes);
41
+ });
42
+ }
43
+ set treeConfig(value) {
44
+ this._treeSubscription?.unsubscribe();
45
+ if (!value) {
46
+ this._treeConfig$.next(undefined);
47
+ return;
48
+ }
49
+ const config = {
50
+ ...value
51
+ };
52
+ if (!config.getNodeLabel) {
53
+ config.getNodeLabel = (node) => node.data.id;
54
+ }
55
+ if (!config.expandIconClass) {
56
+ config.expandIconClass = 'fa-solid fa-chevron-right';
57
+ }
58
+ if (!config.collapseIconClass) {
59
+ config.collapseIconClass = 'fa-solid fa-chevron-down';
60
+ }
61
+ this._treeConfig$.next(config);
62
+ this._treeSubscription = this.watch((s) => selectNgssmExpressionTreeState(s).trees[value.treeId]).subscribe((tree) => this._tree$.next(tree));
63
+ }
64
+ get treeConfig$() {
65
+ return this._treeConfig$.asObservable();
66
+ }
67
+ get displayedNodes$() {
68
+ return this._displayedNodes$.asObservable();
69
+ }
70
+ getItemId(_, node) {
71
+ return node.data.id;
72
+ }
73
+ getDefaultPadding() {
74
+ return this._treeConfig$.getValue()?.nodePadding ?? 20;
75
+ }
76
+ expand(node) {
77
+ const treeId = this._treeConfig$.getValue()?.treeId;
78
+ if (treeId) {
79
+ this.dispatchAction(new NgssmExpandExpressionTreeNodeAction(treeId, node.data.id));
80
+ }
81
+ }
82
+ collapse(node) {
83
+ const treeId = this._treeConfig$.getValue()?.treeId;
84
+ if (treeId) {
85
+ this.dispatchAction(new NgssmCollapseExpressionTreeNodeAction(treeId, node.data.id));
86
+ }
87
+ }
88
+ forceRefresh() {
89
+ this.changeDetectorRef.markForCheck();
90
+ }
91
+ expandAll() {
92
+ const treeId = this._treeConfig$.getValue()?.treeId;
93
+ if (treeId) {
94
+ this.dispatchAction(new NgssmExpandAllExpressionTreeNodesAction(treeId));
95
+ }
96
+ }
97
+ collapseAll() {
98
+ const treeId = this._treeConfig$.getValue()?.treeId;
99
+ if (treeId) {
100
+ this.dispatchAction(new NgssmCollapseAllExpressionTreeNodesAction(treeId));
101
+ }
102
+ }
103
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgssmExpressionTreeComponent, deps: [{ token: i1.Store }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
104
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgssmExpressionTreeComponent, isStandalone: true, selector: "ngssm-expression-tree", inputs: { treeConfig: "treeConfig" }, usesInheritance: true, ngImport: i0, template: "<mat-card class=\"flex-column-stretch fxFlex ngssm-expression-tree\" [cdkContextMenuTriggerFor]=\"contextMenu\">\n <mat-card-content class=\"flex-column-stretch fxFlex ngssm-expression-tree-content\"\n *ngIf=\"(treeConfig$ | async) as treeConfig\">\n <cdk-virtual-scroll-viewport [itemSize]=\"treeConfig.rowSize ?? 30\" class=\"fxFlex\"\n *ngIf=\"treeConfig.disableVirtualization !== true\">\n <div *cdkVirtualFor=\"let item of displayedNodes$ | async; trackBy: getItemId\"\n class=\"ngssm-expression-tree-node\" id=\"{{'node_' + item.data.id}}\">\n <ng-container *ngTemplateOutlet=\"nodeTemplate;context: {treeConfig, item}\"></ng-container>\n </div>\n </cdk-virtual-scroll-viewport>\n <div class=\"ngssm-expression-tree-nodes-container\" *ngIf=\"treeConfig.disableVirtualization === true\">\n <div *ngFor=\"let item of displayedNodes$ | async; trackBy: getItemId\" class=\"ngssm-expression-tree-node\"\n id=\"{{'node_' + item.data.id}}\">\n <ng-container *ngTemplateOutlet=\"nodeTemplate;context: {treeConfig, item}\"></ng-container>\n </div>\n </div>\n </mat-card-content>\n</mat-card>\n\n<ng-template #nodeTemplate let-treeConfig=\"treeConfig\" let-item=\"item\">\n <div class=\"flex-row-center fxFlex\" [style.height.px]=\"treeConfig.rowSize ?? 30\">\n <mat-divider [vertical]=\"true\" class=\"ngssm-expression-tree-node-divider\"\n [style.height.px]=\"treeConfig.rowSize ?? 30\" *ngFor=\"let part of item.path\"\n [style.margin-right.px]=\"getDefaultPadding()\">\n </mat-divider>\n <mat-icon class=\"{{treeConfig.expandIconClass}}\"\n *ngIf=\"(item.data.isExpandable || item.data.hasRowDetail) && item.isExpanded === false\"\n (click)=\"$event.stopPropagation();expand(item);\" id=\"expandIcon\">\n </mat-icon>\n <mat-icon class=\"{{treeConfig.collapseIconClass}}\"\n *ngIf=\"(item.data.isExpandable || item.data.hasRowDetail) && item.isExpanded === true\"\n (click)=\"$event.stopPropagation();collapse(item);\" id=\"collapseIcon\">\n </mat-icon>\n <ngssm-expression-tree-node [nodeId]=\"item.data.id\" [treeConfig]=\"treeConfig\">\n </ngssm-expression-tree-node>\n </div>\n <div *ngIf=\"item.data.hasRowDetail === true && item.isExpanded === true\" class=\"flex-row-center fxFlex\">\n <mat-divider [vertical]=\"true\" class=\"ngssm-expression-tree-node-divider\"\n [style.height.px]=\"detailContainer.getBoundingClientRect().height\" *ngFor=\" let part of item.path\"\n [style.margin-right.px]=\"getDefaultPadding()\">\n </mat-divider>\n\n <div #detailContainer class=\"ngssm-expression-tree-node-detail-component\">\n <ngssm-expression-tree-node-details [nodeId]=\"item.data.id\" [treeConfig]=\"treeConfig\"\n (heightChanged)=\"forceRefresh()\">\n </ngssm-expression-tree-node-details>\n </div>\n </div>\n</ng-template>\n\n<ng-template #contextMenu>\n <div class=\"ngssm-expression-tree-context-menu\" cdkMenu>\n <button class=\"ngssm-expression-tree-context-menu-item\" cdkMenuItem (click)=\"expandAll()\">Expand all</button>\n <button class=\"ngssm-expression-tree-context-menu-item\" cdkMenuItem (click)=\"collapseAll()\">\n Collapse all\n </button>\n </div>\n</ng-template>", styles: [":host{display:flex;flex-direction:column}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ScrollingModule }, { kind: "directive", type: i3.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i3.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i3.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i4.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i4.MatCardContent, selector: "mat-card-content" }, { kind: "ngmodule", type: MatDividerModule }, { kind: "component", type: i5.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: CdkMenuModule }, { kind: "directive", type: i7.CdkMenu, selector: "[cdkMenu]", outputs: ["closed"], exportAs: ["cdkMenu"] }, { kind: "directive", type: i7.CdkMenuItem, selector: "[cdkMenuItem]", inputs: ["cdkMenuItemDisabled", "cdkMenuitemTypeaheadLabel"], outputs: ["cdkMenuItemTriggered"], exportAs: ["cdkMenuItem"] }, { kind: "directive", type: i7.CdkContextMenuTrigger, selector: "[cdkContextMenuTriggerFor]", inputs: ["cdkContextMenuTriggerFor", "cdkContextMenuPosition", "cdkContextMenuTriggerData", "cdkContextMenuDisabled"], outputs: ["cdkContextMenuOpened", "cdkContextMenuClosed"], exportAs: ["cdkContextMenuTriggerFor"] }, { kind: "component", type: NgssmExpressionTreeNodeComponent, selector: "ngssm-expression-tree-node", inputs: ["nodeId", "treeConfig"] }, { kind: "component", type: NgssmExpressionTreeNodeDetailsComponent, selector: "ngssm-expression-tree-node-details", inputs: ["nodeId", "treeConfig"], outputs: ["heightChanged"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
105
+ }
106
+ export { NgssmExpressionTreeComponent };
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgssmExpressionTreeComponent, decorators: [{
108
+ type: Component,
109
+ args: [{ selector: 'ngssm-expression-tree', standalone: true, imports: [
110
+ CommonModule,
111
+ ScrollingModule,
112
+ MatCardModule,
113
+ MatDividerModule,
114
+ MatIconModule,
115
+ CdkMenuModule,
116
+ NgssmExpressionTreeNodeComponent,
117
+ NgssmExpressionTreeNodeDetailsComponent
118
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-card class=\"flex-column-stretch fxFlex ngssm-expression-tree\" [cdkContextMenuTriggerFor]=\"contextMenu\">\n <mat-card-content class=\"flex-column-stretch fxFlex ngssm-expression-tree-content\"\n *ngIf=\"(treeConfig$ | async) as treeConfig\">\n <cdk-virtual-scroll-viewport [itemSize]=\"treeConfig.rowSize ?? 30\" class=\"fxFlex\"\n *ngIf=\"treeConfig.disableVirtualization !== true\">\n <div *cdkVirtualFor=\"let item of displayedNodes$ | async; trackBy: getItemId\"\n class=\"ngssm-expression-tree-node\" id=\"{{'node_' + item.data.id}}\">\n <ng-container *ngTemplateOutlet=\"nodeTemplate;context: {treeConfig, item}\"></ng-container>\n </div>\n </cdk-virtual-scroll-viewport>\n <div class=\"ngssm-expression-tree-nodes-container\" *ngIf=\"treeConfig.disableVirtualization === true\">\n <div *ngFor=\"let item of displayedNodes$ | async; trackBy: getItemId\" class=\"ngssm-expression-tree-node\"\n id=\"{{'node_' + item.data.id}}\">\n <ng-container *ngTemplateOutlet=\"nodeTemplate;context: {treeConfig, item}\"></ng-container>\n </div>\n </div>\n </mat-card-content>\n</mat-card>\n\n<ng-template #nodeTemplate let-treeConfig=\"treeConfig\" let-item=\"item\">\n <div class=\"flex-row-center fxFlex\" [style.height.px]=\"treeConfig.rowSize ?? 30\">\n <mat-divider [vertical]=\"true\" class=\"ngssm-expression-tree-node-divider\"\n [style.height.px]=\"treeConfig.rowSize ?? 30\" *ngFor=\"let part of item.path\"\n [style.margin-right.px]=\"getDefaultPadding()\">\n </mat-divider>\n <mat-icon class=\"{{treeConfig.expandIconClass}}\"\n *ngIf=\"(item.data.isExpandable || item.data.hasRowDetail) && item.isExpanded === false\"\n (click)=\"$event.stopPropagation();expand(item);\" id=\"expandIcon\">\n </mat-icon>\n <mat-icon class=\"{{treeConfig.collapseIconClass}}\"\n *ngIf=\"(item.data.isExpandable || item.data.hasRowDetail) && item.isExpanded === true\"\n (click)=\"$event.stopPropagation();collapse(item);\" id=\"collapseIcon\">\n </mat-icon>\n <ngssm-expression-tree-node [nodeId]=\"item.data.id\" [treeConfig]=\"treeConfig\">\n </ngssm-expression-tree-node>\n </div>\n <div *ngIf=\"item.data.hasRowDetail === true && item.isExpanded === true\" class=\"flex-row-center fxFlex\">\n <mat-divider [vertical]=\"true\" class=\"ngssm-expression-tree-node-divider\"\n [style.height.px]=\"detailContainer.getBoundingClientRect().height\" *ngFor=\" let part of item.path\"\n [style.margin-right.px]=\"getDefaultPadding()\">\n </mat-divider>\n\n <div #detailContainer class=\"ngssm-expression-tree-node-detail-component\">\n <ngssm-expression-tree-node-details [nodeId]=\"item.data.id\" [treeConfig]=\"treeConfig\"\n (heightChanged)=\"forceRefresh()\">\n </ngssm-expression-tree-node-details>\n </div>\n </div>\n</ng-template>\n\n<ng-template #contextMenu>\n <div class=\"ngssm-expression-tree-context-menu\" cdkMenu>\n <button class=\"ngssm-expression-tree-context-menu-item\" cdkMenuItem (click)=\"expandAll()\">Expand all</button>\n <button class=\"ngssm-expression-tree-context-menu-item\" cdkMenuItem (click)=\"collapseAll()\">\n Collapse all\n </button>\n </div>\n</ng-template>", styles: [":host{display:flex;flex-direction:column}\n"] }]
119
+ }], ctorParameters: function () { return [{ type: i1.Store }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { treeConfig: [{
120
+ type: Input
121
+ }] } });
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngssm-expression-tree.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngssm-tree/src/lib/ngssm-expression-tree/components/ngssm-expression-tree/ngssm-expression-tree.component.ts","../../../../../../../projects/ngssm-tree/src/lib/ngssm-expression-tree/components/ngssm-expression-tree/ngssm-expression-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectionStrategy, Input, ChangeDetectorRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ScrollingModule } from '@angular/cdk/scrolling';\nimport { MatCardModule } from '@angular/material/card';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { MatIconModule } from '@angular/material/icon';\nimport { CdkMenuModule } from '@angular/cdk/menu';\nimport { BehaviorSubject, Observable, Subscription, takeUntil } from 'rxjs';\n\nimport { NgSsmComponent, Store } from 'ngssm-store';\n\nimport { NgssmExpressionTree, NgssmExpressionTreeConfig, NgssmExpressionTreeNode } from '../../model';\nimport { selectNgssmExpressionTreeState } from '../../state';\nimport {\n  NgssmCollapseAllExpressionTreeNodesAction,\n  NgssmCollapseExpressionTreeNodeAction,\n  NgssmExpandAllExpressionTreeNodesAction,\n  NgssmExpandExpressionTreeNodeAction\n} from '../../actions';\nimport { NgssmExpressionTreeNodeComponent } from '../ngssm-expression-tree-node/ngssm-expression-tree-node.component';\nimport { NgssmExpressionTreeNodeDetailsComponent } from '../ngssm-expression-tree-node-details/ngssm-expression-tree-node-details.component';\n\n@Component({\n  selector: 'ngssm-expression-tree',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ScrollingModule,\n    MatCardModule,\n    MatDividerModule,\n    MatIconModule,\n    CdkMenuModule,\n    NgssmExpressionTreeNodeComponent,\n    NgssmExpressionTreeNodeDetailsComponent\n  ],\n  templateUrl: './ngssm-expression-tree.component.html',\n  styleUrls: ['./ngssm-expression-tree.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NgssmExpressionTreeComponent extends NgSsmComponent {\n  private readonly _tree$ = new BehaviorSubject<NgssmExpressionTree | undefined>(undefined);\n  private readonly _displayedNodes$ = new BehaviorSubject<NgssmExpressionTreeNode[]>([]);\n  private readonly _treeConfig$ = new BehaviorSubject<NgssmExpressionTreeConfig | undefined>(undefined);\n\n  private _treeSubscription?: Subscription;\n\n  constructor(store: Store, private changeDetectorRef: ChangeDetectorRef) {\n    super(store);\n\n    this._tree$.pipe(takeUntil(this.unsubscribeAll$)).subscribe((tree) => {\n      const displayedNodes: NgssmExpressionTreeNode[] = [];\n      const collapsedNodes = new Set<string>();\n      (tree?.nodes ?? []).forEach((node) => {\n        if (node.data.isExpandable === true && node.isExpanded === false) {\n          collapsedNodes.add(node.data.id);\n        }\n\n        if (!node.data.parentId || node.path.findIndex((p) => collapsedNodes.has(p)) === -1) {\n          displayedNodes.push(node);\n        }\n      });\n\n      this._displayedNodes$.next(displayedNodes);\n    });\n  }\n\n  @Input() public set treeConfig(value: NgssmExpressionTreeConfig | null | undefined) {\n    this._treeSubscription?.unsubscribe();\n    if (!value) {\n      this._treeConfig$.next(undefined);\n      return;\n    }\n\n    const config: NgssmExpressionTreeConfig = {\n      ...value\n    };\n    if (!config.getNodeLabel) {\n      config.getNodeLabel = (node) => node.data.id;\n    }\n\n    if (!config.expandIconClass) {\n      config.expandIconClass = 'fa-solid fa-chevron-right';\n    }\n\n    if (!config.collapseIconClass) {\n      config.collapseIconClass = 'fa-solid fa-chevron-down';\n    }\n\n    this._treeConfig$.next(config);\n    this._treeSubscription = this.watch((s) => selectNgssmExpressionTreeState(s).trees[value.treeId]).subscribe((tree) =>\n      this._tree$.next(tree)\n    );\n  }\n\n  public get treeConfig$(): Observable<NgssmExpressionTreeConfig | undefined> {\n    return this._treeConfig$.asObservable();\n  }\n\n  public get displayedNodes$(): Observable<NgssmExpressionTreeNode[]> {\n    return this._displayedNodes$.asObservable();\n  }\n\n  public getItemId(_: number, node: NgssmExpressionTreeNode): string {\n    return node.data.id;\n  }\n\n  public getDefaultPadding(): number {\n    return this._treeConfig$.getValue()?.nodePadding ?? 20;\n  }\n\n  public expand(node: NgssmExpressionTreeNode): void {\n    const treeId = this._treeConfig$.getValue()?.treeId;\n    if (treeId) {\n      this.dispatchAction(new NgssmExpandExpressionTreeNodeAction(treeId, node.data.id));\n    }\n  }\n\n  public collapse(node: NgssmExpressionTreeNode): void {\n    const treeId = this._treeConfig$.getValue()?.treeId;\n    if (treeId) {\n      this.dispatchAction(new NgssmCollapseExpressionTreeNodeAction(treeId, node.data.id));\n    }\n  }\n\n  public forceRefresh(): void {\n    this.changeDetectorRef.markForCheck();\n  }\n\n  public expandAll(): void {\n    const treeId = this._treeConfig$.getValue()?.treeId;\n    if (treeId) {\n      this.dispatchAction(new NgssmExpandAllExpressionTreeNodesAction(treeId));\n    }\n  }\n\n  public collapseAll(): void {\n    const treeId = this._treeConfig$.getValue()?.treeId;\n    if (treeId) {\n      this.dispatchAction(new NgssmCollapseAllExpressionTreeNodesAction(treeId));\n    }\n  }\n}\n","<mat-card class=\"flex-column-stretch fxFlex ngssm-expression-tree\" [cdkContextMenuTriggerFor]=\"contextMenu\">\n    <mat-card-content class=\"flex-column-stretch fxFlex ngssm-expression-tree-content\"\n        *ngIf=\"(treeConfig$ | async) as treeConfig\">\n        <cdk-virtual-scroll-viewport [itemSize]=\"treeConfig.rowSize ?? 30\" class=\"fxFlex\"\n            *ngIf=\"treeConfig.disableVirtualization !== true\">\n            <div *cdkVirtualFor=\"let item of displayedNodes$ | async; trackBy: getItemId\"\n                class=\"ngssm-expression-tree-node\" id=\"{{'node_' + item.data.id}}\">\n                <ng-container *ngTemplateOutlet=\"nodeTemplate;context: {treeConfig, item}\"></ng-container>\n            </div>\n        </cdk-virtual-scroll-viewport>\n        <div class=\"ngssm-expression-tree-nodes-container\" *ngIf=\"treeConfig.disableVirtualization === true\">\n            <div *ngFor=\"let item of displayedNodes$ | async; trackBy: getItemId\" class=\"ngssm-expression-tree-node\"\n                id=\"{{'node_' + item.data.id}}\">\n                <ng-container *ngTemplateOutlet=\"nodeTemplate;context: {treeConfig, item}\"></ng-container>\n            </div>\n        </div>\n    </mat-card-content>\n</mat-card>\n\n<ng-template #nodeTemplate let-treeConfig=\"treeConfig\" let-item=\"item\">\n    <div class=\"flex-row-center fxFlex\" [style.height.px]=\"treeConfig.rowSize ?? 30\">\n        <mat-divider [vertical]=\"true\" class=\"ngssm-expression-tree-node-divider\"\n            [style.height.px]=\"treeConfig.rowSize ?? 30\" *ngFor=\"let part of item.path\"\n            [style.margin-right.px]=\"getDefaultPadding()\">\n        </mat-divider>\n        <mat-icon class=\"{{treeConfig.expandIconClass}}\"\n            *ngIf=\"(item.data.isExpandable || item.data.hasRowDetail) && item.isExpanded === false\"\n            (click)=\"$event.stopPropagation();expand(item);\" id=\"expandIcon\">\n        </mat-icon>\n        <mat-icon class=\"{{treeConfig.collapseIconClass}}\"\n            *ngIf=\"(item.data.isExpandable || item.data.hasRowDetail) && item.isExpanded === true\"\n            (click)=\"$event.stopPropagation();collapse(item);\" id=\"collapseIcon\">\n        </mat-icon>\n        <ngssm-expression-tree-node [nodeId]=\"item.data.id\" [treeConfig]=\"treeConfig\">\n        </ngssm-expression-tree-node>\n    </div>\n    <div *ngIf=\"item.data.hasRowDetail === true && item.isExpanded === true\" class=\"flex-row-center fxFlex\">\n        <mat-divider [vertical]=\"true\" class=\"ngssm-expression-tree-node-divider\"\n            [style.height.px]=\"detailContainer.getBoundingClientRect().height\" *ngFor=\" let part of item.path\"\n            [style.margin-right.px]=\"getDefaultPadding()\">\n        </mat-divider>\n\n        <div #detailContainer class=\"ngssm-expression-tree-node-detail-component\">\n            <ngssm-expression-tree-node-details [nodeId]=\"item.data.id\" [treeConfig]=\"treeConfig\"\n                (heightChanged)=\"forceRefresh()\">\n            </ngssm-expression-tree-node-details>\n        </div>\n    </div>\n</ng-template>\n\n<ng-template #contextMenu>\n    <div class=\"ngssm-expression-tree-context-menu\" cdkMenu>\n        <button class=\"ngssm-expression-tree-context-menu-item\" cdkMenuItem (click)=\"expandAll()\">Expand all</button>\n        <button class=\"ngssm-expression-tree-context-menu-item\" cdkMenuItem (click)=\"collapseAll()\">\n            Collapse all\n        </button>\n    </div>\n</ng-template>"]}
@@ -0,0 +1,87 @@
1
+ import { Component, ChangeDetectionStrategy, Input } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { MatIconModule } from '@angular/material/icon';
4
+ import { BehaviorSubject, combineLatest, filter, switchMap, takeUntil } from 'rxjs';
5
+ import { NgSsmComponent } from 'ngssm-store';
6
+ import { NgssmComponentDisplayDirective } from 'ngssm-toolkit';
7
+ import { selectNgssmExpressionTreeState } from '../../state';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "ngssm-store";
10
+ import * as i2 from "@angular/common";
11
+ import * as i3 from "@angular/material/icon";
12
+ class NgssmExpressionTreeNodeComponent extends NgSsmComponent {
13
+ constructor(store) {
14
+ super(store);
15
+ this._nodeId$ = new BehaviorSubject(undefined);
16
+ this._treeConfig$ = new BehaviorSubject(undefined);
17
+ this._nodeLabel$ = new BehaviorSubject('');
18
+ this._nodeCssIcon$ = new BehaviorSubject(undefined);
19
+ this._nodeDescription$ = new BehaviorSubject(undefined);
20
+ this._componentAction$ = new BehaviorSubject(undefined);
21
+ this._componentToDisplay$ = new BehaviorSubject(undefined);
22
+ combineLatest([this._nodeId$, this._treeConfig$])
23
+ .pipe(filter((v) => v[0] !== undefined && v[1] !== undefined), takeUntil(this.unsubscribeAll$), switchMap((v) => combineLatest([
24
+ this.watch((s) => selectNgssmExpressionTreeState(s).trees[v[1]?.treeId ?? 'unknown'].data[v[0] ?? 'unknown']),
25
+ this.watch((s) => selectNgssmExpressionTreeState(s).trees[v[1]?.treeId ?? 'unknown'].nodes)
26
+ ])), takeUntil(this.unsubscribeAll$))
27
+ .subscribe((values) => {
28
+ const node = values[1].find((v) => v.data.id === this._nodeId$.getValue());
29
+ const treeConfig = this._treeConfig$.getValue();
30
+ const nodeValue = values[0];
31
+ if (node && treeConfig && nodeValue) {
32
+ this._nodeLabel$.next(treeConfig.getNodeLabel?.(node, nodeValue) ?? '');
33
+ this._nodeCssIcon$.next(treeConfig.getNodeCssIcon?.(node, nodeValue) ?? undefined);
34
+ this._nodeDescription$.next(treeConfig.getNodeDescription?.(node, nodeValue));
35
+ }
36
+ });
37
+ combineLatest([this._nodeId$, this._treeConfig$])
38
+ .pipe(takeUntil(this.unsubscribeAll$))
39
+ .subscribe((values) => {
40
+ const treeConfig = values[1];
41
+ const nodeId = values[0];
42
+ if (treeConfig && nodeId) {
43
+ this._componentAction$.next((c) => c.setup(treeConfig.treeId, nodeId));
44
+ this._componentToDisplay$.next(treeConfig.nodeDescriptionComponent);
45
+ }
46
+ });
47
+ }
48
+ set nodeId(value) {
49
+ if (!value) {
50
+ return;
51
+ }
52
+ this._nodeId$.next(value);
53
+ }
54
+ set treeConfig(value) {
55
+ if (!value) {
56
+ return;
57
+ }
58
+ this._treeConfig$.next(value);
59
+ }
60
+ get nodeLabel$() {
61
+ return this._nodeLabel$.asObservable();
62
+ }
63
+ get nodeCssIcon$() {
64
+ return this._nodeCssIcon$.asObservable();
65
+ }
66
+ get nodeDescription$() {
67
+ return this._nodeDescription$.asObservable();
68
+ }
69
+ get componentAction$() {
70
+ return this._componentAction$.asObservable();
71
+ }
72
+ get componentToDisplay$() {
73
+ return this._componentToDisplay$.asObservable();
74
+ }
75
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgssmExpressionTreeNodeComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
76
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgssmExpressionTreeNodeComponent, isStandalone: true, selector: "ngssm-expression-tree-node", inputs: { nodeId: "nodeId", treeConfig: "treeConfig" }, usesInheritance: true, ngImport: i0, template: "<div class=\"ngssm-expression-tree-node-icon\" *ngIf=\"(nodeCssIcon$ | async) !== undefined\">\n <mat-icon class=\"{{nodeCssIcon$ | async}}\"></mat-icon>\n</div>\n\n<div class=\"ngssm-expression-tree-node-label\">\n {{nodeLabel$ | async}}\n</div>\n\n<div class=\"ngssm-expression-tree-node-description\" [innerHTML]=\"nodeDescription$ | async\">\n</div>\n\n<div class=\"ngssm-expression-tree-node-description-component\" [ngssmComponentDisplay]=\"componentToDisplay$ | async\"\n [ngssmComponentAction]=\"componentAction$ | async\">\n</div>", styles: [":host{display:flex;flex-direction:row;align-items:center;flex:1}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NgssmComponentDisplayDirective, selector: "[ngssmComponentDisplay]", inputs: ["ngssmComponentDisplay", "ngssmComponentAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
77
+ }
78
+ export { NgssmExpressionTreeNodeComponent };
79
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgssmExpressionTreeNodeComponent, decorators: [{
80
+ type: Component,
81
+ args: [{ selector: 'ngssm-expression-tree-node', standalone: true, imports: [CommonModule, MatIconModule, NgssmComponentDisplayDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ngssm-expression-tree-node-icon\" *ngIf=\"(nodeCssIcon$ | async) !== undefined\">\n <mat-icon class=\"{{nodeCssIcon$ | async}}\"></mat-icon>\n</div>\n\n<div class=\"ngssm-expression-tree-node-label\">\n {{nodeLabel$ | async}}\n</div>\n\n<div class=\"ngssm-expression-tree-node-description\" [innerHTML]=\"nodeDescription$ | async\">\n</div>\n\n<div class=\"ngssm-expression-tree-node-description-component\" [ngssmComponentDisplay]=\"componentToDisplay$ | async\"\n [ngssmComponentAction]=\"componentAction$ | async\">\n</div>", styles: [":host{display:flex;flex-direction:row;align-items:center;flex:1}\n"] }]
82
+ }], ctorParameters: function () { return [{ type: i1.Store }]; }, propDecorators: { nodeId: [{
83
+ type: Input
84
+ }], treeConfig: [{
85
+ type: Input
86
+ }] } });
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngssm-expression-tree-node.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngssm-tree/src/lib/ngssm-expression-tree/components/ngssm-expression-tree-node/ngssm-expression-tree-node.component.ts","../../../../../../../projects/ngssm-tree/src/lib/ngssm-expression-tree/components/ngssm-expression-tree-node/ngssm-expression-tree-node.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectionStrategy, Input } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatIconModule } from '@angular/material/icon';\nimport { BehaviorSubject, Observable, combineLatest, filter, switchMap, takeUntil } from 'rxjs';\n\nimport { NgSsmComponent, Store } from 'ngssm-store';\nimport { NgssmComponentAction, NgssmComponentDisplayDirective } from 'ngssm-toolkit';\n\nimport { NgssmExpressionTreeConfig, NgssmExpressionTreeCustomComponent } from '../../model';\nimport { selectNgssmExpressionTreeState } from '../../state';\n\n@Component({\n  selector: 'ngssm-expression-tree-node',\n  standalone: true,\n  imports: [CommonModule, MatIconModule, NgssmComponentDisplayDirective],\n  templateUrl: './ngssm-expression-tree-node.component.html',\n  styleUrls: ['./ngssm-expression-tree-node.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NgssmExpressionTreeNodeComponent extends NgSsmComponent {\n  private readonly _nodeId$ = new BehaviorSubject<string | undefined>(undefined);\n  private readonly _treeConfig$ = new BehaviorSubject<NgssmExpressionTreeConfig | undefined>(undefined);\n  private readonly _nodeLabel$ = new BehaviorSubject<string>('');\n  private readonly _nodeCssIcon$ = new BehaviorSubject<string | undefined>(undefined);\n  private readonly _nodeDescription$ = new BehaviorSubject<string | undefined>(undefined);\n  private readonly _componentAction$ = new BehaviorSubject<NgssmComponentAction | undefined>(undefined);\n  private readonly _componentToDisplay$ = new BehaviorSubject<any>(undefined);\n\n  constructor(store: Store) {\n    super(store);\n\n    combineLatest([this._nodeId$, this._treeConfig$])\n      .pipe(\n        filter((v) => v[0] !== undefined && v[1] !== undefined),\n        takeUntil(this.unsubscribeAll$),\n        switchMap((v) =>\n          combineLatest([\n            this.watch((s) => selectNgssmExpressionTreeState(s).trees[v[1]?.treeId ?? 'unknown'].data[v[0] ?? 'unknown']),\n            this.watch((s) => selectNgssmExpressionTreeState(s).trees[v[1]?.treeId ?? 'unknown'].nodes)\n          ])\n        ),\n        takeUntil(this.unsubscribeAll$)\n      )\n      .subscribe((values) => {\n        const node = values[1].find((v) => v.data.id === this._nodeId$.getValue());\n        const treeConfig = this._treeConfig$.getValue();\n        const nodeValue = values[0];\n        if (node && treeConfig && nodeValue) {\n          this._nodeLabel$.next(treeConfig.getNodeLabel?.(node, nodeValue) ?? '');\n          this._nodeCssIcon$.next(treeConfig.getNodeCssIcon?.(node, nodeValue) ?? undefined);\n          this._nodeDescription$.next(treeConfig.getNodeDescription?.(node, nodeValue));\n        }\n      });\n\n    combineLatest([this._nodeId$, this._treeConfig$])\n      .pipe(takeUntil(this.unsubscribeAll$))\n      .subscribe((values) => {\n        const treeConfig = values[1];\n        const nodeId = values[0];\n        if (treeConfig && nodeId) {\n          this._componentAction$.next((c: NgssmExpressionTreeCustomComponent) => c.setup(treeConfig.treeId, nodeId));\n          this._componentToDisplay$.next(treeConfig.nodeDescriptionComponent);\n        }\n      });\n  }\n\n  @Input() public set nodeId(value: string | null | undefined) {\n    if (!value) {\n      return;\n    }\n\n    this._nodeId$.next(value);\n  }\n\n  @Input() public set treeConfig(value: NgssmExpressionTreeConfig | null | undefined) {\n    if (!value) {\n      return;\n    }\n\n    this._treeConfig$.next(value);\n  }\n\n  public get nodeLabel$(): Observable<string> {\n    return this._nodeLabel$.asObservable();\n  }\n\n  public get nodeCssIcon$(): Observable<string | undefined> {\n    return this._nodeCssIcon$.asObservable();\n  }\n\n  public get nodeDescription$(): Observable<string | undefined> {\n    return this._nodeDescription$.asObservable();\n  }\n\n  public get componentAction$(): Observable<NgssmComponentAction | undefined> {\n    return this._componentAction$.asObservable();\n  }\n\n  public get componentToDisplay$(): Observable<any> {\n    return this._componentToDisplay$.asObservable();\n  }\n}\n","<div class=\"ngssm-expression-tree-node-icon\" *ngIf=\"(nodeCssIcon$ | async) !== undefined\">\n    <mat-icon class=\"{{nodeCssIcon$ | async}}\"></mat-icon>\n</div>\n\n<div class=\"ngssm-expression-tree-node-label\">\n    {{nodeLabel$ | async}}\n</div>\n\n<div class=\"ngssm-expression-tree-node-description\" [innerHTML]=\"nodeDescription$ | async\">\n</div>\n\n<div class=\"ngssm-expression-tree-node-description-component\" [ngssmComponentDisplay]=\"componentToDisplay$ | async\"\n    [ngssmComponentAction]=\"componentAction$ | async\">\n</div>"]}
@@ -0,0 +1,68 @@
1
+ import { Component, ChangeDetectionStrategy, Input, Output, EventEmitter } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { BehaviorSubject, Subject, combineLatest, take } from 'rxjs';
4
+ import { NgSsmComponent } from 'ngssm-store';
5
+ import { NgssmComponentDisplayDirective } from 'ngssm-toolkit';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "ngssm-store";
8
+ import * as i2 from "@angular/common";
9
+ class NgssmExpressionTreeNodeDetailsComponent extends NgSsmComponent {
10
+ constructor(store, elementRef) {
11
+ super(store);
12
+ this.elementRef = elementRef;
13
+ this._nodeId$ = new Subject();
14
+ this._treeConfig$ = new Subject();
15
+ this._componentAction$ = new BehaviorSubject(undefined);
16
+ this._componentToDisplay$ = new BehaviorSubject(undefined);
17
+ this.initialized = false;
18
+ this.heightChanged = new EventEmitter();
19
+ combineLatest([this._nodeId$, this._treeConfig$])
20
+ .pipe(take(1))
21
+ .subscribe((values) => {
22
+ this.initialized = true;
23
+ this._componentAction$.next((c) => c.setup(values[1].treeId, values[0]));
24
+ this._componentToDisplay$.next(values[1].nodeDetailComponent);
25
+ setTimeout(() => {
26
+ this.heightChanged.emit(this.elementRef?.nativeElement.getBoundingClientRect().height ?? 0);
27
+ });
28
+ });
29
+ }
30
+ set nodeId(value) {
31
+ if (!value) {
32
+ return;
33
+ }
34
+ if (this.initialized) {
35
+ throw new Error('Component NgssmExpressionTreeNodeDetailsComponent is already initialized.');
36
+ }
37
+ this._nodeId$.next(value);
38
+ }
39
+ set treeConfig(value) {
40
+ if (!value) {
41
+ return;
42
+ }
43
+ if (this.initialized) {
44
+ throw new Error('Component NgssmExpressionTreeNodeDetailsComponent is already initialized.');
45
+ }
46
+ this._treeConfig$.next(value);
47
+ }
48
+ get componentAction$() {
49
+ return this._componentAction$.asObservable();
50
+ }
51
+ get componentToDisplay$() {
52
+ return this._componentToDisplay$.asObservable();
53
+ }
54
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgssmExpressionTreeNodeDetailsComponent, deps: [{ token: i1.Store }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
55
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgssmExpressionTreeNodeDetailsComponent, isStandalone: true, selector: "ngssm-expression-tree-node-details", inputs: { nodeId: "nodeId", treeConfig: "treeConfig" }, outputs: { heightChanged: "heightChanged" }, usesInheritance: true, ngImport: i0, template: "<div [ngssmComponentDisplay]=\"componentToDisplay$ | async\" [ngssmComponentAction]=\"componentAction$ | async\"></div>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "directive", type: NgssmComponentDisplayDirective, selector: "[ngssmComponentDisplay]", inputs: ["ngssmComponentDisplay", "ngssmComponentAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
56
+ }
57
+ export { NgssmExpressionTreeNodeDetailsComponent };
58
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgssmExpressionTreeNodeDetailsComponent, decorators: [{
59
+ type: Component,
60
+ args: [{ selector: 'ngssm-expression-tree-node-details', standalone: true, imports: [CommonModule, NgssmComponentDisplayDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [ngssmComponentDisplay]=\"componentToDisplay$ | async\" [ngssmComponentAction]=\"componentAction$ | async\"></div>" }]
61
+ }], ctorParameters: function () { return [{ type: i1.Store }, { type: i0.ElementRef }]; }, propDecorators: { heightChanged: [{
62
+ type: Output
63
+ }], nodeId: [{
64
+ type: Input
65
+ }], treeConfig: [{
66
+ type: Input
67
+ }] } });
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdzc20tZXhwcmVzc2lvbi10cmVlLW5vZGUtZGV0YWlscy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3NzbS10cmVlL3NyYy9saWIvbmdzc20tZXhwcmVzc2lvbi10cmVlL2NvbXBvbmVudHMvbmdzc20tZXhwcmVzc2lvbi10cmVlLW5vZGUtZGV0YWlscy9uZ3NzbS1leHByZXNzaW9uLXRyZWUtbm9kZS1kZXRhaWxzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nc3NtLXRyZWUvc3JjL2xpYi9uZ3NzbS1leHByZXNzaW9uLXRyZWUvY29tcG9uZW50cy9uZ3NzbS1leHByZXNzaW9uLXRyZWUtbm9kZS1kZXRhaWxzL25nc3NtLWV4cHJlc3Npb24tdHJlZS1ub2RlLWRldGFpbHMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSx1QkFBdUIsRUFBRSxLQUFLLEVBQWMsTUFBTSxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGVBQWUsRUFBYyxPQUFPLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBYSxNQUFNLE1BQU0sQ0FBQztBQUU1RixPQUFPLEVBQUUsY0FBYyxFQUFTLE1BQU0sYUFBYSxDQUFDO0FBQ3BELE9BQU8sRUFBd0IsOEJBQThCLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFLckYsTUFRYSx1Q0FBd0MsU0FBUSxjQUFjO0lBVXpFLFlBQVksS0FBWSxFQUFVLFVBQXNCO1FBQ3RELEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQURtQixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBVHZDLGFBQVEsR0FBRyxJQUFJLE9BQU8sRUFBVSxDQUFDO1FBQ2pDLGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBQTZCLENBQUM7UUFDeEQsc0JBQWlCLEdBQUcsSUFBSSxlQUFlLENBQW1DLFNBQVMsQ0FBQyxDQUFDO1FBQ3JGLHlCQUFvQixHQUFHLElBQUksZUFBZSxDQUFNLFNBQVMsQ0FBQyxDQUFDO1FBRXBFLGdCQUFXLEdBQUcsS0FBSyxDQUFDO1FBRVgsa0JBQWEsR0FBeUIsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUtoRixhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQzthQUM5QyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ2IsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7WUFFeEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQXFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzdHLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLG1CQUFtQixDQUFDLENBQUM7WUFDOUQsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLGFBQWEsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQztZQUM5RixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELElBQW9CLE1BQU0sQ0FBQyxLQUFnQztRQUN6RCxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ1YsT0FBTztTQUNSO1FBRUQsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsMkVBQTJFLENBQUMsQ0FBQztTQUM5RjtRQUVELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFvQixVQUFVLENBQUMsS0FBbUQ7UUFDaEYsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNWLE9BQU87U0FDUjtRQUVELElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLDJFQUEyRSxDQUFDLENBQUM7U0FDOUY7UUFFRCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBRUQsSUFBVyxnQkFBZ0I7UUFDekIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDL0MsQ0FBQztJQUVELElBQVcsbUJBQW1CO1FBQzVCLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ2xELENBQUM7OEdBeERVLHVDQUF1QztrR0FBdkMsdUNBQXVDLDBOQ2xCcEQseUhBQW1ILHlERGF2RyxZQUFZLG9GQUFFLDhCQUE4Qjs7U0FLM0MsdUNBQXVDOzJGQUF2Qyx1Q0FBdUM7a0JBUm5ELFNBQVM7K0JBQ0Usb0NBQW9DLGNBQ2xDLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSw4QkFBOEIsQ0FBQyxtQkFHdEMsdUJBQXVCLENBQUMsTUFBTTtxSEFVOUIsYUFBYTtzQkFBN0IsTUFBTTtnQkFrQmEsTUFBTTtzQkFBekIsS0FBSztnQkFZYyxVQUFVO3NCQUE3QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgSW5wdXQsIEVsZW1lbnRSZWYsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBTdWJqZWN0LCBjb21iaW5lTGF0ZXN0LCB0YWtlLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgTmdTc21Db21wb25lbnQsIFN0b3JlIH0gZnJvbSAnbmdzc20tc3RvcmUnO1xuaW1wb3J0IHsgTmdzc21Db21wb25lbnRBY3Rpb24sIE5nc3NtQ29tcG9uZW50RGlzcGxheURpcmVjdGl2ZSB9IGZyb20gJ25nc3NtLXRvb2xraXQnO1xuXG5pbXBvcnQgeyBOZ3NzbUV4cHJlc3Npb25UcmVlQ29uZmlnLCBOZ3NzbUV4cHJlc3Npb25UcmVlQ3VzdG9tQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vbW9kZWwnO1xuaW1wb3J0IHsgc2VsZWN0Tmdzc21FeHByZXNzaW9uVHJlZVN0YXRlIH0gZnJvbSAnLi4vLi4vc3RhdGUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ3NzbS1leHByZXNzaW9uLXRyZWUtbm9kZS1kZXRhaWxzJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdzc21Db21wb25lbnREaXNwbGF5RGlyZWN0aXZlXSxcbiAgdGVtcGxhdGVVcmw6ICcuL25nc3NtLWV4cHJlc3Npb24tdHJlZS1ub2RlLWRldGFpbHMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9uZ3NzbS1leHByZXNzaW9uLXRyZWUtbm9kZS1kZXRhaWxzLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIE5nc3NtRXhwcmVzc2lvblRyZWVOb2RlRGV0YWlsc0NvbXBvbmVudCBleHRlbmRzIE5nU3NtQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSByZWFkb25seSBfbm9kZUlkJCA9IG5ldyBTdWJqZWN0PHN0cmluZz4oKTtcbiAgcHJpdmF0ZSByZWFkb25seSBfdHJlZUNvbmZpZyQgPSBuZXcgU3ViamVjdDxOZ3NzbUV4cHJlc3Npb25UcmVlQ29uZmlnPigpO1xuICBwcml2YXRlIHJlYWRvbmx5IF9jb21wb25lbnRBY3Rpb24kID0gbmV3IEJlaGF2aW9yU3ViamVjdDxOZ3NzbUNvbXBvbmVudEFjdGlvbiB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcbiAgcHJpdmF0ZSByZWFkb25seSBfY29tcG9uZW50VG9EaXNwbGF5JCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8YW55Pih1bmRlZmluZWQpO1xuXG4gIHByaXZhdGUgaW5pdGlhbGl6ZWQgPSBmYWxzZTtcblxuICBAT3V0cHV0KCkgcHVibGljIGhlaWdodENoYW5nZWQ6IEV2ZW50RW1pdHRlcjxudW1iZXI+ID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XG5cbiAgY29uc3RydWN0b3Ioc3RvcmU6IFN0b3JlLCBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcbiAgICBzdXBlcihzdG9yZSk7XG5cbiAgICBjb21iaW5lTGF0ZXN0KFt0aGlzLl9ub2RlSWQkLCB0aGlzLl90cmVlQ29uZmlnJF0pXG4gICAgICAucGlwZSh0YWtlKDEpKVxuICAgICAgLnN1YnNjcmliZSgodmFsdWVzKSA9PiB7XG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZWQgPSB0cnVlO1xuXG4gICAgICAgIHRoaXMuX2NvbXBvbmVudEFjdGlvbiQubmV4dCgoYzogTmdzc21FeHByZXNzaW9uVHJlZUN1c3RvbUNvbXBvbmVudCkgPT4gYy5zZXR1cCh2YWx1ZXNbMV0udHJlZUlkLCB2YWx1ZXNbMF0pKTtcbiAgICAgICAgdGhpcy5fY29tcG9uZW50VG9EaXNwbGF5JC5uZXh0KHZhbHVlc1sxXS5ub2RlRGV0YWlsQ29tcG9uZW50KTtcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgdGhpcy5oZWlnaHRDaGFuZ2VkLmVtaXQodGhpcy5lbGVtZW50UmVmPy5uYXRpdmVFbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpLmhlaWdodCA/PyAwKTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgfVxuXG4gIEBJbnB1dCgpIHB1YmxpYyBzZXQgbm9kZUlkKHZhbHVlOiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkKSB7XG4gICAgaWYgKCF2YWx1ZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGlmICh0aGlzLmluaXRpYWxpemVkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0NvbXBvbmVudCBOZ3NzbUV4cHJlc3Npb25UcmVlTm9kZURldGFpbHNDb21wb25lbnQgaXMgYWxyZWFkeSBpbml0aWFsaXplZC4nKTtcbiAgICB9XG5cbiAgICB0aGlzLl9ub2RlSWQkLm5leHQodmFsdWUpO1xuICB9XG5cbiAgQElucHV0KCkgcHVibGljIHNldCB0cmVlQ29uZmlnKHZhbHVlOiBOZ3NzbUV4cHJlc3Npb25UcmVlQ29uZmlnIHwgbnVsbCB8IHVuZGVmaW5lZCkge1xuICAgIGlmICghdmFsdWUpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5pbml0aWFsaXplZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdDb21wb25lbnQgTmdzc21FeHByZXNzaW9uVHJlZU5vZGVEZXRhaWxzQ29tcG9uZW50IGlzIGFscmVhZHkgaW5pdGlhbGl6ZWQuJyk7XG4gICAgfVxuXG4gICAgdGhpcy5fdHJlZUNvbmZpZyQubmV4dCh2YWx1ZSk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGNvbXBvbmVudEFjdGlvbiQoKTogT2JzZXJ2YWJsZTxOZ3NzbUNvbXBvbmVudEFjdGlvbiB8IHVuZGVmaW5lZD4ge1xuICAgIHJldHVybiB0aGlzLl9jb21wb25lbnRBY3Rpb24kLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgcHVibGljIGdldCBjb21wb25lbnRUb0Rpc3BsYXkkKCk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgcmV0dXJuIHRoaXMuX2NvbXBvbmVudFRvRGlzcGxheSQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cbn1cbiIsIjxkaXYgW25nc3NtQ29tcG9uZW50RGlzcGxheV09XCJjb21wb25lbnRUb0Rpc3BsYXkkIHwgYXN5bmNcIiBbbmdzc21Db21wb25lbnRBY3Rpb25dPVwiY29tcG9uZW50QWN0aW9uJCB8IGFzeW5jXCI+PC9kaXY+Il19
@@ -0,0 +1,133 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { NGSSM_REDUCER } from 'ngssm-store';
3
+ import { NgssmExpressionTreeActionType } from '../actions';
4
+ import { selectNgssmExpressionTreeState, updateNgssmExpressionTreeState } from '../state';
5
+ import * as i0 from "@angular/core";
6
+ class TreeNodeEditionReducer {
7
+ constructor() {
8
+ this.processedActions = [
9
+ NgssmExpressionTreeActionType.ngssmAddExpressionTreeNode,
10
+ NgssmExpressionTreeActionType.ngssmDeleteExpressionTreeNode,
11
+ NgssmExpressionTreeActionType.ngssmUpdateExpressionTreeNode,
12
+ NgssmExpressionTreeActionType.ngssmAddExpressionTreeNodes
13
+ ];
14
+ }
15
+ updateState(state, action) {
16
+ switch (action.type) {
17
+ case NgssmExpressionTreeActionType.ngssmAddExpressionTreeNode: {
18
+ const ngssmAddExpressionTreeNodeAction = action;
19
+ return updateNgssmExpressionTreeState(state, {
20
+ trees: {
21
+ [ngssmAddExpressionTreeNodeAction.treeId]: {
22
+ data: {
23
+ [ngssmAddExpressionTreeNodeAction.node.id]: { $set: ngssmAddExpressionTreeNodeAction.node.data }
24
+ },
25
+ nodes: {
26
+ $apply: (values) => {
27
+ const output = [...values];
28
+ this.addNodeToList(ngssmAddExpressionTreeNodeAction.node, output);
29
+ return output;
30
+ }
31
+ }
32
+ }
33
+ }
34
+ });
35
+ }
36
+ case NgssmExpressionTreeActionType.ngssmAddExpressionTreeNodes: {
37
+ const ngssmAddExpressionTreeNodesAction = action;
38
+ const newProps = {};
39
+ ngssmAddExpressionTreeNodesAction.nodes.forEach((node) => (newProps[node.id] = node.data));
40
+ return updateNgssmExpressionTreeState(state, {
41
+ trees: {
42
+ [ngssmAddExpressionTreeNodesAction.treeId]: {
43
+ data: { $merge: newProps },
44
+ nodes: {
45
+ $apply: (values) => {
46
+ const output = [...values];
47
+ ngssmAddExpressionTreeNodesAction.nodes.forEach((node) => this.addNodeToList(node, output));
48
+ return output;
49
+ }
50
+ }
51
+ }
52
+ }
53
+ });
54
+ }
55
+ case NgssmExpressionTreeActionType.ngssmDeleteExpressionTreeNode: {
56
+ const ngssmDeleteExpressionTreeNodeAction = action;
57
+ const nodeIdsToDelete = selectNgssmExpressionTreeState(state)
58
+ .trees[ngssmDeleteExpressionTreeNodeAction.treeId].nodes.filter((n) => n.path.includes(ngssmDeleteExpressionTreeNodeAction.nodeId))
59
+ .map((n) => n.data.id);
60
+ nodeIdsToDelete.push(ngssmDeleteExpressionTreeNodeAction.nodeId);
61
+ return updateNgssmExpressionTreeState(state, {
62
+ trees: {
63
+ [ngssmDeleteExpressionTreeNodeAction.treeId]: {
64
+ nodes: { $apply: (values) => values.filter((v) => !nodeIdsToDelete.includes(v.data.id)) },
65
+ data: { $unset: nodeIdsToDelete }
66
+ }
67
+ }
68
+ });
69
+ }
70
+ case NgssmExpressionTreeActionType.ngssmUpdateExpressionTreeNode: {
71
+ const ngssmUpdateExpressionTreeNodeAction = action;
72
+ return updateNgssmExpressionTreeState(state, {
73
+ trees: {
74
+ [ngssmUpdateExpressionTreeNodeAction.treeId]: {
75
+ data: {
76
+ [ngssmUpdateExpressionTreeNodeAction.nodeId]: { $set: ngssmUpdateExpressionTreeNodeAction.data }
77
+ }
78
+ }
79
+ }
80
+ });
81
+ }
82
+ }
83
+ return state;
84
+ }
85
+ addNodeToList(node, nodeList) {
86
+ if (node.parentId === undefined) {
87
+ nodeList.push({
88
+ path: [],
89
+ data: node,
90
+ isExpanded: true
91
+ });
92
+ return;
93
+ }
94
+ let parentNode;
95
+ let insertionIndex = -1;
96
+ for (let i = 0; i < nodeList.length; i++) {
97
+ if (parentNode) {
98
+ if (nodeList[i].path.includes(node.parentId)) {
99
+ insertionIndex = i + 1;
100
+ }
101
+ else {
102
+ break;
103
+ }
104
+ continue;
105
+ }
106
+ if (nodeList[i].data.id === node.parentId) {
107
+ parentNode = nodeList[i];
108
+ insertionIndex = i + 1;
109
+ continue;
110
+ }
111
+ }
112
+ if (!parentNode || insertionIndex === -1) {
113
+ throw new Error('Invalid parent id');
114
+ }
115
+ nodeList.splice(insertionIndex, 0, {
116
+ path: [...parentNode.path, parentNode.data.id],
117
+ data: node,
118
+ isExpanded: true
119
+ });
120
+ }
121
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TreeNodeEditionReducer, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
122
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TreeNodeEditionReducer }); }
123
+ }
124
+ export { TreeNodeEditionReducer };
125
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TreeNodeEditionReducer, decorators: [{
126
+ type: Injectable
127
+ }] });
128
+ export const treeNodeEditionReducerProvider = {
129
+ provide: NGSSM_REDUCER,
130
+ useClass: TreeNodeEditionReducer,
131
+ multi: true
132
+ };
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-node-edition.reducer.js","sourceRoot":"","sources":["../../../../../../projects/ngssm-tree/src/lib/ngssm-expression-tree/reducers/tree-node-edition.reducer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Provider } from '@angular/core';\n\nimport { Reducer, State, Action, NGSSM_REDUCER } from 'ngssm-store';\n\nimport {\n  NgssmAddExpressionTreeNodeAction,\n  NgssmAddExpressionTreeNodesAction,\n  NgssmDeleteExpressionTreeNodeAction,\n  NgssmExpressionTreeActionType,\n  NgssmUpdateExpressionTreeNodeAction\n} from '../actions';\nimport { selectNgssmExpressionTreeState, updateNgssmExpressionTreeState } from '../state';\nimport { NgssmExpressionTreeData, NgssmExpressionTreeNode, NgssmNode } from '../model';\n\n@Injectable()\nexport class TreeNodeEditionReducer implements Reducer {\n  public readonly processedActions: string[] = [\n    NgssmExpressionTreeActionType.ngssmAddExpressionTreeNode,\n    NgssmExpressionTreeActionType.ngssmDeleteExpressionTreeNode,\n    NgssmExpressionTreeActionType.ngssmUpdateExpressionTreeNode,\n    NgssmExpressionTreeActionType.ngssmAddExpressionTreeNodes\n  ];\n\n  public updateState(state: State, action: Action): State {\n    switch (action.type) {\n      case NgssmExpressionTreeActionType.ngssmAddExpressionTreeNode: {\n        const ngssmAddExpressionTreeNodeAction = action as NgssmAddExpressionTreeNodeAction;\n        return updateNgssmExpressionTreeState(state, {\n          trees: {\n            [ngssmAddExpressionTreeNodeAction.treeId]: {\n              data: {\n                [ngssmAddExpressionTreeNodeAction.node.id]: { $set: ngssmAddExpressionTreeNodeAction.node.data }\n              },\n              nodes: {\n                $apply: (values: NgssmExpressionTreeNode[]) => {\n                  const output: NgssmExpressionTreeNode[] = [...values];\n                  this.addNodeToList(ngssmAddExpressionTreeNodeAction.node, output);\n                  return output;\n                }\n              }\n            }\n          }\n        });\n      }\n\n      case NgssmExpressionTreeActionType.ngssmAddExpressionTreeNodes: {\n        const ngssmAddExpressionTreeNodesAction = action as NgssmAddExpressionTreeNodesAction;\n        const newProps: NgssmExpressionTreeData = {};\n        ngssmAddExpressionTreeNodesAction.nodes.forEach((node) => (newProps[node.id] = node.data));\n        return updateNgssmExpressionTreeState(state, {\n          trees: {\n            [ngssmAddExpressionTreeNodesAction.treeId]: {\n              data: { $merge: newProps },\n              nodes: {\n                $apply: (values: NgssmExpressionTreeNode[]) => {\n                  const output: NgssmExpressionTreeNode[] = [...values];\n                  ngssmAddExpressionTreeNodesAction.nodes.forEach((node) => this.addNodeToList(node, output));\n                  return output;\n                }\n              }\n            }\n          }\n        });\n      }\n\n      case NgssmExpressionTreeActionType.ngssmDeleteExpressionTreeNode: {\n        const ngssmDeleteExpressionTreeNodeAction = action as NgssmDeleteExpressionTreeNodeAction;\n        const nodeIdsToDelete: string[] = selectNgssmExpressionTreeState(state)\n          .trees[ngssmDeleteExpressionTreeNodeAction.treeId].nodes.filter((n) =>\n            n.path.includes(ngssmDeleteExpressionTreeNodeAction.nodeId)\n          )\n          .map((n) => n.data.id);\n        nodeIdsToDelete.push(ngssmDeleteExpressionTreeNodeAction.nodeId);\n        return updateNgssmExpressionTreeState(state, {\n          trees: {\n            [ngssmDeleteExpressionTreeNodeAction.treeId]: {\n              nodes: { $apply: (values: NgssmExpressionTreeNode[]) => values.filter((v) => !nodeIdsToDelete.includes(v.data.id)) },\n              data: { $unset: nodeIdsToDelete }\n            }\n          }\n        });\n      }\n\n      case NgssmExpressionTreeActionType.ngssmUpdateExpressionTreeNode: {\n        const ngssmUpdateExpressionTreeNodeAction = action as NgssmUpdateExpressionTreeNodeAction;\n        return updateNgssmExpressionTreeState(state, {\n          trees: {\n            [ngssmUpdateExpressionTreeNodeAction.treeId]: {\n              data: {\n                [ngssmUpdateExpressionTreeNodeAction.nodeId]: { $set: ngssmUpdateExpressionTreeNodeAction.data }\n              }\n            }\n          }\n        });\n      }\n    }\n\n    return state;\n  }\n\n  private addNodeToList(node: NgssmNode, nodeList: NgssmExpressionTreeNode[]): void {\n    if (node.parentId === undefined) {\n      nodeList.push({\n        path: [],\n        data: node,\n        isExpanded: true\n      });\n      return;\n    }\n\n    let parentNode: NgssmExpressionTreeNode | undefined;\n    let insertionIndex = -1;\n    for (let i = 0; i < nodeList.length; i++) {\n      if (parentNode) {\n        if (nodeList[i].path.includes(node.parentId)) {\n          insertionIndex = i + 1;\n        } else {\n          break;\n        }\n\n        continue;\n      }\n\n      if (nodeList[i].data.id === node.parentId) {\n        parentNode = nodeList[i];\n        insertionIndex = i + 1;\n        continue;\n      }\n    }\n\n    if (!parentNode || insertionIndex === -1) {\n      throw new Error('Invalid parent id');\n    }\n\n    nodeList.splice(insertionIndex, 0, {\n      path: [...parentNode.path, parentNode.data.id],\n      data: node,\n      isExpanded: true\n    });\n  }\n}\n\nexport const treeNodeEditionReducerProvider: Provider = {\n  provide: NGSSM_REDUCER,\n  useClass: TreeNodeEditionReducer,\n  multi: true\n};\n"]}