summaryrefslogtreecommitdiff
path: root/source/helpers/simplified-element-observer.ts
blob: 07b2f2e691e5416b007094f1b0025e8577513480 (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
/* 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);
	});
}