Files
Atay-Makhzan/web_src/js/features/contextpopup.js
T

46 lines
1.2 KiB
JavaScript
Raw Normal View History

2022-10-01 16:26:38 +02:00
import {createApp} from 'vue';
import ContextPopup from '../components/ContextPopup.vue';
2021-10-22 22:34:01 +08:00
import {parseIssueHref} from '../utils.js';
2022-07-19 00:33:34 +02:00
import {createTippy} from '../modules/tippy.js';
2020-02-11 19:53:18 -06:00
2022-12-23 17:03:11 +01:00
export function initContextPopups() {
const refIssues = document.querySelectorAll('.ref-issue');
attachRefIssueContextPopup(refIssues);
}
2020-01-19 22:39:21 -06:00
export function attachRefIssueContextPopup(refIssues) {
for (const refIssue of refIssues) {
if (refIssue.classList.contains('ref-external-issue')) {
return;
}
2021-10-22 22:34:01 +08:00
const {owner, repo, index} = parseIssueHref(refIssue.getAttribute('href'));
2021-10-22 22:34:01 +08:00
if (!owner) return;
2020-01-19 22:39:21 -06:00
const el = document.createElement('div');
2024-04-30 16:52:46 +02:00
el.classList.add('tw-p-3');
refIssue.parentNode.insertBefore(el, refIssue.nextSibling);
2020-01-19 22:39:21 -06:00
2022-10-01 16:26:38 +02:00
const view = createApp(ContextPopup);
2020-01-19 22:39:21 -06:00
try {
2022-10-01 16:26:38 +02:00
view.mount(el);
} catch (err) {
console.error(err);
el.textContent = 'ContextPopup failed to load';
2020-01-19 22:39:21 -06:00
}
createTippy(refIssue, {
2024-04-30 16:52:46 +02:00
theme: 'default',
2022-07-19 00:33:34 +02:00
content: el,
placement: 'top-start',
2022-07-19 00:33:34 +02:00
interactive: true,
role: 'dialog',
interactiveBorder: 5,
onShow: () => {
2023-03-05 22:23:42 +08:00
el.firstChild.dispatchEvent(new CustomEvent('ce-load-context-popup', {detail: {owner, repo, index}}));
},
2020-01-19 22:39:21 -06:00
});
}
2020-01-19 22:39:21 -06:00
}