Visual editor: simple tagging capability
[fnpeditor.git] / modules / visualEditor.transformations.js
index 2d2f630..57049e7 100644 (file)
@@ -8,7 +8,42 @@ if(typeof module !== 'undefined' && module.exports) {
 
     transformations.fromXML = {
         getHTMLTree: function(xml) {
 
     transformations.fromXML = {
         getHTMLTree: function(xml) {
-            return xml;
+            var inner = $(xml).clone();
+            var toret = $('<div></div>');
+            toret.append(inner);
+            
+            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 currentTag = $(this);
+                    if(currentTag.attr('wlxml-tag'))
+                        return;
+                    var toret = $('<div></div>').attr('wlxml-tag', tagName);
+                    if(currentTag.attr('class'))
+                        toret.attr('wlxml-class', currentTag.attr('class').replace(/\./g, '-'));
+                    toret.append(currentTag.contents());
+                    return toret;
+                });
+            });
+            
+            toInline.forEach(function(tagName) {
+                tagName = tagName.toLowerCase();
+                toret.find(tagName).replaceWith(function() {
+                    var currentTag = $(this);
+                    if(currentTag.attr('wlxml-tag'))
+                        return;
+                    var toret = $('<span></span>').attr('wlxml-tag', tagName);
+                    if(currentTag.attr('class'))
+                        toret.attr('wlxml-class', currentTag.attr('class').replace(/\./g, '-'));
+                    toret.append(currentTag.contents());
+                    return toret;
+                });
+            });
+            return toret.children();
         },
         getMetaData: function(xml) {
             var toret = {};
         },
         getMetaData: function(xml) {
             var toret = {};
@@ -28,7 +63,31 @@ if(typeof module !== 'undefined' && module.exports) {
 
     transformations.toXML = {
         getXML: function(documentDescription) {
 
     transformations.toXML = {
         getXML: function(documentDescription) {
-            return documentDescription.HTMLTree;
+            
+            var inner = $(documentDescription.HTMLTree);
+            var toret = $('<div></div>');
+            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').replace(/-/g, '.'))
+                toret.append(div.contents());
+                return toret;
+            });
+            
+            var meta = $('<metadata></metadata>\n');
+            _.each(_.keys(documentDescription.metadata), function(key) {
+                meta.append('\n\t<dc:'+key+'>' + documentDescription.metadata[key] + '</dc:'+key+'>');
+            });
+            meta.append('\n');
+            
+            toret.find('metadata').replaceWith(meta);
+            
+            return toret.html();
+            
         }
     }
 
         }
     }