2017-06-27 09:37:58 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/* global bootstrapViewer, inject */
|
|
|
|
|
2017-10-22 22:23:51 +02:00
|
|
|
var pick = require('lodash/object/pick');
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 11:41:21 +01:00
|
|
|
var labelEditingModule = require('lib/features/label-editing'),
|
|
|
|
coreModule = require('lib/core'),
|
2017-06-27 09:37:58 +02:00
|
|
|
draggingModule = require('diagram-js/lib/features/dragging'),
|
2018-01-24 20:25:28 +01:00
|
|
|
modelingModule = require('lib/features/modeling');
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2017-10-22 22:23:51 +02:00
|
|
|
|
2017-06-27 09:37:58 +02:00
|
|
|
describe('features - label-editing preview', function() {
|
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
var diagramXML = require('./LabelEditing.bpmn');
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
beforeEach(bootstrapViewer(diagramXML, {
|
|
|
|
modules: [
|
|
|
|
labelEditingModule,
|
|
|
|
coreModule,
|
|
|
|
draggingModule,
|
|
|
|
modelingModule
|
|
|
|
]
|
|
|
|
}));
|
2017-06-27 09:37:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
describe('activate', function() {
|
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
it('[external labels AND text annotations ] should add marker to hide element on activate', inject(
|
|
|
|
function(directEditing, elementRegistry) {
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// given
|
|
|
|
var textAnnotation = elementRegistry.get('TextAnnotation_1');
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// when
|
|
|
|
directEditing.activate(textAnnotation);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// then
|
|
|
|
var gfx = elementRegistry.getGraphics(textAnnotation);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
expect(gfx.classList.contains('djs-element-hidden')).to.be.true;
|
|
|
|
}
|
|
|
|
));
|
2017-06-27 09:37:58 +02:00
|
|
|
|
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
it('[internal labels] should add marker to hide label on activate', inject(
|
|
|
|
function(directEditing, elementRegistry) {
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1');
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// when
|
|
|
|
directEditing.activate(task);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// then
|
|
|
|
var gfx = elementRegistry.getGraphics(task);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
expect(gfx.classList.contains('djs-label-hidden')).to.be.true;
|
|
|
|
}
|
|
|
|
));
|
2017-06-27 09:37:58 +02:00
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('resize', function() {
|
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
it('[text annotations] should resize preview on resize', inject(
|
|
|
|
function(directEditing, elementRegistry, eventBus, labelEditingPreview) {
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// given
|
|
|
|
var textAnnotation = elementRegistry.get('TextAnnotation_1');
|
|
|
|
directEditing.activate(textAnnotation);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// when
|
|
|
|
eventBus.fire('directEditing.resize', {
|
|
|
|
width: 200,
|
|
|
|
height: 200,
|
|
|
|
dx: 100,
|
|
|
|
dy: 100
|
|
|
|
});
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// then
|
|
|
|
var bounds = bbox(labelEditingPreview.path);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
expect(bounds).to.eql({ x: 0, y: 0, width: 10, height: 300 });
|
|
|
|
}
|
|
|
|
));
|
2017-06-27 09:37:58 +02:00
|
|
|
|
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
it('[text annotations] should resize preview below 0', inject(
|
|
|
|
function(directEditing, elementRegistry, eventBus, labelEditingPreview) {
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// given
|
|
|
|
var textAnnotation = elementRegistry.get('TextAnnotation_1');
|
|
|
|
directEditing.activate(textAnnotation);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// when
|
|
|
|
eventBus.fire('directEditing.resize', {
|
|
|
|
width: 200,
|
|
|
|
height: 200,
|
|
|
|
dx: -300,
|
|
|
|
dy: -300
|
|
|
|
});
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// then
|
|
|
|
var bounds = bbox(labelEditingPreview.path);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
expect(bounds).to.eql({ x: 0, y: 0, width: 10, height: 0 });
|
|
|
|
}
|
|
|
|
));
|
2017-06-27 09:37:58 +02:00
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('complete/cancel', function() {
|
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
it('[external labels AND text annotations] should remove marker to hide element on complete', inject(
|
|
|
|
function(directEditing, elementRegistry) {
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// given
|
|
|
|
var textAnnotation = elementRegistry.get('TextAnnotation_1');
|
|
|
|
directEditing.activate(textAnnotation);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// when
|
|
|
|
directEditing.complete();
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// then
|
|
|
|
var gfx = elementRegistry.getGraphics(textAnnotation);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
expect(gfx.classList.contains('djs-element-hidden')).to.be.false;
|
|
|
|
}
|
|
|
|
));
|
2017-06-27 09:37:58 +02:00
|
|
|
|
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
it('[internal labels] should remove marker to hide label on complete', inject(
|
|
|
|
function(directEditing, elementRegistry) {
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// given
|
|
|
|
var task = elementRegistry.get('Task_1');
|
|
|
|
directEditing.activate(task);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// when
|
|
|
|
directEditing.complete();
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// then
|
|
|
|
var gfx = elementRegistry.getGraphics(task);
|
2017-06-27 09:37:58 +02:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
expect(gfx.classList.contains('djs-label-hidden')).to.be.false;
|
|
|
|
}
|
|
|
|
));
|
2017-06-27 09:37:58 +02:00
|
|
|
|
|
|
|
});
|
2017-10-22 22:23:51 +02:00
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function bbox(el) {
|
|
|
|
return pick(el.getBBox(), [ 'x', 'y', 'width', 'height' ]);
|
|
|
|
}
|