smartxml: TextNode.before/after
authorAleksander Łukasz <aleksander.lukasz@nowoczesnapolska.org.pl>
Thu, 24 Oct 2013 11:32:11 +0000 (13:32 +0200)
committerAleksander Łukasz <aleksander.lukasz@nowoczesnapolska.org.pl>
Thu, 24 Oct 2013 11:32:11 +0000 (13:32 +0200)
src/smartxml/smartxml.js
src/smartxml/smartxml.test.js

index 2e507db..47e2b2e 100644 (file)
@@ -36,8 +36,16 @@ $.extend(DocumentNode.prototype, {
         return this.nativeNode.parentNode ? this.document.createElementNode(this.nativeNode.parentNode) : null;
     },
 
+    after: function(node) {
+        node = node instanceof ElementNode ? node : this.document.createElementNode(node);
+        this._$.after(node.nativeNode);
+        return node;
+    },
+
     before: function(node) {
+        node = node instanceof ElementNode ? node : this.document.createElementNode(node);
         this._$.before(node.nativeNode);
+        return node;
     },
 
     wrapWith: function(node) {
@@ -248,7 +256,11 @@ $.extend(Document.prototype, Backbone.Events, {
 
     createElementNode: function(from) {
         if(!(from instanceof HTMLElement)) {
-            from = $('<' + from.tagName + '>')[0];
+            if(from.text) {
+                from = document.createTextNode(from.text);
+            } else {
+                from = $('<' + from.tagName + '>')[0];
+            }
         }
         return new this.ElementNodeFactory(from, this);
     },
index 58156c2..31d854a 100644 (file)
@@ -179,6 +179,20 @@ describe('smartxml', function() {
             expect(event.type).to.equal('nodeTextChange');
         });
 
+        it('puts NodeElement after itself', function() {
+            var node = elementNodeFromXML('<div>Alice</div>'),
+                textNode = node.contents()[0],
+                returned = textNode.after({tagName:'div'});
+            expect(returned.sameNode(node.contents()[1])).to.be.true;
+        });
+
+        it('puts NodeElement before itself', function() {
+            var node = elementNodeFromXML('<div>Alice</div>'),
+                textNode = node.contents()[0],
+                returned = textNode.before({tagName:'div'});
+            expect(returned.sameNode(node.contents()[0])).to.be.true;
+        });
+
         describe('Wrapping TextNode contents', function() {
 
             it('wraps DocumentTextElement', function() {