codigo0/node_modules/happy-dom/lib/nodes/child-node/ChildNodeUtility.js
planetazuzu 5d7a6500fe refactor: Fase 1 - Clean Architecture, refactorización modular y eliminación de duplicidades
-  Ticket 1.1: Estructura Clean Architecture en backend
-  Ticket 1.2: Schemas Zod compartidos
-  Ticket 1.3: Refactorización drugs.ts (1362 → 8 archivos modulares)
-  Ticket 1.4: Refactorización procedures.ts (3583 → 6 archivos modulares)
-  Ticket 1.5: Eliminación de duplicidades (~50 líneas)

Cambios principales:
- Creada estructura Clean Architecture en backend/src/
- Schemas Zod compartidos en backend/src/shared/schemas/
- Refactorización modular de drugs y procedures
- Utilidades genéricas en src/utils/ (filter, validation)
- Eliminados scripts obsoletos y documentación antigua
- Corregidos errores: QueryClient, import test-error-handling
- Build verificado y funcionando correctamente
2026-01-25 21:09:47 +01:00

84 lines
2.9 KiB
JavaScript

import DOMException from '../../exception/DOMException.js';
import * as PropertySymbol from '../../PropertySymbol.js';
import Node from '../node/Node.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 (node instanceof Node) {
parent.insertBefore(node, childNode);
}
else {
parent.insertBefore(parent[PropertySymbol.ownerDocument].createTextNode(String(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 (node instanceof Node) {
parent.insertBefore(node, childNode);
}
else {
parent.insertBefore(parent[PropertySymbol.ownerDocument].createTextNode(String(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) {
const insertedNode = node instanceof Node
? node
: parent[PropertySymbol.ownerDocument].createTextNode(String(node));
if (!nextSibling) {
parent.appendChild(insertedNode);
}
else {
parent.insertBefore(insertedNode, nextSibling);
}
}
}
}
//# sourceMappingURL=ChildNodeUtility.js.map