import DOMException from '../../exception/DOMException.js'; import * as PropertySymbol from '../../PropertySymbol.js'; import XMLParser from '../../xml-parser/XMLParser.js'; /** * Child node utility. */ export default class ChildNodeUtility { /** * Removes the node from its parent. * * @param childNode Child node. */ static remove(childNode) { if (childNode[PropertySymbol.parentNode]) { childNode[PropertySymbol.parentNode].removeChild(childNode); } } /** * The Node.replaceWith() method replaces this Node in the children list of its parent with a set of Node or DOMString objects. * * @param childNode Child node. * @param nodes List of Node or DOMString. */ static replaceWith(childNode, ...nodes) { const parent = childNode[PropertySymbol.parentNode]; if (!parent) { throw new DOMException('This element has no parent node.'); } for (const node of nodes) { if (typeof node === 'string') { const newChildNodes = (XMLParser.parse(childNode[PropertySymbol.ownerDocument], node))[PropertySymbol.childNodes].slice(); for (const newChildNode of newChildNodes) { parent.insertBefore(newChildNode, childNode); } } else { parent.insertBefore(node, childNode); } } parent.removeChild(childNode); } /** * Inserts a set of Node or DOMString objects in the children list of this ChildNode's parent, just before this ChildNode. DOMString objects are inserted as equivalent Text nodes. * * @param childNode Child node. * @param nodes List of Node or DOMString. */ static before(childNode, ...nodes) { const parent = childNode[PropertySymbol.parentNode]; if (!parent) { return; } for (const node of nodes) { if (typeof node === 'string') { const newChildNodes = (XMLParser.parse(childNode[PropertySymbol.ownerDocument], node))[PropertySymbol.childNodes].slice(); for (const newChildNode of newChildNodes) { parent.insertBefore(newChildNode, childNode); } } else { parent.insertBefore(node, childNode); } } } /** * Inserts a set of Node or DOMString objects in the children list of this ChildNode's parent, just after this ChildNode. DOMString objects are inserted as equivalent Text nodes. * * @param childNode Child node. * @param nodes List of Node or DOMString. */ static after(childNode, ...nodes) { const parent = childNode[PropertySymbol.parentNode]; if (!parent) { return; } const nextSibling = childNode.nextSibling; for (const node of nodes) { if (typeof node === 'string') { const newChildNodes = (XMLParser.parse(childNode[PropertySymbol.ownerDocument], node))[PropertySymbol.childNodes].slice(); for (const newChildNode of newChildNodes) { if (!nextSibling) { parent.appendChild(newChildNode); } else { parent.insertBefore(newChildNode, nextSibling); } } } else if (!nextSibling) { parent.appendChild(node); } else { parent.insertBefore(node, nextSibling); } } } } //# sourceMappingURL=ChildNodeUtility.js.map