mirror of
https://github.com/sartography/bpmn-js.git
synced 2025-01-14 02:54:37 +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
188 lines
4.5 KiB
JavaScript
188 lines
4.5 KiB
JavaScript
'use strict';
|
|
|
|
var inherits = require('inherits');
|
|
|
|
var BaseModeling = require('diagram-js/lib/features/modeling/Modeling');
|
|
|
|
var UpdatePropertiesHandler = require('./cmd/UpdatePropertiesHandler'),
|
|
UpdateCanvasRootHandler = require('./cmd/UpdateCanvasRootHandler'),
|
|
AddLaneHandler = require('./cmd/AddLaneHandler'),
|
|
SplitLaneHandler = require('./cmd/SplitLaneHandler'),
|
|
ResizeLaneHandler = require('./cmd/ResizeLaneHandler'),
|
|
UpdateFlowNodeRefsHandler = require('./cmd/UpdateFlowNodeRefsHandler'),
|
|
IdClaimHandler = require('./cmd/IdClaimHandler'),
|
|
SetColorHandler = require('./cmd/SetColorHandler');
|
|
|
|
var UpdateLabelHandler = require('../label-editing/cmd/UpdateLabelHandler');
|
|
|
|
|
|
/**
|
|
* BPMN 2.0 modeling features activator
|
|
*
|
|
* @param {EventBus} eventBus
|
|
* @param {ElementFactory} elementFactory
|
|
* @param {CommandStack} commandStack
|
|
* @param {BpmnRules} bpmnRules
|
|
*/
|
|
function Modeling(eventBus, elementFactory, commandStack, bpmnRules) {
|
|
BaseModeling.call(this, eventBus, elementFactory, commandStack);
|
|
|
|
this._bpmnRules = bpmnRules;
|
|
}
|
|
|
|
inherits(Modeling, BaseModeling);
|
|
|
|
Modeling.$inject = [ 'eventBus', 'elementFactory', 'commandStack', 'bpmnRules' ];
|
|
|
|
module.exports = Modeling;
|
|
|
|
|
|
Modeling.prototype.getHandlers = function() {
|
|
var handlers = BaseModeling.prototype.getHandlers.call(this);
|
|
|
|
handlers['element.updateProperties'] = UpdatePropertiesHandler;
|
|
handlers['canvas.updateRoot'] = UpdateCanvasRootHandler;
|
|
handlers['lane.add'] = AddLaneHandler;
|
|
handlers['lane.resize'] = ResizeLaneHandler;
|
|
handlers['lane.split'] = SplitLaneHandler;
|
|
handlers['lane.updateRefs'] = UpdateFlowNodeRefsHandler;
|
|
handlers['id.updateClaim'] = IdClaimHandler;
|
|
handlers['element.setColor'] = SetColorHandler;
|
|
handlers['element.updateLabel'] = UpdateLabelHandler;
|
|
|
|
return handlers;
|
|
};
|
|
|
|
|
|
Modeling.prototype.updateLabel = function(element, newLabel, newBounds) {
|
|
this._commandStack.execute('element.updateLabel', {
|
|
element: element,
|
|
newLabel: newLabel,
|
|
newBounds: newBounds
|
|
});
|
|
};
|
|
|
|
|
|
Modeling.prototype.connect = function(source, target, attrs, hints) {
|
|
|
|
var bpmnRules = this._bpmnRules;
|
|
|
|
if (!attrs) {
|
|
attrs = bpmnRules.canConnect(source, target);
|
|
}
|
|
|
|
if (!attrs) {
|
|
return;
|
|
}
|
|
|
|
return this.createConnection(source, target, attrs, source.parent, hints);
|
|
};
|
|
|
|
|
|
Modeling.prototype.updateProperties = function(element, properties) {
|
|
this._commandStack.execute('element.updateProperties', {
|
|
element: element,
|
|
properties: properties
|
|
});
|
|
};
|
|
|
|
Modeling.prototype.resizeLane = function(laneShape, newBounds, balanced) {
|
|
this._commandStack.execute('lane.resize', {
|
|
shape: laneShape,
|
|
newBounds: newBounds,
|
|
balanced: balanced
|
|
});
|
|
};
|
|
|
|
Modeling.prototype.addLane = function(targetLaneShape, location) {
|
|
var context = {
|
|
shape: targetLaneShape,
|
|
location: location
|
|
};
|
|
|
|
this._commandStack.execute('lane.add', context);
|
|
|
|
return context.newLane;
|
|
};
|
|
|
|
Modeling.prototype.splitLane = function(targetLane, count) {
|
|
this._commandStack.execute('lane.split', {
|
|
shape: targetLane,
|
|
count: count
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Transform the current diagram into a collaboration.
|
|
*
|
|
* @return {djs.model.Root} the new root element
|
|
*/
|
|
Modeling.prototype.makeCollaboration = function() {
|
|
|
|
var collaborationElement = this._create('root', {
|
|
type: 'bpmn:Collaboration'
|
|
});
|
|
|
|
var context = {
|
|
newRoot: collaborationElement
|
|
};
|
|
|
|
this._commandStack.execute('canvas.updateRoot', context);
|
|
|
|
return collaborationElement;
|
|
};
|
|
|
|
Modeling.prototype.updateLaneRefs = function(flowNodeShapes, laneShapes) {
|
|
|
|
this._commandStack.execute('lane.updateRefs', {
|
|
flowNodeShapes: flowNodeShapes,
|
|
laneShapes: laneShapes
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Transform the current diagram into a process.
|
|
*
|
|
* @return {djs.model.Root} the new root element
|
|
*/
|
|
Modeling.prototype.makeProcess = function() {
|
|
|
|
var processElement = this._create('root', {
|
|
type: 'bpmn:Process'
|
|
});
|
|
|
|
var context = {
|
|
newRoot: processElement
|
|
};
|
|
|
|
this._commandStack.execute('canvas.updateRoot', context);
|
|
};
|
|
|
|
|
|
Modeling.prototype.claimId = function(id, moddleElement) {
|
|
this._commandStack.execute('id.updateClaim', {
|
|
id: id,
|
|
element: moddleElement,
|
|
claiming: true
|
|
});
|
|
};
|
|
|
|
|
|
Modeling.prototype.unclaimId = function(id, moddleElement) {
|
|
this._commandStack.execute('id.updateClaim', {
|
|
id: id,
|
|
element: moddleElement
|
|
});
|
|
};
|
|
|
|
Modeling.prototype.setColor = function(elements, colors) {
|
|
if (!elements.length) {
|
|
elements = [ elements ];
|
|
}
|
|
|
|
this._commandStack.execute('element.setColor', {
|
|
elements: elements,
|
|
colors: colors
|
|
});
|
|
};
|