ant-design/components/watermark/useMutationObserver.ts
lijianan 7e821bc8f6
chore: code style optimization (#39405)
* chore: code style optimization

* fix lint

* add size-limit
2022-12-08 22:32:37 +08:00

30 lines
753 B
TypeScript

import { useEffect, useRef } from 'react';
export default function useMutationObserver() {
const instance = useRef<MutationObserver>();
const destroyObserver = () => {
if (instance.current) {
instance.current.takeRecords();
instance.current.disconnect();
instance.current = undefined;
}
};
const createObserver = (target: Node, callback: MutationCallback) => {
if (MutationObserver) {
destroyObserver();
instance.current = new MutationObserver(callback);
instance.current.observe(target, {
childList: true,
subtree: true,
attributeFilter: ['style', 'class'],
});
}
};
useEffect(() => destroyObserver, []);
return { createObserver, destroyObserver };
}