2014-07-30 16:07:43 +02:00
|
|
|
'use strict';
|
|
|
|
|
2015-07-15 17:22:19 +02:00
|
|
|
var TestHelper = require('../../../TestHelper');
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-08-05 08:17:22 +02:00
|
|
|
/* global bootstrapModeler, inject */
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
|
2014-08-01 07:16:59 +02:00
|
|
|
var modelingModule = require('../../../../lib/features/modeling'),
|
2014-10-30 12:06:43 +01:00
|
|
|
coreModule = require('../../../../lib/core');
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
|
|
|
|
describe('features/modeling - move shape', function() {
|
|
|
|
|
2015-03-31 14:17:15 +02:00
|
|
|
var diagramXML = require('../../../fixtures/bpmn/simple.bpmn');
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-10-30 12:06:43 +01:00
|
|
|
var testModules = [ coreModule, modelingModule ];
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-08-05 08:17:22 +02:00
|
|
|
beforeEach(bootstrapModeler(diagramXML, { modules: testModules }));
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
|
2014-11-27 11:55:38 +01:00
|
|
|
describe('shape', function() {
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2015-07-15 17:22:19 +02:00
|
|
|
it('should move', inject(function(elementRegistry, modeling, bpmnFactory) {
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
// given
|
2014-11-17 17:36:22 +01:00
|
|
|
var startEventElement = elementRegistry.get('StartEvent_1'),
|
2014-07-31 15:46:55 +02:00
|
|
|
startEvent = startEventElement.businessObject;
|
|
|
|
|
2014-11-17 17:36:22 +01:00
|
|
|
var sequenceFlowElement = elementRegistry.get('SequenceFlow_1'),
|
2014-07-31 15:46:55 +02:00
|
|
|
sequenceFlow = sequenceFlowElement.businessObject;
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
var oldPosition = {
|
2014-07-31 15:46:55 +02:00
|
|
|
x: startEventElement.x,
|
|
|
|
y: startEventElement.y
|
2014-07-30 16:07:43 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
// when
|
2014-08-02 16:38:40 +02:00
|
|
|
modeling.moveShape(startEventElement, { x: 0, y: 50 });
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(startEvent.di).to.have.position({
|
|
|
|
x: oldPosition.x,
|
|
|
|
y: oldPosition.y + 50
|
|
|
|
});
|
2014-07-31 15:46:55 +02:00
|
|
|
|
2015-07-29 15:11:54 +02:00
|
|
|
var newWaypoints = sequenceFlowElement.waypoints;
|
|
|
|
|
|
|
|
var expectedDiWaypoints = bpmnFactory.createDiWaypoints(newWaypoints.map(function(p) {
|
|
|
|
return { x: p.x, y: p.y };
|
|
|
|
}));
|
|
|
|
|
|
|
|
// see LayoutSpec for actual connection layouting tests
|
|
|
|
|
|
|
|
// expect di waypoints update
|
|
|
|
expect(sequenceFlow.di.waypoint).to.eql(expectedDiWaypoints);
|
2014-07-30 16:07:43 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
2014-11-27 11:55:38 +01:00
|
|
|
it('should move label', inject(function(elementRegistry, modeling) {
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
// given
|
2014-11-17 17:36:22 +01:00
|
|
|
var labelElement = elementRegistry.get('StartEvent_1_label'),
|
2014-07-31 15:46:55 +02:00
|
|
|
startEvent = labelElement.businessObject;
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
var oldPosition = {
|
2014-07-31 15:46:55 +02:00
|
|
|
x: labelElement.x,
|
|
|
|
y: labelElement.y
|
2014-07-30 16:07:43 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
// when
|
2014-08-02 16:38:40 +02:00
|
|
|
modeling.moveShape(labelElement, { x: 0, y: 50 });
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(startEvent.di.label).to.have.position({
|
|
|
|
x: oldPosition.x,
|
|
|
|
y: oldPosition.y + 50
|
|
|
|
});
|
2014-07-30 16:07:43 +02:00
|
|
|
}));
|
|
|
|
|
2014-09-11 17:22:59 +02:00
|
|
|
|
2014-11-27 11:55:38 +01:00
|
|
|
it('should move label to new parent', inject(function(elementRegistry, modeling) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var startEventElement = elementRegistry.get('StartEvent_1'),
|
|
|
|
labelElement = elementRegistry.get('StartEvent_1_label'),
|
|
|
|
processElement = elementRegistry.get('Process_1'),
|
|
|
|
subProcessElement = elementRegistry.get('SubProcess_1'),
|
|
|
|
startEvent = labelElement.businessObject,
|
|
|
|
subProcess = subProcessElement.businessObject;
|
|
|
|
|
|
|
|
// when
|
|
|
|
modeling.moveShape(labelElement, { x: 0, y: 50 }, processElement);
|
|
|
|
|
|
|
|
// then
|
2015-07-15 17:22:19 +02:00
|
|
|
expect(labelElement.parent).to.eql(processElement);
|
2014-11-27 11:55:38 +01:00
|
|
|
|
|
|
|
// expect actual element + businessObject to be unchanged
|
2015-07-15 17:22:19 +02:00
|
|
|
expect(startEventElement.parent).to.eql(subProcessElement);
|
|
|
|
expect(startEvent.$parent).to.eql(subProcess);
|
2014-11-27 11:55:38 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
describe('undo support', function() {
|
2014-09-11 17:22:59 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
it('should undo', inject(function(elementRegistry, commandStack, modeling) {
|
2014-09-11 17:22:59 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
// given
|
|
|
|
var startEventElement = elementRegistry.get('StartEvent_1'),
|
|
|
|
startEvent = startEventElement.businessObject;
|
2014-09-11 17:22:59 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
var oldPosition = {
|
|
|
|
x: startEventElement.x,
|
|
|
|
y: startEventElement.y
|
|
|
|
};
|
2014-09-11 17:22:59 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
modeling.moveShape(startEventElement, { x: 0, y: 50 });
|
2014-09-11 17:22:59 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
// when
|
|
|
|
commandStack.undo();
|
2014-09-11 17:22:59 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(startEvent.di).to.have.position(oldPosition);
|
2014-11-28 11:38:06 +01:00
|
|
|
}));
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
it('should undo on label', inject(function(elementRegistry, commandStack, modeling) {
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
// given
|
|
|
|
var labelElement = elementRegistry.get('StartEvent_1_label'),
|
|
|
|
startEvent = labelElement.businessObject;
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
var oldPosition = {
|
|
|
|
x: labelElement.x,
|
|
|
|
y: labelElement.y
|
|
|
|
};
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
modeling.moveShape(labelElement, { x: 0, y: 50 });
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
// when
|
|
|
|
commandStack.undo();
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(startEvent.di.label).to.have.position(oldPosition);
|
2014-11-28 11:38:06 +01:00
|
|
|
}));
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
});
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
describe('redo support', function() {
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
it('should redo', inject(function(elementRegistry, commandStack, modeling) {
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
// given
|
|
|
|
var startEventElement = elementRegistry.get('StartEvent_1'),
|
|
|
|
startEvent = startEventElement.businessObject;
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
modeling.moveShape(startEventElement, { x: 0, y: 50 });
|
2014-07-30 16:07:43 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
var newPosition = {
|
|
|
|
x: startEventElement.x,
|
|
|
|
y: startEventElement.y
|
|
|
|
};
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(startEvent.di).to.have.position(newPosition);
|
2014-11-28 11:38:06 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should redo on label', inject(function(elementRegistry, commandStack, modeling) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var labelElement = elementRegistry.get('StartEvent_1_label'),
|
|
|
|
startEvent = labelElement.businessObject;
|
|
|
|
|
|
|
|
modeling.moveShape(labelElement, { x: 0, y: 50 });
|
|
|
|
|
|
|
|
var newPosition = {
|
|
|
|
x: labelElement.x,
|
|
|
|
y: labelElement.y
|
|
|
|
};
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(startEvent.di.label).to.have.position(newPosition);
|
2014-11-28 11:38:06 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
2014-07-30 16:07:43 +02:00
|
|
|
|
|
|
|
});
|
|
|
|
|
2014-07-31 15:46:55 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
describe('label suport', function() {
|
2014-07-31 15:46:55 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
it('should move label with shape', inject(function(elementRegistry, modeling) {
|
2014-07-31 15:46:55 +02:00
|
|
|
|
|
|
|
// given
|
2015-07-13 10:37:43 +02:00
|
|
|
var startEventElement = elementRegistry.get('StartEvent_1');
|
2014-07-31 15:46:55 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
var label = startEventElement.label;
|
2014-07-31 15:46:55 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
var labelPosition = {
|
|
|
|
x: label.x,
|
|
|
|
y: label.y
|
2014-07-31 15:46:55 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
// when
|
2015-08-13 10:51:52 +02:00
|
|
|
modeling.moveElements([ startEventElement ], { x: 40, y: -80 });
|
2014-07-31 15:46:55 +02:00
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(label).to.have.position({
|
|
|
|
x: labelPosition.x + 40,
|
|
|
|
y: labelPosition.y - 80
|
|
|
|
});
|
2014-07-31 15:46:55 +02:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
it('should move label with connection', inject(function(elementRegistry, modeling) {
|
2014-07-31 15:46:55 +02:00
|
|
|
|
|
|
|
// given
|
2014-11-28 11:38:06 +01:00
|
|
|
var startEventElement = elementRegistry.get('StartEvent_2'),
|
|
|
|
subProcessElement = elementRegistry.get('SubProcess_1'),
|
|
|
|
flowLabel = elementRegistry.get('SequenceFlow_3_label');
|
2014-07-31 15:46:55 +02:00
|
|
|
|
2014-11-28 11:38:06 +01:00
|
|
|
var labelPosition = {
|
|
|
|
x: flowLabel.x,
|
|
|
|
y: flowLabel.y
|
2014-07-31 15:46:55 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
// when
|
2015-08-13 10:51:52 +02:00
|
|
|
modeling.moveElements([ startEventElement, subProcessElement ], { x: 40, y: -80 });
|
2014-07-31 15:46:55 +02:00
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(flowLabel).to.have.position({
|
|
|
|
x: labelPosition.x + 40,
|
|
|
|
y: labelPosition.y - 80
|
|
|
|
});
|
2014-07-31 15:46:55 +02:00
|
|
|
}));
|
|
|
|
|
2014-11-28 13:19:57 +01:00
|
|
|
|
|
|
|
describe('undo', function() {
|
|
|
|
|
|
|
|
it('should undo label with shape', inject(function(elementRegistry, modeling, commandStack) {
|
|
|
|
|
|
|
|
// given
|
2015-07-13 10:37:43 +02:00
|
|
|
var startEventElement = elementRegistry.get('StartEvent_1');
|
2014-11-28 13:19:57 +01:00
|
|
|
|
|
|
|
var label = startEventElement.label;
|
|
|
|
|
|
|
|
var labelPosition = {
|
|
|
|
x: label.x,
|
|
|
|
y: label.y
|
|
|
|
};
|
|
|
|
|
2015-08-13 10:51:52 +02:00
|
|
|
modeling.moveElements([ startEventElement ], { x: 40, y: -80 });
|
2014-11-28 13:19:57 +01:00
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(label).to.have.position(labelPosition);
|
2014-11-28 13:19:57 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should move label with connection', inject(function(elementRegistry, modeling, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var startEventElement = elementRegistry.get('StartEvent_2'),
|
|
|
|
subProcessElement = elementRegistry.get('SubProcess_1'),
|
|
|
|
flowLabel = elementRegistry.get('SequenceFlow_3_label');
|
|
|
|
|
|
|
|
var labelPosition = {
|
|
|
|
x: flowLabel.x,
|
|
|
|
y: flowLabel.y
|
|
|
|
};
|
|
|
|
|
2015-08-13 10:51:52 +02:00
|
|
|
modeling.moveElements([ startEventElement, subProcessElement ], { x: 40, y: -80 });
|
2014-11-28 13:19:57 +01:00
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(flowLabel).to.have.position(labelPosition);
|
2014-11-28 13:19:57 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('redo', function() {
|
|
|
|
|
|
|
|
it('should redo move label with shape', inject(function(elementRegistry, modeling, commandStack) {
|
|
|
|
|
|
|
|
// given
|
2015-07-13 10:37:43 +02:00
|
|
|
var startEventElement = elementRegistry.get('StartEvent_1');
|
2014-11-28 13:19:57 +01:00
|
|
|
|
|
|
|
var label = startEventElement.label;
|
|
|
|
|
|
|
|
var labelPosition = {
|
|
|
|
x: label.x,
|
|
|
|
y: label.y
|
|
|
|
};
|
|
|
|
|
2015-08-13 10:51:52 +02:00
|
|
|
modeling.moveElements([ startEventElement ], { x: 40, y: -80 });
|
2014-11-28 13:19:57 +01:00
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(label).to.have.position({
|
|
|
|
x: labelPosition.x + 40,
|
|
|
|
y: labelPosition.y - 80
|
|
|
|
});
|
2014-11-28 13:19:57 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
it('should redo move label with connection', inject(function(elementRegistry, modeling, commandStack) {
|
|
|
|
|
|
|
|
// given
|
|
|
|
var startEventElement = elementRegistry.get('StartEvent_2'),
|
|
|
|
subProcessElement = elementRegistry.get('SubProcess_1'),
|
|
|
|
flowLabel = elementRegistry.get('SequenceFlow_3_label');
|
|
|
|
|
|
|
|
var labelPosition = {
|
|
|
|
x: flowLabel.x,
|
|
|
|
y: flowLabel.y
|
|
|
|
};
|
|
|
|
|
2015-08-13 10:51:52 +02:00
|
|
|
modeling.moveElements([ startEventElement, subProcessElement ], { x: 40, y: -80 });
|
2014-11-28 13:19:57 +01:00
|
|
|
commandStack.undo();
|
|
|
|
|
|
|
|
// when
|
|
|
|
commandStack.redo();
|
|
|
|
|
|
|
|
// then
|
2015-09-02 14:15:45 +02:00
|
|
|
expect(flowLabel).to.have.position({
|
|
|
|
x: labelPosition.x + 40,
|
|
|
|
y: labelPosition.y - 80
|
|
|
|
});
|
2014-11-28 13:19:57 +01:00
|
|
|
}));
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2014-07-31 15:46:55 +02:00
|
|
|
});
|
|
|
|
|
2014-10-27 12:07:57 +01:00
|
|
|
});
|