2014-06-11 15:08:45 +02:00
|
|
|
'use strict';
|
|
|
|
|
2014-06-17 11:53:07 +02:00
|
|
|
var LabelUtil = require('../LabelUtil');
|
|
|
|
|
2017-02-13 13:47:00 +01:00
|
|
|
var TextUtil = require('diagram-js/lib/util/Text');
|
|
|
|
|
|
|
|
var hasExternalLabel = require('../../../util/LabelUtil').hasExternalLabel;
|
|
|
|
|
|
|
|
var getBusinessObject = require('../../../util/ModelUtil').getBusinessObject;
|
|
|
|
|
|
|
|
var NULL_DIMENSIONS = {
|
|
|
|
width: 0,
|
|
|
|
height: 0
|
|
|
|
};
|
|
|
|
|
2014-06-17 11:53:07 +02:00
|
|
|
|
2014-06-11 15:08:45 +02:00
|
|
|
/**
|
2014-09-11 16:44:56 +02:00
|
|
|
* A handler that updates the text of a BPMN element.
|
2014-06-11 15:08:45 +02:00
|
|
|
*/
|
2017-02-13 13:47:00 +01:00
|
|
|
function UpdateLabelHandler(modeling) {
|
|
|
|
|
|
|
|
var textUtil = new TextUtil();
|
2016-03-03 17:09:43 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the label and return the changed elements.
|
|
|
|
*
|
|
|
|
* Element parameter can be label itself or connection (i.e. sequence flow).
|
|
|
|
*
|
|
|
|
* @param {djs.model.Base} element
|
|
|
|
* @param {String} text
|
|
|
|
*/
|
2014-06-11 15:08:45 +02:00
|
|
|
function setText(element, text) {
|
|
|
|
|
2016-03-03 17:09:43 +01:00
|
|
|
// external label if present
|
|
|
|
var label = element.label || element;
|
|
|
|
|
|
|
|
var labelTarget = element.labelTarget || element;
|
|
|
|
|
|
|
|
LabelUtil.setLabel(label, text, labelTarget !== label);
|
|
|
|
|
|
|
|
return [ label, labelTarget ];
|
2014-06-11 15:08:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function execute(ctx) {
|
2014-09-08 19:03:39 +02:00
|
|
|
ctx.oldLabel = LabelUtil.getLabel(ctx.element);
|
2014-09-11 16:44:56 +02:00
|
|
|
return setText(ctx.element, ctx.newLabel);
|
2014-06-11 15:08:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function revert(ctx) {
|
2014-09-11 16:44:56 +02:00
|
|
|
return setText(ctx.element, ctx.oldLabel);
|
2014-06-11 15:08:45 +02:00
|
|
|
}
|
|
|
|
|
2017-02-13 13:47:00 +01:00
|
|
|
function postExecute(ctx) {
|
|
|
|
var element = ctx.element,
|
|
|
|
label = element.label || element;
|
|
|
|
|
|
|
|
// ignore internal labels
|
|
|
|
if (!hasExternalLabel(element)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var text = getBusinessObject(label).name;
|
|
|
|
|
|
|
|
if (!text) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// get layouted text bounds and resize external
|
|
|
|
// external label accordingly
|
|
|
|
var newBounds = getLayoutedBounds(label, text, textUtil);
|
|
|
|
|
|
|
|
modeling.resizeShape(label, newBounds, NULL_DIMENSIONS);
|
|
|
|
}
|
|
|
|
|
2016-03-15 15:03:11 +01:00
|
|
|
// API
|
2016-05-18 07:54:58 +02:00
|
|
|
|
2014-06-11 15:08:45 +02:00
|
|
|
this.execute = execute;
|
|
|
|
this.revert = revert;
|
2017-02-13 13:47:00 +01:00
|
|
|
this.postExecute = postExecute;
|
2014-06-11 15:08:45 +02:00
|
|
|
}
|
|
|
|
|
2017-02-13 13:47:00 +01:00
|
|
|
UpdateLabelHandler.$inject = [ 'modeling' ];
|
|
|
|
|
|
|
|
module.exports = UpdateLabelHandler;
|
|
|
|
|
|
|
|
|
|
|
|
// TODO(nikku): repeating code (search for <getLayoutedBounds>)
|
|
|
|
|
|
|
|
var EXTERNAL_LABEL_STYLE = {
|
|
|
|
fontFamily: 'Arial, sans-serif',
|
|
|
|
fontSize: '11px'
|
|
|
|
};
|
|
|
|
|
|
|
|
function getLayoutedBounds(bounds, text, textUtil) {
|
|
|
|
|
|
|
|
var layoutedLabelDimensions = textUtil.getDimensions(text, {
|
|
|
|
box: {
|
|
|
|
width: 90,
|
|
|
|
height: 30,
|
|
|
|
x: bounds.width / 2 + bounds.x,
|
|
|
|
y: bounds.height / 2 + bounds.y
|
|
|
|
},
|
|
|
|
style: EXTERNAL_LABEL_STYLE
|
|
|
|
});
|
|
|
|
|
|
|
|
// resize label shape to fit label text
|
|
|
|
return {
|
|
|
|
x: Math.round(bounds.x + bounds.width / 2 - layoutedLabelDimensions.width / 2),
|
|
|
|
y: Math.round(bounds.y),
|
|
|
|
width: Math.ceil(layoutedLabelDimensions.width),
|
|
|
|
height: Math.ceil(layoutedLabelDimensions.height)
|
|
|
|
};
|
|
|
|
}
|