static/js/bootstrap.js
author stetrabby <info@trabucchi.de>
Fri, 20 Dec 2013 21:57:50 +0100
changeset 51 d68c1b192ade
parent 0 46abfb767ff2
permissions -rwxr-xr-x
js updated to version 3.0.3
     1 /*!
     2  * Bootstrap v3.0.3 (http://getbootstrap.com)
     3  * Copyright 2013 Twitter, Inc.
     4  * Licensed under http://www.apache.org/licenses/LICENSE-2.0
     5  */
     6 
     7 if (typeof jQuery === "undefined") { throw new Error("Bootstrap requires jQuery") }
     8 
     9 /* ========================================================================
    10  * Bootstrap: transition.js v3.0.3
    11  * http://getbootstrap.com/javascript/#transitions
    12  * ========================================================================
    13  * Copyright 2013 Twitter, Inc.
    14  *
    15  * Licensed under the Apache License, Version 2.0 (the "License");
    16  * you may not use this file except in compliance with the License.
    17  * You may obtain a copy of the License at
    18  *
    19  * http://www.apache.org/licenses/LICENSE-2.0
    20  *
    21  * Unless required by applicable law or agreed to in writing, software
    22  * distributed under the License is distributed on an "AS IS" BASIS,
    23  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    24  * See the License for the specific language governing permissions and
    25  * limitations under the License.
    26  * ======================================================================== */
    27 
    28 
    29 +function ($) { "use strict";
    30 
    31   // CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
    32   // ============================================================
    33 
    34   function transitionEnd() {
    35     var el = document.createElement('bootstrap')
    36 
    37     var transEndEventNames = {
    38       'WebkitTransition' : 'webkitTransitionEnd'
    39     , 'MozTransition'    : 'transitionend'
    40     , 'OTransition'      : 'oTransitionEnd otransitionend'
    41     , 'transition'       : 'transitionend'
    42     }
    43 
    44     for (var name in transEndEventNames) {
    45       if (el.style[name] !== undefined) {
    46         return { end: transEndEventNames[name] }
    47       }
    48     }
    49   }
    50 
    51   // http://blog.alexmaccaw.com/css-transitions
    52   $.fn.emulateTransitionEnd = function (duration) {
    53     var called = false, $el = this
    54     $(this).one($.support.transition.end, function () { called = true })
    55     var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
    56     setTimeout(callback, duration)
    57     return this
    58   }
    59 
    60   $(function () {
    61     $.support.transition = transitionEnd()
    62   })
    63 
    64 }(jQuery);
    65 
    66 /* ========================================================================
    67  * Bootstrap: alert.js v3.0.3
    68  * http://getbootstrap.com/javascript/#alerts
    69  * ========================================================================
    70  * Copyright 2013 Twitter, Inc.
    71  *
    72  * Licensed under the Apache License, Version 2.0 (the "License");
    73  * you may not use this file except in compliance with the License.
    74  * You may obtain a copy of the License at
    75  *
    76  * http://www.apache.org/licenses/LICENSE-2.0
    77  *
    78  * Unless required by applicable law or agreed to in writing, software
    79  * distributed under the License is distributed on an "AS IS" BASIS,
    80  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    81  * See the License for the specific language governing permissions and
    82  * limitations under the License.
    83  * ======================================================================== */
    84 
    85 
    86 +function ($) { "use strict";
    87 
    88   // ALERT CLASS DEFINITION
    89   // ======================
    90 
    91   var dismiss = '[data-dismiss="alert"]'
    92   var Alert   = function (el) {
    93     $(el).on('click', dismiss, this.close)
    94   }
    95 
    96   Alert.prototype.close = function (e) {
    97     var $this    = $(this)
    98     var selector = $this.attr('data-target')
    99 
   100     if (!selector) {
   101       selector = $this.attr('href')
   102       selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
   103     }
   104 
   105     var $parent = $(selector)
   106 
   107     if (e) e.preventDefault()
   108 
   109     if (!$parent.length) {
   110       $parent = $this.hasClass('alert') ? $this : $this.parent()
   111     }
   112 
   113     $parent.trigger(e = $.Event('close.bs.alert'))
   114 
   115     if (e.isDefaultPrevented()) return
   116 
   117     $parent.removeClass('in')
   118 
   119     function removeElement() {
   120       $parent.trigger('closed.bs.alert').remove()
   121     }
   122 
   123     $.support.transition && $parent.hasClass('fade') ?
   124       $parent
   125         .one($.support.transition.end, removeElement)
   126         .emulateTransitionEnd(150) :
   127       removeElement()
   128   }
   129 
   130 
   131   // ALERT PLUGIN DEFINITION
   132   // =======================
   133 
   134   var old = $.fn.alert
   135 
   136   $.fn.alert = function (option) {
   137     return this.each(function () {
   138       var $this = $(this)
   139       var data  = $this.data('bs.alert')
   140 
   141       if (!data) $this.data('bs.alert', (data = new Alert(this)))
   142       if (typeof option == 'string') data[option].call($this)
   143     })
   144   }
   145 
   146   $.fn.alert.Constructor = Alert
   147 
   148 
   149   // ALERT NO CONFLICT
   150   // =================
   151 
   152   $.fn.alert.noConflict = function () {
   153     $.fn.alert = old
   154     return this
   155   }
   156 
   157 
   158   // ALERT DATA-API
   159   // ==============
   160 
   161   $(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close)
   162 
   163 }(jQuery);
   164 
   165 /* ========================================================================
   166  * Bootstrap: button.js v3.0.3
   167  * http://getbootstrap.com/javascript/#buttons
   168  * ========================================================================
   169  * Copyright 2013 Twitter, Inc.
   170  *
   171  * Licensed under the Apache License, Version 2.0 (the "License");
   172  * you may not use this file except in compliance with the License.
   173  * You may obtain a copy of the License at
   174  *
   175  * http://www.apache.org/licenses/LICENSE-2.0
   176  *
   177  * Unless required by applicable law or agreed to in writing, software
   178  * distributed under the License is distributed on an "AS IS" BASIS,
   179  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   180  * See the License for the specific language governing permissions and
   181  * limitations under the License.
   182  * ======================================================================== */
   183 
   184 
   185 +function ($) { "use strict";
   186 
   187   // BUTTON PUBLIC CLASS DEFINITION
   188   // ==============================
   189 
   190   var Button = function (element, options) {
   191     this.$element = $(element)
   192     this.options  = $.extend({}, Button.DEFAULTS, options)
   193   }
   194 
   195   Button.DEFAULTS = {
   196     loadingText: 'loading...'
   197   }
   198 
   199   Button.prototype.setState = function (state) {
   200     var d    = 'disabled'
   201     var $el  = this.$element
   202     var val  = $el.is('input') ? 'val' : 'html'
   203     var data = $el.data()
   204 
   205     state = state + 'Text'
   206 
   207     if (!data.resetText) $el.data('resetText', $el[val]())
   208 
   209     $el[val](data[state] || this.options[state])
   210 
   211     // push to event loop to allow forms to submit
   212     setTimeout(function () {
   213       state == 'loadingText' ?
   214         $el.addClass(d).attr(d, d) :
   215         $el.removeClass(d).removeAttr(d);
   216     }, 0)
   217   }
   218 
   219   Button.prototype.toggle = function () {
   220     var $parent = this.$element.closest('[data-toggle="buttons"]')
   221     var changed = true
   222 
   223     if ($parent.length) {
   224       var $input = this.$element.find('input')
   225       if ($input.prop('type') === 'radio') {
   226         // see if clicking on current one
   227         if ($input.prop('checked') && this.$element.hasClass('active'))
   228           changed = false
   229         else
   230           $parent.find('.active').removeClass('active')
   231       }
   232       if (changed) $input.prop('checked', !this.$element.hasClass('active')).trigger('change')
   233     }
   234 
   235     if (changed) this.$element.toggleClass('active')
   236   }
   237 
   238 
   239   // BUTTON PLUGIN DEFINITION
   240   // ========================
   241 
   242   var old = $.fn.button
   243 
   244   $.fn.button = function (option) {
   245     return this.each(function () {
   246       var $this   = $(this)
   247       var data    = $this.data('bs.button')
   248       var options = typeof option == 'object' && option
   249 
   250       if (!data) $this.data('bs.button', (data = new Button(this, options)))
   251 
   252       if (option == 'toggle') data.toggle()
   253       else if (option) data.setState(option)
   254     })
   255   }
   256 
   257   $.fn.button.Constructor = Button
   258 
   259 
   260   // BUTTON NO CONFLICT
   261   // ==================
   262 
   263   $.fn.button.noConflict = function () {
   264     $.fn.button = old
   265     return this
   266   }
   267 
   268 
   269   // BUTTON DATA-API
   270   // ===============
   271 
   272   $(document).on('click.bs.button.data-api', '[data-toggle^=button]', function (e) {
   273     var $btn = $(e.target)
   274     if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
   275     $btn.button('toggle')
   276     e.preventDefault()
   277   })
   278 
   279 }(jQuery);
   280 
   281 /* ========================================================================
   282  * Bootstrap: carousel.js v3.0.3
   283  * http://getbootstrap.com/javascript/#carousel
   284  * ========================================================================
   285  * Copyright 2013 Twitter, Inc.
   286  *
   287  * Licensed under the Apache License, Version 2.0 (the "License");
   288  * you may not use this file except in compliance with the License.
   289  * You may obtain a copy of the License at
   290  *
   291  * http://www.apache.org/licenses/LICENSE-2.0
   292  *
   293  * Unless required by applicable law or agreed to in writing, software
   294  * distributed under the License is distributed on an "AS IS" BASIS,
   295  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   296  * See the License for the specific language governing permissions and
   297  * limitations under the License.
   298  * ======================================================================== */
   299 
   300 
   301 +function ($) { "use strict";
   302 
   303   // CAROUSEL CLASS DEFINITION
   304   // =========================
   305 
   306   var Carousel = function (element, options) {
   307     this.$element    = $(element)
   308     this.$indicators = this.$element.find('.carousel-indicators')
   309     this.options     = options
   310     this.paused      =
   311     this.sliding     =
   312     this.interval    =
   313     this.$active     =
   314     this.$items      = null
   315 
   316     this.options.pause == 'hover' && this.$element
   317       .on('mouseenter', $.proxy(this.pause, this))
   318       .on('mouseleave', $.proxy(this.cycle, this))
   319   }
   320 
   321   Carousel.DEFAULTS = {
   322     interval: 5000
   323   , pause: 'hover'
   324   , wrap: true
   325   }
   326 
   327   Carousel.prototype.cycle =  function (e) {
   328     e || (this.paused = false)
   329 
   330     this.interval && clearInterval(this.interval)
   331 
   332     this.options.interval
   333       && !this.paused
   334       && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
   335 
   336     return this
   337   }
   338 
   339   Carousel.prototype.getActiveIndex = function () {
   340     this.$active = this.$element.find('.item.active')
   341     this.$items  = this.$active.parent().children()
   342 
   343     return this.$items.index(this.$active)
   344   }
   345 
   346   Carousel.prototype.to = function (pos) {
   347     var that        = this
   348     var activeIndex = this.getActiveIndex()
   349 
   350     if (pos > (this.$items.length - 1) || pos < 0) return
   351 
   352     if (this.sliding)       return this.$element.one('slid.bs.carousel', function () { that.to(pos) })
   353     if (activeIndex == pos) return this.pause().cycle()
   354 
   355     return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))
   356   }
   357 
   358   Carousel.prototype.pause = function (e) {
   359     e || (this.paused = true)
   360 
   361     if (this.$element.find('.next, .prev').length && $.support.transition.end) {
   362       this.$element.trigger($.support.transition.end)
   363       this.cycle(true)
   364     }
   365 
   366     this.interval = clearInterval(this.interval)
   367 
   368     return this
   369   }
   370 
   371   Carousel.prototype.next = function () {
   372     if (this.sliding) return
   373     return this.slide('next')
   374   }
   375 
   376   Carousel.prototype.prev = function () {
   377     if (this.sliding) return
   378     return this.slide('prev')
   379   }
   380 
   381   Carousel.prototype.slide = function (type, next) {
   382     var $active   = this.$element.find('.item.active')
   383     var $next     = next || $active[type]()
   384     var isCycling = this.interval
   385     var direction = type == 'next' ? 'left' : 'right'
   386     var fallback  = type == 'next' ? 'first' : 'last'
   387     var that      = this
   388 
   389     if (!$next.length) {
   390       if (!this.options.wrap) return
   391       $next = this.$element.find('.item')[fallback]()
   392     }
   393 
   394     this.sliding = true
   395 
   396     isCycling && this.pause()
   397 
   398     var e = $.Event('slide.bs.carousel', { relatedTarget: $next[0], direction: direction })
   399 
   400     if ($next.hasClass('active')) return
   401 
   402     if (this.$indicators.length) {
   403       this.$indicators.find('.active').removeClass('active')
   404       this.$element.one('slid.bs.carousel', function () {
   405         var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()])
   406         $nextIndicator && $nextIndicator.addClass('active')
   407       })
   408     }
   409 
   410     if ($.support.transition && this.$element.hasClass('slide')) {
   411       this.$element.trigger(e)
   412       if (e.isDefaultPrevented()) return
   413       $next.addClass(type)
   414       $next[0].offsetWidth // force reflow
   415       $active.addClass(direction)
   416       $next.addClass(direction)
   417       $active
   418         .one($.support.transition.end, function () {
   419           $next.removeClass([type, direction].join(' ')).addClass('active')
   420           $active.removeClass(['active', direction].join(' '))
   421           that.sliding = false
   422           setTimeout(function () { that.$element.trigger('slid.bs.carousel') }, 0)
   423         })
   424         .emulateTransitionEnd(600)
   425     } else {
   426       this.$element.trigger(e)
   427       if (e.isDefaultPrevented()) return
   428       $active.removeClass('active')
   429       $next.addClass('active')
   430       this.sliding = false
   431       this.$element.trigger('slid.bs.carousel')
   432     }
   433 
   434     isCycling && this.cycle()
   435 
   436     return this
   437   }
   438 
   439 
   440   // CAROUSEL PLUGIN DEFINITION
   441   // ==========================
   442 
   443   var old = $.fn.carousel
   444 
   445   $.fn.carousel = function (option) {
   446     return this.each(function () {
   447       var $this   = $(this)
   448       var data    = $this.data('bs.carousel')
   449       var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option)
   450       var action  = typeof option == 'string' ? option : options.slide
   451 
   452       if (!data) $this.data('bs.carousel', (data = new Carousel(this, options)))
   453       if (typeof option == 'number') data.to(option)
   454       else if (action) data[action]()
   455       else if (options.interval) data.pause().cycle()
   456     })
   457   }
   458 
   459   $.fn.carousel.Constructor = Carousel
   460 
   461 
   462   // CAROUSEL NO CONFLICT
   463   // ====================
   464 
   465   $.fn.carousel.noConflict = function () {
   466     $.fn.carousel = old
   467     return this
   468   }
   469 
   470 
   471   // CAROUSEL DATA-API
   472   // =================
   473 
   474   $(document).on('click.bs.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {
   475     var $this   = $(this), href
   476     var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
   477     var options = $.extend({}, $target.data(), $this.data())
   478     var slideIndex = $this.attr('data-slide-to')
   479     if (slideIndex) options.interval = false
   480 
   481     $target.carousel(options)
   482 
   483     if (slideIndex = $this.attr('data-slide-to')) {
   484       $target.data('bs.carousel').to(slideIndex)
   485     }
   486 
   487     e.preventDefault()
   488   })
   489 
   490   $(window).on('load', function () {
   491     $('[data-ride="carousel"]').each(function () {
   492       var $carousel = $(this)
   493       $carousel.carousel($carousel.data())
   494     })
   495   })
   496 
   497 }(jQuery);
   498 
   499 /* ========================================================================
   500  * Bootstrap: collapse.js v3.0.3
   501  * http://getbootstrap.com/javascript/#collapse
   502  * ========================================================================
   503  * Copyright 2013 Twitter, Inc.
   504  *
   505  * Licensed under the Apache License, Version 2.0 (the "License");
   506  * you may not use this file except in compliance with the License.
   507  * You may obtain a copy of the License at
   508  *
   509  * http://www.apache.org/licenses/LICENSE-2.0
   510  *
   511  * Unless required by applicable law or agreed to in writing, software
   512  * distributed under the License is distributed on an "AS IS" BASIS,
   513  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   514  * See the License for the specific language governing permissions and
   515  * limitations under the License.
   516  * ======================================================================== */
   517 
   518 
   519 +function ($) { "use strict";
   520 
   521   // COLLAPSE PUBLIC CLASS DEFINITION
   522   // ================================
   523 
   524   var Collapse = function (element, options) {
   525     this.$element      = $(element)
   526     this.options       = $.extend({}, Collapse.DEFAULTS, options)
   527     this.transitioning = null
   528 
   529     if (this.options.parent) this.$parent = $(this.options.parent)
   530     if (this.options.toggle) this.toggle()
   531   }
   532 
   533   Collapse.DEFAULTS = {
   534     toggle: true
   535   }
   536 
   537   Collapse.prototype.dimension = function () {
   538     var hasWidth = this.$element.hasClass('width')
   539     return hasWidth ? 'width' : 'height'
   540   }
   541 
   542   Collapse.prototype.show = function () {
   543     if (this.transitioning || this.$element.hasClass('in')) return
   544 
   545     var startEvent = $.Event('show.bs.collapse')
   546     this.$element.trigger(startEvent)
   547     if (startEvent.isDefaultPrevented()) return
   548 
   549     var actives = this.$parent && this.$parent.find('> .panel > .in')
   550 
   551     if (actives && actives.length) {
   552       var hasData = actives.data('bs.collapse')
   553       if (hasData && hasData.transitioning) return
   554       actives.collapse('hide')
   555       hasData || actives.data('bs.collapse', null)
   556     }
   557 
   558     var dimension = this.dimension()
   559 
   560     this.$element
   561       .removeClass('collapse')
   562       .addClass('collapsing')
   563       [dimension](0)
   564 
   565     this.transitioning = 1
   566 
   567     var complete = function () {
   568       this.$element
   569         .removeClass('collapsing')
   570         .addClass('in')
   571         [dimension]('auto')
   572       this.transitioning = 0
   573       this.$element.trigger('shown.bs.collapse')
   574     }
   575 
   576     if (!$.support.transition) return complete.call(this)
   577 
   578     var scrollSize = $.camelCase(['scroll', dimension].join('-'))
   579 
   580     this.$element
   581       .one($.support.transition.end, $.proxy(complete, this))
   582       .emulateTransitionEnd(350)
   583       [dimension](this.$element[0][scrollSize])
   584   }
   585 
   586   Collapse.prototype.hide = function () {
   587     if (this.transitioning || !this.$element.hasClass('in')) return
   588 
   589     var startEvent = $.Event('hide.bs.collapse')
   590     this.$element.trigger(startEvent)
   591     if (startEvent.isDefaultPrevented()) return
   592 
   593     var dimension = this.dimension()
   594 
   595     this.$element
   596       [dimension](this.$element[dimension]())
   597       [0].offsetHeight
   598 
   599     this.$element
   600       .addClass('collapsing')
   601       .removeClass('collapse')
   602       .removeClass('in')
   603 
   604     this.transitioning = 1
   605 
   606     var complete = function () {
   607       this.transitioning = 0
   608       this.$element
   609         .trigger('hidden.bs.collapse')
   610         .removeClass('collapsing')
   611         .addClass('collapse')
   612     }
   613 
   614     if (!$.support.transition) return complete.call(this)
   615 
   616     this.$element
   617       [dimension](0)
   618       .one($.support.transition.end, $.proxy(complete, this))
   619       .emulateTransitionEnd(350)
   620   }
   621 
   622   Collapse.prototype.toggle = function () {
   623     this[this.$element.hasClass('in') ? 'hide' : 'show']()
   624   }
   625 
   626 
   627   // COLLAPSE PLUGIN DEFINITION
   628   // ==========================
   629 
   630   var old = $.fn.collapse
   631 
   632   $.fn.collapse = function (option) {
   633     return this.each(function () {
   634       var $this   = $(this)
   635       var data    = $this.data('bs.collapse')
   636       var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
   637 
   638       if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
   639       if (typeof option == 'string') data[option]()
   640     })
   641   }
   642 
   643   $.fn.collapse.Constructor = Collapse
   644 
   645 
   646   // COLLAPSE NO CONFLICT
   647   // ====================
   648 
   649   $.fn.collapse.noConflict = function () {
   650     $.fn.collapse = old
   651     return this
   652   }
   653 
   654 
   655   // COLLAPSE DATA-API
   656   // =================
   657 
   658   $(document).on('click.bs.collapse.data-api', '[data-toggle=collapse]', function (e) {
   659     var $this   = $(this), href
   660     var target  = $this.attr('data-target')
   661         || e.preventDefault()
   662         || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
   663     var $target = $(target)
   664     var data    = $target.data('bs.collapse')
   665     var option  = data ? 'toggle' : $this.data()
   666     var parent  = $this.attr('data-parent')
   667     var $parent = parent && $(parent)
   668 
   669     if (!data || !data.transitioning) {
   670       if ($parent) $parent.find('[data-toggle=collapse][data-parent="' + parent + '"]').not($this).addClass('collapsed')
   671       $this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
   672     }
   673 
   674     $target.collapse(option)
   675   })
   676 
   677 }(jQuery);
   678 
   679 /* ========================================================================
   680  * Bootstrap: dropdown.js v3.0.3
   681  * http://getbootstrap.com/javascript/#dropdowns
   682  * ========================================================================
   683  * Copyright 2013 Twitter, Inc.
   684  *
   685  * Licensed under the Apache License, Version 2.0 (the "License");
   686  * you may not use this file except in compliance with the License.
   687  * You may obtain a copy of the License at
   688  *
   689  * http://www.apache.org/licenses/LICENSE-2.0
   690  *
   691  * Unless required by applicable law or agreed to in writing, software
   692  * distributed under the License is distributed on an "AS IS" BASIS,
   693  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   694  * See the License for the specific language governing permissions and
   695  * limitations under the License.
   696  * ======================================================================== */
   697 
   698 
   699 +function ($) { "use strict";
   700 
   701   // DROPDOWN CLASS DEFINITION
   702   // =========================
   703 
   704   var backdrop = '.dropdown-backdrop'
   705   var toggle   = '[data-toggle=dropdown]'
   706   var Dropdown = function (element) {
   707     $(element).on('click.bs.dropdown', this.toggle)
   708   }
   709 
   710   Dropdown.prototype.toggle = function (e) {
   711     var $this = $(this)
   712 
   713     if ($this.is('.disabled, :disabled')) return
   714 
   715     var $parent  = getParent($this)
   716     var isActive = $parent.hasClass('open')
   717 
   718     clearMenus()
   719 
   720     if (!isActive) {
   721       if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
   722         // if mobile we use a backdrop because click events don't delegate
   723         $('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus)
   724       }
   725 
   726       $parent.trigger(e = $.Event('show.bs.dropdown'))
   727 
   728       if (e.isDefaultPrevented()) return
   729 
   730       $parent
   731         .toggleClass('open')
   732         .trigger('shown.bs.dropdown')
   733 
   734       $this.focus()
   735     }
   736 
   737     return false
   738   }
   739 
   740   Dropdown.prototype.keydown = function (e) {
   741     if (!/(38|40|27)/.test(e.keyCode)) return
   742 
   743     var $this = $(this)
   744 
   745     e.preventDefault()
   746     e.stopPropagation()
   747 
   748     if ($this.is('.disabled, :disabled')) return
   749 
   750     var $parent  = getParent($this)
   751     var isActive = $parent.hasClass('open')
   752 
   753     if (!isActive || (isActive && e.keyCode == 27)) {
   754       if (e.which == 27) $parent.find(toggle).focus()
   755       return $this.click()
   756     }
   757 
   758     var $items = $('[role=menu] li:not(.divider):visible a', $parent)
   759 
   760     if (!$items.length) return
   761 
   762     var index = $items.index($items.filter(':focus'))
   763 
   764     if (e.keyCode == 38 && index > 0)                 index--                        // up
   765     if (e.keyCode == 40 && index < $items.length - 1) index++                        // down
   766     if (!~index)                                      index=0
   767 
   768     $items.eq(index).focus()
   769   }
   770 
   771   function clearMenus() {
   772     $(backdrop).remove()
   773     $(toggle).each(function (e) {
   774       var $parent = getParent($(this))
   775       if (!$parent.hasClass('open')) return
   776       $parent.trigger(e = $.Event('hide.bs.dropdown'))
   777       if (e.isDefaultPrevented()) return
   778       $parent.removeClass('open').trigger('hidden.bs.dropdown')
   779     })
   780   }
   781 
   782   function getParent($this) {
   783     var selector = $this.attr('data-target')
   784 
   785     if (!selector) {
   786       selector = $this.attr('href')
   787       selector = selector && /#/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
   788     }
   789 
   790     var $parent = selector && $(selector)
   791 
   792     return $parent && $parent.length ? $parent : $this.parent()
   793   }
   794 
   795 
   796   // DROPDOWN PLUGIN DEFINITION
   797   // ==========================
   798 
   799   var old = $.fn.dropdown
   800 
   801   $.fn.dropdown = function (option) {
   802     return this.each(function () {
   803       var $this = $(this)
   804       var data  = $this.data('bs.dropdown')
   805 
   806       if (!data) $this.data('bs.dropdown', (data = new Dropdown(this)))
   807       if (typeof option == 'string') data[option].call($this)
   808     })
   809   }
   810 
   811   $.fn.dropdown.Constructor = Dropdown
   812 
   813 
   814   // DROPDOWN NO CONFLICT
   815   // ====================
   816 
   817   $.fn.dropdown.noConflict = function () {
   818     $.fn.dropdown = old
   819     return this
   820   }
   821 
   822 
   823   // APPLY TO STANDARD DROPDOWN ELEMENTS
   824   // ===================================
   825 
   826   $(document)
   827     .on('click.bs.dropdown.data-api', clearMenus)
   828     .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
   829     .on('click.bs.dropdown.data-api'  , toggle, Dropdown.prototype.toggle)
   830     .on('keydown.bs.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown)
   831 
   832 }(jQuery);
   833 
   834 /* ========================================================================
   835  * Bootstrap: modal.js v3.0.3
   836  * http://getbootstrap.com/javascript/#modals
   837  * ========================================================================
   838  * Copyright 2013 Twitter, Inc.
   839  *
   840  * Licensed under the Apache License, Version 2.0 (the "License");
   841  * you may not use this file except in compliance with the License.
   842  * You may obtain a copy of the License at
   843  *
   844  * http://www.apache.org/licenses/LICENSE-2.0
   845  *
   846  * Unless required by applicable law or agreed to in writing, software
   847  * distributed under the License is distributed on an "AS IS" BASIS,
   848  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   849  * See the License for the specific language governing permissions and
   850  * limitations under the License.
   851  * ======================================================================== */
   852 
   853 
   854 +function ($) { "use strict";
   855 
   856   // MODAL CLASS DEFINITION
   857   // ======================
   858 
   859   var Modal = function (element, options) {
   860     this.options   = options
   861     this.$element  = $(element)
   862     this.$backdrop =
   863     this.isShown   = null
   864 
   865     if (this.options.remote) this.$element.load(this.options.remote)
   866   }
   867 
   868   Modal.DEFAULTS = {
   869       backdrop: true
   870     , keyboard: true
   871     , show: true
   872   }
   873 
   874   Modal.prototype.toggle = function (_relatedTarget) {
   875     return this[!this.isShown ? 'show' : 'hide'](_relatedTarget)
   876   }
   877 
   878   Modal.prototype.show = function (_relatedTarget) {
   879     var that = this
   880     var e    = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
   881 
   882     this.$element.trigger(e)
   883 
   884     if (this.isShown || e.isDefaultPrevented()) return
   885 
   886     this.isShown = true
   887 
   888     this.escape()
   889 
   890     this.$element.on('click.dismiss.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
   891 
   892     this.backdrop(function () {
   893       var transition = $.support.transition && that.$element.hasClass('fade')
   894 
   895       if (!that.$element.parent().length) {
   896         that.$element.appendTo(document.body) // don't move modals dom position
   897       }
   898 
   899       that.$element.show()
   900 
   901       if (transition) {
   902         that.$element[0].offsetWidth // force reflow
   903       }
   904 
   905       that.$element
   906         .addClass('in')
   907         .attr('aria-hidden', false)
   908 
   909       that.enforceFocus()
   910 
   911       var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
   912 
   913       transition ?
   914         that.$element.find('.modal-dialog') // wait for modal to slide in
   915           .one($.support.transition.end, function () {
   916             that.$element.focus().trigger(e)
   917           })
   918           .emulateTransitionEnd(300) :
   919         that.$element.focus().trigger(e)
   920     })
   921   }
   922 
   923   Modal.prototype.hide = function (e) {
   924     if (e) e.preventDefault()
   925 
   926     e = $.Event('hide.bs.modal')
   927 
   928     this.$element.trigger(e)
   929 
   930     if (!this.isShown || e.isDefaultPrevented()) return
   931 
   932     this.isShown = false
   933 
   934     this.escape()
   935 
   936     $(document).off('focusin.bs.modal')
   937 
   938     this.$element
   939       .removeClass('in')
   940       .attr('aria-hidden', true)
   941       .off('click.dismiss.modal')
   942 
   943     $.support.transition && this.$element.hasClass('fade') ?
   944       this.$element
   945         .one($.support.transition.end, $.proxy(this.hideModal, this))
   946         .emulateTransitionEnd(300) :
   947       this.hideModal()
   948   }
   949 
   950   Modal.prototype.enforceFocus = function () {
   951     $(document)
   952       .off('focusin.bs.modal') // guard against infinite focus loop
   953       .on('focusin.bs.modal', $.proxy(function (e) {
   954         if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
   955           this.$element.focus()
   956         }
   957       }, this))
   958   }
   959 
   960   Modal.prototype.escape = function () {
   961     if (this.isShown && this.options.keyboard) {
   962       this.$element.on('keyup.dismiss.bs.modal', $.proxy(function (e) {
   963         e.which == 27 && this.hide()
   964       }, this))
   965     } else if (!this.isShown) {
   966       this.$element.off('keyup.dismiss.bs.modal')
   967     }
   968   }
   969 
   970   Modal.prototype.hideModal = function () {
   971     var that = this
   972     this.$element.hide()
   973     this.backdrop(function () {
   974       that.removeBackdrop()
   975       that.$element.trigger('hidden.bs.modal')
   976     })
   977   }
   978 
   979   Modal.prototype.removeBackdrop = function () {
   980     this.$backdrop && this.$backdrop.remove()
   981     this.$backdrop = null
   982   }
   983 
   984   Modal.prototype.backdrop = function (callback) {
   985     var that    = this
   986     var animate = this.$element.hasClass('fade') ? 'fade' : ''
   987 
   988     if (this.isShown && this.options.backdrop) {
   989       var doAnimate = $.support.transition && animate
   990 
   991       this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
   992         .appendTo(document.body)
   993 
   994       this.$element.on('click.dismiss.modal', $.proxy(function (e) {
   995         if (e.target !== e.currentTarget) return
   996         this.options.backdrop == 'static'
   997           ? this.$element[0].focus.call(this.$element[0])
   998           : this.hide.call(this)
   999       }, this))
  1000 
  1001       if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
  1002 
  1003       this.$backdrop.addClass('in')
  1004 
  1005       if (!callback) return
  1006 
  1007       doAnimate ?
  1008         this.$backdrop
  1009           .one($.support.transition.end, callback)
  1010           .emulateTransitionEnd(150) :
  1011         callback()
  1012 
  1013     } else if (!this.isShown && this.$backdrop) {
  1014       this.$backdrop.removeClass('in')
  1015 
  1016       $.support.transition && this.$element.hasClass('fade')?
  1017         this.$backdrop
  1018           .one($.support.transition.end, callback)
  1019           .emulateTransitionEnd(150) :
  1020         callback()
  1021 
  1022     } else if (callback) {
  1023       callback()
  1024     }
  1025   }
  1026 
  1027 
  1028   // MODAL PLUGIN DEFINITION
  1029   // =======================
  1030 
  1031   var old = $.fn.modal
  1032 
  1033   $.fn.modal = function (option, _relatedTarget) {
  1034     return this.each(function () {
  1035       var $this   = $(this)
  1036       var data    = $this.data('bs.modal')
  1037       var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)
  1038 
  1039       if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
  1040       if (typeof option == 'string') data[option](_relatedTarget)
  1041       else if (options.show) data.show(_relatedTarget)
  1042     })
  1043   }
  1044 
  1045   $.fn.modal.Constructor = Modal
  1046 
  1047 
  1048   // MODAL NO CONFLICT
  1049   // =================
  1050 
  1051   $.fn.modal.noConflict = function () {
  1052     $.fn.modal = old
  1053     return this
  1054   }
  1055 
  1056 
  1057   // MODAL DATA-API
  1058   // ==============
  1059 
  1060   $(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
  1061     var $this   = $(this)
  1062     var href    = $this.attr('href')
  1063     var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
  1064     var option  = $target.data('modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
  1065 
  1066     e.preventDefault()
  1067 
  1068     $target
  1069       .modal(option, this)
  1070       .one('hide', function () {
  1071         $this.is(':visible') && $this.focus()
  1072       })
  1073   })
  1074 
  1075   $(document)
  1076     .on('show.bs.modal',  '.modal', function () { $(document.body).addClass('modal-open') })
  1077     .on('hidden.bs.modal', '.modal', function () { $(document.body).removeClass('modal-open') })
  1078 
  1079 }(jQuery);
  1080 
  1081 /* ========================================================================
  1082  * Bootstrap: tooltip.js v3.0.3
  1083  * http://getbootstrap.com/javascript/#tooltip
  1084  * Inspired by the original jQuery.tipsy by Jason Frame
  1085  * ========================================================================
  1086  * Copyright 2013 Twitter, Inc.
  1087  *
  1088  * Licensed under the Apache License, Version 2.0 (the "License");
  1089  * you may not use this file except in compliance with the License.
  1090  * You may obtain a copy of the License at
  1091  *
  1092  * http://www.apache.org/licenses/LICENSE-2.0
  1093  *
  1094  * Unless required by applicable law or agreed to in writing, software
  1095  * distributed under the License is distributed on an "AS IS" BASIS,
  1096  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1097  * See the License for the specific language governing permissions and
  1098  * limitations under the License.
  1099  * ======================================================================== */
  1100 
  1101 
  1102 +function ($) { "use strict";
  1103 
  1104   // TOOLTIP PUBLIC CLASS DEFINITION
  1105   // ===============================
  1106 
  1107   var Tooltip = function (element, options) {
  1108     this.type       =
  1109     this.options    =
  1110     this.enabled    =
  1111     this.timeout    =
  1112     this.hoverState =
  1113     this.$element   = null
  1114 
  1115     this.init('tooltip', element, options)
  1116   }
  1117 
  1118   Tooltip.DEFAULTS = {
  1119     animation: true
  1120   , placement: 'top'
  1121   , selector: false
  1122   , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
  1123   , trigger: 'hover focus'
  1124   , title: ''
  1125   , delay: 0
  1126   , html: false
  1127   , container: false
  1128   }
  1129 
  1130   Tooltip.prototype.init = function (type, element, options) {
  1131     this.enabled  = true
  1132     this.type     = type
  1133     this.$element = $(element)
  1134     this.options  = this.getOptions(options)
  1135 
  1136     var triggers = this.options.trigger.split(' ')
  1137 
  1138     for (var i = triggers.length; i--;) {
  1139       var trigger = triggers[i]
  1140 
  1141       if (trigger == 'click') {
  1142         this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
  1143       } else if (trigger != 'manual') {
  1144         var eventIn  = trigger == 'hover' ? 'mouseenter' : 'focus'
  1145         var eventOut = trigger == 'hover' ? 'mouseleave' : 'blur'
  1146 
  1147         this.$element.on(eventIn  + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
  1148         this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
  1149       }
  1150     }
  1151 
  1152     this.options.selector ?
  1153       (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
  1154       this.fixTitle()
  1155   }
  1156 
  1157   Tooltip.prototype.getDefaults = function () {
  1158     return Tooltip.DEFAULTS
  1159   }
  1160 
  1161   Tooltip.prototype.getOptions = function (options) {
  1162     options = $.extend({}, this.getDefaults(), this.$element.data(), options)
  1163 
  1164     if (options.delay && typeof options.delay == 'number') {
  1165       options.delay = {
  1166         show: options.delay
  1167       , hide: options.delay
  1168       }
  1169     }
  1170 
  1171     return options
  1172   }
  1173 
  1174   Tooltip.prototype.getDelegateOptions = function () {
  1175     var options  = {}
  1176     var defaults = this.getDefaults()
  1177 
  1178     this._options && $.each(this._options, function (key, value) {
  1179       if (defaults[key] != value) options[key] = value
  1180     })
  1181 
  1182     return options
  1183   }
  1184 
  1185   Tooltip.prototype.enter = function (obj) {
  1186     var self = obj instanceof this.constructor ?
  1187       obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
  1188 
  1189     clearTimeout(self.timeout)
  1190 
  1191     self.hoverState = 'in'
  1192 
  1193     if (!self.options.delay || !self.options.delay.show) return self.show()
  1194 
  1195     self.timeout = setTimeout(function () {
  1196       if (self.hoverState == 'in') self.show()
  1197     }, self.options.delay.show)
  1198   }
  1199 
  1200   Tooltip.prototype.leave = function (obj) {
  1201     var self = obj instanceof this.constructor ?
  1202       obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
  1203 
  1204     clearTimeout(self.timeout)
  1205 
  1206     self.hoverState = 'out'
  1207 
  1208     if (!self.options.delay || !self.options.delay.hide) return self.hide()
  1209 
  1210     self.timeout = setTimeout(function () {
  1211       if (self.hoverState == 'out') self.hide()
  1212     }, self.options.delay.hide)
  1213   }
  1214 
  1215   Tooltip.prototype.show = function () {
  1216     var e = $.Event('show.bs.'+ this.type)
  1217 
  1218     if (this.hasContent() && this.enabled) {
  1219       this.$element.trigger(e)
  1220 
  1221       if (e.isDefaultPrevented()) return
  1222 
  1223       var $tip = this.tip()
  1224 
  1225       this.setContent()
  1226 
  1227       if (this.options.animation) $tip.addClass('fade')
  1228 
  1229       var placement = typeof this.options.placement == 'function' ?
  1230         this.options.placement.call(this, $tip[0], this.$element[0]) :
  1231         this.options.placement
  1232 
  1233       var autoToken = /\s?auto?\s?/i
  1234       var autoPlace = autoToken.test(placement)
  1235       if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
  1236 
  1237       $tip
  1238         .detach()
  1239         .css({ top: 0, left: 0, display: 'block' })
  1240         .addClass(placement)
  1241 
  1242       this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
  1243 
  1244       var pos          = this.getPosition()
  1245       var actualWidth  = $tip[0].offsetWidth
  1246       var actualHeight = $tip[0].offsetHeight
  1247 
  1248       if (autoPlace) {
  1249         var $parent = this.$element.parent()
  1250 
  1251         var orgPlacement = placement
  1252         var docScroll    = document.documentElement.scrollTop || document.body.scrollTop
  1253         var parentWidth  = this.options.container == 'body' ? window.innerWidth  : $parent.outerWidth()
  1254         var parentHeight = this.options.container == 'body' ? window.innerHeight : $parent.outerHeight()
  1255         var parentLeft   = this.options.container == 'body' ? 0 : $parent.offset().left
  1256 
  1257         placement = placement == 'bottom' && pos.top   + pos.height  + actualHeight - docScroll > parentHeight  ? 'top'    :
  1258                     placement == 'top'    && pos.top   - docScroll   - actualHeight < 0                         ? 'bottom' :
  1259                     placement == 'right'  && pos.right + actualWidth > parentWidth                              ? 'left'   :
  1260                     placement == 'left'   && pos.left  - actualWidth < parentLeft                               ? 'right'  :
  1261                     placement
  1262 
  1263         $tip
  1264           .removeClass(orgPlacement)
  1265           .addClass(placement)
  1266       }
  1267 
  1268       var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight)
  1269 
  1270       this.applyPlacement(calculatedOffset, placement)
  1271       this.$element.trigger('shown.bs.' + this.type)
  1272     }
  1273   }
  1274 
  1275   Tooltip.prototype.applyPlacement = function(offset, placement) {
  1276     var replace
  1277     var $tip   = this.tip()
  1278     var width  = $tip[0].offsetWidth
  1279     var height = $tip[0].offsetHeight
  1280 
  1281     // manually read margins because getBoundingClientRect includes difference
  1282     var marginTop = parseInt($tip.css('margin-top'), 10)
  1283     var marginLeft = parseInt($tip.css('margin-left'), 10)
  1284 
  1285     // we must check for NaN for ie 8/9
  1286     if (isNaN(marginTop))  marginTop  = 0
  1287     if (isNaN(marginLeft)) marginLeft = 0
  1288 
  1289     offset.top  = offset.top  + marginTop
  1290     offset.left = offset.left + marginLeft
  1291 
  1292     $tip
  1293       .offset(offset)
  1294       .addClass('in')
  1295 
  1296     // check to see if placing tip in new offset caused the tip to resize itself
  1297     var actualWidth  = $tip[0].offsetWidth
  1298     var actualHeight = $tip[0].offsetHeight
  1299 
  1300     if (placement == 'top' && actualHeight != height) {
  1301       replace = true
  1302       offset.top = offset.top + height - actualHeight
  1303     }
  1304 
  1305     if (/bottom|top/.test(placement)) {
  1306       var delta = 0
  1307 
  1308       if (offset.left < 0) {
  1309         delta       = offset.left * -2
  1310         offset.left = 0
  1311 
  1312         $tip.offset(offset)
  1313 
  1314         actualWidth  = $tip[0].offsetWidth
  1315         actualHeight = $tip[0].offsetHeight
  1316       }
  1317 
  1318       this.replaceArrow(delta - width + actualWidth, actualWidth, 'left')
  1319     } else {
  1320       this.replaceArrow(actualHeight - height, actualHeight, 'top')
  1321     }
  1322 
  1323     if (replace) $tip.offset(offset)
  1324   }
  1325 
  1326   Tooltip.prototype.replaceArrow = function(delta, dimension, position) {
  1327     this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + "%") : '')
  1328   }
  1329 
  1330   Tooltip.prototype.setContent = function () {
  1331     var $tip  = this.tip()
  1332     var title = this.getTitle()
  1333 
  1334     $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
  1335     $tip.removeClass('fade in top bottom left right')
  1336   }
  1337 
  1338   Tooltip.prototype.hide = function () {
  1339     var that = this
  1340     var $tip = this.tip()
  1341     var e    = $.Event('hide.bs.' + this.type)
  1342 
  1343     function complete() {
  1344       if (that.hoverState != 'in') $tip.detach()
  1345     }
  1346 
  1347     this.$element.trigger(e)
  1348 
  1349     if (e.isDefaultPrevented()) return
  1350 
  1351     $tip.removeClass('in')
  1352 
  1353     $.support.transition && this.$tip.hasClass('fade') ?
  1354       $tip
  1355         .one($.support.transition.end, complete)
  1356         .emulateTransitionEnd(150) :
  1357       complete()
  1358 
  1359     this.$element.trigger('hidden.bs.' + this.type)
  1360 
  1361     return this
  1362   }
  1363 
  1364   Tooltip.prototype.fixTitle = function () {
  1365     var $e = this.$element
  1366     if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
  1367       $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
  1368     }
  1369   }
  1370 
  1371   Tooltip.prototype.hasContent = function () {
  1372     return this.getTitle()
  1373   }
  1374 
  1375   Tooltip.prototype.getPosition = function () {
  1376     var el = this.$element[0]
  1377     return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : {
  1378       width: el.offsetWidth
  1379     , height: el.offsetHeight
  1380     }, this.$element.offset())
  1381   }
  1382 
  1383   Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) {
  1384     return placement == 'bottom' ? { top: pos.top + pos.height,   left: pos.left + pos.width / 2 - actualWidth / 2  } :
  1385            placement == 'top'    ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2  } :
  1386            placement == 'left'   ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } :
  1387         /* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width   }
  1388   }
  1389 
  1390   Tooltip.prototype.getTitle = function () {
  1391     var title
  1392     var $e = this.$element
  1393     var o  = this.options
  1394 
  1395     title = $e.attr('data-original-title')
  1396       || (typeof o.title == 'function' ? o.title.call($e[0]) :  o.title)
  1397 
  1398     return title
  1399   }
  1400 
  1401   Tooltip.prototype.tip = function () {
  1402     return this.$tip = this.$tip || $(this.options.template)
  1403   }
  1404 
  1405   Tooltip.prototype.arrow = function () {
  1406     return this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow')
  1407   }
  1408 
  1409   Tooltip.prototype.validate = function () {
  1410     if (!this.$element[0].parentNode) {
  1411       this.hide()
  1412       this.$element = null
  1413       this.options  = null
  1414     }
  1415   }
  1416 
  1417   Tooltip.prototype.enable = function () {
  1418     this.enabled = true
  1419   }
  1420 
  1421   Tooltip.prototype.disable = function () {
  1422     this.enabled = false
  1423   }
  1424 
  1425   Tooltip.prototype.toggleEnabled = function () {
  1426     this.enabled = !this.enabled
  1427   }
  1428 
  1429   Tooltip.prototype.toggle = function (e) {
  1430     var self = e ? $(e.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) : this
  1431     self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
  1432   }
  1433 
  1434   Tooltip.prototype.destroy = function () {
  1435     this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
  1436   }
  1437 
  1438 
  1439   // TOOLTIP PLUGIN DEFINITION
  1440   // =========================
  1441 
  1442   var old = $.fn.tooltip
  1443 
  1444   $.fn.tooltip = function (option) {
  1445     return this.each(function () {
  1446       var $this   = $(this)
  1447       var data    = $this.data('bs.tooltip')
  1448       var options = typeof option == 'object' && option
  1449 
  1450       if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
  1451       if (typeof option == 'string') data[option]()
  1452     })
  1453   }
  1454 
  1455   $.fn.tooltip.Constructor = Tooltip
  1456 
  1457 
  1458   // TOOLTIP NO CONFLICT
  1459   // ===================
  1460 
  1461   $.fn.tooltip.noConflict = function () {
  1462     $.fn.tooltip = old
  1463     return this
  1464   }
  1465 
  1466 }(jQuery);
  1467 
  1468 /* ========================================================================
  1469  * Bootstrap: popover.js v3.0.3
  1470  * http://getbootstrap.com/javascript/#popovers
  1471  * ========================================================================
  1472  * Copyright 2013 Twitter, Inc.
  1473  *
  1474  * Licensed under the Apache License, Version 2.0 (the "License");
  1475  * you may not use this file except in compliance with the License.
  1476  * You may obtain a copy of the License at
  1477  *
  1478  * http://www.apache.org/licenses/LICENSE-2.0
  1479  *
  1480  * Unless required by applicable law or agreed to in writing, software
  1481  * distributed under the License is distributed on an "AS IS" BASIS,
  1482  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1483  * See the License for the specific language governing permissions and
  1484  * limitations under the License.
  1485  * ======================================================================== */
  1486 
  1487 
  1488 +function ($) { "use strict";
  1489 
  1490   // POPOVER PUBLIC CLASS DEFINITION
  1491   // ===============================
  1492 
  1493   var Popover = function (element, options) {
  1494     this.init('popover', element, options)
  1495   }
  1496 
  1497   if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js')
  1498 
  1499   Popover.DEFAULTS = $.extend({} , $.fn.tooltip.Constructor.DEFAULTS, {
  1500     placement: 'right'
  1501   , trigger: 'click'
  1502   , content: ''
  1503   , template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
  1504   })
  1505 
  1506 
  1507   // NOTE: POPOVER EXTENDS tooltip.js
  1508   // ================================
  1509 
  1510   Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
  1511 
  1512   Popover.prototype.constructor = Popover
  1513 
  1514   Popover.prototype.getDefaults = function () {
  1515     return Popover.DEFAULTS
  1516   }
  1517 
  1518   Popover.prototype.setContent = function () {
  1519     var $tip    = this.tip()
  1520     var title   = this.getTitle()
  1521     var content = this.getContent()
  1522 
  1523     $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
  1524     $tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
  1525 
  1526     $tip.removeClass('fade top bottom left right in')
  1527 
  1528     // IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
  1529     // this manually by checking the contents.
  1530     if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide()
  1531   }
  1532 
  1533   Popover.prototype.hasContent = function () {
  1534     return this.getTitle() || this.getContent()
  1535   }
  1536 
  1537   Popover.prototype.getContent = function () {
  1538     var $e = this.$element
  1539     var o  = this.options
  1540 
  1541     return $e.attr('data-content')
  1542       || (typeof o.content == 'function' ?
  1543             o.content.call($e[0]) :
  1544             o.content)
  1545   }
  1546 
  1547   Popover.prototype.arrow = function () {
  1548     return this.$arrow = this.$arrow || this.tip().find('.arrow')
  1549   }
  1550 
  1551   Popover.prototype.tip = function () {
  1552     if (!this.$tip) this.$tip = $(this.options.template)
  1553     return this.$tip
  1554   }
  1555 
  1556 
  1557   // POPOVER PLUGIN DEFINITION
  1558   // =========================
  1559 
  1560   var old = $.fn.popover
  1561 
  1562   $.fn.popover = function (option) {
  1563     return this.each(function () {
  1564       var $this   = $(this)
  1565       var data    = $this.data('bs.popover')
  1566       var options = typeof option == 'object' && option
  1567 
  1568       if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
  1569       if (typeof option == 'string') data[option]()
  1570     })
  1571   }
  1572 
  1573   $.fn.popover.Constructor = Popover
  1574 
  1575 
  1576   // POPOVER NO CONFLICT
  1577   // ===================
  1578 
  1579   $.fn.popover.noConflict = function () {
  1580     $.fn.popover = old
  1581     return this
  1582   }
  1583 
  1584 }(jQuery);
  1585 
  1586 /* ========================================================================
  1587  * Bootstrap: scrollspy.js v3.0.3
  1588  * http://getbootstrap.com/javascript/#scrollspy
  1589  * ========================================================================
  1590  * Copyright 2013 Twitter, Inc.
  1591  *
  1592  * Licensed under the Apache License, Version 2.0 (the "License");
  1593  * you may not use this file except in compliance with the License.
  1594  * You may obtain a copy of the License at
  1595  *
  1596  * http://www.apache.org/licenses/LICENSE-2.0
  1597  *
  1598  * Unless required by applicable law or agreed to in writing, software
  1599  * distributed under the License is distributed on an "AS IS" BASIS,
  1600  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1601  * See the License for the specific language governing permissions and
  1602  * limitations under the License.
  1603  * ======================================================================== */
  1604 
  1605 
  1606 +function ($) { "use strict";
  1607 
  1608   // SCROLLSPY CLASS DEFINITION
  1609   // ==========================
  1610 
  1611   function ScrollSpy(element, options) {
  1612     var href
  1613     var process  = $.proxy(this.process, this)
  1614 
  1615     this.$element       = $(element).is('body') ? $(window) : $(element)
  1616     this.$body          = $('body')
  1617     this.$scrollElement = this.$element.on('scroll.bs.scroll-spy.data-api', process)
  1618     this.options        = $.extend({}, ScrollSpy.DEFAULTS, options)
  1619     this.selector       = (this.options.target
  1620       || ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
  1621       || '') + ' .nav li > a'
  1622     this.offsets        = $([])
  1623     this.targets        = $([])
  1624     this.activeTarget   = null
  1625 
  1626     this.refresh()
  1627     this.process()
  1628   }
  1629 
  1630   ScrollSpy.DEFAULTS = {
  1631     offset: 10
  1632   }
  1633 
  1634   ScrollSpy.prototype.refresh = function () {
  1635     var offsetMethod = this.$element[0] == window ? 'offset' : 'position'
  1636 
  1637     this.offsets = $([])
  1638     this.targets = $([])
  1639 
  1640     var self     = this
  1641     var $targets = this.$body
  1642       .find(this.selector)
  1643       .map(function () {
  1644         var $el   = $(this)
  1645         var href  = $el.data('target') || $el.attr('href')
  1646         var $href = /^#\w/.test(href) && $(href)
  1647 
  1648         return ($href
  1649           && $href.length
  1650           && [[ $href[offsetMethod]().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]]) || null
  1651       })
  1652       .sort(function (a, b) { return a[0] - b[0] })
  1653       .each(function () {
  1654         self.offsets.push(this[0])
  1655         self.targets.push(this[1])
  1656       })
  1657   }
  1658 
  1659   ScrollSpy.prototype.process = function () {
  1660     var scrollTop    = this.$scrollElement.scrollTop() + this.options.offset
  1661     var scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
  1662     var maxScroll    = scrollHeight - this.$scrollElement.height()
  1663     var offsets      = this.offsets
  1664     var targets      = this.targets
  1665     var activeTarget = this.activeTarget
  1666     var i
  1667 
  1668     if (scrollTop >= maxScroll) {
  1669       return activeTarget != (i = targets.last()[0]) && this.activate(i)
  1670     }
  1671 
  1672     for (i = offsets.length; i--;) {
  1673       activeTarget != targets[i]
  1674         && scrollTop >= offsets[i]
  1675         && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
  1676         && this.activate( targets[i] )
  1677     }
  1678   }
  1679 
  1680   ScrollSpy.prototype.activate = function (target) {
  1681     this.activeTarget = target
  1682 
  1683     $(this.selector)
  1684       .parents('.active')
  1685       .removeClass('active')
  1686 
  1687     var selector = this.selector
  1688       + '[data-target="' + target + '"],'
  1689       + this.selector + '[href="' + target + '"]'
  1690 
  1691     var active = $(selector)
  1692       .parents('li')
  1693       .addClass('active')
  1694 
  1695     if (active.parent('.dropdown-menu').length)  {
  1696       active = active
  1697         .closest('li.dropdown')
  1698         .addClass('active')
  1699     }
  1700 
  1701     active.trigger('activate.bs.scrollspy')
  1702   }
  1703 
  1704 
  1705   // SCROLLSPY PLUGIN DEFINITION
  1706   // ===========================
  1707 
  1708   var old = $.fn.scrollspy
  1709 
  1710   $.fn.scrollspy = function (option) {
  1711     return this.each(function () {
  1712       var $this   = $(this)
  1713       var data    = $this.data('bs.scrollspy')
  1714       var options = typeof option == 'object' && option
  1715 
  1716       if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
  1717       if (typeof option == 'string') data[option]()
  1718     })
  1719   }
  1720 
  1721   $.fn.scrollspy.Constructor = ScrollSpy
  1722 
  1723 
  1724   // SCROLLSPY NO CONFLICT
  1725   // =====================
  1726 
  1727   $.fn.scrollspy.noConflict = function () {
  1728     $.fn.scrollspy = old
  1729     return this
  1730   }
  1731 
  1732 
  1733   // SCROLLSPY DATA-API
  1734   // ==================
  1735 
  1736   $(window).on('load', function () {
  1737     $('[data-spy="scroll"]').each(function () {
  1738       var $spy = $(this)
  1739       $spy.scrollspy($spy.data())
  1740     })
  1741   })
  1742 
  1743 }(jQuery);
  1744 
  1745 /* ========================================================================
  1746  * Bootstrap: tab.js v3.0.3
  1747  * http://getbootstrap.com/javascript/#tabs
  1748  * ========================================================================
  1749  * Copyright 2013 Twitter, Inc.
  1750  *
  1751  * Licensed under the Apache License, Version 2.0 (the "License");
  1752  * you may not use this file except in compliance with the License.
  1753  * You may obtain a copy of the License at
  1754  *
  1755  * http://www.apache.org/licenses/LICENSE-2.0
  1756  *
  1757  * Unless required by applicable law or agreed to in writing, software
  1758  * distributed under the License is distributed on an "AS IS" BASIS,
  1759  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1760  * See the License for the specific language governing permissions and
  1761  * limitations under the License.
  1762  * ======================================================================== */
  1763 
  1764 
  1765 +function ($) { "use strict";
  1766 
  1767   // TAB CLASS DEFINITION
  1768   // ====================
  1769 
  1770   var Tab = function (element) {
  1771     this.element = $(element)
  1772   }
  1773 
  1774   Tab.prototype.show = function () {
  1775     var $this    = this.element
  1776     var $ul      = $this.closest('ul:not(.dropdown-menu)')
  1777     var selector = $this.data('target')
  1778 
  1779     if (!selector) {
  1780       selector = $this.attr('href')
  1781       selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
  1782     }
  1783 
  1784     if ($this.parent('li').hasClass('active')) return
  1785 
  1786     var previous = $ul.find('.active:last a')[0]
  1787     var e        = $.Event('show.bs.tab', {
  1788       relatedTarget: previous
  1789     })
  1790 
  1791     $this.trigger(e)
  1792 
  1793     if (e.isDefaultPrevented()) return
  1794 
  1795     var $target = $(selector)
  1796 
  1797     this.activate($this.parent('li'), $ul)
  1798     this.activate($target, $target.parent(), function () {
  1799       $this.trigger({
  1800         type: 'shown.bs.tab'
  1801       , relatedTarget: previous
  1802       })
  1803     })
  1804   }
  1805 
  1806   Tab.prototype.activate = function (element, container, callback) {
  1807     var $active    = container.find('> .active')
  1808     var transition = callback
  1809       && $.support.transition
  1810       && $active.hasClass('fade')
  1811 
  1812     function next() {
  1813       $active
  1814         .removeClass('active')
  1815         .find('> .dropdown-menu > .active')
  1816         .removeClass('active')
  1817 
  1818       element.addClass('active')
  1819 
  1820       if (transition) {
  1821         element[0].offsetWidth // reflow for transition
  1822         element.addClass('in')
  1823       } else {
  1824         element.removeClass('fade')
  1825       }
  1826 
  1827       if (element.parent('.dropdown-menu')) {
  1828         element.closest('li.dropdown').addClass('active')
  1829       }
  1830 
  1831       callback && callback()
  1832     }
  1833 
  1834     transition ?
  1835       $active
  1836         .one($.support.transition.end, next)
  1837         .emulateTransitionEnd(150) :
  1838       next()
  1839 
  1840     $active.removeClass('in')
  1841   }
  1842 
  1843 
  1844   // TAB PLUGIN DEFINITION
  1845   // =====================
  1846 
  1847   var old = $.fn.tab
  1848 
  1849   $.fn.tab = function ( option ) {
  1850     return this.each(function () {
  1851       var $this = $(this)
  1852       var data  = $this.data('bs.tab')
  1853 
  1854       if (!data) $this.data('bs.tab', (data = new Tab(this)))
  1855       if (typeof option == 'string') data[option]()
  1856     })
  1857   }
  1858 
  1859   $.fn.tab.Constructor = Tab
  1860 
  1861 
  1862   // TAB NO CONFLICT
  1863   // ===============
  1864 
  1865   $.fn.tab.noConflict = function () {
  1866     $.fn.tab = old
  1867     return this
  1868   }
  1869 
  1870 
  1871   // TAB DATA-API
  1872   // ============
  1873 
  1874   $(document).on('click.bs.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) {
  1875     e.preventDefault()
  1876     $(this).tab('show')
  1877   })
  1878 
  1879 }(jQuery);
  1880 
  1881 /* ========================================================================
  1882  * Bootstrap: affix.js v3.0.3
  1883  * http://getbootstrap.com/javascript/#affix
  1884  * ========================================================================
  1885  * Copyright 2013 Twitter, Inc.
  1886  *
  1887  * Licensed under the Apache License, Version 2.0 (the "License");
  1888  * you may not use this file except in compliance with the License.
  1889  * You may obtain a copy of the License at
  1890  *
  1891  * http://www.apache.org/licenses/LICENSE-2.0
  1892  *
  1893  * Unless required by applicable law or agreed to in writing, software
  1894  * distributed under the License is distributed on an "AS IS" BASIS,
  1895  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1896  * See the License for the specific language governing permissions and
  1897  * limitations under the License.
  1898  * ======================================================================== */
  1899 
  1900 
  1901 +function ($) { "use strict";
  1902 
  1903   // AFFIX CLASS DEFINITION
  1904   // ======================
  1905 
  1906   var Affix = function (element, options) {
  1907     this.options = $.extend({}, Affix.DEFAULTS, options)
  1908     this.$window = $(window)
  1909       .on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))
  1910       .on('click.bs.affix.data-api',  $.proxy(this.checkPositionWithEventLoop, this))
  1911 
  1912     this.$element = $(element)
  1913     this.affixed  =
  1914     this.unpin    = null
  1915 
  1916     this.checkPosition()
  1917   }
  1918 
  1919   Affix.RESET = 'affix affix-top affix-bottom'
  1920 
  1921   Affix.DEFAULTS = {
  1922     offset: 0
  1923   }
  1924 
  1925   Affix.prototype.checkPositionWithEventLoop = function () {
  1926     setTimeout($.proxy(this.checkPosition, this), 1)
  1927   }
  1928 
  1929   Affix.prototype.checkPosition = function () {
  1930     if (!this.$element.is(':visible')) return
  1931 
  1932     var scrollHeight = $(document).height()
  1933     var scrollTop    = this.$window.scrollTop()
  1934     var position     = this.$element.offset()
  1935     var offset       = this.options.offset
  1936     var offsetTop    = offset.top
  1937     var offsetBottom = offset.bottom
  1938 
  1939     if (typeof offset != 'object')         offsetBottom = offsetTop = offset
  1940     if (typeof offsetTop == 'function')    offsetTop    = offset.top()
  1941     if (typeof offsetBottom == 'function') offsetBottom = offset.bottom()
  1942 
  1943     var affix = this.unpin   != null && (scrollTop + this.unpin <= position.top) ? false :
  1944                 offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? 'bottom' :
  1945                 offsetTop    != null && (scrollTop <= offsetTop) ? 'top' : false
  1946 
  1947     if (this.affixed === affix) return
  1948     if (this.unpin) this.$element.css('top', '')
  1949 
  1950     this.affixed = affix
  1951     this.unpin   = affix == 'bottom' ? position.top - scrollTop : null
  1952 
  1953     this.$element.removeClass(Affix.RESET).addClass('affix' + (affix ? '-' + affix : ''))
  1954 
  1955     if (affix == 'bottom') {
  1956       this.$element.offset({ top: document.body.offsetHeight - offsetBottom - this.$element.height() })
  1957     }
  1958   }
  1959 
  1960 
  1961   // AFFIX PLUGIN DEFINITION
  1962   // =======================
  1963 
  1964   var old = $.fn.affix
  1965 
  1966   $.fn.affix = function (option) {
  1967     return this.each(function () {
  1968       var $this   = $(this)
  1969       var data    = $this.data('bs.affix')
  1970       var options = typeof option == 'object' && option
  1971 
  1972       if (!data) $this.data('bs.affix', (data = new Affix(this, options)))
  1973       if (typeof option == 'string') data[option]()
  1974     })
  1975   }
  1976 
  1977   $.fn.affix.Constructor = Affix
  1978 
  1979 
  1980   // AFFIX NO CONFLICT
  1981   // =================
  1982 
  1983   $.fn.affix.noConflict = function () {
  1984     $.fn.affix = old
  1985     return this
  1986   }
  1987 
  1988 
  1989   // AFFIX DATA-API
  1990   // ==============
  1991 
  1992   $(window).on('load', function () {
  1993     $('[data-spy="affix"]').each(function () {
  1994       var $spy = $(this)
  1995       var data = $spy.data()
  1996 
  1997       data.offset = data.offset || {}
  1998 
  1999       if (data.offsetBottom) data.offset.bottom = data.offsetBottom
  2000       if (data.offsetTop)    data.offset.top    = data.offsetTop
  2001 
  2002       $spy.affix(data)
  2003     })
  2004   })
  2005 
  2006 }(jQuery);
Impressum Datenschutzerklärung