summaryrefslogtreecommitdiff
path: root/source/helpers/simplified-element-observer.ts
blob: 821633e3c04551d8b45860e9c6053e219edb035d (plain) (blame)
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
/* eslint-disable unicorn/no-object-as-default-parameter -- We want to replace the whole default object, not just part of it */

export default function observeElement(
	element: Node | string,
	listener: MutationCallback,
	options: MutationObserverInit = {childList: true}
): MutationObserver | undefined {
	if (typeof element === 'string') {
		element = document.querySelector(element)!;
	}

	// Run on updates
	const observer = new MutationObserver(listener);
	observer.observe(element, options);

	// Run the first time
	listener.call(observer, [], observer);

	return observer;
}

export async function observeOneMutation(
	element: Element,
	options: MutationObserverInit = {
		childList: true,
		subtree: true
	}
): Promise<MutationRecord> {
	return new Promise(resolve => {
		new MutationObserver(([change], observer) => {
			observer.disconnect();
			resolve(change);
		}).observe(element, options);
	});
}