@flowgram.ai/free-layout-core 0.1.0-alpha.7 → 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 +242 -153
- package/dist/esm/index.js.map +1 -1
- package/dist/index.d.mts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +236 -147
- package/dist/index.js.map +1 -1
- package/dist/typings/index.d.mts +1 -1
- package/dist/typings/index.d.ts +1 -1
- package/dist/typings/workflow-drag.d.mts +1 -1
- package/dist/typings/workflow-drag.d.ts +1 -1
- package/dist/typings/workflow-json.d.mts +1 -1
- package/dist/typings/workflow-json.d.ts +1 -1
- package/dist/typings/workflow-line.d.mts +1 -1
- package/dist/typings/workflow-line.d.ts +1 -1
- package/dist/typings/workflow-node.d.mts +1 -1
- package/dist/typings/workflow-node.d.ts +1 -1
- package/dist/typings/workflow-registry.d.mts +1 -1
- package/dist/typings/workflow-registry.d.ts +1 -1
- package/dist/{workflow-line-entity-DgCmDX1d.d.mts → workflow-line-entity-DSMjQU0t.d.mts} +51 -5
- package/dist/{workflow-line-entity-B8wC-OVt.d.ts → workflow-line-entity-VNz8dyPS.d.ts} +51 -5
- package/package.json +11 -11
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
|
|
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
|
|
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)
|
|
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)
|
|
461
|
+
return (_a = this.getPortEntity(id)) != null ? _a : this.createPortEntity(portInfo);
|
|
458
462
|
}
|
|
459
463
|
/**
|
|
460
464
|
* 更新 port 实体
|
|
@@ -522,7 +526,7 @@ var _WorkflowNodeLinesData = class _WorkflowNodeLinesData extends EntityData2 {
|
|
|
522
526
|
return;
|
|
523
527
|
}
|
|
524
528
|
inputNodes.forEach((inputNode) => {
|
|
525
|
-
if (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
|
|
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
|
-
|
|
620
|
+
var _a, _b;
|
|
621
|
+
return (_b = (_a = this.currentLine) == null ? void 0 : _a.path) != null ? _b : "";
|
|
617
622
|
}
|
|
618
623
|
calcDistance(pos) {
|
|
619
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
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
|
|
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
|
|
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
|
-
|
|
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
|
|
898
|
-
toPort
|
|
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
|
|
922
|
-
this._node.dataset.toNodeId = this.to
|
|
923
|
-
this._node.dataset.toPortId = this.toPort
|
|
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
|
-
|
|
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 {
|
|
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
|
-
|
|
1153
|
-
|
|
1154
|
-
|
|
1155
|
-
|
|
1156
|
-
|
|
1157
|
-
|
|
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
|
-
|
|
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
|
|
1184
|
-
if (subCanvas
|
|
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)
|
|
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
|
|
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
|
|
1339
|
+
toNode == null ? void 0 : toNode.removeLine(line);
|
|
1321
1340
|
line.validate();
|
|
1322
1341
|
});
|
|
1323
|
-
line.
|
|
1324
|
-
|
|
1325
|
-
|
|
1326
|
-
|
|
1327
|
-
|
|
1328
|
-
|
|
1329
|
-
|
|
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) =>
|
|
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)
|
|
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
|
|
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
|
|
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 {
|
|
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
|
-
|
|
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,9 +1763,11 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1701
1763
|
* @param json
|
|
1702
1764
|
*/
|
|
1703
1765
|
fromJSON(json, fireRender = true) {
|
|
1766
|
+
var _a, _b;
|
|
1767
|
+
if (this.disposed) return;
|
|
1704
1768
|
const workflowJSON = {
|
|
1705
|
-
nodes: json.nodes
|
|
1706
|
-
edges: json.edges
|
|
1769
|
+
nodes: (_a = json.nodes) != null ? _a : [],
|
|
1770
|
+
edges: (_b = json.edges) != null ? _b : []
|
|
1707
1771
|
};
|
|
1708
1772
|
this.entityManager.changeEntityLocked = true;
|
|
1709
1773
|
this.renderJSON(workflowJSON);
|
|
@@ -1727,14 +1791,16 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1727
1791
|
* @param json
|
|
1728
1792
|
*/
|
|
1729
1793
|
createWorkflowNode(json, isClone = false, parentId) {
|
|
1794
|
+
var _a, _b, _c;
|
|
1730
1795
|
const isExistedNode = this.getNode(json.id);
|
|
1731
|
-
const parent = this.getNode(parentId
|
|
1796
|
+
const parent = (_a = this.getNode(parentId != null ? parentId : this.root.id)) != null ? _a : this.root;
|
|
1732
1797
|
const node = this.addNode(
|
|
1733
1798
|
{
|
|
1734
1799
|
...json,
|
|
1735
1800
|
parent
|
|
1736
1801
|
},
|
|
1737
1802
|
void 0,
|
|
1803
|
+
true,
|
|
1738
1804
|
true
|
|
1739
1805
|
);
|
|
1740
1806
|
const registry = node.getNodeRegistry();
|
|
@@ -1743,9 +1809,11 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1743
1809
|
const formData = getFlowNodeFormData(node);
|
|
1744
1810
|
const transform = node.getData(FlowNodeTransformData5);
|
|
1745
1811
|
const freeLayout = this.layout;
|
|
1746
|
-
|
|
1747
|
-
|
|
1748
|
-
|
|
1812
|
+
if (!isExistedNode) {
|
|
1813
|
+
transform.onDataChange(() => {
|
|
1814
|
+
freeLayout.syncTransform(node);
|
|
1815
|
+
});
|
|
1816
|
+
}
|
|
1749
1817
|
let { position } = meta;
|
|
1750
1818
|
if (!position) {
|
|
1751
1819
|
position = this.getNodeDefaultPosition(json.type);
|
|
@@ -1764,44 +1832,44 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1764
1832
|
});
|
|
1765
1833
|
}
|
|
1766
1834
|
const positionData = node.getData(PositionData);
|
|
1767
|
-
|
|
1768
|
-
|
|
1769
|
-
|
|
1770
|
-
|
|
1771
|
-
|
|
1835
|
+
if (!isExistedNode) {
|
|
1836
|
+
positionData.onDataChange(() => {
|
|
1837
|
+
this.fireContentChange({
|
|
1838
|
+
type: "MOVE_NODE" /* MOVE_NODE */,
|
|
1839
|
+
toJSON: () => positionData.toJSON(),
|
|
1840
|
+
entity: node
|
|
1841
|
+
});
|
|
1772
1842
|
});
|
|
1773
|
-
}
|
|
1843
|
+
}
|
|
1774
1844
|
const subCanvas = this.getNodeSubCanvas(node);
|
|
1775
|
-
if (!isExistedNode && !subCanvas
|
|
1845
|
+
if (!isExistedNode && !(subCanvas == null ? void 0 : subCanvas.isCanvas)) {
|
|
1776
1846
|
this.fireContentChange({
|
|
1777
1847
|
type: "ADD_NODE" /* ADD_NODE */,
|
|
1778
1848
|
entity: node,
|
|
1779
1849
|
toJSON: () => this.toNodeJSON(node)
|
|
1780
1850
|
});
|
|
1781
|
-
node.
|
|
1782
|
-
|
|
1783
|
-
|
|
1784
|
-
|
|
1785
|
-
|
|
1786
|
-
|
|
1787
|
-
|
|
1788
|
-
|
|
1789
|
-
)
|
|
1790
|
-
|
|
1791
|
-
|
|
1792
|
-
|
|
1793
|
-
|
|
1794
|
-
|
|
1795
|
-
|
|
1796
|
-
|
|
1797
|
-
|
|
1798
|
-
|
|
1799
|
-
})
|
|
1800
|
-
);
|
|
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
|
+
});
|
|
1801
1869
|
}
|
|
1802
1870
|
if (json.blocks) {
|
|
1803
1871
|
this.renderJSON(
|
|
1804
|
-
{ nodes: json.blocks, edges: json.edges
|
|
1872
|
+
{ nodes: json.blocks, edges: (_b = json.edges) != null ? _b : [] },
|
|
1805
1873
|
{
|
|
1806
1874
|
parent: node,
|
|
1807
1875
|
isClone
|
|
@@ -1811,21 +1879,39 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1811
1879
|
if (subCanvas) {
|
|
1812
1880
|
const canvasTransform = subCanvas.canvasNode.getData(TransformData8);
|
|
1813
1881
|
canvasTransform.update({
|
|
1814
|
-
position: subCanvas.parentNode.getNodeMeta()
|
|
1882
|
+
position: (_c = subCanvas.parentNode.getNodeMeta()) == null ? void 0 : _c.canvasPosition
|
|
1815
1883
|
});
|
|
1816
|
-
|
|
1817
|
-
subCanvas.
|
|
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
|
|
1818
1898
|
});
|
|
1819
|
-
|
|
1820
|
-
|
|
1899
|
+
} else {
|
|
1900
|
+
this.onNodeUpdateEmitter.fire({
|
|
1901
|
+
node,
|
|
1902
|
+
data: json,
|
|
1903
|
+
json
|
|
1821
1904
|
});
|
|
1822
1905
|
}
|
|
1823
|
-
this.onNodeCreateEmitter.fire({
|
|
1824
|
-
node,
|
|
1825
|
-
data: json
|
|
1826
|
-
});
|
|
1827
1906
|
return node;
|
|
1828
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
|
+
}
|
|
1829
1915
|
/**
|
|
1830
1916
|
* 获取默认的 x y 坐标, 默认为当前画布可视区域中心
|
|
1831
1917
|
* @param type
|
|
@@ -1862,11 +1948,11 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1862
1948
|
...json,
|
|
1863
1949
|
id,
|
|
1864
1950
|
type,
|
|
1865
|
-
meta: { position, ...json
|
|
1951
|
+
meta: { position, ...json == null ? void 0 : json.meta },
|
|
1866
1952
|
// TODO title 和 meta 要从注册数据去拿
|
|
1867
|
-
data: json
|
|
1868
|
-
blocks: json
|
|
1869
|
-
edges: json
|
|
1953
|
+
data: json == null ? void 0 : json.data,
|
|
1954
|
+
blocks: json == null ? void 0 : json.blocks,
|
|
1955
|
+
edges: json == null ? void 0 : json.edges
|
|
1870
1956
|
},
|
|
1871
1957
|
false,
|
|
1872
1958
|
parentID
|
|
@@ -1893,7 +1979,10 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1893
1979
|
}));
|
|
1894
1980
|
const startNodeId = allNode.find((node) => node.isStart).id;
|
|
1895
1981
|
const endNodeId = allNode.find((node) => node.isNodeEnd).id;
|
|
1896
|
-
const nodeInContainer = allNode.filter((node) =>
|
|
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);
|
|
1897
1986
|
const associatedCache = /* @__PURE__ */ new Set([endNodeId, ...nodeInContainer]);
|
|
1898
1987
|
const bfs = (nodeId) => {
|
|
1899
1988
|
if (associatedCache.has(nodeId)) {
|
|
@@ -1928,7 +2017,7 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1928
2017
|
}
|
|
1929
2018
|
toNodeJSON(node) {
|
|
1930
2019
|
const subCanvas = this.getNodeSubCanvas(node);
|
|
1931
|
-
if (subCanvas
|
|
2020
|
+
if ((subCanvas == null ? void 0 : subCanvas.isCanvas) === true) {
|
|
1932
2021
|
return this.toNodeJSON(subCanvas.parentNode);
|
|
1933
2022
|
}
|
|
1934
2023
|
const json = this.toNodeJSONFromOptions(node);
|
|
@@ -1962,6 +2051,7 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1962
2051
|
return WorkflowDocumentOptionsDefault.toNodeJSON(node);
|
|
1963
2052
|
}
|
|
1964
2053
|
copyNode(node, newNodeId, format, position) {
|
|
2054
|
+
var _a;
|
|
1965
2055
|
let json = this.toNodeJSON(node);
|
|
1966
2056
|
if (format) {
|
|
1967
2057
|
json = format(json);
|
|
@@ -1983,7 +2073,7 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
1983
2073
|
edges: json.edges
|
|
1984
2074
|
},
|
|
1985
2075
|
true,
|
|
1986
|
-
node.parent
|
|
2076
|
+
(_a = node.parent) == null ? void 0 : _a.id
|
|
1987
2077
|
);
|
|
1988
2078
|
}
|
|
1989
2079
|
copyNodeFromJSON(flowNodeType, nodeJSON, newNodeId, position, parentId) {
|
|
@@ -2030,26 +2120,24 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
2030
2120
|
* 导出数据
|
|
2031
2121
|
*/
|
|
2032
2122
|
toJSON() {
|
|
2123
|
+
var _a, _b;
|
|
2033
2124
|
const rootJSON = this.toNodeJSON(this.root);
|
|
2034
2125
|
return {
|
|
2035
|
-
nodes: rootJSON.blocks
|
|
2036
|
-
edges: rootJSON.edges
|
|
2126
|
+
nodes: (_a = rootJSON.blocks) != null ? _a : [],
|
|
2127
|
+
edges: (_b = rootJSON.edges) != null ? _b : []
|
|
2037
2128
|
};
|
|
2038
2129
|
}
|
|
2039
2130
|
dispose() {
|
|
2040
|
-
if (this.disposed) {
|
|
2041
|
-
return;
|
|
2042
|
-
}
|
|
2043
2131
|
super.dispose();
|
|
2044
|
-
this.disposed = true;
|
|
2045
2132
|
this._onReloadEmitter.dispose();
|
|
2046
2133
|
}
|
|
2047
2134
|
/**
|
|
2048
2135
|
* 逐层创建节点和线条
|
|
2049
2136
|
*/
|
|
2050
2137
|
renderJSON(json, options) {
|
|
2051
|
-
|
|
2052
|
-
const
|
|
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;
|
|
2053
2141
|
const nodes = json.nodes.map(
|
|
2054
2142
|
(nodeJSON) => this.createWorkflowNode(nodeJSON, isClone, containerID)
|
|
2055
2143
|
);
|
|
@@ -2057,9 +2145,10 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
2057
2145
|
return { nodes, edges };
|
|
2058
2146
|
}
|
|
2059
2147
|
getNodeSubCanvas(node) {
|
|
2148
|
+
var _a;
|
|
2060
2149
|
if (!node) return;
|
|
2061
2150
|
const nodeMeta = node.getNodeMeta();
|
|
2062
|
-
const subCanvas = nodeMeta.subCanvas
|
|
2151
|
+
const subCanvas = (_a = nodeMeta.subCanvas) == null ? void 0 : _a.call(nodeMeta, node);
|
|
2063
2152
|
return subCanvas;
|
|
2064
2153
|
}
|
|
2065
2154
|
getNodeChildren(node) {
|
|
@@ -2067,8 +2156,9 @@ var WorkflowDocument = class extends FlowDocument {
|
|
|
2067
2156
|
const subCanvas = this.getNodeSubCanvas(node);
|
|
2068
2157
|
const childrenWithCanvas = subCanvas ? subCanvas.canvasNode.collapsedChildren : node.collapsedChildren;
|
|
2069
2158
|
const children = childrenWithCanvas.filter((child) => {
|
|
2159
|
+
var _a, _b;
|
|
2070
2160
|
const childMeta = child.getNodeMeta();
|
|
2071
|
-
return !childMeta.subCanvas
|
|
2161
|
+
return !((_b = (_a = childMeta.subCanvas) == null ? void 0 : _a.call(childMeta, node)) == null ? void 0 : _b.isCanvas);
|
|
2072
2162
|
}).filter(Boolean);
|
|
2073
2163
|
return children;
|
|
2074
2164
|
}
|
|
@@ -2195,6 +2285,7 @@ var WorkflowDragService = class {
|
|
|
2195
2285
|
* @param triggerEvent
|
|
2196
2286
|
*/
|
|
2197
2287
|
async startDragSelectedNodes(triggerEvent) {
|
|
2288
|
+
var _a;
|
|
2198
2289
|
let { selectedNodes } = this.selectService;
|
|
2199
2290
|
if (selectedNodes.length === 0 || this.playgroundConfig.readonly || this.playgroundConfig.disabled || this.isDragging) {
|
|
2200
2291
|
return Promise.resolve(false);
|
|
@@ -2239,15 +2330,10 @@ var WorkflowDragService = class {
|
|
|
2239
2330
|
x: nodeStartPosition.x + offset.x,
|
|
2240
2331
|
y: nodeStartPosition.y + offset.y
|
|
2241
2332
|
};
|
|
2242
|
-
if (node.collapsedChildren?.length > 0) {
|
|
2243
|
-
node.collapsedChildren.forEach((childNode) => {
|
|
2244
|
-
const childNodeTransformData = childNode.getData(FlowNodeTransformData6);
|
|
2245
|
-
childNodeTransformData.fireChange();
|
|
2246
|
-
});
|
|
2247
|
-
}
|
|
2248
2333
|
transform.update({
|
|
2249
2334
|
position: newPosition
|
|
2250
2335
|
});
|
|
2336
|
+
this.document.layout.updateAffectedTransform(node);
|
|
2251
2337
|
positions.push(newPosition);
|
|
2252
2338
|
});
|
|
2253
2339
|
this._nodesDragEmitter.fire({
|
|
@@ -2272,7 +2358,7 @@ var WorkflowDragService = class {
|
|
|
2272
2358
|
});
|
|
2273
2359
|
}
|
|
2274
2360
|
});
|
|
2275
|
-
return dragger.start(triggerEvent.clientX, triggerEvent.clientY, this.playgroundConfig)
|
|
2361
|
+
return (_a = dragger.start(triggerEvent.clientX, triggerEvent.clientY, this.playgroundConfig)) == null ? void 0 : _a.then(() => dragSuccess);
|
|
2276
2362
|
}
|
|
2277
2363
|
/**
|
|
2278
2364
|
* 通过拖入卡片添加
|
|
@@ -2290,7 +2376,7 @@ var WorkflowDragService = class {
|
|
|
2290
2376
|
type,
|
|
2291
2377
|
position,
|
|
2292
2378
|
data,
|
|
2293
|
-
parent
|
|
2379
|
+
parent == null ? void 0 : parent.id
|
|
2294
2380
|
);
|
|
2295
2381
|
return node;
|
|
2296
2382
|
}
|
|
@@ -2340,7 +2426,7 @@ var WorkflowDragService = class {
|
|
|
2340
2426
|
);
|
|
2341
2427
|
return Rectangle8.intersects(draggingRect, transformRect);
|
|
2342
2428
|
});
|
|
2343
|
-
this.updateDropNode(collisionTransform
|
|
2429
|
+
this.updateDropNode(collisionTransform == null ? void 0 : collisionTransform.entity);
|
|
2344
2430
|
},
|
|
2345
2431
|
onDragEnd: async (e) => {
|
|
2346
2432
|
const dropNode = this._dropNode;
|
|
@@ -2457,7 +2543,8 @@ var WorkflowDragService = class {
|
|
|
2457
2543
|
}
|
|
2458
2544
|
/** 是否容器节点 */
|
|
2459
2545
|
isContainer(node) {
|
|
2460
|
-
|
|
2546
|
+
var _a;
|
|
2547
|
+
return (_a = node == null ? void 0 : node.getNodeMeta().isContainer) != null ? _a : false;
|
|
2461
2548
|
}
|
|
2462
2549
|
/**
|
|
2463
2550
|
* 获取节点整体位置
|
|
@@ -2482,7 +2569,7 @@ var WorkflowDragService = class {
|
|
|
2482
2569
|
}
|
|
2483
2570
|
updateDropNode(node) {
|
|
2484
2571
|
if (this._dropNode) {
|
|
2485
|
-
if (this._dropNode.id === node
|
|
2572
|
+
if (this._dropNode.id === (node == null ? void 0 : node.id)) {
|
|
2486
2573
|
return;
|
|
2487
2574
|
}
|
|
2488
2575
|
this.selectService.clear();
|
|
@@ -2504,7 +2591,7 @@ var WorkflowDragService = class {
|
|
|
2504
2591
|
this.hoverService.clearHovered();
|
|
2505
2592
|
}
|
|
2506
2593
|
handleDragOnNode(toNode, fromPort, line, toPort, originLine) {
|
|
2507
|
-
if (toPort && (originLine
|
|
2594
|
+
if (toPort && ((originLine == null ? void 0 : originLine.toPort) === toPort || toPort.portType === "input" && this.linesManager.canAddLine(fromPort, toPort, true))) {
|
|
2508
2595
|
this.hoverService.updateHoveredKey(toPort.id);
|
|
2509
2596
|
line.setToPort(toPort);
|
|
2510
2597
|
this._onDragLineEventEmitter.fire({
|
|
@@ -2526,14 +2613,15 @@ var WorkflowDragService = class {
|
|
|
2526
2613
|
}
|
|
2527
2614
|
}
|
|
2528
2615
|
childrenOfContainer(nodes) {
|
|
2616
|
+
var _a;
|
|
2529
2617
|
if (nodes.length === 0) {
|
|
2530
2618
|
return;
|
|
2531
2619
|
}
|
|
2532
|
-
const sourceContainer = nodes[0]
|
|
2620
|
+
const sourceContainer = (_a = nodes[0]) == null ? void 0 : _a.parent;
|
|
2533
2621
|
if (!sourceContainer || sourceContainer.collapsedChildren.length !== nodes.length) {
|
|
2534
2622
|
return;
|
|
2535
2623
|
}
|
|
2536
|
-
const valid = nodes.every((node) => node
|
|
2624
|
+
const valid = nodes.every((node) => (node == null ? void 0 : node.parent) === sourceContainer);
|
|
2537
2625
|
if (!valid) {
|
|
2538
2626
|
return;
|
|
2539
2627
|
}
|
|
@@ -2546,7 +2634,7 @@ var WorkflowDragService = class {
|
|
|
2546
2634
|
*/
|
|
2547
2635
|
async startDrawingLine(fromPort, event, originLine) {
|
|
2548
2636
|
const isFromInActivePort = !originLine && fromPort.isErrorPort() && fromPort.disabled;
|
|
2549
|
-
if (originLine
|
|
2637
|
+
if ((originLine == null ? void 0 : originLine.disabled) || isFromInActivePort || this.playgroundConfig.readonly || this.playgroundConfig.disabled) {
|
|
2550
2638
|
return { dragSuccess: false, newLine: void 0 };
|
|
2551
2639
|
}
|
|
2552
2640
|
this.selectService.clear();
|
|
@@ -2609,7 +2697,7 @@ var WorkflowDragService = class {
|
|
|
2609
2697
|
} else {
|
|
2610
2698
|
line.drawingTo = { x: dragPos.x, y: dragPos.y };
|
|
2611
2699
|
}
|
|
2612
|
-
originLine
|
|
2700
|
+
originLine == null ? void 0 : originLine.validate();
|
|
2613
2701
|
line.validate();
|
|
2614
2702
|
},
|
|
2615
2703
|
// eslint-disable-next-line complexity
|
|
@@ -2629,7 +2717,7 @@ var WorkflowDragService = class {
|
|
|
2629
2717
|
})
|
|
2630
2718
|
)
|
|
2631
2719
|
);
|
|
2632
|
-
line
|
|
2720
|
+
line == null ? void 0 : line.dispose();
|
|
2633
2721
|
this._onDragLineEventEmitter.fire({
|
|
2634
2722
|
type: "onDragEnd"
|
|
2635
2723
|
});
|
|
@@ -2637,7 +2725,7 @@ var WorkflowDragService = class {
|
|
|
2637
2725
|
originLine.highlightColor = "";
|
|
2638
2726
|
}
|
|
2639
2727
|
const end = () => {
|
|
2640
|
-
originLine
|
|
2728
|
+
originLine == null ? void 0 : originLine.validate();
|
|
2641
2729
|
deferred.resolve({ dragSuccess });
|
|
2642
2730
|
};
|
|
2643
2731
|
if (dragSuccess) {
|
|
@@ -2664,7 +2752,7 @@ var WorkflowDragService = class {
|
|
|
2664
2752
|
if (originLine && (!this.linesManager.canRemove(originLine, newLineInfo, false) || lineErrorReset)) {
|
|
2665
2753
|
return end();
|
|
2666
2754
|
} else {
|
|
2667
|
-
originLine
|
|
2755
|
+
originLine == null ? void 0 : originLine.dispose();
|
|
2668
2756
|
}
|
|
2669
2757
|
if (!toPort || !this.linesManager.canAddLine(fromPort, toPort, false)) {
|
|
2670
2758
|
return end();
|
|
@@ -2768,18 +2856,14 @@ var layoutToPositions = async (nodes, nodePositionMap) => {
|
|
|
2768
2856
|
const transform = node.getData(TransformData10);
|
|
2769
2857
|
const deltaX = (nodePositionMap[node.id].x - transform.position.x) * v.d / 100;
|
|
2770
2858
|
const deltaY = (nodePositionMap[node.id].y - transform.bounds.height / 2 - transform.position.y) * v.d / 100;
|
|
2771
|
-
if (node.collapsedChildren?.length > 0) {
|
|
2772
|
-
node.collapsedChildren.forEach((childNode) => {
|
|
2773
|
-
const childNodeTransformData = childNode.getData(FlowNodeTransformData7);
|
|
2774
|
-
childNodeTransformData.fireChange();
|
|
2775
|
-
});
|
|
2776
|
-
}
|
|
2777
2859
|
transform.update({
|
|
2778
2860
|
position: {
|
|
2779
2861
|
x: transform.position.x + deltaX,
|
|
2780
2862
|
y: transform.position.y + deltaY
|
|
2781
2863
|
}
|
|
2782
2864
|
});
|
|
2865
|
+
const document2 = node.document;
|
|
2866
|
+
document2.layout.updateAffectedTransform(node);
|
|
2783
2867
|
});
|
|
2784
2868
|
},
|
|
2785
2869
|
onComplete: () => {
|
|
@@ -2895,7 +2979,7 @@ function usePlaygroundReadonlyState(listenChange) {
|
|
|
2895
2979
|
if (listenChange) {
|
|
2896
2980
|
dispose = playground.config.onReadonlyOrDisabledChange(() => refresh());
|
|
2897
2981
|
}
|
|
2898
|
-
return () => dispose
|
|
2982
|
+
return () => dispose == null ? void 0 : dispose.dispose();
|
|
2899
2983
|
}, [listenChange]);
|
|
2900
2984
|
return playground.config.readonly;
|
|
2901
2985
|
}
|
|
@@ -2905,6 +2989,7 @@ function checkTargetDraggable(el) {
|
|
|
2905
2989
|
return el && el.tagName !== "INPUT" && el.tagName !== "TEXTAREA" && !el.closest(".flow-canvas-not-draggable");
|
|
2906
2990
|
}
|
|
2907
2991
|
function useNodeRender(nodeFromProps) {
|
|
2992
|
+
var _a, _b;
|
|
2908
2993
|
const node = nodeFromProps || useContext(PlaygroundEntityContext);
|
|
2909
2994
|
const renderData = node.getData(FlowNodeRenderData3);
|
|
2910
2995
|
const portsData = node.getData(WorkflowNodePortsData);
|
|
@@ -2928,6 +3013,7 @@ function useNodeRender(nodeFromProps) {
|
|
|
2928
3013
|
}, []);
|
|
2929
3014
|
const startDrag = useCallback(
|
|
2930
3015
|
(e) => {
|
|
3016
|
+
var _a2;
|
|
2931
3017
|
e.preventDefault();
|
|
2932
3018
|
if (!selectionService.isSelected(node.id)) {
|
|
2933
3019
|
selectNode(e);
|
|
@@ -2936,7 +3022,7 @@ function useNodeRender(nodeFromProps) {
|
|
|
2936
3022
|
return;
|
|
2937
3023
|
}
|
|
2938
3024
|
isDragging.current = true;
|
|
2939
|
-
dragService.startDragSelectedNodes(e)
|
|
3025
|
+
(_a2 = dragService.startDragSelectedNodes(e)) == null ? void 0 : _a2.finally(
|
|
2940
3026
|
() => setTimeout(() => {
|
|
2941
3027
|
isDragging.current = false;
|
|
2942
3028
|
})
|
|
@@ -2962,15 +3048,17 @@ function useNodeRender(nodeFromProps) {
|
|
|
2962
3048
|
);
|
|
2963
3049
|
const deleteNode = useCallback(() => node.dispose(), [node]);
|
|
2964
3050
|
useListenEvents(portsData.onDataChange);
|
|
2965
|
-
const isFirefox = navigator
|
|
3051
|
+
const isFirefox = (_b = (_a = navigator == null ? void 0 : navigator.userAgent) == null ? void 0 : _a.includes) == null ? void 0 : _b.call(_a, "Firefox");
|
|
2966
3052
|
const onFocus = useCallback(() => {
|
|
3053
|
+
var _a2;
|
|
2967
3054
|
if (isFirefox) {
|
|
2968
|
-
nodeRef.current
|
|
3055
|
+
(_a2 = nodeRef.current) == null ? void 0 : _a2.setAttribute("draggable", "false");
|
|
2969
3056
|
}
|
|
2970
3057
|
}, []);
|
|
2971
3058
|
const onBlur = useCallback(() => {
|
|
3059
|
+
var _a2;
|
|
2972
3060
|
if (isFirefox) {
|
|
2973
|
-
nodeRef.current
|
|
3061
|
+
(_a2 = nodeRef.current) == null ? void 0 : _a2.setAttribute("draggable", "true");
|
|
2974
3062
|
}
|
|
2975
3063
|
}, []);
|
|
2976
3064
|
const getExtInfo = useCallback(() => node.getExtInfo(), [node]);
|
|
@@ -2981,7 +3069,7 @@ function useNodeRender(nodeFromProps) {
|
|
|
2981
3069
|
[node]
|
|
2982
3070
|
);
|
|
2983
3071
|
const form = useMemo(() => getNodeForm(node), [node]);
|
|
2984
|
-
const formState = useObserve(form
|
|
3072
|
+
const formState = useObserve(form == null ? void 0 : form.state);
|
|
2985
3073
|
const toggleExpand = useCallback(() => {
|
|
2986
3074
|
renderData.toggleExpand();
|
|
2987
3075
|
}, [renderData]);
|
|
@@ -3117,7 +3205,8 @@ var WorkflowSimpleLineContribution = class {
|
|
|
3117
3205
|
this.entity = entity;
|
|
3118
3206
|
}
|
|
3119
3207
|
get path() {
|
|
3120
|
-
|
|
3208
|
+
var _a, _b;
|
|
3209
|
+
return (_b = (_a = this.data) == null ? void 0 : _a.path) != null ? _b : "";
|
|
3121
3210
|
}
|
|
3122
3211
|
calcDistance(pos) {
|
|
3123
3212
|
if (!this.data) {
|