diff options
| author | GeoSot <[email protected]> | 2021-04-19 08:20:25 +0300 |
|---|---|---|
| committer | GitHub <[email protected]> | 2021-04-19 08:20:25 +0300 |
| commit | a9d7a62658c5d93dcba5ed5fc47d84f3ddd3e0a3 (patch) | |
| tree | abc7fcf44b0dabe61ea03933d1b1c6308e2619ae /js/tests/unit/offcanvas.spec.js | |
| parent | df8131a1f88e62f6bc8ae1c669bc0e534965bf1a (diff) | |
| download | bootstrap-a9d7a62658c5d93dcba5ed5fc47d84f3ddd3e0a3.tar.xz bootstrap-a9d7a62658c5d93dcba5ed5fc47d84f3ddd3e0a3.zip | |
Use the backdrop util in offcanvas, enforcing consistency (#33545)
* respect /share modal's backdrop functionality, keeping consistency
* listen click events over backdrop (only) and trigger `hide()` without add/remove event tricks
* achieve to hide foreign open offcanvas instances without glitches `if (allReadyOpen && allReadyOpen !== target)`, in case another is going to be open, when user clicks on trigger button
Diffstat (limited to 'js/tests/unit/offcanvas.spec.js')
| -rw-r--r-- | js/tests/unit/offcanvas.spec.js | 100 |
1 files changed, 93 insertions, 7 deletions
diff --git a/js/tests/unit/offcanvas.spec.js b/js/tests/unit/offcanvas.spec.js index 0a921bc9f..67831ad24 100644 --- a/js/tests/unit/offcanvas.spec.js +++ b/js/tests/unit/offcanvas.spec.js @@ -3,6 +3,7 @@ import EventHandler from '../../src/dom/event-handler' /** Test helpers */ import { clearFixture, createEvent, getFixture, jQueryMock } from '../helpers/fixture' +import { isVisible } from '../../src/util' describe('Offcanvas', () => { let fixtureEl @@ -59,6 +60,7 @@ describe('Offcanvas', () => { closeEl.click() + expect(offCanvas._config.keyboard).toBe(true) expect(offCanvas.hide).toHaveBeenCalled() }) @@ -72,7 +74,7 @@ describe('Offcanvas', () => { spyOn(offCanvas, 'hide') - document.dispatchEvent(keyDownEsc) + offCanvasEl.dispatchEvent(keyDownEsc) expect(offCanvas.hide).toHaveBeenCalled() }) @@ -104,6 +106,7 @@ describe('Offcanvas', () => { document.dispatchEvent(keyDownEsc) + expect(offCanvas._config.keyboard).toBe(false) expect(offCanvas.hide).not.toHaveBeenCalled() }) }) @@ -119,6 +122,7 @@ describe('Offcanvas', () => { const offCanvas = new Offcanvas(offCanvasEl) expect(offCanvas._config.backdrop).toEqual(true) + expect(offCanvas._backdrop._config.isVisible).toEqual(true) expect(offCanvas._config.keyboard).toEqual(true) expect(offCanvas._config.scroll).toEqual(false) }) @@ -133,6 +137,7 @@ describe('Offcanvas', () => { const offCanvas = new Offcanvas(offCanvasEl) expect(offCanvas._config.backdrop).toEqual(false) + expect(offCanvas._backdrop._config.isVisible).toEqual(false) expect(offCanvas._config.keyboard).toEqual(false) expect(offCanvas._config.scroll).toEqual(true) }) @@ -191,6 +196,30 @@ describe('Offcanvas', () => { }) offCanvas.show() }) + + it('should hide a shown element if user click on backdrop', done => { + fixtureEl.innerHTML = '<div class="offcanvas"></div>' + + const offCanvasEl = fixtureEl.querySelector('div') + const offCanvas = new Offcanvas(offCanvasEl, { backdrop: true }) + + const clickEvent = document.createEvent('MouseEvents') + clickEvent.initEvent('mousedown', true, true) + spyOn(offCanvas._backdrop._config, 'clickCallback').and.callThrough() + + offCanvasEl.addEventListener('shown.bs.offcanvas', () => { + expect(typeof offCanvas._backdrop._config.clickCallback).toBe('function') + + offCanvas._backdrop._getElement().dispatchEvent(clickEvent) + }) + + offCanvasEl.addEventListener('hidden.bs.offcanvas', () => { + expect(offCanvas._backdrop._config.clickCallback).toHaveBeenCalled() + done() + }) + + offCanvas.show() + }) }) describe('toggle', () => { @@ -229,14 +258,16 @@ describe('Offcanvas', () => { const offCanvasEl = fixtureEl.querySelector('div') const offCanvas = new Offcanvas(offCanvasEl) - offCanvas.show() + expect(offCanvasEl.classList.contains('show')).toBe(true) + spyOn(offCanvas._backdrop, 'show').and.callThrough() spyOn(EventHandler, 'trigger').and.callThrough() offCanvas.show() expect(EventHandler.trigger).not.toHaveBeenCalled() + expect(offCanvas._backdrop.show).not.toHaveBeenCalled() }) it('should show a hidden element', done => { @@ -244,9 +275,11 @@ describe('Offcanvas', () => { const offCanvasEl = fixtureEl.querySelector('div') const offCanvas = new Offcanvas(offCanvasEl) + spyOn(offCanvas._backdrop, 'show').and.callThrough() offCanvasEl.addEventListener('shown.bs.offcanvas', () => { expect(offCanvasEl.classList.contains('show')).toEqual(true) + expect(offCanvas._backdrop.show).toHaveBeenCalled() done() }) @@ -258,10 +291,11 @@ describe('Offcanvas', () => { const offCanvasEl = fixtureEl.querySelector('div') const offCanvas = new Offcanvas(offCanvasEl) + spyOn(offCanvas._backdrop, 'show').and.callThrough() const expectEnd = () => { setTimeout(() => { - expect().nothing() + expect(offCanvas._backdrop.show).not.toHaveBeenCalled() done() }, 10) } @@ -304,9 +338,10 @@ describe('Offcanvas', () => { const offCanvasEl = fixtureEl.querySelector('div') const offCanvas = new Offcanvas(offCanvasEl) + spyOn(offCanvas._backdrop, 'hide').and.callThrough() offCanvas.hide() - + expect(offCanvas._backdrop.hide).not.toHaveBeenCalled() expect(EventHandler.trigger).not.toHaveBeenCalled() }) @@ -315,10 +350,12 @@ describe('Offcanvas', () => { const offCanvasEl = fixtureEl.querySelector('div') const offCanvas = new Offcanvas(offCanvasEl) + spyOn(offCanvas._backdrop, 'hide').and.callThrough() offCanvas.show() offCanvasEl.addEventListener('hidden.bs.offcanvas', () => { expect(offCanvasEl.classList.contains('show')).toEqual(false) + expect(offCanvas._backdrop.hide).toHaveBeenCalled() done() }) @@ -330,11 +367,13 @@ describe('Offcanvas', () => { const offCanvasEl = fixtureEl.querySelector('div') const offCanvas = new Offcanvas(offCanvasEl) + spyOn(offCanvas._backdrop, 'hide').and.callThrough() + offCanvas.show() const expectEnd = () => { setTimeout(() => { - expect().nothing() + expect(offCanvas._backdrop.hide).not.toHaveBeenCalled() done() }, 10) } @@ -352,6 +391,27 @@ describe('Offcanvas', () => { }) }) + describe('dispose', () => { + it('should dispose an offcanvas', () => { + fixtureEl.innerHTML = '<div class="offcanvas"></div>' + + const offCanvasEl = fixtureEl.querySelector('div') + const offCanvas = new Offcanvas(offCanvasEl) + const backdrop = offCanvas._backdrop + spyOn(backdrop, 'dispose').and.callThrough() + + expect(Offcanvas.getInstance(offCanvasEl)).toEqual(offCanvas) + + spyOn(EventHandler, 'off') + + offCanvas.dispose() + + expect(backdrop.dispose).toHaveBeenCalled() + expect(offCanvas._backdrop).toBeNull() + expect(Offcanvas.getInstance(offCanvasEl)).toEqual(null) + }) + }) + describe('data-api', () => { it('should not prevent event for input', done => { fixtureEl.innerHTML = [ @@ -386,7 +446,7 @@ describe('Offcanvas', () => { expect(Offcanvas.prototype.toggle).not.toHaveBeenCalled() }) - it('should not call toggle if another offcanvas is open', done => { + it('should call hide first, if another offcanvas is open', done => { fixtureEl.innerHTML = [ '<button id="btn2" data-bs-toggle="offcanvas" data-bs-target="#offcanvas2" ></button>', '<div id="offcanvas1" class="offcanvas"></div>', @@ -402,7 +462,7 @@ describe('Offcanvas', () => { trigger2.click() }) offcanvasEl1.addEventListener('hidden.bs.offcanvas', () => { - expect(Offcanvas.getInstance(offcanvasEl2)).toEqual(null) + expect(Offcanvas.getInstance(offcanvasEl2)).not.toBeNull() done() }) offcanvas1.show() @@ -431,6 +491,32 @@ describe('Offcanvas', () => { trigger.click() }) + + it('should not focus on trigger element after closing offcanvas, if it is not visible', done => { + fixtureEl.innerHTML = [ + '<button id="btn" data-bs-toggle="offcanvas" data-bs-target="#offcanvas" ></button>', + '<div id="offcanvas" class="offcanvas"></div>' + ].join('') + + const trigger = fixtureEl.querySelector('#btn') + const offcanvasEl = fixtureEl.querySelector('#offcanvas') + const offcanvas = new Offcanvas(offcanvasEl) + spyOn(trigger, 'focus') + + offcanvasEl.addEventListener('shown.bs.offcanvas', () => { + trigger.style.display = 'none' + offcanvas.hide() + }) + offcanvasEl.addEventListener('hidden.bs.offcanvas', () => { + setTimeout(() => { + expect(isVisible(trigger)).toBe(false) + expect(trigger.focus).not.toHaveBeenCalled() + done() + }, 5) + }) + + trigger.click() + }) }) describe('jQueryInterface', () => { |
