- ✅ 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
84 lines
2.9 KiB
JavaScript
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
|