@flowgram.ai/free-layout-core 0.1.0-alpha.18 → 0.1.0-alpha.19

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 +161 -55
  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 +7 -5
  8. package/dist/index.d.ts +7 -5
  9. package/dist/index.js +159 -50
  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-B-9mEm2k.d.mts → workflow-node-entity-DH5qlw7I.d.mts} +41 -7
  30. package/dist/{workflow-node-entity-DvBGZ5Ve.d.ts → workflow-node-entity-DWVtlA2a.d.ts} +41 -7
  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
@@ -1,9 +1,9 @@
1
1
  import { PlaygroundConfigEntity, CommandService, PlaygroundDragEvent, EntityData } from '@flowgram.ai/core';
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
- 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-B-9mEm2k.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-B-9mEm2k.mjs';
4
+ import { 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-DH5qlw7I.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-DH5qlw7I.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';
@@ -75,7 +75,7 @@ declare class WorkflowDragService {
75
75
  protected linesManager: WorkflowLinesManager;
76
76
  protected commandService: CommandService;
77
77
  protected selectService: WorkflowSelectService;
78
- protected operationService: FlowOperationBaseService;
78
+ protected operationService: WorkflowOperationBaseService;
79
79
  readonly options: WorkflowDocumentOptions;
80
80
  private _onDragLineEventEmitter;
81
81
  readonly onDragLineEventChange: _flowgram_ai_utils.Event<LineEventProps>;
@@ -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
@@ -1,9 +1,9 @@
1
1
  import { PlaygroundConfigEntity, CommandService, PlaygroundDragEvent, EntityData } from '@flowgram.ai/core';
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
- 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-DvBGZ5Ve.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-DvBGZ5Ve.js';
4
+ import { 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-DWVtlA2a.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-DWVtlA2a.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';
@@ -75,7 +75,7 @@ declare class WorkflowDragService {
75
75
  protected linesManager: WorkflowLinesManager;
76
76
  protected commandService: CommandService;
77
77
  protected selectService: WorkflowSelectService;
78
- protected operationService: FlowOperationBaseService;
78
+ protected operationService: WorkflowOperationBaseService;
79
79
  readonly options: WorkflowDocumentOptions;
80
80
  private _onDragLineEventEmitter;
81
81
  readonly onDragLineEventChange: _flowgram_ai_utils.Event<LineEventProps>;
@@ -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
@@ -225,6 +225,27 @@ var import_core5 = require("@flowgram.ai/core");
225
225
  var import_utils5 = require("@flowgram.ai/utils");
226
226
  var import_document3 = require("@flowgram.ai/document");
227
227
  var import_core4 = require("@flowgram.ai/core");
228
+
229
+ // src/utils/location-config-to-point.ts
230
+ function locationConfigToPoint(bounds, config, _offset = { x: 0, y: 0 }) {
231
+ const offset = { ..._offset };
232
+ if (config.left !== void 0) {
233
+ offset.x += typeof config.left === "string" ? parseFloat(config.left) * 0.01 * bounds.width : config.left;
234
+ } else if (config.right !== void 0) {
235
+ offset.x += bounds.width - (typeof config.right === "string" ? parseFloat(config.right) * 0.01 * bounds.width : config.right);
236
+ }
237
+ if (config.top !== void 0) {
238
+ offset.y += typeof config.top === "string" ? parseFloat(config.top) * 0.01 * bounds.height : config.top;
239
+ } else if (config.bottom !== void 0) {
240
+ offset.y += bounds.height - (typeof config.bottom === "string" ? parseFloat(config.bottom) * 0.01 * bounds.height : config.bottom);
241
+ }
242
+ return {
243
+ x: bounds.x + offset.x,
244
+ y: bounds.y + offset.y
245
+ };
246
+ }
247
+
248
+ // src/entities/workflow-port-entity.ts
228
249
  var PORT_SIZE = 24;
229
250
  var WorkflowPortEntity = class extends import_core4.Entity {
230
251
  constructor(opts) {
@@ -237,6 +258,7 @@ var WorkflowPortEntity = class extends import_core4.Entity {
237
258
  this.portType = opts.type;
238
259
  this._disabled = opts.disabled;
239
260
  this._offset = opts.offset;
261
+ this._locationConfig = opts.locationConfig;
240
262
  this._location = opts.location;
241
263
  this._size = opts.size;
242
264
  this.node = opts.node;
@@ -284,7 +306,7 @@ var WorkflowPortEntity = class extends import_core4.Entity {
284
306
  return "right";
285
307
  }
286
308
  get point() {
287
- const { targetElement } = this;
309
+ const { targetElement, _locationConfig } = this;
288
310
  const { bounds } = this.node.getData(import_document3.FlowNodeTransformData);
289
311
  const location2 = this.location;
290
312
  if (targetElement) {
@@ -299,8 +321,14 @@ var WorkflowPortEntity = class extends import_core4.Entity {
299
321
  location: location2
300
322
  };
301
323
  }
302
- let point = { x: 0, y: 0 };
324
+ if (_locationConfig) {
325
+ return {
326
+ ...locationConfigToPoint(bounds, _locationConfig, this._offset),
327
+ location: location2
328
+ };
329
+ }
303
330
  const offset = this._offset || { x: 0, y: 0 };
331
+ let point = { x: 0, y: 0 };
304
332
  switch (location2) {
305
333
  case "left":
306
334
  point = bounds.leftCenter;
@@ -413,6 +441,10 @@ var WorkflowPortEntity = class extends import_core4.Entity {
413
441
  this._offset = data.offset;
414
442
  changed = true;
415
443
  }
444
+ if (import_utils5.Compare.isChanged(data.locationConfig, this._locationConfig)) {
445
+ this._locationConfig = data.locationConfig;
446
+ changed = true;
447
+ }
416
448
  if (import_utils5.Compare.isChanged(data.size, this._size)) {
417
449
  this._size = data.size;
418
450
  changed = true;
@@ -1513,10 +1545,11 @@ function initFormDataFromJSON(node, json, isFirstCreate) {
1513
1545
  // src/workflow-document-option.ts
1514
1546
  var WorkflowDocumentOptions = Symbol("WorkflowDocumentOptions");
1515
1547
  var WorkflowDocumentOptionsDefault = {
1516
- cursors: {
1517
- grab: 'url(""), auto',
1518
- grabbing: 'url(""), auto'
1519
- },
1548
+ // cursors: {
1549
+ // grab: 'url(""), auto',
1550
+ // grabbing:
1551
+ // 'url(""), auto',
1552
+ // },
1520
1553
  fromNodeJSON(node, json, isFirstCreate) {
1521
1554
  initFormDataFromJSON(node, json, isFirstCreate);
1522
1555
  return;
@@ -2104,6 +2137,9 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2104
2137
  this._loading = false;
2105
2138
  this.onLoadedEmitter.fire();
2106
2139
  }
2140
+ /**
2141
+ * @deprecated use `ctx.operation.fromJSON` instead
2142
+ */
2107
2143
  async reload(json, delayTime = 0) {
2108
2144
  if (this.disposed) return;
2109
2145
  this._loading = true;
@@ -2124,7 +2160,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2124
2160
  edges: json.edges ?? []
2125
2161
  };
2126
2162
  this.entityManager.changeEntityLocked = true;
2127
- this.renderJSON(workflowJSON);
2163
+ this.batchAddFromJSON(workflowJSON);
2128
2164
  this.entityManager.changeEntityLocked = false;
2129
2165
  this.transformer.loading = false;
2130
2166
  if (fireRender) {
@@ -2144,9 +2180,17 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2144
2180
  * 创建流程节点
2145
2181
  * @param json
2146
2182
  */
2147
- createWorkflowNode(json, isClone = false, parentId) {
2183
+ createWorkflowNode(json, isClone = false, parentID) {
2184
+ return this._createWorkflowNode(json, { parentID });
2185
+ }
2186
+ /**
2187
+ * 创建流程节点
2188
+ * @param json
2189
+ */
2190
+ _createWorkflowNode(json, options) {
2191
+ const { parentID, onNodeCreated, onEdgeCreated } = options ?? {};
2148
2192
  const isExistedNode = this.getNode(json.id);
2149
- const parent = this.getNode(parentId ?? this.root.id) ?? this.root;
2193
+ const parent = this.getNode(parentID ?? this.root.id) ?? this.root;
2150
2194
  const node = this.addNode(
2151
2195
  {
2152
2196
  ...json,
@@ -2173,15 +2217,19 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2173
2217
  node.getData(import_core14.TransformData).update({
2174
2218
  position
2175
2219
  });
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
2220
+ if (formMeta && formData) {
2221
+ if (!formData.formModel.initialized) {
2222
+ formData.createForm(formMeta, json.data);
2223
+ formData.onDataChange(() => {
2224
+ this.fireContentChange({
2225
+ type: "NODE_DATA_CHANGE" /* NODE_DATA_CHANGE */,
2226
+ toJSON: () => formData.toJSON(),
2227
+ entity: node
2228
+ });
2183
2229
  });
2184
- });
2230
+ } else {
2231
+ formData.updateFormValues(json.data);
2232
+ }
2185
2233
  }
2186
2234
  const positionData = node.getData(import_core14.PositionData);
2187
2235
  if (!isExistedNode) {
@@ -2220,11 +2268,12 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2220
2268
  });
2221
2269
  }
2222
2270
  if (json.blocks) {
2223
- this.renderJSON(
2271
+ this.batchAddFromJSON(
2224
2272
  { nodes: json.blocks, edges: json.edges ?? [] },
2225
2273
  {
2226
2274
  parent: node,
2227
- isClone
2275
+ onNodeCreated,
2276
+ onEdgeCreated
2228
2277
  }
2229
2278
  );
2230
2279
  }
@@ -2356,7 +2405,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2356
2405
  throw new Error(`[WorkflowDocument.createWorkflowNodeByType] Node Id "${id}" duplicated.`);
2357
2406
  }
2358
2407
  }
2359
- return this.createWorkflowNode(
2408
+ return this._createWorkflowNode(
2360
2409
  {
2361
2410
  ...json,
2362
2411
  id,
@@ -2367,13 +2416,15 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2367
2416
  blocks: json?.blocks,
2368
2417
  edges: json?.edges
2369
2418
  },
2370
- false,
2371
- parentID
2419
+ { parentID }
2372
2420
  );
2373
2421
  }
2374
2422
  getAllNodes() {
2375
2423
  return this.entityManager.getEntities(WorkflowNodeEntity).filter((n) => n.id !== import_document8.FlowNodeBaseType.ROOT);
2376
2424
  }
2425
+ getAllEdges() {
2426
+ return this.entityManager.getEntities(WorkflowLineEntity);
2427
+ }
2377
2428
  getAllPorts() {
2378
2429
  return this.entityManager.getEntities(WorkflowPortEntity).filter((p) => p.node.id !== import_document8.FlowNodeBaseType.ROOT);
2379
2430
  }
@@ -2474,7 +2525,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2474
2525
  x: json.meta.position.x + 30,
2475
2526
  y: json.meta.position.y + 30
2476
2527
  };
2477
- return this.createWorkflowNode(
2528
+ return this._createWorkflowNode(
2478
2529
  {
2479
2530
  id: newNodeId || `1${nanoid2()}`,
2480
2531
  type: node.flowNodeType,
@@ -2486,16 +2537,17 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2486
2537
  blocks: json.blocks,
2487
2538
  edges: json.edges
2488
2539
  },
2489
- true,
2490
- node.parent?.id
2540
+ {
2541
+ parentID: node.parent?.id
2542
+ }
2491
2543
  );
2492
2544
  }
2493
- copyNodeFromJSON(flowNodeType, nodeJSON, newNodeId, position, parentId) {
2545
+ copyNodeFromJSON(flowNodeType, nodeJSON, newNodeId, position, parentID) {
2494
2546
  position = position || {
2495
2547
  x: nodeJSON.meta.position.x + 30,
2496
2548
  y: nodeJSON.meta.position.y + 30
2497
2549
  };
2498
- return this.createWorkflowNode(
2550
+ return this._createWorkflowNode(
2499
2551
  {
2500
2552
  id: newNodeId || `1${nanoid2()}`,
2501
2553
  type: flowNodeType,
@@ -2507,8 +2559,9 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2507
2559
  blocks: nodeJSON.blocks,
2508
2560
  edges: nodeJSON.edges
2509
2561
  },
2510
- true,
2511
- parentId
2562
+ {
2563
+ parentID
2564
+ }
2512
2565
  );
2513
2566
  }
2514
2567
  canRemove(node, silent) {
@@ -2563,13 +2616,19 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2563
2616
  * 批量添加节点
2564
2617
  */
2565
2618
  batchAddFromJSON(json, options) {
2566
- const { parent = this.root, isClone = false } = options ?? {};
2567
- const containerID = this.getNodeSubCanvas(parent)?.canvasNode.id ?? parent.id;
2619
+ const { parent = this.root, onNodeCreated, onEdgeCreated } = options ?? {};
2620
+ const parentID = this.getNodeSubCanvas(parent)?.canvasNode.id ?? parent.id;
2568
2621
  const processedJSON = buildGroupJSON(json);
2569
2622
  const nodes = processedJSON.nodes.map(
2570
- (nodeJSON) => this.createWorkflowNode(nodeJSON, isClone, containerID)
2623
+ (nodeJSON) => this._createWorkflowNode(nodeJSON, {
2624
+ parentID,
2625
+ onNodeCreated,
2626
+ onEdgeCreated
2627
+ })
2571
2628
  );
2572
- const edges = processedJSON.edges.map((edge) => this.createWorkflowLine(edge, containerID)).filter(Boolean);
2629
+ const edges = processedJSON.edges.map((edge) => this.createWorkflowLine(edge, parentID)).filter(Boolean);
2630
+ nodes.forEach((node) => options?.onNodeCreated?.(node));
2631
+ edges.forEach((edge) => options?.onEdgeCreated?.(edge));
2573
2632
  return { nodes, edges };
2574
2633
  }
2575
2634
  getNodeSubCanvas(node) {
@@ -2618,7 +2677,7 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2618
2677
  }
2619
2678
  return lineJSON;
2620
2679
  }
2621
- createWorkflowLine(json, parentId) {
2680
+ createWorkflowLine(json, parentID) {
2622
2681
  const fromNode = this.getNode(json.sourceNodeID);
2623
2682
  const toNode = this.getNode(json.targetNodeID);
2624
2683
  if (!fromNode || !toNode) {
@@ -2631,10 +2690,10 @@ var WorkflowDocument = class extends import_document8.FlowDocument {
2631
2690
  toPort: json.targetPortID,
2632
2691
  data: json.data
2633
2692
  };
2634
- if (!parentId) {
2693
+ if (!parentID) {
2635
2694
  return this.linesManager.createLine(lineInfo);
2636
2695
  }
2637
- const canvasNode = this.getNode(parentId);
2696
+ const canvasNode = this.getNode(parentID);
2638
2697
  if (!canvasNode) {
2639
2698
  return this.linesManager.createLine(lineInfo);
2640
2699
  }
@@ -3097,20 +3156,16 @@ var WorkflowDragService = class {
3097
3156
  })
3098
3157
  );
3099
3158
  const containerTransform = container.getData(import_core15.TransformData);
3100
- containerTransform.update({
3101
- position: {
3102
- x: containerTransform.position.x + bounds.x,
3103
- y: containerTransform.position.y + bounds.y
3104
- }
3159
+ this.operationService.updateNodePosition(container, {
3160
+ x: containerTransform.position.x + bounds.x,
3161
+ y: containerTransform.position.y + bounds.y
3105
3162
  });
3106
3163
  this.document.layout.updateAffectedTransform(container);
3107
3164
  container.blocks.forEach((node) => {
3108
3165
  const transform = node.getData(import_core15.TransformData);
3109
- transform.update({
3110
- position: {
3111
- x: transform.position.x - bounds.x,
3112
- y: transform.position.y - bounds.y
3113
- }
3166
+ this.operationService.updateNodePosition(node, {
3167
+ x: transform.position.x - bounds.x,
3168
+ y: transform.position.y - bounds.y
3114
3169
  });
3115
3170
  this.document.layout.updateAffectedTransform(node);
3116
3171
  });
@@ -3431,7 +3486,7 @@ __decorateClass([
3431
3486
  (0, import_inversify6.inject)(WorkflowSelectService)
3432
3487
  ], WorkflowDragService.prototype, "selectService", 2);
3433
3488
  __decorateClass([
3434
- (0, import_inversify6.inject)(import_document9.FlowOperationBaseService)
3489
+ (0, import_inversify6.inject)(WorkflowOperationBaseService)
3435
3490
  ], WorkflowDragService.prototype, "operationService", 2);
3436
3491
  __decorateClass([
3437
3492
  (0, import_inversify6.inject)(WorkflowDocumentOptions)
@@ -3579,10 +3634,64 @@ var WorkflowOperationBaseServiceImpl = class extends import_document12.FlowOpera
3579
3634
  newPosition: position
3580
3635
  });
3581
3636
  }
3637
+ fromJSON(json) {
3638
+ if (this.document.disposed) return;
3639
+ const workflowJSON = {
3640
+ nodes: json.nodes ?? [],
3641
+ edges: json.edges ?? []
3642
+ };
3643
+ const oldNodes = this.document.getAllNodes();
3644
+ const oldEdges = this.linesManager.getAllLines();
3645
+ const oldPositionMap = new Map(
3646
+ oldNodes.map((node) => [
3647
+ node.id,
3648
+ {
3649
+ x: node.transform.transform.position.x,
3650
+ y: node.transform.transform.position.y
3651
+ }
3652
+ ])
3653
+ );
3654
+ const newNodes = [];
3655
+ const newEdges = [];
3656
+ this.document.batchAddFromJSON(workflowJSON, {
3657
+ onNodeCreated: (node) => newNodes.push(node),
3658
+ onEdgeCreated: (edge) => newEdges.push(edge)
3659
+ });
3660
+ const newEdgeIDSet = new Set(newEdges.map((edge) => edge.id));
3661
+ oldEdges.forEach((edge) => {
3662
+ if (!newEdgeIDSet.has(edge.id)) {
3663
+ edge.dispose();
3664
+ return;
3665
+ }
3666
+ });
3667
+ const newNodeIDSet = new Set(newNodes.map((node) => node.id));
3668
+ oldNodes.forEach((node) => {
3669
+ if (!newNodeIDSet.has(node.id)) {
3670
+ node.dispose();
3671
+ return;
3672
+ }
3673
+ const oldPosition = oldPositionMap.get(node.id);
3674
+ const newPosition = {
3675
+ x: node.transform.transform.position.x,
3676
+ y: node.transform.transform.position.y
3677
+ };
3678
+ if (oldPosition && (oldPosition.x !== newPosition.x || oldPosition.y !== newPosition.y)) {
3679
+ this.onNodePostionUpdateEmitter.fire({
3680
+ node,
3681
+ oldPosition,
3682
+ newPosition
3683
+ });
3684
+ }
3685
+ });
3686
+ this.document.fireRender();
3687
+ }
3582
3688
  };
3583
3689
  __decorateClass([
3584
3690
  (0, import_inversify8.inject)(WorkflowDocument)
3585
3691
  ], WorkflowOperationBaseServiceImpl.prototype, "document", 2);
3692
+ __decorateClass([
3693
+ (0, import_inversify8.inject)(WorkflowLinesManager)
3694
+ ], WorkflowOperationBaseServiceImpl.prototype, "linesManager", 2);
3586
3695
 
3587
3696
  // src/hooks/use-playground-readonly-state.ts
3588
3697
  var import_react = require("react");
@@ -3680,8 +3789,8 @@ function useNodeRender(nodeFromProps) {
3680
3789
  }, []);
3681
3790
  const getExtInfo = (0, import_react2.useCallback)(() => node.getExtInfo(), [node]);
3682
3791
  const updateExtInfo = (0, import_react2.useCallback)(
3683
- (data) => {
3684
- node.updateExtInfo(data);
3792
+ (data, fullUpdate) => {
3793
+ node.updateExtInfo(data, fullUpdate);
3685
3794
  },
3686
3795
  [node]
3687
3796
  );
@@ -3716,7 +3825,7 @@ function useNodeRender(nodeFromProps) {
3716
3825
  if (form) {
3717
3826
  form.updateFormValues(values);
3718
3827
  } else {
3719
- updateExtInfo(values);
3828
+ updateExtInfo(values, true);
3720
3829
  }
3721
3830
  },
3722
3831
  node,