├── .github └── workflows │ └── CI.yml ├── .gitignore ├── LICENSE ├── README.md ├── docs ├── cat.gif ├── resize-colors-screenshot.png └── screencast.gif ├── eslint.config.mjs ├── karma.conf.js ├── lib ├── color-picker │ ├── ColorPicker.js │ ├── ColoredRenderer.js │ └── index.js ├── nyan │ ├── cat │ │ ├── cat.gif │ │ └── index.js │ ├── draw │ │ ├── NyanRenderer.js │ │ └── index.js │ └── palette │ │ ├── NyanPaletteProvider.js │ │ └── index.js └── resize-all-rules │ ├── ResizeAllRules.js │ └── index.js ├── package-lock.json ├── package.json ├── renovate.json └── test ├── Helper.js └── spec ├── ModelerSpec.js └── diagram.bpmn /.github/workflows/CI.yml: -------------------------------------------------------------------------------- 1 | name: CI 2 | on: [ push, pull_request ] 3 | jobs: 4 | Build: 5 | runs-on: ${{ matrix.os }} 6 | 7 | strategy: 8 | matrix: 9 | os: [ubuntu-latest] 10 | node-version: [ 20 ] 11 | 12 | steps: 13 | - name: Checkout 14 | uses: actions/checkout@v4 15 | - name: Use Node.js ${{matrix.node-version}} 16 | uses: actions/setup-node@v4 17 | with: 18 | node-version: ${{matrix.node-version}} 19 | cache: 'npm' 20 | - name: Install dependencies 21 | run: npm ci 22 | - name: Setup project 23 | uses: bpmn-io/actions/setup@latest 24 | - name: Build 25 | run: npm run all -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2016-present camunda Services GmbH 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | > If you're interested in custom elements in general, head over to our [:notebook: custom-elements guide](https://github.com/bpmn-io/bpmn-js-examples/tree/master/custom-elements) to get an overview first. 2 | 3 | 4 | # bpmn-js-nyan 5 | 6 | [![CI](https://github.com/bpmn-io/bpmn-js-nyan/workflows/CI/badge.svg)](https://github.com/bpmn-io/bpmn-js-nyan/actions?query=workflow%3ACI) 7 | 8 | [bpmn-js](https://github.com/bpmn-io/bpmn-js) + !["nyan cat in the wild"](./docs/cat.gif) = auto-win. 9 | 10 | This projects bundles lovely nyan cats into a custom BPMN 2.0 modeler. 11 | 12 | 13 | ## About 14 | 15 | Stand out and integrate nyan cats into your next BPMN Modeler! 16 | 17 | !["nyan cat in bpmn-js"](./docs/screencast.gif) 18 | 19 | 20 | ## Great Features 21 | 22 | * [Custom Colors](./lib/color-picker) 23 | * [Nyan Cats](./lib/nyan) 24 | * [Resize all elements](./lib/resize-all-rules) 25 | 26 | 27 | ## Usage 28 | 29 | ```javascript 30 | import BpmnModeler from 'bpmn-js/lib/Modeler'; 31 | 32 | import resizeAllModule from 'bpmn-js-nyan/lib/resize-all-rules'; 33 | import colorPickerModule from 'bpmn-js-nyan/lib/color-picker'; 34 | import nyanDrawModule from 'bpmn-js-nyan/lib/nyan/draw'; 35 | import nyanPaletteModule from 'bpmn-js-nyan/lib/nyan/palette'; 36 | 37 | 38 | var bpmnJS = new BpmnModeler({ 39 | additionalModules: [ 40 | resizeAllModule, 41 | colorPickerModule, 42 | nyanDrawModule, 43 | nyanPaletteModule 44 | ] 45 | }); 46 | ``` 47 | 48 | 49 | ## Building 50 | 51 | To build, lint and test the project run 52 | 53 | ``` 54 | npm install 55 | npm run all 56 | ``` 57 | 58 | To spin up the test interactively in the browser, execute 59 | 60 | ``` 61 | npm run dev 62 | ``` 63 | 64 | Visit [localhost:9876/debug.html](http://localhost:9876/debug.html) in your browser. 65 | 66 | 67 | ## Related 68 | 69 | If you enjoy nyan cats you might be interested in these related examples, too: 70 | 71 | * [Colors](https://github.com/bpmn-io/bpmn-js-examples/tree/master/colors) 72 | * [Custom Elements](https://github.com/bpmn-io/bpmn-js-examples/tree/master/custom-elements) 73 | * [Custom Modeling Rules](https://github.com/bpmn-io/bpmn-js-examples/tree/master/custom-modeling-rules) 74 | * [Theming](https://github.com/bpmn-io/bpmn-js-examples/tree/master/theming) 75 | 76 | 77 | ## License 78 | 79 | MIT 80 | -------------------------------------------------------------------------------- /docs/cat.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bpmn-io/bpmn-js-nyan/f349c24c03fbe586b6d268dd37c1730852e2b47f/docs/cat.gif -------------------------------------------------------------------------------- /docs/resize-colors-screenshot.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bpmn-io/bpmn-js-nyan/f349c24c03fbe586b6d268dd37c1730852e2b47f/docs/resize-colors-screenshot.png -------------------------------------------------------------------------------- /docs/screencast.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bpmn-io/bpmn-js-nyan/f349c24c03fbe586b6d268dd37c1730852e2b47f/docs/screencast.gif -------------------------------------------------------------------------------- /eslint.config.mjs: -------------------------------------------------------------------------------- 1 | import bpmnIoPlugin from 'eslint-plugin-bpmn-io'; 2 | 3 | const files = { 4 | build: [ 5 | '*.js', 6 | '*.mjs' 7 | ], 8 | test: [ 9 | '**/test/**/*.js' 10 | ] 11 | }; 12 | 13 | export default [ 14 | ...bpmnIoPlugin.configs.browser.map(config => { 15 | return { 16 | ...config, 17 | ignores: files.build 18 | }; 19 | }), 20 | ...bpmnIoPlugin.configs.node.map(config => { 21 | return { 22 | ...config, 23 | files: files.build 24 | }; 25 | }), 26 | ...bpmnIoPlugin.configs.mocha.map(config => { 27 | return { 28 | ...config, 29 | files: files.test 30 | }; 31 | }) 32 | ]; 33 | -------------------------------------------------------------------------------- /karma.conf.js: -------------------------------------------------------------------------------- 1 | /* eslint-env node */ 2 | 3 | // configures browsers to run test against 4 | // any of [ 'ChromeHeadless', 'Chrome', 'Firefox' ] 5 | var browsers = (process.env.TEST_BROWSERS || 'ChromeHeadless').split(','); 6 | 7 | // use puppeteer provided Chrome for testing 8 | process.env.CHROME_BIN = require('puppeteer').executablePath(); 9 | 10 | module.exports = function(karma) { 11 | karma.set({ 12 | 13 | frameworks: [ 14 | 'webpack', 15 | 'mocha', 16 | 'sinon-chai' 17 | ], 18 | 19 | files: [ 20 | 'test/spec/**/*Spec.js', 21 | ], 22 | 23 | reporters: [ 'dots' ], 24 | 25 | preprocessors: { 26 | 'test/spec/**/*Spec.js': [ 'webpack' ] 27 | }, 28 | 29 | browsers, 30 | 31 | browserNoActivityTimeout: 30000, 32 | 33 | singleRun: true, 34 | autoWatch: false, 35 | 36 | webpack: { 37 | mode: 'development', 38 | module: { 39 | rules: [ 40 | { 41 | test: /TestHelper/, 42 | sideEffects: true 43 | }, 44 | { 45 | test: /\.(css|bpmn)$/, 46 | type: 'asset/source' 47 | }, 48 | { 49 | test: /\.png$/, 50 | type: 'asset/resource' 51 | } 52 | ] 53 | }, 54 | devtool: 'eval-source-map' 55 | } 56 | }); 57 | }; 58 | -------------------------------------------------------------------------------- /lib/color-picker/ColorPicker.js: -------------------------------------------------------------------------------- 1 | import { 2 | is 3 | } from 'bpmn-js/lib/util/ModelUtil'; 4 | 5 | 6 | /** 7 | * A basic color picker implementation. 8 | * 9 | * @param {EventBus} eventBus 10 | * @param {ContextPad} contextPad 11 | * @param {CommandStack} commandStack 12 | */ 13 | export default function ColorPicker(eventBus, contextPad, commandStack) { 14 | 15 | contextPad.registerProvider(this); 16 | 17 | commandStack.registerHandler('shape.updateColor', UpdateColorHandler); 18 | 19 | function changeColor(event, element) { 20 | 21 | var color = window.prompt('type a color code'); 22 | 23 | commandStack.execute('shape.updateColor', { element: element, color: color }); 24 | } 25 | 26 | 27 | this.getContextPadEntries = function(element) { 28 | 29 | if (is(element, 'bpmn:Event')) { 30 | return { 31 | 'changeColor': { 32 | group: 'edit', 33 | className: 'icon-red', 34 | title: 'Change element color', 35 | action: { 36 | click: changeColor 37 | } 38 | } 39 | }; 40 | } 41 | }; 42 | } 43 | 44 | 45 | 46 | /** 47 | * A handler updating an elements color. 48 | */ 49 | function UpdateColorHandler() { 50 | 51 | this.execute = function(context) { 52 | context.oldColor = context.element.color; 53 | context.element.color = context.color; 54 | 55 | return context.element; 56 | }; 57 | 58 | this.revert = function(context) { 59 | context.element.color = context.oldColor; 60 | 61 | return context.element; 62 | }; 63 | 64 | } -------------------------------------------------------------------------------- /lib/color-picker/ColoredRenderer.js: -------------------------------------------------------------------------------- 1 | import inherits from 'inherits-browser'; 2 | 3 | import { 4 | attr as svgAttr 5 | } from 'tiny-svg'; 6 | 7 | import BpmnRenderer from 'bpmn-js/lib/draw/BpmnRenderer'; 8 | 9 | import { 10 | is 11 | } from 'bpmn-js/lib/util/ModelUtil'; 12 | 13 | 14 | export default function ColoredRenderer( 15 | config, eventBus, styles, 16 | pathMap, canvas, textRenderer) { 17 | 18 | BpmnRenderer.call( 19 | this, 20 | config, eventBus, styles, 21 | pathMap, canvas, textRenderer, 22 | 1400 23 | ); 24 | 25 | this.canRender = function(element) { 26 | return is(element, 'bpmn:BaseElement') && element.color; 27 | }; 28 | 29 | this.drawShape = function(parent, shape) { 30 | 31 | var bpmnShape = this.drawBpmnShape(parent, shape); 32 | 33 | svgAttr(bpmnShape, { fill: shape.color }); 34 | 35 | return bpmnShape; 36 | }; 37 | } 38 | 39 | inherits(ColoredRenderer, BpmnRenderer); 40 | 41 | ColoredRenderer.prototype.drawBpmnShape = BpmnRenderer.prototype.drawShape; 42 | 43 | 44 | ColoredRenderer.$inject = [ 45 | 'config.bpmnRenderer', 46 | 'eventBus', 47 | 'styles', 48 | 'pathMap', 49 | 'canvas', 50 | 'textRenderer' 51 | ]; -------------------------------------------------------------------------------- /lib/color-picker/index.js: -------------------------------------------------------------------------------- 1 | import ColorPicker from './ColorPicker'; 2 | import ColoredRenderer from './ColoredRenderer'; 3 | 4 | export default { 5 | __init__: [ 'colorPicker', 'coloredRenderer' ], 6 | colorPicker: [ 'type', ColorPicker ], 7 | coloredRenderer: [ 'type', ColoredRenderer ] 8 | }; -------------------------------------------------------------------------------- /lib/nyan/cat/cat.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/bpmn-io/bpmn-js-nyan/f349c24c03fbe586b6d268dd37c1730852e2b47f/lib/nyan/cat/cat.gif -------------------------------------------------------------------------------- /lib/nyan/cat/index.js: -------------------------------------------------------------------------------- 1 | // inlined and base64 encoded ./cat.gif 2 | 3 | const Cat = { 4 | dataURL: '' 5 | }; 6 | 7 | export default Cat; -------------------------------------------------------------------------------- /lib/nyan/draw/NyanRenderer.js: -------------------------------------------------------------------------------- 1 | import inherits from 'inherits-browser'; 2 | 3 | import BaseRenderer from 'diagram-js/lib/draw/BaseRenderer'; 4 | 5 | import { 6 | is 7 | } from 'bpmn-js/lib/util/ModelUtil'; 8 | 9 | import Cat from '../cat'; 10 | 11 | import { 12 | append as svgAppend, 13 | create as svgCreate 14 | } from 'tiny-svg'; 15 | 16 | 17 | export default function NyanRender(eventBus) { 18 | BaseRenderer.call(this, eventBus, 1500); 19 | 20 | this.canRender = function(element) { 21 | return is(element, 'bpmn:ServiceTask'); 22 | }; 23 | 24 | 25 | this.drawShape = function(parent, shape) { 26 | var url = Cat.dataURL; 27 | 28 | var catGfx = svgCreate('image', { 29 | x: 0, 30 | y: 0, 31 | width: shape.width, 32 | height: shape.height, 33 | href: url 34 | }); 35 | 36 | svgAppend(parent, catGfx); 37 | 38 | return catGfx; 39 | }; 40 | } 41 | 42 | inherits(NyanRender, BaseRenderer); 43 | 44 | NyanRender.$inject = [ 'eventBus' ]; -------------------------------------------------------------------------------- /lib/nyan/draw/index.js: -------------------------------------------------------------------------------- 1 | import NyanRenderer from './NyanRenderer'; 2 | 3 | export default { 4 | __init__: [ 'nyanRenderer' ], 5 | nyanRenderer: [ 'type', NyanRenderer ] 6 | }; -------------------------------------------------------------------------------- /lib/nyan/palette/NyanPaletteProvider.js: -------------------------------------------------------------------------------- 1 | import Cat from '../cat'; 2 | 3 | 4 | /** 5 | * A provider for quick service task production 6 | */ 7 | export default function NyanPaletteProvider(palette, create, elementFactory) { 8 | 9 | this._create = create; 10 | this._elementFactory = elementFactory; 11 | 12 | palette.registerProvider(this); 13 | } 14 | 15 | NyanPaletteProvider.$inject = [ 16 | 'palette', 17 | 'create', 18 | 'elementFactory' 19 | ]; 20 | 21 | NyanPaletteProvider.prototype.getPaletteEntries = function() { 22 | 23 | var elementFactory = this._elementFactory, 24 | create = this._create; 25 | 26 | function startCreate(event) { 27 | var serviceTaskShape = elementFactory.create( 28 | 'shape', { type: 'bpmn:ServiceTask' } 29 | ); 30 | 31 | create.start(event, serviceTaskShape); 32 | } 33 | 34 | return { 35 | 'create-service-task': { 36 | group: 'activity', 37 | title: 'Create a new nyan CAT!', 38 | imageUrl: Cat.dataURL, 39 | action: { 40 | dragstart: startCreate, 41 | click: startCreate 42 | } 43 | } 44 | }; 45 | }; -------------------------------------------------------------------------------- /lib/nyan/palette/index.js: -------------------------------------------------------------------------------- 1 | import NyanPaletteProvider from './NyanPaletteProvider'; 2 | 3 | export default { 4 | __init__: [ 'nyanPaletteProvider' ], 5 | nyanPaletteProvider: [ 'type', NyanPaletteProvider ] 6 | }; -------------------------------------------------------------------------------- /lib/resize-all-rules/ResizeAllRules.js: -------------------------------------------------------------------------------- 1 | import RuleProvider from 'diagram-js/lib/features/rules/RuleProvider'; 2 | 3 | import inherits from 'inherits-browser'; 4 | 5 | 6 | export default function ResizeAllRules(eventBus) { 7 | RuleProvider.call(this, eventBus); 8 | } 9 | 10 | inherits(ResizeAllRules, RuleProvider); 11 | 12 | ResizeAllRules.$inject = [ 'eventBus' ]; 13 | 14 | 15 | ResizeAllRules.prototype.init = function() { 16 | 17 | this.addRule('shape.resize', 1500, function() { 18 | return true; 19 | }); 20 | 21 | }; -------------------------------------------------------------------------------- /lib/resize-all-rules/index.js: -------------------------------------------------------------------------------- 1 | import ResizeAllRules from './ResizeAllRules'; 2 | 3 | export default { 4 | __init__: [ 'resizeAllRules' ], 5 | resizeAllRules: [ 'type', ResizeAllRules ] 6 | }; -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "bpmn-js-nyan", 3 | "version": "2.2.0", 4 | "description": "Lets processes fly!", 5 | "scripts": { 6 | "all": "run-s lint test", 7 | "dev": "run-s test:watch", 8 | "lint": "eslint .", 9 | "test": "karma start", 10 | "test:watch": "npm test -- --auto-watch --no-single-run" 11 | }, 12 | "author": "Nico Rehwaldt ", 13 | "license": "MIT", 14 | "repository": { 15 | "type": "git", 16 | "url": "https://github.com/bpmn-io/bpmn-js-nyan" 17 | }, 18 | "devDependencies": { 19 | "bpmn-js": "^18.0.0", 20 | "chai": "^4.4.0", 21 | "diagram-js": "^15.0.0", 22 | "eslint": "^9.0.0", 23 | "eslint-plugin-bpmn-io": "^2.0.2", 24 | "karma": "^6.4.2", 25 | "karma-chrome-launcher": "^3.2.0", 26 | "karma-mocha": "^2.0.1", 27 | "karma-sinon-chai": "^2.0.2", 28 | "karma-webpack": "^5.0.0", 29 | "mocha": "^10.2.0", 30 | "npm-run-all2": "^8.0.0", 31 | "puppeteer": "^24.0.0", 32 | "sinon": "^17.0.1", 33 | "sinon-chai": "^3.1.0", 34 | "webpack": "^5.89.0" 35 | }, 36 | "dependencies": { 37 | "inherits-browser": "^0.1.0" 38 | }, 39 | "peerDependencies": { 40 | "bpmn-js": "*", 41 | "diagram-js": "*" 42 | }, 43 | "files": [ 44 | "lib" 45 | ] 46 | } 47 | -------------------------------------------------------------------------------- /renovate.json: -------------------------------------------------------------------------------- 1 | { 2 | "$schema": "https://docs.renovatebot.com/renovate-schema.json", 3 | "extends": [ 4 | "github>bpmn-io/renovate-config:recommended" 5 | ] 6 | } 7 | -------------------------------------------------------------------------------- /test/Helper.js: -------------------------------------------------------------------------------- 1 | import diagramCSS from 'bpmn-js/dist/assets/diagram-js.css'; 2 | import bpmnFontCSS from 'bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css'; 3 | 4 | 5 | export function addStyle(styleText) { 6 | 7 | var head = document.head; 8 | 9 | var styleElement = document.createElement('style'); 10 | styleElement.type = 'text/css'; 11 | styleElement.textContent = styleText; 12 | 13 | head.appendChild(styleElement); 14 | } 15 | 16 | 17 | // add initial style 18 | addStyle(diagramCSS); 19 | addStyle(bpmnFontCSS); -------------------------------------------------------------------------------- /test/spec/ModelerSpec.js: -------------------------------------------------------------------------------- 1 | import { 2 | addStyle 3 | } from '../Helper'; 4 | 5 | addStyle(` 6 | * { 7 | box-sizing: border-box; 8 | } 9 | 10 | html, body { 11 | height: 100%; 12 | padding: 0; 13 | margin: 0; 14 | } 15 | 16 | body { 17 | padding: 10px; 18 | } 19 | 20 | .icon-red { 21 | background: red !important; 22 | } 23 | 24 | .bjs-container { 25 | border: solid 2px #CCC; 26 | margin-bottom: 10px; 27 | } 28 | `); 29 | 30 | import Modeler from 'bpmn-js/lib/Modeler'; 31 | 32 | import resizeAllModule from '../../lib/resize-all-rules'; 33 | 34 | import colorPickerModule from '../../lib/color-picker'; 35 | 36 | import nyanDrawModule from '../../lib/nyan/draw'; 37 | import nyanPaletteModule from '../../lib/nyan/palette'; 38 | 39 | import diagram from './diagram.bpmn'; 40 | 41 | 42 | describe('modeler / nyan version', function() { 43 | 44 | 45 | function withModeler(config, fn) { 46 | 47 | return function(done) { 48 | 49 | var modeler = new Modeler(config); 50 | 51 | modeler.attachTo('body'); 52 | 53 | modeler.importXML(diagram).then( 54 | () => modeler.invoke(fn) 55 | ).then(done, done); 56 | }; 57 | } 58 | 59 | 60 | describe('just modeler', function() { 61 | 62 | function inject(fn) { 63 | return withModeler({}, fn); 64 | } 65 | 66 | 67 | it('should allow me to render a process', inject(function() { 68 | 69 | })); 70 | 71 | }); 72 | 73 | 74 | describe('custom rules (resize all)', function() { 75 | 76 | function inject(fn) { 77 | 78 | var config = { 79 | additionalModules: [ resizeAllModule ] 80 | }; 81 | 82 | return withModeler(config, fn); 83 | } 84 | 85 | 86 | it('should allow to resize all elements', inject(function() { 87 | 88 | })); 89 | 90 | }); 91 | 92 | 93 | describe('custom colors', function() { 94 | 95 | function inject(fn) { 96 | 97 | var config = { 98 | additionalModules: [ colorPickerModule ] 99 | }; 100 | 101 | return withModeler(config, fn); 102 | } 103 | 104 | 105 | it('should allow to color modules', inject(function() { 106 | 107 | })); 108 | 109 | }); 110 | 111 | 112 | describe('draw', function() { 113 | 114 | function inject(fn) { 115 | 116 | var config = { 117 | additionalModules: [ nyanDrawModule ] 118 | }; 119 | 120 | return withModeler(config, fn); 121 | } 122 | 123 | 124 | it('should render cat', inject(function() { 125 | 126 | })); 127 | 128 | }); 129 | 130 | 131 | describe('palette', function() { 132 | 133 | function inject(fn) { 134 | 135 | var config = { 136 | additionalModules: [ nyanPaletteModule ] 137 | }; 138 | 139 | return withModeler(config, fn); 140 | } 141 | 142 | 143 | it('should create cat from palette', inject(function() { 144 | 145 | })); 146 | 147 | }); 148 | 149 | 150 | describe('combined', function() { 151 | 152 | function inject(fn) { 153 | 154 | var config = { 155 | additionalModules: [ 156 | nyanPaletteModule, 157 | nyanDrawModule, 158 | colorPickerModule, 159 | resizeAllModule 160 | ], 161 | keyboard: { 162 | bindTo: document.body 163 | } 164 | }; 165 | 166 | return withModeler(config, fn); 167 | } 168 | 169 | 170 | it('should create cat from palette', inject(function() { 171 | 172 | })); 173 | 174 | }); 175 | }); -------------------------------------------------------------------------------- /test/spec/diagram.bpmn: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | SequenceFlow_1quc928 6 | 7 | 8 | 9 | SequenceFlow_1uxr9e7 10 | SequenceFlow_0x9ulme 11 | 12 | 13 | SequenceFlow_0x9ulme 14 | 15 | 16 | 17 | SequenceFlow_1quc928 18 | SequenceFlow_1uxr9e7 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | --------------------------------------------------------------------------------