qms-angular 2.0.14 → 2.0.15
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.
|
@@ -33,6 +33,7 @@ export class QMSNavDrawerComponent {
|
|
|
33
33
|
this.guidHelper = {
|
|
34
34
|
empty: '00000000-0000-0000-0000-000000000000'
|
|
35
35
|
};
|
|
36
|
+
this.activeRootId = null;
|
|
36
37
|
this.hasChild = (_, node) => node.expandable;
|
|
37
38
|
this.iterableDiffer = iterableDiffers.find([]).create(null);
|
|
38
39
|
}
|
|
@@ -116,12 +117,55 @@ export class QMSNavDrawerComponent {
|
|
|
116
117
|
}
|
|
117
118
|
});
|
|
118
119
|
}
|
|
120
|
+
// --- ADD THIS LOGIC ---
|
|
121
|
+
// Set the initial active root based on the opened nodes.
|
|
122
|
+
const activeNodeId = this.openNodes[this.openNodes.length - 1];
|
|
123
|
+
const activeNode = this.treeControl.dataNodes.find(n => n.id === activeNodeId);
|
|
124
|
+
if (activeNode) {
|
|
125
|
+
const root = this._findRootOfNode(activeNode);
|
|
126
|
+
if (root) {
|
|
127
|
+
this.activeRootId = root.id;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
// ----------------------
|
|
119
131
|
this._activeNode();
|
|
120
132
|
this.cdRef.detectChanges();
|
|
121
133
|
}
|
|
134
|
+
/**
|
|
135
|
+
* Traces back from a given node to find its root-level (level 0) ancestor.
|
|
136
|
+
*/
|
|
137
|
+
_findRootOfNode(node) {
|
|
138
|
+
const allNodes = this.treeControl.dataNodes;
|
|
139
|
+
const nodeIndex = allNodes.findIndex(n => n.id === node.id && n.parentId === node.parentId);
|
|
140
|
+
if (nodeIndex < 0) {
|
|
141
|
+
return null;
|
|
142
|
+
}
|
|
143
|
+
if (node.level === 0) {
|
|
144
|
+
return node;
|
|
145
|
+
}
|
|
146
|
+
let currentLevel = node.level - 1;
|
|
147
|
+
for (let i = nodeIndex - 1; i >= 0; i--) {
|
|
148
|
+
if (allNodes[i].level === currentLevel) {
|
|
149
|
+
if (currentLevel === 0) {
|
|
150
|
+
return allNodes[i]; // Found the root
|
|
151
|
+
}
|
|
152
|
+
currentLevel--; // Look for the next parent up
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
return null; // Should not happen in a well-formed tree
|
|
156
|
+
}
|
|
122
157
|
onClickNode(node) {
|
|
158
|
+
const rootOfClickedNode = this._findRootOfNode(node);
|
|
159
|
+
// --- CORE LOGIC ---
|
|
160
|
+
// Only collapse the tree if the new node belongs to a different root branch.
|
|
161
|
+
if (rootOfClickedNode && this.activeRootId && this.activeRootId !== rootOfClickedNode.id) {
|
|
162
|
+
this.treeControl.collapseAll();
|
|
163
|
+
}
|
|
164
|
+
// ------------------
|
|
165
|
+
if (rootOfClickedNode) {
|
|
166
|
+
this.activeRootId = rootOfClickedNode.id;
|
|
167
|
+
}
|
|
123
168
|
this.activeNode = this.getActiveNode(node.id, node.parentId);
|
|
124
|
-
this.treeControl.collapseAll();
|
|
125
169
|
this.onClickNodeEvent.emit(node);
|
|
126
170
|
this.scrollIntoNode$.next(this.activeNode);
|
|
127
171
|
}
|
|
@@ -221,4 +265,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
221
265
|
}], moveLocationEvent: [{
|
|
222
266
|
type: Output
|
|
223
267
|
}] } });
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qms-nav-drawer.component.js","sourceRoot":"","sources":["../../../../../../projects/qms-angular/src/lib/components/qms-nav-drawer/qms-nav-drawer.component.ts","../../../../../../projects/qms-angular/src/lib/components/qms-nav-drawer/qms-nav-drawer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAkE,MAAM,EAAiB,MAAM,eAAe,CAAC;AAClM,OAAO,EAAE,qBAAqB,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AACjF,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;AAU3C,MAAM,OAAO,qBAAqB;IA4BhC,YAAmB,mBAAyC,EAAU,KAAwB,EAAU,eAAgC;QAArH,wBAAmB,GAAnB,mBAAmB,CAAsB;QAAU,UAAK,GAAL,KAAK,CAAmB;QAAU,oBAAe,GAAf,eAAe,CAAiB;QA1B/H,oBAAe,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAC3D,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC3B,aAAQ,GAA6B,EAAE,CAAC;QACxC,cAAS,GAAa,EAAE,CAAC;QAKxB,oBAAe,GAAsB,IAAI,YAAY,EAAE,CAAC;QACxD,qBAAgB,GAAsB,IAAI,YAAY,EAAE,CAAC;QACzD,wBAAmB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC5D,qBAAgB,GAAsB,IAAI,YAAY,EAAE,CAAC;QACzD,sBAAiB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAGpE,gBAAW,GAAG,IAAI,eAAe,CAAoB,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAClG,kBAAa,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5H,eAAU,GAAG,IAAI,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAC7E,mBAAc,GAAwB,EAAE,CAAC;QAEzC,eAAU,GAAG;YACX,KAAK,EAAE,sCAAsC;SAC9C,CAAC;QAwBF,aAAQ,GAAG,CAAC,CAAS,EAAE,IAAuB,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;QAnBjE,IAAI,CAAC,cAAc,GAAG,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC9D,CAAC;IAED,YAAY,CAAC,IAAuB,EAAE,KAAa;QACjD,OAAO;YACL,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;YAChF,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,KAAK;YACL,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,UAAU,EAAE,IAAI,CAAC,UAAU;SAC5B,CAAC;IACJ,CAAC;IAID,WAAW,CAAC,OAAsB;QAEhC,IAAI,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;YACzH,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;QACvC,CAAC;QAED,IAAI,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE,CAAC;YAC5H,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,mBAAmB,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YAC/F,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;gBAEf,IAAI,gBAAgB,GAAG,EAAE,CAAC;gBAE1B,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;oBACd,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CACnC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC;oBAC5D,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;wBACd,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAC3B,CAAC;gBACH,CAAC,CAAC,CAAC;gBAEH,2BAA2B;gBAC3B,IAAI,gBAAgB,CAAC,MAAM,EAAE,CAAC;oBAC5B,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,gBAAgB,CAAC,CAAC;oBACxD,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBAC3D,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;gBAChC,CAAC;gBACD,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;oBACjC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC1G,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;wBACf,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;oBAC7D,CAAC;gBACH,CAAC,CAAC,CAAC;YAEL,CAAC;QACH,CAAC,CAAC,CAAC;QAGH,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACrC,IAAI,GAAG,EAAE,CAAC;gBACR,UAAU,CAAC,GAAG,EAAE;oBACd,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,uBAAuB,CAAC,CAAC;oBAChE,IAAI,OAAO,EAAE,CAAC;wBACZ,OAAO,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;oBACjD,CAAC;gBACH,CAAC,EAAE,GAAG,CAAC,CAAC;YAEV,CAAC;QACH,CAAC,CAAC,CAAA;IAEJ,CAAC;IAEO,WAAW;QACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9E,MAAM,UAAU,GAAG,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACrE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAC3D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IAED,aAAa,CAAC,EAAE,EAAE,QAAQ;QACxB,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACzB,MAAM,SAAS,GAAG,QAAQ,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;QACnF,OAAO,GAAG,GAAG,IAAI,SAAS,EAAE,CAAC;IAC/B,CAAC;IAED,kBAAkB,CAAC,iBAA0B,KAAK;QAChD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3D,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBAC1B,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;oBAC5C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;oBACxD,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzD,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,IAAuB;QACjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7D,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;QAE/B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IAED,YAAY,CAAC,IAAuB;QAClC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACtC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YAC9B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAChC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACtC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACrC,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;oBACrD,CAAC,CAAC,iBAAiB,GAAG,IAAI,CAAC;gBAC7B,CAAC;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACnF,CAAC;IACH,CAAC;IAED,cAAc,CAAC,IAAS,EAAE,KAAU;QAClC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;QACnC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,WAAW,CAAC,IAAS,EAAE,KAAU;QAC/B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,YAAY,CAAC,IAAS,EAAE,KAAU;QAChC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAEO,iBAAiB,CAAC,IAAuB;QAC/C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;YACrD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAEO,qBAAqB,CAAC,MAAc;QAC1C,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;IACzE,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;IAChC,CAAC;IAED,eAAe,CAAC,IAAI;QAClB,IAAI,GAAG,GAAG,EAAE,EAAE,IAAI,EAAE,KAAK,GAAG,EAAE,EAAE,CAAC,CAAC;QAClC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;YACpC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,CAAA,CAAC,qBAAqB;YAClE,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,0BAA0B;QACnD,CAAC;QAGD,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;YACpC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACf,MAAM,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;YAEnD,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;gBACpF,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;gBACvE,IAAI,MAAM,EAAE,CAAC;oBACX,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC7B,CAAC;YAEH,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnB,CAAC;QAEH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;+GA/NU,qBAAqB;mGAArB,qBAAqB,scCdlC,q3KAuGW;;4FDzFE,qBAAqB;kBAPjC,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM;uJAOtC,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEI,eAAe;sBAAxB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,mBAAmB;sBAA5B,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, IterableChanges, IterableDiffers, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { MatTreeFlatDataSource, MatTreeFlattener } from '@angular/material/tree';\r\nimport { BehaviorSubject, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { FlatNodeNavDrawer, TreeNodeNavDrawer } from './models/qms-nav-drawer.model';\r\nimport { QMSTreeGlobalService } from '../../services/qms-tree-global.service';\r\n@Component({\r\n  selector: 'qms-nav-drawer',\r\n  templateUrl: './qms-nav-drawer.component.html',\r\n  styleUrls: ['./qms-nav-drawer.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\n\r\nexport class QMSNavDrawerComponent implements OnInit, OnChanges, OnDestroy {\r\n\r\n  readonly scrollIntoNode$ = new BehaviorSubject<string>('');\r\n  ngUnsubscribe = new Subject<void>();\r\n  @Input() treeData: Array<TreeNodeNavDrawer> = [];\r\n  @Input() openNodes: string[] = [];\r\n  @Input() favoriteAction: any;\r\n  @Input() addLocationAction: any;\r\n  @Input() moveLocationMode: any;\r\n\r\n  @Output() nodeExpandEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() onClickNodeEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() updateFavoriteEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() addLocationEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() moveLocationEvent: EventEmitter<any> = new EventEmitter();\r\n\r\n\r\n  treeControl = new FlatTreeControl<FlatNodeNavDrawer>(node => node.level, node => node.expandable);\r\n  treeFlattener = new MatTreeFlattener(this._transformer, node => node.level, node => node.expandable, node => node.children);\r\n  dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);\r\n  expandingNodes: FlatNodeNavDrawer[] = [];\r\n  activeNode: string;\r\n  guidHelper = {\r\n    empty: '00000000-0000-0000-0000-000000000000'\r\n  };\r\n\r\n  iterableDiffer;\r\n\r\n  constructor(public qmsNavDrawerService: QMSTreeGlobalService, private cdRef: ChangeDetectorRef, private iterableDiffers: IterableDiffers) {\r\n    this.iterableDiffer = iterableDiffers.find([]).create(null);\r\n  }\r\n\r\n  _transformer(node: TreeNodeNavDrawer, level: number) {\r\n    return {\r\n      expandable: (!!node.children && node.children.length > 0) || (!!node.childCount),\r\n      name: node.name,\r\n      level,\r\n      id: node.id,\r\n      parentId: node.parentId,\r\n      itemIcon: node.itemIcon,\r\n      itemMatIcon: node.itemMatIcon,\r\n      itemIconSvg: node.itemIconSvg,\r\n      isFile: node.isFile,\r\n      markedGetChildren: node.markedGetChildren,\r\n      isFavorite: node.isFavorite\r\n    };\r\n  }\r\n\r\n  hasChild = (_: number, node: FlatNodeNavDrawer) => node.expandable;\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n\r\n    if (changes.treeData && JSON.stringify(changes.treeData.currentValue) !== JSON.stringify(changes.treeData.previousValue)) {\r\n      this.dataSource.data = this.treeData;\r\n    }\r\n\r\n    if (changes.openNodes && JSON.stringify(changes.openNodes.currentValue) !== JSON.stringify(changes.openNodes.previousValue)) {\r\n      this.findAndExpandNodes();\r\n      this._activeNode();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.qmsNavDrawerService.getItemsChildren$.pipe(takeUntil(this.ngUnsubscribe)).subscribe((res) => {\r\n      if (res.length) {\r\n\r\n        let newNodesChildren = [];\r\n\r\n        res.forEach(x => {\r\n          const index = this.treeData.findIndex(\r\n            item => item.id === x.id && item.parentId === x.parentId);\r\n          if (index < 0) {\r\n            newNodesChildren.push(x);\r\n          }\r\n        });\r\n\r\n        // Add children to treeData\r\n        if (newNodesChildren.length) {\r\n          this.treeData = [...this.treeData, ...newNodesChildren];\r\n          this.dataSource.data = this.convertTreeData(this.treeData);\r\n          this.findAndExpandNodes(true);\r\n        }\r\n        this.expandingNodes.forEach(node => {\r\n          const index = this.treeControl.dataNodes.findIndex(x => x.parentId === node.parentId && x.id === node.id);\r\n          if (index >= 0) {\r\n            this.treeControl.expand(this.treeControl.dataNodes[index]);\r\n          }\r\n        });\r\n\r\n      }\r\n    });\r\n\r\n\r\n    this.scrollIntoNode$.subscribe((res) => {\r\n      if (res) {\r\n        setTimeout(() => {\r\n          const element = document.querySelector('.mat-tree-node.active');\r\n          if (element) {\r\n            element.scrollIntoView({ behavior: 'smooth' });\r\n          }\r\n        }, 200);\r\n\r\n      }\r\n    })\r\n\r\n  }\r\n\r\n  private _activeNode() {\r\n    const currNode = this.openNodes[this.openNodes.length - 1];\r\n    const idxParent = this.openNodes.length >= 2 ? this.openNodes.length - 2 : '';\r\n    const parentNode = idxParent !== '' ? this.openNodes[idxParent] : '';\r\n    this.activeNode = this.getActiveNode(currNode, parentNode);\r\n    this.scrollIntoNode$.next(this.activeNode);\r\n  }\r\n\r\n  getActiveNode(id, parentId) {\r\n    const _id = id ? id : '';\r\n    const _parentId = parentId && (parentId !== this.guidHelper.empty) ? parentId : '';\r\n    return `${_id}-${_parentId}`;\r\n  }\r\n\r\n  findAndExpandNodes(expandNewChild: boolean = false) {\r\n    for (let i = 0; i < this.treeControl.dataNodes.length; i++) {\r\n      this.openNodes.forEach(el => {\r\n        if (this.treeControl.dataNodes[i].id === el) {\r\n          this.expandingNodes.push(this.treeControl.dataNodes[i]);\r\n          this.treeControl.expand(this.treeControl.dataNodes[i]);\r\n        }\r\n      });\r\n    }\r\n\r\n    this._activeNode();\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  onClickNode(node: FlatNodeNavDrawer) {\r\n    this.activeNode = this.getActiveNode(node.id, node.parentId);\r\n    this.treeControl.collapseAll();\r\n\r\n    this.onClickNodeEvent.emit(node);\r\n    this.scrollIntoNode$.next(this.activeNode);\r\n  }\r\n\r\n  onExpandNode(node: FlatNodeNavDrawer) {\r\n    this.openNodes = [];\r\n    if (this.treeControl.isExpanded(node)) {\r\n      this.treeControl.expand(node);\r\n      this._addExpandingNode(node);\r\n    } else {\r\n      this.treeControl.collapse(node);\r\n      this._removeExpandingNodes(node.id);\r\n    }\r\n\r\n    if (!node.markedGetChildren) {\r\n      node.markedGetChildren = true;\r\n      this.treeControl.dataNodes.forEach(x => {\r\n        if (x.parentId === node.parentId && x.id === node.id) {\r\n          x.markedGetChildren = true;\r\n        }\r\n      });\r\n      this.nodeExpandEvent.emit({ node, isExpand: this.treeControl.isExpanded(node) });\r\n    }\r\n  }\r\n\r\n  updateFavorite(node: any, event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    node.isFavorite = !node.isFavorite;\r\n    this.updateFavoriteEvent.emit(node);\r\n  }\r\n\r\n  addLocation(node: any, event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    this.addLocationEvent.emit(node);\r\n  }\r\n\r\n  moveLocation(node: any, event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    this.moveLocationEvent.emit(node);\r\n  }\r\n\r\n  private _addExpandingNode(node: FlatNodeNavDrawer): void {\r\n    if (!this.expandingNodes.some(x => x.id === node.id)) {\r\n      this.expandingNodes.push(node);\r\n    }\r\n  }\r\n\r\n  private _removeExpandingNodes(nodeId: string): void {\r\n    this.expandingNodes = this.expandingNodes.filter(x => x.id !== nodeId);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.ngUnsubscribe.next();\r\n    this.ngUnsubscribe.complete();\r\n  }\r\n\r\n  convertTreeData(list) {\r\n    let map = {}, node, roots = [], i;\r\n    for (i = 0; i < list.length; i += 1) {\r\n      map[`${list[i].id}-${list[i].parentId}`] = i // initialize the map\r\n      list[i].children = []; // initialize the children\r\n    }\r\n\r\n\r\n    for (i = 0; i < list.length; i += 1) {\r\n      node = list[i];\r\n      const strKey = `${list[i].id}-${list[i].parentId}`;\r\n\r\n      if (node.parentId && (node.parentId !== this.guidHelper.empty) && list[map[strKey]]) {\r\n        const parent = list.filter(x => x.id === node.parentId && !x.isFile)[0]\r\n        if (parent) {\r\n          parent.children.push(node);\r\n        }\r\n\r\n      } else {\r\n        roots.push(node);\r\n      }\r\n\r\n    }\r\n\r\n    return roots;\r\n  }\r\n\r\n}","<mat-tree class=\"qms-nav-drawer-container\" [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\r\n  <!-- This is the tree node template for leaf nodes -->\r\n  <mat-tree-node *matTreeNodeDef=\"let node\" matTreeNodeToggle matTreeNodePadding [ngClass]=\"{\r\n      active: activeNode === getActiveNode(node.id, node.parentId)\r\n    }\">\r\n\r\n    <div class=\"d-flex align-items-center w-100\">\r\n      <button aria-label=\"disabled\" mat-icon-button disabled></button>\r\n      <img *ngIf=\"node.itemIconSvg\" class=\"material-icons type-icon cursor-pointer\" [src]=\"node.itemIconSvg\"\r\n        (click)=\"onClickNode(node)\" alt=\"Image icon\" />\r\n      <span *ngIf=\"node.itemIcon\" [class]=\"node.itemIcon\" [qmsTransformIcon]=\"node.itemIcon\"\r\n        class=\"material-icons-outlined type-icon cursor-pointer\" (click)=\"onClickNode(node)\"></span>\r\n      <span *ngIf=\"node.itemMatIcon\" class=\"material-icons-outlined type-icon cursor-pointer\"\r\n        (click)=\"onClickNode(node)\">{{\r\n        node.itemMatIcon }}\r\n      </span>\r\n\r\n      <span class=\"text-name cursor-pointer mx-2\" (click)=\"onClickNode(node)\">{{ node.name }}</span>\r\n      <ng-container *ngIf=\"moveLocationMode\">\r\n        <button class=\"btn-action\" aria-label=\"Move location\" (click)=\"moveLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{moveLocationMode.tooltip}}\" mode=\"dark\">\r\n          <mat-icon>\r\n            swap_vert\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"favoriteAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add or remove favorite\" (click)=\"updateFavorite(node, $event)\"\r\n          qms-btn-icon color=\"light\"\r\n          qms-tool-tip=\"{{node.isFavorite ? favoriteAction.tooltipRemoveFavorite : favoriteAction.tooltipAddFavorite}}\"\r\n          mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\" [ngClass]=\"{'primary': node.isFavorite}\">\r\n            {{node.isFavorite ? 'star' : 'star_outline' }}\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n      <ng-container *ngIf=\"addLocationAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add location\" (click)=\"addLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{addLocationAction.tooltipAddLocation}}\" mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\">\r\n            add\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n    </div>\r\n\r\n\r\n  </mat-tree-node>\r\n  <!-- This is the tree node template for expandable nodes -->\r\n  <mat-tree-node *matTreeNodeDef=\"let node; when: hasChild\" matTreeNodePadding [ngClass]=\"{\r\n      'expand-node': treeControl.isExpanded(node),\r\n      'collapse-node': !treeControl.isExpanded(node),\r\n      active: activeNode === getActiveNode(node.id, node.parentId)\r\n    }\">\r\n\r\n    <div class=\"d-flex align-items-center w-100\">\r\n      <button mat-icon-button aria-label=\"Toggle expand\" (click)=\"onExpandNode(node)\" matTreeNodeToggle>\r\n        <mat-icon class=\"mat-icon-rtl-mirror\">\r\n          {{ treeControl.isExpanded(node) ? \"expand_more\" : \"chevron_right\" }}\r\n        </mat-icon>\r\n      </button>\r\n\r\n      <img *ngIf=\"node.itemIconSvg\" class=\"material-icons type-icon cursor-pointer\" [src]=\"node.itemIconSvg\"\r\n        (click)=\"onClickNode(node)\" alt=\"Image icon\" />\r\n      <span *ngIf=\"node.itemIcon\" [class]=\"node.itemIcon\" [qmsTransformIcon]=\"node.itemIcon\"\r\n        class=\"material-icons-outlined type-icon cursor-pointer\" (click)=\"onClickNode(node)\"></span>\r\n      <span *ngIf=\"node.itemMatIcon\" class=\"material-icons-outlined type-icon cursor-pointer\"\r\n        (click)=\"onClickNode(node)\">{{\r\n        node.itemMatIcon }}\r\n      </span>\r\n\r\n      <span class=\"text-name cursor-pointer mx-2\" (click)=\"onClickNode(node)\">{{ node.name }}</span>\r\n      <ng-container *ngIf=\"moveLocationMode\">\r\n        <button class=\"btn-action\" aria-label=\"Move location\" (click)=\"moveLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{moveLocationMode.tooltip}}\" mode=\"dark\">\r\n          <mat-icon>\r\n            swap_vert\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"favoriteAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add or remove favorite\" (click)=\"updateFavorite(node, $event)\"\r\n          qms-btn-icon color=\"light\"\r\n          qms-tool-tip=\"{{node.isFavorite ? favoriteAction.tooltipRemoveFavorite : favoriteAction.tooltipAddFavorite}}\"\r\n          mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\" [ngClass]=\"{'primary': node.isFavorite}\">\r\n            {{node.isFavorite ? 'star' : 'star_outline' }}\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n      <ng-container *ngIf=\"addLocationAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add location\" (click)=\"addLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{addLocationAction.tooltipAddLocation}}\" mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\">\r\n            add\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n    </div>\r\n  </mat-tree-node>\r\n</mat-tree>"]}
|
|
268
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qms-nav-drawer.component.js","sourceRoot":"","sources":["../../../../../../projects/qms-angular/src/lib/components/qms-nav-drawer/qms-nav-drawer.component.ts","../../../../../../projects/qms-angular/src/lib/components/qms-nav-drawer/qms-nav-drawer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FlatTreeControl } from '@angular/cdk/tree';\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, IterableChanges, IterableDiffers, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { MatTreeFlatDataSource, MatTreeFlattener } from '@angular/material/tree';\r\nimport { BehaviorSubject, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { FlatNodeNavDrawer, TreeNodeNavDrawer } from './models/qms-nav-drawer.model';\r\nimport { QMSTreeGlobalService } from '../../services/qms-tree-global.service';\r\n@Component({\r\n  selector: 'qms-nav-drawer',\r\n  templateUrl: './qms-nav-drawer.component.html',\r\n  styleUrls: ['./qms-nav-drawer.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\n\r\nexport class QMSNavDrawerComponent implements OnInit, OnChanges, OnDestroy {\r\n\r\n  readonly scrollIntoNode$ = new BehaviorSubject<string>('');\r\n  ngUnsubscribe = new Subject<void>();\r\n  @Input() treeData: Array<TreeNodeNavDrawer> = [];\r\n  @Input() openNodes: string[] = [];\r\n  @Input() favoriteAction: any;\r\n  @Input() addLocationAction: any;\r\n  @Input() moveLocationMode: any;\r\n\r\n  @Output() nodeExpandEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() onClickNodeEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() updateFavoriteEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() addLocationEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() moveLocationEvent: EventEmitter<any> = new EventEmitter();\r\n\r\n\r\n  treeControl = new FlatTreeControl<FlatNodeNavDrawer>(node => node.level, node => node.expandable);\r\n  treeFlattener = new MatTreeFlattener(this._transformer, node => node.level, node => node.expandable, node => node.children);\r\n  dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);\r\n  expandingNodes: FlatNodeNavDrawer[] = [];\r\n  activeNode: string;\r\n  guidHelper = {\r\n    empty: '00000000-0000-0000-0000-000000000000'\r\n  };\r\n\r\n  iterableDiffer;\r\n  activeRootId: string | null = null;\r\n\r\n  constructor(public qmsNavDrawerService: QMSTreeGlobalService, private cdRef: ChangeDetectorRef, private iterableDiffers: IterableDiffers) {\r\n    this.iterableDiffer = iterableDiffers.find([]).create(null);\r\n  }\r\n\r\n  _transformer(node: TreeNodeNavDrawer, level: number) {\r\n    return {\r\n      expandable: (!!node.children && node.children.length > 0) || (!!node.childCount),\r\n      name: node.name,\r\n      level,\r\n      id: node.id,\r\n      parentId: node.parentId,\r\n      itemIcon: node.itemIcon,\r\n      itemMatIcon: node.itemMatIcon,\r\n      itemIconSvg: node.itemIconSvg,\r\n      isFile: node.isFile,\r\n      markedGetChildren: node.markedGetChildren,\r\n      isFavorite: node.isFavorite\r\n    };\r\n  }\r\n\r\n  hasChild = (_: number, node: FlatNodeNavDrawer) => node.expandable;\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n\r\n    if (changes.treeData && JSON.stringify(changes.treeData.currentValue) !== JSON.stringify(changes.treeData.previousValue)) {\r\n      this.dataSource.data = this.treeData;\r\n    }\r\n\r\n    if (changes.openNodes && JSON.stringify(changes.openNodes.currentValue) !== JSON.stringify(changes.openNodes.previousValue)) {\r\n      this.findAndExpandNodes();\r\n      this._activeNode();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.qmsNavDrawerService.getItemsChildren$.pipe(takeUntil(this.ngUnsubscribe)).subscribe((res) => {\r\n      if (res.length) {\r\n\r\n        let newNodesChildren = [];\r\n\r\n        res.forEach(x => {\r\n          const index = this.treeData.findIndex(\r\n            item => item.id === x.id && item.parentId === x.parentId);\r\n          if (index < 0) {\r\n            newNodesChildren.push(x);\r\n          }\r\n        });\r\n\r\n        // Add children to treeData\r\n        if (newNodesChildren.length) {\r\n          this.treeData = [...this.treeData, ...newNodesChildren];\r\n          this.dataSource.data = this.convertTreeData(this.treeData);\r\n          this.findAndExpandNodes(true);\r\n        }\r\n        this.expandingNodes.forEach(node => {\r\n          const index = this.treeControl.dataNodes.findIndex(x => x.parentId === node.parentId && x.id === node.id);\r\n          if (index >= 0) {\r\n            this.treeControl.expand(this.treeControl.dataNodes[index]);\r\n          }\r\n        });\r\n\r\n      }\r\n    });\r\n\r\n\r\n    this.scrollIntoNode$.subscribe((res) => {\r\n      if (res) {\r\n        setTimeout(() => {\r\n          const element = document.querySelector('.mat-tree-node.active');\r\n          if (element) {\r\n            element.scrollIntoView({ behavior: 'smooth' });\r\n          }\r\n        }, 200);\r\n\r\n      }\r\n    })\r\n\r\n  }\r\n\r\n  private _activeNode() {\r\n    const currNode = this.openNodes[this.openNodes.length - 1];\r\n    const idxParent = this.openNodes.length >= 2 ? this.openNodes.length - 2 : '';\r\n    const parentNode = idxParent !== '' ? this.openNodes[idxParent] : '';\r\n    this.activeNode = this.getActiveNode(currNode, parentNode);\r\n    this.scrollIntoNode$.next(this.activeNode);\r\n  }\r\n\r\n  getActiveNode(id, parentId) {\r\n    const _id = id ? id : '';\r\n    const _parentId = parentId && (parentId !== this.guidHelper.empty) ? parentId : '';\r\n    return `${_id}-${_parentId}`;\r\n  }\r\n\r\n  private findAndExpandNodes(expandNewChild: boolean = false) {\r\n    for (let i = 0; i < this.treeControl.dataNodes.length; i++) {\r\n      this.openNodes.forEach(el => {\r\n        if (this.treeControl.dataNodes[i].id === el) {\r\n          this.expandingNodes.push(this.treeControl.dataNodes[i]);\r\n          this.treeControl.expand(this.treeControl.dataNodes[i]);\r\n        }\r\n      });\r\n    }\r\n\r\n    // --- ADD THIS LOGIC ---\r\n    // Set the initial active root based on the opened nodes.\r\n    const activeNodeId = this.openNodes[this.openNodes.length - 1];\r\n    const activeNode = this.treeControl.dataNodes.find(n => n.id === activeNodeId);\r\n    if (activeNode) {\r\n      const root = this._findRootOfNode(activeNode);\r\n      if (root) {\r\n        this.activeRootId = root.id;\r\n      }\r\n    }\r\n    // ----------------------\r\n\r\n    this._activeNode();\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  /**\r\n  * Traces back from a given node to find its root-level (level 0) ancestor.\r\n  */\r\n  private _findRootOfNode(node: FlatNodeNavDrawer): FlatNodeNavDrawer | null {\r\n    const allNodes = this.treeControl.dataNodes;\r\n    const nodeIndex = allNodes.findIndex(n => n.id === node.id && n.parentId === node.parentId);\r\n\r\n    if (nodeIndex < 0) { return null; }\r\n    if (node.level === 0) { return node; }\r\n\r\n    let currentLevel = node.level - 1;\r\n    for (let i = nodeIndex - 1; i >= 0; i--) {\r\n      if (allNodes[i].level === currentLevel) {\r\n        if (currentLevel === 0) {\r\n          return allNodes[i]; // Found the root\r\n        }\r\n        currentLevel--; // Look for the next parent up\r\n      }\r\n    }\r\n    return null; // Should not happen in a well-formed tree\r\n  }\r\n\r\n  onClickNode(node: FlatNodeNavDrawer) {\r\n    const rootOfClickedNode = this._findRootOfNode(node);\r\n\r\n    // --- CORE LOGIC ---\r\n    // Only collapse the tree if the new node belongs to a different root branch.\r\n    if (rootOfClickedNode && this.activeRootId && this.activeRootId !== rootOfClickedNode.id) {\r\n      this.treeControl.collapseAll();\r\n    }\r\n    // ------------------\r\n\r\n    if (rootOfClickedNode) {\r\n      this.activeRootId = rootOfClickedNode.id;\r\n    }\r\n\r\n    this.activeNode = this.getActiveNode(node.id, node.parentId);\r\n    this.onClickNodeEvent.emit(node);\r\n    this.scrollIntoNode$.next(this.activeNode);\r\n  }\r\n\r\n  onExpandNode(node: FlatNodeNavDrawer) {\r\n    this.openNodes = [];\r\n    if (this.treeControl.isExpanded(node)) {\r\n      this.treeControl.expand(node);\r\n      this._addExpandingNode(node);\r\n    } else {\r\n      this.treeControl.collapse(node);\r\n      this._removeExpandingNodes(node.id);\r\n    }\r\n\r\n    if (!node.markedGetChildren) {\r\n      node.markedGetChildren = true;\r\n      this.treeControl.dataNodes.forEach(x => {\r\n        if (x.parentId === node.parentId && x.id === node.id) {\r\n          x.markedGetChildren = true;\r\n        }\r\n      });\r\n      this.nodeExpandEvent.emit({ node, isExpand: this.treeControl.isExpanded(node) });\r\n    }\r\n  }\r\n\r\n  updateFavorite(node: any, event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    node.isFavorite = !node.isFavorite;\r\n    this.updateFavoriteEvent.emit(node);\r\n  }\r\n\r\n  addLocation(node: any, event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    this.addLocationEvent.emit(node);\r\n  }\r\n\r\n  moveLocation(node: any, event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    this.moveLocationEvent.emit(node);\r\n  }\r\n\r\n  private _addExpandingNode(node: FlatNodeNavDrawer): void {\r\n    if (!this.expandingNodes.some(x => x.id === node.id)) {\r\n      this.expandingNodes.push(node);\r\n    }\r\n  }\r\n\r\n  private _removeExpandingNodes(nodeId: string): void {\r\n    this.expandingNodes = this.expandingNodes.filter(x => x.id !== nodeId);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.ngUnsubscribe.next();\r\n    this.ngUnsubscribe.complete();\r\n  }\r\n\r\n  convertTreeData(list) {\r\n    let map = {}, node, roots = [], i;\r\n    for (i = 0; i < list.length; i += 1) {\r\n      map[`${list[i].id}-${list[i].parentId}`] = i // initialize the map\r\n      list[i].children = []; // initialize the children\r\n    }\r\n\r\n\r\n    for (i = 0; i < list.length; i += 1) {\r\n      node = list[i];\r\n      const strKey = `${list[i].id}-${list[i].parentId}`;\r\n\r\n      if (node.parentId && (node.parentId !== this.guidHelper.empty) && list[map[strKey]]) {\r\n        const parent = list.filter(x => x.id === node.parentId && !x.isFile)[0]\r\n        if (parent) {\r\n          parent.children.push(node);\r\n        }\r\n\r\n      } else {\r\n        roots.push(node);\r\n      }\r\n\r\n    }\r\n\r\n    return roots;\r\n  }\r\n\r\n}","<mat-tree class=\"qms-nav-drawer-container\" [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\r\n  <!-- This is the tree node template for leaf nodes -->\r\n  <mat-tree-node *matTreeNodeDef=\"let node\" matTreeNodeToggle matTreeNodePadding [ngClass]=\"{\r\n      active: activeNode === getActiveNode(node.id, node.parentId)\r\n    }\">\r\n\r\n    <div class=\"d-flex align-items-center w-100\">\r\n      <button aria-label=\"disabled\" mat-icon-button disabled></button>\r\n      <img *ngIf=\"node.itemIconSvg\" class=\"material-icons type-icon cursor-pointer\" [src]=\"node.itemIconSvg\"\r\n        (click)=\"onClickNode(node)\" alt=\"Image icon\" />\r\n      <span *ngIf=\"node.itemIcon\" [class]=\"node.itemIcon\" [qmsTransformIcon]=\"node.itemIcon\"\r\n        class=\"material-icons-outlined type-icon cursor-pointer\" (click)=\"onClickNode(node)\"></span>\r\n      <span *ngIf=\"node.itemMatIcon\" class=\"material-icons-outlined type-icon cursor-pointer\"\r\n        (click)=\"onClickNode(node)\">{{\r\n        node.itemMatIcon }}\r\n      </span>\r\n\r\n      <span class=\"text-name cursor-pointer mx-2\" (click)=\"onClickNode(node)\">{{ node.name }}</span>\r\n      <ng-container *ngIf=\"moveLocationMode\">\r\n        <button class=\"btn-action\" aria-label=\"Move location\" (click)=\"moveLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{moveLocationMode.tooltip}}\" mode=\"dark\">\r\n          <mat-icon>\r\n            swap_vert\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"favoriteAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add or remove favorite\" (click)=\"updateFavorite(node, $event)\"\r\n          qms-btn-icon color=\"light\"\r\n          qms-tool-tip=\"{{node.isFavorite ? favoriteAction.tooltipRemoveFavorite : favoriteAction.tooltipAddFavorite}}\"\r\n          mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\" [ngClass]=\"{'primary': node.isFavorite}\">\r\n            {{node.isFavorite ? 'star' : 'star_outline' }}\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n      <ng-container *ngIf=\"addLocationAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add location\" (click)=\"addLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{addLocationAction.tooltipAddLocation}}\" mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\">\r\n            add\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n    </div>\r\n\r\n\r\n  </mat-tree-node>\r\n  <!-- This is the tree node template for expandable nodes -->\r\n  <mat-tree-node *matTreeNodeDef=\"let node; when: hasChild\" matTreeNodePadding [ngClass]=\"{\r\n      'expand-node': treeControl.isExpanded(node),\r\n      'collapse-node': !treeControl.isExpanded(node),\r\n      active: activeNode === getActiveNode(node.id, node.parentId)\r\n    }\">\r\n\r\n    <div class=\"d-flex align-items-center w-100\">\r\n      <button mat-icon-button aria-label=\"Toggle expand\" (click)=\"onExpandNode(node)\" matTreeNodeToggle>\r\n        <mat-icon class=\"mat-icon-rtl-mirror\">\r\n          {{ treeControl.isExpanded(node) ? \"expand_more\" : \"chevron_right\" }}\r\n        </mat-icon>\r\n      </button>\r\n\r\n      <img *ngIf=\"node.itemIconSvg\" class=\"material-icons type-icon cursor-pointer\" [src]=\"node.itemIconSvg\"\r\n        (click)=\"onClickNode(node)\" alt=\"Image icon\" />\r\n      <span *ngIf=\"node.itemIcon\" [class]=\"node.itemIcon\" [qmsTransformIcon]=\"node.itemIcon\"\r\n        class=\"material-icons-outlined type-icon cursor-pointer\" (click)=\"onClickNode(node)\"></span>\r\n      <span *ngIf=\"node.itemMatIcon\" class=\"material-icons-outlined type-icon cursor-pointer\"\r\n        (click)=\"onClickNode(node)\">{{\r\n        node.itemMatIcon }}\r\n      </span>\r\n\r\n      <span class=\"text-name cursor-pointer mx-2\" (click)=\"onClickNode(node)\">{{ node.name }}</span>\r\n      <ng-container *ngIf=\"moveLocationMode\">\r\n        <button class=\"btn-action\" aria-label=\"Move location\" (click)=\"moveLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{moveLocationMode.tooltip}}\" mode=\"dark\">\r\n          <mat-icon>\r\n            swap_vert\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"favoriteAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add or remove favorite\" (click)=\"updateFavorite(node, $event)\"\r\n          qms-btn-icon color=\"light\"\r\n          qms-tool-tip=\"{{node.isFavorite ? favoriteAction.tooltipRemoveFavorite : favoriteAction.tooltipAddFavorite}}\"\r\n          mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\" [ngClass]=\"{'primary': node.isFavorite}\">\r\n            {{node.isFavorite ? 'star' : 'star_outline' }}\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n\r\n      <ng-container *ngIf=\"addLocationAction\">\r\n        <button class=\"btn-action\" aria-label=\"Add location\" (click)=\"addLocation(node, $event)\" qms-btn-icon\r\n          color=\"light\" qms-tool-tip=\"{{addLocationAction.tooltipAddLocation}}\" mode=\"dark\">\r\n          <mat-icon class=\"material-icons-outlined\">\r\n            add\r\n          </mat-icon>\r\n        </button>\r\n      </ng-container>\r\n    </div>\r\n  </mat-tree-node>\r\n</mat-tree>"]}
|
package/fesm2022/qms-angular.mjs
CHANGED
|
@@ -35487,6 +35487,7 @@ class QMSNavDrawerComponent {
|
|
|
35487
35487
|
this.guidHelper = {
|
|
35488
35488
|
empty: '00000000-0000-0000-0000-000000000000'
|
|
35489
35489
|
};
|
|
35490
|
+
this.activeRootId = null;
|
|
35490
35491
|
this.hasChild = (_, node) => node.expandable;
|
|
35491
35492
|
this.iterableDiffer = iterableDiffers.find([]).create(null);
|
|
35492
35493
|
}
|
|
@@ -35570,12 +35571,55 @@ class QMSNavDrawerComponent {
|
|
|
35570
35571
|
}
|
|
35571
35572
|
});
|
|
35572
35573
|
}
|
|
35574
|
+
// --- ADD THIS LOGIC ---
|
|
35575
|
+
// Set the initial active root based on the opened nodes.
|
|
35576
|
+
const activeNodeId = this.openNodes[this.openNodes.length - 1];
|
|
35577
|
+
const activeNode = this.treeControl.dataNodes.find(n => n.id === activeNodeId);
|
|
35578
|
+
if (activeNode) {
|
|
35579
|
+
const root = this._findRootOfNode(activeNode);
|
|
35580
|
+
if (root) {
|
|
35581
|
+
this.activeRootId = root.id;
|
|
35582
|
+
}
|
|
35583
|
+
}
|
|
35584
|
+
// ----------------------
|
|
35573
35585
|
this._activeNode();
|
|
35574
35586
|
this.cdRef.detectChanges();
|
|
35575
35587
|
}
|
|
35588
|
+
/**
|
|
35589
|
+
* Traces back from a given node to find its root-level (level 0) ancestor.
|
|
35590
|
+
*/
|
|
35591
|
+
_findRootOfNode(node) {
|
|
35592
|
+
const allNodes = this.treeControl.dataNodes;
|
|
35593
|
+
const nodeIndex = allNodes.findIndex(n => n.id === node.id && n.parentId === node.parentId);
|
|
35594
|
+
if (nodeIndex < 0) {
|
|
35595
|
+
return null;
|
|
35596
|
+
}
|
|
35597
|
+
if (node.level === 0) {
|
|
35598
|
+
return node;
|
|
35599
|
+
}
|
|
35600
|
+
let currentLevel = node.level - 1;
|
|
35601
|
+
for (let i = nodeIndex - 1; i >= 0; i--) {
|
|
35602
|
+
if (allNodes[i].level === currentLevel) {
|
|
35603
|
+
if (currentLevel === 0) {
|
|
35604
|
+
return allNodes[i]; // Found the root
|
|
35605
|
+
}
|
|
35606
|
+
currentLevel--; // Look for the next parent up
|
|
35607
|
+
}
|
|
35608
|
+
}
|
|
35609
|
+
return null; // Should not happen in a well-formed tree
|
|
35610
|
+
}
|
|
35576
35611
|
onClickNode(node) {
|
|
35612
|
+
const rootOfClickedNode = this._findRootOfNode(node);
|
|
35613
|
+
// --- CORE LOGIC ---
|
|
35614
|
+
// Only collapse the tree if the new node belongs to a different root branch.
|
|
35615
|
+
if (rootOfClickedNode && this.activeRootId && this.activeRootId !== rootOfClickedNode.id) {
|
|
35616
|
+
this.treeControl.collapseAll();
|
|
35617
|
+
}
|
|
35618
|
+
// ------------------
|
|
35619
|
+
if (rootOfClickedNode) {
|
|
35620
|
+
this.activeRootId = rootOfClickedNode.id;
|
|
35621
|
+
}
|
|
35577
35622
|
this.activeNode = this.getActiveNode(node.id, node.parentId);
|
|
35578
|
-
this.treeControl.collapseAll();
|
|
35579
35623
|
this.onClickNodeEvent.emit(node);
|
|
35580
35624
|
this.scrollIntoNode$.next(this.activeNode);
|
|
35581
35625
|
}
|