2018-04-02 21:01:53 +02:00
|
|
|
import {
|
|
|
|
setLabel,
|
|
|
|
getLabel
|
|
|
|
} from '../LabelUtil';
|
2014-06-17 11:53:07 +02:00
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
import {
|
2018-04-30 11:06:26 +02:00
|
|
|
getExternalLabelMid,
|
|
|
|
isLabelExternal,
|
|
|
|
hasExternalLabel,
|
|
|
|
isLabel
|
2018-04-02 21:01:53 +02:00
|
|
|
} from '../../../util/LabelUtil';
|
2017-02-13 13:47:00 +01:00
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
import {
|
2022-01-18 16:23:54 +01:00
|
|
|
getDi,
|
2018-04-02 21:01:53 +02:00
|
|
|
is
|
|
|
|
} from '../../../util/ModelUtil';
|
2017-02-13 13:47:00 +01:00
|
|
|
|
|
|
|
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
|
|
|
*/
|
2022-01-18 16:23:54 +01:00
|
|
|
export default function UpdateLabelHandler(modeling, textRenderer, bpmnFactory) {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an empty `diLabel` attribute for embedded labels.
|
|
|
|
*
|
|
|
|
* @param {djs.model.Base} element
|
|
|
|
* @param {string} text
|
|
|
|
*/
|
|
|
|
function ensureInternalLabelDi(element, text) {
|
|
|
|
if (isLabelExternal(element)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var di = getDi(element);
|
|
|
|
|
|
|
|
if (text && !di.label) {
|
|
|
|
di.label = bpmnFactory.create('bpmndi:BPMNLabel');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!text && di.label) {
|
|
|
|
di.label = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
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
|
2020-04-03 15:51:45 +02:00
|
|
|
* @param {string} text
|
2016-03-03 17:09:43 +01:00
|
|
|
*/
|
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;
|
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
setLabel(label, text, labelTarget !== label);
|
2016-03-03 17:09:43 +01:00
|
|
|
|
2022-01-18 16:23:54 +01:00
|
|
|
ensureInternalLabelDi(element, text);
|
|
|
|
|
2016-03-03 17:09:43 +01:00
|
|
|
return [ label, labelTarget ];
|
2014-06-11 15:08:45 +02:00
|
|
|
}
|
|
|
|
|
2018-04-30 11:06:26 +02:00
|
|
|
function preExecute(ctx) {
|
|
|
|
var element = ctx.element,
|
|
|
|
businessObject = element.businessObject,
|
|
|
|
newLabel = ctx.newLabel;
|
|
|
|
|
|
|
|
if (!isLabel(element)
|
|
|
|
&& isLabelExternal(element)
|
|
|
|
&& !hasExternalLabel(element)
|
2018-06-08 16:01:40 +02:00
|
|
|
&& !isEmptyText(newLabel)) {
|
2018-04-30 11:06:26 +02:00
|
|
|
|
|
|
|
// create label
|
|
|
|
var paddingTop = 7;
|
|
|
|
|
|
|
|
var labelCenter = getExternalLabelMid(element);
|
|
|
|
|
|
|
|
labelCenter = {
|
|
|
|
x: labelCenter.x,
|
|
|
|
y: labelCenter.y + paddingTop
|
|
|
|
};
|
|
|
|
|
|
|
|
modeling.createLabel(element, labelCenter, {
|
|
|
|
id: businessObject.id + '_label',
|
2021-08-06 10:45:10 +02:00
|
|
|
businessObject: businessObject,
|
|
|
|
di: element.di
|
2018-04-30 11:06:26 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-06-11 15:08:45 +02:00
|
|
|
function execute(ctx) {
|
2018-04-02 21:01:53 +02:00
|
|
|
ctx.oldLabel = 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,
|
2017-06-27 09:37:58 +02:00
|
|
|
label = element.label || element,
|
2018-04-30 11:06:26 +02:00
|
|
|
newLabel = ctx.newLabel,
|
2018-06-08 16:01:40 +02:00
|
|
|
newBounds = ctx.newBounds,
|
|
|
|
hints = ctx.hints || {};
|
2017-02-13 13:47:00 +01:00
|
|
|
|
2020-03-27 23:55:44 +01:00
|
|
|
// ignore internal labels for elements except text annotations
|
|
|
|
if (!isLabel(label) && !is(label, 'bpmn:TextAnnotation')) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-06-08 16:01:40 +02:00
|
|
|
if (isLabel(label) && isEmptyText(newLabel)) {
|
|
|
|
|
|
|
|
if (hints.removeShape !== false) {
|
|
|
|
modeling.removeShape(label, { unsetLabel: false });
|
|
|
|
}
|
2018-04-30 11:06:26 +02:00
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-05-22 08:45:12 +02:00
|
|
|
var text = getLabel(label);
|
2017-02-13 13:47:00 +01:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// resize element based on label _or_ pre-defined bounds
|
|
|
|
if (typeof newBounds === 'undefined') {
|
2018-06-13 09:01:16 +02:00
|
|
|
newBounds = textRenderer.getExternalLabelBounds(label, text);
|
2018-01-24 20:25:28 +01:00
|
|
|
}
|
2017-02-13 13:47:00 +01:00
|
|
|
|
2018-01-24 20:25:28 +01:00
|
|
|
// setting newBounds to false or _null_ will
|
|
|
|
// disable the postExecute resize operation
|
|
|
|
if (newBounds) {
|
|
|
|
modeling.resizeShape(label, newBounds, NULL_DIMENSIONS);
|
|
|
|
}
|
2017-02-13 13:47:00 +01:00
|
|
|
}
|
|
|
|
|
2016-03-15 15:03:11 +01:00
|
|
|
// API
|
2016-05-18 07:54:58 +02:00
|
|
|
|
2018-04-30 11:06:26 +02:00
|
|
|
this.preExecute = preExecute;
|
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
|
|
|
}
|
|
|
|
|
2018-05-24 13:42:40 +02:00
|
|
|
UpdateLabelHandler.$inject = [
|
|
|
|
'modeling',
|
2022-01-18 16:23:54 +01:00
|
|
|
'textRenderer',
|
|
|
|
'bpmnFactory'
|
2018-06-08 16:01:40 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
|
// helpers ///////////////////////
|
|
|
|
|
|
|
|
function isEmptyText(label) {
|
|
|
|
return !label || !label.trim();
|
|
|
|
}
|