3 'modules/documentCanvas/canvas/utils',
4 ], function($, utils) {
8 var Listener = function(canvas) {
12 $.extend(Listener.prototype, {
13 listenTo: function(wlxmlDocument) {
14 if(wlxmlDocument === this.wlxmlDocument) {
17 this.wlxmlDocument = wlxmlDocument;
19 wlxmlDocument.on('change', function(event) {
20 var handler = handlers[event.type];
22 handler.bind(this)(event);
26 wlxmlDocument.on('contentSet', function() {
27 this.canvas.loadWlxmlDocument(wlxmlDocument);
33 nodeAttrChange: function(event) {
34 if(event.meta.attr === 'class') {
35 var canvasNode = utils.findCanvasElement(event.meta.node);
36 canvasNode.setWlxmlClass(event.meta.newVal);
39 nodeTagChange: function(event) {
40 var canvasNode = utils.findCanvasElement(event.meta.node);
41 canvasNode.setWlxmlTag(event.meta.newTagName);
42 canvasNode.data('wlxmlNode', event.meta.node);
44 nodeAdded: function(event, checkForExistence) {
45 if(event.meta.node.isRoot()) {
46 this.canvas.reloadRoot();
49 var parentElement = utils.findCanvasElement(event.meta.node.parent()),
50 nodeIndex = event.meta.node.getIndex(),
51 referenceElement, referenceAction, actionArg;
54 referenceElement = parentElement;
55 referenceAction = 'prepend';
57 referenceElement = parentElement.children()[nodeIndex-1];
58 referenceAction = 'after';
61 actionArg = (checkForExistence && utils.findCanvasElement(event.meta.node)) || event.meta.node;
62 referenceElement[referenceAction](actionArg);
64 nodeMoved: function(event) {
65 return handlers.nodeAdded(event, true);
67 nodeDetached: function(event) {
68 var canvasNode = utils.findCanvasElementInParent(event.meta.node, event.meta.parent);
71 nodeTextChange: function(event) {
72 //console.log('wlxmlListener: ' + event.meta.node.getText());
73 var canvasElement = utils.findCanvasElement(event.meta.node),
74 toSet = event.meta.node.getText();
76 toSet = utils.unicode.ZWS;
78 if(toSet !== canvasElement.getText()) {
79 canvasElement.setText(toSet);
85 create: function(canvas) {
86 return new Listener(canvas);