Skip to content

Commit

Permalink
Fix event propagation from inactive and disabled dropdowns (#30510) (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
luktom committed Apr 7, 2020
1 parent 1b575c2 commit 8cc9def
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 3 deletions.
6 changes: 3 additions & 3 deletions js/src/dropdown.js
Expand Up @@ -452,9 +452,6 @@ class Dropdown {
return
}

event.preventDefault()
event.stopPropagation()

if (this.disabled || $(this).hasClass(CLASS_NAME_DISABLED)) {
return
}
Expand All @@ -466,6 +463,9 @@ class Dropdown {
return
}

event.preventDefault()
event.stopPropagation()

if (!isActive || isActive && (event.which === ESCAPE_KEYCODE || event.which === SPACE_KEYCODE)) {
if (event.which === ESCAPE_KEYCODE) {
const toggle = parent.querySelector(SELECTOR_DATA_TOGGLE)
Expand Down
64 changes: 64 additions & 0 deletions js/tests/unit/dropdown.js
Expand Up @@ -1020,6 +1020,70 @@ $(function () {
$textarea.trigger('click')
})

QUnit.test('should not stop key event propagation when dropdown is disabled', function (assert) {
assert.expect(1)
var done = assert.async()

var dropdownHTML = '<div class="tabs">' +
'<div class="dropdown">' +
'<a href="#" class="dropdown-toggle" id="toggle" data-toggle="dropdown" disabled>Dropdown</a>' +
'<div class="dropdown-menu">' +
'<a class="dropdown-item" id="item" href="#">Menu item</a>' +
'</div>' +
'</div>'

var $dropdown = $(dropdownHTML)
.appendTo('#qunit-fixture')
.find('[data-toggle="dropdown"]')
.bootstrapDropdown()

var $body = $('body')

$(document).on('keydown', function () {
$body.addClass('event-handled')
})

// Key escape
$dropdown.trigger('focus').trigger($.Event('keydown', {
which: 27
}))

assert.ok($body.hasClass('event-handled'), 'ESC key event was propagated')
done()
})

QUnit.test('should not stop ESC key event propagation when dropdown is not active', function (assert) {
assert.expect(1)
var done = assert.async()

var dropdownHTML = '<div class="tabs">' +
'<div class="dropdown">' +
'<a href="#" class="dropdown-toggle" id="toggle" data-toggle="dropdown">Dropdown</a>' +
'<div class="dropdown-menu">' +
'<a class="dropdown-item" id="item" href="#">Menu item</a>' +
'</div>' +
'</div>'

var $dropdown = $(dropdownHTML)
.appendTo('#qunit-fixture')
.find('[data-toggle="dropdown"]')
.bootstrapDropdown()

var $body = $('body')

$(document).on('keydown', function () {
$body.addClass('event-handled')
})

// Key escape
$dropdown.trigger('focus').trigger($.Event('keydown', {
which: 27
}))

assert.ok($body.hasClass('event-handled'), 'ESC key event was propagated')
done()
})

QUnit.test('should not use Popper.js if display set to static', function (assert) {
assert.expect(1)
var dropdownHTML =
Expand Down

0 comments on commit 8cc9def

Please sign in to comment.