toret.find('metadata').remove();
var toBlock = ['div', 'document', 'section', 'header'];
- var toInline = ['aside'];
+ var toInline = ['aside', 'span'];
toBlock.forEach(function(tagName) {
tagName = tagName.toLowerCase();
console.log('running ' + tagName);
toret.find(tagName).replaceWith(function() {
- var suffix = tagName !== 'div' ? tagName : 'block';
- return $('<div></div>').addClass('rng-' + suffix).append($(this).contents());
+ var toret = $('<div></div>').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 node = this;
- return $('<span></span>').addClass('rng-' + tagName).append($(this).contents());
+ var currentTag = $(this);
+ var toret = $('<span></span>').attr('wlxml-tag', tagName);
+ if(currentTag.attr('class'))
+ toret.attr('wlxml-class', currentTag.attr('class'));
+ toret.append(currentTag.contents());
+ return toret;
});
});
return toret.children();
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'))
+ toret.append(div.contents());
+ return toret;
+ });
+
+ var meta = $('<metadata>');
+ _.each(_.keys(documentDescription.metadata), function(key) {
+ meta.append($('<dc:'+key+'>' + documentDescription.metadata[key] + '</dc:'+key+'>'));
+ });
+
+ toret.find('document').prepend(meta);
+
+ return toret.html();
+
}
}