mirror of
https://github.com/sartography/bpmn-js.git
synced 2025-01-10 00:55:51 +00:00
d3449ca87c
* use ES6 import / export * UTILS: export individual utilities * TESTS: localize TestHelper includes BREAKING CHANGE: * all utilities export independent functions * library sources got ported to ES6. You must now use a ES module bundler such as Browserify + babelify or Webpack to consume this library (or parts of it).
130 lines
3.1 KiB
JavaScript
130 lines
3.1 KiB
JavaScript
'use strict';
|
|
|
|
import inherits from 'inherits';
|
|
|
|
import EditorActions from 'diagram-js/lib/features/editor-actions/EditorActions';
|
|
|
|
import { filter } from 'min-dash';
|
|
|
|
import { is } from '../../util/ModelUtil';
|
|
|
|
import {
|
|
getBBox
|
|
} from 'diagram-js/lib/util/Elements';
|
|
|
|
|
|
/**
|
|
* Registers and executes BPMN specific editor actions.
|
|
*/
|
|
export default function BpmnEditorActions(
|
|
injector, canvas, elementRegistry,
|
|
selection, spaceTool, lassoTool,
|
|
handTool, globalConnect, distributeElements,
|
|
alignElements, directEditing, searchPad,
|
|
modeling) {
|
|
|
|
injector.invoke(EditorActions, this);
|
|
|
|
this.register({
|
|
selectElements: function() {
|
|
// select all elements except for the invisible
|
|
// root element
|
|
var rootElement = canvas.getRootElement();
|
|
|
|
var elements = elementRegistry.filter(function(element) {
|
|
return element !== rootElement;
|
|
});
|
|
|
|
selection.select(elements);
|
|
|
|
return elements;
|
|
},
|
|
spaceTool: function() {
|
|
spaceTool.toggle();
|
|
},
|
|
lassoTool: function() {
|
|
lassoTool.toggle();
|
|
},
|
|
handTool: function() {
|
|
handTool.toggle();
|
|
},
|
|
globalConnectTool: function() {
|
|
globalConnect.toggle();
|
|
},
|
|
distributeElements: function(opts) {
|
|
var currentSelection = selection.get(),
|
|
type = opts.type;
|
|
|
|
if (currentSelection.length) {
|
|
distributeElements.trigger(currentSelection, type);
|
|
}
|
|
},
|
|
alignElements: function(opts) {
|
|
var currentSelection = selection.get(),
|
|
aligneableElements = [],
|
|
type = opts.type;
|
|
|
|
if (currentSelection.length) {
|
|
aligneableElements = filter(currentSelection, function(element) {
|
|
return !is(element, 'bpmn:Lane');
|
|
});
|
|
|
|
alignElements.trigger(aligneableElements, type);
|
|
}
|
|
},
|
|
setColor: function(opts) {
|
|
var currentSelection = selection.get();
|
|
|
|
if (currentSelection.length) {
|
|
modeling.setColor(currentSelection, opts);
|
|
}
|
|
},
|
|
directEditing: function() {
|
|
var currentSelection = selection.get();
|
|
|
|
if (currentSelection.length) {
|
|
directEditing.activate(currentSelection[0]);
|
|
}
|
|
},
|
|
find: function() {
|
|
searchPad.toggle();
|
|
},
|
|
moveToOrigin: function() {
|
|
var rootElement = canvas.getRootElement(),
|
|
boundingBox,
|
|
elements;
|
|
|
|
if (is(rootElement, 'bpmn:Collaboration')) {
|
|
elements = elementRegistry.filter(function(element) {
|
|
return is(element.parent, 'bpmn:Collaboration');
|
|
});
|
|
} else {
|
|
elements = elementRegistry.filter(function(element) {
|
|
return element !== rootElement && !is(element.parent, 'bpmn:SubProcess');
|
|
});
|
|
}
|
|
|
|
boundingBox = getBBox(elements);
|
|
|
|
modeling.moveElements(elements, { x: -boundingBox.x, y: -boundingBox.y }, rootElement);
|
|
}
|
|
});
|
|
}
|
|
|
|
inherits(BpmnEditorActions, EditorActions);
|
|
|
|
BpmnEditorActions.$inject = [
|
|
'injector',
|
|
'canvas',
|
|
'elementRegistry',
|
|
'selection',
|
|
'spaceTool',
|
|
'lassoTool',
|
|
'handTool',
|
|
'globalConnect',
|
|
'distributeElements',
|
|
'alignElements',
|
|
'directEditing',
|
|
'searchPad',
|
|
'modeling'
|
|
]; |