define([
+ 'libs/jquery',
+ 'libs/underscore',
'smartxml/smartxml'
-], function(smartxml) {
+], function($, _, smartxml) {
'use strict';
//
+var AttributesList = function() {};
+AttributesList.prototype = Object.create({});
+AttributesList.prototype.keys = function() {
+ return _.keys(this);
+};
+
+
var WLXMLElementNode = function(nativeNode, document) {
smartxml.ElementNode.call(this, nativeNode, document);
};
$.extend(WLXMLElementNode.prototype, smartxml.ElementNode.prototype, {
getClass: function() {
- return this.getAttr('class');
+ return this.getAttr('class') || '';
},
setClass: function(klass) {
return this.setAttr('class', klass);
},
getMetaAttributes: function() {
- var toret = [];
- this.getAttrs().forEach(function(attr) {
- if(isMetaAttribute(attr.name)) {
- toret.push({name: attr.name.substr(5), value: attr.value});
+ var toret = new AttributesList(),
+ classParts = [''].concat(this.getClass().split('.')),
+ classCurrent, classDesc;
+
+ classParts.forEach(function(part) {
+ classCurrent = classCurrent ? classCurrent + '.' + part : part;
+ classDesc = this.document.options.wlxmlClasses[classCurrent];
+ if(classDesc) {
+ _.keys(classDesc.attrs).forEach(function(attrName) {
+ toret[attrName] = _.extend({value: this.getAttr('meta-' + attrName)}, classDesc.attrs[attrName]);
+ }.bind(this));
}
- });
+ }.bind(this));
return toret;
},
+ setMetaAttribute: function(key, value) {
+ this.setAttr('meta-'+key, value);
+ },
getOtherAttributes: function() {
var toret = {};
this.getAttrs().forEach(function(attr) {
-var WLXMLDocument = function(xml) {
+var WLXMLDocument = function(xml, options) {
smartxml.Document.call(this, xml);
+ this.options = options;
};
var formatter_prefix = '_wlxml_formatter_';
ElementNodeFactory: WLXMLElementNode,
loadXML: function(xml) {
- smartxml.Document.prototype.loadXML.call(this, xml);
+ smartxml.Document.prototype.loadXML.call(this, xml, {silent: true});
$(this.dom).find(':not(iframe)').addBack().contents()
.filter(function() {return this.nodeType === Node.TEXT_NODE;})
.each(function() {
} else if(where === 'below') {
target = next ? $(next) : elParent;
key = next ? 'orig_before' : 'orig_end';
- } else { throw new Object;}
+ } else { throw new Error();}
target.data(formatter_prefix + key, toAdd);
if(transformed !== undefined) {
if(original !== undefined) {
target.data(formatter_prefix + key + '_original', original);
}
- }
+ };
text.transformed = text.trimmed;
endingWhiteSpace = endingMatch ? endingMatch[0] : null;
if(endingWhiteSpace) {
- if(text.transformed[text.transformed.length - 1] === ' ' && endingWhiteSpace[0] === ' ')
+ if(text.transformed[text.transformed.length - 1] === ' ' && endingWhiteSpace[0] === ' ') {
endingWhiteSpace = endingWhiteSpace.substr(1);
+ }
addInfo(endingWhiteSpace, 'below', !text.trimmed ? text.transformed : undefined, !text.trimmed ? text.original : undefined);
}
if(startingWhiteSpace && text.trimmed) {
- if(text.transformed[0] === ' ' && startingWhiteSpace[startingWhiteSpace.length-1] === ' ')
+ if(text.transformed[0] === ' ' && startingWhiteSpace[startingWhiteSpace.length-1] === ' ') {
startingWhiteSpace = startingWhiteSpace.substr(0, startingWhiteSpace.length -1);
+ }
addInfo(startingWhiteSpace, 'above', !text.trimmed ? text.transformed : undefined, !text.trimmed ? text.original : undefined);
}
//}
});
+var wlxmlClasses = {
+ 'uri': {
+ attrs: {uri: {type: 'string'}}
+ }
+};
return {
- WLXMLDocumentFromXML: function(xml) {
- return new WLXMLDocument(xml);
+ WLXMLDocumentFromXML: function(xml, options) {
+ options = _.extend({wlxmlClasses: wlxmlClasses}, options);
+ return new WLXMLDocument(xml, options);
},
WLXMLElementNodeFromXML: function(xml) {