mirror of
https://github.com/sartography/bpmn-js.git
synced 2025-01-13 18:46:05 +00:00
Merge branch 'master' into develop
This commit is contained in:
commit
4204c2bb2a
@ -11,6 +11,10 @@ ___Note:__ Yet to be released changes appear here._
|
||||
* Reworked the link of elements to bpmn DIs. You must access the `di` directly from the diagram element instead of the `businessObject`. [#1472](https://github.com/bpmn-io/bpmn-js/issues/1472)
|
||||
* Reworked import and `BpmnFactory` APIs. [#1472](https://github.com/bpmn-io/bpmn-js/issues/1472)
|
||||
|
||||
## 8.8.4
|
||||
|
||||
* `FIX`: set label color on `bpmndi:BPMNLabel#color` ([#1543](https://github.com/bpmn-io/bpmn-js/pull/1543))
|
||||
|
||||
## 8.8.3
|
||||
|
||||
* `FIX`: correct resize handles hidden behind element ([#1520](https://github.com/bpmn-io/bpmn-js/issues/1520))
|
||||
|
@ -5,6 +5,9 @@ import {
|
||||
pick
|
||||
} from 'min-dash';
|
||||
|
||||
import {
|
||||
getDi
|
||||
} from '../../../util/ModelUtil';
|
||||
|
||||
var DEFAULT_COLORS = {
|
||||
fill: undefined,
|
||||
@ -63,12 +66,26 @@ SetColorHandler.prototype.postExecute = function(context) {
|
||||
// TODO @barmac: remove once we drop bpmn.io properties
|
||||
ensureLegacySupport(assignedDi);
|
||||
|
||||
self._commandStack.execute('element.updateProperties', {
|
||||
element: element,
|
||||
properties: {
|
||||
di: assignedDi
|
||||
}
|
||||
});
|
||||
if (element.labelTarget) {
|
||||
|
||||
// set label colors as bpmndi:BPMNLabel#color
|
||||
self._commandStack.execute('element.updateModdleProperties', {
|
||||
element: element,
|
||||
moddleElement: getDi(element).label,
|
||||
properties: {
|
||||
color: di['background-color']
|
||||
}
|
||||
});
|
||||
} else {
|
||||
|
||||
// set colors bpmndi:BPMNEdge or bpmndi:BPMNShape
|
||||
self._commandStack.execute('element.updateProperties', {
|
||||
element: element,
|
||||
properties: {
|
||||
di: assignedDi
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
};
|
||||
|
61
test/spec/features/modeling/SetColor.bpmn
Normal file
61
test/spec/features/modeling/SetColor.bpmn
Normal file
@ -0,0 +1,61 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<bpmn2:definitions xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:bpmn2="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" xsi:schemaLocation="http://www.omg.org/spec/BPMN/20100524/MODEL BPMN20.xsd" id="simple" exporter="camunda modeler" exporterVersion="2.6.0" targetNamespace="http://bpmn.io/schema/bpmn">
|
||||
<bpmn2:process id="Process_1" isExecutable="false">
|
||||
<bpmn2:subProcess id="SubProcess_1" name="Sub Process 1">
|
||||
<bpmn2:incoming>SequenceFlow_3</bpmn2:incoming>
|
||||
<bpmn2:outgoing>SequenceFlow_2</bpmn2:outgoing>
|
||||
<bpmn2:startEvent id="StartEvent_1" name="Start Event 1">
|
||||
<bpmn2:outgoing>SequenceFlow_1</bpmn2:outgoing>
|
||||
</bpmn2:startEvent>
|
||||
<bpmn2:task id="Task_1" name="Task">
|
||||
<bpmn2:incoming>SequenceFlow_1</bpmn2:incoming>
|
||||
</bpmn2:task>
|
||||
<bpmn2:sequenceFlow id="SequenceFlow_1" name="" sourceRef="StartEvent_1" targetRef="Task_1"/>
|
||||
</bpmn2:subProcess>
|
||||
<bpmn2:endEvent id="EndEvent_1" name="End Event">
|
||||
<bpmn2:incoming>SequenceFlow_2</bpmn2:incoming>
|
||||
</bpmn2:endEvent>
|
||||
<bpmn2:sequenceFlow id="SequenceFlow_2" name="" sourceRef="SubProcess_1" targetRef="EndEvent_1"/>
|
||||
<bpmn2:startEvent id="StartEvent_2" name="Start">
|
||||
<bpmn2:outgoing>SequenceFlow_3</bpmn2:outgoing>
|
||||
</bpmn2:startEvent>
|
||||
<bpmn2:sequenceFlow id="SequenceFlow_3" name="Flow" sourceRef="StartEvent_2" targetRef="SubProcess_1"/>
|
||||
</bpmn2:process>
|
||||
<bpmndi:BPMNDiagram id="BPMNDiagram_1">
|
||||
<bpmndi:BPMNPlane id="BPMNPlane_1" bpmnElement="Process_1">
|
||||
<bpmndi:BPMNShape id="_BPMNShape_SubProcess_2" bpmnElement="SubProcess_1" isExpanded="true">
|
||||
<dc:Bounds height="300.0" width="300.0" x="300.0" y="80.0"/>
|
||||
</bpmndi:BPMNShape>
|
||||
<bpmndi:BPMNShape id="_BPMNShape_StartEvent_2" bpmnElement="StartEvent_1">
|
||||
<dc:Bounds height="36.0" width="36.0" x="352.0" y="242.0"/>
|
||||
</bpmndi:BPMNShape>
|
||||
<bpmndi:BPMNShape id="_BPMNShape_Task_2" bpmnElement="Task_1">
|
||||
<dc:Bounds height="80.0" width="100.0" x="420.0" y="220.0"/>
|
||||
</bpmndi:BPMNShape>
|
||||
<bpmndi:BPMNEdge id="BPMNEdge_SequenceFlow_1" bpmnElement="SequenceFlow_1" sourceElement="_BPMNShape_StartEvent_2" targetElement="_BPMNShape_Task_2">
|
||||
<di:waypoint xsi:type="dc:Point" x="388.0" y="260.0"/>
|
||||
<di:waypoint xsi:type="dc:Point" x="420.0" y="260.0"/>
|
||||
</bpmndi:BPMNEdge>
|
||||
<bpmndi:BPMNShape id="_BPMNShape_EndEvent_2" bpmnElement="EndEvent_1">
|
||||
<dc:Bounds height="36.0" width="36.0" x="650.0" y="212.0"/>
|
||||
</bpmndi:BPMNShape>
|
||||
<bpmndi:BPMNEdge id="BPMNEdge_SequenceFlow_2" bpmnElement="SequenceFlow_2" sourceElement="_BPMNShape_SubProcess_2" targetElement="_BPMNShape_EndEvent_2">
|
||||
<di:waypoint xsi:type="dc:Point" x="600.0" y="230.0"/>
|
||||
<di:waypoint xsi:type="dc:Point" x="650.0" y="230.0"/>
|
||||
</bpmndi:BPMNEdge>
|
||||
<bpmndi:BPMNShape id="_BPMNShape_StartEvent_11" bpmnElement="StartEvent_2">
|
||||
<dc:Bounds height="36.0" width="36.0" x="108.0" y="212.0"/>
|
||||
<bpmndi:BPMNLabel>
|
||||
<dc:Bounds height="0.0" width="0.0" x="126.0" y="253.0"/>
|
||||
</bpmndi:BPMNLabel>
|
||||
</bpmndi:BPMNShape>
|
||||
<bpmndi:BPMNEdge id="BPMNEdge_SequenceFlow_3" bpmnElement="SequenceFlow_3" sourceElement="_BPMNShape_StartEvent_11" targetElement="_BPMNShape_SubProcess_2">
|
||||
<di:waypoint xsi:type="dc:Point" x="144.0" y="230.0"/>
|
||||
<di:waypoint xsi:type="dc:Point" x="300.0" y="230.0"/>
|
||||
<bpmndi:BPMNLabel>
|
||||
<dc:Bounds height="21.0" width="33.0" x="192.0" y="204.0"/>
|
||||
</bpmndi:BPMNLabel>
|
||||
</bpmndi:BPMNEdge>
|
||||
</bpmndi:BPMNPlane>
|
||||
</bpmndi:BPMNDiagram>
|
||||
</bpmn2:definitions>
|
@ -13,7 +13,7 @@ var FUCHSIA_HEX = '#ff00ff',
|
||||
|
||||
describe('features/modeling - set color', function() {
|
||||
|
||||
var diagramXML = require('../../../fixtures/bpmn/simple.bpmn');
|
||||
var diagramXML = require('./SetColor.bpmn');
|
||||
|
||||
beforeEach(bootstrapModeler(diagramXML, {
|
||||
modules: [
|
||||
@ -44,6 +44,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { fill: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -60,6 +61,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { fill: 'FUCHSIA', stroke: 'YELLOW' });
|
||||
|
||||
// when
|
||||
@ -78,6 +80,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { fill: 'FUCHSIA', stroke: 'YELLOW' });
|
||||
|
||||
// when
|
||||
@ -96,6 +99,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { fill: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -128,6 +132,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { stroke: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -139,13 +144,52 @@ describe('features/modeling - set color', function() {
|
||||
}));
|
||||
|
||||
|
||||
it('setting stroke + fill color on external label', inject(function(elementRegistry, modeling) {
|
||||
|
||||
// given
|
||||
var flowShape = elementRegistry.get('SequenceFlow_3'),
|
||||
flowLabel = flowShape.label,
|
||||
flowDi = getDi(flowShape);
|
||||
|
||||
// when
|
||||
modeling.setColor(flowLabel, { stroke: 'FUCHSIA', fill: 'FUCHSIA' });
|
||||
|
||||
// then
|
||||
expect(flowDi.get('border-color')).not.to.exist;
|
||||
expect(flowDi.get('background-color')).not.to.exist;
|
||||
|
||||
expect(flowDi.label.get('color')).to.eql(FUCHSIA_HEX);
|
||||
}));
|
||||
|
||||
|
||||
it('unsetting stroke + fill color on external label', inject(function(elementRegistry, modeling) {
|
||||
|
||||
// given
|
||||
var flowShape = elementRegistry.get('SequenceFlow_3'),
|
||||
flowLabel = flowShape.label,
|
||||
flowDi = getDi(flowShape);
|
||||
|
||||
// assume
|
||||
modeling.setColor(flowLabel, { stroke: 'FUCHSIA', fill: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
modeling.setColor(flowLabel, { stroke: undefined, fill: undefined });
|
||||
|
||||
// then
|
||||
expect(flowDi.get('border-color')).not.to.exist;
|
||||
expect(flowDi.get('background-color')).not.to.exist;
|
||||
|
||||
expect(flowDi.label.get('color')).not.to.exist;
|
||||
}));
|
||||
|
||||
|
||||
it('setting fill color (multiple elements)', inject(
|
||||
function(elementRegistry, modeling) {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
|
||||
// when
|
||||
@ -165,9 +209,10 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
|
||||
modeling.setColor([ taskShape, startEventShape ], { fill: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -185,8 +230,8 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
|
||||
// when
|
||||
@ -209,8 +254,8 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
|
||||
modeling.setColor([
|
||||
@ -334,6 +379,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { stroke: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -351,9 +397,9 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
// when
|
||||
modeling.setColor([ taskShape, startEventShape ], { fill: 'FUCHSIA' });
|
||||
@ -371,9 +417,10 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor([ taskShape, startEventShape ], { fill: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -392,9 +439,9 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
// when
|
||||
modeling.setColor([
|
||||
@ -415,9 +462,10 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor([ taskShape, startEventShape ], { stroke: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -459,6 +507,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { fill: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -496,6 +545,7 @@ describe('features/modeling - set color', function() {
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor(taskShape, { stroke: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -514,9 +564,9 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
// when
|
||||
modeling.setColor([ taskShape, startEventShape ], { fill: 'FUCHSIA' });
|
||||
@ -535,9 +585,10 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor([ taskShape, startEventShape ], { fill: 'FUCHSIA' });
|
||||
|
||||
// when
|
||||
@ -557,9 +608,9 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
// when
|
||||
modeling.setColor([ taskShape, startEventShape ], { stroke: 'FUCHSIA' });
|
||||
@ -578,9 +629,10 @@ describe('features/modeling - set color', function() {
|
||||
|
||||
// given
|
||||
var taskShape = elementRegistry.get('Task_1'),
|
||||
taskDi = getDi(taskShape);
|
||||
var startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(startEventShape);
|
||||
taskDi = getDi(taskShape),
|
||||
startEventShape = elementRegistry.get('StartEvent_1'),
|
||||
startEventDi = getDi(taskShape);
|
||||
|
||||
modeling.setColor([
|
||||
taskShape,
|
||||
startEventShape
|
||||
@ -637,5 +689,7 @@ describe('features/modeling - set color', function() {
|
||||
expect(sequenceFlowDi.get('stroke')).to.eql('#abcdef');
|
||||
}
|
||||
));
|
||||
|
||||
});
|
||||
|
||||
});
|
Loading…
x
Reference in New Issue
Block a user