mirror of
https://github.com/sartography/bpmn-js.git
synced 2025-01-10 17:16:02 +00:00
f1daf4841f
This fixes a bug where Modeling#updateLabel would not work on text annotations, because these need to have labels pre-configured. * Modeling#updateLabel now takes the (optional) newBounds * newBounds must now explicitly be passed to trigger resize for text annotations * newBounds is _only_ passed for text annotations via LabelEditingProvider (it was discarded before anyway) * lib/features/label-editing did not depend on lib/features/modeling for historical reasons. It now uses the offical #updateLabel API provided by Modeling * Localize test diagrams Closes #753
160 lines
3.8 KiB
JavaScript
160 lines
3.8 KiB
JavaScript
'use strict';
|
|
|
|
/* global bootstrapModeler, inject */
|
|
|
|
var modelingModule = require('lib/features/modeling'),
|
|
coreModule = require('lib/core');
|
|
|
|
|
|
describe('features/modeling - update label', function() {
|
|
|
|
var diagramXML = require('./UpdateLabel.bpmn');
|
|
|
|
beforeEach(bootstrapModeler(diagramXML, {
|
|
modules: [
|
|
coreModule,
|
|
modelingModule
|
|
]
|
|
}));
|
|
|
|
|
|
it('should change name of start event', inject(
|
|
function(modeling, elementRegistry, eventBus) {
|
|
|
|
// given
|
|
var startEvent_1 = elementRegistry.get('StartEvent_1');
|
|
|
|
// when
|
|
modeling.updateLabel(startEvent_1, 'bar');
|
|
|
|
// then
|
|
expect(startEvent_1.businessObject.name).to.equal('bar');
|
|
expect(startEvent_1.label.hidden).to.be.false;
|
|
}
|
|
));
|
|
|
|
|
|
it('should change name of start event with hidden label', inject(
|
|
function(modeling, elementRegistry) {
|
|
|
|
// given
|
|
var startEvent_2 = elementRegistry.get('StartEvent_2');
|
|
|
|
// when
|
|
modeling.updateLabel(startEvent_2, 'bar');
|
|
|
|
// then
|
|
expect(startEvent_2.businessObject.name).to.equal('bar');
|
|
expect(startEvent_2.label.hidden).to.be.false;
|
|
}
|
|
));
|
|
|
|
|
|
it('should hide label when setting empty string', inject(
|
|
function(modeling, elementRegistry) {
|
|
|
|
// given
|
|
var startEvent_1 = elementRegistry.get('StartEvent_1');
|
|
|
|
// when
|
|
modeling.updateLabel(startEvent_1, '');
|
|
|
|
// then
|
|
expect(startEvent_1.businessObject.name).to.equal('');
|
|
expect(startEvent_1.label.hidden).to.be.true;
|
|
}
|
|
));
|
|
|
|
|
|
it('should change name of start event when editing label', inject(
|
|
function(modeling, elementRegistry) {
|
|
|
|
// given
|
|
var startEvent_1 = elementRegistry.get('StartEvent_1');
|
|
var startEvent_1_label = elementRegistry.get('StartEvent_1_label');
|
|
|
|
// when
|
|
modeling.updateLabel(startEvent_1_label, 'bar');
|
|
|
|
// then
|
|
expect(startEvent_1.businessObject.name).to.equal('bar');
|
|
expect(startEvent_1.label.hidden).to.be.false;
|
|
}
|
|
));
|
|
|
|
|
|
it('should change name of task', inject(function(modeling, elementRegistry) {
|
|
|
|
// given
|
|
var task_1 = elementRegistry.get('Task_1');
|
|
|
|
// when
|
|
modeling.updateLabel(task_1, 'foo');
|
|
|
|
// then
|
|
expect(task_1.businessObject.name).to.equal('foo');
|
|
expect(task_1.label).to.be.undefined;
|
|
}));
|
|
|
|
|
|
it('should change text annotation text and bounds', inject(
|
|
function(modeling, elementRegistry) {
|
|
|
|
// given
|
|
var element = elementRegistry.get('TextAnnotation_1');
|
|
|
|
var newBounds = { x: 100, y: 100, width: 100, height: 30 };
|
|
|
|
// when
|
|
modeling.updateLabel(element, 'bar', newBounds);
|
|
|
|
// then
|
|
expect(element.businessObject.text).to.equal('bar');
|
|
expect(element).to.have.bounds(newBounds);
|
|
}
|
|
));
|
|
|
|
|
|
it('should propertly fire events.changed after event name change', inject(
|
|
function(modeling, elementRegistry, eventBus) {
|
|
|
|
// given
|
|
var startEvent_1 = elementRegistry.get('StartEvent_1');
|
|
|
|
var changedEvent;
|
|
|
|
eventBus.on('elements.changed', function(event) {
|
|
changedEvent = event;
|
|
});
|
|
|
|
// when
|
|
modeling.updateLabel(startEvent_1, 'foo');
|
|
|
|
// then
|
|
expect(changedEvent.elements).to.include(startEvent_1);
|
|
}
|
|
));
|
|
|
|
|
|
it('should propertly fire events.changed after event label change', inject(
|
|
function(modeling, elementRegistry, eventBus) {
|
|
|
|
// given
|
|
var startEvent_1 = elementRegistry.get('StartEvent_1');
|
|
var startEvent_1_label = elementRegistry.get('StartEvent_1_label');
|
|
|
|
var changedEvent;
|
|
|
|
eventBus.on('elements.changed', function(event) {
|
|
changedEvent = event;
|
|
});
|
|
|
|
// when
|
|
modeling.updateLabel(startEvent_1_label, 'foo');
|
|
|
|
// then
|
|
expect(changedEvent.elements).to.include(startEvent_1);
|
|
}
|
|
));
|
|
|
|
}); |