@flowgram.ai/free-layout-core 0.5.0 → 0.5.2

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 (32) hide show
  1. package/dist/esm/{chunk-O4WKIIW2.js → chunk-3UW6BHP2.js} +1 -1
  2. package/dist/esm/chunk-3UW6BHP2.js.map +1 -0
  3. package/dist/esm/index.js +110 -38
  4. package/dist/esm/index.js.map +1 -1
  5. package/dist/esm/typings/index.js +1 -1
  6. package/dist/esm/typings/workflow-operation.js +1 -1
  7. package/dist/index.d.mts +5 -3
  8. package/dist/index.d.ts +5 -3
  9. package/dist/index.js +109 -37
  10. package/dist/index.js.map +1 -1
  11. package/dist/typings/index.d.mts +1 -1
  12. package/dist/typings/index.d.ts +1 -1
  13. package/dist/typings/index.js.map +1 -1
  14. package/dist/typings/workflow-drag.d.mts +1 -1
  15. package/dist/typings/workflow-drag.d.ts +1 -1
  16. package/dist/typings/workflow-json.d.mts +1 -1
  17. package/dist/typings/workflow-json.d.ts +1 -1
  18. package/dist/typings/workflow-line.d.mts +1 -1
  19. package/dist/typings/workflow-line.d.ts +1 -1
  20. package/dist/typings/workflow-node.d.mts +1 -1
  21. package/dist/typings/workflow-node.d.ts +1 -1
  22. package/dist/typings/workflow-operation.d.mts +9 -0
  23. package/dist/typings/workflow-operation.d.ts +9 -0
  24. package/dist/typings/workflow-operation.js.map +1 -1
  25. package/dist/typings/workflow-registry.d.mts +1 -1
  26. package/dist/typings/workflow-registry.d.ts +1 -1
  27. package/dist/typings/workflow-sub-canvas.d.mts +1 -1
  28. package/dist/typings/workflow-sub-canvas.d.ts +1 -1
  29. package/dist/{workflow-node-entity-lKu00Aj4.d.mts → workflow-node-entity-DgQT-wl9.d.mts} +16 -3
  30. package/dist/{workflow-node-entity-Cnte2phX.d.ts → workflow-node-entity-kGsp2Roz.d.ts} +16 -3
  31. package/package.json +9 -9
  32. package/dist/esm/chunk-O4WKIIW2.js.map +0 -1
@@ -15,7 +15,7 @@ import {
15
15
  import "../chunk-DDJTYHXN.js";
16
16
  import {
17
17
  WorkflowOperationBaseService
18
- } from "../chunk-O4WKIIW2.js";
18
+ } from "../chunk-3UW6BHP2.js";
19
19
  import "../chunk-EUXUH3YW.js";
20
20
  export {
21
21
  LineColors,
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  WorkflowOperationBaseService
3
- } from "../chunk-O4WKIIW2.js";
3
+ } from "../chunk-3UW6BHP2.js";
4
4
  import "../chunk-EUXUH3YW.js";
5
5
  export {
6
6
  WorkflowOperationBaseService
package/dist/index.d.mts CHANGED
@@ -2,8 +2,8 @@ import { PlaygroundConfigEntity, CommandService, PlaygroundDragEvent, EntityData
2
2
  export { bindConfigEntity, useConfigEntity, useEntities, useEntityDataFromContext, useEntityFromContext, useListenEvents, usePlayground, usePlaygroundContainer, usePlaygroundContext, useRefresh, useService } from '@flowgram.ai/core';
3
3
  import { NodeFormProps } from '@flowgram.ai/node';
4
4
  import { FlowOperationBaseService, FlowNodeType, FlowOperationBaseServiceImpl, FlowNodeEntityOrId, FlowNodeEntity } from '@flowgram.ai/document';
5
- import { W as WorkflowJSON, L as LineCenterPoint, a as WorkflowDocument, b as WorkflowNodeEntity, c as WorkflowHoverService, d as WorkflowLinesManager, e as WorkflowSelectService, f as WorkflowDocumentOptions, g as LineEventProps, N as NodesDragEvent, h as WorkflowNodeJSON, i as WorkflowPortEntity, j as WorkflowLineEntity, O as OnDragLineEnd, k as LineRenderType, l as WorkflowLineRenderContribution, m as LinePosition } from './workflow-node-entity-lKu00Aj4.mjs';
6
- export { X as HoverPosition, F as LINE_HOVER_DISTANCE, x as LineColor, y as LineColors, w as LinePoint, v as LinePointLocation, u as LineType, C as NodesDragEndEvent, B as NodesDragStartEvent, D as NodesDraggingEvent, P as POINT_RADIUS, K as PORT_SIZE, p as WORKFLOW_LINE_ENTITY, Y as WorkfloEntityHoverable, s as WorkflowContentChangeEvent, r as WorkflowContentChangeType, _ as WorkflowDocumentOptionsDefault, Z as WorkflowDocumentProvider, V as WorkflowEntityHoverable, H as WorkflowLineEntityOpts, I as WorkflowLineInfo, G as WorkflowLinePortInfo, z as WorkflowLineRenderContributionFactory, J as WorkflowLineUIState, T as WorkflowNodeLines, U as WorkflowNodeLinesData, t as WorkflowNodeMeta, S as WorkflowNodePortsData, M as WorkflowPort, R as WorkflowPortEntityOpts, n as WorkflowPortType, Q as WorkflowPorts, A as WorkflowSubCanvas, q as domReactToBounds, o as getPortEntityId, E as onDragLineEndParams } from './workflow-node-entity-lKu00Aj4.mjs';
5
+ import { W as WorkflowJSON, L as LineCenterPoint, a as WorkflowDocument, b as WorkflowNodeEntity, c as WorkflowHoverService, d as WorkflowLinesManager, e as WorkflowSelectService, f as WorkflowDocumentOptions, g as LineEventProps, N as NodesDragEvent, h as WorkflowNodeJSON, i as WorkflowPortEntity, j as WorkflowLineEntity, O as OnDragLineEnd, k as LineRenderType, l as WorkflowLineRenderContribution, m as LinePosition } from './workflow-node-entity-DgQT-wl9.mjs';
6
+ export { X as HoverPosition, F as LINE_HOVER_DISTANCE, x as LineColor, y as LineColors, w as LinePoint, v as LinePointLocation, u as LineType, C as NodesDragEndEvent, B as NodesDragStartEvent, D as NodesDraggingEvent, P as POINT_RADIUS, K as PORT_SIZE, p as WORKFLOW_LINE_ENTITY, Y as WorkfloEntityHoverable, s as WorkflowContentChangeEvent, r as WorkflowContentChangeType, _ as WorkflowDocumentOptionsDefault, Z as WorkflowDocumentProvider, V as WorkflowEntityHoverable, H as WorkflowLineEntityOpts, I as WorkflowLineInfo, G as WorkflowLinePortInfo, z as WorkflowLineRenderContributionFactory, J as WorkflowLineUIState, T as WorkflowNodeLines, U as WorkflowNodeLinesData, t as WorkflowNodeMeta, S as WorkflowNodePortsData, M as WorkflowPort, R as WorkflowPortEntityOpts, n as WorkflowPortType, Q as WorkflowPorts, A as WorkflowSubCanvas, q as domReactToBounds, o as getPortEntityId, E as onDragLineEndParams } from './workflow-node-entity-DgQT-wl9.mjs';
7
7
  import * as _flowgram_ai_utils from '@flowgram.ai/utils';
8
8
  import { IPoint, Rectangle, DisposableCollection, Disposable } from '@flowgram.ai/utils';
9
9
  export { compose, composeAsync, delay } from '@flowgram.ai/utils';
@@ -228,9 +228,11 @@ declare class WorkflowResetLayoutService {
228
228
 
229
229
  declare class WorkflowOperationBaseServiceImpl extends FlowOperationBaseServiceImpl implements WorkflowOperationBaseService {
230
230
  protected document: WorkflowDocument;
231
+ linesManager: WorkflowLinesManager;
231
232
  private onNodePostionUpdateEmitter;
232
233
  readonly onNodePostionUpdate: _flowgram_ai_utils.Event<NodePostionUpdateEvent>;
233
234
  updateNodePosition(nodeOrId: FlowNodeEntityOrId, position: IPoint): void;
235
+ fromJSON(json: WorkflowJSON): void;
234
236
  }
235
237
 
236
238
  /**
@@ -355,7 +357,7 @@ interface NodeRenderReturnType {
355
357
  * 更新节点的扩展数据
356
358
  * @param extInfo
357
359
  */
358
- updateExtInfo<T = any>(extInfo: T): void;
360
+ updateExtInfo<T = any>(extInfo: T, fullUpdate?: boolean): void;
359
361
  /**
360
362
  * 展开/收起节点
361
363
  * @param expanded
package/dist/index.d.ts CHANGED
@@ -2,8 +2,8 @@ import { PlaygroundConfigEntity, CommandService, PlaygroundDragEvent, EntityData
2
2
  export { bindConfigEntity, useConfigEntity, useEntities, useEntityDataFromContext, useEntityFromContext, useListenEvents, usePlayground, usePlaygroundContainer, usePlaygroundContext, useRefresh, useService } from '@flowgram.ai/core';
3
3
  import { NodeFormProps } from '@flowgram.ai/node';
4
4
  import { FlowOperationBaseService, FlowNodeType, FlowOperationBaseServiceImpl, FlowNodeEntityOrId, FlowNodeEntity } from '@flowgram.ai/document';
5
- import { W as WorkflowJSON, L as LineCenterPoint, a as WorkflowDocument, b as WorkflowNodeEntity, c as WorkflowHoverService, d as WorkflowLinesManager, e as WorkflowSelectService, f as WorkflowDocumentOptions, g as LineEventProps, N as NodesDragEvent, h as WorkflowNodeJSON, i as WorkflowPortEntity, j as WorkflowLineEntity, O as OnDragLineEnd, k as LineRenderType, l as WorkflowLineRenderContribution, m as LinePosition } from './workflow-node-entity-Cnte2phX.js';
6
- export { X as HoverPosition, F as LINE_HOVER_DISTANCE, x as LineColor, y as LineColors, w as LinePoint, v as LinePointLocation, u as LineType, C as NodesDragEndEvent, B as NodesDragStartEvent, D as NodesDraggingEvent, P as POINT_RADIUS, K as PORT_SIZE, p as WORKFLOW_LINE_ENTITY, Y as WorkfloEntityHoverable, s as WorkflowContentChangeEvent, r as WorkflowContentChangeType, _ as WorkflowDocumentOptionsDefault, Z as WorkflowDocumentProvider, V as WorkflowEntityHoverable, H as WorkflowLineEntityOpts, I as WorkflowLineInfo, G as WorkflowLinePortInfo, z as WorkflowLineRenderContributionFactory, J as WorkflowLineUIState, T as WorkflowNodeLines, U as WorkflowNodeLinesData, t as WorkflowNodeMeta, S as WorkflowNodePortsData, M as WorkflowPort, R as WorkflowPortEntityOpts, n as WorkflowPortType, Q as WorkflowPorts, A as WorkflowSubCanvas, q as domReactToBounds, o as getPortEntityId, E as onDragLineEndParams } from './workflow-node-entity-Cnte2phX.js';
5
+ import { W as WorkflowJSON, L as LineCenterPoint, a as WorkflowDocument, b as WorkflowNodeEntity, c as WorkflowHoverService, d as WorkflowLinesManager, e as WorkflowSelectService, f as WorkflowDocumentOptions, g as LineEventProps, N as NodesDragEvent, h as WorkflowNodeJSON, i as WorkflowPortEntity, j as WorkflowLineEntity, O as OnDragLineEnd, k as LineRenderType, l as WorkflowLineRenderContribution, m as LinePosition } from './workflow-node-entity-kGsp2Roz.js';
6
+ export { X as HoverPosition, F as LINE_HOVER_DISTANCE, x as LineColor, y as LineColors, w as LinePoint, v as LinePointLocation, u as LineType, C as NodesDragEndEvent, B as NodesDragStartEvent, D as NodesDraggingEvent, P as POINT_RADIUS, K as PORT_SIZE, p as WORKFLOW_LINE_ENTITY, Y as WorkfloEntityHoverable, s as WorkflowContentChangeEvent, r as WorkflowContentChangeType, _ as WorkflowDocumentOptionsDefault, Z as WorkflowDocumentProvider, V as WorkflowEntityHoverable, H as WorkflowLineEntityOpts, I as WorkflowLineInfo, G as WorkflowLinePortInfo, z as WorkflowLineRenderContributionFactory, J as WorkflowLineUIState, T as WorkflowNodeLines, U as WorkflowNodeLinesData, t as WorkflowNodeMeta, S as WorkflowNodePortsData, M as WorkflowPort, R as WorkflowPortEntityOpts, n as WorkflowPortType, Q as WorkflowPorts, A as WorkflowSubCanvas, q as domReactToBounds, o as getPortEntityId, E as onDragLineEndParams } from './workflow-node-entity-kGsp2Roz.js';
7
7
  import * as _flowgram_ai_utils from '@flowgram.ai/utils';
8
8
  import { IPoint, Rectangle, DisposableCollection, Disposable } from '@flowgram.ai/utils';
9
9
  export { compose, composeAsync, delay } from '@flowgram.ai/utils';
@@ -228,9 +228,11 @@ declare class WorkflowResetLayoutService {
228
228
 
229
229
  declare class WorkflowOperationBaseServiceImpl extends FlowOperationBaseServiceImpl implements WorkflowOperationBaseService {
230
230
  protected document: WorkflowDocument;
231
+ linesManager: WorkflowLinesManager;
231
232
  private onNodePostionUpdateEmitter;
232
233
  readonly onNodePostionUpdate: _flowgram_ai_utils.Event<NodePostionUpdateEvent>;
233
234
  updateNodePosition(nodeOrId: FlowNodeEntityOrId, position: IPoint): void;
235
+ fromJSON(json: WorkflowJSON): void;
234
236
  }
235
237
 
236
238
  /**
@@ -355,7 +357,7 @@ interface NodeRenderReturnType {
355
357
  * 更新节点的扩展数据
356
358
  * @param extInfo
357
359
  */
358
- updateExtInfo<T = any>(extInfo: T): void;
360
+ updateExtInfo<T = any>(extInfo: T, fullUpdate?: boolean): void;
359
361
  /**
360
362
  * 展开/收起节点
361
363
  * @param expanded
package/dist/index.js CHANGED
@@ -1513,10 +1513,11 @@ function initFormDataFromJSON(node, json, isFirstCreate) {
1513
1513
  // src/workflow-document-option.ts
1514
1514
  var WorkflowDocumentOptions = Symbol("WorkflowDocumentOptions");
1515
1515
  var WorkflowDocumentOptionsDefault = {
1516
- cursors: {
1517
- grab: 'url(""), auto',
1518
- grabbing: 'url(""), auto'
1519
- },
1516
+ // cursors: {
1517
+ // grab: 'url(""), auto',
1518
+ // grabbing:
1519
+ // 'url(""), auto',
1520
+ // },
1520
1521
  fromNodeJSON(node, json, isFirstCreate) {
1521
1522
  initFormDataFromJSON(node, json, isFirstCreate);
1522
1523
  return;
@@ -2104,6 +2105,9 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2104
2105
  this._loading = false;
2105
2106
  this.onLoadedEmitter.fire();
2106
2107
  }
2108
+ /**
2109
+ * @deprecated use `ctx.operation.fromJSON` instead
2110
+ */
2107
2111
  async reload(json, delayTime = 0) {
2108
2112
  if (this.disposed) return;
2109
2113
  this._loading = true;
@@ -2124,7 +2128,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2124
2128
  edges: json.edges ?? []
2125
2129
  };
2126
2130
  this.entityManager.changeEntityLocked = true;
2127
- this.renderJSON(workflowJSON);
2131
+ this.batchAddFromJSON(workflowJSON);
2128
2132
  this.entityManager.changeEntityLocked = false;
2129
2133
  this.transformer.loading = false;
2130
2134
  if (fireRender) {
@@ -2144,9 +2148,17 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2144
2148
  * 创建流程节点
2145
2149
  * @param json
2146
2150
  */
2147
- createWorkflowNode(json, isClone = false, parentId) {
2151
+ createWorkflowNode(json, isClone = false, parentID) {
2152
+ return this._createWorkflowNode(json, { parentID });
2153
+ }
2154
+ /**
2155
+ * 创建流程节点
2156
+ * @param json
2157
+ */
2158
+ _createWorkflowNode(json, options) {
2159
+ const { parentID, onNodeCreated, onEdgeCreated } = options ?? {};
2148
2160
  const isExistedNode = this.getNode(json.id);
2149
- const parent = this.getNode(parentId ?? this.root.id) ?? this.root;
2161
+ const parent = this.getNode(parentID ?? this.root.id) ?? this.root;
2150
2162
  const node = this.addNode(
2151
2163
  {
2152
2164
  ...json,
@@ -2173,15 +2185,19 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2173
2185
  node.getData(import_core14.TransformData).update({
2174
2186
  position
2175
2187
  });
2176
- if (formMeta && formData && !formData.formModel.initialized) {
2177
- formData.createForm(formMeta, json.data);
2178
- formData.onDataChange(() => {
2179
- this.fireContentChange({
2180
- type: "NODE_DATA_CHANGE" /* NODE_DATA_CHANGE */,
2181
- toJSON: () => formData.toJSON(),
2182
- entity: node
2188
+ if (formMeta && formData) {
2189
+ if (!formData.formModel.initialized) {
2190
+ formData.createForm(formMeta, json.data);
2191
+ formData.onDataChange(() => {
2192
+ this.fireContentChange({
2193
+ type: "NODE_DATA_CHANGE" /* NODE_DATA_CHANGE */,
2194
+ toJSON: () => formData.toJSON(),
2195
+ entity: node
2196
+ });
2183
2197
  });
2184
- });
2198
+ } else {
2199
+ formData.updateFormValues(json.data);
2200
+ }
2185
2201
  }
2186
2202
  const positionData = node.getData(import_core14.PositionData);
2187
2203
  if (!isExistedNode) {
@@ -2220,11 +2236,12 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2220
2236
  });
2221
2237
  }
2222
2238
  if (json.blocks) {
2223
- this.renderJSON(
2239
+ this.batchAddFromJSON(
2224
2240
  { nodes: json.blocks, edges: json.edges ?? [] },
2225
2241
  {
2226
2242
  parent: node,
2227
- isClone
2243
+ onNodeCreated,
2244
+ onEdgeCreated
2228
2245
  }
2229
2246
  );
2230
2247
  }
@@ -2356,7 +2373,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2356
2373
  throw new Error(`[WorkflowDocument.createWorkflowNodeByType] Node Id "${id}" duplicated.`);
2357
2374
  }
2358
2375
  }
2359
- return this.createWorkflowNode(
2376
+ return this._createWorkflowNode(
2360
2377
  {
2361
2378
  ...json,
2362
2379
  id,
@@ -2367,13 +2384,15 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2367
2384
  blocks: json?.blocks,
2368
2385
  edges: json?.edges
2369
2386
  },
2370
- false,
2371
- parentID
2387
+ { parentID }
2372
2388
  );
2373
2389
  }
2374
2390
  getAllNodes() {
2375
2391
  return this.entityManager.getEntities(WorkflowNodeEntity).filter((n) => n.id !== import_document8.FlowNodeBaseType.ROOT);
2376
2392
  }
2393
+ getAllEdges() {
2394
+ return this.entityManager.getEntities(WorkflowLineEntity);
2395
+ }
2377
2396
  getAllPorts() {
2378
2397
  return this.entityManager.getEntities(WorkflowPortEntity).filter((p) => p.node.id !== import_document8.FlowNodeBaseType.ROOT);
2379
2398
  }
@@ -2474,7 +2493,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2474
2493
  x: json.meta.position.x + 30,
2475
2494
  y: json.meta.position.y + 30
2476
2495
  };
2477
- return this.createWorkflowNode(
2496
+ return this._createWorkflowNode(
2478
2497
  {
2479
2498
  id: newNodeId || `1${nanoid2()}`,
2480
2499
  type: node.flowNodeType,
@@ -2486,16 +2505,17 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2486
2505
  blocks: json.blocks,
2487
2506
  edges: json.edges
2488
2507
  },
2489
- true,
2490
- node.parent?.id
2508
+ {
2509
+ parentID: node.parent?.id
2510
+ }
2491
2511
  );
2492
2512
  }
2493
- copyNodeFromJSON(flowNodeType, nodeJSON, newNodeId, position, parentId) {
2513
+ copyNodeFromJSON(flowNodeType, nodeJSON, newNodeId, position, parentID) {
2494
2514
  position = position || {
2495
2515
  x: nodeJSON.meta.position.x + 30,
2496
2516
  y: nodeJSON.meta.position.y + 30
2497
2517
  };
2498
- return this.createWorkflowNode(
2518
+ return this._createWorkflowNode(
2499
2519
  {
2500
2520
  id: newNodeId || `1${nanoid2()}`,
2501
2521
  type: flowNodeType,
@@ -2507,8 +2527,9 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2507
2527
  blocks: nodeJSON.blocks,
2508
2528
  edges: nodeJSON.edges
2509
2529
  },
2510
- true,
2511
- parentId
2530
+ {
2531
+ parentID
2532
+ }
2512
2533
  );
2513
2534
  }
2514
2535
  canRemove(node, silent) {
@@ -2563,13 +2584,17 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2563
2584
  * 批量添加节点
2564
2585
  */
2565
2586
  batchAddFromJSON(json, options) {
2566
- const { parent = this.root, isClone = false } = options ?? {};
2567
- const containerID = this.getNodeSubCanvas(parent)?.canvasNode.id ?? parent.id;
2587
+ const { parent = this.root } = options ?? {};
2588
+ const parentID = this.getNodeSubCanvas(parent)?.canvasNode.id ?? parent.id;
2568
2589
  const processedJSON = buildGroupJSON(json);
2569
2590
  const nodes = processedJSON.nodes.map(
2570
- (nodeJSON) => this.createWorkflowNode(nodeJSON, isClone, containerID)
2591
+ (nodeJSON) => this._createWorkflowNode(nodeJSON, {
2592
+ parentID
2593
+ })
2571
2594
  );
2572
- const edges = processedJSON.edges.map((edge) => this.createWorkflowLine(edge, containerID)).filter(Boolean);
2595
+ const edges = processedJSON.edges.map((edge) => this.createWorkflowLine(edge, parentID)).filter(Boolean);
2596
+ nodes.forEach((node) => options?.onNodeCreated?.(node));
2597
+ edges.forEach((edge) => options?.onEdgeCreated?.(edge));
2573
2598
  return { nodes, edges };
2574
2599
  }
2575
2600
  getNodeSubCanvas(node) {
@@ -2618,7 +2643,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2618
2643
  }
2619
2644
  return lineJSON;
2620
2645
  }
2621
- createWorkflowLine(json, parentId) {
2646
+ createWorkflowLine(json, parentID) {
2622
2647
  const fromNode = this.getNode(json.sourceNodeID);
2623
2648
  const toNode = this.getNode(json.targetNodeID);
2624
2649
  if (!fromNode || !toNode) {
@@ -2631,10 +2656,10 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2631
2656
  toPort: json.targetPortID,
2632
2657
  data: json.data
2633
2658
  };
2634
- if (!parentId) {
2659
+ if (!parentID) {
2635
2660
  return this.linesManager.createLine(lineInfo);
2636
2661
  }
2637
- const canvasNode = this.getNode(parentId);
2662
+ const canvasNode = this.getNode(parentID);
2638
2663
  if (!canvasNode) {
2639
2664
  return this.linesManager.createLine(lineInfo);
2640
2665
  }
@@ -3579,10 +3604,57 @@ var WorkflowOperationBaseServiceImpl = class extends import_document12.FlowOpera
3579
3604
  newPosition: position
3580
3605
  });
3581
3606
  }
3607
+ fromJSON(json) {
3608
+ if (this.document.disposed) return;
3609
+ const workflowJSON = {
3610
+ nodes: json.nodes ?? [],
3611
+ edges: json.edges ?? []
3612
+ };
3613
+ const oldNodes = this.document.getAllNodes();
3614
+ const oldPositionMap = new Map(
3615
+ oldNodes.map((node) => [
3616
+ node.id,
3617
+ {
3618
+ x: node.transform.transform.position.x,
3619
+ y: node.transform.transform.position.y
3620
+ }
3621
+ ])
3622
+ );
3623
+ const newNodes = [];
3624
+ const newEdges = [];
3625
+ this.linesManager.getAllLines().map((line) => line.dispose());
3626
+ this.document.batchAddFromJSON(workflowJSON, {
3627
+ onNodeCreated: (node) => newNodes.push(node),
3628
+ onEdgeCreated: (edge) => newEdges.push(edge)
3629
+ });
3630
+ const newNodeIDSet = new Set(newNodes.map((node) => node.id));
3631
+ oldNodes.forEach((node) => {
3632
+ if (!newNodeIDSet.has(node.id)) {
3633
+ node.dispose();
3634
+ return;
3635
+ }
3636
+ const oldPosition = oldPositionMap.get(node.id);
3637
+ const newPosition = {
3638
+ x: node.transform.transform.position.x,
3639
+ y: node.transform.transform.position.y
3640
+ };
3641
+ if (oldPosition && (oldPosition.x !== newPosition.x || oldPosition.y !== newPosition.y)) {
3642
+ this.onNodePostionUpdateEmitter.fire({
3643
+ node,
3644
+ oldPosition,
3645
+ newPosition
3646
+ });
3647
+ }
3648
+ });
3649
+ this.document.fireRender();
3650
+ }
3582
3651
  };
3583
3652
  __decorateClass([
3584
3653
  (0, import_inversify8.inject)(WorkflowDocument)
3585
3654
  ], WorkflowOperationBaseServiceImpl.prototype, "document", 2);
3655
+ __decorateClass([
3656
+ (0, import_inversify8.inject)(WorkflowLinesManager)
3657
+ ], WorkflowOperationBaseServiceImpl.prototype, "linesManager", 2);
3586
3658
 
3587
3659
  // src/hooks/use-playground-readonly-state.ts
3588
3660
  var import_react = require("react");
@@ -3680,8 +3752,8 @@ function useNodeRender(nodeFromProps) {
3680
3752
  }, []);
3681
3753
  const getExtInfo = (0, import_react2.useCallback)(() => node.getExtInfo(), [node]);
3682
3754
  const updateExtInfo = (0, import_react2.useCallback)(
3683
- (data) => {
3684
- node.updateExtInfo(data);
3755
+ (data, fullUpdate) => {
3756
+ node.updateExtInfo(data, fullUpdate);
3685
3757
  },
3686
3758
  [node]
3687
3759
  );
@@ -3716,7 +3788,7 @@ function useNodeRender(nodeFromProps) {
3716
3788
  if (form) {
3717
3789
  form.updateFormValues(values);
3718
3790
  } else {
3719
- updateExtInfo(values);
3791
+ updateExtInfo(values, true);
3720
3792
  }
3721
3793
  },
3722
3794
  node,