var INSERTION = function(implementation) {
var toret = function(node) {
var insertion = this.getNodeInsertion(node),
+ nodeWasContained = this.document.containsNode(insertion.ofNode),
nodeParent;
if(!(this.document.containsNode(this))) {
nodeParent = insertion.ofNode.parent();
}
implementation.call(this, insertion.ofNode.nativeNode);
- this.triggerChangeEvent(insertion.insertsNew ? 'nodeAdded' : 'nodeMoved', {node: insertion.ofNode}, nodeParent);
+ this.triggerChangeEvent(insertion.insertsNew ? 'nodeAdded' : 'nodeMoved', {node: insertion.ofNode}, nodeParent, nodeWasContained);
return insertion.ofNode;
};
return toret;
}
},
- triggerChangeEvent: function(type, metaData, origParent) {
+ triggerChangeEvent: function(type, metaData, origParent, nodeWasContained) {
var node = (metaData && metaData.node) ? metaData.node : this,
event = new events.ChangeEvent(type, $.extend({node: node}, metaData || {}));
if(type === 'nodeDetached' || this.document.containsNode(event.meta.node)) {
this.document.trigger('change', event);
}
- if((type === 'nodeAdded' || type === 'nodeMoved') && !(this.document.containsNode(this))) {
+ if((type === 'nodeAdded' || type === 'nodeMoved') && !this.document.containsNode(this) && nodeWasContained) {
event = new events.ChangeEvent('nodeDetached', {node: node, parent: origParent});
this.document.trigger('change', event);
}
}
}));
+ElementNode.prototype.transformations.register(transformations.createContextTransformation({
+ name: 'smartxml.setAttr2',
+ impl: function(args) {
+ this.prevAttr = this.getAttr(args.name);
+ this.setAttr(args.name, args.value);
+ },
+ undo: function(args) {
+ this.setAttr(args.name, this.prevAttr);
+ }
+}));
+
DocumentNode.prototype.transformations.register(transformations.createContextTransformation({
name: 'smartxml.wrapWith',
getChangeRoot: function() {
},
setText: function(text) {
- console.log('smartxml: ' + text);
+ //console.log('smartxml: ' + text);
this.nativeNode.data = text;
this.triggerTextChangeEvent();
},
},
getChangeRoot: function() {
return this.context.parent().parent();
+ },
+ isAllowed: function(args) {
+ var parent = this.parent();
+ return !!(parent && parent.parent());
}
}));
this.loadXML(xml);
this.undoStack = [];
this.redoStack = [];
+ this._transformationLevel = 0;
+ this.transformations = new transformations.TransformationStorage();
+
};
$.extend(Document.prototype, Backbone.Events, {
},
transform: function(transformation, args) {
- console.log('transform');
+ //console.log('transform');
var Transformation, toret;
if(typeof transformation === 'string') {
Transformation = this.transformations.get(transformation);
}
}
if(transformation) {
+ this._transformationLevel++;
toret = transformation.run();
- this.undoStack.push(transformation);
- console.log('clearing redo stack');
+ if(this._transformationLevel === 1) {
+ this.undoStack.push(transformation);
+ }
+ this._transformationLevel--;
+ //console.log('clearing redo stack');
this.redoStack = [];
return toret;
} else {
Document: Document,
DocumentNode: DocumentNode,
- ElementNode: ElementNode
+ ElementNode: ElementNode,
+ TextNode: TextNode
};
});
\ No newline at end of file