blob: c56f7aaa678065d21da44901953cc85aa2a1c6f8 (
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
|
import { useEffect } from 'react';
type UseMutationObserverProps = {
callback: () => void;
options: MutationObserverInit;
nodeOrSelector: string | HTMLElement;
};
export const useMutationObserver = ({
callback,
options,
nodeOrSelector,
}: UseMutationObserverProps) => {
useEffect(() => {
const targetNode =
typeof nodeOrSelector === 'string'
? document.querySelector(nodeOrSelector)!
: nodeOrSelector;
const observer = new MutationObserver(callback);
observer.observe(targetNode, options);
return () => {
observer.disconnect();
};
}, [nodeOrSelector, options, callback]);
};
|