Skip to content

Commit

Permalink
fix(core): prevent scrolling on canvas focus
Browse files Browse the repository at this point in the history
  • Loading branch information
nikku authored and vsgoulart committed Jan 23, 2024
1 parent 7c47df6 commit 50a2150
Show file tree
Hide file tree
Showing 2 changed files with 97 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/core/Canvas.js
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ Canvas.prototype._init = function(config) {

eventBus.on('element.hover', function() {
if (document.activeElement === document.body) {
svg.focus();
svg.focus({ preventScroll: true });
}
});

Expand Down
96 changes: 96 additions & 0 deletions test/spec/core/CanvasSpec.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,97 @@ describe('Canvas', function() {
});


describe('focus handling', function() {

beforeEach(function() {
container = TestContainer.get(this);
});

beforeEach(createDiagram());


it('should be focusable', function() {

// given
var svg = container.querySelector('svg');

// when
svg.focus();

// then
expect(document.activeElement).to.equal(svg);
});


describe('<hover>', function() {

beforeEach(function() {
document.body.focus();
});


it('should focus if body is focused', inject(function(canvas, eventBus) {

// given
var svg = container.querySelector('svg');

// when
eventBus.fire('element.hover', {
element: canvas.getRootElement(),
gfx: svg
});

// then
expect(document.activeElement).to.equal(svg);
}));


(isPhantomJS() ? it.skip : it)('should not scroll on focus', inject(function(canvas, eventBus) {

// given
var svg = container.querySelector('svg');

var clientRect = svg.getBoundingClientRect();

// when
eventBus.fire('element.hover', {
element: canvas.getRootElement(),
gfx: svg
});

// then
expect(clientRect).to.eql(svg.getBoundingClientRect());
}));


it('should not focus on existing document focus', inject(function(canvas, eventBus) {

// given
var inputEl = document.createElement('input');

document.body.appendChild(inputEl);
inputEl.focus();

// assume
expect(document.activeElement).to.equal(inputEl);

var svg = container.querySelector('svg');

// when
eventBus.fire('element.hover', {
element: canvas.getRootElement(),
gfx: svg
});

// then
expect(document.activeElement).to.eql(inputEl);
}));

});

});


describe('events', function() {

beforeEach(function() {
Expand Down Expand Up @@ -2628,4 +2719,9 @@ function expectChildren(parent, children) {
expect(existingChildrenGfx).to.eql(expectedChildrenGfx);
});

}


function isPhantomJS() {
return /PhantomJS/.test(window.navigator.userAgent);
}

0 comments on commit 50a2150

Please sign in to comment.