@coreui/vue
Version:
UI Components Library for Vue.js
90 lines (87 loc) • 3.13 kB
JavaScript
import { createPopper } from '@popperjs/core';
import 'vue';
import { useUniqueId } from '../composables/useUniqueId.js';
const createTooltipElement = (id, content) => {
const tooltip = document.createElement('div');
tooltip.id = id;
tooltip.classList.add('tooltip', 'bs-tooltip-auto', 'fade');
tooltip.setAttribute('role', 'tooltip');
tooltip.innerHTML = `<div class="tooltip-arrow" data-popper-arrow></div>
<div class="tooltip-inner" id="">${content}</div>`;
return tooltip;
};
const addTooltipElement = (el, tooltip, popperOptions, uID) => {
el.setAttribute('aria-describedby', uID);
document.body.appendChild(tooltip);
createPopper(el, tooltip, popperOptions);
setTimeout(() => {
tooltip.classList.add('show');
}, 1);
};
const removeTooltipElement = (el, tooltip) => {
el.removeAttribute('aria-describedby');
tooltip.classList.remove('show');
setTimeout(() => {
tooltip.remove();
}, 300);
};
const toggleTooltipElement = (el, tooltip, popperOptions, uID) => {
const popperElement = document.getElementById(tooltip.id);
if (popperElement && popperElement.classList.contains('show')) {
removeTooltipElement(el, tooltip);
return;
}
addTooltipElement(el, tooltip, popperOptions, uID);
};
var vCTooltip = {
name: 'c-tooltip',
mounted(el, binding) {
const { getUID } = useUniqueId('tooltip');
const value = binding.value;
const content = typeof value === 'string' ? value : value.content ?? '';
const trigger = value.trigger ?? 'hover';
// Popper Config
const offset = value.offset ?? [0, 6];
const placement = value.placement ?? 'top';
const popperOptions = {
placement: placement,
modifiers: [
{
name: 'offset',
options: {
offset: offset,
},
},
],
};
const uID = getUID();
binding.arg = uID;
const tooltip = createTooltipElement(uID, content);
trigger.includes('click') &&
el.addEventListener('click', () => {
toggleTooltipElement(el, tooltip, popperOptions, uID);
});
if (trigger.includes('focus')) {
el.addEventListener('focus', () => {
addTooltipElement(el, tooltip, popperOptions, uID);
});
el.addEventListener('blur', () => {
removeTooltipElement(el, tooltip);
});
}
if (trigger.includes('hover')) {
el.addEventListener('mouseenter', () => {
addTooltipElement(el, tooltip, popperOptions, uID);
});
el.addEventListener('mouseleave', () => {
removeTooltipElement(el, tooltip);
});
}
},
beforeUnmount(_el, binding) {
const tooltip = binding.arg && document.getElementById(binding.arg);
tooltip && tooltip.remove();
},
};
export { vCTooltip as default };
//# sourceMappingURL=v-c-tooltip.js.map