A developer did not like the default tooltip that is offered by browsers and instead used bootstrap's tooltip component. Bootstrap's tooltip component is not by default accessible and they failed to take corrective actions to mitigate the issues.
Because it takes a lot of time and thought to solve the issue, the required code is given below. Basically the trigger of the tooltip is switched from the default that is hover focus
into manual
and the events are handled manually.
Try to hover the tooltip before and after you paste the code below into the javascript editor to see the difference it makes!
var tooltipTriggerList = Array.from(
document.querySelectorAll('[data-bs-toggle="tooltip"]')
);
var tooltipList = tooltipTriggerList.map((tooltipTriggerEl) => {
return new bootstrap.Tooltip(tooltipTriggerEl, { trigger: 'manual' });
})
tooltipTriggerList.forEach(tooltipTriggerEl => {
var tooltip = bootstrap.Tooltip.getInstance(tooltipTriggerEl);
tooltipTriggerEl.addEventListener('mouseenter', () => {
tooltip.show();
document.querySelector('.tooltip').addEventListener('mouseleave', () => {
if(
!tooltipTriggerEl.parentElement.querySelector(
`${tooltipTriggerEl.tagName}:hover`
)
) {
tooltip.hide();
}
});
});
tooltipTriggerEl.addEventListener('mouseleave', () => {
if(!document.querySelector('.tooltip:hover')) {
tooltip.hide();
}
});
tooltipTriggerEl.addEventListener('focus', () => {
tooltip.show();
});
tooltipTriggerEl.addEventListener('blur', () => {
tooltip.hide();
});
});
window.addEventListener('keydown', (event) => {
if(event.code === 'Escape') {
tooltipTriggerList.forEach(tooltipTriggerEl => {
bootstrap.Tooltip.getInstance(tooltipTriggerEl).hide();
});
}
});
A developer did not like the default tooltip that is offered by browsers and instead used bootstrap's tooltip component. Bootstrap's tooltip component is not by default accessible and they failed to take corrective actions to mitigate the issues.
Because it takes a lot of time and thought to solve the issue, the required code is given below. Basically the trigger of the tooltip is switched from the default that is hover focus
into manual
and the events are handled manually.
Try to hover the tooltip before and after you paste the code below into the javascript editor to see the difference it makes!
var tooltipTriggerList = Array.from(
document.querySelectorAll('[data-bs-toggle="tooltip"]')
);
var tooltipList = tooltipTriggerList.map((tooltipTriggerEl) => {
return new bootstrap.Tooltip(tooltipTriggerEl, { trigger: 'manual' });
})
tooltipTriggerList.forEach(tooltipTriggerEl => {
var tooltip = bootstrap.Tooltip.getInstance(tooltipTriggerEl);
tooltipTriggerEl.addEventListener('mouseenter', () => {
tooltip.show();
document.querySelector('.tooltip').addEventListener('mouseleave', () => {
if(
!tooltipTriggerEl.parentElement.querySelector(
`${tooltipTriggerEl.tagName}:hover`
)
) {
tooltip.hide();
}
});
});
tooltipTriggerEl.addEventListener('mouseleave', () => {
if(!document.querySelector('.tooltip:hover')) {
tooltip.hide();
}
});
tooltipTriggerEl.addEventListener('focus', () => {
tooltip.show();
});
tooltipTriggerEl.addEventListener('blur', () => {
tooltip.hide();
});
});
window.addEventListener('keydown', (event) => {
if(event.code === 'Escape') {
tooltipTriggerList.forEach(tooltipTriggerEl => {
bootstrap.Tooltip.getInstance(tooltipTriggerEl).hide();
});
}
});