| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- import { Directive, createVNode, render, DirectiveBinding } from 'vue'
- import ContextmenuComponent from '@/components/Contextmenu/index.vue'
- const CTX_CONTEXTMENU_HANDLER = 'CTX_CONTEXTMENU_HANDLER'
- const contextmenuListener = (el: HTMLElement, event: MouseEvent, binding: DirectiveBinding) => {
- event.stopPropagation()
- event.preventDefault()
- const menus = binding.value(el)
- if (!menus) return
- let container: HTMLDivElement | null = null
- const removeContextmenu = () => {
- if (container) {
- document.body.removeChild(container)
- container = null
- }
- el.classList.remove('contextmenu-active')
- document.body.removeEventListener('scroll', removeContextmenu)
- window.removeEventListener('resize', removeContextmenu)
- }
- const options = {
- axis: { x: event.x, y: event.y },
- el,
- menus,
- removeContextmenu,
- }
- container = document.createElement('div')
- const vm = createVNode(ContextmenuComponent, options, null)
- render(vm, container)
- document.body.appendChild(container)
- el.classList.add('contextmenu-active')
- document.body.addEventListener('scroll', removeContextmenu)
- window.addEventListener('resize', removeContextmenu)
- }
- const ContextmenuDirective: Directive = {
- mounted(el: HTMLElement, binding) {
- el[CTX_CONTEXTMENU_HANDLER] = (event: MouseEvent) => contextmenuListener(el, event, binding)
- el.addEventListener('contextmenu', el[CTX_CONTEXTMENU_HANDLER])
- },
- unmounted(el: HTMLElement) {
- if (el && el[CTX_CONTEXTMENU_HANDLER]) {
- el.removeEventListener('contextmenu', el[CTX_CONTEXTMENU_HANDLER])
- delete el[CTX_CONTEXTMENU_HANDLER]
- }
- },
- }
- export default ContextmenuDirective
|