vuetify
Version:
Vue Material Component Framework
46 lines (39 loc) • 1.24 kB
JavaScript
function inserted(el, binding) {
if (typeof window === 'undefined' || !('IntersectionObserver' in window)) return;
const modifiers = binding.modifiers || {};
const value = binding.value;
const {
handler,
options
} = typeof value === 'object' ? value : {
handler: value,
options: {}
};
const observer = new IntersectionObserver((entries = [], observer) => {
/* istanbul ignore if */
if (!el._observe) return; // Just in case, should never fire
const isIntersecting = entries.some(entry => entry.isIntersecting); // If is not quiet or has already been
// initted, invoke the user callback
if (handler && (!modifiers.quiet || el._observe.init) && (!modifiers.once || isIntersecting || !el._observe.init)) {
handler(entries, observer, isIntersecting);
}
if (isIntersecting && modifiers.once) unbind(el);else el._observe.init = true;
}, options);
el._observe = {
init: false,
observer
};
observer.observe(el);
}
function unbind(el) {
/* istanbul ignore if */
if (!el._observe) return;
el._observe.observer.unobserve(el);
delete el._observe;
}
export const Intersect = {
inserted,
unbind
};
export default Intersect;
//# sourceMappingURL=index.js.map