All files / lib mutations.js

0% Statements 0/19
0% Branches 0/2
0% Functions 0/9
0% Lines 0/18

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61                                                                                                                         
// https://github.com/PaulMaly/svelte-actions-mutation/blob/master/src/index.js
 
/**
 *
 * @param {HTMLElement} node
 * @param {MutationObserverInit & Partial<Record<`on${MutationRecordType}`, (m: MutationRecord) => void>>} options
 * @returns
 */
export function mutationobserver(node, options) {
	/** @type {MutationObserver|null}  */
	let observer = null;
 
	function update(options = {}) {
		destroy();
		observer = new MutationObserver((mutations) => {
			// @ts-ignore
			mutations.forEach((m) => options[`on${m.type}`]?.(m));
		});
		observer.observe(node, options);
	}
 
	function destroy() {
		observer?.disconnect();
		observer = null;
	}
 
	update(options);
 
	return { update, destroy };
}
 
// Same thing but for ResizeObserver
 
/**
 *
 * @param {HTMLElement} node
 * @param {{onresize?: (entries: ResizeObserverEntry[], observer: ResizeObserver) => void}} options
 * @returns
 */
export function resizeobserver(node, options) {
	/** @type {ResizeObserver|null}  */
	let observer = null;
 
	function update(options = {}) {
		destroy();
		observer = new ResizeObserver((entries, observer) => {
			options.onresize?.(entries, observer);
		});
		observer.observe(node);
	}
 
	function destroy() {
		observer?.disconnect();
		observer = null;
	}
 
	update(options);
 
	return { update, destroy };
}