mirror of
https://github.com/koel/koel
synced 2025-01-12 04:38:44 +00:00
19 lines
661 B
TypeScript
19 lines
661 B
TypeScript
|
import { Directive } from 'vue'
|
||
|
|
||
|
const toggleClasses = (el: HTMLElement) => {
|
||
|
el.classList.toggle('fade-top', el.scrollTop !== 0)
|
||
|
el.classList.toggle('fade-bottom', el.scrollTop + el.clientHeight !== el.scrollHeight)
|
||
|
}
|
||
|
|
||
|
const observeVisibility = (el: HTMLElement, callback: Closure) => {
|
||
|
const observer = new IntersectionObserver(entries => entries.forEach(entry => entry.isIntersecting && callback()))
|
||
|
observer.observe(el)
|
||
|
}
|
||
|
|
||
|
export const overflowFade: Directive = {
|
||
|
mounted: async (el: HTMLElement) => {
|
||
|
observeVisibility(el, () => toggleClasses(el))
|
||
|
el.addEventListener('scroll', () => requestAnimationFrame(() => toggleClasses(el)))
|
||
|
}
|
||
|
}
|