@flowgram.ai/free-group-plugin 0.1.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 +282 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/index.d.mts +34 -0
- package/dist/index.d.ts +34 -0
- package/dist/index.js +301 -0
- package/dist/index.js.map +1 -0
- package/package.json +68 -0
|
@@ -0,0 +1,282 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
4
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
5
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
6
|
+
if (decorator = decorators[i])
|
|
7
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
8
|
+
if (kind && result) __defProp(target, key, result);
|
|
9
|
+
return result;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
// src/create-free-group-plugin.tsx
|
|
13
|
+
import { ShortcutsRegistry } from "@flowgram.ai/shortcuts-plugin";
|
|
14
|
+
import { FlowRendererRegistry } from "@flowgram.ai/renderer";
|
|
15
|
+
import { WorkflowDocument as WorkflowDocument2 } from "@flowgram.ai/free-layout-core";
|
|
16
|
+
import { FlowGroupService as FlowGroupService2, FlowNodeBaseType as FlowNodeBaseType5 } from "@flowgram.ai/document";
|
|
17
|
+
import { definePluginCreator } from "@flowgram.ai/core";
|
|
18
|
+
|
|
19
|
+
// src/workflow-group-service.ts
|
|
20
|
+
import { injectable, inject } from "inversify";
|
|
21
|
+
import { DisposableCollection } from "@flowgram.ai/utils";
|
|
22
|
+
import {
|
|
23
|
+
WorkflowDocument,
|
|
24
|
+
WorkflowOperationBaseService,
|
|
25
|
+
nanoid
|
|
26
|
+
} from "@flowgram.ai/free-layout-core";
|
|
27
|
+
import { HistoryService } from "@flowgram.ai/free-history-plugin";
|
|
28
|
+
import {
|
|
29
|
+
NodeIntoContainerService,
|
|
30
|
+
NodeIntoContainerType
|
|
31
|
+
} from "@flowgram.ai/free-container-plugin";
|
|
32
|
+
import { FlowGroupService, FlowNodeBaseType as FlowNodeBaseType2 } from "@flowgram.ai/document";
|
|
33
|
+
import { TransformData } from "@flowgram.ai/core";
|
|
34
|
+
|
|
35
|
+
// src/utils.ts
|
|
36
|
+
import { FlowNodeBaseType } from "@flowgram.ai/document";
|
|
37
|
+
var WorkflowGroupUtils;
|
|
38
|
+
((WorkflowGroupUtils2) => {
|
|
39
|
+
const isNodeInGroup = (node) => {
|
|
40
|
+
if (node?.parent?.flowNodeType === FlowNodeBaseType.GROUP) {
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
return false;
|
|
44
|
+
};
|
|
45
|
+
const isGroupNode = (group) => group.flowNodeType === FlowNodeBaseType.GROUP;
|
|
46
|
+
WorkflowGroupUtils2.validate = (nodes) => {
|
|
47
|
+
if (!nodes || !Array.isArray(nodes) || nodes.length === 0) {
|
|
48
|
+
return false;
|
|
49
|
+
}
|
|
50
|
+
const isGroupRelatedNode = nodes.some((node) => isGroupNode(node));
|
|
51
|
+
if (isGroupRelatedNode) return false;
|
|
52
|
+
const hasGroup = nodes.some((node) => node && isNodeInGroup(node));
|
|
53
|
+
if (hasGroup) return false;
|
|
54
|
+
const parent = nodes[0].parent;
|
|
55
|
+
const isSameParent = nodes.every((node) => node.parent === parent);
|
|
56
|
+
if (!isSameParent) return false;
|
|
57
|
+
return true;
|
|
58
|
+
};
|
|
59
|
+
})(WorkflowGroupUtils || (WorkflowGroupUtils = {}));
|
|
60
|
+
|
|
61
|
+
// src/workflow-group-service.ts
|
|
62
|
+
var WorkflowGroupService = class extends FlowGroupService {
|
|
63
|
+
constructor() {
|
|
64
|
+
super(...arguments);
|
|
65
|
+
this.toDispose = new DisposableCollection();
|
|
66
|
+
}
|
|
67
|
+
ready() {
|
|
68
|
+
this.toDispose.push(this.listenContainer());
|
|
69
|
+
}
|
|
70
|
+
dispose() {
|
|
71
|
+
this.toDispose.dispose();
|
|
72
|
+
}
|
|
73
|
+
/** 创建分组节点 */
|
|
74
|
+
createGroup(nodes) {
|
|
75
|
+
if (!WorkflowGroupUtils.validate(nodes)) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
const parent = nodes[0].parent ?? this.document.root;
|
|
79
|
+
const groupId = `group_${nanoid(5)}`;
|
|
80
|
+
const groupJSON = {
|
|
81
|
+
type: FlowNodeBaseType2.GROUP,
|
|
82
|
+
id: groupId,
|
|
83
|
+
meta: {
|
|
84
|
+
position: {
|
|
85
|
+
x: 0,
|
|
86
|
+
y: 0
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
data: {}
|
|
90
|
+
};
|
|
91
|
+
this.historyService.startTransaction();
|
|
92
|
+
this.document.createWorkflowNodeByType(
|
|
93
|
+
FlowNodeBaseType2.GROUP,
|
|
94
|
+
{
|
|
95
|
+
x: 0,
|
|
96
|
+
y: 0
|
|
97
|
+
},
|
|
98
|
+
groupJSON,
|
|
99
|
+
parent.id
|
|
100
|
+
);
|
|
101
|
+
nodes.forEach((node) => {
|
|
102
|
+
this.freeOperationService.moveNode(node, {
|
|
103
|
+
parent: groupId
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
this.historyService.endTransaction();
|
|
107
|
+
}
|
|
108
|
+
/** 取消分组 */
|
|
109
|
+
ungroup(groupNode) {
|
|
110
|
+
const groupBlocks = groupNode.blocks.slice();
|
|
111
|
+
if (!groupNode.parent) {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
const groupPosition = groupNode.transform.position;
|
|
115
|
+
this.historyService.startTransaction();
|
|
116
|
+
groupBlocks.forEach((node) => {
|
|
117
|
+
this.freeOperationService.moveNode(node, {
|
|
118
|
+
parent: groupNode.parent?.id
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
groupNode.dispose();
|
|
122
|
+
groupBlocks.forEach((node) => {
|
|
123
|
+
const transform = node.getData(TransformData);
|
|
124
|
+
const position = {
|
|
125
|
+
x: transform.position.x + groupPosition.x,
|
|
126
|
+
y: transform.position.y + groupPosition.y
|
|
127
|
+
};
|
|
128
|
+
this.freeOperationService.updateNodePosition(node, position);
|
|
129
|
+
});
|
|
130
|
+
this.historyService.endTransaction();
|
|
131
|
+
}
|
|
132
|
+
listenContainer() {
|
|
133
|
+
return this.nodeIntoContainerService.on((e) => {
|
|
134
|
+
if (e.type !== NodeIntoContainerType.Out || e.sourceContainer?.flowNodeType !== FlowNodeBaseType2.GROUP) {
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
if (e.sourceContainer?.blocks.length === 0) {
|
|
138
|
+
e.sourceContainer.dispose();
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
};
|
|
143
|
+
__decorateClass([
|
|
144
|
+
inject(WorkflowDocument)
|
|
145
|
+
], WorkflowGroupService.prototype, "document", 2);
|
|
146
|
+
__decorateClass([
|
|
147
|
+
inject(WorkflowOperationBaseService)
|
|
148
|
+
], WorkflowGroupService.prototype, "freeOperationService", 2);
|
|
149
|
+
__decorateClass([
|
|
150
|
+
inject(HistoryService)
|
|
151
|
+
], WorkflowGroupService.prototype, "historyService", 2);
|
|
152
|
+
__decorateClass([
|
|
153
|
+
inject(NodeIntoContainerService)
|
|
154
|
+
], WorkflowGroupService.prototype, "nodeIntoContainerService", 2);
|
|
155
|
+
WorkflowGroupService = __decorateClass([
|
|
156
|
+
injectable()
|
|
157
|
+
], WorkflowGroupService);
|
|
158
|
+
|
|
159
|
+
// src/shortcuts/group.ts
|
|
160
|
+
import { WorkflowSelectService } from "@flowgram.ai/free-layout-core";
|
|
161
|
+
|
|
162
|
+
// src/constant.ts
|
|
163
|
+
var WorkflowGroupCommand = /* @__PURE__ */ ((WorkflowGroupCommand2) => {
|
|
164
|
+
WorkflowGroupCommand2["Group"] = "group";
|
|
165
|
+
WorkflowGroupCommand2["Ungroup"] = "ungroup";
|
|
166
|
+
return WorkflowGroupCommand2;
|
|
167
|
+
})(WorkflowGroupCommand || {});
|
|
168
|
+
|
|
169
|
+
// src/shortcuts/group.ts
|
|
170
|
+
var GroupShortcut = class {
|
|
171
|
+
constructor(context) {
|
|
172
|
+
this.commandId = "group" /* Group */;
|
|
173
|
+
this.commandDetail = {
|
|
174
|
+
label: "Group"
|
|
175
|
+
};
|
|
176
|
+
this.shortcuts = ["meta g", "ctrl g"];
|
|
177
|
+
this.selectService = context.get(WorkflowSelectService);
|
|
178
|
+
this.groupService = context.get(WorkflowGroupService);
|
|
179
|
+
this.execute = this.execute.bind(this);
|
|
180
|
+
}
|
|
181
|
+
async execute() {
|
|
182
|
+
this.groupService.createGroup(this.selectService.selectedNodes);
|
|
183
|
+
this.selectService.clear();
|
|
184
|
+
}
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
// src/shortcuts/ungroup.ts
|
|
188
|
+
import { WorkflowSelectService as WorkflowSelectService2 } from "@flowgram.ai/free-layout-core";
|
|
189
|
+
import { FlowNodeBaseType as FlowNodeBaseType3 } from "@flowgram.ai/document";
|
|
190
|
+
var UngroupShortcut = class {
|
|
191
|
+
constructor(context) {
|
|
192
|
+
this.commandId = "ungroup" /* Ungroup */;
|
|
193
|
+
this.commandDetail = {
|
|
194
|
+
label: "Ungroup"
|
|
195
|
+
};
|
|
196
|
+
this.shortcuts = ["meta shift g", "ctrl shift g"];
|
|
197
|
+
this.selectService = context.get(WorkflowSelectService2);
|
|
198
|
+
this.groupService = context.get(WorkflowGroupService);
|
|
199
|
+
this.execute = this.execute.bind(this);
|
|
200
|
+
}
|
|
201
|
+
async execute(_groupNode) {
|
|
202
|
+
const groupNode = _groupNode || this.selectService.activatedNode;
|
|
203
|
+
if (!groupNode || groupNode.flowNodeType !== FlowNodeBaseType3.GROUP) {
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
this.groupService.ungroup(groupNode);
|
|
207
|
+
this.selectService.clear();
|
|
208
|
+
}
|
|
209
|
+
};
|
|
210
|
+
|
|
211
|
+
// src/group-node.tsx
|
|
212
|
+
import { FlowNodeBaseType as FlowNodeBaseType4, FlowNodeTransformData } from "@flowgram.ai/document";
|
|
213
|
+
var GroupNodeRegistry = {
|
|
214
|
+
type: FlowNodeBaseType4.GROUP,
|
|
215
|
+
meta: {
|
|
216
|
+
renderKey: FlowNodeBaseType4.GROUP,
|
|
217
|
+
defaultPorts: [],
|
|
218
|
+
isContainer: true,
|
|
219
|
+
disableSideBar: true,
|
|
220
|
+
size: {
|
|
221
|
+
width: 560,
|
|
222
|
+
height: 400
|
|
223
|
+
},
|
|
224
|
+
padding: () => ({
|
|
225
|
+
top: 80,
|
|
226
|
+
bottom: 40,
|
|
227
|
+
left: 65,
|
|
228
|
+
right: 65
|
|
229
|
+
}),
|
|
230
|
+
selectable(node, mousePos) {
|
|
231
|
+
if (!mousePos) {
|
|
232
|
+
return true;
|
|
233
|
+
}
|
|
234
|
+
const transform = node.getData(FlowNodeTransformData);
|
|
235
|
+
return !transform.bounds.contains(mousePos.x, mousePos.y);
|
|
236
|
+
},
|
|
237
|
+
expandable: false
|
|
238
|
+
},
|
|
239
|
+
formMeta: {
|
|
240
|
+
render: () => /* @__PURE__ */ React.createElement(React.Fragment, null)
|
|
241
|
+
},
|
|
242
|
+
onCreate() {
|
|
243
|
+
}
|
|
244
|
+
};
|
|
245
|
+
|
|
246
|
+
// src/create-free-group-plugin.tsx
|
|
247
|
+
var createFreeGroupPlugin = definePluginCreator(
|
|
248
|
+
{
|
|
249
|
+
onBind({ bind, rebind }) {
|
|
250
|
+
bind(WorkflowGroupService).toSelf().inSingletonScope();
|
|
251
|
+
rebind(FlowGroupService2).toService(WorkflowGroupService);
|
|
252
|
+
},
|
|
253
|
+
onInit(ctx, { groupNodeRender, disableGroupShortcuts = false, disableGroupNodeRegister = false }) {
|
|
254
|
+
if (groupNodeRender) {
|
|
255
|
+
const renderRegistry = ctx.get(FlowRendererRegistry);
|
|
256
|
+
renderRegistry.registerReactComponent(FlowNodeBaseType5.GROUP, groupNodeRender);
|
|
257
|
+
}
|
|
258
|
+
if (!disableGroupShortcuts) {
|
|
259
|
+
const shortcutsRegistry = ctx.get(ShortcutsRegistry);
|
|
260
|
+
shortcutsRegistry.addHandlers(new GroupShortcut(ctx), new UngroupShortcut(ctx));
|
|
261
|
+
}
|
|
262
|
+
if (!disableGroupNodeRegister) {
|
|
263
|
+
const document = ctx.get(WorkflowDocument2);
|
|
264
|
+
document.registerFlowNodes(GroupNodeRegistry);
|
|
265
|
+
}
|
|
266
|
+
},
|
|
267
|
+
onReady(ctx) {
|
|
268
|
+
const groupService = ctx.get(WorkflowGroupService);
|
|
269
|
+
groupService.ready();
|
|
270
|
+
},
|
|
271
|
+
onDispose(ctx) {
|
|
272
|
+
const groupService = ctx.get(WorkflowGroupService);
|
|
273
|
+
groupService.dispose();
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
);
|
|
277
|
+
export {
|
|
278
|
+
WorkflowGroupCommand,
|
|
279
|
+
WorkflowGroupService,
|
|
280
|
+
createFreeGroupPlugin
|
|
281
|
+
};
|
|
282
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/create-free-group-plugin.tsx","../../src/workflow-group-service.ts","../../src/utils.ts","../../src/shortcuts/group.ts","../../src/constant.ts","../../src/shortcuts/ungroup.ts","../../src/group-node.tsx"],"sourcesContent":["import { ShortcutsRegistry } from '@flowgram.ai/shortcuts-plugin';\nimport { FlowRendererRegistry } from '@flowgram.ai/renderer';\nimport { WorkflowDocument } from '@flowgram.ai/free-layout-core';\nimport { FlowGroupService, FlowNodeBaseType } from '@flowgram.ai/document';\nimport { definePluginCreator, PluginContext } from '@flowgram.ai/core';\n\nimport { WorkflowGroupService } from './workflow-group-service';\nimport { WorkflowGroupPluginOptions } from './type';\nimport { GroupShortcut, UngroupShortcut } from './shortcuts';\nimport { GroupNodeRegistry } from './group-node';\n\nexport const createFreeGroupPlugin = definePluginCreator<WorkflowGroupPluginOptions, PluginContext>(\n {\n onBind({ bind, rebind }) {\n bind(WorkflowGroupService).toSelf().inSingletonScope();\n rebind(FlowGroupService).toService(WorkflowGroupService);\n },\n onInit(\n ctx,\n { groupNodeRender, disableGroupShortcuts = false, disableGroupNodeRegister = false }\n ) {\n // register node render\n if (groupNodeRender) {\n const renderRegistry = ctx.get<FlowRendererRegistry>(FlowRendererRegistry);\n renderRegistry.registerReactComponent(FlowNodeBaseType.GROUP, groupNodeRender);\n }\n // register shortcuts\n if (!disableGroupShortcuts) {\n const shortcutsRegistry = ctx.get(ShortcutsRegistry);\n shortcutsRegistry.addHandlers(new GroupShortcut(ctx), new UngroupShortcut(ctx));\n }\n if (!disableGroupNodeRegister) {\n const document = ctx.get(WorkflowDocument);\n document.registerFlowNodes(GroupNodeRegistry);\n }\n },\n onReady(ctx) {\n const groupService = ctx.get(WorkflowGroupService);\n groupService.ready();\n },\n onDispose(ctx) {\n const groupService = ctx.get(WorkflowGroupService);\n groupService.dispose();\n },\n }\n);\n","import { injectable, inject } from 'inversify';\nimport { DisposableCollection, Disposable } from '@flowgram.ai/utils';\nimport {\n WorkflowDocument,\n WorkflowOperationBaseService,\n WorkflowNodeEntity,\n nanoid,\n WorkflowNodeJSON,\n} from '@flowgram.ai/free-layout-core';\nimport { HistoryService } from '@flowgram.ai/free-history-plugin';\nimport {\n NodeIntoContainerService,\n NodeIntoContainerType,\n} from '@flowgram.ai/free-container-plugin';\nimport { FlowGroupService, FlowNodeBaseType } from '@flowgram.ai/document';\nimport { TransformData } from '@flowgram.ai/core';\n\nimport { WorkflowGroupUtils } from './utils';\n\n@injectable()\n/** 分组服务 */\nexport class WorkflowGroupService extends FlowGroupService {\n @inject(WorkflowDocument) private document: WorkflowDocument;\n\n @inject(WorkflowOperationBaseService) freeOperationService: WorkflowOperationBaseService;\n\n @inject(HistoryService) private historyService: HistoryService;\n\n @inject(NodeIntoContainerService) private nodeIntoContainerService: NodeIntoContainerService;\n\n private toDispose = new DisposableCollection();\n\n public ready(): void {\n this.toDispose.push(this.listenContainer());\n }\n\n public dispose(): void {\n this.toDispose.dispose();\n }\n\n /** 创建分组节点 */\n public createGroup(nodes: WorkflowNodeEntity[]): WorkflowNodeEntity | undefined {\n if (!WorkflowGroupUtils.validate(nodes)) {\n return;\n }\n const parent = nodes[0].parent ?? this.document.root;\n const groupId = `group_${nanoid(5)}`;\n const groupJSON: WorkflowNodeJSON = {\n type: FlowNodeBaseType.GROUP,\n id: groupId,\n meta: {\n position: {\n x: 0,\n y: 0,\n },\n },\n data: {},\n };\n this.historyService.startTransaction();\n this.document.createWorkflowNodeByType(\n FlowNodeBaseType.GROUP,\n {\n x: 0,\n y: 0,\n },\n groupJSON,\n parent.id\n );\n nodes.forEach((node) => {\n this.freeOperationService.moveNode(node, {\n parent: groupId,\n });\n });\n this.historyService.endTransaction();\n }\n\n /** 取消分组 */\n public ungroup(groupNode: WorkflowNodeEntity): void {\n const groupBlocks = groupNode.blocks.slice();\n if (!groupNode.parent) {\n return;\n }\n const groupPosition = groupNode.transform.position;\n\n this.historyService.startTransaction();\n groupBlocks.forEach((node) => {\n this.freeOperationService.moveNode(node, {\n parent: groupNode.parent?.id,\n });\n });\n groupNode.dispose();\n groupBlocks.forEach((node) => {\n const transform = node.getData(TransformData);\n const position = {\n x: transform.position.x + groupPosition.x,\n y: transform.position.y + groupPosition.y,\n };\n this.freeOperationService.updateNodePosition(node, position);\n });\n this.historyService.endTransaction();\n }\n\n private listenContainer(): Disposable {\n return this.nodeIntoContainerService.on((e) => {\n if (\n e.type !== NodeIntoContainerType.Out ||\n e.sourceContainer?.flowNodeType !== FlowNodeBaseType.GROUP\n ) {\n return;\n }\n if (e.sourceContainer?.blocks.length === 0) {\n e.sourceContainer.dispose();\n }\n });\n }\n}\n","import { WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';\nimport { FlowNodeBaseType } from '@flowgram.ai/document';\n\nexport namespace WorkflowGroupUtils {\n /** 找到节点所有上级 */\n // const findNodeParents = (node: WorkflowNodeEntity): WorkflowNodeEntity[] => {\n // const parents = [];\n // let parent = node.parent;\n // while (parent) {\n // parents.push(parent);\n // parent = parent.parent;\n // }\n // return parents;\n // };\n\n /** 节点是否处于分组中 */\n const isNodeInGroup = (node: WorkflowNodeEntity): boolean => {\n // 处于分组中\n if (node?.parent?.flowNodeType === FlowNodeBaseType.GROUP) {\n return true;\n }\n return false;\n };\n\n /** 是否分组节点 */\n const isGroupNode = (group: WorkflowNodeEntity): boolean =>\n group.flowNodeType === FlowNodeBaseType.GROUP;\n\n /** 判断节点能否组成分组 */\n export const validate = (nodes: WorkflowNodeEntity[]): boolean => {\n if (!nodes || !Array.isArray(nodes) || nodes.length === 0) {\n // 参数不合法\n return false;\n }\n\n // 判断是否有分组节点\n const isGroupRelatedNode = nodes.some((node) => isGroupNode(node));\n if (isGroupRelatedNode) return false;\n\n // 判断是否有节点已经处于分组中\n const hasGroup = nodes.some((node) => node && isNodeInGroup(node));\n if (hasGroup) return false;\n\n // 判断是否来自同一个父亲\n const parent = nodes[0].parent;\n const isSameParent = nodes.every((node) => node.parent === parent);\n if (!isSameParent) return false;\n\n // 判断节点父亲是否已经在分组中\n // const parents = findNodeParents(nodes[0]);\n // const parentsInGroup = parents.some((parent) => isNodeInGroup(parent));\n // if (parentsInGroup) return false;\n\n // 参数正确\n return true;\n };\n}\n","import { ShortcutsHandler } from '@flowgram.ai/shortcuts-plugin';\nimport { WorkflowSelectService } from '@flowgram.ai/free-layout-core';\nimport { PluginContext } from '@flowgram.ai/core';\n\nimport { WorkflowGroupService } from '../workflow-group-service';\nimport { WorkflowGroupCommand } from '../constant';\n\nexport class GroupShortcut implements ShortcutsHandler {\n public commandId = WorkflowGroupCommand.Group;\n\n public commandDetail: ShortcutsHandler['commandDetail'] = {\n label: 'Group',\n };\n\n public shortcuts = ['meta g', 'ctrl g'];\n\n private selectService: WorkflowSelectService;\n\n private groupService: WorkflowGroupService;\n\n constructor(context: PluginContext) {\n this.selectService = context.get(WorkflowSelectService);\n this.groupService = context.get(WorkflowGroupService);\n this.execute = this.execute.bind(this);\n }\n\n public async execute(): Promise<void> {\n this.groupService.createGroup(this.selectService.selectedNodes);\n this.selectService.clear();\n }\n}\n","export enum WorkflowGroupCommand {\n Group = 'group',\n Ungroup = 'ungroup',\n}\n","import { ShortcutsHandler } from '@flowgram.ai/shortcuts-plugin';\nimport { WorkflowSelectService, WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';\nimport { FlowNodeBaseType } from '@flowgram.ai/document';\nimport { PluginContext } from '@flowgram.ai/core';\n\nimport { WorkflowGroupService } from '../workflow-group-service';\nimport { WorkflowGroupCommand } from '../constant';\n\nexport class UngroupShortcut implements ShortcutsHandler {\n public commandId = WorkflowGroupCommand.Ungroup;\n\n public commandDetail: ShortcutsHandler['commandDetail'] = {\n label: 'Ungroup',\n };\n\n public shortcuts = ['meta shift g', 'ctrl shift g'];\n\n private selectService: WorkflowSelectService;\n\n private groupService: WorkflowGroupService;\n\n constructor(context: PluginContext) {\n this.selectService = context.get(WorkflowSelectService);\n this.groupService = context.get(WorkflowGroupService);\n this.execute = this.execute.bind(this);\n }\n\n public async execute(_groupNode?: WorkflowNodeEntity): Promise<void> {\n const groupNode = _groupNode || this.selectService.activatedNode;\n if (!groupNode || groupNode.flowNodeType !== FlowNodeBaseType.GROUP) {\n return;\n }\n this.groupService.ungroup(groupNode);\n this.selectService.clear();\n }\n}\n","import { PositionSchema } from '@flowgram.ai/utils';\nimport { WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';\nimport { FlowNodeRegistry, FlowNodeBaseType, FlowNodeTransformData } from '@flowgram.ai/document';\n\nexport const GroupNodeRegistry: FlowNodeRegistry = {\n type: FlowNodeBaseType.GROUP,\n meta: {\n renderKey: FlowNodeBaseType.GROUP,\n defaultPorts: [],\n isContainer: true,\n disableSideBar: true,\n size: {\n width: 560,\n height: 400,\n },\n padding: () => ({\n top: 80,\n bottom: 40,\n left: 65,\n right: 65,\n }),\n selectable(node: WorkflowNodeEntity, mousePos?: PositionSchema): boolean {\n if (!mousePos) {\n return true;\n }\n const transform = node.getData<FlowNodeTransformData>(FlowNodeTransformData);\n return !transform.bounds.contains(mousePos.x, mousePos.y);\n },\n expandable: false,\n },\n formMeta: {\n render: () => <></>,\n },\n onCreate() {\n // NOTICE: 这个函数是为了避免触发固定布局 flowDocument.addBlocksAsChildren\n },\n};\n"],"mappings":"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","names":["WorkflowDocument","FlowGroupService","FlowNodeBaseType","FlowNodeBaseType","WorkflowGroupUtils","FlowNodeBaseType","WorkflowGroupCommand","WorkflowSelectService","FlowNodeBaseType","WorkflowSelectService","FlowNodeBaseType","FlowNodeBaseType","FlowGroupService","FlowNodeBaseType","WorkflowDocument"]}
|
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import * as _flowgram_ai_core from '@flowgram.ai/core';
|
|
2
|
+
import { FC } from 'react';
|
|
3
|
+
import { WorkflowOperationBaseService, WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';
|
|
4
|
+
import { FlowGroupService } from '@flowgram.ai/document';
|
|
5
|
+
|
|
6
|
+
interface WorkflowGroupPluginOptions {
|
|
7
|
+
groupNodeRender: FC;
|
|
8
|
+
disableGroupShortcuts?: boolean;
|
|
9
|
+
disableGroupNodeRegister?: boolean;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
declare const createFreeGroupPlugin: _flowgram_ai_core.PluginCreator<WorkflowGroupPluginOptions>;
|
|
13
|
+
|
|
14
|
+
declare class WorkflowGroupService extends FlowGroupService {
|
|
15
|
+
private document;
|
|
16
|
+
freeOperationService: WorkflowOperationBaseService;
|
|
17
|
+
private historyService;
|
|
18
|
+
private nodeIntoContainerService;
|
|
19
|
+
private toDispose;
|
|
20
|
+
ready(): void;
|
|
21
|
+
dispose(): void;
|
|
22
|
+
/** 创建分组节点 */
|
|
23
|
+
createGroup(nodes: WorkflowNodeEntity[]): WorkflowNodeEntity | undefined;
|
|
24
|
+
/** 取消分组 */
|
|
25
|
+
ungroup(groupNode: WorkflowNodeEntity): void;
|
|
26
|
+
private listenContainer;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
declare enum WorkflowGroupCommand {
|
|
30
|
+
Group = "group",
|
|
31
|
+
Ungroup = "ungroup"
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export { WorkflowGroupCommand, WorkflowGroupService, createFreeGroupPlugin };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import * as _flowgram_ai_core from '@flowgram.ai/core';
|
|
2
|
+
import { FC } from 'react';
|
|
3
|
+
import { WorkflowOperationBaseService, WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';
|
|
4
|
+
import { FlowGroupService } from '@flowgram.ai/document';
|
|
5
|
+
|
|
6
|
+
interface WorkflowGroupPluginOptions {
|
|
7
|
+
groupNodeRender: FC;
|
|
8
|
+
disableGroupShortcuts?: boolean;
|
|
9
|
+
disableGroupNodeRegister?: boolean;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
declare const createFreeGroupPlugin: _flowgram_ai_core.PluginCreator<WorkflowGroupPluginOptions>;
|
|
13
|
+
|
|
14
|
+
declare class WorkflowGroupService extends FlowGroupService {
|
|
15
|
+
private document;
|
|
16
|
+
freeOperationService: WorkflowOperationBaseService;
|
|
17
|
+
private historyService;
|
|
18
|
+
private nodeIntoContainerService;
|
|
19
|
+
private toDispose;
|
|
20
|
+
ready(): void;
|
|
21
|
+
dispose(): void;
|
|
22
|
+
/** 创建分组节点 */
|
|
23
|
+
createGroup(nodes: WorkflowNodeEntity[]): WorkflowNodeEntity | undefined;
|
|
24
|
+
/** 取消分组 */
|
|
25
|
+
ungroup(groupNode: WorkflowNodeEntity): void;
|
|
26
|
+
private listenContainer;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
declare enum WorkflowGroupCommand {
|
|
30
|
+
Group = "group",
|
|
31
|
+
Ungroup = "ungroup"
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export { WorkflowGroupCommand, WorkflowGroupService, createFreeGroupPlugin };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
20
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
21
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
22
|
+
if (decorator = decorators[i])
|
|
23
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
24
|
+
if (kind && result) __defProp(target, key, result);
|
|
25
|
+
return result;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
// src/index.ts
|
|
29
|
+
var src_exports = {};
|
|
30
|
+
__export(src_exports, {
|
|
31
|
+
WorkflowGroupCommand: () => WorkflowGroupCommand,
|
|
32
|
+
WorkflowGroupService: () => WorkflowGroupService,
|
|
33
|
+
createFreeGroupPlugin: () => createFreeGroupPlugin
|
|
34
|
+
});
|
|
35
|
+
module.exports = __toCommonJS(src_exports);
|
|
36
|
+
|
|
37
|
+
// src/create-free-group-plugin.tsx
|
|
38
|
+
var import_shortcuts_plugin = require("@flowgram.ai/shortcuts-plugin");
|
|
39
|
+
var import_renderer = require("@flowgram.ai/renderer");
|
|
40
|
+
var import_free_layout_core4 = require("@flowgram.ai/free-layout-core");
|
|
41
|
+
var import_document5 = require("@flowgram.ai/document");
|
|
42
|
+
var import_core2 = require("@flowgram.ai/core");
|
|
43
|
+
|
|
44
|
+
// src/workflow-group-service.ts
|
|
45
|
+
var import_inversify = require("inversify");
|
|
46
|
+
var import_utils = require("@flowgram.ai/utils");
|
|
47
|
+
var import_free_layout_core = require("@flowgram.ai/free-layout-core");
|
|
48
|
+
var import_free_history_plugin = require("@flowgram.ai/free-history-plugin");
|
|
49
|
+
var import_free_container_plugin = require("@flowgram.ai/free-container-plugin");
|
|
50
|
+
var import_document2 = require("@flowgram.ai/document");
|
|
51
|
+
var import_core = require("@flowgram.ai/core");
|
|
52
|
+
|
|
53
|
+
// src/utils.ts
|
|
54
|
+
var import_document = require("@flowgram.ai/document");
|
|
55
|
+
var WorkflowGroupUtils;
|
|
56
|
+
((WorkflowGroupUtils2) => {
|
|
57
|
+
const isNodeInGroup = (node) => {
|
|
58
|
+
if (node?.parent?.flowNodeType === import_document.FlowNodeBaseType.GROUP) {
|
|
59
|
+
return true;
|
|
60
|
+
}
|
|
61
|
+
return false;
|
|
62
|
+
};
|
|
63
|
+
const isGroupNode = (group) => group.flowNodeType === import_document.FlowNodeBaseType.GROUP;
|
|
64
|
+
WorkflowGroupUtils2.validate = (nodes) => {
|
|
65
|
+
if (!nodes || !Array.isArray(nodes) || nodes.length === 0) {
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
const isGroupRelatedNode = nodes.some((node) => isGroupNode(node));
|
|
69
|
+
if (isGroupRelatedNode) return false;
|
|
70
|
+
const hasGroup = nodes.some((node) => node && isNodeInGroup(node));
|
|
71
|
+
if (hasGroup) return false;
|
|
72
|
+
const parent = nodes[0].parent;
|
|
73
|
+
const isSameParent = nodes.every((node) => node.parent === parent);
|
|
74
|
+
if (!isSameParent) return false;
|
|
75
|
+
return true;
|
|
76
|
+
};
|
|
77
|
+
})(WorkflowGroupUtils || (WorkflowGroupUtils = {}));
|
|
78
|
+
|
|
79
|
+
// src/workflow-group-service.ts
|
|
80
|
+
var WorkflowGroupService = class extends import_document2.FlowGroupService {
|
|
81
|
+
constructor() {
|
|
82
|
+
super(...arguments);
|
|
83
|
+
this.toDispose = new import_utils.DisposableCollection();
|
|
84
|
+
}
|
|
85
|
+
ready() {
|
|
86
|
+
this.toDispose.push(this.listenContainer());
|
|
87
|
+
}
|
|
88
|
+
dispose() {
|
|
89
|
+
this.toDispose.dispose();
|
|
90
|
+
}
|
|
91
|
+
/** 创建分组节点 */
|
|
92
|
+
createGroup(nodes) {
|
|
93
|
+
if (!WorkflowGroupUtils.validate(nodes)) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
const parent = nodes[0].parent ?? this.document.root;
|
|
97
|
+
const groupId = `group_${(0, import_free_layout_core.nanoid)(5)}`;
|
|
98
|
+
const groupJSON = {
|
|
99
|
+
type: import_document2.FlowNodeBaseType.GROUP,
|
|
100
|
+
id: groupId,
|
|
101
|
+
meta: {
|
|
102
|
+
position: {
|
|
103
|
+
x: 0,
|
|
104
|
+
y: 0
|
|
105
|
+
}
|
|
106
|
+
},
|
|
107
|
+
data: {}
|
|
108
|
+
};
|
|
109
|
+
this.historyService.startTransaction();
|
|
110
|
+
this.document.createWorkflowNodeByType(
|
|
111
|
+
import_document2.FlowNodeBaseType.GROUP,
|
|
112
|
+
{
|
|
113
|
+
x: 0,
|
|
114
|
+
y: 0
|
|
115
|
+
},
|
|
116
|
+
groupJSON,
|
|
117
|
+
parent.id
|
|
118
|
+
);
|
|
119
|
+
nodes.forEach((node) => {
|
|
120
|
+
this.freeOperationService.moveNode(node, {
|
|
121
|
+
parent: groupId
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
this.historyService.endTransaction();
|
|
125
|
+
}
|
|
126
|
+
/** 取消分组 */
|
|
127
|
+
ungroup(groupNode) {
|
|
128
|
+
const groupBlocks = groupNode.blocks.slice();
|
|
129
|
+
if (!groupNode.parent) {
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
const groupPosition = groupNode.transform.position;
|
|
133
|
+
this.historyService.startTransaction();
|
|
134
|
+
groupBlocks.forEach((node) => {
|
|
135
|
+
this.freeOperationService.moveNode(node, {
|
|
136
|
+
parent: groupNode.parent?.id
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
groupNode.dispose();
|
|
140
|
+
groupBlocks.forEach((node) => {
|
|
141
|
+
const transform = node.getData(import_core.TransformData);
|
|
142
|
+
const position = {
|
|
143
|
+
x: transform.position.x + groupPosition.x,
|
|
144
|
+
y: transform.position.y + groupPosition.y
|
|
145
|
+
};
|
|
146
|
+
this.freeOperationService.updateNodePosition(node, position);
|
|
147
|
+
});
|
|
148
|
+
this.historyService.endTransaction();
|
|
149
|
+
}
|
|
150
|
+
listenContainer() {
|
|
151
|
+
return this.nodeIntoContainerService.on((e) => {
|
|
152
|
+
if (e.type !== import_free_container_plugin.NodeIntoContainerType.Out || e.sourceContainer?.flowNodeType !== import_document2.FlowNodeBaseType.GROUP) {
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
if (e.sourceContainer?.blocks.length === 0) {
|
|
156
|
+
e.sourceContainer.dispose();
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
__decorateClass([
|
|
162
|
+
(0, import_inversify.inject)(import_free_layout_core.WorkflowDocument)
|
|
163
|
+
], WorkflowGroupService.prototype, "document", 2);
|
|
164
|
+
__decorateClass([
|
|
165
|
+
(0, import_inversify.inject)(import_free_layout_core.WorkflowOperationBaseService)
|
|
166
|
+
], WorkflowGroupService.prototype, "freeOperationService", 2);
|
|
167
|
+
__decorateClass([
|
|
168
|
+
(0, import_inversify.inject)(import_free_history_plugin.HistoryService)
|
|
169
|
+
], WorkflowGroupService.prototype, "historyService", 2);
|
|
170
|
+
__decorateClass([
|
|
171
|
+
(0, import_inversify.inject)(import_free_container_plugin.NodeIntoContainerService)
|
|
172
|
+
], WorkflowGroupService.prototype, "nodeIntoContainerService", 2);
|
|
173
|
+
WorkflowGroupService = __decorateClass([
|
|
174
|
+
(0, import_inversify.injectable)()
|
|
175
|
+
], WorkflowGroupService);
|
|
176
|
+
|
|
177
|
+
// src/shortcuts/group.ts
|
|
178
|
+
var import_free_layout_core2 = require("@flowgram.ai/free-layout-core");
|
|
179
|
+
|
|
180
|
+
// src/constant.ts
|
|
181
|
+
var WorkflowGroupCommand = /* @__PURE__ */ ((WorkflowGroupCommand2) => {
|
|
182
|
+
WorkflowGroupCommand2["Group"] = "group";
|
|
183
|
+
WorkflowGroupCommand2["Ungroup"] = "ungroup";
|
|
184
|
+
return WorkflowGroupCommand2;
|
|
185
|
+
})(WorkflowGroupCommand || {});
|
|
186
|
+
|
|
187
|
+
// src/shortcuts/group.ts
|
|
188
|
+
var GroupShortcut = class {
|
|
189
|
+
constructor(context) {
|
|
190
|
+
this.commandId = "group" /* Group */;
|
|
191
|
+
this.commandDetail = {
|
|
192
|
+
label: "Group"
|
|
193
|
+
};
|
|
194
|
+
this.shortcuts = ["meta g", "ctrl g"];
|
|
195
|
+
this.selectService = context.get(import_free_layout_core2.WorkflowSelectService);
|
|
196
|
+
this.groupService = context.get(WorkflowGroupService);
|
|
197
|
+
this.execute = this.execute.bind(this);
|
|
198
|
+
}
|
|
199
|
+
async execute() {
|
|
200
|
+
this.groupService.createGroup(this.selectService.selectedNodes);
|
|
201
|
+
this.selectService.clear();
|
|
202
|
+
}
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
// src/shortcuts/ungroup.ts
|
|
206
|
+
var import_free_layout_core3 = require("@flowgram.ai/free-layout-core");
|
|
207
|
+
var import_document3 = require("@flowgram.ai/document");
|
|
208
|
+
var UngroupShortcut = class {
|
|
209
|
+
constructor(context) {
|
|
210
|
+
this.commandId = "ungroup" /* Ungroup */;
|
|
211
|
+
this.commandDetail = {
|
|
212
|
+
label: "Ungroup"
|
|
213
|
+
};
|
|
214
|
+
this.shortcuts = ["meta shift g", "ctrl shift g"];
|
|
215
|
+
this.selectService = context.get(import_free_layout_core3.WorkflowSelectService);
|
|
216
|
+
this.groupService = context.get(WorkflowGroupService);
|
|
217
|
+
this.execute = this.execute.bind(this);
|
|
218
|
+
}
|
|
219
|
+
async execute(_groupNode) {
|
|
220
|
+
const groupNode = _groupNode || this.selectService.activatedNode;
|
|
221
|
+
if (!groupNode || groupNode.flowNodeType !== import_document3.FlowNodeBaseType.GROUP) {
|
|
222
|
+
return;
|
|
223
|
+
}
|
|
224
|
+
this.groupService.ungroup(groupNode);
|
|
225
|
+
this.selectService.clear();
|
|
226
|
+
}
|
|
227
|
+
};
|
|
228
|
+
|
|
229
|
+
// src/group-node.tsx
|
|
230
|
+
var import_document4 = require("@flowgram.ai/document");
|
|
231
|
+
var GroupNodeRegistry = {
|
|
232
|
+
type: import_document4.FlowNodeBaseType.GROUP,
|
|
233
|
+
meta: {
|
|
234
|
+
renderKey: import_document4.FlowNodeBaseType.GROUP,
|
|
235
|
+
defaultPorts: [],
|
|
236
|
+
isContainer: true,
|
|
237
|
+
disableSideBar: true,
|
|
238
|
+
size: {
|
|
239
|
+
width: 560,
|
|
240
|
+
height: 400
|
|
241
|
+
},
|
|
242
|
+
padding: () => ({
|
|
243
|
+
top: 80,
|
|
244
|
+
bottom: 40,
|
|
245
|
+
left: 65,
|
|
246
|
+
right: 65
|
|
247
|
+
}),
|
|
248
|
+
selectable(node, mousePos) {
|
|
249
|
+
if (!mousePos) {
|
|
250
|
+
return true;
|
|
251
|
+
}
|
|
252
|
+
const transform = node.getData(import_document4.FlowNodeTransformData);
|
|
253
|
+
return !transform.bounds.contains(mousePos.x, mousePos.y);
|
|
254
|
+
},
|
|
255
|
+
expandable: false
|
|
256
|
+
},
|
|
257
|
+
formMeta: {
|
|
258
|
+
render: () => /* @__PURE__ */ React.createElement(React.Fragment, null)
|
|
259
|
+
},
|
|
260
|
+
onCreate() {
|
|
261
|
+
}
|
|
262
|
+
};
|
|
263
|
+
|
|
264
|
+
// src/create-free-group-plugin.tsx
|
|
265
|
+
var createFreeGroupPlugin = (0, import_core2.definePluginCreator)(
|
|
266
|
+
{
|
|
267
|
+
onBind({ bind, rebind }) {
|
|
268
|
+
bind(WorkflowGroupService).toSelf().inSingletonScope();
|
|
269
|
+
rebind(import_document5.FlowGroupService).toService(WorkflowGroupService);
|
|
270
|
+
},
|
|
271
|
+
onInit(ctx, { groupNodeRender, disableGroupShortcuts = false, disableGroupNodeRegister = false }) {
|
|
272
|
+
if (groupNodeRender) {
|
|
273
|
+
const renderRegistry = ctx.get(import_renderer.FlowRendererRegistry);
|
|
274
|
+
renderRegistry.registerReactComponent(import_document5.FlowNodeBaseType.GROUP, groupNodeRender);
|
|
275
|
+
}
|
|
276
|
+
if (!disableGroupShortcuts) {
|
|
277
|
+
const shortcutsRegistry = ctx.get(import_shortcuts_plugin.ShortcutsRegistry);
|
|
278
|
+
shortcutsRegistry.addHandlers(new GroupShortcut(ctx), new UngroupShortcut(ctx));
|
|
279
|
+
}
|
|
280
|
+
if (!disableGroupNodeRegister) {
|
|
281
|
+
const document = ctx.get(import_free_layout_core4.WorkflowDocument);
|
|
282
|
+
document.registerFlowNodes(GroupNodeRegistry);
|
|
283
|
+
}
|
|
284
|
+
},
|
|
285
|
+
onReady(ctx) {
|
|
286
|
+
const groupService = ctx.get(WorkflowGroupService);
|
|
287
|
+
groupService.ready();
|
|
288
|
+
},
|
|
289
|
+
onDispose(ctx) {
|
|
290
|
+
const groupService = ctx.get(WorkflowGroupService);
|
|
291
|
+
groupService.dispose();
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
);
|
|
295
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
296
|
+
0 && (module.exports = {
|
|
297
|
+
WorkflowGroupCommand,
|
|
298
|
+
WorkflowGroupService,
|
|
299
|
+
createFreeGroupPlugin
|
|
300
|
+
});
|
|
301
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/create-free-group-plugin.tsx","../src/workflow-group-service.ts","../src/utils.ts","../src/shortcuts/group.ts","../src/constant.ts","../src/shortcuts/ungroup.ts","../src/group-node.tsx"],"sourcesContent":["export { createFreeGroupPlugin } from './create-free-group-plugin';\nexport { WorkflowGroupService } from './workflow-group-service';\nexport { WorkflowGroupCommand } from './constant';\n","import { ShortcutsRegistry } from '@flowgram.ai/shortcuts-plugin';\nimport { FlowRendererRegistry } from '@flowgram.ai/renderer';\nimport { WorkflowDocument } from '@flowgram.ai/free-layout-core';\nimport { FlowGroupService, FlowNodeBaseType } from '@flowgram.ai/document';\nimport { definePluginCreator, PluginContext } from '@flowgram.ai/core';\n\nimport { WorkflowGroupService } from './workflow-group-service';\nimport { WorkflowGroupPluginOptions } from './type';\nimport { GroupShortcut, UngroupShortcut } from './shortcuts';\nimport { GroupNodeRegistry } from './group-node';\n\nexport const createFreeGroupPlugin = definePluginCreator<WorkflowGroupPluginOptions, PluginContext>(\n {\n onBind({ bind, rebind }) {\n bind(WorkflowGroupService).toSelf().inSingletonScope();\n rebind(FlowGroupService).toService(WorkflowGroupService);\n },\n onInit(\n ctx,\n { groupNodeRender, disableGroupShortcuts = false, disableGroupNodeRegister = false }\n ) {\n // register node render\n if (groupNodeRender) {\n const renderRegistry = ctx.get<FlowRendererRegistry>(FlowRendererRegistry);\n renderRegistry.registerReactComponent(FlowNodeBaseType.GROUP, groupNodeRender);\n }\n // register shortcuts\n if (!disableGroupShortcuts) {\n const shortcutsRegistry = ctx.get(ShortcutsRegistry);\n shortcutsRegistry.addHandlers(new GroupShortcut(ctx), new UngroupShortcut(ctx));\n }\n if (!disableGroupNodeRegister) {\n const document = ctx.get(WorkflowDocument);\n document.registerFlowNodes(GroupNodeRegistry);\n }\n },\n onReady(ctx) {\n const groupService = ctx.get(WorkflowGroupService);\n groupService.ready();\n },\n onDispose(ctx) {\n const groupService = ctx.get(WorkflowGroupService);\n groupService.dispose();\n },\n }\n);\n","import { injectable, inject } from 'inversify';\nimport { DisposableCollection, Disposable } from '@flowgram.ai/utils';\nimport {\n WorkflowDocument,\n WorkflowOperationBaseService,\n WorkflowNodeEntity,\n nanoid,\n WorkflowNodeJSON,\n} from '@flowgram.ai/free-layout-core';\nimport { HistoryService } from '@flowgram.ai/free-history-plugin';\nimport {\n NodeIntoContainerService,\n NodeIntoContainerType,\n} from '@flowgram.ai/free-container-plugin';\nimport { FlowGroupService, FlowNodeBaseType } from '@flowgram.ai/document';\nimport { TransformData } from '@flowgram.ai/core';\n\nimport { WorkflowGroupUtils } from './utils';\n\n@injectable()\n/** 分组服务 */\nexport class WorkflowGroupService extends FlowGroupService {\n @inject(WorkflowDocument) private document: WorkflowDocument;\n\n @inject(WorkflowOperationBaseService) freeOperationService: WorkflowOperationBaseService;\n\n @inject(HistoryService) private historyService: HistoryService;\n\n @inject(NodeIntoContainerService) private nodeIntoContainerService: NodeIntoContainerService;\n\n private toDispose = new DisposableCollection();\n\n public ready(): void {\n this.toDispose.push(this.listenContainer());\n }\n\n public dispose(): void {\n this.toDispose.dispose();\n }\n\n /** 创建分组节点 */\n public createGroup(nodes: WorkflowNodeEntity[]): WorkflowNodeEntity | undefined {\n if (!WorkflowGroupUtils.validate(nodes)) {\n return;\n }\n const parent = nodes[0].parent ?? this.document.root;\n const groupId = `group_${nanoid(5)}`;\n const groupJSON: WorkflowNodeJSON = {\n type: FlowNodeBaseType.GROUP,\n id: groupId,\n meta: {\n position: {\n x: 0,\n y: 0,\n },\n },\n data: {},\n };\n this.historyService.startTransaction();\n this.document.createWorkflowNodeByType(\n FlowNodeBaseType.GROUP,\n {\n x: 0,\n y: 0,\n },\n groupJSON,\n parent.id\n );\n nodes.forEach((node) => {\n this.freeOperationService.moveNode(node, {\n parent: groupId,\n });\n });\n this.historyService.endTransaction();\n }\n\n /** 取消分组 */\n public ungroup(groupNode: WorkflowNodeEntity): void {\n const groupBlocks = groupNode.blocks.slice();\n if (!groupNode.parent) {\n return;\n }\n const groupPosition = groupNode.transform.position;\n\n this.historyService.startTransaction();\n groupBlocks.forEach((node) => {\n this.freeOperationService.moveNode(node, {\n parent: groupNode.parent?.id,\n });\n });\n groupNode.dispose();\n groupBlocks.forEach((node) => {\n const transform = node.getData(TransformData);\n const position = {\n x: transform.position.x + groupPosition.x,\n y: transform.position.y + groupPosition.y,\n };\n this.freeOperationService.updateNodePosition(node, position);\n });\n this.historyService.endTransaction();\n }\n\n private listenContainer(): Disposable {\n return this.nodeIntoContainerService.on((e) => {\n if (\n e.type !== NodeIntoContainerType.Out ||\n e.sourceContainer?.flowNodeType !== FlowNodeBaseType.GROUP\n ) {\n return;\n }\n if (e.sourceContainer?.blocks.length === 0) {\n e.sourceContainer.dispose();\n }\n });\n }\n}\n","import { WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';\nimport { FlowNodeBaseType } from '@flowgram.ai/document';\n\nexport namespace WorkflowGroupUtils {\n /** 找到节点所有上级 */\n // const findNodeParents = (node: WorkflowNodeEntity): WorkflowNodeEntity[] => {\n // const parents = [];\n // let parent = node.parent;\n // while (parent) {\n // parents.push(parent);\n // parent = parent.parent;\n // }\n // return parents;\n // };\n\n /** 节点是否处于分组中 */\n const isNodeInGroup = (node: WorkflowNodeEntity): boolean => {\n // 处于分组中\n if (node?.parent?.flowNodeType === FlowNodeBaseType.GROUP) {\n return true;\n }\n return false;\n };\n\n /** 是否分组节点 */\n const isGroupNode = (group: WorkflowNodeEntity): boolean =>\n group.flowNodeType === FlowNodeBaseType.GROUP;\n\n /** 判断节点能否组成分组 */\n export const validate = (nodes: WorkflowNodeEntity[]): boolean => {\n if (!nodes || !Array.isArray(nodes) || nodes.length === 0) {\n // 参数不合法\n return false;\n }\n\n // 判断是否有分组节点\n const isGroupRelatedNode = nodes.some((node) => isGroupNode(node));\n if (isGroupRelatedNode) return false;\n\n // 判断是否有节点已经处于分组中\n const hasGroup = nodes.some((node) => node && isNodeInGroup(node));\n if (hasGroup) return false;\n\n // 判断是否来自同一个父亲\n const parent = nodes[0].parent;\n const isSameParent = nodes.every((node) => node.parent === parent);\n if (!isSameParent) return false;\n\n // 判断节点父亲是否已经在分组中\n // const parents = findNodeParents(nodes[0]);\n // const parentsInGroup = parents.some((parent) => isNodeInGroup(parent));\n // if (parentsInGroup) return false;\n\n // 参数正确\n return true;\n };\n}\n","import { ShortcutsHandler } from '@flowgram.ai/shortcuts-plugin';\nimport { WorkflowSelectService } from '@flowgram.ai/free-layout-core';\nimport { PluginContext } from '@flowgram.ai/core';\n\nimport { WorkflowGroupService } from '../workflow-group-service';\nimport { WorkflowGroupCommand } from '../constant';\n\nexport class GroupShortcut implements ShortcutsHandler {\n public commandId = WorkflowGroupCommand.Group;\n\n public commandDetail: ShortcutsHandler['commandDetail'] = {\n label: 'Group',\n };\n\n public shortcuts = ['meta g', 'ctrl g'];\n\n private selectService: WorkflowSelectService;\n\n private groupService: WorkflowGroupService;\n\n constructor(context: PluginContext) {\n this.selectService = context.get(WorkflowSelectService);\n this.groupService = context.get(WorkflowGroupService);\n this.execute = this.execute.bind(this);\n }\n\n public async execute(): Promise<void> {\n this.groupService.createGroup(this.selectService.selectedNodes);\n this.selectService.clear();\n }\n}\n","export enum WorkflowGroupCommand {\n Group = 'group',\n Ungroup = 'ungroup',\n}\n","import { ShortcutsHandler } from '@flowgram.ai/shortcuts-plugin';\nimport { WorkflowSelectService, WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';\nimport { FlowNodeBaseType } from '@flowgram.ai/document';\nimport { PluginContext } from '@flowgram.ai/core';\n\nimport { WorkflowGroupService } from '../workflow-group-service';\nimport { WorkflowGroupCommand } from '../constant';\n\nexport class UngroupShortcut implements ShortcutsHandler {\n public commandId = WorkflowGroupCommand.Ungroup;\n\n public commandDetail: ShortcutsHandler['commandDetail'] = {\n label: 'Ungroup',\n };\n\n public shortcuts = ['meta shift g', 'ctrl shift g'];\n\n private selectService: WorkflowSelectService;\n\n private groupService: WorkflowGroupService;\n\n constructor(context: PluginContext) {\n this.selectService = context.get(WorkflowSelectService);\n this.groupService = context.get(WorkflowGroupService);\n this.execute = this.execute.bind(this);\n }\n\n public async execute(_groupNode?: WorkflowNodeEntity): Promise<void> {\n const groupNode = _groupNode || this.selectService.activatedNode;\n if (!groupNode || groupNode.flowNodeType !== FlowNodeBaseType.GROUP) {\n return;\n }\n this.groupService.ungroup(groupNode);\n this.selectService.clear();\n }\n}\n","import { PositionSchema } from '@flowgram.ai/utils';\nimport { WorkflowNodeEntity } from '@flowgram.ai/free-layout-core';\nimport { FlowNodeRegistry, FlowNodeBaseType, FlowNodeTransformData } from '@flowgram.ai/document';\n\nexport const GroupNodeRegistry: FlowNodeRegistry = {\n type: FlowNodeBaseType.GROUP,\n meta: {\n renderKey: FlowNodeBaseType.GROUP,\n defaultPorts: [],\n isContainer: true,\n disableSideBar: true,\n size: {\n width: 560,\n height: 400,\n },\n padding: () => ({\n top: 80,\n bottom: 40,\n left: 65,\n right: 65,\n }),\n selectable(node: WorkflowNodeEntity, mousePos?: PositionSchema): boolean {\n if (!mousePos) {\n return true;\n }\n const transform = node.getData<FlowNodeTransformData>(FlowNodeTransformData);\n return !transform.bounds.contains(mousePos.x, mousePos.y);\n },\n expandable: false,\n },\n formMeta: {\n render: () => <></>,\n },\n onCreate() {\n // NOTICE: 这个函数是为了避免触发固定布局 flowDocument.addBlocksAsChildren\n },\n};\n"],"mappings":"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","names":["import_free_layout_core","import_document","import_core","import_document","WorkflowGroupUtils","import_free_layout_core","WorkflowGroupCommand","import_free_layout_core","import_document","import_document"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@flowgram.ai/free-group-plugin",
|
|
3
|
+
"version": "0.1.8",
|
|
4
|
+
"homepage": "https://flowgram.ai/",
|
|
5
|
+
"repository": "https://github.com/bytedance/flowgram.ai",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"exports": {
|
|
8
|
+
"types": "./dist/index.d.ts",
|
|
9
|
+
"import": "./dist/esm/index.js",
|
|
10
|
+
"require": "./dist/index.js"
|
|
11
|
+
},
|
|
12
|
+
"main": "./dist/index.js",
|
|
13
|
+
"module": "./dist/esm/index.js",
|
|
14
|
+
"types": "./dist/index.d.ts",
|
|
15
|
+
"files": [
|
|
16
|
+
"dist"
|
|
17
|
+
],
|
|
18
|
+
"dependencies": {
|
|
19
|
+
"inversify": "^6.0.1",
|
|
20
|
+
"reflect-metadata": "~0.2.2",
|
|
21
|
+
"lodash": "^4.17.21",
|
|
22
|
+
"@flowgram.ai/free-history-plugin": "0.1.8",
|
|
23
|
+
"@flowgram.ai/free-container-plugin": "0.1.8",
|
|
24
|
+
"@flowgram.ai/free-lines-plugin": "0.1.8",
|
|
25
|
+
"@flowgram.ai/document": "0.1.8",
|
|
26
|
+
"@flowgram.ai/core": "0.1.8",
|
|
27
|
+
"@flowgram.ai/shortcuts-plugin": "0.1.8",
|
|
28
|
+
"@flowgram.ai/renderer": "0.1.8",
|
|
29
|
+
"@flowgram.ai/utils": "0.1.8",
|
|
30
|
+
"@flowgram.ai/free-layout-core": "0.1.8"
|
|
31
|
+
},
|
|
32
|
+
"devDependencies": {
|
|
33
|
+
"@types/bezier-js": "4.1.3",
|
|
34
|
+
"@types/lodash": "^4.14.137",
|
|
35
|
+
"@types/react": "^18",
|
|
36
|
+
"@types/react-dom": "^18",
|
|
37
|
+
"@types/styled-components": "^5",
|
|
38
|
+
"@vitest/coverage-v8": "^0.32.0",
|
|
39
|
+
"eslint": "^8.54.0",
|
|
40
|
+
"react": "^18",
|
|
41
|
+
"react-dom": "^18",
|
|
42
|
+
"styled-components": "^5",
|
|
43
|
+
"tsup": "^8.0.1",
|
|
44
|
+
"typescript": "^5.0.4",
|
|
45
|
+
"vitest": "^0.34.6",
|
|
46
|
+
"@flowgram.ai/ts-config": "0.1.8",
|
|
47
|
+
"@flowgram.ai/eslint-config": "0.1.8"
|
|
48
|
+
},
|
|
49
|
+
"peerDependencies": {
|
|
50
|
+
"react": ">=17",
|
|
51
|
+
"react-dom": ">=17",
|
|
52
|
+
"styled-components": ">=4"
|
|
53
|
+
},
|
|
54
|
+
"publishConfig": {
|
|
55
|
+
"access": "public",
|
|
56
|
+
"registry": "https://registry.npmjs.org/"
|
|
57
|
+
},
|
|
58
|
+
"scripts": {
|
|
59
|
+
"build": "npm run build:fast -- --dts-resolve",
|
|
60
|
+
"build:fast": "tsup src/index.ts --format cjs,esm --sourcemap --legacy-output",
|
|
61
|
+
"build:watch": "npm run build:fast -- --dts-resolve",
|
|
62
|
+
"clean": "rimraf dist",
|
|
63
|
+
"test": "exit 0",
|
|
64
|
+
"test:cov": "exit 0",
|
|
65
|
+
"ts-check": "tsc --noEmit",
|
|
66
|
+
"watch": "npm run build:fast -- --dts-resolve --watch --ignore-watch dist"
|
|
67
|
+
}
|
|
68
|
+
}
|