LogicFlow 是一款流程图编辑框架,提供了一系列流程图交互、编辑所必需的功能和灵活的节点自定义、插件等拓展机制。LogicFlow支持前端研发自定义开发各种逻辑编排场景,如流程图、ER图、BPMN流程等。在工作审批配置、机器人逻辑编排、无代码平台流程配置都有较好的应用。
这一节将讲解快速上手 LogicFlow 流程图编辑框架的内置插件使用,项目整体基于Vue3+Vite3+Ts4开发,为帮助还为熟练使用 Vue3 和 Typescript 语法的小伙伴提供便利,如果你已经很熟练在Vue3中的开发习惯,建议直接访问 LogicFlow 将获取完整的入门指南。
1. 内置插件介绍:
这里介绍三个比较常见的功能,这样的功能也被 LF 做了内置的插件来进行简单的实现,在你的实际业务中还是需要通过插件的扩展来实现更加丰富的功能。那么这三个功能和每个功能对应的插件分别是:
- 第一个功能是通常在页面左侧的拖拽面板,对应的插件是
DndPanel
,用来将代表不同业务的节点拖至流程画布中; - 第二个功能就是框选功能,对应的插件是
SelectionSelect
,用来框选一个或多个业务节点,以便下一步的操作; - 第三个功能就是分组,对应的插件是
Group
,用来将一组具有关联性的节点放到一个分组。
这三个插件的配置已经在上一节中完成,你只需要fork上一节的代码就可以开始本节的学习了,准备好就要开始了~
2. 拖拽面板插件的配置&使用:
拖拽面板的插件配置相对简单,只需要掌握下面这几个配置就可以搞定了:
名称 | 类型 | 描述 |
---|---|---|
type | string | 指定用户鼠标可以拖入的节点类型,包括自定义节点类型, 不传则不会创建节点,只会触发callback |
text | string | 创建节点的文本 |
properties | object | 创建节点的properties |
label | string | 拖拽面板节点文本描述 |
icon | string | 拖拽面板上显示的图标,可以传入图标url地址或base64编码 |
className | string | 额外传入可以拖拽项的class, 用于自定义拖拽项的样式 |
callback | fn | 用户鼠标按下拖拽项后触发的回调 |
2.1 配置拖拽面板数据:
案例配置中准备了三中业务节点类型,分别是开始节点、用户任务节点和结束节点,它们的配置如下:
const patternItems = [
{
type: 'circle',
text: '开始',
label: '开始节点',
icon: '',
},
{
type: 'rect',
label: '用户任务',
icon: '',
},
{
type: 'circle',
text: '结束',
label: '结束节点',
icon: '',
}
]
2.2 将配置完成的数据装载到LF:
插件正确安装后就可以在LF实例的extension属性中读取对应的插件对象了,这里要通过 dndPanel.setPatternItems(data)
函数来为LF实例装载数据:
// 在执行render前配置
lf.value.extension.dndPanel.setPatternItems(patternItems);
lf.value.render();
数据配置成功后就可以看到页面左侧的拖拽面板了,在你的项目中试一下吧~
3. 框选插件的配置&使用:
框选插件在使用时必须要提到的是,开启框选功能的方式有两种,其中一种是通过LF实例化时的选项进行开启和关闭、第二种就是通过插件提供的开启和关闭的函数动态实现。
3.1 开启&关闭框选:
通过选项开闭:因为框选功能和画布拖拽功能属于互斥功能,所以是通过
stopMoveGraph
一个选项控制的,如果选项开启则表示禁止移动画布(开启框选),反之则是开启移动画布(禁止框选),我在源码处预留了这个选项,你可以打开注释尝试一下;通过插件提供的函数开闭:需要结合前面的拖拽面板,这也是符合使用习惯的一种方式,当需要框选节点时点击拖拽面板的框选图标开启框选功能,在框选结束后关闭框选功能,后面的案例会展示这一块;
开启函数:
lf.extension.selectionSelect.openSelectionSelect();
关闭函数:
lf.extension.selectionSelect.closeSelectionSelect();
3.2 框选的灵敏区域:
- 默认需要框选整个节点才选中节点
- 默认需要框选边的起点、终点才选中边
可以使用 setSelectionSense
函数调整:
lf.extension.selectionSelect.setSelectionSense(false, true);
参数 | 默认值 | 描述 |
---|---|---|
isWholeEdge | true | 是否要边的起点终点都在选区范围才算选中 |
isWholeNode | true | 是否要节点的全部点都在选区范围才算选中 |
3.3 结合 DndPanel 控制框选功能:
在 Dndpanel
示例的 patternItems
数据中新增下面的配置,通过点击元素后触发的 callback
事件启用框选,并监听选中事件后关闭框选来完成功能的切换;
const patternItems = [{
label: '选区',
icon: '',
callback: () => {
lf.value!.extension.selectionSelect.openSelectionSelect();
lf.value!.once('selection:selected', () => {
lf.value!.extension.selectionSelect.closeSelectionSelect();
});
}
}]
成功配置后就可以点击选区后去选中几个拖拽好的节点了~
4. 分组插件的配置&使用:
分组插件的使用还是很简单的,这里需要重点关注一下自定义分组,因为这里跟前面小节的自定义业务节点和自定义Edge一样,需要继承内置类去进行各种函数的重写。
4.1 默认分组&数据格式:
默认的分组和分组的数据格式如下,通过 type
为 group
的节点提供的 children
属性填充进去需要放到一组的节点ID,就完成了分组;
const graphData = {
nodes: [
{
type: 'group',
x: 200,
y: 200,
children: ["node_2"],
},
{
id: 'node_2',
type: 'circle',
x: 200,
y: 200,
}
]
}
4.2 自定义分组:
准备自定义分组的模板:
import { GroupNode } from "@logicflow/extension";
class MyGroup extends GroupNode.view { }
class MyGroupModel extends GroupNode.model { }
export default {
type: "my-group",
model: MyGroupModel,
view: MyGroup
};
优先注册&使用:
// 导入模块
import MyGroup from "./MyGroup";
lf.value.register(MyGroup);
const graphData = {
nodes: [
{
type: 'my-group', // 换为自定义分组的type名称
x: 200,
y: 200,
children: ["node_2"]
},
// ... 省略部分代码
]
}
自定义样式:
重写
getNodeStyle
函数
getNodeStyle() {
const style = super.getNodeStyle();
style.stroke = "#AEAFAE";
style.strokeWidth = 1;
return style;
}
自定义形状:
重写
initNodeData
函数
initNodeData(data: any) {
super.initNodeData(data);
this.isRestrict = true;
this.resizable = true;
this.width = 200;
this.height = 180;
}
更多的状态:
groupModel除节点通用的属性外,还有下面这些状态属性的支持,建议在setAttributes函数配置;
setAttributes(): void {
this.isRestrict = true;
this.resizable = true;
this.foldable = true;
}
名称 | 类型 | 描述 |
---|---|---|
isRestrict | boolean | 是否限制分组子节点拖出分组,默认false |
resizable | boolean | 分组是否支持手动调整大小,默认false |
foldable | boolean | 分组是否显示展开收起按钮,默认false |
width | number | 分组宽度 |
height | number | 分组高度 |
foldedWidth | number | 分组折叠后的宽度 |
foldedHeight | number | 分组折叠后的高度 |
isFolded | boolean | 只读,表示分组是否被折叠。 |
isGroup | boolean | 只读,永远为true, 用于识别model为group。 |
总结
这一节的内容就到此结束了,本节中的三个插件都是非常实用的功能,在实际业务中也需要做更多的功能扩展,所有内置的插件使用和自定义是很有必要掌握的,下一节准备了内置插件中一个比较重要的的插件菜单,没有成功运行的小伙伴要赶紧调试代码了~