|
|
|
'use strict';
|
|
|
|
define(
|
|
|
|
[
|
|
|
|
'app',
|
|
|
|
'$',
|
|
|
|
'marionette',
|
|
|
|
'bootstrap'
|
|
|
|
], function (app, $, Marionette) {
|
|
|
|
var region = Marionette.Region.extend({
|
|
|
|
el: '#modal-region',
|
|
|
|
|
|
|
|
constructor: function () {
|
|
|
|
Backbone.Marionette.Region.prototype.constructor.apply(this, arguments);
|
|
|
|
this.on('show', this.showModal, this);
|
|
|
|
},
|
|
|
|
|
|
|
|
getEl: function (selector) {
|
|
|
|
var $el = $(selector);
|
|
|
|
$el.on('hidden', this.close);
|
|
|
|
return $el;
|
|
|
|
},
|
|
|
|
|
|
|
|
showModal: function () {
|
|
|
|
this.$el.addClass('modal hide fade');
|
|
|
|
|
|
|
|
//need tab index so close on escape works
|
|
|
|
//https://github.com/twitter/bootstrap/issues/4663
|
|
|
|
this.$el.attr('tabindex', '-1');
|
|
|
|
this.$el.modal({
|
|
|
|
'show' : true,
|
|
|
|
'keyboard': true,
|
|
|
|
'backdrop': 'static'});
|
|
|
|
},
|
|
|
|
|
|
|
|
closeModal: function () {
|
|
|
|
$(this.el).modal('hide');
|
|
|
|
this.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
require(
|
|
|
|
[
|
|
|
|
'Shared/Modal/Controller'
|
|
|
|
], function () {
|
|
|
|
|
|
|
|
app.addInitializer(function () {
|
|
|
|
app.addRegions({
|
|
|
|
modalRegion: region
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
return region;
|
|
|
|
});
|