/* ========================================================= * bootstrap-modal.js * http://twitter.github.com/bootstrap/javascript.html#modal * ========================================================= * Copyright 2011 Twitter, Inc. * * 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( $ ){ /* CSS TRANSITION SUPPORT (https://gist.github.com/373874) * ======================================================= */ var transitionEnd $(function () { $.support.transition = (function () { var thisBody = document.body || document.documentElement , thisStyle = thisBody.style , support = thisStyle.transition !== undefined || thisStyle.WebkitTransition !== undefined || thisStyle.MozTransition !== undefined || thisStyle.MsTransition !== undefined || thisStyle.OTransition !== undefined return support })() // set CSS transition event type if ( $.support.transition ) { transitionEnd = "TransitionEnd" if ( $.browser.webkit ) { transitionEnd = "webkitTransitionEnd" } else if ( $.browser.mozilla ) { transitionEnd = "transitionend" } else if ( $.browser.opera ) { transitionEnd = "oTransitionEnd" } } }) /* MODAL PUBLIC CLASS DEFINITION * ============================= */ var Modal = function ( content, options ) { this.settings = $.extend({}, $.fn.modal.defaults) this.$element = $(content) .delegate('.close', 'click.modal', $.proxy(this.hide, this)) if ( options ) { $.extend( this.settings, options ) if ( options.show ) { this.show() } } return this } Modal.prototype = { toggle: function () { return this[!this.isShown ? 'show' : 'hide']() } , show: function () { var that = this this.isShown = true this.$element.trigger('show') escape.call(this) backdrop.call(this, function () { that.$element .appendTo(document.body) .show() setTimeout(function () { that.$element .addClass('in') .trigger('shown') }, 1) }) return this } , hide: function (e) { e && e.preventDefault() var that = this this.isShown = false escape.call(this) this.$element .trigger('hide') .removeClass('in') function removeElement () { that.$element .hide() .trigger('hidden') backdrop.call(that) } $.support.transition && this.$element.hasClass('fade') ? this.$element.one(transitionEnd, removeElement) : removeElement() return this } } /* MODAL PRIVATE METHODS * ===================== */ function backdrop ( callback ) { var that = this , animate = this.$element.hasClass('fade') ? 'fade' : '' if ( this.isShown && this.settings.backdrop ) { this.$backdrop = $('
') .click($.proxy(this.hide, this)) .appendTo(document.body) setTimeout(function () { that.$backdrop && that.$backdrop.addClass('in') $.support.transition && that.$backdrop.hasClass('fade') ? that.$backdrop.one(transitionEnd, callback) : callback() }) } else if ( !this.isShown && this.$backdrop ) { this.$backdrop.removeClass('in') function removeElement() { that.$backdrop.remove() that.$backdrop = null } $.support.transition && this.$element.hasClass('fade')? this.$backdrop.one(transitionEnd, removeElement) : removeElement() } else if ( callback ) { callback() } } function escape() { var that = this if ( this.isShown && this.settings.keyboard ) { $('body').bind('keyup.modal', function ( e ) { if ( e.which == 27 ) { that.hide() } }) } else if ( !this.isShown ) { $('body').unbind('keyup.modal') } } /* MODAL PLUGIN DEFINITION * ======================= */ $.fn.modal = function ( options ) { var modal = this.data('modal') if (!modal) { if (typeof options == 'string') { options = { show: /show|toggle/.test(options) } } return this.each(function () { $(this).data('modal', new Modal(this, options)) }) } if ( options === true ) { return modal } if ( typeof options == 'string' ) { modal[options]() } else if ( modal ) { modal.toggle() } return this } $.fn.modal.Modal = Modal $.fn.modal.defaults = { backdrop: false , keyboard: false , show: true } /* MODAL DATA- IMPLEMENTATION * ========================== */ $(function () { $('body').delegate('[data-controls-modal]', 'click', function (e) { e.preventDefault() var $this = $(this).data('show', true) $('#' + $this.attr('data-controls-modal')).modal( $this.data() ) }) }) })( jQuery || ender )