From 27b31698d79208b1b5c8c2b170438efd9d278602 Mon Sep 17 00:00:00 2001 From: Beatriz Mendes Date: Fri, 3 Nov 2023 11:07:08 +0100 Subject: [PATCH] Revert "feat: remove selection outline" This reverts commit 651f40c3bf5e416f696e7995912154fc22c7cb02. --- lib/features/outline/Outline.js | 34 +++++++++++++++++++++++ test/spec/features/outline/OutlineSpec.js | 4 +-- 2 files changed, 36 insertions(+), 2 deletions(-) diff --git a/lib/features/outline/Outline.js b/lib/features/outline/Outline.js index b4d6a743d..837712955 100644 --- a/lib/features/outline/Outline.js +++ b/lib/features/outline/Outline.js @@ -1,3 +1,5 @@ +import { getBBox } from '../../util/Elements'; + var LOW_PRIORITY = 500; import { @@ -75,6 +77,19 @@ export default function Outline(eventBus, styles) { } }); + eventBus.on([ 'connection.added', 'connection.changed' ], function(event) { + var element = event.element, + gfx = event.gfx; + + var outline = domQuery('.djs-outline', gfx); + + if (!outline) { + outline = createOutline(gfx, element); + svgAppend(gfx, outline); + } + + self.updateConnectionOutline(outline, element); + }); } @@ -106,6 +121,25 @@ Outline.prototype.updateShapeOutline = function(outline, element) { } }; +/** + * Updates the outline of a connection respecting the bounding box of + * the connection and an outline offset. + * Register an outline provider with the given priority. + * + * @param {SVGElement} outline + * @param {Element} connection + **/ +Outline.prototype.updateConnectionOutline = function(outline, connection) { + var bbox = getBBox(connection); + + svgAttr(outline, { + x: bbox.x - this.offset, + y: bbox.y - this.offset, + width: bbox.width + this.offset * 2, + height: bbox.height + this.offset * 2 + }); +}; + /** * Register an outline provider with the given priority. * diff --git a/test/spec/features/outline/OutlineSpec.js b/test/spec/features/outline/OutlineSpec.js index 8466ab922..893d76b4e 100755 --- a/test/spec/features/outline/OutlineSpec.js +++ b/test/spec/features/outline/OutlineSpec.js @@ -51,7 +51,7 @@ describe('features/outline/Outline', function() { })); - it('should not add outline to connection', inject(function(selection, canvas, elementRegistry) { + it('should add outline to connection', inject(function(selection, canvas, elementRegistry) { // given var connection = canvas.addConnection({ id: 'select1', waypoints: [ { x: 25, y: 25 }, { x: 115, y: 115 } ] }); @@ -63,7 +63,7 @@ describe('features/outline/Outline', function() { var gfx = elementRegistry.getGraphics(connection); var outline = domQuery('.djs-outline', gfx); - expect(outline).to.not.exist; + expect(outline).to.exist; expect(svgClasses(gfx).has('selected')).to.be.true; // Outline class is set }));