X-Git-Url: https://git.mdrn.pl/fnpeditor.git/blobdiff_plain/2c3bcb5d2d550bb6546c0f8aa3721f623ca9d6b6..bf8e16e2a24ce9828193a3b4145dfdbc5b94a935:/src/editor/modules/documentCanvas/commands.js diff --git a/src/editor/modules/documentCanvas/commands.js b/src/editor/modules/documentCanvas/commands.js index 5f3583e..a411a37 100644 --- a/src/editor/modules/documentCanvas/commands.js +++ b/src/editor/modules/documentCanvas/commands.js @@ -111,7 +111,7 @@ commands.register('newNodeRequested', function(canvas, params, user) { var insertNode = function(insertion, callback) { var doc = canvas.wlxmlDocument, - node, metadata, creator, dialog; + metadata, creator, dialog; var execCallback = function(node) { if(callback) { @@ -121,7 +121,7 @@ commands.register('newNodeRequested', function(canvas, params, user) { if(params.wlxmlTag === 'aside' && params.wlxmlClass === 'comment') { doc.transaction(function() { - node = insertion(); + var node = insertion(); if(user) { creator = user.name; if(user.email) { @@ -134,8 +134,10 @@ commands.register('newNodeRequested', function(canvas, params, user) { metadata = node.getMetadata(); metadata.add({key: 'creator', value: creator}); metadata.add({key: 'date', value: datetime.currentStrfmt()}); + return node; + }, { + success: execCallback }); - execCallback(node); } else if(params.wlxmlClass === 'link') { dialog = Dialog.create({ title: gettext('Create link'), @@ -147,18 +149,19 @@ commands.register('newNodeRequested', function(canvas, params, user) { }); dialog.on('execute', function(event) { doc.transaction(function() { - node = insertion(); + var node = insertion(); node.setAttr('href', event.formData.href); event.success(); + return node; + }, { + success: execCallback }); - execCallback(node); }); dialog.show(); } else { doc.transaction(function() { - node = insertion(); - }); - execCallback(node); + return insertion(); + }, {success: execCallback}); } };