X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/84f2fdcdf9bd8e62fbecaa9a47e7418cc8a4f858..4729ca360f43f0b909dadabbce5438d4910382ed:/src/smartxml/core.js diff --git a/src/smartxml/core.js b/src/smartxml/core.js index 419b175..048130e 100644 --- a/src/smartxml/core.js +++ b/src/smartxml/core.js @@ -16,6 +16,12 @@ var INSERTION = function(implementation) { if(!(this.document.containsNode(this)) || !insertion.isNew) { nodeParent = insertion.ofNode.parent(); } + if(!insertion.insertsNew && insertion.ofNode.isSurroundedByTextNodes()) { + var prev = insertion.ofNode.prev(), + next = insertion.ofNode.next(); + prev.setText(prev.getText()+next.getText()); + next.detach(); + } returned = implementation.call(this, insertion.ofNode); if(!options.silent && returned.sameNode(insertion.ofNode)) { this.triggerChangeEvent(insertion.insertsNew ? 'nodeAdded' : 'nodeMoved', {node: insertion.ofNode}, nodeParent, nodeWasContained); @@ -310,12 +316,12 @@ var textNodeTransformations = { var newElement = this.document.createDocumentNode({tagName: parentElement.getTagName(), attrs: attrs}); parentElement.after(newElement); + succeedingChildren.reverse().forEach(function(child) { + newElement.prepend(child); + }); if(suffix.length > 0) { - newElement.append({text: suffix}); + newElement.prepend({text: suffix}); } - succeedingChildren.forEach(function(child) { - newElement.append(child); - }); return {first: parentElement, second: newElement}; },