# workflow-bpmn-modeler-antdv **Repository Path**: gspandy78/workflow-bpmn-modeler-antdv ## Basic Information - **Project Name**: workflow-bpmn-modeler-antdv - **Description**: fork https://github.com/GoldSubmarine/workflow-bpmn-modeler.git 适配为antdv版本 - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 20 - **Created**: 2022-04-25 - **Last Updated**: 2022-04-25 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README [English](./README_EN.md) | 简体中文 | [GitHub](https://github.com/Vincent-Vic/workflow-bpmn-modeler-antdv) | [Gitee](https://gitee.com/Vincent-Vic/workflow-bpmn-modeler-antdv) # workflow-bpmn-modeler-antdv [![NPM Version](http://img.shields.io/npm/v/workflow-bpmn-modeler-antdv.svg?style=flat)](https://www.npmjs.org/package/workflow-bpmn-modeler-antdv) [![NPM Downloads](https://img.shields.io/npm/dm/workflow-bpmn-modeler-antdv.svg?style=flat)](https://www.npmjs.org/package/workflow-bpmn-modeler-antdv) ![](https://img.shields.io/badge/license-MIT-000000.svg) 🔥 本项目基于 `vue` 和 `bpmn.io@7.0` ,实现 flowable 的工作流设计器 🔥 本项目基于 [workflow-bpmn-modeler](https://github.com/GoldSubmarine/workflow-bpmn-modeler) 进行了Ant Design Vue的适配,初始版本基于0.2.8发展适配为antdv下的1.0.1版本 🔥 本项目基于 [workflow-bpmn-modeler](https://github.com/GoldSubmarine/workflow-bpmn-modeler) 如果需要Element UI版本可以直接访问原仓库 > 本项目代码去除原有表单XFORM组件,整体改的有点冗余,前端功底较差 ## 预览 📟 ![20200930030243](https://cdn.jsdelivr.net/gh/goldsubmarine/cdn@master/blog/20200930030243.png) ## 在线 demo 📢 👉 https://vincent-vic.github.io/workflow-bpmn-modeler-antdv/demo/ ## 安装 ⏳ ```bash # yarn yarn add workflow-bpmn-modeler-antdv # Or npm npm i workflow-bpmn-modeler-antdv ``` ## 使用说明 👣 ### 简单例子 👣 ```vue ``` ### 完整示例 👣 ```vue ``` > 内容参数均为选用,无需任何参数也可以使用,根据实际情况配置 ## 组件参数 👣 ### 主要参数 👣 | Attributes | describe | structure | type | default | | ----------------- | ------------------- | ------------------------------------------------------------ | ------- | ------- | | xml | 流程文件xml数据 | | String | '' | | users | 指定或候选用户列表 | [
{ name: 'name', id: 'id' },
] | Array | [] | | groups | 候选组 | [
{ name: 'name', id: 'id' },
] | Array | [] | | categories | 流程分类 | [
{ name: 'name', id: 'id' },
] | Array | [] | | isView | 视图模式 | | Boolean | false | | rightActionConfig | 头部右侧导航栏按钮配置 | {
".*":{
"show":true,
"icon":true,
"label":"XML"
}
} | Object | 见下文 | 头部右侧导航栏按钮配置默认配置 ```json { "showCode":{ "show":true, "icon":true, "label":"XML" }, "downloadXML":{ "show":true, "icon":true, "label":"XML" }, "downloadSVG":{ "show":true, "icon":true, "label":"SVG" }, "save":{ "show":true, "icon":true, "label":"保存" } } ``` ### 面板参数 👣 | Attributes | describe | type | default | | ----------------------------- | --------------------------------------------- | ------- | ------------------------------------------------------------ | | filters | 面板参数过滤 | Array | [] | | showInitiator | 【用户任务】指定人员中是否显示发起人(固定) | Boolean | true | | initiator | 【用户任务】指定人员中发起人显示数据格式 | Object | {
label: "流程发起人",
value: "${INITIATOR}"
} | | associateFormConfig | 关联表单配置 | Object | {
//此项为false,后设置两项均无效
enable:false,
isView: true,
isCreate: true,
} | | associateFormDataOptions | 关联表单动态数据 | Array | | | assigneeDataSource | 分配到任务的人动态数据 | Array | [
"#{approval}",
"${approverId}",
"${INITIATOR}"
] | | dueDateDataSource | 过期时间动态数据 | Array | ["${dueDate}"] | | followUpDateDataSource | 观察时间动态数据 | Array | ["${followUpDate}"] | | initiatorDataSource | 【开始节点】发起人动态数据 | Array | ["initiator"] | | skipExpressionDataSource | 跳过表达式动态数据 | Array | [] | | conditionExpressionDataSource | 跳转动态数据 | Array | [] | > 面板部分使用Ant Design Vue的AutoComplete 自动完成组件来提高使用便携性,为提高扩展性,可以自行配置自动完成的数据,默认数据如表 #### 过滤属性 👣 ```javascript filters: { type: Array, default: () => [] } ``` 参数列表 > 包含在参数列表的可以通过filters配置隐藏参数配置 | 选项 | 过滤字段 | | ----------------- | ------------------- | | 流程分类 | category | | 流程描述 | documentation | | 执行监听器 | executionListener | | 信号定义 | signal | | 消息定义 | message | | 节点描述 | nodeDocumentation | | 跳转条件 | conditionExpression | | 跳过条件 | skipExpression | | 发起人 | initiator | | 表单标识/表单挂载 | formKey | | 任务监听器 | taskListener | | 多实例 | multiInstance | | 异步 | async | | 优先级 | priority | | 是否为补偿 | isForCompensation | | 服务任务可触发 | triggerable | | 自动存储变量 | autoStoreVariables | | 排除 | exclude | | 输入变量 | ruleVariablesInput | | 规则 | rules | | 结果变量 | resultVariable | | 类 | class | | 过期时间 | dueDate | | 观察时间 | followUpDate | ### 组件栏 👣 #### 过滤属性 👣 paletteFilters 设置可以将操作栏组件隐藏 | 选项 | 过滤字段 | | -------- | --------------------------- | | 抓手 | hand-tool | | 套索 | lasso-tool | | 空间 | space-tool | | 连接 | global-connect-tool | | 开始 | create.start-event | | 中间 | create.intermediate-event | | 结束 | create.end-event | | 网关 | create.exclusive-gateway | | 任务 | create.task | | 子流程 | create.subprocess-expanded | | 数据对象 | create.data-object | | 数据存储 | create.data-store | | 扩展存储 | create.participant-expanded | | 分组 | create.group | ## 事件 👣 | 事件名称 | 参数 | 描述 | | :--------: | ------------------------------------------------------------ | :------------------- | | save | {
"process":{
"id":"",
"category":"",
"name":""
},
"svg":"",
"xml":""
} | 保存按钮触发事件 | | showForm | formKey | 显示挂载表单点击事件 | | createForm | | 创建表单点击事件 | ## iframe 部署 🎪 如果你的项目是 jquery 或 react 类项目,可以通过 iframe 的方式集成该流程设计器 本仓库通过 github pages 部署了静态页面,使用 jsdelivr 做 cdn ,国内访问也非常快速,所以你可以直接集成本仓库的页面,因为全部白嫖了 github 的资源,没有自己建服务器维护,所以不用担心资源失效问题。 当然你也可以在 `docs/lib` 文件夹下下载对应的版本,进行本地部署。 集成方式如下(ps:可直接拷贝以下代码到一个html文件中试一下): ```html ``` ## 关于定制 🛠 本组件对标的是 flowable 官方设计器,也就是实现 flowable 的 xml 规则标准,里面所用名词也都是官方文档中的专业术语。所以这个组件只是程序员在开发阶段,自己建模导出 xml 的工具,试图定制该建模器的行为都是不对的,不要把业务带到建模器中来!自己的业务应该另行开发增删改查来实现。 该组件未来也不会升级 UI 库和 vue。不管库是否兼容,通过 iframe 的方式集成建模器才是最简单正确的方式。 ## License 📄 [MIT](http://opensource.org/licenses/MIT) base Copyright (c) 2020-present, charles Copyright (c) 2022-present, Vincent-Vic