mirror of
https://github.com/sartography/bpmn-js.git
synced 2025-01-11 17:44:12 +00:00
fix(modeling): manhattan layout compensation association
Related to #291
This commit is contained in:
parent
5ab0db65a5
commit
206daa1154
@ -38,9 +38,13 @@ BpmnLayouter.prototype.layoutConnection = function(connection, layoutHints) {
|
|||||||
// TODO (nre): support vertical modeling
|
// TODO (nre): support vertical modeling
|
||||||
// and invert preferredLayouts accordingly
|
// and invert preferredLayouts accordingly
|
||||||
|
|
||||||
if ((is(connection, 'bpmn:Association') || is(connection, 'bpmn:DataAssociation')) && waypoints) {
|
if (is(connection, 'bpmn:Association') ||
|
||||||
|
is(connection, 'bpmn:DataAssociation')) {
|
||||||
|
|
||||||
|
if (waypoints && !isCompensationAssociation(connection)) {
|
||||||
return waypoints;
|
return waypoints;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// manhattan layout sequence / message flows
|
// manhattan layout sequence / message flows
|
||||||
if (is(connection, 'bpmn:MessageFlow')) {
|
if (is(connection, 'bpmn:MessageFlow')) {
|
||||||
@ -63,7 +67,8 @@ BpmnLayouter.prototype.layoutConnection = function(connection, layoutHints) {
|
|||||||
// (1) outgoing of BoundaryEvents -> layout h:v or v:h based on attach orientation
|
// (1) outgoing of BoundaryEvents -> layout h:v or v:h based on attach orientation
|
||||||
// (2) incoming / outgoing of Gateway -> v:h (outgoing), h:v (incoming)
|
// (2) incoming / outgoing of Gateway -> v:h (outgoing), h:v (incoming)
|
||||||
//
|
//
|
||||||
if (is(connection, 'bpmn:SequenceFlow')) {
|
if (is(connection, 'bpmn:SequenceFlow') ||
|
||||||
|
isCompensationAssociation(connection)) {
|
||||||
|
|
||||||
// make sure boundary event connections do
|
// make sure boundary event connections do
|
||||||
// not look ugly =:>
|
// not look ugly =:>
|
||||||
@ -136,3 +141,13 @@ function getConnectionDocking(waypoints, idx, shape) {
|
|||||||
|
|
||||||
return point ? (point.original || point) : getMid(shape);
|
return point ? (point.original || point) : getMid(shape);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isCompensationAssociation(connection) {
|
||||||
|
|
||||||
|
var source = connection.source,
|
||||||
|
target = connection.target;
|
||||||
|
|
||||||
|
return is(target, 'bpmn:Activity') &&
|
||||||
|
is(source, 'bpmn:BoundaryEvent') &&
|
||||||
|
target.businessObject.isForCompensation;
|
||||||
|
}
|
@ -0,0 +1,26 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<bpmn:definitions xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:bpmn="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:dc="http://www.omg.org/spec/DD/20100524/DC" xmlns:di="http://www.omg.org/spec/DD/20100524/DI" id="Definitions_1" targetNamespace="http://bpmn.io/schema/bpmn">
|
||||||
|
<bpmn:process id="Process_1" isExecutable="false">
|
||||||
|
<bpmn:task id="Task_09clsti" />
|
||||||
|
<bpmn:boundaryEvent id="CompensationBoundary" attachedToRef="Task_09clsti">
|
||||||
|
<bpmn:compensateEventDefinition />
|
||||||
|
</bpmn:boundaryEvent>
|
||||||
|
<bpmn:task id="CompensationActivity" isForCompensation="true" />
|
||||||
|
</bpmn:process>
|
||||||
|
<bpmndi:BPMNDiagram id="BPMNDiagram_1">
|
||||||
|
<bpmndi:BPMNPlane id="BPMNPlane_1" bpmnElement="Process_1">
|
||||||
|
<bpmndi:BPMNShape id="Task_09clsti_di" bpmnElement="Task_09clsti">
|
||||||
|
<dc:Bounds x="45" y="44" width="100" height="80" />
|
||||||
|
</bpmndi:BPMNShape>
|
||||||
|
<bpmndi:BPMNShape id="CompensationBoundary_di" bpmnElement="CompensationBoundary">
|
||||||
|
<dc:Bounds x="89" y="106" width="36" height="36" />
|
||||||
|
<bpmndi:BPMNLabel>
|
||||||
|
<dc:Bounds x="62" y="142" width="90" height="20" />
|
||||||
|
</bpmndi:BPMNLabel>
|
||||||
|
</bpmndi:BPMNShape>
|
||||||
|
<bpmndi:BPMNShape id="CompensationActivity_di" bpmnElement="CompensationActivity">
|
||||||
|
<dc:Bounds x="206" y="214" width="100" height="80" />
|
||||||
|
</bpmndi:BPMNShape>
|
||||||
|
</bpmndi:BPMNPlane>
|
||||||
|
</bpmndi:BPMNDiagram>
|
||||||
|
</bpmn:definitions>
|
@ -0,0 +1,46 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
require('../../../../TestHelper');
|
||||||
|
|
||||||
|
/* global inject, bootstrapModeler */
|
||||||
|
|
||||||
|
var find = require('lodash/collection/find');
|
||||||
|
|
||||||
|
var modelingModule = require('../../../../../lib/features/modeling');
|
||||||
|
|
||||||
|
|
||||||
|
describe('modeling/behavior - CompensationAssociation', function(){
|
||||||
|
|
||||||
|
var diagramXML = require('./CompensationAssociationBehavior.bpmn');
|
||||||
|
|
||||||
|
beforeEach(bootstrapModeler(diagramXML, { modules: modelingModule }));
|
||||||
|
|
||||||
|
|
||||||
|
it('should manhattan layout', inject(function(modeling, elementRegistry) {
|
||||||
|
|
||||||
|
// given
|
||||||
|
var boundaryShape = elementRegistry.get('CompensationBoundary'),
|
||||||
|
activityShape = elementRegistry.get('CompensationActivity');
|
||||||
|
|
||||||
|
|
||||||
|
// when
|
||||||
|
var newConnection = modeling.connect(boundaryShape, activityShape, {
|
||||||
|
type: 'bpmn:DataInputAssociation'
|
||||||
|
});
|
||||||
|
|
||||||
|
// then
|
||||||
|
expect(waypoints(newConnection)).to.eql([
|
||||||
|
{ x: 107, y: 142 },
|
||||||
|
{ x: 107, y: 254 },
|
||||||
|
{ x: 206, y: 254 }
|
||||||
|
]);
|
||||||
|
}));
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
function waypoints(connection) {
|
||||||
|
return connection.waypoints.map(function(wp) {
|
||||||
|
return { x: wp.x, y: wp.y };
|
||||||
|
});
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user