IMPR: Stop bubling on second click

This commit is contained in:
Tony Air 2023-10-23 05:39:55 +02:00
parent fe5ede2003
commit 03c6ca6332

View File

@ -26,7 +26,7 @@ const DropdownHoverUI = ((window) => {
HideAll() HideAll()
const menu = el.querySelector('.dropdown-menu') const menu = el.querySelector('.dropdown-menu')
if(menu) { if (menu) {
menu.classList.toggle('show') menu.classList.toggle('show')
} }
} }
@ -37,7 +37,7 @@ const DropdownHoverUI = ((window) => {
el.classList.add(...ACTIVECLS) el.classList.add(...ACTIVECLS)
const menu = el.querySelector('.dropdown-menu') const menu = el.querySelector('.dropdown-menu')
if(menu){ if (menu) {
menu.classList.add('show') menu.classList.add('show')
} }
} }
@ -48,7 +48,7 @@ const DropdownHoverUI = ((window) => {
el.classList.remove(...ACTIVECLS) el.classList.remove(...ACTIVECLS)
const menu = el.querySelector('.dropdown-menu') const menu = el.querySelector('.dropdown-menu')
if(menu){ if (menu) {
menu.classList.remove('show') menu.classList.remove('show')
} }
} }
@ -75,17 +75,31 @@ const DropdownHoverUI = ((window) => {
const href = el.getAttribute('href') const href = el.getAttribute('href')
// nav second click // nav second click
if(href && el.dataset.firstClick) { if (href && el.dataset.firstClick) {
console.log(`${NAME}: nav second click`) console.log(`${NAME}: nav second click`)
e.stopImmediatePropagation()
if (typeof window.app === 'undefined' || typeof window.app.Router === 'undefined') {
window.location.href = href window.location.href = href
return
}
window.app.Router.openURL(href)
} }
el.dataset.firstClick = true el.dataset.firstClick = true
if(parent){ if (parent) {
// big screen click // big screen click
if(href && window.innerWidth > 768 && parent.classList.contains('active-dropdown')){ if (href && window.innerWidth > 768 && parent.classList.contains('active-dropdown')) {
console.log(`${NAME}: big screen | nav click the dropdown is shown already`) console.log(`${NAME}: big screen | nav click the dropdown is shown already`)
e.stopImmediatePropagation()
if (typeof window.app === 'undefined' || typeof window.app.Router === 'undefined') {
window.location.href = href window.location.href = href
return
}
window.app.Router.openURL(href)
} }
console.log(`${NAME}: nav toggle`) console.log(`${NAME}: nav toggle`)
@ -130,7 +144,7 @@ const DropdownHoverUI = ((window) => {
hoverableEls.forEach((el, i) => { hoverableEls.forEach((el, i) => {
const parent = el.closest('.dropdown') const parent = el.closest('.dropdown')
if(parent){ if (parent) {
attachHoverEvents(parent) attachHoverEvents(parent)
} }
}) })