koel/resources/assets/js/directives/clickaway.js

20 lines
450 B
JavaScript
Raw Normal View History

2016-06-25 16:05:24 +00:00
/**
* A fork of https://github.com/simplesmiler/vue-clickaway.
* Trigger a function if the user clicks out of the bound element.
* @type {Object}
*/
export const clickawayDirective = {
bind(el, { value }) {
if (typeof value !== 'function') {
console.warn(`Expect a function, got ${value}`);
return;
}
document.addEventListener('click', e => {
if (!el.contains(e.target)) {
value();
}
});
},
}