UNPKG

vevet

Version:

Vevet is a JavaScript library for creative development that simplifies crafting rich interactions like split text animations, carousels, marquees, preloading, and more.

40 lines 1.48 kB
import { doc } from '../../../internal/env'; export function saveInitialNodes(root) { const flatArray = []; function copy(node) { // Add the current node and its parent to the array flatArray.push({ node, cssText: node instanceof HTMLElement ? node.style.cssText : null, parent: node.parentNode, }); // Recursively process child nodes node.childNodes.forEach((child) => copy(child)); } // Start recursion with the root node root.childNodes.forEach((child) => copy(child)); // Return a function to restore the initial nodes return { restore: () => { const fragment = doc.createDocumentFragment(); flatArray.forEach((element) => { const { node, cssText } = element; if (node instanceof HTMLElement && cssText) { node.style.cssText = cssText; } while (node.childNodes[0]) { node.childNodes[0].remove(); } if (element.parent) { const parent = element.parent === root ? fragment : element.parent; parent.appendChild(element.node); } }); while (root.childNodes[0]) { root.childNodes[0].remove(); } root.appendChild(fragment); }, }; } //# sourceMappingURL=saveInitialNodes.js.map