{I" class:ETI"ProcessedAsset; FI"logical_path; TI"-improved-modal/bootstrap-modalmanager.js; FI" pathname; TI"†/Users/jfriesen/.rvm/gems/ruby-2.0.0-p247@curate/gems/blacklight-4.5.0/app/assets/javascripts/improved-modal/bootstrap-modalmanager.js; FI"content_type; TI"application/javascript; TI" mtime; Tl+ hnRI"length; Ti&I"digest; TI"%813c259a9e785bc50960112f874ea460; FI"source; TI"& /* =========================================================== * bootstrap-modalmanager.js v2.0 * =========================================================== * Copyright 2012 Jordan Schroter. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ========================================================== */ !function ($) { "use strict"; // jshint ;_; /* MODAL MANAGER CLASS DEFINITION * ====================== */ var ModalManager = function (element, options) { this.init(element, options); } ModalManager.prototype = { constructor: ModalManager, init: function (element, options) { this.$element = $(element); this.options = $.extend({}, $.fn.modalmanager.defaults, this.$element.data(), typeof options == 'object' && options); this.stack = []; this.backdropCount = 0; }, createModal: function (element, options) { $(element).modal($.extend({ manager: this }, options)); }, appendModal: function (modal) { this.stack.push(modal); var that = this; modal.$element.on('show.modalmanager', targetIsSelf(function (e) { modal.isShown = true; var transition = $.support.transition && modal.$element.hasClass('fade'); that.$element .toggleClass('modal-open', that.hasOpenModal()) .toggleClass('page-overflow', $(window).height() < that.$element.height()); modal.$parent = modal.$element.parent(); modal.$container = that.createContainer(modal); modal.$element.appendTo(modal.$container); var modalOverflow = $(window).height() < modal.$element.height() || modal.options.modalOverflow; that.backdrop(modal, function () { modal.$element.show(); if (transition) { modal.$element[0].style.display = 'run-in'; modal.$element[0].offsetWidth; modal.$element.one($.support.transition.end, function () { modal.$element[0].style.display = 'block' }); } modal.$element .toggleClass('modal-overflow', modalOverflow) .css('margin-top', modalOverflow ? 0 : 0 - modal.$element.height()/2) .addClass('in') .attr('aria-hidden', false); var complete = function () { that.setFocus(); modal.$element.triggerHandler('shown'); } transition ? modal.$element.one($.support.transition.end, complete) : complete(); }); })); modal.$element.on('hidden.modalmanager', targetIsSelf(function (e) { that.backdrop(modal); if (modal.$backdrop){ $.support.transition && modal.$element.hasClass('fade')? modal.$backdrop.one($.support.transition.end, function () { that.destroyModal(modal) }) : that.destroyModal(modal); } else { that.destroyModal(modal); } })); modal.$element.on('destroy.modalmanager', targetIsSelf(function (e) { that.removeModal(modal); })); }, destroyModal: function (modal) { modal.destroy(); var hasOpenModal = this.hasOpenModal(); this.$element.toggleClass('modal-open', hasOpenModal); if (!hasOpenModal){ this.$element.removeClass('page-overflow'); } this.removeContainer(modal); this.setFocus(); }, hasOpenModal: function () { for (var i = 0; i < this.stack.length; i++){ if (this.stack[i].isShown) return true; } return false; }, setFocus: function () { var topModal; for (var i = 0; i < this.stack.length; i++){ if (this.stack[i].isShown) topModal = this.stack[i]; } if (!topModal) return; topModal.focus(); }, removeModal: function (modal) { modal.$element.off('.modalmanager'); if (modal.$backdrop) this.removeBackdrop.call(modal); this.stack.splice(this.getIndexOfModal(modal), 1); }, getModalAt: function (index) { return this.stack[index]; }, getIndexOfModal: function (modal) { for (var i = 0; i < this.stack.length; i++){ if (modal === this.stack[i]) return i; } }, removeBackdrop: function (modal) { modal.$backdrop.remove(); modal.$backdrop = null; }, createBackdrop: function (animate) { var $backdrop; if (!this.isLoading) { $backdrop = $('
') .appendTo(this.$element); } else { $backdrop = this.$loading; $backdrop.off('.modalmanager'); this.$spinner.remove(); this.isLoading = false; this.$loading = this.$spinner = null; } return $backdrop }, removeContainer: function (modal) { modal.$container.remove(); modal.$container = null; }, createContainer: function (modal) { var $container; $container = $('