-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtooltips.js
More file actions
55 lines (48 loc) · 1.63 KB
/
tooltips.js
File metadata and controls
55 lines (48 loc) · 1.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
document.addEventListener("DOMContentLoaded", function () {
const tooltipElements = document.querySelectorAll("[data-tooltip]");
tooltipElements.forEach((el) => {
const tooltipText = el.getAttribute("data-tooltip");
const tooltipDiv = document.createElement("div");
tooltipDiv.className =
"tooltip-div " + el.getAttribute("data-tooltip-classes");
tooltipDiv.innerHTML = tooltipText;
if (el.getAttribute("data-tooltip-parent") != null) {
document
.querySelector(el.getAttribute("data-tooltip-parent"))
.appendChild(tooltipDiv);
} else {
el.appendChild(tooltipDiv);
}
});
// Enhanced tooltip hover handling to prevent gap issues
tooltipElements.forEach((el) => {
const parentContainer = el.getAttribute("data-tooltip-parent")
? document.querySelector(el.getAttribute("data-tooltip-parent"))
: el.parentElement;
let hideTimeout;
const showTooltip = () => {
clearTimeout(hideTimeout);
const tooltip = parentContainer.querySelector('.tooltip-div');
if (tooltip) {
tooltip.style.display = 'block';
}
};
const hideTooltipDelayed = () => {
hideTimeout = setTimeout(() => {
const tooltip = parentContainer.querySelector('.tooltip-div');
if (tooltip) {
tooltip.style.display = 'none';
}
}, 100);
};
// Trigger element events
el.addEventListener('mouseenter', showTooltip);
el.addEventListener('mouseleave', hideTooltipDelayed);
// Tooltip element events
const tooltip = parentContainer.querySelector('.tooltip-div');
if (tooltip) {
tooltip.addEventListener('mouseenter', showTooltip);
tooltip.addEventListener('mouseleave', hideTooltipDelayed);
}
});
});