@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 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) => e.source.nodeId !== nodeId && e.target.nodeId !== nodeId);
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) {