bpmn.js自定义各项,palette contextPad elementFactory modeling renderer rules

bpmn仓库给出的example
https://github.com/bpmn-io/bpmn-js-examples
我们要实现自定义可以有两种方式,

  1. 【继承】 bpmn-js,并修改原型上的方法,达到兼容自定义的相关
  2. 【重新实现】也就是把bpmn做的事情,在本地再做一遍,当然你可以各种“借鉴”里面的function,并达到你的要求

比如
customModeler/index.js 👈👈👈

import CustomContextPadProvider from './CustomContextPadProvider';
import CustomElementFactory from './CustomElementFactory';
import CustomOrderingProvider from './CustomOrderingProvider';
import CustomPalette from './CustomPalette';
import CustomRenderer from './CustomRenderer';
import CustomRules from './CustomRules';
import CustomUpdater from './CustomUpdater';
import CustomModeling from './CustomModeling';

export default {
  __init__: [
    'contextPadProvider',
    'customOrderingProvider',
    'customRenderer',
    'customRules',
    'customUpdater',
    'customUpdater',
    'paletteProvider',
    'modeling'
  ],
  contextPadProvider: ['type', CustomContextPadProvider],
  customOrderingProvider: ['type', CustomOrderingProvider],
  customRenderer: ['type', CustomRenderer],
  customRules: ['type', CustomRules],
  customUpdater: ['type', CustomUpdater],
  elementFactory: ['type', CustomElementFactory],
  paletteProvider: ['type', CustomPalette],
  modeling: ['type', CustomModeling]
};

里面elementFactory、paletteProvider、modeling都是对原有的进行覆盖,当你在使用$inject的时候,使用的其实是你自定义的部分;
其余则是新增(追加),不会改变原有,也可以在 $inject的时候引进你的名字进行使用

原有的

import BpmnModeler from 'bpmn-js/lib/Modeler';
import CustomModeler from '../customModeler';

this.bpmnModeler = new BpmnModeler({
// ...
})
改为上面的👆
this.bpmnModeler = new CustomModeler({
// ...
})

当你要新增一个并列与bpmn:Task,bpmn:StartEvent的类型,你可以建CustomElementFactory
继承bpmn

import BpmnElementFactory from 'bpmn-js/lib/features/modeling/ElementFactory';
import inherits from 'inherits';

export default function CustomElementFactory(bpmnFactory, moddle, translate) {
  BpmnElementFactory.call(this, bpmnFactory, moddle, translate);

  var self = this;
  this.create = function(elementType, attrs) {
    var type = attrs.type;
    // ...
    // 排除自定义类型,exaple中自定义的图标类型是custom:triangle / custom:circle
    if (/^custom:/.test(type)) {
      // ...
    }
    // 真实创建在这里✨✨✨
    return self.createBpmnElement(elementType, attrs);
  }
}
inherits(CustomElementFactory, BpmnElementFactory);

CustomElementFactory.$inject = [
  'bpmnFactory',
  'moddle',
  'translate'
];
// 重写bpmn中BpmnElementFactory的一些方法
CustomElementFactory.prototype._getCustomElementSize = function(type) {
  var shapes = {
    __default: { width: 100, height: 80 },
    'custom:triangle': { width: 40, height: 40 },
    'custom:circle': { width: 140, height: 140 }
  };

  return shapes[type] || shapes.__default;
}

看这句self.createBpmnElement
追溯到’bpmn-js/lib/features/modeling/ElementFactory’文件下可以看到,其实调用的还是diagram-js/lib/core/ElementFactory

import BaseElementFactory from 'diagram-js/lib/core/ElementFactory';
// ...
ElementFactory.prototype.baseCreate = BaseElementFactory.prototype.create;

🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫 分割线 🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫🎫

左侧菜单

import {
  assign
} from 'min-dash';
import PaletteProvider from 'bpmn-js/lib/features/palette/PaletteProvider';

export default function PaletteProvider(injector, palette, create, elementFactory, spaceTool, lassoTool) {

  this._create = create;
  this._elementFactory = elementFactory;
  this._spaceTool = spaceTool;
  this._lassoTool = lassoTool;
  // 如果你希望在原有上追加,使用cached这一种
  // injector.invoke(PaletteProvider, this);
  // this._cached = bind(this.getPaletteEntries, this);

  palette.registerProvider(this);
}
PaletteProvider.$inject = [
  'injector',
  'palette',
  'create',
  'elementFactory',
  'spaceTool',
  'lassoTool'
];
// getPaletteEntries  !!!!!!!!!!!!!!!!!👌👌👌👌👌👌👌👌👌👌👌👌👌👌!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
PaletteProvider.prototype.getPaletteEntries = function(element) {
  // 如果你希望在原有上追加,使用cached这一种
  // let actions = this._cached(element);
  let actions = {}, // 清空原有的所有项目
    create = this._create,
    elementFactory = this._elementFactory;
    
  function createAction(type, group, className, title, options) {
    // 'custom:triangle', 'custom', 'icon-custom-triangle'

    function createListener(event) {
      let shape = elementFactory.createShape(assign({ type: type }, options));

      if (options) {
        shape.businessObject.di.isExpanded = options.isExpanded;
      }

      create.start(event, shape);
    }

    let shortType = type.replace(/^bpmn:/, '');

    return {
      group: group,
      className: className,
      title: title || 'Create ' + shortType,
      action: {
        dragstart: createListener,
        click: createListener
      }
    };
  }
  
  assign(actions, {
    // 自定义类型1
    'custom-triangle': createAction(
      'custom:triangle', 'custom', 'icon-custom-triangle'
    ),
    // 自定义类型2
    'custom-circle': createAction(
      'custom:circle', 'custom', 'icon-custom-circle'
    ),
    'custom-separator': {
      group: 'custom',
      separator: true
    },
    'create.start-event': createAction(
      'bpmn:StartEvent', 'event', 'bpmn-icon-start-event-none'
    ),
    'create.end-event': createAction(
      'bpmn:EndEvent', 'event', 'bpmn-icon-end-event-none'
    ),
  }
  return actions;
}

任务清单:

  1. 追加左侧palette类型:结构可以自行控制
  2. 追加节点(随意控制包括自定义节点的任意节点)选中时身边的contextPadProvider:可以链接到其他自定义类型
  3. 内置的connect是有rule限制的,所以要自定义rule修改规则,允许连线到自定义节点
  4. 单个节点的结构要允许能够自行定义(网络做法是自定义moddleExtensions,动作时
{
  "name": "QualityAssurance",
  "uri": "http://some-company/schema/bpmn/qa",
  "prefix": "qa",
  "xml": {
    "tagAlias": "lowerCase"
  },
  "types": [
    {
      "name": "XssProperties",
      "superClass": ["Element"],
      "meta": {
        "allowedIn": ["*"]
      },
	  "properties": [
        {
          "name": "values",
          "type": "XssProperty",
          "isMany": true
        }
	  ]
	},
	{
	    "name": "XssPropertyStruct",
	    "properties": [
	      {
	        "name": "value",
	        "type": "String",
	        "isAttr": true
	      }
	    ]
	  },
	  {
	    "name": "XssProperty",
	    "superClass": ["InputOutputParameterDefinition"],
	    "properties": [
	      {
	        "name": "type",
	        "isAttr": true,
	        "type": "XssPropertyStruct"
	      },
	      {
	        "name": "value",
	        "isAttr": true,
	        "type": "XssPropertyStruct"
	      }
    ]
  }],
  "emumerations": [],
  "associations": []
}
let dd = moddle.create('qa:XssProperties', { values: [] });
let typeObj = moddle.create('qa:XssPropertyStruct', { value: 'type1' });
let valueObj = moddle.create('qa:XssPropertyStruct', { value: '0' });
let dd2 = moddle.create('qa:XssProperty', { type: {}, value: {} });
const extensions = moddle.create('bpmn:ExtensionElements', { values: [] });
dd2.type = typeObj;
dd2.value = valueObj;
dd.values.push(dd2);
extensions.values.push(dd);

this.bpmnModeler.get('modeling').updateProperties(this.bpmnElement, {
  extensionElements: extensions
})

还有问题的可以一起留言讨论

### 集成与自定义 bpmn.js 在 Vue3 中实现业务流程管理 #### 安装依赖库 为了在 Vue3 项目中集成 `bpmn-js`,首先需要安装必要的 npm 包。通过命令行执行如下指令来引入核心库及其样式文件: ```bash npm install bpmn-js --save ``` 对于希望获得更佳用户体验的应用程序来说,还可以考虑加入额外插件支持,比如用于增强模型编辑能力的模块。 #### 创建 BPMN 组件 接着,在 Vue3 应用里创建一个新的组件用来承载 BPMN 编辑器实例。此过程涉及到了初始化 `BpmnJS` 对象以及将其挂载到指定 DOM 节点上[^1]。 ```javascript // src/components/BPMNEditor.vue import { defineComponent, onMounted } from 'vue'; import BpmnJs from 'bpmn-js/lib/Modeler'; export default defineComponent({ name: 'BPMNEditor', setup() { let bpmnjs; onMounted(() => { const container = document.querySelector('#canvas'); bpmnjs = new BpmnJs({ container }); // 加载默认图形或从服务器获取已有数据... bpmnjs.createDiagram(); }); return {}; } }); ``` 上述代码片段展示了如何利用 Composition API 来设置一个简单的 BPMN 编辑环境,并且调用了 `createDiagram()` 方法以展示初始空白图表界面给用户交互使用。 #### 自定义扩展功能 针对特定应用场景下的定制化需求,可以通过修改现有行为或是添加新的特性来进行进一步开发工作。例如,如果想要改变某些元素外观,则可通过覆盖 CSS 类名的方式轻松达成目的;而对于更加复杂的逻辑变更,则可能涉及到重写内部方法或者注册事件监听器等高级技巧。 ```css /* 修改节点颜色 */ .djs-shape.bpmn-process > .djs-visual > rect { fill: lightblue !important; } ``` 此外,也可以基于官方文档提供的接口指南实施更多样化的调整方案,如导入导出 XML/SVG 文件等功能均能有效提升系统的实用价值。 #### 整合 Vuex 或 Pinia 进行状态管理 考虑到大型应用往往伴随着复杂的状态流转情况,因此建议采用集中式的存储机制(Vuex/Pinia),以便更好地维护全局变量及跨页面通信等问题。这样不仅有助于提高代码可读性和维护效率,同时也便于后期测试与调试工作的开展。 ```typescript // 使用Pinia作为示例 import { createSlice } from '@reduxjs/toolkit' const useBpmnStore = defineStore('bpmn', { state: () => ({ diagramXML: '' }), actions: { updateDiagram(xmlString) { this.diagramXML = xmlString; } } }) ``` 以上就是关于怎样在 Vue3 平台上成功部署并个性化配置 `bpmn.js` 的基本指导说明。当然实际操作过程中还可能会遇到各种各样未曾预见的技术挑战,这就需要开发者们不断探索学习新知,积极寻求解决方案了。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值