bpmn-visualization
Version:
A TypeScript library for visualizing process execution data on BPMN diagrams
233 lines (164 loc) ā¢ 11.5 kB
Markdown
<h1 align="center">bpmn-visualization TypeScript library</h1>
<div align="center">
<p align="center"><img title="bpmn-visualization" src="docs/users/images/custom-behavior-path-highlighting.gif" alt="Examples of the bpmn-visualization TypeScript library"></p>
<p align="center">
<a href="https://npmjs.org/package/bpmn-visualization">
<img alt="npm package" src="https://img.shields.io/npm/v/bpmn-visualization.svg?color=orange">
</a>
<a href="https://github.com/process-analytics/bpmn-visualization-js/releases">
<img alt="GitHub release (latest by date including pre-releases)" src="https://img.shields.io/github/v/release/process-analytics/bpmn-visualization-js?label=changelog&include_prereleases">
</a>
<a href="https://cdn.statically.io/gh/process-analytics/bpmn-visualization-examples/master/examples/index.html">
<img alt="Live Demo" src="https://img.shields.io/badge/demo-online-blueviolet.svg">
</a>
<a href="https://github.com/process-analytics/bpmn-visualization-js/actions">
<img alt="Build" src="https://github.com/process-analytics/bpmn-visualization-js/workflows/Build/badge.svg">
</a>
<a href="https://sonarcloud.io/dashboard?id=process-analytics_bpmn-visualization-js">
<img alt="Coverage" src="https://sonarcloud.io/api/project_badges/measure?project=process-analytics_bpmn-visualization-js&metric=coverage"
title="The code coverage is underestimated. It doesn't count the code that is only tested through HTML page.">
</a>
<a href="https://gitpod.io/#https://github.com/process-analytics/bpmn-visualization-js" target="_blank">
<img alt="Gitpod" src="https://img.shields.io/badge/Gitpod-ready--to--code-chartreuse?logo=gitpod">
</a>
<br>
<a href="CONTRIBUTING.md">
<img alt="PRs Welcome" src="https://img.shields.io/badge/PRs-welcome-ff69b4.svg?style=flat-square">
</a>
<a href="CODE_OF_CONDUCT.md">
<img alt="Contributor Covenant" src="https://img.shields.io/badge/Contributor%20Covenant-v2.0%20adopted-ff69b4.svg">
</a>
<a href="LICENSE">
<img alt="License" src="https://img.shields.io/github/license/process-analytics/bpmn-visualization-js?color=blue">
</a>
</p>
</div>
<br>
`bpmn-visualization` is a TypeScript library for visualizing process execution data on [BPMN](https://www.omg.org/spec/BPMN/2.0.2/) diagrams, with simplicity.
Based on the customization capability, it provides a set of diagram visualization features that includes additional display options for execution data (_highlighting of some elements_, _adding customizable overlays_, and more) as well as personalized interactive capabilities (_mouse hover_, _click_, and more).
We hope it will help you to create applications for process visualization and analysis š
## š® Demo and examples
Please check the [__ā© live environment__](https://cdn.statically.io/gh/process-analytics/bpmn-visualization-examples/master/examples/index.html).
You will find their basic usage as well as detailed examples showing possible rendering customizations.
## š Repository Structure
The [dev](./dev) directory contains the source code for the **Load and Navigation demo** showcased on the [example site](https://cdn.statically.io/gh/process-analytics/bpmn-visualization-examples/master/examples/index.html). \
This demo is also used for the PR previews of this repository.
## š Project Status
`bpmn-visualization` is actively developed and maintained.
Before the release of version `1.0.0`, there may be some breaking changes. We avoid these as much as possible, and carefully document them in the release notes.
As far as possible, we maintain compatibility for some minor versions.
## š¤© Why using bpmn-visualization?
- āØ True opensource license without watermark display
- ā”ļø Strong identity: the only BPMN viewer with a woman icon in the User Tasks
- šø Fully documented and with a lot of integration examples
- š Highly customizable rendering in a simple way
- š„ TypeScript support
- šÆ Battle tested: high test coverage, thousands of tests, including tests on all supported browsers for Linux, macOS and Windows
## šØ Features
Already available features:
- [Supported BPMN Elements](https://process-analytics.github.io/bpmn-visualization-js/#supported-bpmn-elements).
- [Navigate through the BPMN diagram](https://process-analytics.github.io/bpmn-visualization-js/#diagram-navigation)
- [Display execution data with interactive capabilities](https://process-analytics.github.io/bpmn-visualization-js/#process_data)
š„ Some add-on features are available through a dedicated package: [__ā© bpmn-visualization-addons__](https://github.com/process-analytics/bpmn-visualization-addons/)
Planned new features:
- Additional BPMN styling capabilities
- Library extension points
## š Browsers Support
| <img src="https://www.google.com/chrome/static/images/chrome-logo.svg" alt="Chrome" width="18px" height="18px" /> Chrome | <img src="http://blog.mozilla.org/design/files/2019/10/Fx-Browser-icon-fullColor.svg" alt="Firefox" height="18px" /> Firefox | <img src="https://upload.wikimedia.org/wikipedia/commons/5/52/Safari_browser_logo.svg" alt="Safari" width="18px" height="18px" /> Safari | <img src="https://avatars0.githubusercontent.com/u/11354582?s=200&v=4" alt="Edge" width="18px" height="18px" /> Edge |
| :---------: | :---------: | :---------: | :---------: |
| āļø | āļø | āļø | āļø |
**Notes**:
- Chromium based browsers should work (automatic tests are run with Chromium canary releases). In particular, the following
desktop browsers are known working with `bpmn-visualization@0.44.0`:
- Brave 1.70.126
- Chromium: 129.0.6668.100
- Opera 114.0.5282.102
- Support Chromium Edge but not Legacy Edge
- The library may work with the other browsers. They must at least support ES2015.
## ā»ļø Usage
The library is available from [NPM](https://npmjs.org/package/bpmn-visualization). \
We support various module formats such as:
- [ESM](https://dev.to/iggredible/what-the-heck-are-cjs-amd-umd-and-esm-ikm): `dist/bpmn-visualization.esm.js`
- [IIFE](https://developer.mozilla.org/en-US/docs/Glossary/IIFE): `dist/bpmn-visualization.js` and its minified companion `dist/bpmn-visualization.min.js`
### š Usage in applications and projects
Install `bpmn-visualization`:
```shell script
npm i bpmn-visualization
```
Then use this snippet to load your BPMN diagram in a page:
```javascript
import { BpmnVisualization } from 'bpmn-visualization';
// initialize `bpmn-visualization` and load the BPMN diagram
// 'bpmn-container' is the id of the HTMLElement that renders the BPMN Diagram
const bpmnVisualization = new BpmnVisualization({ container: 'bpmn-container' });
let bpmnContent; // your BPMN 2.0 XML content
try {
bpmnVisualization.load(bpmnContent);
} catch (error) {
console.error('Error loading BPMN content', error);
}
```
You can set the BPMN content using one of the following ways:
* Copy/Paste directly the XML content in a variable
* Load it from an url, like this [example](https://github.com/process-analytics/bpmn-visualization-examples/blob/master/examples/display-bpmn-diagram/load-remote-bpmn-diagrams/index.html)
* Load from your computer, like the [demo example](https://github.com/process-analytics/bpmn-visualization-examples/tree/master/examples/display-bpmn-diagram/load-local-bpmn-diagrams/index.html)
The `bpmn-visualization` npm package includes type definitions, so the integration works out of the box in TypeScript projects.
`bpmn-visualization` requires **TypeScript 4.0** or greater. Past versions had the following requirements:
* 0.21.0 to 0.27.1: TypeScript 4.5
* 0.17.1 to 0.20.1: TypeScript 4.3
ā¹ļø If you are looking for examples of projects integrating `bpmn-visualization` with TypeScript, see the `bpmn-visualization-examples` [repository](https://github.com/process-analytics/bpmn-visualization-examples/#bpmn-visualization-usage-in-projects).
---
**NOTE**
Prior version 0.27.0, `bpmn-visualization` required extra configuration for TypeScript projects as explained in the [v0.26.2 README](https://github.com/process-analytics/bpmn-visualization-js/tree/v0.26.2#-typescript-support).
---
In the HTML page:
* Load `bpmn-visualization` (replace `{version}` by the recent version)
* Define the container that displays the BPMN diagram, here _bpmn-container_
* Load your BPMN diagram in a page
```html
<script src="https://cdn.jsdelivr.net/npm/bpmn-visualization@{version}/dist/bpmn-visualization.min.js"></script>
...
<div id="bpmn-container"></div>
...
<script>
// initialize `bpmn-visualization` and load the BPMN diagram
// 'bpmn-container' is the id of the HTMLElement that renders the BPMN Diagram
const bpmnVisualization = new bpmnvisu.BpmnVisualization({ container: 'bpmn-container'});
let bpmnContent; // your BPMN 2.0 XML content
try {
bpmnVisualization.load(bpmnContent);
} catch (error) {
console.error('Error loading BPMN content', error);
}
</script>
```
The User documentation (with the feature list & the public API) is available in the [documentation site](https://process-analytics.github.io/bpmn-visualization-js/).
### āļø More
š” Want to know more about `bpmn-visualization` usage and extensibility? Have a look at the
[__ā© live examples site__](https://cdn.statically.io/gh/process-analytics/bpmn-visualization-examples/master/examples/index.html).
For more technical details and how-to, go to the `bpmn-visualization-examples` [repository](https://github.com/process-analytics/bpmn-visualization-examples/).
## š§ Contributing
To contribute to `bpmn-visualization`, fork and clone this repository locally and commit your code on a separate branch.
Please write tests for your code before opening a pull-request:
```sh
npm test # run all tests
```
You can find more detail in our [Contributing guide](CONTRIBUTING.md). Participation in this open source project is subject to a [Code of Conduct](CODE_OF_CONDUCT.md).
āØ A BIG thanks to all our contributors š
## š License
`bpmn-visualization` is released under the [Apache 2.0](LICENSE) license.
Copyright © 2020-present, Bonitasoft S.A.
Some BPMN icons used by `bpmn-visualization` are derived from existing projects. See the [BPMN Support documentation](https://process-analytics.github.io/bpmn-visualization-js/#supported-bpmn-elements)
for more details:
- [draw.io](https://github.com/jgraph/drawio) (Apache-2.0)
- [flaticon](https://www.flaticon.com) ([freepikcompany license](https://www.freepikcompany.com/legal#nav-flaticon))
- [noun project](https://thenounproject.com/) (mainly Creative Commons CCBY 3.0)
[](https://statically.io)
**[statically.io](https://statically.io)** (<kbd>demo</kbd> and <kbd>examples</kbd> live environments)
<img src="https://surge.sh/images/logos/svg/surge-logo.svg" alt="surge.sh logo" title="surge.sh" width="110"/>
**[surge.sh](https://surge.sh)** (<kbd>demo</kbd> and <kbd>documentation</kbd> preview environments)
[ ]: https://cdn.statically.io/gh/process-analytics/bpmn-visualization-examples/master/demo/index.html