smartxml: trigger events on attr change
authorAleksander Łukasz <aleksander.lukasz@nowoczesnapolska.org.pl>
Thu, 10 Oct 2013 13:39:02 +0000 (15:39 +0200)
committerAleksander Łukasz <aleksander.lukasz@nowoczesnapolska.org.pl>
Thu, 10 Oct 2013 13:39:02 +0000 (15:39 +0200)
src/smartxml/events.js [new file with mode: 0644]
src/smartxml/smartxml.js

diff --git a/src/smartxml/events.js b/src/smartxml/events.js
new file mode 100644 (file)
index 0000000..c5e84c4
--- /dev/null
@@ -0,0 +1,18 @@
+define([
+
+], function() {
+
+'use strict';
+
+
+var ChangeEvent = function(type, meta) {
+    this.type = type;
+    this.meta = meta;
+};
+
+
+return {
+    ChangeEvent: ChangeEvent
+};
+
+});
\ No newline at end of file
index 477166b..bac53af 100644 (file)
@@ -1,6 +1,8 @@
 define([
-    'libs/jquery'
-], function($) {
+    'libs/jquery',
+    'libs/backbone',
+    'smartxml/events'
+], function($, Backbone, events) {
     
 'use strict';
 
@@ -38,6 +40,11 @@ $.extend(DocumentNode.prototype, {
         }
         node.append(this);
     },
+
+    triggerChangeEvent: function(type, metaData) {
+        var event = new events.ChangeEvent(type, $.extend({node: this}, metaData || {}));
+        this.document.trigger('change', event);
+    },
 });
 
 var ElementNode = function(nativeNode, document) {
@@ -74,7 +81,9 @@ $.extend(ElementNode.prototype, DocumentNode.prototype, {
     },
 
     setAttr: function(name, value) {
+        var oldVal = this.getAttr(name);
         this._$.attr(name, value);
+        this.triggerChangeEvent('nodeAttrChange', {attr: name, oldVal: oldVal, newVal: value});
     },
 
     getAttrs: function() {
@@ -178,7 +187,7 @@ var Document = function(xml) {
         return $document[0];
     }});
 };
-$.extend(Document.prototype, {
+$.extend(Document.prototype, Backbone.Events, {
     ElementNodeFactory: ElementNode,
     TextNodeFactory: TextNode,