move method
Implementation
void move(DomRenderObject parent, web.Node targetNode, web.Node? afterNode) {
assert(parent == this.parent, 'Cannot move fragment to a different parent.');
assert(isAttached, 'Cannot move fragment that is not attached to a parent.');
if (kVerboseMode) {
print("Move fragment $node to $targetNode after $afterNode");
}
if (firstChildNode == null) {
// If fragment is empty, nothing to move.
return;
}
assert(lastChildNode != null, 'Non-empty attached fragments must have a valid last child reference.');
if (firstChildNode!.previousSibling == afterNode && firstChildNode!.parentNode == targetNode) {
return;
}
web.Node? currentNode = lastChildNode;
web.Node? beforeNode = afterNode == null ? targetNode.childNodes.item(0) : afterNode.nextSibling;
// Move nodes in reverse order for efficient insertion.
while (currentNode != null) {
final prevNode = currentNode != firstChildNode ? currentNode.previousSibling : null;
// Attach to new parent
targetNode.insertBefore(currentNode, beforeNode);
beforeNode = currentNode;
currentNode = prevNode;
}
assert(
firstChildNode!.previousSibling == afterNode,
'First child node should have been placed after the specified node.',
);
}