| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437 | 
							- /* ===================================================
 
-  * bootstrap-transition.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#transitions
 
-  * ===================================================
 
-  * Copyright 2013 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-modal.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#modals
 
-  * =========================================================
 
-  * Copyright 2013 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 ;_;
 
-  /* MODAL CLASS DEFINITION
 
-   * ====================== */
 
-   var Modal = function (element, options) {
 
-     this.options = options
 
-     this.$element = $(element)
 
-       .delegate('[data-dismiss="modal"]', 'click.dismiss.modal', $.proxy(this.hide, this))
 
-     this.options.remote && this.$element.find('.modal-body').load(this.options.remote)
 
-   }
 
-   Modal.prototype = {
 
-       constructor: Modal
 
-     , toggle: function () {
 
-         return this[!this.isShown ? 'show' : 'hide']()
 
-       }
 
-     , show: function () {
 
-         var that = this
 
-           , e = $.Event('show')
 
-         this.$element.trigger(e)
 
-         if (this.isShown || e.isDefaultPrevented()) return
 
-         this.isShown = true
 
-         this.escape()
 
-         this.backdrop(function () {
 
-           var transition = $.support.transition && that.$element.hasClass('fade')
 
-           if (!that.$element.parent().length) {
 
-             that.$element.appendTo(document.body) //don't move modals dom position
 
-           }
 
-           that.$element.show()
 
-           if (transition) {
 
-             that.$element[0].offsetWidth // force reflow
 
-           }
 
-           that.$element
 
-             .addClass('in')
 
-             .attr('aria-hidden', false)
 
-           that.enforceFocus()
 
-           transition ?
 
-             that.$element.one($.support.transition.end, function () { that.$element.focus().trigger('shown') }) :
 
-             that.$element.focus().trigger('shown')
 
-         })
 
-       }
 
-     , hide: function (e) {
 
-         e && e.preventDefault()
 
-         var that = this
 
-         e = $.Event('hide')
 
-         this.$element.trigger(e)
 
-         if (!this.isShown || e.isDefaultPrevented()) return
 
-         this.isShown = false
 
-         this.escape()
 
-         $(document).off('focusin.modal')
 
-         this.$element
 
-           .removeClass('in')
 
-           .attr('aria-hidden', true)
 
-         $.support.transition && this.$element.hasClass('fade') ?
 
-           this.hideWithTransition() :
 
-           this.hideModal()
 
-       }
 
-     , enforceFocus: function () {
 
-         var that = this
 
-         $(document).on('focusin.modal', function (e) {
 
-           if (that.$element[0] !== e.target && !that.$element.has(e.target).length) {
 
-             that.$element.focus()
 
-           }
 
-         })
 
-       }
 
-     , escape: function () {
 
-         var that = this
 
-         if (this.isShown && this.options.keyboard) {
 
-           this.$element.on('keyup.dismiss.modal', function ( e ) {
 
-             e.which == 27 && that.hide()
 
-           })
 
-         } else if (!this.isShown) {
 
-           this.$element.off('keyup.dismiss.modal')
 
-         }
 
-       }
 
-     , hideWithTransition: function () {
 
-         var that = this
 
-           , timeout = setTimeout(function () {
 
-               that.$element.off($.support.transition.end)
 
-               that.hideModal()
 
-             }, 500)
 
-         this.$element.one($.support.transition.end, function () {
 
-           clearTimeout(timeout)
 
-           that.hideModal()
 
-         })
 
-       }
 
-     , hideModal: function () {
 
-         var that = this
 
-         this.$element.hide()
 
-         this.backdrop(function () {
 
-           that.removeBackdrop()
 
-           that.$element.trigger('hidden')
 
-         })
 
-       }
 
-     , removeBackdrop: function () {
 
-         this.$backdrop && this.$backdrop.remove()
 
-         this.$backdrop = null
 
-       }
 
-     , backdrop: function (callback) {
 
-         var that = this
 
-           , animate = this.$element.hasClass('fade') ? 'fade' : ''
 
-         if (this.isShown && this.options.backdrop) {
 
-           var doAnimate = $.support.transition && animate
 
-           this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
 
-             .appendTo(document.body)
 
-           this.$backdrop.click(
 
-             this.options.backdrop == 'static' ?
 
-               $.proxy(this.$element[0].focus, this.$element[0])
 
-             : $.proxy(this.hide, this)
 
-           )
 
-           if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
 
-           this.$backdrop.addClass('in')
 
-           if (!callback) return
 
-           doAnimate ?
 
-             this.$backdrop.one($.support.transition.end, callback) :
 
-             callback()
 
-         } else if (!this.isShown && this.$backdrop) {
 
-           this.$backdrop.removeClass('in')
 
-           $.support.transition && this.$element.hasClass('fade')?
 
-             this.$backdrop.one($.support.transition.end, callback) :
 
-             callback()
 
-         } else if (callback) {
 
-           callback()
 
-         }
 
-       }
 
-   }
 
-  /* MODAL PLUGIN DEFINITION
 
-   * ======================= */
 
-   var old = $.fn.modal
 
-   $.fn.modal = function (option) {
 
-     return this.each(function () {
 
-       var $this = $(this)
 
-         , data = $this.data('modal')
 
-         , options = $.extend({}, $.fn.modal.defaults, $this.data(), typeof option == 'object' && option)
 
-       if (!data) $this.data('modal', (data = new Modal(this, options)))
 
-       if (typeof option == 'string') data[option]()
 
-       else if (options.show) data.show()
 
-     })
 
-   }
 
-   $.fn.modal.defaults = {
 
-       backdrop: true
 
-     , keyboard: true
 
-     , show: true
 
-   }
 
-   $.fn.modal.Constructor = Modal
 
-  /* MODAL NO CONFLICT
 
-   * ================= */
 
-   $.fn.modal.noConflict = function () {
 
-     $.fn.modal = old
 
-     return this
 
-   }
 
-  /* MODAL DATA-API
 
-   * ============== */
 
-   $(document).on('click.modal.data-api', '[data-toggle="modal"]', function (e) {
 
-     var $this = $(this)
 
-       , href = $this.attr('href')
 
-       , $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
 
-       , option = $target.data('modal') ? 'toggle' : $.extend({ remote:!/#/.test(href) && href }, $target.data(), $this.data())
 
-     e.preventDefault()
 
-     $target
 
-       .modal(option)
 
-       .one('hide', function () {
 
-         $this.focus()
 
-       })
 
-   })
 
- }(window.jQuery);
 
- /* ============================================================
 
-  * bootstrap-dropdown.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#dropdowns
 
-  * ============================================================
 
-  * Copyright 2013 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 ;_;
 
-  /* DROPDOWN CLASS DEFINITION
 
-   * ========================= */
 
-   var toggle = '[data-toggle=dropdown]'
 
-     , Dropdown = function (element) {
 
-         var $el = $(element).on('click.dropdown.data-api', this.toggle)
 
-         $('html').on('click.dropdown.data-api', function () {
 
-           $el.parent().removeClass('open')
 
-         })
 
-       }
 
-   Dropdown.prototype = {
 
-     constructor: Dropdown
 
-   , toggle: function (e) {
 
-       var $this = $(this)
 
-         , $parent
 
-         , isActive
 
-       if ($this.is('.disabled, :disabled')) return
 
-       $parent = getParent($this)
 
-       isActive = $parent.hasClass('open')
 
-       clearMenus()
 
-       if (!isActive) {
 
-         if ('ontouchstart' in document.documentElement) {
 
-           // if mobile we we use a backdrop because click events don't delegate
 
-           $('<div class="dropdown-backdrop"/>').insertBefore($(this)).on('click', clearMenus)
 
-         }
 
-         $parent.toggleClass('open')
 
-       }
 
-       $this.focus()
 
-       return false
 
-     }
 
-   , keydown: function (e) {
 
-       var $this
 
-         , $items
 
-         , $active
 
-         , $parent
 
-         , isActive
 
-         , index
 
-       if (!/(38|40|27)/.test(e.keyCode)) return
 
-       $this = $(this)
 
-       e.preventDefault()
 
-       e.stopPropagation()
 
-       if ($this.is('.disabled, :disabled')) return
 
-       $parent = getParent($this)
 
-       isActive = $parent.hasClass('open')
 
-       if (!isActive || (isActive && e.keyCode == 27)) {
 
-         if (e.which == 27) $parent.find(toggle).focus()
 
-         return $this.click()
 
-       }
 
-       $items = $('[role=menu] li:not(.divider):visible a', $parent)
 
-       if (!$items.length) return
 
-       index = $items.index($items.filter(':focus'))
 
-       if (e.keyCode == 38 && index > 0) index--                                        // up
 
-       if (e.keyCode == 40 && index < $items.length - 1) index++                        // down
 
-       if (!~index) index = 0
 
-       $items
 
-         .eq(index)
 
-         .focus()
 
-     }
 
-   }
 
-   function clearMenus() {
 
-     $('.dropdown-backdrop').remove()
 
-     $(toggle).each(function () {
 
-       getParent($(this)).removeClass('open')
 
-     })
 
-   }
 
-   function getParent($this) {
 
-     var selector = $this.attr('data-target')
 
-       , $parent
 
-     if (!selector) {
 
-       selector = $this.attr('href')
 
-       selector = selector && /#/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
 
-     }
 
-     $parent = selector && $(selector)
 
-     if (!$parent || !$parent.length) $parent = $this.parent()
 
-     return $parent
 
-   }
 
-   /* DROPDOWN PLUGIN DEFINITION
 
-    * ========================== */
 
-   var old = $.fn.dropdown
 
-   $.fn.dropdown = function (option) {
 
-     return this.each(function () {
 
-       var $this = $(this)
 
-         , data = $this.data('dropdown')
 
-       if (!data) $this.data('dropdown', (data = new Dropdown(this)))
 
-       if (typeof option == 'string') data[option].call($this)
 
-     })
 
-   }
 
-   $.fn.dropdown.Constructor = Dropdown
 
-  /* DROPDOWN NO CONFLICT
 
-   * ==================== */
 
-   $.fn.dropdown.noConflict = function () {
 
-     $.fn.dropdown = old
 
-     return this
 
-   }
 
-   /* APPLY TO STANDARD DROPDOWN ELEMENTS
 
-    * =================================== */
 
-   $(document)
 
-     .on('click.dropdown.data-api', clearMenus)
 
-     .on('click.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
 
-     .on('click.dropdown.data-api'  , toggle, Dropdown.prototype.toggle)
 
-     .on('keydown.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown)
 
- }(window.jQuery);
 
- /* ===========================================================
 
-  * bootstrap-tooltip.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#tooltips
 
-  * Inspired by the original jQuery.tipsy by Jason Frame
 
-  * ===========================================================
 
-  * Copyright 2013 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 ;_;
 
-  /* TOOLTIP PUBLIC CLASS DEFINITION
 
-   * =============================== */
 
-   var Tooltip = function (element, options) {
 
-     this.init('tooltip', element, options)
 
-   }
 
-   Tooltip.prototype = {
 
-     constructor: Tooltip
 
-   , init: function (type, element, options) {
 
-       var eventIn
 
-         , eventOut
 
-         , triggers
 
-         , trigger
 
-         , i
 
-       this.type = type
 
-       this.$element = $(element)
 
-       this.options = this.getOptions(options)
 
-       this.enabled = true
 
-       triggers = this.options.trigger.split(' ')
 
-       for (i = triggers.length; i--;) {
 
-         trigger = triggers[i]
 
-         if (trigger == 'click') {
 
-           this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
 
-         } else if (trigger != 'manual') {
 
-           eventIn = trigger == 'hover' ? 'mouseenter' : 'focus'
 
-           eventOut = trigger == 'hover' ? 'mouseleave' : 'blur'
 
-           this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
 
-           this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
 
-         }
 
-       }
 
-       this.options.selector ?
 
-         (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
 
-         this.fixTitle()
 
-     }
 
-   , getOptions: function (options) {
 
-       options = $.extend({}, $.fn[this.type].defaults, this.$element.data(), options)
 
-       if (options.delay && typeof options.delay == 'number') {
 
-         options.delay = {
 
-           show: options.delay
 
-         , hide: options.delay
 
-         }
 
-       }
 
-       return options
 
-     }
 
-   , enter: function (e) {
 
-       var defaults = $.fn[this.type].defaults
 
-         , options = {}
 
-         , self
 
-       this._options && $.each(this._options, function (key, value) {
 
-         if (defaults[key] != value) options[key] = value
 
-       }, this)
 
-       self = $(e.currentTarget)[this.type](options).data(this.type)
 
-       if (!self.options.delay || !self.options.delay.show) return self.show()
 
-       clearTimeout(this.timeout)
 
-       self.hoverState = 'in'
 
-       this.timeout = setTimeout(function() {
 
-         if (self.hoverState == 'in') self.show()
 
-       }, self.options.delay.show)
 
-     }
 
-   , leave: function (e) {
 
-       var self = $(e.currentTarget)[this.type](this._options).data(this.type)
 
-       if (this.timeout) clearTimeout(this.timeout)
 
-       if (!self.options.delay || !self.options.delay.hide) return self.hide()
 
-       self.hoverState = 'out'
 
-       this.timeout = setTimeout(function() {
 
-         if (self.hoverState == 'out') self.hide()
 
-       }, self.options.delay.hide)
 
-     }
 
-   , show: function () {
 
-       var $tip
 
-         , pos
 
-         , actualWidth
 
-         , actualHeight
 
-         , placement
 
-         , tp
 
-         , e = $.Event('show')
 
-       if (this.hasContent() && this.enabled) {
 
-         this.$element.trigger(e)
 
-         if (e.isDefaultPrevented()) return
 
-         $tip = this.tip()
 
-         this.setContent()
 
-         if (this.options.animation) {
 
-           $tip.addClass('fade')
 
-         }
 
-         placement = typeof this.options.placement == 'function' ?
 
-           this.options.placement.call(this, $tip[0], this.$element[0]) :
 
-           this.options.placement
 
-         $tip
 
-           .detach()
 
-           .css({ top: 0, left: 0, display: 'block' })
 
-         this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
 
-         pos = this.getPosition()
 
-         actualWidth = $tip[0].offsetWidth
 
-         actualHeight = $tip[0].offsetHeight
 
-         switch (placement) {
 
-           case 'bottom':
 
-             tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}
 
-             break
 
-           case 'top':
 
-             tp = {top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2}
 
-             break
 
-           case 'left':
 
-             tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth}
 
-             break
 
-           case 'right':
 
-             tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width}
 
-             break
 
-         }
 
-         this.applyPlacement(tp, placement)
 
-         this.$element.trigger('shown')
 
-       }
 
-     }
 
-   , applyPlacement: function(offset, placement){
 
-       var $tip = this.tip()
 
-         , width = $tip[0].offsetWidth
 
-         , height = $tip[0].offsetHeight
 
-         , actualWidth
 
-         , actualHeight
 
-         , delta
 
-         , replace
 
-       $tip
 
-         .offset(offset)
 
-         .addClass(placement)
 
-         .addClass('in')
 
-       actualWidth = $tip[0].offsetWidth
 
-       actualHeight = $tip[0].offsetHeight
 
-       if (placement == 'top' && actualHeight != height) {
 
-         offset.top = offset.top + height - actualHeight
 
-         replace = true
 
-       }
 
-       if (placement == 'bottom' || placement == 'top') {
 
-         delta = 0
 
-         if (offset.left < 0){
 
-           delta = offset.left * -2
 
-           offset.left = 0
 
-           $tip.offset(offset)
 
-           actualWidth = $tip[0].offsetWidth
 
-           actualHeight = $tip[0].offsetHeight
 
-         }
 
-         this.replaceArrow(delta - width + actualWidth, actualWidth, 'left')
 
-       } else {
 
-         this.replaceArrow(actualHeight - height, actualHeight, 'top')
 
-       }
 
-       if (replace) $tip.offset(offset)
 
-     }
 
-   , replaceArrow: function(delta, dimension, position){
 
-       this
 
-         .arrow()
 
-         .css(position, delta ? (50 * (1 - delta / dimension) + "%") : '')
 
-     }
 
-   , setContent: function () {
 
-       var $tip = this.tip()
 
-         , title = this.getTitle()
 
-       $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
 
-       $tip.removeClass('fade in top bottom left right')
 
-     }
 
-   , hide: function () {
 
-       var that = this
 
-         , $tip = this.tip()
 
-         , e = $.Event('hide')
 
-       this.$element.trigger(e)
 
-       if (e.isDefaultPrevented()) return
 
-       $tip.removeClass('in')
 
-       function removeWithAnimation() {
 
-         var timeout = setTimeout(function () {
 
-           $tip.off($.support.transition.end).detach()
 
-         }, 500)
 
-         $tip.one($.support.transition.end, function () {
 
-           clearTimeout(timeout)
 
-           $tip.detach()
 
-         })
 
-       }
 
-       $.support.transition && this.$tip.hasClass('fade') ?
 
-         removeWithAnimation() :
 
-         $tip.detach()
 
-       this.$element.trigger('hidden')
 
-       return this
 
-     }
 
-   , fixTitle: function () {
 
-       var $e = this.$element
 
-       if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
 
-         $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
 
-       }
 
-     }
 
-   , hasContent: function () {
 
-       return this.getTitle()
 
-     }
 
-   , getPosition: function () {
 
-       var el = this.$element[0]
 
-       return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : {
 
-         width: el.offsetWidth
 
-       , height: el.offsetHeight
 
-       }, this.$element.offset())
 
-     }
 
-   , getTitle: function () {
 
-       var title
 
-         , $e = this.$element
 
-         , o = this.options
 
-       title = $e.attr('data-original-title')
 
-         || (typeof o.title == 'function' ? o.title.call($e[0]) :  o.title)
 
-       return title
 
-     }
 
-   , tip: function () {
 
-       return this.$tip = this.$tip || $(this.options.template)
 
-     }
 
-   , arrow: function(){
 
-       return this.$arrow = this.$arrow || this.tip().find(".tooltip-arrow")
 
-     }
 
-   , validate: function () {
 
-       if (!this.$element[0].parentNode) {
 
-         this.hide()
 
-         this.$element = null
 
-         this.options = null
 
-       }
 
-     }
 
-   , enable: function () {
 
-       this.enabled = true
 
-     }
 
-   , disable: function () {
 
-       this.enabled = false
 
-     }
 
-   , toggleEnabled: function () {
 
-       this.enabled = !this.enabled
 
-     }
 
-   , toggle: function (e) {
 
-       var self = e ? $(e.currentTarget)[this.type](this._options).data(this.type) : this
 
-       self.tip().hasClass('in') ? self.hide() : self.show()
 
-     }
 
-   , destroy: function () {
 
-       this.hide().$element.off('.' + this.type).removeData(this.type)
 
-     }
 
-   }
 
-  /* TOOLTIP PLUGIN DEFINITION
 
-   * ========================= */
 
-   var old = $.fn.tooltip
 
-   $.fn.tooltip = function ( option ) {
 
-     return this.each(function () {
 
-       var $this = $(this)
 
-         , data = $this.data('tooltip')
 
-         , options = typeof option == 'object' && option
 
-       if (!data) $this.data('tooltip', (data = new Tooltip(this, options)))
 
-       if (typeof option == 'string') data[option]()
 
-     })
 
-   }
 
-   $.fn.tooltip.Constructor = Tooltip
 
-   $.fn.tooltip.defaults = {
 
-     animation: true
 
-   , placement: 'top'
 
-   , selector: false
 
-   , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
 
-   , trigger: 'hover focus'
 
-   , title: ''
 
-   , delay: 0
 
-   , html: false
 
-   , container: false
 
-   }
 
-  /* TOOLTIP NO CONFLICT
 
-   * =================== */
 
-   $.fn.tooltip.noConflict = function () {
 
-     $.fn.tooltip = old
 
-     return this
 
-   }
 
- }(window.jQuery);
 
- /* ===========================================================
 
-  * bootstrap-popover.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#popovers
 
-  * ===========================================================
 
-  * Copyright 2013 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 ;_;
 
-  /* POPOVER PUBLIC CLASS DEFINITION
 
-   * =============================== */
 
-   var Popover = function (element, options) {
 
-     this.init('popover', element, options)
 
-   }
 
-   /* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
 
-      ========================================== */
 
-   Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype, {
 
-     constructor: Popover
 
-   , setContent: function () {
 
-       var $tip = this.tip()
 
-         , title = this.getTitle()
 
-         , content = this.getContent()
 
-       $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
 
-       $tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
 
-       $tip.removeClass('fade top bottom left right in')
 
-     }
 
-   , hasContent: function () {
 
-       return this.getTitle() || this.getContent()
 
-     }
 
-   , getContent: function () {
 
-       var content
 
-         , $e = this.$element
 
-         , o = this.options
 
-       content = (typeof o.content == 'function' ? o.content.call($e[0]) :  o.content)
 
-         || $e.attr('data-content')
 
-       return content
 
-     }
 
-   , tip: function () {
 
-       if (!this.$tip) {
 
-         this.$tip = $(this.options.template)
 
-       }
 
-       return this.$tip
 
-     }
 
-   , destroy: function () {
 
-       this.hide().$element.off('.' + this.type).removeData(this.type)
 
-     }
 
-   })
 
-  /* POPOVER PLUGIN DEFINITION
 
-   * ======================= */
 
-   var old = $.fn.popover
 
-   $.fn.popover = function (option) {
 
-     return this.each(function () {
 
-       var $this = $(this)
 
-         , data = $this.data('popover')
 
-         , options = typeof option == 'object' && option
 
-       if (!data) $this.data('popover', (data = new Popover(this, options)))
 
-       if (typeof option == 'string') data[option]()
 
-     })
 
-   }
 
-   $.fn.popover.Constructor = Popover
 
-   $.fn.popover.defaults = $.extend({} , $.fn.tooltip.defaults, {
 
-     placement: 'right'
 
-   , trigger: 'click'
 
-   , content: ''
 
-   , template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
 
-   })
 
-  /* POPOVER NO CONFLICT
 
-   * =================== */
 
-   $.fn.popover.noConflict = function () {
 
-     $.fn.popover = old
 
-     return this
 
-   }
 
- }(window.jQuery);
 
- /* ==========================================================
 
-  * bootstrap-alert.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#alerts
 
-  * ==========================================================
 
-  * Copyright 2013 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
 
-   * ======================= */
 
-   var old = $.fn.alert
 
-   $.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 NO CONFLICT
 
-   * ================= */
 
-   $.fn.alert.noConflict = function () {
 
-     $.fn.alert = old
 
-     return this
 
-   }
 
-  /* ALERT DATA-API
 
-   * ============== */
 
-   $(document).on('click.alert.data-api', dismiss, Alert.prototype.close)
 
- }(window.jQuery);
 
- /* ============================================================
 
-  * bootstrap-button.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#buttons
 
-  * ============================================================
 
-  * Copyright 2013 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
 
-   * ======================== */
 
-   var old = $.fn.button
 
-   $.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 NO CONFLICT
 
-   * ================== */
 
-   $.fn.button.noConflict = function () {
 
-     $.fn.button = old
 
-     return this
 
-   }
 
-  /* 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-affix.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#affix
 
-  * ==========================================================
 
-  * Copyright 2013 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 ;_;
 
-  /* AFFIX CLASS DEFINITION
 
-   * ====================== */
 
-   var Affix = function (element, options) {
 
-     this.options = $.extend({}, $.fn.affix.defaults, options)
 
-     this.$window = $(window)
 
-       .on('scroll.affix.data-api', $.proxy(this.checkPosition, this))
 
-       .on('click.affix.data-api',  $.proxy(function () { setTimeout($.proxy(this.checkPosition, this), 1) }, this))
 
-     this.$element = $(element)
 
-     this.checkPosition()
 
-   }
 
-   Affix.prototype.checkPosition = function () {
 
-     if (!this.$element.is(':visible')) return
 
-     var scrollHeight = $(document).height()
 
-       , scrollTop = this.$window.scrollTop()
 
-       , position = this.$element.offset()
 
-       , offset = this.options.offset
 
-       , offsetBottom = offset.bottom
 
-       , offsetTop = offset.top
 
-       , reset = 'affix affix-top affix-bottom'
 
-       , affix
 
-     if (typeof offset != 'object') offsetBottom = offsetTop = offset
 
-     if (typeof offsetTop == 'function') offsetTop = offset.top()
 
-     if (typeof offsetBottom == 'function') offsetBottom = offset.bottom()
 
-     affix = this.unpin != null && (scrollTop + this.unpin <= position.top) ?
 
-       false    : offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ?
 
-       'bottom' : offsetTop != null && scrollTop <= offsetTop ?
 
-       'top'    : false
 
-     if (this.affixed === affix) return
 
-     this.affixed = affix
 
-     this.unpin = affix == 'bottom' ? position.top - scrollTop : null
 
-     this.$element.removeClass(reset).addClass('affix' + (affix ? '-' + affix : ''))
 
-   }
 
-  /* AFFIX PLUGIN DEFINITION
 
-   * ======================= */
 
-   var old = $.fn.affix
 
-   $.fn.affix = function (option) {
 
-     return this.each(function () {
 
-       var $this = $(this)
 
-         , data = $this.data('affix')
 
-         , options = typeof option == 'object' && option
 
-       if (!data) $this.data('affix', (data = new Affix(this, options)))
 
-       if (typeof option == 'string') data[option]()
 
-     })
 
-   }
 
-   $.fn.affix.Constructor = Affix
 
-   $.fn.affix.defaults = {
 
-     offset: 0
 
-   }
 
-  /* AFFIX NO CONFLICT
 
-   * ================= */
 
-   $.fn.affix.noConflict = function () {
 
-     $.fn.affix = old
 
-     return this
 
-   }
 
-  /* AFFIX DATA-API
 
-   * ============== */
 
-   $(window).on('load', function () {
 
-     $('[data-spy="affix"]').each(function () {
 
-       var $spy = $(this)
 
-         , data = $spy.data()
 
-       data.offset = data.offset || {}
 
-       data.offsetBottom && (data.offset.bottom = data.offsetBottom)
 
-       data.offsetTop && (data.offset.top = data.offsetTop)
 
-       $spy.affix(data)
 
-     })
 
-   })
 
- }(window.jQuery);
 
- /* =============================================================
 
-  * bootstrap-scrollspy.js v2.3.2
 
-  * http://getbootstrap.com/2.3.2/javascript.html#scrollspy
 
-  * =============================================================
 
-  * Copyright 2013 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 ;_;
 
-  /* SCROLLSPY CLASS DEFINITION
 
-   * ========================== */
 
-   function ScrollSpy(element, options) {
 
-     var process = $.proxy(this.process, this)
 
-       , $element = $(element).is('body') ? $(window) : $(element)
 
-       , href
 
-     this.options = $.extend({}, $.fn.scrollspy.defaults, options)
 
-     this.$scrollElement = $element.on('scroll.scroll-spy.data-api', process)
 
-     this.selector = (this.options.target
 
-       || ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
 
-       || '') + ' .inav li > a'
 
-     this.$body = $('body')
 
-     this.refresh()
 
-     this.process()
 
-   }
 
-   ScrollSpy.prototype = {
 
-       constructor: ScrollSpy
 
-     , refresh: function () {
 
-         var self = this
 
-           , $targets
 
-         this.offsets = $([])
 
-         this.targets = $([])
 
-         $targets = this.$body
 
-           .find(this.selector)
 
-           .map(function () {
 
-             var $el = $(this)
 
-               , href = $el.data('target') || $el.attr('href')
 
-               , $href = /^#\w/.test(href) && $(href)
 
-             return ( $href
 
-               && $href.length
 
-               && [[ $href.position().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]] ) || null
 
-           })
 
-           .sort(function (a, b) { return a[0] - b[0] })
 
-           .each(function () {
 
-             self.offsets.push(this[0])
 
-             self.targets.push(this[1])
 
-           })
 
-       }
 
-     , process: function () {
 
-         var scrollTop = this.$scrollElement.scrollTop() + this.options.offset
 
-           , scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
 
-           , maxScroll = scrollHeight - this.$scrollElement.height()
 
-           , offsets = this.offsets
 
-           , targets = this.targets
 
-           , activeTarget = this.activeTarget
 
-           , i
 
-         if (scrollTop >= maxScroll) {
 
-           return activeTarget != (i = targets.last()[0])
 
-             && this.activate ( i )
 
-         }
 
-         for (i = offsets.length; i--;) {
 
-           activeTarget != targets[i]
 
-             && scrollTop >= offsets[i]
 
-             && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
 
-             && this.activate( targets[i] )
 
-         }
 
-       }
 
-     , activate: function (target) {
 
-         var active
 
-           , selector
 
-         this.activeTarget = target
 
-         $(this.selector)
 
-           .parent('.active')
 
-           .removeClass('active')
 
-         selector = this.selector
 
-           + '[data-target="' + target + '"],'
 
-           + this.selector + '[href="' + target + '"]'
 
-         active = $(selector)
 
-           .parent('li')
 
-           .addClass('active')
 
-         if (active.parent('.dropdown-menu').length)  {
 
-           active = active.closest('li.dropdown').addClass('active')
 
-         }
 
-         active.trigger('activate')
 
-       }
 
-   }
 
-  /* SCROLLSPY PLUGIN DEFINITION
 
-   * =========================== */
 
-   var old = $.fn.scrollspy
 
-   $.fn.scrollspy = function (option) {
 
-     return this.each(function () {
 
-       var $this = $(this)
 
-         , data = $this.data('scrollspy')
 
-         , options = typeof option == 'object' && option
 
-       if (!data) $this.data('scrollspy', (data = new ScrollSpy(this, options)))
 
-       if (typeof option == 'string') data[option]()
 
-     })
 
-   }
 
-   $.fn.scrollspy.Constructor = ScrollSpy
 
-   $.fn.scrollspy.defaults = {
 
-     offset: 10
 
-   }
 
-  /* SCROLLSPY NO CONFLICT
 
-   * ===================== */
 
-   $.fn.scrollspy.noConflict = function () {
 
-     $.fn.scrollspy = old
 
-     return this
 
-   }
 
-  /* SCROLLSPY DATA-API
 
-   * ================== */
 
-   $(window).on('load', function () {
 
-     $('[data-spy="scroll"]').each(function () {
 
-       var $spy = $(this)
 
-       $spy.scrollspy($spy.data())
 
-     })
 
-   })
 
- }(window.jQuery);
 
 
  |