mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 02:04:11 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import {queryElems} from '../utils/dom.ts';
 | 
						|
import {parseIssueHref} from '../utils.ts';
 | 
						|
import {createApp} from 'vue';
 | 
						|
import ContextPopup from '../components/ContextPopup.vue';
 | 
						|
import {createTippy, getAttachedTippyInstance} from '../modules/tippy.ts';
 | 
						|
 | 
						|
export function initMarkupRefIssue(el: HTMLElement) {
 | 
						|
  queryElems(el, '.ref-issue', (el) => {
 | 
						|
    el.addEventListener('mouseenter', showMarkupRefIssuePopup);
 | 
						|
    el.addEventListener('focus', showMarkupRefIssuePopup);
 | 
						|
  });
 | 
						|
}
 | 
						|
 | 
						|
export function showMarkupRefIssuePopup(e: MouseEvent | FocusEvent) {
 | 
						|
  const refIssue = e.currentTarget as HTMLElement;
 | 
						|
  if (getAttachedTippyInstance(refIssue)) return;
 | 
						|
  if (refIssue.classList.contains('ref-external-issue')) return;
 | 
						|
 | 
						|
  const issuePathInfo = parseIssueHref(refIssue.getAttribute('href'));
 | 
						|
  if (!issuePathInfo.ownerName) return;
 | 
						|
 | 
						|
  const el = document.createElement('div');
 | 
						|
  const tippy = createTippy(refIssue, {
 | 
						|
    theme: 'default',
 | 
						|
    content: el,
 | 
						|
    trigger: 'mouseenter focus',
 | 
						|
    placement: 'top-start',
 | 
						|
    interactive: true,
 | 
						|
    role: 'dialog',
 | 
						|
    interactiveBorder: 5,
 | 
						|
    // onHide() { return false }, // help to keep the popup and debug the layout
 | 
						|
    onShow: () => {
 | 
						|
      const view = createApp(ContextPopup, {
 | 
						|
        // backend: GetIssueInfo
 | 
						|
        loadIssueInfoUrl: `${window.config.appSubUrl}/${issuePathInfo.ownerName}/${issuePathInfo.repoName}/issues/${issuePathInfo.indexString}/info`,
 | 
						|
      });
 | 
						|
      view.mount(el);
 | 
						|
    },
 | 
						|
  });
 | 
						|
  tippy.show();
 | 
						|
}
 |