@bian-womp/spark-workbench 0.3.68 → 0.3.70
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.
- package/lib/cjs/index.cjs +22 -1
- package/lib/cjs/index.cjs.map +1 -1
- package/lib/cjs/src/core/InMemoryWorkbench.d.ts +1 -0
- package/lib/cjs/src/core/InMemoryWorkbench.d.ts.map +1 -1
- package/lib/esm/index.js +22 -1
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/src/core/InMemoryWorkbench.d.ts +1 -0
- package/lib/esm/src/core/InMemoryWorkbench.d.ts.map +1 -1
- package/package.json +4 -4
package/lib/cjs/index.cjs
CHANGED
|
@@ -281,11 +281,22 @@ class InMemoryWorkbench extends AbstractWorkbench {
|
|
|
281
281
|
return id;
|
|
282
282
|
}
|
|
283
283
|
removeNode(nodeId, options) {
|
|
284
|
+
const removedEdges = new Set();
|
|
284
285
|
this._def.nodes = this._def.nodes.filter((n) => n.nodeId !== nodeId);
|
|
285
|
-
this._def.edges = this._def.edges.filter((e) =>
|
|
286
|
+
this._def.edges = this._def.edges.filter((e) => {
|
|
287
|
+
if (e.source.nodeId === nodeId || e.target.nodeId === nodeId) {
|
|
288
|
+
removedEdges.add(e.id);
|
|
289
|
+
return false;
|
|
290
|
+
}
|
|
291
|
+
return true;
|
|
292
|
+
});
|
|
286
293
|
delete this.positions[nodeId];
|
|
287
294
|
delete this.sizes[nodeId];
|
|
288
295
|
delete this.nodeNames[nodeId];
|
|
296
|
+
this.setSelectionInternal({
|
|
297
|
+
nodes: this.selection.nodes.filter((id) => id !== nodeId),
|
|
298
|
+
edges: this.selection.edges.filter((id) => !removedEdges.has(id)),
|
|
299
|
+
}, options);
|
|
289
300
|
this.emit("graphChanged", {
|
|
290
301
|
def: this._def,
|
|
291
302
|
change: { type: "removeNode", nodeId },
|
|
@@ -564,6 +575,7 @@ class InMemoryWorkbench extends AbstractWorkbench {
|
|
|
564
575
|
const copiedNodes = nodesToCopy.map((node) => {
|
|
565
576
|
const pos = positions[node.nodeId];
|
|
566
577
|
const size = sizes[node.nodeId];
|
|
578
|
+
const customNodeData = this.getCustomNodeData(node.nodeId);
|
|
567
579
|
// Get all inbound edges for this node
|
|
568
580
|
const inboundEdges = this.def.edges.filter((e) => e.target.nodeId === node.nodeId);
|
|
569
581
|
// Build set of handles that have inbound edges
|
|
@@ -588,6 +600,9 @@ class InMemoryWorkbench extends AbstractWorkbench {
|
|
|
588
600
|
: undefined,
|
|
589
601
|
size,
|
|
590
602
|
inputs: inputsToCopy,
|
|
603
|
+
customData: customNodeData !== undefined
|
|
604
|
+
? lod.cloneDeep(customNodeData)
|
|
605
|
+
: undefined,
|
|
591
606
|
originalNodeId: node.nodeId,
|
|
592
607
|
};
|
|
593
608
|
});
|
|
@@ -864,6 +879,12 @@ class InMemoryWorkbench extends AbstractWorkbench {
|
|
|
864
879
|
dry: true,
|
|
865
880
|
});
|
|
866
881
|
nodeIdMap.set(nodeData.originalNodeId, newNodeId);
|
|
882
|
+
if (nodeData.customData !== undefined) {
|
|
883
|
+
this.setCustomNodeData(newNodeId, lod.cloneDeep(nodeData.customData), {
|
|
884
|
+
commit: false,
|
|
885
|
+
reason: options?.reason,
|
|
886
|
+
});
|
|
887
|
+
}
|
|
867
888
|
}
|
|
868
889
|
// Add edges
|
|
869
890
|
for (const edgeData of data.edges) {
|