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

50 lines
1.2 KiB
JavaScript
Raw Normal View History

import Vue from 'vue';
2020-02-11 19:53:18 -06:00
import ContextPopup from '../components/ContextPopup.vue';
2021-10-22 22:34:01 +08:00
import {parseIssueHref} from '../utils.js';
2020-02-11 19:53:18 -06:00
export default function initContextPopups() {
2020-01-19 22:39:21 -06:00
const refIssues = $('.ref-issue');
if (!refIssues.length) return;
refIssues.each(function () {
if ($(this).hasClass('ref-external-issue')) {
return;
}
2021-10-22 22:34:01 +08:00
const {owner, repo, index} = parseIssueHref($(this).attr('href'));
if (!owner) return;
2020-01-19 22:39:21 -06:00
const el = document.createElement('div');
el.className = 'ui custom popup hidden';
el.innerHTML = '<div></div>';
this.parentNode.insertBefore(el, this.nextSibling);
2020-01-19 22:39:21 -06:00
const View = Vue.extend({
render: (createElement) => createElement(ContextPopup),
});
2020-01-19 22:39:21 -06:00
const view = new View();
2020-01-19 22:39:21 -06:00
try {
view.$mount(el.firstChild);
} catch (err) {
console.error(err);
el.textContent = 'ContextPopup failed to load';
2020-01-19 22:39:21 -06:00
}
$(this).popup({
2020-01-19 22:39:21 -06:00
variation: 'wide',
delay: {
show: 250
},
onShow: () => {
view.$emit('load-context-popup', {owner, repo, index}, () => {
$(this).popup('reposition');
});
},
popup: $(el),
2020-01-19 22:39:21 -06:00
});
});
}