diff options
Diffstat (limited to 'module/web/static')
-rw-r--r-- | module/web/static/js/app.js | 1 | ||||
-rw-r--r-- | module/web/static/js/utils/dialogs.js | 15 | ||||
-rw-r--r-- | module/web/static/js/views/abstract/modalView.js | 31 | ||||
-rw-r--r-- | module/web/static/js/views/selectionView.js | 5 |
4 files changed, 47 insertions, 5 deletions
diff --git a/module/web/static/js/app.js b/module/web/static/js/app.js index dcc9594af..e3fad4ea1 100644 --- a/module/web/static/js/app.js +++ b/module/web/static/js/app.js @@ -12,6 +12,7 @@ define([ 'utils/initHB', 'utils/animations', 'utils/lazyRequire', + 'utils/dialogs', 'wreqr', 'bootstrap', 'animate' diff --git a/module/web/static/js/utils/dialogs.js b/module/web/static/js/utils/dialogs.js new file mode 100644 index 000000000..13478ff88 --- /dev/null +++ b/module/web/static/js/utils/dialogs.js @@ -0,0 +1,15 @@ +// Loads all helper and set own handlebars rules +define(['jquery', 'underscore', 'views/abstract/modalView'], function($, _, modal) { + + // Shows the confirm dialog for given context + // on success executes func with context + _.confirm = function(template, func, context) { + template = "text!tpl/" + template; + _.requireOnce([template], function(html) { + var template = _.compile(html); + var dialog = new modal(template, _.bind(func, context)); + dialog.show(); + }); + + }; +});
\ No newline at end of file diff --git a/module/web/static/js/views/abstract/modalView.js b/module/web/static/js/views/abstract/modalView.js index 56c060a42..e0542d552 100644 --- a/module/web/static/js/views/abstract/modalView.js +++ b/module/web/static/js/views/abstract/modalView.js @@ -3,6 +3,7 @@ define(['jquery', 'backbone', 'underscore', 'omniwindow'], function($, Backbone, return Backbone.View.extend({ events: { + 'click .btn-confirm': 'confirm', 'click .btn-close': 'hide', 'click .close': 'hide' }, @@ -10,12 +11,22 @@ define(['jquery', 'backbone', 'underscore', 'omniwindow'], function($, Backbone, template: null, dialog: null, - initialize: function() { + onHideDestroy: false, + confirmCallback: null, + + initialize: function(template, confirm) { + this.confirmCallback = confirm; var self = this; if (this.template === null) { - require(['text!tpl/default/modal.html'], function(template) { - self.template = template; - }); + if (template) { + this.template = template; + // When template was provided this is a temporary dialog + this.onHideDestroy = true; + } + else + require(['text!tpl/default/modal.html'], function(template) { + self.template = template; + }); } }, @@ -26,6 +37,8 @@ define(['jquery', 'backbone', 'underscore', 'omniwindow'], function($, Backbone, this.$el.css({opacity: 0, scale: 0.7}); $("body").append(this.el); + var self = this; + this.dialog = this.$el.omniWindow({ overlay: { selector: '#modal-overlay', @@ -34,6 +47,8 @@ define(['jquery', 'backbone', 'underscore', 'omniwindow'], function($, Backbone, hide: function(subjects, internalCallback) { subjects.overlay.transition({opacity: 'hide', delay: 100}, 300, function() { internalCallback(subjects); + if (self.onHideDestroy) + self.destroy(); }); }, show: function(subjects, internalCallback) { @@ -74,9 +89,17 @@ define(['jquery', 'backbone', 'underscore', 'omniwindow'], function($, Backbone, this.dialog.trigger('hide'); }, + confirm: function() { + if (this.confirmCallback) + this.confirmCallback.apply(); + + this.hide(); + }, + destroy: function() { this.$el.remove(); this.dialog = null; + this.remove(); } }); diff --git a/module/web/static/js/views/selectionView.js b/module/web/static/js/views/selectionView.js index 8dbd069bd..6d346b6ee 100644 --- a/module/web/static/js/views/selectionView.js +++ b/module/web/static/js/views/selectionView.js @@ -80,7 +80,10 @@ define(['jquery', 'backbone', 'underscore', 'app'], }, pause: function() { - // TODO + _.confirm('default/confirmDialog.html', function() { + alert("Not implemented yet"); + this.deselect(); + }, this); }, trash: function() { |