npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

bpmn-jseditor

v1.0.28

Published

View and edit BPMN 2.0 diagrams in the browser.

Downloads

35

Readme

bpmn-editor

License npm

A javascript module that edits the BPMN on the browser. Bpmn Editor是一个可以在线查看和编辑BPMN 2.0流程图的Javascript库。它可以很方便的嵌入到流程相关的应用中 使得您的客户可以根据自己的需要设计工作流程。

流程图

安装

npm install bpmn-jseditor

或者

<script src="dist/bpmn-jseditor.min.js"></script>

开始使用

容器

首先需要一个容器来装载Editor

<div id="container">

</div>

初始化

然后就可以初始化BpmnEditor了

import BpmnEditor from "bpmn-jseditor";
let editor = new BpmnEditor('#container', {
    name: 'My Process', //流程名称
    key: 'Process-1' //流程Key/ID
})

加载BPMN XML

加载一个符合 BPMN 2.0 规范的XML文件。

editor.xml('Your XML content')
.then(resp => {
   //加载成功
}).catch(resp => {
    //加载失败
})

获取XML

将编辑的流程转换为 BPMN 2.0 XML

editor.xml()
.then(resp => {
   console.log(resp.xml)
})
.catch(resp => {
})

编辑流程图

设置编辑器的Operation即可进入相应的编辑状态。

新增节点

调用serOpertion方法之后,点击编辑器即可添加相应的的节点

editor.setOperation(BpmnEditor.operations.ADD_USERTASK) //进入新增UserTask状态

目前支持的Operation包括:

- NONE: 无操作
- ADD_USERTASK: 添加用户任务 
- ADD_EXCLUSIVE_GATEWAY: 添加互斥网关
- ADD_STARTEVENT: 添加开始事件
- ADD_ENDEVENT: 添加结束事件
- ADD_TIMEREVENT: 添加边界计时事件
- ADD_SUBPROCESS: 添加子流程
- PREPARE_DRAW_CONNECTION: 准备绘制连接线
- REMOVE: 删除选择的节点

绘制连接线

设置操作状态为PREPARE_DRAW_CONNECTION之后,依次点击起点节点、终点节点即可绘制连接线

editor.setOperation(BpmnEditor.operations.PREPARE_DRAW_CONNECTION) //进入绘制连接线状态

删除节点

鼠标点击节点或者框选多个节点,按下Delete按键即可。也可以调用Api:

let selections = editor._getSelections()
for (let i = 0; i < selections.length; i++) {
    editor.remove(selections[i])
}

事件

可以在初始化的时候声明一个回调函数,以处理节点点击事件:

let editor = new BpmnEditor('#container', {
    name: 'My Process', //流程名称
    key: 'Process-1', //流程Key/ID
    elementClick: function(element) {
       let nodeData = element.json()
       //do something, eg. show data in a form
       element.update(nodeData)
    }
})

elementClick方法的参数是点击的节点,如果没有点击任何节点则为流程图本身。调用element.json()方法 可以获取此节点符合activiti 7.0格式的JSON对象。 可以修改此JSON对象,并调用update方法更新节点属性。

TODO List

  • 支持流程嵌套
  • 支持更多的节点类型,例如:Service Task
  • 更多的事件以满足复杂的要求