X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/56ab6eadd6887a63a83c768abf3c02393d1f4a28..6c3dfb35e4a92d05de9ffcfd7d6e23a9a9cb32fe:/modules/visualEditor.transformations.js diff --git a/modules/visualEditor.transformations.js b/modules/visualEditor.transformations.js index 2d2f630..7374f2e 100644 --- a/modules/visualEditor.transformations.js +++ b/modules/visualEditor.transformations.js @@ -8,7 +8,39 @@ if(typeof module !== 'undefined' && module.exports) { transformations.fromXML = { getHTMLTree: function(xml) { - return xml; + var inner = $(xml).clone(); + var toret = $('
'); + toret.append(inner); + toret.find('metadata').remove(); + + var toBlock = ['div', 'document', 'section', 'header']; + var toInline = ['aside', 'span']; + + toBlock.forEach(function(tagName) { + tagName = tagName.toLowerCase(); + console.log('running ' + tagName); + toret.find(tagName).replaceWith(function() { + var toret = $('
').attr('wlxml-tag', tagName); + var currentTag = $(this); + if(currentTag.attr('class')) + toret.attr('wlxml-class', currentTag.attr('class')); + toret.append(currentTag.contents()); + return toret; + }); + }); + + toInline.forEach(function(tagName) { + tagName = tagName.toLowerCase(); + toret.find(tagName).replaceWith(function() { + var currentTag = $(this); + var toret = $('').attr('wlxml-tag', tagName); + if(currentTag.attr('class')) + toret.attr('wlxml-class', currentTag.attr('class')); + toret.append(currentTag.contents()); + return toret; + }); + }); + return toret.children(); }, getMetaData: function(xml) { var toret = {}; @@ -28,7 +60,30 @@ if(typeof module !== 'undefined' && module.exports) { transformations.toXML = { getXML: function(documentDescription) { - return documentDescription.HTMLTree; + + var inner = $(documentDescription.HTMLTree); + var toret = $('
'); + toret.append(inner); + + toret.find('div, span').replaceWith(function() { + var div = $(this); + var tagName = div.attr('wlxml-tag'); + var toret = $('<'+tagName+'>'); + if(div.attr('wlxml-class')) + toret.attr('class', div.attr('wlxml-class')) + toret.append(div.contents()); + return toret; + }); + + var meta = $(''); + _.each(_.keys(documentDescription.metadata), function(key) { + meta.append($('' + documentDescription.metadata[key] + '')); + }); + + toret.find('document').prepend(meta); + + return toret.html(); + } }