123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- /* ========================================================================
- * Bootstrap: sidebar.js v0.1
- * ========================================================================
- * Copyright 2011-2014 Asyraf Abdul Rahman
- * Licensed under MIT
- * ======================================================================== */
- + function($) {
- 'use strict';
- // SIDEBAR PUBLIC CLASS DEFINITION
- // ================================
- var Sidebar = function(element, options) {
- this.$element = $(element)
- this.options = $.extend({}, Sidebar.DEFAULTS, options)
- this.transitioning = null
- if (this.options.parent) this.$parent = $(this.options.parent)
- if (this.options.toggle) this.toggle()
- }
- Sidebar.DEFAULTS = {
- toggle: true
- }
- Sidebar.prototype.show = function() {
- if (this.transitioning || this.$element.hasClass('sidebar-open')) return
- var startEvent = $.Event('show.bs.sidebar')
- this.$element.trigger(startEvent);
- if (startEvent.isDefaultPrevented()) return
- this.$element
- .addClass('sidebar-open')
- this.transitioning = 1
- var complete = function() {
- this.$element
- this.transitioning = 0
- this.$element.trigger('shown.bs.sidebar')
- }
- if (!$.support.transition) return complete.call(this)
- this.$element
- .one($.support.transition.end, $.proxy(complete, this))
- .emulateTransitionEnd(400)
- }
- Sidebar.prototype.hide = function() {
- if (this.transitioning || !this.$element.hasClass('sidebar-open')) return
- var startEvent = $.Event('hide.bs.sidebar')
- this.$element.trigger(startEvent)
- if (startEvent.isDefaultPrevented()) return
- this.$element
- .removeClass('sidebar-open')
- this.transitioning = 1
- var complete = function() {
- this.transitioning = 0
- this.$element
- .trigger('hidden.bs.sidebar')
- }
- if (!$.support.transition) return complete.call(this)
- this.$element
- .one($.support.transition.end, $.proxy(complete, this))
- .emulateTransitionEnd(400)
- }
- Sidebar.prototype.toggle = function() {
- this[this.$element.hasClass('sidebar-open') ? 'hide' : 'show']()
- }
- var old = $.fn.sidebar
- $.fn.sidebar = function(option) {
- return this.each(function() {
- var $this = $(this)
- var data = $this.data('bs.sidebar')
- var options = $.extend({}, Sidebar.DEFAULTS, $this.data(), typeof options == 'object' && option)
- if (!data && options.toggle && option == 'show') option = !option
- if (!data) $this.data('bs.sidebar', (data = new Sidebar(this, options)))
- if (typeof option == 'string') data[option]()
- })
- }
- $.fn.sidebar.Constructor = Sidebar
- $.fn.sidebar.noConflict = function() {
- $.fn.sidebar = old
- return this
- }
- $(document).on('click.bs.sidebar.data-api', '[data-bs-toggle="sidebar-right"]', function(e) {
- var $this = $(this),
- href
- var target = $this.attr('data-target') ||
- e.preventDefault() ||
- (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')
- var $target = $(target)
- var data = $target.data('bs.sidebar')
- var option = data ? 'toggle' : $this.data()
- $target.sidebar(option)
- })
- $('html').on('click.bs.sidebar.autohide', function(event) {
- var $this = $(event.target);
- var isButtonOrSidebar = $this.is('.sidebar, [data-bs-toggle="sidebar-right"]') || $this.parents('.sidebar, [data-bs-toggle="sidebar-right"]').length;
- if (isButtonOrSidebar) {
- return;
- } else {
- var $target = $('.sidebar');
- $target.each(function(i, trgt) {
- var $trgt = $(trgt);
- if ($trgt.data('bs.sidebar') && $trgt.hasClass('sidebar-open')) {
- $trgt.sidebar('hide');
- }
- })
- }
- });
- }(jQuery);
|