+
+ var parent, newNode;
+
+ var copyNode = function(n) {
+ var attrs = {};
+ n.getAttrs().forEach(function(attr) {
+ attrs[attr.name] = attr.value;
+ });
+
+ return node.document.createDocumentNode({
+ tagName: n.getTagName(),
+ attrs: attrs
+ });
+ };
+
+ var move = function(node, to) {
+ var copy;
+ if(!node.containsNode(newNodes.second)) {
+ to.append(node);
+ return false;
+ } else {
+ if(!node.sameNode(newNodes.second)) {
+ copy = to.append(copyNode(node));
+ node.contents().some(function(n) {
+ return move(n, copy);
+ });
+ }
+ return true;
+ }
+ };
+
+ if(isSpan) {
+ newNodes.first.parents().some(function(p) {
+ if(p.getTagName() !== 'span') {
+ parent = p;
+ return true;
+ }
+ });
+ newNode = parent.before({tagName: parent.getTagName(), attrs: {'class': parent.getClass()}});
+ parent.contents().some(function(n) {
+ return move(n, newNode);
+ });
+ // span can't be the last node
+ newNode.append({'text': ''});
+ if(newNodes.second.contents()[0].getText().length === 0) {
+ var textNode = newNodes.second.contents()[0];
+ newNodes.second.detach();
+ newNodes.second = parent;
+ emptyText = newNodes.second.append(textNode);
+ }
+ }
+
+ var newNodeText = newNodes.second.contents()[0].getText();
+ if(newNodes.second.is({tagName: 'header'}) && newNodeText === '') {
+ newNodes.second = newNodes.second.setTag('div');
+ newNodes.second.setClass('p');
+ }
+