this.dom = this.createDOM();
this.dom.data('canvas-element', this);
+ this.wlxmlNode.setData('canvasElement', this);
};
$.extend(DocumentElement.prototype, {
sameNode: function(other) {
return other && (typeof other === typeof this) && other.dom[0] === this.dom[0];
},
+ isRootElement: function() {
+ return this.sameNode(this.canvas.rootElement);
+ },
trigger: function() {
this.canvas.eventBus.trigger.apply(this.canvas.eventBus, Array.prototype.slice.call(arguments, 0));
// DocumentNodeElement represents an element node from WLXML document rendered inside Canvas
var DocumentNodeElement = function(wlxmlNode, canvas) {
DocumentElement.call(this, wlxmlNode, canvas);
- wlxmlNode.setData('canvasElement', this);
this.init(this.dom);
};
createDOM: function() {
var wrapper = $('<div>').attr('document-node-element', ''),
widgetsContainer = $('<div>')
- .addClass('canvas-widgets')
- .attr('contenteditable', false),
+ .addClass('canvas-widgets'),
contentContainer = $('<div>')
.attr('document-element-content', '');
detach: function(isChild) {
var parents;
+ if(this.gutterGroup) {
+ this.gutterGroup.remove();
+ }
if(_.isFunction(this.children)) {
this.children().forEach(function(child) {
child.detach(true);