2018-04-02 21:01:53 +02:00
|
|
|
import inherits from 'inherits';
|
2016-06-16 13:57:32 +02:00
|
|
|
|
2018-04-02 21:01:53 +02:00
|
|
|
import CommandInterceptor from 'diagram-js/lib/command/CommandInterceptor';
|
|
|
|
|
|
|
|
import {
|
|
|
|
getBusinessObject,
|
|
|
|
is
|
|
|
|
} from '../../../util/ModelUtil';
|
|
|
|
|
|
|
|
import {
|
|
|
|
computeChildrenBBox
|
|
|
|
} from 'diagram-js/lib/features/resize/ResizeUtil';
|
2016-06-16 13:57:32 +02:00
|
|
|
|
|
|
|
|
|
|
|
var LOW_PRIORITY = 500;
|
|
|
|
|
|
|
|
|
2019-05-29 10:38:11 +02:00
|
|
|
export default function ToggleElementCollapseBehaviour(
|
|
|
|
eventBus, elementFactory, modeling,
|
|
|
|
resize) {
|
|
|
|
|
2016-06-16 13:57:32 +02:00
|
|
|
CommandInterceptor.call(this, eventBus);
|
|
|
|
|
2019-05-29 10:38:11 +02:00
|
|
|
|
2019-09-09 12:21:33 +02:00
|
|
|
function hideEmptyLabels(children) {
|
2016-06-16 13:57:32 +02:00
|
|
|
if (children.length) {
|
|
|
|
children.forEach(function(child) {
|
|
|
|
if (child.type === 'label' && !child.businessObject.name) {
|
|
|
|
child.hidden = true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-29 10:38:11 +02:00
|
|
|
function expandedBounds(shape, defaultSize) {
|
|
|
|
var children = shape.children,
|
|
|
|
newBounds = defaultSize,
|
|
|
|
visibleElements,
|
|
|
|
visibleBBox;
|
|
|
|
|
|
|
|
visibleElements = filterVisible(children).concat([ shape ]);
|
|
|
|
|
|
|
|
visibleBBox = computeChildrenBBox(visibleElements);
|
|
|
|
|
|
|
|
if (visibleBBox) {
|
2019-08-19 10:39:20 +02:00
|
|
|
|
2019-05-29 10:38:11 +02:00
|
|
|
// center to visibleBBox with max(defaultSize, childrenBounds)
|
|
|
|
newBounds.width = Math.max(visibleBBox.width, newBounds.width);
|
|
|
|
newBounds.height = Math.max(visibleBBox.height, newBounds.height);
|
|
|
|
|
|
|
|
newBounds.x = visibleBBox.x + (visibleBBox.width - newBounds.width) / 2;
|
|
|
|
newBounds.y = visibleBBox.y + (visibleBBox.height - newBounds.height) / 2;
|
|
|
|
} else {
|
2019-08-19 10:39:20 +02:00
|
|
|
|
2019-05-29 10:38:11 +02:00
|
|
|
// center to collapsed shape with defaultSize
|
|
|
|
newBounds.x = shape.x + (shape.width - newBounds.width) / 2;
|
|
|
|
newBounds.y = shape.y + (shape.height - newBounds.height) / 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
return newBounds;
|
|
|
|
}
|
|
|
|
|
|
|
|
function collapsedBounds(shape, defaultSize) {
|
|
|
|
|
|
|
|
return {
|
|
|
|
x: shape.x + (shape.width - defaultSize.width) / 2,
|
|
|
|
y: shape.y + (shape.height - defaultSize.height) / 2,
|
|
|
|
width: defaultSize.width,
|
|
|
|
height: defaultSize.height
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2016-06-16 13:57:32 +02:00
|
|
|
this.executed([ 'shape.toggleCollapse' ], LOW_PRIORITY, function(e) {
|
|
|
|
|
|
|
|
var context = e.context,
|
|
|
|
shape = context.shape;
|
|
|
|
|
|
|
|
if (!is(shape, 'bpmn:SubProcess')) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!shape.collapsed) {
|
2019-08-19 10:39:20 +02:00
|
|
|
|
2016-06-16 13:57:32 +02:00
|
|
|
// all children got made visible through djs, hide empty labels
|
2019-09-09 12:21:33 +02:00
|
|
|
hideEmptyLabels(shape.children);
|
2016-06-16 13:57:32 +02:00
|
|
|
|
|
|
|
// remove collapsed marker
|
|
|
|
getBusinessObject(shape).di.isExpanded = true;
|
|
|
|
} else {
|
2019-08-19 10:39:20 +02:00
|
|
|
|
2016-06-16 13:57:32 +02:00
|
|
|
// place collapsed marker
|
|
|
|
getBusinessObject(shape).di.isExpanded = false;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
this.reverted([ 'shape.toggleCollapse' ], LOW_PRIORITY, function(e) {
|
|
|
|
|
|
|
|
var context = e.context;
|
|
|
|
var shape = context.shape;
|
|
|
|
|
|
|
|
|
|
|
|
// revert removing/placing collapsed marker
|
|
|
|
if (!shape.collapsed) {
|
|
|
|
getBusinessObject(shape).di.isExpanded = true;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
getBusinessObject(shape).di.isExpanded = false;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
this.postExecuted([ 'shape.toggleCollapse' ], LOW_PRIORITY, function(e) {
|
|
|
|
var shape = e.context.shape,
|
|
|
|
defaultSize = elementFactory._getDefaultSize(shape),
|
|
|
|
newBounds;
|
|
|
|
|
|
|
|
if (shape.collapsed) {
|
|
|
|
|
|
|
|
// resize to default size of collapsed shapes
|
|
|
|
newBounds = collapsedBounds(shape, defaultSize);
|
|
|
|
} else {
|
|
|
|
|
|
|
|
// resize to bounds of max(visible children, defaultSize)
|
|
|
|
newBounds = expandedBounds(shape, defaultSize);
|
|
|
|
}
|
|
|
|
|
2019-04-18 13:25:53 +02:00
|
|
|
modeling.resizeShape(shape, newBounds, null, {
|
|
|
|
autoResize: shape.collapsed ? false : 'nwse'
|
|
|
|
});
|
2016-06-16 13:57:32 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inherits(ToggleElementCollapseBehaviour, CommandInterceptor);
|
|
|
|
|
|
|
|
ToggleElementCollapseBehaviour.$inject = [
|
2019-05-15 16:21:30 +02:00
|
|
|
'eventBus',
|
2019-05-29 10:38:11 +02:00
|
|
|
'elementFactory',
|
2016-06-16 13:57:32 +02:00
|
|
|
'modeling'
|
|
|
|
];
|
|
|
|
|
|
|
|
|
2019-05-29 10:38:11 +02:00
|
|
|
// helpers //////////////////////
|
2016-06-16 13:57:32 +02:00
|
|
|
|
|
|
|
function filterVisible(elements) {
|
|
|
|
return elements.filter(function(e) {
|
|
|
|
return !e.hidden;
|
|
|
|
});
|
|
|
|
}
|