X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/0c53f4a333bbfcc04e75ad2f462f840301514321..436728b375888873e6e96079a73f12d8adbd7b96:/src/editor/modules/documentCanvas/canvas/wlxmlListener.js diff --git a/src/editor/modules/documentCanvas/canvas/wlxmlListener.js b/src/editor/modules/documentCanvas/canvas/wlxmlListener.js index ecf4900..bb09ec7 100644 --- a/src/editor/modules/documentCanvas/canvas/wlxmlListener.js +++ b/src/editor/modules/documentCanvas/canvas/wlxmlListener.js @@ -23,23 +23,68 @@ $.extend(Listener.prototype, { } }, this); + wlxmlDocument.on('operationEnd', function() { + this.canvas.triggerSelectionChanged(); + }, this); + wlxmlDocument.on('contentSet', function() { this.canvas.loadWlxmlDocument(wlxmlDocument); }, this); } }); + +var _metadataEventHandler = function(event) { + var element = utils.getElementForNode(event.meta.node); + element.handle(event); +}; + + var handlers = { nodeAttrChange: function(event) { + var element = utils.getElementForNode(event.meta.node), + newElement; if(event.meta.attr === 'class') { - var canvasNode = utils.findCanvasElement(event.meta.node); - canvasNode.setWlxmlClass(event.meta.newVal); + if(element.wlxmlNode.getClass() !== event.meta.attr) { + if(event.meta.node.isRoot()) { + this.canvas.reloadRoot(); + } else { + newElement = this.canvas.createElement(event.meta.node); + element.dom.replaceWith(newElement.dom); + } + } + + } else { + element.handle(event); } }, - nodeTagChange: function(event) { - var canvasNode = utils.findCanvasElement(event.meta.node); - canvasNode.setWlxmlTag(event.meta.newTagName); - } + nodeAdded: function(event) { + if(event.meta.node.isRoot()) { + this.canvas.reloadRoot(); + return; + } + + var containingNode = event.meta.node.parent(), + containingElement = utils.getElementForNode(containingNode); + + containingElement.handle(event); + }, + nodeMoved: function(event) { + return handlers.nodeAdded.call(this, event); // + // + }, + nodeDetached: function(event) { + var element = utils.getElementForDetachedNode(event.meta.node, event.meta.parent); + element.handle(event); + }, + nodeTextChange: function(event) { + var element = utils.getElementForTextNode(event.meta.node); + element.handle(event); + }, + + metadataChanged: _metadataEventHandler, + metadataAdded: _metadataEventHandler, + metadataRemoved: _metadataEventHandler }; return {