@flowgram.ai/free-layout-core 0.1.0-alpha.6 → 0.1.0-alpha.8

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/dist/esm/index.js CHANGED
@@ -145,6 +145,7 @@ var PORT_SIZE = 24;
145
145
  var WorkflowPortEntity = class extends Entity {
146
146
  // relativePosition
147
147
  constructor(opts) {
148
+ var _a;
148
149
  super(opts);
149
150
  this.portID = "";
150
151
  this._disabled = false;
@@ -153,7 +154,7 @@ var WorkflowPortEntity = class extends Entity {
153
154
  this.onErrorChanged = this._onErrorChangedEmitter.event;
154
155
  this.portID = opts.portID || "";
155
156
  this.portType = opts.type;
156
- this._disabled = opts.disabled ?? false;
157
+ this._disabled = (_a = opts.disabled) != null ? _a : false;
157
158
  this.node = opts.node;
158
159
  this.updateTargetElement(opts.targetElement);
159
160
  this.toDispose.push(this.node.getData(TransformData3).onDataChange(() => this.fireChange()));
@@ -283,6 +284,7 @@ WorkflowPortEntity.type = "WorkflowPortEntity";
283
284
  // src/entity-datas/workflow-node-ports-data.ts
284
285
  var WorkflowNodePortsData = class extends EntityData {
285
286
  constructor(entity) {
287
+ var _a;
286
288
  super(entity);
287
289
  /** 静态的 ports 数据 */
288
290
  this._staticPorts = [];
@@ -291,7 +293,7 @@ var WorkflowNodePortsData = class extends EntityData {
291
293
  this.entity = entity;
292
294
  const meta = entity.getNodeMeta();
293
295
  const defaultPorts = meta.useDynamicPort ? [] : [{ type: "input" }, { type: "output" }];
294
- this._staticPorts = meta.defaultPorts?.slice() || defaultPorts;
296
+ this._staticPorts = ((_a = meta.defaultPorts) == null ? void 0 : _a.slice()) || defaultPorts;
295
297
  this.updatePorts(this._staticPorts);
296
298
  if (meta.useDynamicPort) {
297
299
  this.toDispose.push(
@@ -358,8 +360,9 @@ var WorkflowNodePortsData = class extends EntityData {
358
360
  if (!isEqual(this._prePorts, ports)) {
359
361
  const portKeys = ports.map((port) => this.getPortId(port.type, port.portID));
360
362
  this._portIDSet.forEach((portId) => {
363
+ var _a;
361
364
  if (!portKeys.includes(portId)) {
362
- this.getPortEntity(portId)?.dispose();
365
+ (_a = this.getPortEntity(portId)) == null ? void 0 : _a.dispose();
363
366
  }
364
367
  });
365
368
  ports.forEach((port) => this.updatePortEntity(port));
@@ -453,8 +456,9 @@ var WorkflowNodePortsData = class extends EntityData {
453
456
  * 获取或创建 port 实体
454
457
  */
455
458
  getOrCreatePortEntity(portInfo) {
459
+ var _a;
456
460
  const id = this.getPortId(portInfo.type, portInfo.portID);
457
- return this.getPortEntity(id) ?? this.createPortEntity(portInfo);
461
+ return (_a = this.getPortEntity(id)) != null ? _a : this.createPortEntity(portInfo);
458
462
  }
459
463
  /**
460
464
  * 更新 port 实体
@@ -482,7 +486,7 @@ var _WorkflowNodeLinesData = class _WorkflowNodeLinesData extends EntityData2 {
482
486
  constructor(entity) {
483
487
  super(entity);
484
488
  this.entity = entity;
485
- this.toDispose.push(
489
+ this.entity.preDispose.push(
486
490
  Disposable.create(() => {
487
491
  this.inputLines.slice().forEach((line) => line.dispose());
488
492
  this.outputLines.slice().forEach((line) => line.dispose());
@@ -522,7 +526,7 @@ var _WorkflowNodeLinesData = class _WorkflowNodeLinesData extends EntityData2 {
522
526
  return;
523
527
  }
524
528
  inputNodes.forEach((inputNode) => {
525
- if (inputNode?.parent === node || node?.parent === inputNode) {
529
+ if ((inputNode == null ? void 0 : inputNode.parent) === node || (node == null ? void 0 : node.parent) === inputNode) {
526
530
  return;
527
531
  }
528
532
  handleNode(inputNode);
@@ -553,7 +557,7 @@ var _WorkflowNodeLinesData = class _WorkflowNodeLinesData extends EntityData2 {
553
557
  return;
554
558
  }
555
559
  outputNodes.forEach((outputNode) => {
556
- if (outputNode?.parent === node || node?.parent === outputNode) {
560
+ if ((outputNode == null ? void 0 : outputNode.parent) === node || (node == null ? void 0 : node.parent) === outputNode) {
557
561
  return;
558
562
  }
559
563
  handleNode(outputNode);
@@ -613,19 +617,23 @@ var WorkflowLineRenderData = class extends EntityData3 {
613
617
  return this.data.position;
614
618
  }
615
619
  get path() {
616
- return this.currentLine?.path ?? "";
620
+ var _a, _b;
621
+ return (_b = (_a = this.currentLine) == null ? void 0 : _a.path) != null ? _b : "";
617
622
  }
618
623
  calcDistance(pos) {
619
- return this.currentLine?.calcDistance(pos) ?? Number.MAX_SAFE_INTEGER;
624
+ var _a, _b;
625
+ return (_b = (_a = this.currentLine) == null ? void 0 : _a.calcDistance(pos)) != null ? _b : Number.MAX_SAFE_INTEGER;
620
626
  }
621
627
  get bounds() {
622
- return this.currentLine?.bounds ?? new Rectangle4();
628
+ var _a, _b;
629
+ return (_b = (_a = this.currentLine) == null ? void 0 : _a.bounds) != null ? _b : new Rectangle4();
623
630
  }
624
631
  /**
625
632
  * 更新数据
626
633
  * WARNING: 这个方法,必须在 requestAnimationFrame / useLayoutEffect 中调用,否则会引起浏览器强制重排
627
634
  */
628
635
  update() {
636
+ var _a;
629
637
  this.syncContributions();
630
638
  const oldVersion = this.data.version;
631
639
  this.updatePosition();
@@ -634,21 +642,23 @@ var WorkflowLineRenderData = class extends EntityData3 {
634
642
  return;
635
643
  }
636
644
  this.data.version = newVersion;
637
- this.currentLine?.update({
645
+ (_a = this.currentLine) == null ? void 0 : _a.update({
638
646
  fromPos: this.data.position.from,
639
647
  toPos: this.data.position.to
640
648
  });
641
649
  }
642
650
  get lineType() {
643
- return this.entity.renderType ?? this.entity.linesManager.lineType;
651
+ var _a;
652
+ return (_a = this.entity.renderType) != null ? _a : this.entity.linesManager.lineType;
644
653
  }
645
654
  /**
646
655
  * 更新版本
647
656
  * WARNING: 这个方法,必须在 requestAnimationFrame / useLayoutEffect 中调用,否则会引起浏览器强制重排
648
657
  */
649
658
  updatePosition() {
659
+ var _a, _b, _c, _d;
650
660
  this.data.position.from = this.entity.from.getData(WorkflowNodePortsData).getOutputPoint(this.entity.info.fromPort);
651
- this.data.position.to = this.entity.info.drawingTo ?? this.entity.to?.getData(WorkflowNodePortsData)?.getInputPoint(this.entity.info.toPort) ?? {
661
+ this.data.position.to = (_d = (_c = this.entity.info.drawingTo) != null ? _c : (_b = (_a = this.entity.to) == null ? void 0 : _a.getData(WorkflowNodePortsData)) == null ? void 0 : _b.getInputPoint(this.entity.info.toPort)) != null ? _d : {
652
662
  x: this.data.position.from.x,
653
663
  y: this.data.position.from.y
654
664
  };
@@ -732,7 +742,7 @@ var _WorkflowLineEntity = class _WorkflowLineEntity extends Entity2 {
732
742
  return this.highlightColor === this.linesManager.lineColor.hidden;
733
743
  }
734
744
  get inContainer() {
735
- const nodeInContainer = (node) => !!node?.parent && node.parent.flowNodeType !== "root";
745
+ const nodeInContainer = (node) => !!(node == null ? void 0 : node.parent) && node.parent.flowNodeType !== "root";
736
746
  return nodeInContainer(this.from) || nodeInContainer(this.to);
737
747
  }
738
748
  /**
@@ -873,7 +883,8 @@ var _WorkflowLineEntity = class _WorkflowLineEntity extends Entity2 {
873
883
  }
874
884
  /** 获取线条样式 */
875
885
  get className() {
876
- return this.linesManager.setLineClassName(this) ?? "";
886
+ var _a;
887
+ return (_a = this.linesManager.setLineClassName(this)) != null ? _a : "";
877
888
  }
878
889
  get color() {
879
890
  return this.linesManager.getLineColor(this);
@@ -894,8 +905,8 @@ var _WorkflowLineEntity = class _WorkflowLineEntity extends Entity2 {
894
905
  validate() {
895
906
  const { fromPort, toPort } = this;
896
907
  this.validateSelf();
897
- fromPort?.validate();
898
- toPort?.validate();
908
+ fromPort == null ? void 0 : fromPort.validate();
909
+ toPort == null ? void 0 : toPort.validate();
899
910
  }
900
911
  validateSelf() {
901
912
  const { fromPort, toPort } = this;
@@ -913,14 +924,15 @@ var _WorkflowLineEntity = class _WorkflowLineEntity extends Entity2 {
913
924
  return this.linesManager.canRemove(this, newLineInfo);
914
925
  }
915
926
  get node() {
927
+ var _a, _b, _c, _d, _e, _f;
916
928
  if (this._node) return this._node;
917
929
  this._node = domUtils.createDivWithClass("gedit-flow-activity-line");
918
930
  this._node.dataset.testid = "sdk.workflow.canvas.line";
919
931
  this._node.dataset.lineId = this.id;
920
932
  this._node.dataset.fromNodeId = this.from.id;
921
- this._node.dataset.fromPortId = this.fromPort?.id ?? "";
922
- this._node.dataset.toNodeId = this.to?.id ?? "";
923
- this._node.dataset.toPortId = this.toPort?.id ?? "";
933
+ this._node.dataset.fromPortId = (_b = (_a = this.fromPort) == null ? void 0 : _a.id) != null ? _b : "";
934
+ this._node.dataset.toNodeId = (_d = (_c = this.to) == null ? void 0 : _c.id) != null ? _d : "";
935
+ this._node.dataset.toPortId = (_f = (_e = this.toPort) == null ? void 0 : _e.id) != null ? _f : "";
924
936
  this._node.dataset.hasError = this.hasError ? "true" : "false";
925
937
  return this._node;
926
938
  }
@@ -972,7 +984,8 @@ var WorkflowSelectService = class {
972
984
  return this.selectionService.selection.some((s) => s.id === id);
973
985
  }
974
986
  isActivated(id) {
975
- return this.activatedNode?.id === id;
987
+ var _a;
988
+ return ((_a = this.activatedNode) == null ? void 0 : _a.id) === id;
976
989
  }
977
990
  /**
978
991
  * 选中的节点
@@ -1043,8 +1056,8 @@ WorkflowSelectService = __decorateClass([
1043
1056
 
1044
1057
  // src/service/workflow-hover-service.ts
1045
1058
  import { inject as inject2, injectable as injectable2 } from "inversify";
1046
- import { EntityManager } from "@flowgram.ai/core";
1047
1059
  import { Emitter as Emitter2 } from "@flowgram.ai/utils";
1060
+ import { EntityManager } from "@flowgram.ai/core";
1048
1061
  var WorkflowHoverService = class {
1049
1062
  constructor() {
1050
1063
  this.onHoveredChangeEmitter = new Emitter2();
@@ -1125,7 +1138,7 @@ import {
1125
1138
  // src/workflow-lines-manager.ts
1126
1139
  import { last } from "lodash-es";
1127
1140
  import { inject as inject3, injectable as injectable3 } from "inversify";
1128
- import { Disposable as Disposable2, DisposableCollection, Emitter as Emitter3 } from "@flowgram.ai/utils";
1141
+ import { DisposableCollection, Emitter as Emitter3 } from "@flowgram.ai/utils";
1129
1142
  import { FlowNodeRenderData as FlowNodeRenderData2, FlowNodeTransformData as FlowNodeTransformData3 } from "@flowgram.ai/document";
1130
1143
  import { EntityManager as EntityManager2, PlaygroundConfigEntity as PlaygroundConfigEntity2, TransformData as TransformData6 } from "@flowgram.ai/core";
1131
1144
 
@@ -1144,19 +1157,23 @@ function toFormJSON(node) {
1144
1157
  if (!formData || !node.getNodeRegistry().formMeta) return void 0;
1145
1158
  return formData.toJSON();
1146
1159
  }
1147
- function initFormDataFromJSON(node, json) {
1160
+ function initFormDataFromJSON(node, json, isFirstCreate) {
1148
1161
  const formData = node.getData(FlowNodeFormData);
1149
1162
  const registry = node.getNodeRegistry();
1150
1163
  const { formMeta } = registry;
1151
1164
  if (formData && formMeta) {
1152
- formData.createForm(formMeta, json.data);
1153
- formData.onDataChange(() => {
1154
- node.document.fireContentChange({
1155
- type: "NODE_DATA_CHANGE" /* NODE_DATA_CHANGE */,
1156
- toJSON: () => formData.toJSON(),
1157
- entity: node
1165
+ if (isFirstCreate) {
1166
+ formData.createForm(formMeta, json.data);
1167
+ formData.onDataChange(() => {
1168
+ node.document.fireContentChange({
1169
+ type: "NODE_DATA_CHANGE" /* NODE_DATA_CHANGE */,
1170
+ toJSON: () => formData.toJSON(),
1171
+ entity: node
1172
+ });
1158
1173
  });
1159
- });
1174
+ } else {
1175
+ formData.updateFormValues(json.data);
1176
+ }
1160
1177
  }
1161
1178
  }
1162
1179
 
@@ -1167,12 +1184,13 @@ var WorkflowDocumentOptionsDefault = {
1167
1184
  grab: 'url(""), auto',
1168
1185
  grabbing: 'url(""), auto'
1169
1186
  },
1170
- fromNodeJSON(node, json) {
1171
- initFormDataFromJSON(node, json);
1187
+ fromNodeJSON(node, json, isFirstCreate) {
1188
+ initFormDataFromJSON(node, json, isFirstCreate);
1172
1189
  return;
1173
1190
  },
1174
1191
  toNodeJSON(node) {
1175
- const nodeError = node.getData(FlowNodeErrorData)?.getError();
1192
+ var _a, _b;
1193
+ const nodeError = (_a = node.getData(FlowNodeErrorData)) == null ? void 0 : _a.getError();
1176
1194
  if (nodeError) {
1177
1195
  throw nodeError;
1178
1196
  }
@@ -1180,8 +1198,8 @@ var WorkflowDocumentOptionsDefault = {
1180
1198
  let formJSON = toFormJSON(node);
1181
1199
  const metaData = {};
1182
1200
  const nodeMeta = node.getNodeMeta();
1183
- const subCanvas = nodeMeta.subCanvas?.(node);
1184
- if (subCanvas?.isCanvas === false) {
1201
+ const subCanvas = (_b = nodeMeta.subCanvas) == null ? void 0 : _b.call(nodeMeta, node);
1202
+ if ((subCanvas == null ? void 0 : subCanvas.isCanvas) === false) {
1185
1203
  const canvasNodeTransform = subCanvas.canvasNode.getData(FlowNodeTransformData2);
1186
1204
  const { x, y } = canvasNodeTransform.transform.position;
1187
1205
  metaData.canvasPosition = { x, y };
@@ -1284,6 +1302,7 @@ var WorkflowLinesManager = class {
1284
1302
  return this.createLine(newPortInfo);
1285
1303
  }
1286
1304
  createLine(options) {
1305
+ var _a;
1287
1306
  const { from, to, drawingTo, fromPort, toPort } = options;
1288
1307
  const available = Boolean(from && to);
1289
1308
  const key = options.key || WorkflowLineEntity.portInfoToLineId(options);
@@ -1293,7 +1312,7 @@ var WorkflowLinesManager = class {
1293
1312
  line.validate();
1294
1313
  return line;
1295
1314
  }
1296
- const fromNode = this.entityManager.getEntityById(from)?.getData(WorkflowNodeLinesData);
1315
+ const fromNode = (_a = this.entityManager.getEntityById(from)) == null ? void 0 : _a.getData(WorkflowNodeLinesData);
1297
1316
  const toNode = to ? this.entityManager.getEntityById(to).getData(WorkflowNodeLinesData) : void 0;
1298
1317
  if (!fromNode) {
1299
1318
  return;
@@ -1311,26 +1330,24 @@ var WorkflowLinesManager = class {
1311
1330
  });
1312
1331
  this.registerData(line);
1313
1332
  fromNode.addLine(line);
1314
- toNode?.addLine(line);
1333
+ toNode == null ? void 0 : toNode.addLine(line);
1315
1334
  line.onDispose(() => {
1316
1335
  if (drawingTo) {
1317
1336
  this.isDrawing = false;
1318
1337
  }
1319
1338
  fromNode.removeLine(line);
1320
- toNode?.removeLine(line);
1339
+ toNode == null ? void 0 : toNode.removeLine(line);
1321
1340
  line.validate();
1322
1341
  });
1323
- line.toDispose.push(
1324
- Disposable2.create(() => {
1325
- if (available) {
1326
- this.onAvailableLinesChangeEmitter.fire({
1327
- type: "DELETE_LINE" /* DELETE_LINE */,
1328
- toJSON: () => line.toJSON(),
1329
- entity: line
1330
- });
1331
- }
1332
- })
1333
- );
1342
+ line.onDispose(() => {
1343
+ if (available) {
1344
+ this.onAvailableLinesChangeEmitter.fire({
1345
+ type: "DELETE_LINE" /* DELETE_LINE */,
1346
+ toJSON: () => line.toJSON(),
1347
+ entity: line
1348
+ });
1349
+ }
1350
+ });
1334
1351
  if (available) {
1335
1352
  this.onAvailableLinesChangeEmitter.fire({
1336
1353
  type: "ADD_LINE" /* ADD_LINE */,
@@ -1468,7 +1485,10 @@ var WorkflowLinesManager = class {
1468
1485
  const allPorts = this.entityManager.getEntities(WorkflowPortEntity).filter((port) => port.node.flowNodeType !== "root");
1469
1486
  const targetPort = allPorts.find((port) => port.isHovered(pos.x, pos.y));
1470
1487
  if (targetPort) {
1471
- const targetNode = this.document.getAllNodes().slice().reverse().filter((node) => targetPort.node?.parent?.id !== node.id).find((node) => node.getData(TransformData6).contains(pos.x, pos.y));
1488
+ const targetNode = this.document.getAllNodes().slice().reverse().filter((node) => {
1489
+ var _a, _b;
1490
+ return ((_b = (_a = targetPort.node) == null ? void 0 : _a.parent) == null ? void 0 : _b.id) !== node.id;
1491
+ }).find((node) => node.getData(TransformData6).contains(pos.x, pos.y));
1472
1492
  if (targetNode && targetNode !== targetPort.node) {
1473
1493
  return;
1474
1494
  }
@@ -1480,21 +1500,22 @@ var WorkflowLinesManager = class {
1480
1500
  * @param pos - 鼠标位置
1481
1501
  */
1482
1502
  getNodeFromMousePos(pos) {
1503
+ var _a, _b;
1483
1504
  const allNodes = this.document.getAllNodes().sort((a, b) => this.getNodeIndex(a) - this.getNodeIndex(b));
1484
1505
  const containNodes = [];
1485
1506
  const { selection } = this.selectService;
1486
- const zoom = this.entityManager.getEntity(PlaygroundConfigEntity2)?.config?.zoom || 1;
1507
+ const zoom = ((_b = (_a = this.entityManager.getEntity(PlaygroundConfigEntity2)) == null ? void 0 : _a.config) == null ? void 0 : _b.zoom) || 1;
1487
1508
  allNodes.forEach((node) => {
1488
1509
  const { bounds } = node.getData(FlowNodeTransformData3);
1489
1510
  if (bounds.clone().pad(4 / zoom).contains(pos.x, pos.y)) {
1490
1511
  containNodes.push(node);
1491
1512
  }
1492
1513
  });
1493
- if (selection?.length) {
1514
+ if (selection == null ? void 0 : selection.length) {
1494
1515
  const filteredNodes = containNodes.filter(
1495
1516
  (node) => selection.some((_node) => node.id === _node.id)
1496
1517
  );
1497
- if (filteredNodes?.length) {
1518
+ if (filteredNodes == null ? void 0 : filteredNodes.length) {
1498
1519
  return last(filteredNodes);
1499
1520
  }
1500
1521
  }
@@ -1531,7 +1552,7 @@ WorkflowLinesManager = __decorateClass([
1531
1552
  // src/workflow-document.ts
1532
1553
  import { customAlphabet } from "nanoid";
1533
1554
  import { inject as inject5, injectable as injectable5, optional, postConstruct } from "inversify";
1534
- import { Disposable as Disposable3, Emitter as Emitter4 } from "@flowgram.ai/utils";
1555
+ import { Emitter as Emitter4 } from "@flowgram.ai/utils";
1535
1556
  import { NodeEngineContext } from "@flowgram.ai/form-core";
1536
1557
  import { FlowDocument, FlowNodeBaseType, FlowNodeTransformData as FlowNodeTransformData5 } from "@flowgram.ai/document";
1537
1558
  import {
@@ -1543,16 +1564,16 @@ import {
1543
1564
 
1544
1565
  // src/layout/free-layout.ts
1545
1566
  import { inject as inject4, injectable as injectable4 } from "inversify";
1546
- import {
1547
- FlowDocumentProvider,
1548
- FlowNodeTransformData as FlowNodeTransformData4
1549
- } from "@flowgram.ai/document";
1550
- import { PlaygroundConfigEntity as PlaygroundConfigEntity3, TransformData as TransformData7 } from "@flowgram.ai/core";
1551
1567
  import {
1552
1568
  PaddingSchema,
1553
1569
  Rectangle as Rectangle7,
1554
1570
  SizeSchema as SizeSchema2
1555
1571
  } from "@flowgram.ai/utils";
1572
+ import {
1573
+ FlowDocumentProvider,
1574
+ FlowNodeTransformData as FlowNodeTransformData4
1575
+ } from "@flowgram.ai/document";
1576
+ import { PlaygroundConfigEntity as PlaygroundConfigEntity3, TransformData as TransformData7 } from "@flowgram.ai/core";
1556
1577
  var FREE_LAYOUT_KEY = "free-layout";
1557
1578
  var FreeLayout = class {
1558
1579
  constructor() {
@@ -1565,7 +1586,8 @@ var FreeLayout = class {
1565
1586
  * 更新布局
1566
1587
  */
1567
1588
  update() {
1568
- if (this.document.root.getData(FlowNodeTransformData4)?.localDirty) {
1589
+ var _a;
1590
+ if ((_a = this.document.root.getData(FlowNodeTransformData4)) == null ? void 0 : _a.localDirty) {
1569
1591
  this.document.root.clearMemoGlobal();
1570
1592
  }
1571
1593
  }
@@ -1587,6 +1609,21 @@ var FreeLayout = class {
1587
1609
  const parentTransform = node.parent.getData(FlowNodeTransformData4);
1588
1610
  parentTransform.transform.fireChange();
1589
1611
  }
1612
+ /**
1613
+ * 更新所有受影响的上下游节点
1614
+ */
1615
+ updateAffectedTransform(node) {
1616
+ const transformData = node.transform;
1617
+ if (!transformData.localDirty) {
1618
+ return;
1619
+ }
1620
+ const allParents = this.getAllParents(node);
1621
+ const allBlocks = this.getAllBlocks(node).reverse();
1622
+ const affectedNodes = [...allBlocks, ...allParents];
1623
+ affectedNodes.forEach((node2) => {
1624
+ this.fireChange(node2);
1625
+ });
1626
+ }
1590
1627
  /**
1591
1628
  * 获取节点的 padding 数据
1592
1629
  * @param node
@@ -1632,6 +1669,30 @@ var FreeLayout = class {
1632
1669
  getDefaultNodeOrigin() {
1633
1670
  return { x: 0.5, y: 0 };
1634
1671
  }
1672
+ getAllParents(node) {
1673
+ const parents = [];
1674
+ let current = node.parent;
1675
+ while (current) {
1676
+ parents.push(current);
1677
+ current = current.parent;
1678
+ }
1679
+ return parents;
1680
+ }
1681
+ getAllBlocks(node) {
1682
+ return node.blocks.reduce(
1683
+ (acc, child) => [...acc, ...this.getAllBlocks(child)],
1684
+ [node]
1685
+ );
1686
+ }
1687
+ fireChange(node) {
1688
+ const transformData = node == null ? void 0 : node.transform;
1689
+ if (!node || !(transformData == null ? void 0 : transformData.localDirty)) {
1690
+ return;
1691
+ }
1692
+ node.clearMemoGlobal();
1693
+ node.clearMemoLocal();
1694
+ transformData.transform.fireChange();
1695
+ }
1635
1696
  };
1636
1697
  __decorateClass([
1637
1698
  inject4(PlaygroundConfigEntity3)
@@ -1654,7 +1715,6 @@ var WorkflowDocument = class extends FlowDocument {
1654
1715
  this.onContentChange = this._onContentChangeEmitter.event;
1655
1716
  this._onReloadEmitter = new Emitter4();
1656
1717
  this.onReload = this._onReloadEmitter.event;
1657
- this.disposed = false;
1658
1718
  /**
1659
1719
  * 数据加载完成
1660
1720
  */
@@ -1683,12 +1743,14 @@ var WorkflowDocument = class extends FlowDocument {
1683
1743
  });
1684
1744
  }
1685
1745
  async load() {
1746
+ if (this.disposed) return;
1686
1747
  this._loading = true;
1687
1748
  await super.load();
1688
1749
  this._loading = false;
1689
1750
  this.onLoadedEmitter.fire();
1690
1751
  }
1691
1752
  async reload(json, delayTime = 0) {
1753
+ if (this.disposed) return;
1692
1754
  this._loading = true;
1693
1755
  this.clear();
1694
1756
  this.fromJSON(json);
@@ -1701,10 +1763,14 @@ var WorkflowDocument = class extends FlowDocument {
1701
1763
  * @param json
1702
1764
  */
1703
1765
  fromJSON(json, fireRender = true) {
1704
- const { flattenJSON, nodeBlocks, nodeEdges } = this.flatJSON(json);
1705
- const nestedJSON = this.nestJSON(flattenJSON, nodeBlocks, nodeEdges);
1766
+ var _a, _b;
1767
+ if (this.disposed) return;
1768
+ const workflowJSON = {
1769
+ nodes: (_a = json.nodes) != null ? _a : [],
1770
+ edges: (_b = json.edges) != null ? _b : []
1771
+ };
1706
1772
  this.entityManager.changeEntityLocked = true;
1707
- this.renderJSON(nestedJSON);
1773
+ this.renderJSON(workflowJSON);
1708
1774
  this.entityManager.changeEntityLocked = false;
1709
1775
  this.transformer.loading = false;
1710
1776
  if (fireRender) {
@@ -1725,14 +1791,16 @@ var WorkflowDocument = class extends FlowDocument {
1725
1791
  * @param json
1726
1792
  */
1727
1793
  createWorkflowNode(json, isClone = false, parentId) {
1794
+ var _a, _b, _c;
1728
1795
  const isExistedNode = this.getNode(json.id);
1729
- const parent = this.getNode(parentId ?? this.root.id) ?? this.root;
1796
+ const parent = (_a = this.getNode(parentId != null ? parentId : this.root.id)) != null ? _a : this.root;
1730
1797
  const node = this.addNode(
1731
1798
  {
1732
1799
  ...json,
1733
1800
  parent
1734
1801
  },
1735
1802
  void 0,
1803
+ true,
1736
1804
  true
1737
1805
  );
1738
1806
  const registry = node.getNodeRegistry();
@@ -1741,9 +1809,11 @@ var WorkflowDocument = class extends FlowDocument {
1741
1809
  const formData = getFlowNodeFormData(node);
1742
1810
  const transform = node.getData(FlowNodeTransformData5);
1743
1811
  const freeLayout = this.layout;
1744
- transform.onDataChange(() => {
1745
- freeLayout.syncTransform(node);
1746
- });
1812
+ if (!isExistedNode) {
1813
+ transform.onDataChange(() => {
1814
+ freeLayout.syncTransform(node);
1815
+ });
1816
+ }
1747
1817
  let { position } = meta;
1748
1818
  if (!position) {
1749
1819
  position = this.getNodeDefaultPosition(json.type);
@@ -1762,44 +1832,44 @@ var WorkflowDocument = class extends FlowDocument {
1762
1832
  });
1763
1833
  }
1764
1834
  const positionData = node.getData(PositionData);
1765
- positionData.onDataChange(() => {
1766
- this.fireContentChange({
1767
- type: "MOVE_NODE" /* MOVE_NODE */,
1768
- toJSON: () => positionData.toJSON(),
1769
- entity: node
1835
+ if (!isExistedNode) {
1836
+ positionData.onDataChange(() => {
1837
+ this.fireContentChange({
1838
+ type: "MOVE_NODE" /* MOVE_NODE */,
1839
+ toJSON: () => positionData.toJSON(),
1840
+ entity: node
1841
+ });
1770
1842
  });
1771
- });
1843
+ }
1772
1844
  const subCanvas = this.getNodeSubCanvas(node);
1773
- if (!isExistedNode && !subCanvas?.isCanvas) {
1845
+ if (!isExistedNode && !(subCanvas == null ? void 0 : subCanvas.isCanvas)) {
1774
1846
  this.fireContentChange({
1775
1847
  type: "ADD_NODE" /* ADD_NODE */,
1776
1848
  entity: node,
1777
1849
  toJSON: () => this.toNodeJSON(node)
1778
1850
  });
1779
- node.toDispose.push(
1780
- Disposable3.create(() => {
1781
- this.fireContentChange({
1782
- type: "DELETE_NODE" /* DELETE_NODE */,
1783
- entity: node,
1784
- toJSON: () => this.toNodeJSON(node)
1785
- });
1786
- })
1787
- );
1788
- node.toDispose.push(
1789
- Disposable3.create(() => {
1790
- if (!node.parent || node.parent.flowNodeType === FlowNodeBaseType.ROOT) {
1791
- return;
1792
- }
1793
- const parentTransform = node.parent.getData(FlowNodeTransformData5);
1794
- setTimeout(() => {
1795
- parentTransform.fireChange();
1796
- }, 0);
1797
- })
1798
- );
1851
+ node.onDispose(() => {
1852
+ if (!node.parent || node.parent.flowNodeType === FlowNodeBaseType.ROOT) {
1853
+ return;
1854
+ }
1855
+ const parentTransform = node.parent.getData(FlowNodeTransformData5);
1856
+ parentTransform.fireChange();
1857
+ });
1858
+ let lastDeleteNodeData;
1859
+ node.preDispose.onDispose(() => {
1860
+ lastDeleteNodeData = this.toNodeJSON(node);
1861
+ });
1862
+ node.onDispose(() => {
1863
+ this.fireContentChange({
1864
+ type: "DELETE_NODE" /* DELETE_NODE */,
1865
+ entity: node,
1866
+ toJSON: () => lastDeleteNodeData
1867
+ });
1868
+ });
1799
1869
  }
1800
1870
  if (json.blocks) {
1801
1871
  this.renderJSON(
1802
- { nodes: json.blocks, edges: json.edges ?? [] },
1872
+ { nodes: json.blocks, edges: (_b = json.edges) != null ? _b : [] },
1803
1873
  {
1804
1874
  parent: node,
1805
1875
  isClone
@@ -1809,21 +1879,39 @@ var WorkflowDocument = class extends FlowDocument {
1809
1879
  if (subCanvas) {
1810
1880
  const canvasTransform = subCanvas.canvasNode.getData(TransformData8);
1811
1881
  canvasTransform.update({
1812
- position: subCanvas.parentNode.getNodeMeta()?.canvasPosition
1882
+ position: (_c = subCanvas.parentNode.getNodeMeta()) == null ? void 0 : _c.canvasPosition
1813
1883
  });
1814
- subCanvas.parentNode.onDispose(() => {
1815
- subCanvas.canvasNode.dispose();
1884
+ if (!isExistedNode) {
1885
+ subCanvas.parentNode.onDispose(() => {
1886
+ subCanvas.canvasNode.dispose();
1887
+ });
1888
+ subCanvas.canvasNode.onDispose(() => {
1889
+ subCanvas.parentNode.dispose();
1890
+ });
1891
+ }
1892
+ }
1893
+ if (!isExistedNode) {
1894
+ this.onNodeCreateEmitter.fire({
1895
+ node,
1896
+ data: json,
1897
+ json
1816
1898
  });
1817
- subCanvas.canvasNode.onDispose(() => {
1818
- subCanvas.parentNode.dispose();
1899
+ } else {
1900
+ this.onNodeUpdateEmitter.fire({
1901
+ node,
1902
+ data: json,
1903
+ json
1819
1904
  });
1820
1905
  }
1821
- this.onNodeCreateEmitter.fire({
1822
- node,
1823
- data: json
1824
- });
1825
1906
  return node;
1826
1907
  }
1908
+ get layout() {
1909
+ const layout = this.layouts.find((layout2) => layout2.name == this.currentLayoutKey);
1910
+ if (!layout) {
1911
+ throw new Error(`Unknown flow layout: ${this.currentLayoutKey}`);
1912
+ }
1913
+ return layout;
1914
+ }
1827
1915
  /**
1828
1916
  * 获取默认的 x y 坐标, 默认为当前画布可视区域中心
1829
1917
  * @param type
@@ -1860,11 +1948,11 @@ var WorkflowDocument = class extends FlowDocument {
1860
1948
  ...json,
1861
1949
  id,
1862
1950
  type,
1863
- meta: { position, ...json?.meta },
1951
+ meta: { position, ...json == null ? void 0 : json.meta },
1864
1952
  // TODO title 和 meta 要从注册数据去拿
1865
- data: json?.data,
1866
- blocks: json?.blocks,
1867
- edges: json?.edges
1953
+ data: json == null ? void 0 : json.data,
1954
+ blocks: json == null ? void 0 : json.blocks,
1955
+ edges: json == null ? void 0 : json.edges
1868
1956
  },
1869
1957
  false,
1870
1958
  parentID
@@ -1891,7 +1979,10 @@ var WorkflowDocument = class extends FlowDocument {
1891
1979
  }));
1892
1980
  const startNodeId = allNode.find((node) => node.isStart).id;
1893
1981
  const endNodeId = allNode.find((node) => node.isNodeEnd).id;
1894
- const nodeInContainer = allNode.filter((node) => node.parent?.getNodeMeta().isContainer).map((node) => node.id);
1982
+ const nodeInContainer = allNode.filter((node) => {
1983
+ var _a;
1984
+ return (_a = node.parent) == null ? void 0 : _a.getNodeMeta().isContainer;
1985
+ }).map((node) => node.id);
1895
1986
  const associatedCache = /* @__PURE__ */ new Set([endNodeId, ...nodeInContainer]);
1896
1987
  const bfs = (nodeId) => {
1897
1988
  if (associatedCache.has(nodeId)) {
@@ -1926,7 +2017,7 @@ var WorkflowDocument = class extends FlowDocument {
1926
2017
  }
1927
2018
  toNodeJSON(node) {
1928
2019
  const subCanvas = this.getNodeSubCanvas(node);
1929
- if (subCanvas?.isCanvas === true) {
2020
+ if ((subCanvas == null ? void 0 : subCanvas.isCanvas) === true) {
1930
2021
  return this.toNodeJSON(subCanvas.parentNode);
1931
2022
  }
1932
2023
  const json = this.toNodeJSONFromOptions(node);
@@ -1960,6 +2051,7 @@ var WorkflowDocument = class extends FlowDocument {
1960
2051
  return WorkflowDocumentOptionsDefault.toNodeJSON(node);
1961
2052
  }
1962
2053
  copyNode(node, newNodeId, format, position) {
2054
+ var _a;
1963
2055
  let json = this.toNodeJSON(node);
1964
2056
  if (format) {
1965
2057
  json = format(json);
@@ -1981,7 +2073,7 @@ var WorkflowDocument = class extends FlowDocument {
1981
2073
  edges: json.edges
1982
2074
  },
1983
2075
  true,
1984
- node.parent?.id
2076
+ (_a = node.parent) == null ? void 0 : _a.id
1985
2077
  );
1986
2078
  }
1987
2079
  copyNodeFromJSON(flowNodeType, nodeJSON, newNodeId, position, parentId) {
@@ -2028,131 +2120,35 @@ var WorkflowDocument = class extends FlowDocument {
2028
2120
  * 导出数据
2029
2121
  */
2030
2122
  toJSON() {
2123
+ var _a, _b;
2031
2124
  const rootJSON = this.toNodeJSON(this.root);
2032
2125
  return {
2033
- nodes: rootJSON.blocks ?? [],
2034
- edges: rootJSON.edges ?? []
2126
+ nodes: (_a = rootJSON.blocks) != null ? _a : [],
2127
+ edges: (_b = rootJSON.edges) != null ? _b : []
2035
2128
  };
2036
2129
  }
2037
2130
  dispose() {
2038
- if (this.disposed) {
2039
- return;
2040
- }
2041
2131
  super.dispose();
2042
- this.disposed = true;
2043
2132
  this._onReloadEmitter.dispose();
2044
2133
  }
2045
- getEdgeID(edge) {
2046
- return WorkflowLineEntity.portInfoToLineId({
2047
- from: edge.sourceNodeID,
2048
- to: edge.targetNodeID,
2049
- fromPort: edge.sourcePortID,
2050
- toPort: edge.targetPortID
2051
- });
2052
- }
2053
- /**
2054
- * 拍平树形json结构,将结构信息提取到map
2055
- */
2056
- flatJSON(json = { nodes: [], edges: [] }) {
2057
- const nodeBlocks = /* @__PURE__ */ new Map();
2058
- const nodeEdges = /* @__PURE__ */ new Map();
2059
- const rootNodes = json.nodes ?? [];
2060
- const rootEdges = json.edges ?? [];
2061
- const flattenNodeJSONs = [...rootNodes];
2062
- const flattenEdgeJSONs = [...rootEdges];
2063
- const rootBlockIDs = rootNodes.map((node) => node.id);
2064
- const rootEdgeIDs = rootEdges.map((edge) => this.getEdgeID(edge));
2065
- nodeBlocks.set(FlowNodeBaseType.ROOT, rootBlockIDs);
2066
- nodeEdges.set(FlowNodeBaseType.ROOT, rootEdgeIDs);
2067
- rootNodes.forEach((nodeJSON) => {
2068
- const { blocks, edges } = nodeJSON;
2069
- if (blocks) {
2070
- flattenNodeJSONs.push(...blocks);
2071
- const blockIDs = [];
2072
- blocks.forEach((block) => {
2073
- blockIDs.push(block.id);
2074
- });
2075
- nodeBlocks.set(nodeJSON.id, blockIDs);
2076
- delete nodeJSON.blocks;
2077
- }
2078
- if (edges) {
2079
- flattenEdgeJSONs.push(...edges);
2080
- const edgeIDs = [];
2081
- edges.forEach((edge) => {
2082
- const edgeID = this.getEdgeID(edge);
2083
- edgeIDs.push(edgeID);
2084
- });
2085
- nodeEdges.set(nodeJSON.id, edgeIDs);
2086
- delete nodeJSON.edges;
2087
- }
2088
- });
2089
- const flattenJSON = {
2090
- nodes: flattenNodeJSONs,
2091
- edges: flattenEdgeJSONs
2092
- };
2093
- return {
2094
- flattenJSON,
2095
- nodeBlocks,
2096
- nodeEdges
2097
- };
2098
- }
2099
- /**
2100
- * 对JSON进行分层
2101
- */
2102
- nestJSON(flattenJSON, nodeBlocks, nodeEdges) {
2103
- const nestJSON = {
2104
- nodes: [],
2105
- edges: []
2106
- };
2107
- const nodeMap = /* @__PURE__ */ new Map();
2108
- const edgeMap = /* @__PURE__ */ new Map();
2109
- const rootBlockSet = new Set(nodeBlocks.get(FlowNodeBaseType.ROOT) ?? []);
2110
- const rootEdgeSet = new Set(nodeEdges.get(FlowNodeBaseType.ROOT) ?? []);
2111
- flattenJSON.nodes.forEach((nodeJSON) => {
2112
- nodeMap.set(nodeJSON.id, nodeJSON);
2113
- });
2114
- flattenJSON.edges.forEach((edgeJSON) => {
2115
- const edgeID = this.getEdgeID(edgeJSON);
2116
- edgeMap.set(edgeID, edgeJSON);
2117
- });
2118
- flattenJSON.nodes.forEach((nodeJSON) => {
2119
- if (rootBlockSet.has(nodeJSON.id)) {
2120
- nestJSON.nodes.push(nodeJSON);
2121
- }
2122
- if (nodeBlocks.has(nodeJSON.id)) {
2123
- const blockIDs = nodeBlocks.get(nodeJSON.id);
2124
- const blockJSONs = blockIDs.map((blockID) => nodeMap.get(blockID)).filter(Boolean);
2125
- nodeJSON.blocks = blockJSONs;
2126
- }
2127
- if (nodeEdges.has(nodeJSON.id)) {
2128
- const edgeIDs = nodeEdges.get(nodeJSON.id);
2129
- const edgeJSONs = edgeIDs.map((edgeID) => edgeMap.get(edgeID)).filter(Boolean);
2130
- nodeJSON.edges = edgeJSONs;
2131
- }
2132
- });
2133
- flattenJSON.edges.forEach((edgeJSON) => {
2134
- const edgeID = this.getEdgeID(edgeJSON);
2135
- if (rootEdgeSet.has(edgeID)) {
2136
- nestJSON.edges.push(edgeJSON);
2137
- }
2138
- });
2139
- return nestJSON;
2140
- }
2141
2134
  /**
2142
2135
  * 逐层创建节点和线条
2143
2136
  */
2144
2137
  renderJSON(json, options) {
2145
- const { parent = this.root, isClone = false } = options ?? {};
2146
- const containerID = this.getNodeSubCanvas(parent)?.canvasNode.id ?? parent.id;
2147
- json.nodes.forEach((nodeJSON) => {
2148
- this.createWorkflowNode(nodeJSON, isClone, containerID);
2149
- }), // 创建线条
2150
- json.edges.forEach((edge) => this.createWorkflowLine(edge, containerID));
2138
+ var _a, _b;
2139
+ const { parent = this.root, isClone = false } = options != null ? options : {};
2140
+ const containerID = (_b = (_a = this.getNodeSubCanvas(parent)) == null ? void 0 : _a.canvasNode.id) != null ? _b : parent.id;
2141
+ const nodes = json.nodes.map(
2142
+ (nodeJSON) => this.createWorkflowNode(nodeJSON, isClone, containerID)
2143
+ );
2144
+ const edges = json.edges.map((edge) => this.createWorkflowLine(edge, containerID)).filter(Boolean);
2145
+ return { nodes, edges };
2151
2146
  }
2152
2147
  getNodeSubCanvas(node) {
2148
+ var _a;
2153
2149
  if (!node) return;
2154
2150
  const nodeMeta = node.getNodeMeta();
2155
- const subCanvas = nodeMeta.subCanvas?.(node);
2151
+ const subCanvas = (_a = nodeMeta.subCanvas) == null ? void 0 : _a.call(nodeMeta, node);
2156
2152
  return subCanvas;
2157
2153
  }
2158
2154
  getNodeChildren(node) {
@@ -2160,8 +2156,9 @@ var WorkflowDocument = class extends FlowDocument {
2160
2156
  const subCanvas = this.getNodeSubCanvas(node);
2161
2157
  const childrenWithCanvas = subCanvas ? subCanvas.canvasNode.collapsedChildren : node.collapsedChildren;
2162
2158
  const children = childrenWithCanvas.filter((child) => {
2159
+ var _a, _b;
2163
2160
  const childMeta = child.getNodeMeta();
2164
- return !childMeta.subCanvas?.(node)?.isCanvas;
2161
+ return !((_b = (_a = childMeta.subCanvas) == null ? void 0 : _a.call(childMeta, node)) == null ? void 0 : _b.isCanvas);
2165
2162
  }).filter(Boolean);
2166
2163
  return children;
2167
2164
  }
@@ -2287,7 +2284,8 @@ var WorkflowDragService = class {
2287
2284
  * 拖拽选中节点
2288
2285
  * @param triggerEvent
2289
2286
  */
2290
- startDragSelectedNodes(triggerEvent) {
2287
+ async startDragSelectedNodes(triggerEvent) {
2288
+ var _a;
2291
2289
  let { selectedNodes } = this.selectService;
2292
2290
  if (selectedNodes.length === 0 || this.playgroundConfig.readonly || this.playgroundConfig.disabled || this.isDragging) {
2293
2291
  return Promise.resolve(false);
@@ -2297,7 +2295,6 @@ var WorkflowDragService = class {
2297
2295
  if (sameParent && sameParent.flowNodeType !== FlowNodeBaseType2.ROOT) {
2298
2296
  selectedNodes = [sameParent];
2299
2297
  }
2300
- const { altKey } = triggerEvent;
2301
2298
  let startPosition = this.getNodesPosition(selectedNodes);
2302
2299
  let startPositions = selectedNodes.map((node) => {
2303
2300
  const transform = node.getData(TransformData9);
@@ -2311,7 +2308,6 @@ var WorkflowDragService = class {
2311
2308
  type: "onDragStart",
2312
2309
  nodes: selectedNodes,
2313
2310
  startPositions,
2314
- altKey,
2315
2311
  dragEvent,
2316
2312
  triggerEvent,
2317
2313
  dragger
@@ -2320,25 +2316,6 @@ var WorkflowDragService = class {
2320
2316
  onDrag: (dragEvent) => {
2321
2317
  if (!dragSuccess && checkDragSuccess(Date.now() - startTime, dragEvent)) {
2322
2318
  dragSuccess = true;
2323
- if (altKey) {
2324
- const tryCopyNodes = selectedNodes;
2325
- if (tryCopyNodes.length > 0) {
2326
- this.selectService.clear();
2327
- this.commandService.executeCommand("PASTE_NODES" /* PASTE_NODES */, tryCopyNodes, true).then((newNodes) => {
2328
- if (newNodes && Array.isArray(newNodes) && newNodes.length > 0) {
2329
- selectedNodes = newNodes;
2330
- startPosition = this.getNodesPosition(tryCopyNodes);
2331
- startPositions = tryCopyNodes.filter((n) => !n.getNodeMeta().copyDisable).map((node) => {
2332
- const transform = node.getData(TransformData9);
2333
- return {
2334
- x: transform.position.x,
2335
- y: transform.position.y
2336
- };
2337
- });
2338
- }
2339
- });
2340
- }
2341
- }
2342
2319
  }
2343
2320
  const offset = this.getDragPosOffset({
2344
2321
  event: dragEvent,
@@ -2353,15 +2330,10 @@ var WorkflowDragService = class {
2353
2330
  x: nodeStartPosition.x + offset.x,
2354
2331
  y: nodeStartPosition.y + offset.y
2355
2332
  };
2356
- if (node.collapsedChildren?.length > 0) {
2357
- node.collapsedChildren.forEach((childNode) => {
2358
- const childNodeTransformData = childNode.getData(FlowNodeTransformData6);
2359
- childNodeTransformData.fireChange();
2360
- });
2361
- }
2362
2333
  transform.update({
2363
2334
  position: newPosition
2364
2335
  });
2336
+ this.document.layout.updateAffectedTransform(node);
2365
2337
  positions.push(newPosition);
2366
2338
  });
2367
2339
  this._nodesDragEmitter.fire({
@@ -2369,7 +2341,6 @@ var WorkflowDragService = class {
2369
2341
  nodes: selectedNodes,
2370
2342
  startPositions,
2371
2343
  positions,
2372
- altKey,
2373
2344
  dragEvent,
2374
2345
  triggerEvent,
2375
2346
  dragger
@@ -2381,14 +2352,13 @@ var WorkflowDragService = class {
2381
2352
  type: "onDragEnd",
2382
2353
  nodes: selectedNodes,
2383
2354
  startPositions,
2384
- altKey,
2385
2355
  dragEvent,
2386
2356
  triggerEvent,
2387
2357
  dragger
2388
2358
  });
2389
2359
  }
2390
2360
  });
2391
- return dragger.start(triggerEvent.clientX, triggerEvent.clientY, this.playgroundConfig)?.then(() => dragSuccess);
2361
+ return (_a = dragger.start(triggerEvent.clientX, triggerEvent.clientY, this.playgroundConfig)) == null ? void 0 : _a.then(() => dragSuccess);
2392
2362
  }
2393
2363
  /**
2394
2364
  * 通过拖入卡片添加
@@ -2406,7 +2376,7 @@ var WorkflowDragService = class {
2406
2376
  type,
2407
2377
  position,
2408
2378
  data,
2409
- parent?.id
2379
+ parent == null ? void 0 : parent.id
2410
2380
  );
2411
2381
  return node;
2412
2382
  }
@@ -2456,7 +2426,7 @@ var WorkflowDragService = class {
2456
2426
  );
2457
2427
  return Rectangle8.intersects(draggingRect, transformRect);
2458
2428
  });
2459
- this.updateDropNode(collisionTransform?.entity);
2429
+ this.updateDropNode(collisionTransform == null ? void 0 : collisionTransform.entity);
2460
2430
  },
2461
2431
  onDragEnd: async (e) => {
2462
2432
  const dropNode = this._dropNode;
@@ -2573,7 +2543,8 @@ var WorkflowDragService = class {
2573
2543
  }
2574
2544
  /** 是否容器节点 */
2575
2545
  isContainer(node) {
2576
- return node?.getNodeMeta().isContainer ?? false;
2546
+ var _a;
2547
+ return (_a = node == null ? void 0 : node.getNodeMeta().isContainer) != null ? _a : false;
2577
2548
  }
2578
2549
  /**
2579
2550
  * 获取节点整体位置
@@ -2598,7 +2569,7 @@ var WorkflowDragService = class {
2598
2569
  }
2599
2570
  updateDropNode(node) {
2600
2571
  if (this._dropNode) {
2601
- if (this._dropNode.id === node?.id) {
2572
+ if (this._dropNode.id === (node == null ? void 0 : node.id)) {
2602
2573
  return;
2603
2574
  }
2604
2575
  this.selectService.clear();
@@ -2620,7 +2591,7 @@ var WorkflowDragService = class {
2620
2591
  this.hoverService.clearHovered();
2621
2592
  }
2622
2593
  handleDragOnNode(toNode, fromPort, line, toPort, originLine) {
2623
- if (toPort && (originLine?.toPort === toPort || toPort.portType === "input" && this.linesManager.canAddLine(fromPort, toPort, true))) {
2594
+ if (toPort && ((originLine == null ? void 0 : originLine.toPort) === toPort || toPort.portType === "input" && this.linesManager.canAddLine(fromPort, toPort, true))) {
2624
2595
  this.hoverService.updateHoveredKey(toPort.id);
2625
2596
  line.setToPort(toPort);
2626
2597
  this._onDragLineEventEmitter.fire({
@@ -2642,14 +2613,15 @@ var WorkflowDragService = class {
2642
2613
  }
2643
2614
  }
2644
2615
  childrenOfContainer(nodes) {
2616
+ var _a;
2645
2617
  if (nodes.length === 0) {
2646
2618
  return;
2647
2619
  }
2648
- const sourceContainer = nodes[0]?.parent;
2620
+ const sourceContainer = (_a = nodes[0]) == null ? void 0 : _a.parent;
2649
2621
  if (!sourceContainer || sourceContainer.collapsedChildren.length !== nodes.length) {
2650
2622
  return;
2651
2623
  }
2652
- const valid = nodes.every((node) => node?.parent === sourceContainer);
2624
+ const valid = nodes.every((node) => (node == null ? void 0 : node.parent) === sourceContainer);
2653
2625
  if (!valid) {
2654
2626
  return;
2655
2627
  }
@@ -2662,7 +2634,7 @@ var WorkflowDragService = class {
2662
2634
  */
2663
2635
  async startDrawingLine(fromPort, event, originLine) {
2664
2636
  const isFromInActivePort = !originLine && fromPort.isErrorPort() && fromPort.disabled;
2665
- if (originLine?.disabled || isFromInActivePort || this.playgroundConfig.readonly || this.playgroundConfig.disabled) {
2637
+ if ((originLine == null ? void 0 : originLine.disabled) || isFromInActivePort || this.playgroundConfig.readonly || this.playgroundConfig.disabled) {
2666
2638
  return { dragSuccess: false, newLine: void 0 };
2667
2639
  }
2668
2640
  this.selectService.clear();
@@ -2725,7 +2697,7 @@ var WorkflowDragService = class {
2725
2697
  } else {
2726
2698
  line.drawingTo = { x: dragPos.x, y: dragPos.y };
2727
2699
  }
2728
- originLine?.validate();
2700
+ originLine == null ? void 0 : originLine.validate();
2729
2701
  line.validate();
2730
2702
  },
2731
2703
  // eslint-disable-next-line complexity
@@ -2745,7 +2717,7 @@ var WorkflowDragService = class {
2745
2717
  })
2746
2718
  )
2747
2719
  );
2748
- line?.dispose();
2720
+ line == null ? void 0 : line.dispose();
2749
2721
  this._onDragLineEventEmitter.fire({
2750
2722
  type: "onDragEnd"
2751
2723
  });
@@ -2753,7 +2725,7 @@ var WorkflowDragService = class {
2753
2725
  originLine.highlightColor = "";
2754
2726
  }
2755
2727
  const end = () => {
2756
- originLine?.validate();
2728
+ originLine == null ? void 0 : originLine.validate();
2757
2729
  deferred.resolve({ dragSuccess });
2758
2730
  };
2759
2731
  if (dragSuccess) {
@@ -2780,7 +2752,7 @@ var WorkflowDragService = class {
2780
2752
  if (originLine && (!this.linesManager.canRemove(originLine, newLineInfo, false) || lineErrorReset)) {
2781
2753
  return end();
2782
2754
  } else {
2783
- originLine?.dispose();
2755
+ originLine == null ? void 0 : originLine.dispose();
2784
2756
  }
2785
2757
  if (!toPort || !this.linesManager.canAddLine(fromPort, toPort, false)) {
2786
2758
  return end();
@@ -2884,18 +2856,14 @@ var layoutToPositions = async (nodes, nodePositionMap) => {
2884
2856
  const transform = node.getData(TransformData10);
2885
2857
  const deltaX = (nodePositionMap[node.id].x - transform.position.x) * v.d / 100;
2886
2858
  const deltaY = (nodePositionMap[node.id].y - transform.bounds.height / 2 - transform.position.y) * v.d / 100;
2887
- if (node.collapsedChildren?.length > 0) {
2888
- node.collapsedChildren.forEach((childNode) => {
2889
- const childNodeTransformData = childNode.getData(FlowNodeTransformData7);
2890
- childNodeTransformData.fireChange();
2891
- });
2892
- }
2893
2859
  transform.update({
2894
2860
  position: {
2895
2861
  x: transform.position.x + deltaX,
2896
2862
  y: transform.position.y + deltaY
2897
2863
  }
2898
2864
  });
2865
+ const document2 = node.document;
2866
+ document2.layout.updateAffectedTransform(node);
2899
2867
  });
2900
2868
  },
2901
2869
  onComplete: () => {
@@ -3011,7 +2979,7 @@ function usePlaygroundReadonlyState(listenChange) {
3011
2979
  if (listenChange) {
3012
2980
  dispose = playground.config.onReadonlyOrDisabledChange(() => refresh());
3013
2981
  }
3014
- return () => dispose?.dispose();
2982
+ return () => dispose == null ? void 0 : dispose.dispose();
3015
2983
  }, [listenChange]);
3016
2984
  return playground.config.readonly;
3017
2985
  }
@@ -3021,6 +2989,7 @@ function checkTargetDraggable(el) {
3021
2989
  return el && el.tagName !== "INPUT" && el.tagName !== "TEXTAREA" && !el.closest(".flow-canvas-not-draggable");
3022
2990
  }
3023
2991
  function useNodeRender(nodeFromProps) {
2992
+ var _a, _b;
3024
2993
  const node = nodeFromProps || useContext(PlaygroundEntityContext);
3025
2994
  const renderData = node.getData(FlowNodeRenderData3);
3026
2995
  const portsData = node.getData(WorkflowNodePortsData);
@@ -3044,6 +3013,7 @@ function useNodeRender(nodeFromProps) {
3044
3013
  }, []);
3045
3014
  const startDrag = useCallback(
3046
3015
  (e) => {
3016
+ var _a2;
3047
3017
  e.preventDefault();
3048
3018
  if (!selectionService.isSelected(node.id)) {
3049
3019
  selectNode(e);
@@ -3052,7 +3022,7 @@ function useNodeRender(nodeFromProps) {
3052
3022
  return;
3053
3023
  }
3054
3024
  isDragging.current = true;
3055
- dragService.startDragSelectedNodes(e)?.finally(
3025
+ (_a2 = dragService.startDragSelectedNodes(e)) == null ? void 0 : _a2.finally(
3056
3026
  () => setTimeout(() => {
3057
3027
  isDragging.current = false;
3058
3028
  })
@@ -3078,15 +3048,17 @@ function useNodeRender(nodeFromProps) {
3078
3048
  );
3079
3049
  const deleteNode = useCallback(() => node.dispose(), [node]);
3080
3050
  useListenEvents(portsData.onDataChange);
3081
- const isFirefox = navigator?.userAgent?.includes?.("Firefox");
3051
+ const isFirefox = (_b = (_a = navigator == null ? void 0 : navigator.userAgent) == null ? void 0 : _a.includes) == null ? void 0 : _b.call(_a, "Firefox");
3082
3052
  const onFocus = useCallback(() => {
3053
+ var _a2;
3083
3054
  if (isFirefox) {
3084
- nodeRef.current?.setAttribute("draggable", "false");
3055
+ (_a2 = nodeRef.current) == null ? void 0 : _a2.setAttribute("draggable", "false");
3085
3056
  }
3086
3057
  }, []);
3087
3058
  const onBlur = useCallback(() => {
3059
+ var _a2;
3088
3060
  if (isFirefox) {
3089
- nodeRef.current?.setAttribute("draggable", "true");
3061
+ (_a2 = nodeRef.current) == null ? void 0 : _a2.setAttribute("draggable", "true");
3090
3062
  }
3091
3063
  }, []);
3092
3064
  const getExtInfo = useCallback(() => node.getExtInfo(), [node]);
@@ -3097,7 +3069,7 @@ function useNodeRender(nodeFromProps) {
3097
3069
  [node]
3098
3070
  );
3099
3071
  const form = useMemo(() => getNodeForm(node), [node]);
3100
- const formState = useObserve(form?.state);
3072
+ const formState = useObserve(form == null ? void 0 : form.state);
3101
3073
  const toggleExpand = useCallback(() => {
3102
3074
  renderData.toggleExpand();
3103
3075
  }, [renderData]);
@@ -3233,7 +3205,8 @@ var WorkflowSimpleLineContribution = class {
3233
3205
  this.entity = entity;
3234
3206
  }
3235
3207
  get path() {
3236
- return this.data?.path ?? "";
3208
+ var _a, _b;
3209
+ return (_b = (_a = this.data) == null ? void 0 : _a.path) != null ? _b : "";
3237
3210
  }
3238
3211
  calcDistance(pos) {
3239
3212
  if (!this.data) {