2015-09-08 14:38:50 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/* global bootstrapModeler, inject */
|
|
|
|
|
|
|
|
var Modeler = require('../../lib/Modeler');
|
|
|
|
|
|
|
|
var canvasEvent = require('../util/MockEvents').createCanvasEvent;
|
|
|
|
|
|
|
|
|
|
|
|
var customElementsModules = require('./custom-elements'),
|
2016-06-07 08:46:45 +02:00
|
|
|
noTouchInteractionModule = { touchInteractionEvents: ['value', null ] },
|
2015-09-08 14:38:50 +02:00
|
|
|
modelerModules = Modeler.prototype._modules,
|
|
|
|
customModules = [ customElementsModules, noTouchInteractionModule ];
|
|
|
|
|
|
|
|
var testModules = [].concat(modelerModules, customModules);
|
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
var processDiagramXML = require('../fixtures/bpmn/simple.bpmn');
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
var collaborationDiagramXML = require('../fixtures/bpmn/collaboration.bpmn');
|
2015-09-08 14:38:50 +02:00
|
|
|
|
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
describe('custom elements', function() {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
describe('renderer', function() {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
beforeEach(bootstrapModeler(processDiagramXML, {
|
|
|
|
modules: testModules
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
2015-09-08 14:38:50 +02:00
|
|
|
var triangle, circle;
|
|
|
|
|
|
|
|
beforeEach(inject(function(elementFactory, canvas) {
|
|
|
|
triangle = elementFactory.createShape({
|
|
|
|
id: 'triangle',
|
|
|
|
type: 'custom:triangle',
|
|
|
|
x: 700, y: 100
|
|
|
|
});
|
|
|
|
|
|
|
|
canvas.addShape(triangle);
|
|
|
|
|
|
|
|
circle = elementFactory.createShape({
|
|
|
|
id: 'circle',
|
|
|
|
type: 'custom:circle',
|
|
|
|
x: 800, y: 100
|
|
|
|
});
|
|
|
|
|
|
|
|
canvas.addShape(circle);
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should render custom elements', inject(function(elementRegistry) {
|
|
|
|
// when
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(elementRegistry.get('triangle')).to.eql(triangle);
|
|
|
|
expect(elementRegistry.get('circle')).to.eql(circle);
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should get the correct custom elements path', inject(function(graphicsFactory) {
|
|
|
|
// when
|
|
|
|
var trianglePath = graphicsFactory.getShapePath(triangle),
|
|
|
|
circlePath = graphicsFactory.getShapePath(circle);
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(trianglePath).to.equal('M720,100l20,40l-40,0z');
|
|
|
|
expect(circlePath).to.equal('M870,170m0,-70a70,70,0,1,1,0,140a70,70,0,1,1,0,-140z');
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should still render bpmn elements', inject(function(elementFactory) {
|
|
|
|
// when
|
|
|
|
var startEvent = elementFactory.createShape({ type: 'bpmn:StartEvent' });
|
|
|
|
|
|
|
|
// then
|
|
|
|
expect(startEvent.businessObject.$type).to.equal('bpmn:StartEvent');
|
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
describe('integration', function() {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
describe('process diagram', function() {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
beforeEach(bootstrapModeler(processDiagramXML, {
|
|
|
|
modules: testModules
|
|
|
|
}));
|
2015-09-08 14:38:50 +02:00
|
|
|
|
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
var triangle, circle;
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
beforeEach(inject(function(elementFactory, canvas) {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
circle = elementFactory.createShape({
|
|
|
|
id: 'circle',
|
|
|
|
type: 'custom:circle',
|
|
|
|
x: 800, y: 100
|
|
|
|
});
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
canvas.addShape(circle);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
triangle = elementFactory.createShape({
|
|
|
|
id: 'triangle',
|
|
|
|
type: 'custom:triangle',
|
|
|
|
x: 700, y: 100
|
|
|
|
});
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
canvas.addShape(triangle);
|
|
|
|
}));
|
2015-09-08 14:38:50 +02:00
|
|
|
|
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
it('should allow moving a custom shape inside another one',
|
|
|
|
inject(function(elementFactory, elementRegistry, dragging, move) {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var circleGfx = elementRegistry.getGraphics(circle);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), triangle);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
dragging.move(canvasEvent({ x: 100, y: 0 }));
|
|
|
|
dragging.hover({ element: circle, gfx: circleGfx });
|
|
|
|
dragging.move(canvasEvent({ x: 150, y: 50 }));
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
dragging.end();
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
expect(triangle.parent).to.equal(circle);
|
|
|
|
})
|
|
|
|
);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
it('should update the custom shape properties',
|
|
|
|
inject(function(elementFactory, elementRegistry, dragging, move) {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var circleGfx = elementRegistry.getGraphics(circle);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
move.start(canvasEvent({ x: 0, y: 0 }), triangle);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
dragging.move(canvasEvent({ x: 100, y: 0 }));
|
|
|
|
dragging.hover({ element: circle, gfx: circleGfx });
|
|
|
|
dragging.move(canvasEvent({ x: 150, y: 50 }));
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
dragging.end();
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
expect(triangle.businessObject.leader).to.equal(circle);
|
|
|
|
expect(circle.businessObject.companions).to.include(triangle);
|
|
|
|
})
|
|
|
|
);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
|
|
|
|
2016-05-30 19:42:46 +02:00
|
|
|
it('should connect a bpmn element to a custom one',
|
|
|
|
inject(function(elementFactory, dragging, elementRegistry, connect) {
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var subProcess = elementRegistry.get('SubProcess_1'),
|
|
|
|
triangleGfx = elementRegistry.getGraphics(triangle);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
connect.start(canvasEvent({ x: 590, y: 90 }), subProcess);
|
2015-09-08 14:38:50 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
dragging.move(canvasEvent({ x: 700, y: 100 }));
|
|
|
|
dragging.hover({ element: triangle, gfx: triangleGfx });
|
|
|
|
dragging.move(canvasEvent({ x: 715, y: 115 }));
|
2016-05-30 19:42:46 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
dragging.end();
|
2016-05-30 19:42:46 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var connection = triangle.incoming[0];
|
2016-05-30 19:42:46 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
expect(connection.type).to.equal('bpmn:Association');
|
|
|
|
expect(connection.source).to.equal(subProcess);
|
|
|
|
})
|
|
|
|
);
|
2016-05-30 19:42:46 +02:00
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('collaboration diagram', function() {
|
|
|
|
|
|
|
|
beforeEach(bootstrapModeler(collaborationDiagramXML, {
|
|
|
|
modules: testModules
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
var triangle;
|
|
|
|
|
|
|
|
beforeEach(inject(function(elementFactory, canvas) {
|
|
|
|
|
|
|
|
triangle = elementFactory.createShape({
|
|
|
|
id: 'triangle',
|
|
|
|
type: 'custom:triangle',
|
|
|
|
x: 700, y: 100
|
|
|
|
});
|
|
|
|
|
|
|
|
canvas.addShape(triangle);
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should update parent when removing collaboration',
|
|
|
|
inject(function(elementRegistry, modeling, canvas) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var customTriangle = elementRegistry.get('triangle');
|
2016-05-30 19:42:46 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
modeling.removeElements([
|
|
|
|
elementRegistry.get('Participant_1'),
|
|
|
|
elementRegistry.get('Participant_2')
|
|
|
|
]);
|
2016-05-30 19:42:46 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
expect(customTriangle.parent).to.eql(canvas.getRootElement());
|
|
|
|
})
|
|
|
|
);
|
2016-05-30 19:42:46 +02:00
|
|
|
|
|
|
|
});
|
2015-09-08 14:38:50 +02:00
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|