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