jsdom
Version:
A JavaScript implementation of many web standards
81 lines (66 loc) • 2.02 kB
JavaScript
"use strict";
const { convertNodesIntoNode } = require("../node");
class ChildNodeImpl {
remove() {
if (!this.parentNode) {
return;
}
this.parentNode._remove(this);
}
after(...nodes) {
const parent = this.parentNode;
if (parent) {
let viableNextSibling = this.nextSibling;
let idx = viableNextSibling ? nodes.indexOf(viableNextSibling) : -1;
while (idx !== -1) {
viableNextSibling = viableNextSibling.nextSibling;
if (!viableNextSibling) {
break;
}
idx = nodes.indexOf(viableNextSibling);
}
parent._preInsert(convertNodesIntoNode(this._ownerDocument, nodes), viableNextSibling);
}
}
before(...nodes) {
const parent = this.parentNode;
if (parent) {
let viablePreviousSibling = this.previousSibling;
let idx = viablePreviousSibling ? nodes.indexOf(viablePreviousSibling) : -1;
while (idx !== -1) {
viablePreviousSibling = viablePreviousSibling.previousSibling;
if (!viablePreviousSibling) {
break;
}
idx = nodes.indexOf(viablePreviousSibling);
}
parent._preInsert(
convertNodesIntoNode(this._ownerDocument, nodes),
viablePreviousSibling ? viablePreviousSibling.nextSibling : parent.firstChild
);
}
}
replaceWith(...nodes) {
const parent = this.parentNode;
if (parent) {
let viableNextSibling = this.nextSibling;
let idx = viableNextSibling ? nodes.indexOf(viableNextSibling) : -1;
while (idx !== -1) {
viableNextSibling = viableNextSibling.nextSibling;
if (!viableNextSibling) {
break;
}
idx = nodes.indexOf(viableNextSibling);
}
const node = convertNodesIntoNode(this._ownerDocument, nodes);
if (this.parentNode === parent) {
parent._replace(node, this);
} else {
parent._preInsert(node, viableNextSibling);
}
}
}
}
module.exports = {
implementation: ChildNodeImpl
};