debian-mirror-gitlab/app/assets/javascripts/tooltips/index.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

98 lines
2.6 KiB
JavaScript
Raw Normal View History

2021-03-11 19:13:27 +05:30
import { toArray, isElement } from 'lodash';
2020-11-24 15:15:51 +05:30
import Vue from 'vue';
import Tooltips from './components/tooltips.vue';
let app;
const EVENTS_MAP = {
hover: 'mouseenter',
click: 'click',
focus: 'focus',
};
const DEFAULT_TRIGGER = 'hover focus';
const APP_ELEMENT_ID = 'gl-tooltips-app';
const tooltipsApp = () => {
if (!app) {
const container = document.createElement('div');
container.setAttribute('id', APP_ELEMENT_ID);
document.body.appendChild(container);
app = new Vue({
2022-04-04 11:22:00 +05:30
name: 'TooltipsRoot',
2020-11-24 15:15:51 +05:30
render(h) {
return h(Tooltips, {
props: {
elements: this.elements,
},
ref: 'tooltips',
});
},
}).$mount(container);
}
return app.$refs.tooltips;
};
const isTooltip = (node, selector) => node.matches && node.matches(selector);
const addTooltips = (elements, config) => {
tooltipsApp().addTooltips(toArray(elements), config);
};
const handleTooltipEvent = (rootTarget, e, selector, config = {}) => {
for (let { target } = e; target && target !== rootTarget; target = target.parentNode) {
if (isTooltip(target, selector)) {
2021-04-29 21:17:54 +05:30
addTooltips([target], config);
2020-11-24 15:15:51 +05:30
break;
}
}
};
2021-01-03 14:25:43 +05:30
const applyToElements = (elements, handler) => {
const iterable = isElement(elements) ? [elements] : toArray(elements);
toArray(iterable).forEach(handler);
};
2020-11-24 15:15:51 +05:30
2021-03-11 19:13:27 +05:30
const createTooltipApiInvoker = (glHandler) => (elements) => {
applyToElements(elements, glHandler);
2020-11-24 15:15:51 +05:30
};
export const initTooltips = (config = {}) => {
2021-03-11 19:13:27 +05:30
const triggers = config?.triggers || DEFAULT_TRIGGER;
const events = triggers.split(' ').map((trigger) => EVENTS_MAP[trigger]);
events.forEach((event) => {
document.addEventListener(
event,
(e) => handleTooltipEvent(document, e, config.selector, config),
true,
);
});
return tooltipsApp();
2021-01-29 00:20:46 +05:30
};
2021-03-11 19:13:27 +05:30
export const add = (elements, config = {}) => addTooltips(elements, config);
export const dispose = createTooltipApiInvoker((element) => tooltipsApp().dispose(element));
export const fixTitle = createTooltipApiInvoker((element) => tooltipsApp().fixTitle(element));
export const enable = createTooltipApiInvoker((element) =>
tooltipsApp().triggerEvent(element, 'enable'),
);
export const disable = createTooltipApiInvoker((element) =>
tooltipsApp().triggerEvent(element, 'disable'),
);
export const hide = createTooltipApiInvoker((element) =>
tooltipsApp().triggerEvent(element, 'close'),
);
export const show = createTooltipApiInvoker((element) =>
tooltipsApp().triggerEvent(element, 'open'),
);
2021-04-17 20:07:23 +05:30
export const once = (event, cb) => tooltipsApp().$once(event, cb);
2020-11-24 15:15:51 +05:30
export const destroy = () => {
tooltipsApp().$destroy();
app = null;
};