var inner = $(xml).clone();
var toret = $('<div></div>');
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 suffix = tagName !== 'div' ? tagName : 'block';
- var toret = $('<div></div>').attr('wlxml-tag', suffix);
- var currentTag = $(this);
- if(currentTag.attr('class'))
- toret.attr('wlxml-class', currentTag.attr('class'));
- toret.append(currentTag.contents());
- return toret;
+ var transform = function(tags, replacingTagName) {
+ tags.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 = $('<' + replacingTagName + '>').attr('wlxml-tag', tagName);
+ for(var i = 0; i < this.attributes.length; i++) {
+ var attr = this.attributes.item(i);
+ var value = attr.name === 'class' ? attr.value.replace(/\./g, '-') : attr.value;
+ toret.attr('wlxml-' + attr.name, value)
+ }
+ toret.append(currentTag.contents());
+ return toret;
+ });
});
- });
+ }
- toInline.forEach(function(tagName) {
- tagName = tagName.toLowerCase();
- toret.find(tagName).replaceWith(function() {
- 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;
- });
- });
+ transform(toBlock, 'div');
+ transform(toInline, 'span');
+
return toret.children();
},
getMetaData: function(xml) {
toret.find('div, span').replaceWith(function() {
var div = $(this);
var tagName = div.attr('wlxml-tag');
- return $('<'+tagName+'>').append(div.contents());
+ var toret = $('<'+tagName+'>');
+
+ for(var i = 0; i < this.attributes.length; i++) {
+ var attr = this.attributes.item(i);
+ var split = attr.name.split('-')
+ console.log(split);
+ if(split[0] !== 'wlxml' || (split.length > 1 && split[1] === 'tag'))
+ continue;
+ var wlxmlName = split.splice(1).join('-');
+ var value = wlxmlName === 'class' ? attr.value.replace(/-/g, '.') : attr.value;
+ console.log(name + ': ' + value);
+ toret.attr(wlxmlName, value);
+ }
+
+ toret.append(div.contents());
+ return toret;
});
- var meta = $('<metadata>');
+ var meta = $('<metadata></metadata>\n');
_.each(_.keys(documentDescription.metadata), function(key) {
- meta.append($('<dc:'+key+'>' + documentDescription.metadata[key] + '</dc:'+key+'>'));
+ meta.append('\n\t<dc:'+key+'>' + documentDescription.metadata[key] + '</dc:'+key+'>');
});
+ meta.append('\n');
- toret.find('document').prepend(meta);
+ toret.find('metadata').replaceWith(meta);
return toret.html();