2018-04-02 21:01:53 +02:00
|
|
|
import {
|
|
|
|
bootstrapModeler,
|
|
|
|
inject
|
|
|
|
} from 'test/TestHelper';
|
|
|
|
|
|
|
|
import replacePreviewModule from 'lib/features/replace-preview';
|
|
|
|
import moveModule from 'diagram-js/lib/features/move';
|
|
|
|
import modelingModule from 'lib/features/modeling';
|
|
|
|
import coreModule from 'lib/core';
|
|
|
|
|
|
|
|
import {
|
|
|
|
createCanvasEvent as canvasEvent
|
|
|
|
} from '../../../util/MockEvents';
|
|
|
|
|
|
|
|
import {
|
|
|
|
assign
|
|
|
|
} from 'min-dash';
|
|
|
|
|
|
|
|
import {
|
|
|
|
attr as svgAttr,
|
|
|
|
clone as svgClone,
|
|
|
|
innerSVG
|
|
|
|
} from 'tiny-svg';
|
2016-09-14 08:18:56 +02:00
|
|
|
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
describe('features/replace-preview', function() {
|
|
|
|
|
2015-08-18 13:35:48 +02:00
|
|
|
var diagramXML = require('../../../fixtures/bpmn/event-sub-processes.bpmn');
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
var startEvent_1,
|
2015-09-01 17:57:32 +02:00
|
|
|
rootElement;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
var getGfx,
|
|
|
|
moveShape;
|
|
|
|
|
2017-12-10 23:04:08 +01:00
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
|
|
modules: [
|
|
|
|
replacePreviewModule,
|
|
|
|
moveModule,
|
|
|
|
modelingModule,
|
|
|
|
coreModule
|
|
|
|
]
|
|
|
|
}));
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
beforeEach(inject(function(canvas, elementRegistry, elementFactory, move, dragging) {
|
|
|
|
|
|
|
|
startEvent_1 = elementRegistry.get('StartEvent_1');
|
|
|
|
rootElement = canvas.getRootElement();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* returns the gfx representation of an element type
|
|
|
|
*
|
|
|
|
* @param {Object} elementData
|
|
|
|
*
|
|
|
|
* @return {Object}
|
|
|
|
*/
|
|
|
|
getGfx = function(elementData) {
|
|
|
|
assign(elementData, { x: 0, y: 0 });
|
|
|
|
|
|
|
|
var tempShape = elementFactory.createShape(elementData);
|
|
|
|
|
|
|
|
canvas.addShape(tempShape, rootElement);
|
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
var gfx = svgClone(elementRegistry.getGraphics(tempShape));
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
canvas.removeShape(tempShape);
|
|
|
|
|
|
|
|
return gfx;
|
|
|
|
};
|
|
|
|
|
|
|
|
moveShape = function(shape, target, position) {
|
|
|
|
var startPosition = { x: shape.x + 10 + (shape.width / 2), y: shape.y + 30 + (shape.height / 2) };
|
|
|
|
|
2015-08-24 15:31:47 +02:00
|
|
|
move.start(canvasEvent(startPosition), shape);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
dragging.hover({
|
|
|
|
element: target,
|
|
|
|
gfx: elementRegistry.getGraphics(target)
|
|
|
|
});
|
|
|
|
|
2015-08-24 15:31:47 +02:00
|
|
|
dragging.move(canvasEvent(position));
|
2015-08-17 16:43:15 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
|
2015-08-17 16:43:15 +02:00
|
|
|
it('should replace visuals at the same position as the replaced visual', inject(function(dragging) {
|
|
|
|
|
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 280, y: 120 });
|
|
|
|
|
|
|
|
// then
|
2016-01-27 13:37:47 +01:00
|
|
|
var dragGroup = dragging.context().data.context.dragGroup;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
svgAttr(dragGroup.childNodes[0], 'display', 'inline');
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(dragGroup.childNodes[0].getBBox()).to.eql(dragGroup.childNodes[1].getBBox());
|
2015-08-17 16:43:15 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
2015-09-24 16:50:34 +02:00
|
|
|
it('should add dragger to context.visualReplacements once', inject(function(dragging) {
|
|
|
|
|
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 275, y: 120 });
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 280, y: 120 });
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 285, y: 120 });
|
|
|
|
|
|
|
|
// then
|
2016-01-27 13:37:47 +01:00
|
|
|
var visualReplacements = dragging.context().data.context.visualReplacements;
|
2015-09-24 16:50:34 +02:00
|
|
|
|
|
|
|
expect(visualReplacements[startEvent_1.id]).to.exist;
|
|
|
|
expect(Object.keys(visualReplacements).length).to.equal(1);
|
|
|
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should remove dragger from context.visualReplacements', inject(function(elementRegistry, dragging) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var subProcess_2 = elementRegistry.get('SubProcess_2');
|
|
|
|
|
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 275, y: 120 });
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 280, y: 120 });
|
|
|
|
moveShape(startEvent_1, subProcess_2, { x: 350, y: 120 });
|
|
|
|
|
|
|
|
// then
|
2016-01-27 13:37:47 +01:00
|
|
|
var visualReplacements = dragging.context().data.context.visualReplacements;
|
2015-09-24 16:50:34 +02:00
|
|
|
|
|
|
|
expect(visualReplacements).to.be.empty;
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
it('should hide the replaced visual', inject(function(dragging) {
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 280, y: 120 });
|
|
|
|
|
|
|
|
// then
|
2016-01-27 13:37:47 +01:00
|
|
|
var dragGroup = dragging.context().data.context.dragGroup;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(svgAttr(dragGroup.childNodes[0], 'display')).to.equal('none');
|
2015-08-17 16:43:15 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should not replace non-interrupting start event while hover over same event sub process',
|
|
|
|
inject(function(dragging, elementRegistry) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var subProcess_1 = elementRegistry.get('SubProcess_1');
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, subProcess_1, { x: 210, y: 180 });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var context = dragging.context().data.context;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
// check if the visual representation remains a non interrupting message start event
|
|
|
|
var startEventGfx = getGfx({
|
|
|
|
type: 'bpmn:StartEvent',
|
|
|
|
isInterrupting: false,
|
|
|
|
eventDefinitionType: 'bpmn:MessageEventDefinition'
|
|
|
|
});
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(innerSVG(context.dragGroup.childNodes[0])).to.equal(innerSVG(startEventGfx));
|
2016-06-07 08:46:45 +02:00
|
|
|
})
|
|
|
|
);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
it('should replace non-interrupting start event while hover over root element',
|
|
|
|
inject(function(dragging, elementRegistry) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, rootElement, { x: 280, y: 120 });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var context = dragging.context().data.context;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
// check if the visual replacement is a blank interrupting start event
|
|
|
|
var startEventGfx = getGfx({ type: 'bpmn:StartEvent' });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(innerSVG(context.dragGroup.childNodes[1])).to.equal(innerSVG(startEventGfx));
|
2016-06-07 08:46:45 +02:00
|
|
|
})
|
|
|
|
);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
it('should not replace non-interrupting start event while hover over another event sub process',
|
|
|
|
inject(function(dragging, elementRegistry) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var subProcess_2 = elementRegistry.get('SubProcess_2');
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, subProcess_2, { x: 350, y: 120 });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var context = dragging.context().data.context;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
// check if the visual representation remains a non interrupting message start event
|
|
|
|
var startEventGfx = getGfx({
|
|
|
|
type: 'bpmn:StartEvent',
|
|
|
|
isInterrupting: false,
|
|
|
|
eventDefinitionType: 'bpmn:MessageEventDefinition'
|
|
|
|
});
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(innerSVG(context.dragGroup.childNodes[0])).to.equal(innerSVG(startEventGfx));
|
2016-06-07 08:46:45 +02:00
|
|
|
})
|
|
|
|
);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
it('should replace non-interrupting start event while hover over regular sub process',
|
|
|
|
inject(function(dragging, elementRegistry) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var subProcess_3 = elementRegistry.get('SubProcess_3');
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
moveShape(startEvent_1, subProcess_3, { x: 600, y: 120 });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var context = dragging.context().data.context;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
// check if the visual representation remains a non interrupting message start event
|
|
|
|
var startEventGfx = getGfx({ type: 'bpmn:StartEvent' });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(innerSVG(context.dragGroup.childNodes[1])).to.equal(innerSVG(startEventGfx));
|
2016-06-07 08:46:45 +02:00
|
|
|
})
|
|
|
|
);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
it('should replace all non-interrupting start events in a selection of multiple elements',
|
|
|
|
inject(function(move, dragging, elementRegistry, selection) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var startEvent_2 = elementRegistry.get('StartEvent_2'),
|
|
|
|
startEvent_3 = elementRegistry.get('StartEvent_3');
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
selection.select([ startEvent_1, startEvent_2, startEvent_3 ]);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
moveShape(startEvent_1, rootElement, { x: 150, y: 250 });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var context = dragging.context().data.context;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
// check if the visual replacements are blank interrupting start events
|
|
|
|
var startEventGfx = getGfx({ type: 'bpmn:StartEvent' });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(innerSVG(context.dragGroup.childNodes[1])).to.equal(innerSVG(startEventGfx));
|
|
|
|
expect(innerSVG(context.dragGroup.childNodes[3])).to.equal(innerSVG(startEventGfx));
|
|
|
|
expect(innerSVG(context.dragGroup.childNodes[4])).to.equal(innerSVG(startEventGfx));
|
2016-06-07 08:46:45 +02:00
|
|
|
})
|
|
|
|
);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
|
|
|
|
2018-03-22 12:43:36 +01:00
|
|
|
it('should not replace any non-interrupting start events in a selection of multiple elements',
|
2015-08-17 16:43:15 +02:00
|
|
|
inject(function(move, dragging, elementRegistry, selection) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var startEvent_2 = elementRegistry.get('StartEvent_2'),
|
|
|
|
startEvent_3 = elementRegistry.get('StartEvent_3'),
|
|
|
|
subProcess_2 = elementRegistry.get('SubProcess_2');
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var messageStartEventGfx = getGfx({
|
|
|
|
type: 'bpmn:StartEvent',
|
|
|
|
isInterrupting: false,
|
|
|
|
eventDefinitionType: 'bpmn:MessageEventDefinition'
|
|
|
|
});
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var timerStartEventGfx = getGfx({
|
|
|
|
type: 'bpmn:StartEvent',
|
|
|
|
isInterrupting: false,
|
|
|
|
eventDefinitionType: 'bpmn:TimerEventDefinition'
|
|
|
|
});
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var startEventGfx = getGfx({ type: 'bpmn:StartEvent' });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
selection.select([ startEvent_1, startEvent_2, startEvent_3 ]);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
moveShape(startEvent_1, subProcess_2, { x: 350, y: 120 });
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var context = dragging.context().data.context;
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
2016-09-14 08:18:56 +02:00
|
|
|
expect(innerSVG(context.dragGroup.childNodes[0])).to.equal(innerSVG(messageStartEventGfx));
|
|
|
|
expect(innerSVG(context.dragGroup.childNodes[1])).to.equal(innerSVG(startEventGfx));
|
|
|
|
expect(innerSVG(context.dragGroup.childNodes[2])).to.equal(innerSVG(timerStartEventGfx));
|
2016-06-07 08:46:45 +02:00
|
|
|
})
|
|
|
|
);
|
2015-08-17 16:43:15 +02:00
|
|
|
|
2015-09-01 17:57:32 +02:00
|
|
|
|
|
|
|
it('should not throw TypeError when moving boundaryEvent',
|
|
|
|
inject(function(move, dragging, elementRegistry, elementFactory, selection, modeling) {
|
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// given
|
|
|
|
var startEvent_1 = elementRegistry.get('StartEvent_1'),
|
|
|
|
subProcess_3 = elementRegistry.get('SubProcess_3');
|
2015-09-01 17:57:32 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var intermediateEvent = elementFactory.createShape({ type: 'bpmn:IntermediateThrowEvent' });
|
2015-09-01 17:57:32 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
var boundaryEvent = modeling.createShape(intermediateEvent, { x: 550, y: 180 }, subProcess_3, true);
|
2015-09-01 17:57:32 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// when
|
|
|
|
selection.select([ startEvent_1 ]);
|
2015-09-01 17:57:32 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
moveShape(boundaryEvent, subProcess_3, { x: 580, y: 210 });
|
|
|
|
moveShape(boundaryEvent, subProcess_3, { x: 580, y: 180 });
|
2015-09-01 17:57:32 +02:00
|
|
|
|
2016-06-07 08:46:45 +02:00
|
|
|
// then
|
|
|
|
// expect not to throw TypeError: Cannot read property 'oldElementId' of undefined
|
|
|
|
})
|
|
|
|
);
|
2015-09-01 17:57:32 +02:00
|
|
|
|
2015-08-17 16:43:15 +02:00
|
|
|
});
|