Files
bpmn-js/lib/BaseModeler.spec.ts
Nico Rehwaldt edfec4cdc8 feat: allow to type services and events
This PR builds on upon diagram-js provided service and event typing:

* https://github.com/bpmn-io/diagram-js/pull/862

It allows you to specify (public) types exposed by your BPMN toolkit
trough a ServiceMap. Events exposed are parsed from the EventBus
dynamic types.

Closes #2121
2024-04-30 10:12:09 +02:00

59 lines
1003 B
TypeScript

import Canvas from 'diagram-js/lib/core/Canvas';
import EventBus from 'diagram-js/lib/core/EventBus';
import BaseModeler from './BaseModeler';
import { testViewer } from './BaseViewer.spec';
const modeler = new BaseModeler({
container: 'container'
});
testViewer(modeler);
const otherModeler = new BaseModeler({
container: 'container'
});
const extendedModeler = new BaseModeler({
container: 'container',
alignToOrigin: false,
propertiesPanel: {
attachTo: '#properties-panel'
}
});
// typed API usage
type FooEvent = {
/**
* Very cool field!
*/
foo: string;
};
type EventMap = {
foo: FooEvent
};
type TypeMap = {
canvas: Canvas,
eventBus: EventBus<EventMap>
};
const typedModeler = new BaseModeler<TypeMap>();
const bus = typedModeler.get('eventBus');
const canvas = typedModeler.get('canvas');
canvas.zoom('fit-viewport');
typedModeler.on('foo', event => {
console.log(event.foo);
});
typedModeler.get('eventBus').on('foo', e => console.log(e.foo));