2022-10-12 14:21:19 +00:00
|
|
|
import BpmnModeler from 'bpmn-js/lib/Modeler';
|
|
|
|
import {
|
|
|
|
BpmnPropertiesPanelModule,
|
|
|
|
BpmnPropertiesProviderModule,
|
|
|
|
} from 'bpmn-js-properties-panel';
|
2022-11-07 19:35:53 +00:00
|
|
|
import diagramXML from '../test/spec/bpmn/diagram.bpmn';
|
2022-10-12 14:21:19 +00:00
|
|
|
import spiffworkflow from './spiffworkflow';
|
|
|
|
import setupFileOperations from './fileOperations';
|
|
|
|
|
|
|
|
const modelerEl = document.getElementById('modeler');
|
|
|
|
const panelEl = document.getElementById('panel');
|
|
|
|
const spiffModdleExtension = require('./spiffworkflow/moddle/spiffworkflow.json');
|
|
|
|
|
|
|
|
let bpmnModeler;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This provides an example of how to instantiate a BPMN Modeler configured with
|
|
|
|
* all the extensions and modifications in this application.
|
|
|
|
*/
|
|
|
|
try {
|
|
|
|
bpmnModeler = new BpmnModeler({
|
|
|
|
container: modelerEl,
|
|
|
|
propertiesPanel: {
|
|
|
|
parent: panelEl,
|
|
|
|
},
|
|
|
|
additionalModules: [
|
|
|
|
spiffworkflow,
|
|
|
|
BpmnPropertiesPanelModule,
|
|
|
|
BpmnPropertiesProviderModule,
|
|
|
|
],
|
|
|
|
moddleExtensions: {
|
|
|
|
spiffworkflowModdle: spiffModdleExtension,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
} catch (error) {
|
|
|
|
if (error.constructor.name === 'AggregateError') {
|
|
|
|
console.log(error.message);
|
|
|
|
console.log(error.name);
|
|
|
|
console.log(error.errors);
|
|
|
|
}
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
|
|
|
|
// import XML
|
|
|
|
bpmnModeler.importXML(diagramXML).then(() => {});
|
|
|
|
|
|
|
|
/**
|
2022-10-31 21:02:34 +00:00
|
|
|
* It is possible to populate certain components using API calls to
|
2022-10-12 14:21:19 +00:00
|
|
|
* a backend. Here we mock out the API call, but this gives you
|
|
|
|
* a sense of how things might work.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
bpmnModeler.on('spiff.service_tasks.requested', (event) => {
|
|
|
|
event.eventBus.fire('spiff.service_tasks.returned', {
|
|
|
|
serviceTaskOperators: [
|
|
|
|
{
|
|
|
|
id: 'Chuck Norris Fact Service',
|
|
|
|
parameters: [
|
|
|
|
{
|
|
|
|
id: 'category',
|
|
|
|
type: 'string',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'Fact about a Number',
|
|
|
|
parameters: [
|
|
|
|
{
|
|
|
|
id: 'number',
|
|
|
|
type: 'integer',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-10-31 21:02:34 +00:00
|
|
|
/**
|
|
|
|
* Python Script authoring is best done in some sort of editor
|
|
|
|
* here is an example that will connect a large CodeMirror editor
|
|
|
|
* to the "Launch Editor" buttons (Script Tasks, and the Pre and Post
|
|
|
|
* scripts on all other tasks.
|
|
|
|
*/
|
|
|
|
const myCodeMirror = CodeMirror(document.getElementById('code_editor'), {
|
|
|
|
lineNumbers: true,
|
|
|
|
mode: 'python',
|
|
|
|
});
|
|
|
|
|
|
|
|
const saveCodeBtn = document.getElementById('saveCode');
|
|
|
|
let launchCodeEvent = null;
|
|
|
|
|
2022-11-07 19:35:53 +00:00
|
|
|
bpmnModeler.on('spiff.script.edit', (newEvent) => {
|
2022-10-31 21:02:34 +00:00
|
|
|
launchCodeEvent = newEvent;
|
|
|
|
myCodeMirror.setValue(launchCodeEvent.script);
|
2022-11-07 19:35:53 +00:00
|
|
|
setTimeout(function () {
|
2022-10-31 21:02:34 +00:00
|
|
|
myCodeMirror.refresh();
|
2022-11-07 19:35:53 +00:00
|
|
|
}, 1); // We have to wait a moment before calling refresh.
|
2022-10-31 21:02:34 +00:00
|
|
|
document.getElementById('code_overlay').style.display = 'block';
|
|
|
|
document.getElementById('code_editor').focus();
|
|
|
|
});
|
|
|
|
|
|
|
|
saveCodeBtn.addEventListener('click', (_event) => {
|
|
|
|
const { scriptType, element } = launchCodeEvent;
|
2022-11-07 19:35:53 +00:00
|
|
|
launchCodeEvent.eventBus.fire('spiff.script.update', {
|
|
|
|
element,
|
|
|
|
scriptType,
|
|
|
|
script: myCodeMirror.getValue(),
|
|
|
|
});
|
2022-10-31 21:02:34 +00:00
|
|
|
document.getElementById('code_overlay').style.display = 'none';
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Like Python Script Editing, it can be nice to edit your Markdown in a
|
|
|
|
* good editor as well.
|
|
|
|
*/
|
2022-11-07 19:35:53 +00:00
|
|
|
const simplemde = new SimpleMDE({
|
|
|
|
element: document.getElementById('markdown_textarea'),
|
|
|
|
});
|
2022-10-31 21:02:34 +00:00
|
|
|
let launchMarkdownEvent = null;
|
2022-11-07 19:35:53 +00:00
|
|
|
bpmnModeler.on('spiff.markdown.edit', (newEvent) => {
|
2022-10-31 21:02:34 +00:00
|
|
|
launchMarkdownEvent = newEvent;
|
2022-11-07 19:35:53 +00:00
|
|
|
simplemde.value(launchMarkdownEvent.value);
|
2022-10-31 21:02:34 +00:00
|
|
|
document.getElementById('markdown_overlay').style.display = 'block';
|
|
|
|
document.getElementById('markdown_editor').focus();
|
|
|
|
});
|
|
|
|
|
|
|
|
const saveMarkdownBtn = document.getElementById('saveMarkdown');
|
|
|
|
saveMarkdownBtn.addEventListener('click', (_event) => {
|
|
|
|
const { element } = launchMarkdownEvent;
|
2022-11-07 19:35:53 +00:00
|
|
|
launchMarkdownEvent.eventBus.fire('spiff.markdown.update', {
|
|
|
|
element,
|
|
|
|
value: simplemde.value(),
|
|
|
|
});
|
2022-10-31 21:02:34 +00:00
|
|
|
document.getElementById('markdown_overlay').style.display = 'none';
|
|
|
|
});
|
|
|
|
|
2022-11-07 19:35:53 +00:00
|
|
|
/**
|
|
|
|
* Also can be good to launch an editor for a call activity, or file
|
|
|
|
* Not implemented here but imagine opening up a new browser tab
|
|
|
|
* and showing a different process or completly different file editor.
|
|
|
|
*/
|
|
|
|
bpmnModeler.on('spiff.callactivity.edit', (newEvent) => {
|
|
|
|
console.log(
|
|
|
|
'Open new window with editor for call activity: ',
|
|
|
|
newEvent.processId
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Also can be good to launch an editor for a call activity, or DMN
|
|
|
|
* Not implemented here but imagine opening up a new browser tab
|
|
|
|
* and showing a different process.
|
|
|
|
*/
|
|
|
|
bpmnModeler.on('spiff.file.edit', (newEvent) => {
|
|
|
|
console.log('Open new window to edit file: ', newEvent.value);
|
|
|
|
});
|
|
|
|
bpmnModeler.on('spiff.dmn.edit', (newEvent) => {
|
|
|
|
console.log('Open new window to edit DMN table: ', newEvent.value);
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Also handy to get a list of available files that can be used in a given
|
|
|
|
* context, say json files for a form, or a DMN file for a BusinessRuleTask
|
|
|
|
*/
|
|
|
|
bpmnModeler.on('spiff.json_files.requested', (event) => {
|
|
|
|
event.eventBus.fire('spiff.json_files.returned', {
|
|
|
|
options: [
|
|
|
|
{ label: 'pizza_form.json', value: 'pizza_form.json' },
|
|
|
|
{ label: 'credit_card_form.json', value: 'credit_card_form.json' },
|
|
|
|
],
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
bpmnModeler.on('spiff.dmn_files.requested', (event) => {
|
|
|
|
event.eventBus.fire('spiff.dmn_files.returned', {
|
|
|
|
options: [
|
|
|
|
{ label: 'Pizza Special Prices', value: 'pizza_prices' },
|
|
|
|
{ label: 'Topping Prices', value: 'topping_prices' },
|
|
|
|
{ label: 'Test Decision', value: 'test_decision' },
|
|
|
|
],
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-10-12 14:21:19 +00:00
|
|
|
// This handles the download and upload buttons - it isn't specific to
|
|
|
|
// the BPMN modeler or these extensions, just a quick way to allow you to
|
2022-10-31 21:02:34 +00:00
|
|
|
// create and save files, so keeping it outside the example.
|
2022-10-12 14:21:19 +00:00
|
|
|
setupFileOperations(bpmnModeler);
|