Skip to content

Commit

Permalink
Refactor dropdown's hide functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
rohit2sharma95 committed Apr 2, 2021
1 parent 20cfbdf commit fe7018e
Showing 1 changed file with 33 additions and 50 deletions.
83 changes: 33 additions & 50 deletions js/src/dropdown.js
Original file line number Diff line number Diff line change
Expand Up @@ -212,28 +212,7 @@ class Dropdown extends BaseComponent {
relatedTarget: this._element
}

const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE, relatedTarget)

if (hideEvent.defaultPrevented) {
return
}

// If this is a touch-enabled device we remove the extra
// empty mouseover listeners we added for iOS support
if ('ontouchstart' in document.documentElement) {
[].concat(...document.body.children)
.forEach(elem => EventHandler.off(elem, 'mouseover', null, noop()))
}

if (this._popper) {
this._popper.destroy()
}

this._menu.classList.toggle(CLASS_NAME_SHOW)
this._element.classList.toggle(CLASS_NAME_SHOW)
this._element.setAttribute('aria-expanded', 'false')
Manipulator.removeDataAttribute(this._menu, 'popper')
EventHandler.trigger(this._element, EVENT_HIDDEN, relatedTarget)
this._completeHide(this._element, this._menu, relatedTarget)
}

dispose() {
Expand Down Expand Up @@ -264,6 +243,30 @@ class Dropdown extends BaseComponent {
})
}

_completeHide(element, menu, relatedTarget) {
const hideEvent = EventHandler.trigger(element, EVENT_HIDE, relatedTarget)
if (hideEvent.defaultPrevented) {
return
}

// If this is a touch-enabled device we remove the extra
// empty mouseover listeners we added for iOS support
if ('ontouchstart' in document.documentElement) {
[].concat(...document.body.children)
.forEach(elem => EventHandler.off(elem, 'mouseover', null, noop()))
}

if (this._popper) {
this._popper.destroy()
}

menu.classList.toggle(CLASS_NAME_SHOW)
element.classList.toggle(CLASS_NAME_SHOW)
element.setAttribute('aria-expanded', 'false')
Manipulator.removeDataAttribute(menu, 'popper')
EventHandler.trigger(element, EVENT_HIDDEN, relatedTarget)
}

_getConfig(config) {
config = {
...this.constructor.Default,
Expand Down Expand Up @@ -397,14 +400,6 @@ class Dropdown extends BaseComponent {

for (let i = 0, len = toggles.length; i < len; i++) {
const context = Data.get(toggles[i], DATA_KEY)
const relatedTarget = {
relatedTarget: toggles[i]
}

if (event && event.type === 'click') {
relatedTarget.clickEvent = event
}

if (!context) {
continue
}
Expand All @@ -414,6 +409,10 @@ class Dropdown extends BaseComponent {
continue
}

const relatedTarget = {
relatedTarget: toggles[i]
}

if (event) {
// Don't close the menu if the clicked element or one of its parents is the dropdown button
if ([context._element].some(element => event.composedPath().includes(element))) {
Expand All @@ -424,29 +423,13 @@ class Dropdown extends BaseComponent {
if (event.type === 'keyup' && event.key === TAB_KEY && dropdownMenu.contains(event.target)) {
continue
}
}

const hideEvent = EventHandler.trigger(toggles[i], EVENT_HIDE, relatedTarget)
if (hideEvent.defaultPrevented) {
continue
}

// If this is a touch-enabled device we remove the extra
// empty mouseover listeners we added for iOS support
if ('ontouchstart' in document.documentElement) {
[].concat(...document.body.children)
.forEach(elem => EventHandler.off(elem, 'mouseover', null, noop()))
}

if (context._popper) {
context._popper.destroy()
if (event.type === 'click') {
relatedTarget.clickEvent = event
}
}

dropdownMenu.classList.remove(CLASS_NAME_SHOW)
toggles[i].classList.remove(CLASS_NAME_SHOW)
toggles[i].setAttribute('aria-expanded', 'false')
Manipulator.removeDataAttribute(dropdownMenu, 'popper')
EventHandler.trigger(toggles[i], EVENT_HIDDEN, relatedTarget)
context._completeHide(toggles[i], dropdownMenu, relatedTarget)
}
}

Expand Down

0 comments on commit fe7018e

Please sign in to comment.