Add bootstrap css
[disclosr.git] / documents / js / bootstrap.js
blob:a/documents/js/bootstrap.js -> blob:b/documents/js/bootstrap.js
  /* ===================================================
  * bootstrap-transition.js v2.2.1
  * http://twitter.github.com/bootstrap/javascript.html#transitions
  * ===================================================
  * Copyright 2012 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 ($) {
   
  "use strict"; // jshint ;_;
   
   
  /* CSS TRANSITION SUPPORT (http://www.modernizr.com/)
  * ======================================================= */
   
  $(function () {
   
  $.support.transition = (function () {
   
  var transitionEnd = (function () {
   
  var el = document.createElement('bootstrap')
  , transEndEventNames = {
  'WebkitTransition' : 'webkitTransitionEnd'
  , 'MozTransition' : 'transitionend'
  , 'OTransition' : 'oTransitionEnd otransitionend'
  , 'transition' : 'transitionend'
  }
  , name
   
  for (name in transEndEventNames){
  if (el.style[name] !== undefined) {
  return transEndEventNames[name]
  }
  }
   
  }())
   
  return transitionEnd && {
  end: transitionEnd
  }
   
  })()
   
  })
   
  }(window.jQuery);/* ==========================================================
  * bootstrap-alert.js v2.2.1
  * http://twitter.github.com/bootstrap/javascript.html#alerts
  * ==========================================================
  * Copyright 2012 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 ($) {
   
  "use strict"; // jshint ;_;
   
   
  /* ALERT CLASS DEFINITION
  * ====================== */
   
  var dismiss = '[data-dismiss="alert"]'
  , Alert = function (el) {
  $(el).on('click', dismiss, this.close)
  }
   
  Alert.prototype.close = function (e) {
  var $this = $(this)
  , selector = $this.attr('data-target')
  , $parent
   
  if (!selector) {
  selector = $this.attr('href')
  selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
  }
   
  $parent = $(selector)
   
  e && e.preventDefault()
   
  $parent.length || ($parent = $this.hasClass('alert') ? $this : $this.parent())
   
  $parent.trigger(e = $.Event('close'))
   
  if (e.isDefaultPrevented()) return
   
  $parent.removeClass('in')
   
  function removeElement() {
  $parent
  .trigger('closed')
  .remove()
  }
   
  $.support.transition && $parent.hasClass('fade') ?
  $parent.on($.support.transition.end, removeElement) :
  removeElement()
  }
   
   
  /* ALERT PLUGIN DEFINITION
  * ======================= */
   
  $.fn.alert = function (option) {
  return this.each(function () {
  var $this = $(this)
  , data = $this.data('alert')
  if (!data) $this.data('alert', (data = new Alert(this)))
  if (typeof option == 'string') data[option].call($this)
  })
  }
   
  $.fn.alert.Constructor = Alert
   
   
  /* ALERT DATA-API
  * ============== */
   
  $(document).on('click.alert.data-api', dismiss, Alert.prototype.close)
   
  }(window.jQuery);/* ============================================================
  * bootstrap-button.js v2.2.1
  * http://twitter.github.com/bootstrap/javascript.html#buttons
  * ============================================================
  * Copyright 2012 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 ($) {
   
  "use strict"; // jshint ;_;
   
   
  /* BUTTON PUBLIC CLASS DEFINITION
  * ============================== */
   
  var Button = function (element, options) {
  this.$element = $(element)
  this.options = $.extend({}, $.fn.button.defaults, options)
  }
   
  Button.prototype.setState = function (state) {
  var d = 'disabled'
  , $el = this.$element
  , data = $el.data()
  , val = $el.is('input') ? 'val' : 'html'
   
  state = state + 'Text'
  data.resetText || $el.data('resetText', $el[val]())
   
  $el[val](data[state] || this.options[state])
   
  // push to event loop to allow forms to submit
  setTimeout(function () {
  state == 'loadingText' ?
  $el.addClass(d).attr(d, d) :
  $el.removeClass(d).removeAttr(d)
  }, 0)
  }
   
  Button.prototype.toggle = function () {
  var $parent = this.$element.closest('[data-toggle="buttons-radio"]')
   
  $parent && $parent
  .find('.active')
  .removeClass('active')
   
  this.$element.toggleClass('active')
  }
   
   
  /* BUTTON PLUGIN DEFINITION
  * ======================== */
   
  $.fn.button = function (option) {
  return this.each(function () {
  var $this = $(this)
  , data = $this.data('button')
  , options = typeof option == 'object' && option
  if (!data) $this.data('button', (data = new Button(this, options)))
  if (option == 'toggle') data.toggle()
  else if (option) data.setState(option)
  })
  }
   
  $.fn.button.defaults = {
  loadingText: 'loading...'
  }
   
  $.fn.button.Constructor = Button
   
   
  /* BUTTON DATA-API
  * =============== */
   
  $(document).on('click.button.data-api', '[data-toggle^=button]', function (e) {
  var $btn = $(e.target)
  if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
  $btn.button('toggle')
  })
   
  }(window.jQuery);/* ==========================================================
  * bootstrap-carousel.js v2.2.1
  * http://twitter.github.com/bootstrap/javascript.html#carousel
  * ==========================================================
  * Copyright 2012 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 ($) {
   
  "use strict"; // jshint ;_;
   
   
  /* CAROUSEL CLASS DEFINITION
  * ========================= */
   
  var Carousel = function (element, options) {
  this.$element = $(element)
  this.options = options
  this.options.slide && this.slide(this.options.slide)
  this.options.pause == 'hover' && this.$element
  .on('mouseenter', $.proxy(this.pause, this))
  .on('mouseleave', $.proxy(this.cycle, this))
  }
   
  Carousel.prototype = {
   
  cycle: function (e) {
  if (!e) this.paused = false
  this.options.interval
  && !this.paused
  && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
  return this
  }
   
  , to: function (pos) {
  var $active = this.$element.find('.item.active')
  , children = $active.parent().children()
  , activePos = children.index($active)
  , that = this
   
  if (pos > (children.length - 1) || pos < 0) return
   
  if (this.sliding) {
  return this.$element.one('slid', function () {
  that.to(pos)
  })
  }
   
  if (activePos == pos) {
  return this.pause().cycle()
  }
   
  return this.slide(pos > activePos ? 'next' : 'prev', $(children[pos]))
  }
   
  , pause: function (e) {
  if (!e) this.paused = true
  if (this.$element.find('.next, .prev').length && $.support.transition.end) {
  this.$element.trigger($.support.transition.end)
  this.cycle()
  }
  clearInterval(this.interval)
  this.interval = null
  return this
  }
   
  , next: function () {
  if (this.sliding) return
  return this.slide('next')
  }
   
  , prev: function () {
  if (this.sliding) return
  return this.slide('prev')
  }
   
  , slide: function (type, next) {
  var $active = this.$element.find('.item.active')
  , $next = next || $active[type]()
  , isCycling = this.interval
  , direction = type == 'next' ? 'left' : 'right'
  , fallback = type == 'next' ? 'first' : 'last'
  , that = this
  , e
   
  this.sliding = true
   
  isCycling && this.pause()
   
  $next = $next.length ? $next : this.$element.find('.item')[fallback]()
   
  e = $.Event('slide', {
  relatedTarget: $next[0]
  })
   
  if ($next.hasClass('active')) return
   
  if ($.support.transition && this.$element.hasClass('slide')) {
  this.$element.trigger(e)
  if (e.isDefaultPrevented()) return
  $next.addClass(type)
  $next[0].offsetWidth // force reflow
  $active.addClass(direction)
  $next.addClass(direction)
  this.$element.one($.support.transition.end, function () {
  $next.removeClass([type, direction].join(' ')).addClass('active')
  $active.removeClass(['active', direction].join(' '))
  that.sliding = false
  setTimeout(function () { that.$element.trigger('slid') }, 0)
  })
  } else {
  this.$element.trigger(e)
  if (e.isDefaultPrevented()) return
  $active.removeClass('active')
  $next.addClass('active')
  this.sliding = false
  this.$element.trigger('slid')
  }
   
  isCycling && this.cycle()
   
  return this
  }
   
  }
   
   
  /* CAROUSEL PLUGIN DEFINITION
  * ========================== */
   
  $.fn.carousel = function (option) {
  return this.each(function () {