summaryrefslogtreecommitdiff
path: root/packages/frontend/src/directives/appear.ts
blob: 599f2378d1d444b581d58ebbfb4ad3233283498f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/*
 * SPDX-FileCopyrightText: syuilo and misskey-project
 * SPDX-License-Identifier: AGPL-3.0-only
 */

import { throttle } from 'throttle-debounce';
import type { Directive } from 'vue';
import type { Awaitable } from '@/types/misc.js';

interface HTMLElementWithObserver extends HTMLElement {
	_observer_?: IntersectionObserver;
}

export const appearDirective = {
	mounted(src, binding) {
		const fn = binding.value;
		if (fn == null) return;

		const check = throttle<IntersectionObserverCallback>(500, (entries) => {
			if (entries.some(entry => entry.isIntersecting)) {
				fn();
			}
		});

		const observer = new IntersectionObserver(check);

		observer.observe(src);

		src._observer_ = observer;
	},

	unmounted(src) {
		if (src._observer_) src._observer_.disconnect();
	},
} as Directive<HTMLElementWithObserver, (() => Awaitable<void>) | null | undefined>;