当前位置: 首页 > 工具软件 > LogicFlow > 使用案例 >

LogicFlow插件-常用&内置

阳光辉
2023-12-01

Hi~ 大家好,我是小鑫同学,一位长期从事前端开发的编程爱好者,我将使用更为实用的案例输出更多的编程知识,同时我信奉分享是成长的唯一捷径,在这里也希望我的每一篇文章都能成为你技术落地的参考~

1. 准备工作:

1. 初始化项目:

1.1 初始化环境:

使用pnpm create vite创建项目,选择Vue框架及TypeScript变体;

1.2 安装核心模块:

在完成了前面的准备工作后,需要安装非核心的插件依赖模块:

pnpm add @logicflow/core
pnpm add @logicflow/extension

2. 插件注册:

2.1 注册插件到全局:

import { BpmnElement } from '@logicflow/extension';
LogicFlow.use(BpmnElement);

2.2 注册插件到实例:

import LogicFlow from "@logicflow/core";
import { DndPanel, SelectionSelect } from "@logicflow/extension";
import "@logicflow/core/dist/style/index.css";
import "@logicflow/extension/lib/style/index.css";

const lf = new LogicFlow({
  container: document.querySelector("#app"),
  grid: true,
  plugins: [DndPanel, SelectionSelect]
});

2. 配置拖拽面板 DndPanel:

拖拽面板的插件安装完成后就可以为拖拽面板添加元素了,也就是被拖拽的内容,每个元素都具备以下7个可选选项进行控制:

名称类型描述
typestring指定用户鼠标可以拖入的节点类型,包括自定义节点类型, 不传则不会创建节点,只会触发callback
textstring创建节点的文本
propertiesobject创建节点的properties
labelstring拖拽面板节点文本描述
iconstring拖拽面试上显示的图标,可以传入图标url地址或base64编码
classNamestring额外传入可以拖拽项的class, 用于自定义拖拽项的样式
callbackfn用户鼠标按下拖拽项后触发的回调
<script setup lang="ts">
import LogicFlow from "@logicflow/core";
import { DndPanel } from "@logicflow/extension";
import "@logicflow/core/dist/style/index.css";
import "@logicflow/extension/lib/style/index.css";

import { onMounted, ref } from "vue";

const container = ref();
const lf = ref<LogicFlow>();

const patternItems = [
    {
      type: 'circle',
      text: '开始',
      label: '开始节点',
      icon: '',
    },
    {
      type: 'rect',
      label: '用户任务',
      icon: '',
    },
    {
      type: 'circle',
      text: '结束',
      label: '结束节点',
      icon: '',
    }
  ]
onMounted(() => {
  lf.value = new LogicFlow({
    container: container.value,
    grid: true,
    plugins: [DndPanel]
  })
  lf.value.extension.dndPanel.setPatternItems(patternItems);
  lf.value.render();
})
</script>

3. 配置框选 SelectionSelect:

框选和拖动画布两个功能不能同时支持,stopMoveGraph开启时(禁止拖动画布)则支持框选,反之失效;

3.1 启用、禁用、默认:

默认配置:

new LogicFlow({stopMoveGraph: true});

开启方式:

lf.extension.selectionSelect.openSelectionSelect();

关闭方式:

lf.extension.selectionSelect.closeSelectionSelect();

3.2 配置灵敏区域:

  • 默认需要框选整个节点才选中节点
  • 默认需要框选边的起点、终点才选中边

使用setSelectionSense函数调整:

lf.extension.selectionSelect.setSelectionSense(false, true);
参数默认值描述
isWholeEdgetrue是否要边的起点终点都在选区范围才算选中
isWholeNodetrue是否要节点的全部点都在选区范围才算选中

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. 配置分组 Group:

4.1 默认分组&数据格式:

LF渲染下面的graphData数据将得到一个默认的分组区域,它很像一个rect节点;

const graphData = {
  nodes: [
    {
      type: 'group',
      x: 300,
      y: 300
    }
  ]
}

group节点通过特有的children属性可以管理其该包含的子节点;

const graphData = {
  nodes: [
    {
      type: 'group',
      x: 300,
      y: 300,
      children: ["node_2"]
    },
    {
      id: 'node_2',
      type: 'circle',
      x: 300,
      y: 300
    }
  ]
}

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
};

优先注册&使用:

<script setup lang="ts">
import LogicFlow from "@logicflow/core";
import { Group } from "@logicflow/extension";
import "@logicflow/core/dist/style/index.css";
import "@logicflow/extension/lib/style/index.css";
// 导入模块
import MyGroup from "./MyGroup";

import { onMounted, ref } from "vue";

const container = ref();
const lf = ref<LogicFlow>();
const graphData = {
  nodes: [
    {
      type: 'my-group',
      x: 300,
      y: 300,
      children: ["node_2"]
    },
    {
      id: 'node_2',
      type: 'circle',
      x: 300,
      y: 300
    }
  ]
}
onMounted(() => {
  lf.value = new LogicFlow({
    container: container.value,
    grid: true,
    plugins: [Group],
  })
  // 注册自定义分组
  lf.value.register(MyGroup);
  lf.value.render(graphData);
})
</script>

自定义样式,重写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 = 480;
    this.height = 280;
}

4.3 状态属性设置:

groupModel除节点通用的属性外,还有下面这些状态属性的支持,建议在setAttributes函数配置;

setAttributes(): void {
    this.isRestrict = true;
    this.resizable = true;
    this.foldable = true;
}
名称类型描述
isRestrictboolean是否限制分组子节点拖出分组,默认false
resizableboolean分组是否支持手动调整大小,默认false
foldableboolean分组是否显示展开收起按钮,默认false
widthnumber分组宽度
heightnumber分组高度
foldedWidthnumber分组折叠后的宽度
foldedHeightnumber分组折叠后的高度
isFoldedboolean只读,表示分组是否被折叠。
isGroupboolean只读,永远为true, 用于识别model为group。

4.4 提供的方法:

addChild:

将某个节点设置为分组的子节点。注意,此方法只会添加关系,不会自动将节点移动到分组里面。

const groupModel = lf.getNodeModelById('group_id');
const node = lf.addNode({
  type: 'rect',
  x: groupModel.x,
  y: groupModel.y
});
groupModel.addChild(node.id);

removeChild:

从分组中移除某个子节点。

const groupModel = lf.getNodeModelById('group_id');
groupModel.removeChild('node_id_1');

foldGroup:

收起分组, 参数为true表示收起分组、false表示展开分组

const groupModel = lf.getNodeModelById('group_id');
groupModel.foldGroup(true);

isAllowAppendIn(nodeData):

校验是否允许传入节点添加到此分组中,默认所有的节点都可以。

class MyGroupModel extends GroupNode.model {

    isAllowAppendIn(nodeData: any): boolean {
        // 设置只允许circle节点被添加到此分组中
        return nodeData.type === 'circle'
    }
}

getAddableOutlineStyle:

设置拖动节点到分组上时,分组高亮的提示效果样式。

class MyGroupModel extends GroupNode.model {

    getAddableOutlineStyle() {
        const style = super.getAddableOutlineStyle();
        style.stroke = '#AEAFAE';
        style.strokeDasharray = '3 3';
        return style;
    }
}

如果看完觉得有收获,欢迎点赞、评论、分享支持一下。你的支持和肯定,是我坚持写作的动力~

 类似资料: