2014-05-26 11:26:02 +02:00
|
|
|
# bpmn-js - BPMN 2.0 for the web
|
2014-05-07 09:55:06 +02:00
|
|
|
|
2021-04-30 19:38:25 +02:00
|
|
|
[![Build Status](https://github.com/bpmn-io/bpmn-js/workflows/CI/badge.svg)](https://github.com/bpmn-io/bpmn-js/actions?query=workflow%3ACI)
|
2015-02-19 14:59:57 +01:00
|
|
|
|
2018-02-05 16:29:49 +01:00
|
|
|
View and edit BPMN 2.0 diagrams in the browser.
|
2016-03-29 09:15:52 +02:00
|
|
|
|
2018-02-05 16:24:42 +01:00
|
|
|
[![bpmn-js screencast](./resources/screencast.gif "bpmn-js in action")](http://demo.bpmn.io/s/start)
|
2014-05-07 09:55:06 +02:00
|
|
|
|
|
|
|
|
2018-02-05 16:29:49 +01:00
|
|
|
## Installation
|
2014-05-22 13:23:29 +02:00
|
|
|
|
2018-02-08 23:02:14 +01:00
|
|
|
Use the library [pre-packaged](https://github.com/bpmn-io/bpmn-js-examples/tree/master/pre-packaged)
|
2018-02-05 16:21:39 +01:00
|
|
|
or include it [via npm](https://github.com/bpmn-io/bpmn-js-examples/tree/master/bundling)
|
|
|
|
into your node-style web-application.
|
2014-05-22 13:23:29 +02:00
|
|
|
|
2018-02-05 16:29:49 +01:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
To get started, create a [bpmn-js](https://github.com/bpmn-io/bpmn-js) instance
|
2018-02-14 22:42:19 +01:00
|
|
|
and render [BPMN 2.0 diagrams](https://www.omg.org/spec/BPMN/2.0.2/) in the browser:
|
2014-05-22 13:23:29 +02:00
|
|
|
|
|
|
|
```javascript
|
2020-12-15 23:25:43 +01:00
|
|
|
const xml = '...'; // my BPMN 2.0 xml
|
|
|
|
const viewer = new BpmnJS({
|
2018-02-05 16:24:05 +01:00
|
|
|
container: 'body'
|
|
|
|
});
|
2014-05-22 13:23:29 +02:00
|
|
|
|
2020-04-29 11:02:42 +02:00
|
|
|
try {
|
|
|
|
const { warnings } = await viewer.importXML(xml);
|
|
|
|
|
|
|
|
console.log('rendered');
|
|
|
|
} catch (err) {
|
|
|
|
console.log('error rendering', err);
|
|
|
|
}
|
2014-05-22 13:23:29 +02:00
|
|
|
```
|
|
|
|
|
2018-02-05 16:30:35 +01:00
|
|
|
Checkout our [examples](https://github.com/bpmn-io/bpmn-js-examples) for many
|
|
|
|
more supported usage scenarios.
|
|
|
|
|
|
|
|
|
2017-01-27 10:09:34 +01:00
|
|
|
### Dynamic Attach/Detach
|
|
|
|
|
|
|
|
You may attach or detach the viewer dynamically to any element on the page, too:
|
|
|
|
|
|
|
|
```javascript
|
2020-12-15 23:25:43 +01:00
|
|
|
const viewer = new BpmnJS();
|
2017-01-27 10:09:34 +01:00
|
|
|
|
|
|
|
// attach it to some element
|
|
|
|
viewer.attachTo('#container');
|
|
|
|
|
|
|
|
// detach the panel
|
|
|
|
viewer.detach();
|
|
|
|
```
|
2014-06-13 20:01:36 +02:00
|
|
|
|
2014-05-22 13:23:29 +02:00
|
|
|
|
2014-05-07 09:55:06 +02:00
|
|
|
## Resources
|
|
|
|
|
2018-04-05 21:12:44 +02:00
|
|
|
* [Demo](http://demo.bpmn.io)
|
|
|
|
* [Issues](https://github.com/bpmn-io/bpmn-js/issues)
|
|
|
|
* [Examples](https://github.com/bpmn-io/bpmn-js-examples)
|
|
|
|
* [Forum](https://forum.bpmn.io)
|
|
|
|
* [Changelog](./CHANGELOG.md)
|
2014-05-07 09:55:06 +02:00
|
|
|
|
|
|
|
|
2020-12-21 13:39:14 +01:00
|
|
|
## Build and Run
|
2014-06-19 08:11:13 +02:00
|
|
|
|
2020-12-21 13:39:14 +01:00
|
|
|
Prepare the project by installing all dependencies:
|
2014-06-19 08:11:13 +02:00
|
|
|
|
2020-12-21 13:39:14 +01:00
|
|
|
```sh
|
2016-05-20 09:11:13 +02:00
|
|
|
npm install
|
2020-12-21 13:39:14 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Then, depending on your use-case you may run any of the following commands:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
# build the library and run all tests
|
2016-07-04 14:38:51 +02:00
|
|
|
npm run all
|
2020-12-21 13:39:14 +01:00
|
|
|
|
|
|
|
# spin up a single local modeler instance
|
|
|
|
npm start
|
|
|
|
|
|
|
|
# run the full development setup
|
|
|
|
npm run dev
|
2016-05-20 09:11:13 +02:00
|
|
|
```
|
2014-06-19 08:11:13 +02:00
|
|
|
|
2018-02-05 16:21:39 +01:00
|
|
|
You may need to perform [additional project setup](./docs/project/SETUP.md) when
|
|
|
|
building the latest development snapshot.
|
2016-07-04 14:38:51 +02:00
|
|
|
|
2014-05-07 09:55:06 +02:00
|
|
|
|
2016-05-20 09:11:13 +02:00
|
|
|
## Related
|
|
|
|
|
2019-07-10 12:15:33 +02:00
|
|
|
bpmn-js builds on top of a few powerful tools:
|
2016-05-20 09:11:13 +02:00
|
|
|
|
|
|
|
* [bpmn-moddle](https://github.com/bpmn-io/bpmn-moddle): Read / write support for BPMN 2.0 XML in the browsers
|
|
|
|
* [diagram-js](https://github.com/bpmn-io/diagram-js): Diagram rendering and editing toolkit
|
2014-05-07 09:55:06 +02:00
|
|
|
|
|
|
|
|
2021-02-26 08:52:51 +01:00
|
|
|
## Contributing
|
|
|
|
|
|
|
|
Please checkout our [contributing guidelines](./.github/CONTRIBUTING.md) if you plan to
|
|
|
|
file an issue or pull request.
|
|
|
|
|
|
|
|
|
|
|
|
## Code of Conduct
|
|
|
|
|
|
|
|
By participating to this project, please uphold to our [Code of Conduct](https://github.com/bpmn-io/.github/blob/master/.github/CODE_OF_CONDUCT.md).
|
|
|
|
|
|
|
|
|
2014-05-07 09:55:06 +02:00
|
|
|
## License
|
|
|
|
|
2015-11-30 16:50:13 +01:00
|
|
|
Use under the terms of the [bpmn.io license](http://bpmn.io/license).
|