Enable html tooltips with this simple script and power up your cross table, graphical table or data tables
(() => { let i = 0; let tooltipTimeout = null; // Tooltips dictionary with lowercase keys const tooltips = { 'city': 'Another big city!', 'state': 'The inner text or textContent for this item is "state"', 'population': 'Population in millions<br>Look, we can use images!<br><img style="background:white" src="https://img.icons8.com/ios-filled/100/000000/crowd.png">', 'country': 'Tooltip for country', 'latitude': 'Geographical latitude.', 'longitude': 'Geographical longitude.', 'average temperature (f)': 'Average temperature data.', 'air quality index': 'Current air quality index.', 'observation date': 'Date of observation.', 'bullet graph':'This bullet graph represnts the air quality index min and max' }; const tooltip = document.createElement('div'); tooltip.id = 'tooltip'; tooltip.style.position = 'absolute'; tooltip.style.backgroundColor = 'black'; tooltip.style.color = 'white'; tooltip.style.padding = '5px'; tooltip.style.borderRadius = '5px'; tooltip.style.fontSize = '12px'; tooltip.style.visibility = 'hidden'; tooltip.style.opacity = '0'; tooltip.style.transition = 'opacity 0.2s'; tooltip.style.pointerEvents = 'none'; // Ensures the tooltip doesn't trigger any events document.body.appendChild(tooltip); const hasColumnHeaderClass = (element) => { while (element) { if ([...element.classList].some(cls => cls.includes('column-header'))) { return true; } element = element.parentElement; } return false; }; // Function to handle mouseover event const handleMouseOver = (event) => { const target = event.target; const textContent = target.textContent.trim().toLowerCase(); // Clear any existing timeout to avoid overlapping timeouts if (tooltipTimeout) { clearTimeout(tooltipTimeout); } tooltipTimeout = setTimeout(() => { if (tooltips[textContent] && hasColumnHeaderClass(target)) { tooltip.innerHTML = tooltips[textContent]; tooltip.style.visibility = 'visible'; tooltip.style.opacity = '1'; i++; console.log(i); } else { tooltip.style.visibility = 'hidden'; tooltip.style.opacity = '0'; } }, 800); // 0.8 seconds delay }; // Function to handle mousemove event const handleMouseMove = (event) => { tooltip.style.left = `${event.pageX + 10}px`; tooltip.style.top = `${event.pageY + 10}px`; }; // Function to handle mouseout event const handleMouseOut = () => { // Clear any existing timeout when mouse leaves if (tooltipTimeout) { clearTimeout(tooltipTimeout); } tooltip.style.visibility = 'hidden'; tooltip.style.opacity = '0'; }; // Attach event handlers using 'on' properties document.body.onmouseover = handleMouseOver; document.body.onmousemove = handleMouseMove; document.body.onmouseout = handleMouseOut; })();
No comments:
Post a Comment