'libs/underscore',
'smartxml/smartxml',
'smartxml/transformations',
- 'wlxml/extensions/metadata/metadata'
-], function($, _, smartxml, transformations, metadataExtension) {
+ 'wlxml/extensions/metadata/metadata',
+ 'wlxml/extensions/comments/comments',
+ 'wlxml/extensions/edumed/edumed'
+], function($, _, smartxml, transformations, metadataExtension, commentExtension, edumedExtension) {
'use strict';
me.concat(this.parents()).some(function(node) {
if(node.is(query)) {
toret = node;
- return true;
}
- });
+ return !!toret || (!node.sameNode(this) && node.isContextRoot());
+ }.bind(this));
+
return toret;
},
-};
-
-var AttributesList = function() {};
-AttributesList.prototype = Object.create({});
-AttributesList.prototype.keys = function() {
- return _.keys(this);
+ isContextRoot: function() {
+ var me = this.nodeType === Node.ELEMENT_NODE ? [this] : [],
+ toret = false;
+ if(!this.parent()) {
+ return true;
+ }
+ me.concat(this.parents()).some(function(node) {
+ if(_.isFunction(node.object.isContextRoot) && node.object.isContextRoot(this)) {
+ toret = true;
+ return true;
+ }
+ }.bind(this));
+ return toret;
+ }
};
var getClassLists = function(klassName) {
});
instance.object = Object.create(_.extend({}, methods, transformations));
_.keys(methods).concat(_.keys(transformations)).forEach(function(key) {
- instance.object[key] = _.bind(instance.object[key], instance);
+ if(_.isFunction(instance.object[key])) {
+ instance.object[key] = _.bind(instance.object[key], instance);
+ }
});
};
return (_.isUndefined(query.klass) || this.getClass().substr(0, query.klass.length) === query.klass) &&
(_.isUndefined(query.tagName) || this.getTagName() === query.tagName);
},
- getMetaAttributes: function() {
- 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(attrName)}, classDesc.attrs[attrName]);
- }.bind(this));
- }
+ hasChild: function(query) {
+ return this.contents().some(function(child) {
+ return child.is(query);
}.bind(this));
- return toret;
- },
- setMetaAttribute: function(key, value) {
- this.setAttr(key, value);
- },
- getOtherAttributes: function() {
- var toret = {},
- node = this;
- this.getAttrs().forEach(function(attr) {
- if(attr.name !== 'class' && !node.isMetaAttribute(attr.name)) {
- toret[attr.name] = {value: attr.value};
- }
- });
- return toret;
- },
- isMetaAttribute: function(attrName) {
- return attrName !== 'class' &&_.contains(_.keys(this.getMetaAttributes()), attrName);
},
_getXMLDOMToDump: function() {
$(this).prepend(metaNode);
}
}
-
});
-
-
return DOM;
}
});
-// WLXMLElementNode.prototype.transformations.register(transformations.createContextTransformation({
-// name: 'wlxml.setMetaAttribute',
-// impl: function(args) {
-// this.setMetaAttribute(args.name, args.value);
-// },
-// getChangeRoot: function() {
-// return this.context;
-// }
-// }));
-
-
var WLXMLDocumentNode = function() {
smartxml.DocumentNode.apply(this, arguments);
smartxml.TextNode.apply(this, arguments);
};
WLXMLTextNode.prototype = Object.create(smartxml.TextNode.prototype);
-$.extend(WLXMLTextNode.prototype, WLXMLDocumentNodeMethods);
+$.extend(WLXMLTextNode.prototype, WLXMLDocumentNodeMethods, {
+ is: function() { return false; }
+});
var WLXMLDocument = function(xml, options) {
this.classMethods = {};
this.classTransformations = {};
- smartxml.Document.call(this, xml, [metadataExtension]);
+ smartxml.Document.call(this, xml, [metadataExtension, commentExtension, edumedExtension]);
this.options = options;
};
},
registerExtension: function(extension) {
- //debugger;
smartxml.Document.prototype.registerExtension.call(this, extension);
var doc = this;
});
-var wlxmlClasses = {
- 'link': {
- attrs: {href: {type: 'string'}}
- }
-};
-
-
return {
WLXMLDocumentFromXML: function(xml, options, Factory) {
- options = _.extend({wlxmlClasses: wlxmlClasses}, options);
Factory = Factory || WLXMLDocument;
return new Factory(xml, options);
},
-
WLXMLElementNodeFromXML: function(xml) {
return this.WLXMLDocumentFromXML(xml).root;
},