diff options
Diffstat (limited to 'pyload/web/app/scripts/views/abstract/modalView.js')
| -rw-r--r-- | pyload/web/app/scripts/views/abstract/modalView.js | 124 | 
1 files changed, 124 insertions, 0 deletions
| diff --git a/pyload/web/app/scripts/views/abstract/modalView.js b/pyload/web/app/scripts/views/abstract/modalView.js new file mode 100644 index 000000000..65bc0a3c8 --- /dev/null +++ b/pyload/web/app/scripts/views/abstract/modalView.js @@ -0,0 +1,124 @@ +define(['jquery', 'backbone', 'underscore', 'omniwindow'], function($, Backbone, _) { +    'use strict'; + +    return Backbone.View.extend({ + +        events: { +            'click .btn-confirm': 'confirm', +            'click .btn-close': 'hide', +            'click .close': 'hide' +        }, + +        template: null, +        dialog: null, + +        onHideDestroy: false, +        confirmCallback: null, + +        initialize: function(template, confirm) { +            this.confirmCallback = confirm; +            var self = this; +            if (this.template === null) { +                if (template) { +                    this.template = template; +                    // When template was provided this is a temporary dialog +                    this.onHideDestroy = true; +                } +                else +                    require(['hbs!tpl/dialogs/modal'], function(template) { +                        self.template = template; +                    }); +            } +        }, + +        // TODO: whole modal stuff is not very elegant +        render: function() { +            this.$el.html(this.template(this.renderContent())); +            this.onRender(); + +            if (this.dialog === null) { +                this.$el.addClass('modal hide'); +                this.$el.css({opacity: 0, scale: 0.7}); + +                var self = this; +                $('body').append(this.el); +                this.dialog = this.$el.omniWindow({ +                    overlay: { +                        selector: '#modal-overlay', +                        hideClass: 'hide', +                        animations: { +                            hide: function(subjects, internalCallback) { +                                subjects.overlay.transition({opacity: 'hide', delay: 100}, 300, function() { +                                    internalCallback(subjects); +                                    self.onHide(); +                                    if (self.onHideDestroy) +                                        self.destroy(); +                                }); +                            }, +                            show: function(subjects, internalCallback) { +                                subjects.overlay.fadeIn(300); +                                internalCallback(subjects); +                            }}}, +                    modal: { +                        hideClass: 'hide', +                        animations: { +                            hide: function(subjects, internalCallback) { +                                subjects.modal.transition({opacity: 'hide', scale: 0.7}, 300); +                                internalCallback(subjects); +                            }, + +                            show: function(subjects, internalCallback) { +                                subjects.modal.transition({opacity: 'show', scale: 1, delay: 100}, 300, function() { +                                    internalCallback(subjects); +                                }); +                            }} +                    }}); +            } + +            return this; +        }, + +        onRender: function() { + +        }, + +        renderContent: function() { +            return {}; +        }, + +        show: function() { +            if (this.dialog === null) +                this.render(); + +            this.dialog.trigger('show'); + +            this.onShow(); +        }, + +        onShow: function() { + +        }, + +        hide: function() { +            this.dialog.trigger('hide'); +        }, + +        onHide: function() { + +        }, + +        confirm: function() { +            if (this.confirmCallback) +                this.confirmCallback.apply(); + +            this.hide(); +        }, + +        destroy: function() { +            this.$el.remove(); +            this.dialog = null; +            this.remove(); +        } + +    }); +});
\ No newline at end of file | 
