Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/twbs/bootstrap.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/js/src
diff options
context:
space:
mode:
authorTanguy Krotoff <tkrotoff@gmail.com>2020-06-18 10:02:44 +0300
committerGitHub <noreply@github.com>2020-06-18 10:02:44 +0300
commitd80a9fc553b609f94c1a24a5c310fd5d17c63c41 (patch)
treef701c9c780067a7481607a0edd7c63d59c3ab333 /js/src
parentffbdb08474cac2b721099e48ebf6a756c1ee30ec (diff)
Fix tooltip when hovering a children element (delegateTarget) (#30928)
Co-authored-by: XhmikosR <xhmikosr@gmail.com>
Diffstat (limited to 'js/src')
-rw-r--r--js/src/dom/event-handler.js2
-rw-r--r--js/src/tooltip.js18
2 files changed, 11 insertions, 9 deletions
diff --git a/js/src/dom/event-handler.js b/js/src/dom/event-handler.js
index b766778588..5fea030182 100644
--- a/js/src/dom/event-handler.js
+++ b/js/src/dom/event-handler.js
@@ -94,6 +94,7 @@ function getEvent(element) {
function bootstrapHandler(element, fn) {
return function handler(event) {
+ event.delegateTarget = element
if (handler.oneOff) {
EventHandler.off(element, event.type, fn)
}
@@ -109,6 +110,7 @@ function bootstrapDelegationHandler(element, selector, fn) {
for (let { target } = event; target && target !== this; target = target.parentNode) {
for (let i = domElements.length; i--;) {
if (domElements[i] === target) {
+ event.delegateTarget = target
if (handler.oneOff) {
EventHandler.off(element, event.type, fn)
}
diff --git a/js/src/tooltip.js b/js/src/tooltip.js
index d76679a6a0..64011796de 100644
--- a/js/src/tooltip.js
+++ b/js/src/tooltip.js
@@ -194,14 +194,14 @@ class Tooltip {
if (event) {
const dataKey = this.constructor.DATA_KEY
- let context = Data.getData(event.target, dataKey)
+ let context = Data.getData(event.delegateTarget, dataKey)
if (!context) {
context = new this.constructor(
- event.target,
+ event.delegateTarget,
this._getDelegateConfig()
)
- Data.setData(event.target, dataKey, context)
+ Data.setData(event.delegateTarget, dataKey, context)
}
context._activeTrigger.click = !context._activeTrigger.click
@@ -587,14 +587,14 @@ class Tooltip {
_enter(event, context) {
const dataKey = this.constructor.DATA_KEY
- context = context || Data.getData(event.target, dataKey)
+ context = context || Data.getData(event.delegateTarget, dataKey)
if (!context) {
context = new this.constructor(
- event.target,
+ event.delegateTarget,
this._getDelegateConfig()
)
- Data.setData(event.target, dataKey, context)
+ Data.setData(event.delegateTarget, dataKey, context)
}
if (event) {
@@ -627,14 +627,14 @@ class Tooltip {
_leave(event, context) {
const dataKey = this.constructor.DATA_KEY
- context = context || Data.getData(event.target, dataKey)
+ context = context || Data.getData(event.delegateTarget, dataKey)
if (!context) {
context = new this.constructor(
- event.target,
+ event.delegateTarget,
this._getDelegateConfig()
)
- Data.setData(event.target, dataKey, context)
+ Data.setData(event.delegateTarget, dataKey, context)
}
if (event) {