UNPKG

@kangc/v-md-editor

Version:
73 lines (62 loc) 1.7 kB
// Modified from https://github.com/ElemeFE/element/blob/dev/src/utils/clickoutside.js const nodeList = []; const ctx = '@@clickoutsideContext'; const isServer = typeof window === 'undefined'; let startClick; let seed = 0; if (!isServer) { document.addEventListener('mousedown', (e) => { startClick = e; }); document.addEventListener('mouseup', (e) => { nodeList.forEach((node) => node[ctx].documentHandler(e, startClick)); }); } function createDocumentHandler(el, binding, vnode) { return function (mouseup = {}, mousedown = {}) { if ( !vnode || !binding || !binding.instance || !mouseup.target || !mousedown.target || el.contains(mouseup.target) || el.contains(mousedown.target) || el === mouseup.target ) { return; } if (binding.arg && el[ctx].methodName && binding.instance[el[ctx].methodName]) { binding.instance[el[ctx].methodName](); } else { el[ctx].bindingFn && el[ctx].bindingFn(); } }; } export default { beforeMount(el, binding, vnode) { nodeList.push(el); const id = seed++; el[ctx] = { id, documentHandler: createDocumentHandler(el, binding, vnode), methodName: binding.arg, bindingFn: binding.value, }; }, updated(el, binding, vnode) { el[ctx].documentHandler = createDocumentHandler(el, binding, vnode); el[ctx].methodName = binding.arg; el[ctx].bindingFn = binding.value; }, unmounted(el) { const len = nodeList.length; for (let i = 0; i < len; i++) { if (nodeList[i][ctx].id === el[ctx].id) { nodeList.splice(i, 1); break; } } delete el[ctx]; }, };