next.detach();
}
returned = implementation.call(this, insertion.ofNode);
- if(!options.silent && returned.sameNode(insertion.ofNode)) {
+ if(!options.silent && returned && returned.sameNode(insertion.ofNode)) {
if(!insertion.insertsNew) {
this.triggerChangeEvent('nodeDetached', {node: insertion.ofNode, parent: nodeParent, move: true});
}
},
after: INSERTION(function(node) {
+ if(this.isRoot()) {
+ return;
+ }
var next = this.next();
+
if(next && next.nodeType === Node.TEXT_NODE && node.nodeType === Node.TEXT_NODE) {
next.setText(node.getText() + next.getText());
node.detach();
}),
before: INSERTION(function(node) {
+ if(this.isRoot()) {
+ return;
+ }
var prev = this.prev();
if(prev && prev.nodeType === Node.TEXT_NODE && node.nodeType === Node.TEXT_NODE) {
prev.setText(prev.getText() + node.getText());
});
});
});
+
+ describe('Putting nodes around', function() {
+ it('will not allow to put node before or after root node', function() {
+ var doc = getDocumentFromXML('<root></root>'),
+ spy = sinon.spy(),
+ root = doc.root,
+ result;
+
+ doc.on('change', spy);
+
+ result = doc.root.before({tagName: 'test'});
+
+ expect(spy.callCount).to.equal(0);
+ expect(result).to.undefined;
+
+ result = doc.root.after({tagName: 'test'});
+
+ expect(spy.callCount).to.equal(0);
+ expect(result).to.undefined;
+
+ expect(doc.root.sameNode(root));
+ });
+ });
});
describe('Basic TextNode properties', function() {