项目作者: evanyangg

项目描述 :
Design BPMN 2.0 modeler in a Vue.js application based on bpmn-js.
高级语言: Vue
项目地址: git://github.com/evanyangg/vue-bpmn-modeler.git
创建时间: 2019-10-18T16:16:54Z
项目社区:https://github.com/evanyangg/vue-bpmn-modeler

开源协议:MIT License

下载


vue-bpmn-modeler

Design BPMN 2.0 modeler in a Vue.js application based on bpmn-js.

Usage

  1. yarn add vue-bpmn-modeler
  1. # main.js
  2. import VueBpmnModeler from "vue-bpmn-modeler";
  3. Vue.use(VueBpmnModeler);
  1. # yourPage.vue
  2. <style lang="less">
  3. @import "~vue-bpmn-modeler/lib/vue-bpmn-modeler.css";
  4. </style>

viewer

组件会显示设计器,参数 v-model=”modeler”,会通过画图操作实时返回对应的xml数据和svg数据,用于保存初始化的模板。

  1. <template>
  2. <BpmnModeler v-model="modeler"></BpmnModeler>
  3. </template>
  4. <script>
  5. export default {
  6. name: "BpmnModeler",
  7. props: {
  8. diagramXML: String
  9. },
  10. watch: {
  11. diagramXML(val) {
  12. this.openDiagram(val)
  13. }
  14. },
  15. data() {
  16. modeler: {
  17. // 模型xml数据
  18. // model xml data
  19. xmlData: "",
  20. // svg图片数据
  21. // svg data
  22. svgImage: ""
  23. }
  24. },
  25. // 详细代码请参考源码
  26. // see source code for detail
  27. mounted() {
  28. },
  29. methods: {
  30. openDiagram(xml) {
  31. if (xml) {
  32. this.modeler.importXML(xml, function(err) {
  33. if (err) {
  34. console.error(err);
  35. } else {
  36. }
  37. });
  38. this.xmlData = xml;
  39. } else {
  40. this.modeler.createDiagram();
  41. let _self = this;
  42. setTimeout(() => {
  43. /**
  44. * 修改xml属性值 isExecutable = false => true
  45. * isExecutable = false 后端部署流程时 不会创建流程定义数据
  46. */
  47. let modelerCanvas = _self.modeler.get("canvas");
  48. let rootElement = modelerCanvas.getRootElement();
  49. let modeling = _self.modeler.get("modeling");
  50. // modeling.updateProperties(rootElement, {
  51. // // isExecutable: true
  52. // });
  53. // 设定开始节点名称和结束节点名称
  54. // set StartEvent name 'start' and EndEvent name 'end'
  55. rootElement.children.forEach(n => {
  56. if (n.type === 'bpmn:StartEvent') {
  57. modeling.updateProperties(n, {
  58. name: '开始',
  59. });
  60. } else if (n.type === 'bpmn:EndEvent') {
  61. modeling.updateProperties(n, {
  62. name: '结束',
  63. });
  64. }
  65. })
  66. });
  67. }
  68. }
  69. }
  70. };
  71. </script>

当流程启动时,流程会默认走到第一个节点 提交申请,此时的待办任务会显示橙色。

When the process starts, the process will complete first task by default, and the TODO tasks will be orange.

viewer

当流程完成 提交申请 且满足 条件1 时,流程会走到 成本中心 节点,此时已经完成的待办任务会显示绿色。

when the first task completed and met condition 1, the process coming to ‘costcenter’ task, Completed tasks displayed in green.

viewer

参数介绍:
xmlData: 表示流程图的xml数据
taskList: 表示流程的历史记录 可以通过服务的接口 historyService 获得

  1. <template>
  2. <BpmnViewer :xmlData="xmlData" :taskData="taskList"></BpmnViewer>
  3. </template>
  4. <script>
  5. export default {
  6. data() {
  7. modeler: {
  8. // 模型xml数据
  9. xmlData: "",
  10. // 任务列表
  11. taskList: [{
  12. // 任务定义的key
  13. "key": "",
  14. // 任务是否完成
  15. "completed": true
  16. }]
  17. }
  18. }
  19. };
  20. </script>

动态添加/替换任务节点

dynamically add/replace task

viewer

  1. addTask () {
  2. let addOrReplace = {
  3. // task || sequenceFlow || gateway
  4. replaceActivity: 'UserTask_0hkfnx2',
  5. taskList: [
  6. {
  7. label: 'test task'
  8. }
  9. ]
  10. }
  11. this.$refs.modeler.replace(addOrReplace).then((taskList) => {
  12. // new task list, incluce taskId
  13. console.log(taskList);
  14. });
  15. }

开启 propertiesPanel

  1. <template>
  2. <BpmnModeler v-model="modeler" propertiesPanel></BpmnModeler>
  3. </template>

Examples

  1. # clone the project
  2. git clone https://github.com/evanyangg/vue-bpmn-modeler.git
  3. # enter the project directory
  4. cd vue-bpmn-modeler
  5. # install dependencies
  6. yarn
  7. # serve with hot reload at localhost:8080
  8. yarn serve

License

MIT