Вход Регистрация
Файл: js/plusstrap.js
Строк: 2028
<?php
/* ===================================================
 * bootstrap-transition.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#transitions
 * ===================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================== */


!function ($) {

  $(function () {

    
"use strict"// jshint ;_;


    /* CSS TRANSITION SUPPORT (http://www.modernizr.com/)
     * ======================================================= */

    
$.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 && {
        
endtransitionEnd
      
}

    })()

  })

}(
window.jQuery);
/* =========================================================
 * bootstrap-modal.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#modals
 * =========================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================= */


!function ($) {

  
"use strict"// jshint ;_;


 /* MODAL CLASS DEFINITION
  * ====================== */

  
var Modal = function (elementoptions) {
    
this.options options
    this
.$element = $(element)
      .
delegate('[data-dismiss="modal"]''click.dismiss.modal', $.proxy(this.hidethis))
    
this.options.remote && this.$element.find('.modal-body').load(this.options.remote)
  }

  
Modal.prototype = {

      
constructorModal

    
toggle: function () {
        return 
this[!this.isShown 'show' 'hide']()
      }

    , 
show: function () {
        var 
that this
          
= $.Event('show')

        
this.$element.trigger(e)

        if (
this.isShown || e.isDefaultPrevented()) return

        $(
'body').addClass('modal-open')

        
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)
            .
focus()

          
that.enforceFocus()

          
transition ?
            
that.$element.one($.support.transition.end, function () { that.$element.trigger('shown') }) :
            
that.$element.trigger('shown')

        })
      }

    , 
hide: function (e) {
        
&& e.preventDefault()

        var 
that this

        e 
= $.Event('hide')

        
this.$element.trigger(e)

        if (!
this.isShown || e.isDefaultPrevented()) return

        
this.isShown false

        
$('body').removeClass('modal-open')

        
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.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 (that) {
        
this.$element
          
.hide()
          .
trigger('hidden')

        
this.backdrop()
      }

    , 
removeBackdrop: function () {
        
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)

          if (
this.options.backdrop != 'static') {
            
this.$backdrop.click($.proxy(this.hidethis))
          }

          if (
doAnimatethis.$backdrop[0].offsetWidth // force reflow

          
this.$backdrop.addClass('in')

          
doAnimate ?
            
this.$backdrop.one($.support.transition.endcallback) :
            
callback()

        } else if (!
this.isShown && this.$backdrop) {
          
this.$backdrop.removeClass('in')

          $.
support.transition && this.$element.hasClass('fade')?
            
this.$backdrop.one($.support.transition.end, $.proxy(this.removeBackdropthis)) :
            
this.removeBackdrop()

        } else if (
callback) {
          
callback()
        }
      }
  }


 
/* MODAL PLUGIN DEFINITION
  * ======================= */

  
$.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(thisoptions)))
      if (
typeof option == 'string'data[option]()
      else if (
options.showdata.show()
    })
  }

  $.fn.
modal.defaults = {
      
backdroptrue
    
keyboardtrue
    
showtrue
  
}

  $.fn.
modal.Constructor Modal


 
/* MODAL DATA-API
  * ============== */

  
$(function () {
    $(
'body').on('click.modal.data-api''[data-toggle="modal"]', function ( ) {
      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.0.4
 * http://twitter.github.com/bootstrap/javascript.html#dropdowns
 * ============================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============================================================ */


!function ($) {

  
"use strict"// jshint ;_;


 /* 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 = {

    
constructorDropdown

  
toggle: function (e) {
      var 
$this = $(this)
        , 
$parent
        
isActive

      
if ($this.is('.disabled, :disabled')) return

      
$parent getParent($this)

      
isActive $parent.hasClass('open')

      
clearMenus()

      if (!
isActive) {
        
$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)) return $this.click()

      
$items = $('[role=menu] li:not(.divider) a'$parent)

      if (!
$items.length) return

      
index $items.index($items.filter(':focus'))

      if (
e.keyCode == 38 && index 0index--                                        // up
      
if (e.keyCode == 40 && index $items.length 1index++                        // down
      
if (!~indexindex 0

      $items
        
.eq(index)
        .
focus()
    }

  }

  function 
clearMenus() {
    
getParent($(toggle))
      .
removeClass('open')
  }

  function 
getParent($this) {
    var 
selector $this.attr('data-target')
      , 
$parent

    
if (!selector) {
      
selector $this.attr('href')
      
selector selector && selector.replace(/.*(?=#[^s]*$)/, '') //strip for ie7
    
}

    
$parent = $(selector)
    
$parent.length || ($parent $this.parent())

    return 
$parent
  
}


  
/* DROPDOWN PLUGIN DEFINITION
   * ========================== */

  
$.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


  
/* APPLY TO STANDARD DROPDOWN ELEMENTS
   * =================================== */

  
$(function () {
    $(
'html')
      .
on('click.dropdown.data-api'clearMenus)
    $(
'body')
      .
on('click.dropdown''.dropdown form', function (e) { e.stopPropagation() })
      .
on('click.dropdown.data-api'  toggleDropdown.prototype.toggle)
      .
on('keydown.dropdown.data-api'toggle ', [role=menu]' Dropdown.prototype.keydown)
  })

}(
window.jQuery);
/* =============================================================
 * bootstrap-scrollspy.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#scrollspy
 * =============================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============================================================== */


!function ($) {

  
"use strict"// jshint ;_;


 /* SCROLLSPY CLASS DEFINITION
  * ========================== */

  
function ScrollSpy(elementoptions) {
    var 
process = $.proxy(this.processthis)
      , 
$element = $(element).is('body') ? $(window) : $(element)
      , 
href
    this
.options = $.extend({}, $.fn.scrollspy.defaultsoptions)
    
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
      
|| '') + ' .nav li > a'
    
this.$body = $('body')
    
this.refresh()
    
this.process()
  }

  
ScrollSpy.prototype = {

      
constructorScrollSpy

    
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().tophref ]] ) || null
          
})
          .
sort(function (ab) { 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 != (targets.last()[0])
            && 
this.activate )
        }

        for (
offsets.lengthi--;) {
          
activeTarget != targets[i]
            && 
scrollTop >= offsets[i]
            && (!
offsets[1] || scrollTop <= offsets[1])
            && 
this.activatetargets[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
  * =========================== */

  
$.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(thisoptions)))
      if (
typeof option == 'string'data[option]()
    })
  }

  $.fn.
scrollspy.Constructor ScrollSpy

  
$.fn.scrollspy.defaults = {
    
offset10
  
}


 
/* SCROLLSPY DATA-API
  * ================== */

  
$(window).on('load', function () {
    $(
'[data-spy="scroll"]').each(function () {
      var 
$spy = $(this)
      
$spy.scrollspy($spy.data())
    })
  })

}(
window.jQuery);
/* ========================================================
 * bootstrap-tab.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#tabs
 * ========================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ======================================================== */


!function ($) {

  
"use strict"// jshint ;_;


 /* TAB CLASS DEFINITION
  * ==================== */

  
var Tab = function (element) {
    
this.element = $(element)
  }

  
Tab.prototype = {

    
constructorTab

  
show: function () {
      var 
$this this.element
        
$ul $this.closest('ul:not(.dropdown-menu)')
        , 
selector $this.attr('data-target')
        , 
previous
        
$target
        
e

      
if (!selector) {
        
selector $this.attr('href')
        
selector selector && selector.replace(/.*(?=#[^s]*$)/, '') //strip for ie7
      
}

      if ( 
$this.parent('li').hasClass('active') ) return

      
previous $ul.find('.active a').last()[0]

      
= $.Event('show', {
        
relatedTargetprevious
      
})

      
$this.trigger(e)

      if (
e.isDefaultPrevented()) return

      
$target = $(selector)

      
this.activate($this.parent('li'), $ul)
      
this.activate($target$target.parent(), function () {
        
$this.trigger({
          
type'shown'
        
relatedTargetprevious
        
})
      })
    }

  , 
activate: function ( elementcontainercallback) {
      var 
$active container.find('> .active')
        , 
transition callback
            
&& $.support.transition
            
&& $active.hasClass('fade')

      function 
next() {
        
$active
          
.removeClass('active')
          .
find('> .dropdown-menu > .active')
          .
removeClass('active')

        
element.addClass('active')

        if (
transition) {
          
element[0].offsetWidth // reflow for transition
          
element.addClass('in')
        } else {
          
element.removeClass('fade')
        }

        if ( 
element.parent('.dropdown-menu') ) {
          
element.closest('li.dropdown').addClass('active')
        }

        
callback && callback()
      }

      
transition ?
        
$active.one($.support.transition.endnext) :
        
next()

      
$active.removeClass('in')
    }
  }


 
/* TAB PLUGIN DEFINITION
  * ===================== */

  
$.fn.tab = function ( option ) {
    return 
this.each(function () {
      var 
$this = $(this)
        , 
data $this.data('tab')
      if (!
data$this.data('tab', (data = new Tab(this)))
      if (
typeof option == 'string'data[option]()
    })
  }

  $.fn.
tab.Constructor Tab


 
/* TAB DATA-API
  * ============ */

  
$(function () {
    $(
'body').on('click.tab.data-api''[data-toggle="tab"], [data-toggle="pill"]', function (e) {
      
e.preventDefault()
      $(
this).tab('show')
    })
  })

}(
window.jQuery);
/* ===========================================================
 * bootstrap-tooltip.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#tooltips
 * Inspired by the original jQuery.tipsy by Jason Frame
 * ===========================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================== */


!function ($) {

  
"use strict"// jshint ;_;


 /* TOOLTIP PUBLIC CLASS DEFINITION
  * =============================== */

  
var Tooltip = function (elementoptions) {
    
this.init('tooltip'elementoptions)
  }

  
Tooltip.prototype = {

    
constructorTooltip

  
init: function (typeelementoptions) {
      var 
eventIn
        
eventOut

      this
.type type
      this
.$element = $(element)
      
this.options this.getOptions(options)
      
this.enabled true

      
if (this.options.trigger != 'manual') {
        
eventIn  this.options.trigger == 'hover' 'mouseenter' 'focus'
        
eventOut this.options.trigger == 'hover' 'mouseleave' 'blur'
        
this.$element.on(eventIn '.' this.typethis.options.selector, $.proxy(this.enterthis))
        
this.$element.on(eventOut '.' this.typethis.options.selector, $.proxy(this.leavethis))
      }

      
this.options.selector ?
        (
this._options = $.extend({}, this.options, { trigger'manual'selector'' })) :
        
this.fixTitle()
    }

  , 
getOptions: function (options) {
      
options = $.extend({}, $.fn[this.type].defaultsoptionsthis.$element.data())

      if (
options.delay && typeof options.delay == 'number') {
        
options.delay = {
          
showoptions.delay
        
hideoptions.delay
        
}
      }

      return 
options
    
}

  , 
enter: function (e) {
      var 
self = $(e.currentTarget)[this.type](this._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.timeoutclearTimeout(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
        
inside
        
pos
        
actualWidth
        
actualHeight
        
placement
        
tp

      
if (this.hasContent() && this.enabled) {
        
$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

        inside 
= /in/.test(placement)

        
$tip
          
.remove()
          .
css({ top0left0display'block' })
          .
appendTo(inside this.$element document.body)

        
pos this.getPosition(inside)

        
actualWidth $tip[0].offsetWidth
        actualHeight 
$tip[0].offsetHeight

        
switch (inside placement.split(' ')[1] : placement) {
          case 
'bottom':
            
tp = {toppos.top pos.heightleftpos.left pos.width actualWidth 2}
            break
          case 
'top':
            
tp = {toppos.top actualHeightleftpos.left pos.width actualWidth 2}
            break
          case 
'left':
            
tp = {toppos.top pos.height actualHeight 2leftpos.left actualWidth}
            break
          case 
'right':
            
tp = {toppos.top pos.height actualHeight 2leftpos.left pos.width}
            break
        }

        
$tip
          
.css(tp)
          .
addClass(placement)
          .
addClass('in')
      }
    }

  , 
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()

      
$tip.removeClass('in')

      function 
removeWithAnimation() {
        var 
timeout setTimeout(function () {
          
$tip.off($.support.transition.end).remove()
        }, 
500)

        
$tip.one($.support.transition.end, function () {
          
clearTimeout(timeout)
          
$tip.remove()
        })
      }

      $.
support.transition && this.$tip.hasClass('fade') ?
        
removeWithAnimation() :
        
$tip.remove()

      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') || '').removeAttr('title')
      }
    }

  , 
hasContent: function () {
      return 
this.getTitle()
    }

  , 
getPosition: function (inside) {
      return $.
extend({}, (inside ? {top0left0} : this.$element.offset()), {
        
widththis.$element[0].offsetWidth
      
heightthis.$element[0].offsetHeight
      
})
    }

  , 
getTitle: function () {
      var 
title
        
$e this.$element
        
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)
    }

  , 
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 () {
      
this[this.tip().hasClass('in') ? 'hide' 'show']()
    }

  , 
destroy: function () {
      
this.hide().$element.off('.' this.type).removeData(this.type)
    }

  }


 
/* TOOLTIP PLUGIN DEFINITION
  * ========================= */

  
$.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(thisoptions)))
      if (
typeof option == 'string'data[option]()
    })
  }

  $.fn.
tooltip.Constructor Tooltip

  
$.fn.tooltip.defaults = {
    
animationtrue
  
placement'top'
  
selectorfalse
  
template'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
  
trigger'hover'
  
title''
  
delay0
  
htmltrue
  
}

}(
window.jQuery);

/* ===========================================================
 * bootstrap-popover.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#popovers
 * ===========================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * =========================================================== */


!function ($) {

  
"use strict"// jshint ;_;


 /* POPOVER PUBLIC CLASS DEFINITION
  * =============================== */

  
var Popover = function (elementoptions) {
    
this.init('popover'elementoptions)
  }


  
/* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
     ========================================== */

  
Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype, {

    
constructorPopover

  
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
        
this.options

      content 
$e.attr('data-content')
        || (
typeof o.content == 'function' o.content.call($e[0]) :  o.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
  * ======================= */

  
$.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(thisoptions)))
      if (
typeof option == 'string'data[option]()
    })
  }

  $.fn.
popover.Constructor Popover

  
$.fn.popover.defaults = $.extend({} , $.fn.tooltip.defaults, {
    
placement'right'
  
content''
  
template'<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"><p></p></div></div></div>'
  
})

}(
window.jQuery);
/* ==========================================================
 * bootstrap-affix.js v2.1.0
 * http://twitter.github.com/bootstrap/javascript.html#affix
 * ==========================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================== */


!function ($) {

  
"use strict"// jshint ;_;


 /* AFFIX CLASS DEFINITION
  * ====================== */

  
var Affix = function (elementoptions) {
    
this.options = $.extend({}, $.fn.affix.defaultsoptions)
    
this.$window = $(window)
      .
on('scroll.affix.data-api', $.proxy(this.checkPositionthis))
      .
on('resize.affix.data-api', $.proxy(this.refreshthis))
    
this.$element = $(element)
    
this.refresh()
  }

  
Affix.prototype.refresh = function () {
    
this.position this.$element.offset()
  }

  
Affix.prototype.checkPosition = function () {
    if (!
this.$element.is(':visible')) return

    var 
scrollLeft this.$window.scrollLeft()
      , 
scrollTop this.$window.scrollTop()
      , 
position this.position
      
offset this.options.offset
      
affix

    
if (typeof offset != 'object'offset = { xoffsetyoffset }

    
affix = (offset.== null || (position.left scrollLeft <= offset.x))
         && (
offset.== null || (position.top  scrollTop  <= offset.y))

    if (
affix == this.affixed) return

    
this.affixed affix

    this
.$element[affix 'addClass' 'removeClass']('affix')
  }


 
/* AFFIX PLUGIN DEFINITION
  * ======================= */

  
$.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(thisoptions)))
      if (
typeof option == 'string'data[option]()
    })
  }

  $.fn.
affix.Constructor Affix

  
$.fn.affix.defaults = {
    
offset0
  
}


 
/* AFFIX DATA-API
  * ============== */

  
$(function () {
    $(
'[data-spy="affix"]').each(function () {
      var 
$spy = $(this)
        , 
data $spy.data()

      
data.offset data.offset || {}

      
data.offsetX && (data.offset.data.offsetX)
      
data.offsetY && (data.offset.data.offsetY)

      
$spy.affix(data)
    })
  })


}(
window.jQuery);
/* ==========================================================
 * bootstrap-alert.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#alerts
 * ==========================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================== */


!function ($) {

  
"use strict"// jshint ;_;


 /* ALERT CLASS DEFINITION
  * ====================== */

  
var dismiss '[data-dismiss="alert"]'
    
Alert = function (el) {
        $(
el).on('click'dismissthis.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.preventDefault()

    
$parent.length || ($parent $this.hasClass('alert') ? $this $this.parent())

    
$parent.trigger(= $.Event('close'))

    if (
e.isDefaultPrevented()) return

    
$parent.removeClass('in')

    function 
removeElement() {
      
$parent
        
.trigger('closed')
        .
remove()
    }

    $.
support.transition && $parent.hasClass('fade') ?
      
$parent.on($.support.transition.endremoveElement) :
      
removeElement()
  }


 
/* ALERT PLUGIN DEFINITION
  * ======================= */

  
$.fn.alert = function (option) {
    return 
this.each(function () {
      var 
$this = $(this)
        , 
data $this.data('alert')
      if (!
data$this.data('alert', (data = new Alert(this)))
      if (
typeof option == 'string'data[option].call($this)
    })
  }

  $.fn.
alert.Constructor Alert


 
/* ALERT DATA-API
  * ============== */

  
$(function () {
    $(
'body').on('click.alert.data-api'dismissAlert.prototype.close)
  })

}(
window.jQuery);
/* ============================================================
 * bootstrap-button.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#buttons
 * ============================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============================================================ */


!function ($) {

  
"use strict"// jshint ;_;


 /* BUTTON PUBLIC CLASS DEFINITION
  * ============================== */

  
var Button = function (elementoptions) {
    
this.$element = $(element)
    
this.options = $.extend({}, $.fn.button.defaultsoptions)
  }

  
Button.prototype.setState = function (state) {
    var 
'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(dd) :
        
$el.removeClass(d).removeAttr(d)
    }, 
0)
  }

  
Button.prototype.toggle = function () {
    var 
$parent this.$element.parent('[data-toggle="buttons-radio"]')

    
$parent && $parent
      
.find('.active')
      .
removeClass('active')

    
this.$element.toggleClass('active')
  }


 
/* BUTTON PLUGIN DEFINITION
  * ======================== */

  
$.fn.button = function (option) {
    return 
this.each(function () {
      var 
$this = $(this)
        , 
data $this.data('button')
        , 
options typeof option == 'object' && option
      
if (!data$this.data('button', (data = new Button(thisoptions)))
      if (
option == 'toggle'data.toggle()
      else if (
optiondata.setState(option)
    })
  }

  $.fn.
button.defaults = {
    
loadingText'loading...'
  
}

  $.fn.
button.Constructor Button


 
/* BUTTON DATA-API
  * =============== */

  
$(function () {
    $(
'body').on('click.button.data-api''[data-toggle^=button]', function ( ) {
      var 
$btn = $(e.target)
      if (!
$btn.hasClass('btn')) $btn $btn.closest('.btn')
      
$btn.button('toggle')
    })
  })

}(
window.jQuery);
/* =============================================================
 * bootstrap-collapse.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#collapse
 * =============================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============================================================ */


!function ($) {

  
"use strict"// jshint ;_;


 /* COLLAPSE PUBLIC CLASS DEFINITION
  * ================================ */

  
var Collapse = function (elementoptions) {
    
this.$element = $(element)
    
this.options = $.extend({}, $.fn.collapse.defaultsoptions)

    if (
this.options.parent) {
      
this.$parent = $(this.options.parent)
    }

    
this.options.toggle && this.toggle()
  }

  
Collapse.prototype = {

    
constructorCollapse

  
dimension: function () {
      var 
hasWidth this.$element.hasClass('width')
      return 
hasWidth 'width' 'height'
    
}

  , 
show: function () {
      var 
dimension
        
scroll
        
actives
        
hasData

      
if (this.transitioning) return

      
dimension this.dimension()
      
scroll = $.camelCase(['scroll'dimension].join('-'))
      
actives this.$parent && this.$parent.find('> .accordion-group > .in')

      if (
actives && actives.length) {
        
hasData actives.data('collapse')
        if (
hasData && hasData.transitioning) return
        
actives.collapse('hide')
        
hasData || actives.data('collapse'null)
      }

      
this.$element[dimension](0)
      
this.transition('addClass', $.Event('show'), 'shown')
      $.
support.transition && this.$element[dimension](this.$element[0][scroll])
    }

  , 
hide: function () {
      var 
dimension
      
if (this.transitioning) return
      
dimension this.dimension()
      
this.reset(this.$element[dimension]())
      
this.transition('removeClass', $.Event('hide'), 'hidden')
      
this.$element[dimension](0)
    }

  , 
reset: function (size) {
      var 
dimension this.dimension()

      
this.$element
        
.removeClass('collapse')
        [
dimension](size || 'auto')
        [
0].offsetWidth

      this
.$element[size !== null 'addClass' 'removeClass']('collapse')

      return 
this
    
}

  , 
transition: function (methodstartEventcompleteEvent) {
      var 
that this
        
complete = function () {
            if (
startEvent.type == 'show'that.reset()
            
that.transitioning 0
            that
.$element.trigger(completeEvent)
          }

      
this.$element.trigger(startEvent)

      if (
startEvent.isDefaultPrevented()) return

      
this.transitioning 1

      this
.$element[method]('in')

      $.
support.transition && this.$element.hasClass('collapse') ?
        
this.$element.one($.support.transition.endcomplete) :
        
complete()
    }

  , 
toggle: function () {
      
this[this.$element.hasClass('in') ? 'hide' 'show']()
    }

  }


 
/* COLLAPSIBLE PLUGIN DEFINITION
  * ============================== */

  
$.fn.collapse = function (option) {
    return 
this.each(function () {
      var 
$this = $(this)
        , 
data $this.data('collapse')
        , 
options typeof option == 'object' && option
      
if (!data$this.data('collapse', (data = new Collapse(thisoptions)))
      if (
typeof option == 'string'data[option]()
    })
  }

  $.fn.
collapse.defaults = {
    
toggletrue
  
}

  $.fn.
collapse.Constructor Collapse


 
/* COLLAPSIBLE DATA-API
  * ==================== */

  
$(function () {
    $(
'body').on('click.collapse.data-api''[data-toggle=collapse]', function (e) {
      var 
$this = $(this), href
        
target $this.attr('data-target')
          || 
e.preventDefault()
          || (
href $this.attr('href')) && href.replace(/.*(?=#[^s]+$)/, '') //strip for ie7
        
option = $(target).data('collapse') ? 'toggle' $this.data()
      
$this[$(target).hasClass('in') ? 'addClass' 'removeClass']('collapsed')
      $(
target).collapse(option)
    })
  })

}(
window.jQuery);
/* ==========================================================
 * bootstrap-carousel.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#carousel
 * ==========================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ========================================================== */


!function ($) {

  
"use strict"// jshint ;_;


 /* CAROUSEL CLASS DEFINITION
  * ========================= */

  
var Carousel = function (elementoptions) {
    
this.$element = $(element)
    
this.options options
    this
.options.slide && this.slide(this.options.slide)
    
this.options.pause == 'hover' && this.$element
      
.on('mouseenter', $.proxy(this.pausethis))
      .
on('mouseleave', $.proxy(this.cyclethis))
  }

  
Carousel.prototype = {

    
cycle: function (e) {
      if (!
ethis.paused false
      this
.options.interval
        
&& !this.paused
        
&& (this.interval setInterval($.proxy(this.nextthis), this.options.interval))
      return 
this
    
}

  , 
to: function (pos) {
      var 
$active this.$element.find('.item.active')
        , 
children $active.parent().children()
        , 
activePos children.index($active)
        , 
that this

      
if (pos > (children.length 1) || pos 0) return

      if (
this.sliding) {
        return 
this.$element.one('slid', function () {
          
that.to(pos)
        })
      }

      if (
activePos == pos) {
        return 
this.pause().cycle()
      }

      return 
this.slide(pos activePos 'next' 'prev', $(children[pos]))
    }

  , 
pause: function (e) {
      if (!
ethis.paused true
      
if (this.$element.find('.next, .prev').length && $.support.transition.end) {
        
this.$element.trigger($.support.transition.end)
        
this.cycle()
      }
      
clearInterval(this.interval)
      
this.interval null
      
return this
    
}

  , 
next: function () {
      if (
this.sliding) return
      return 
this.slide('next')
    }

  , 
prev: function () {
      if (
this.sliding) return
      return 
this.slide('prev')
    }

  , 
slide: function (typenext) {
      var 
$active this.$element.find('.item.active')
        , 
$next next || $active[type]()
        , 
isCycling this.interval
        
direction type == 'next' 'left' 'right'
        
fallback  type == 'next' 'first' 'last'
        
that this
        
= $.Event('slide', {
            
relatedTarget$next[0]
          })

      
this.sliding true

      isCycling 
&& this.pause()

      
$next $next.length $next this.$element.find('.item')[fallback]()

      if (
$next.hasClass('active')) return

      if ($.
support.transition && this.$element.hasClass('slide')) {
        
this.$element.trigger(e)
        if (
e.isDefaultPrevented()) return
        
$next.addClass(type)
        
$next[0].offsetWidth // force reflow
        
$active.addClass(direction)
        
$next.addClass(direction)
        
this.$element.one($.support.transition.end, function () {
          
$next.removeClass([typedirection].join(' ')).addClass('active')
          
$active.removeClass(['active'direction].join(' '))
          
that.sliding false
          setTimeout
(function () { that.$element.trigger('slid') }, 0)
        })
      } else {
        
this.$element.trigger(e)
        if (
e.isDefaultPrevented()) return
        
$active.removeClass('active')
        
$next.addClass('active')
        
this.sliding false
        this
.$element.trigger('slid')
      }

      
isCycling && this.cycle()

      return 
this
    
}

  }


 
/* CAROUSEL PLUGIN DEFINITION
  * ========================== */

  
$.fn.carousel = function (option) {
    return 
this.each(function () {
      var 
$this = $(this)
        , 
data $this.data('carousel')
        , 
options = $.extend({}, $.fn.carousel.defaultstypeof option == 'object' && option)
        , 
action typeof option == 'string' option options.slide
      
if (!data$this.data('carousel', (data = new Carousel(thisoptions)))
      if (
typeof option == 'number'data.to(option)
      else if (
actiondata[action]()
      else if (
options.intervaldata.cycle()
    })
  }

  $.fn.
carousel.defaults = {
    
interval5000
  
pause'hover'
  
}

  $.fn.
carousel.Constructor Carousel


 
/* CAROUSEL DATA-API
  * ================= */

  
$(function () {
    $(
'body').on('click.carousel.data-api''[data-slide]', function ( ) {
      var 
$this = $(this), href
        
$target = $($this.attr('data-target') || (href $this.attr('href')) && href.replace(/.*(?=#[^s]+$)/, '')) //strip for ie7
        
options = !$target.data('modal') && $.extend({}, $target.data(), $this.data())
      
$target.carousel(options)
      
e.preventDefault()
    })
  })

}(
window.jQuery);
/* =============================================================
 * bootstrap-typeahead.js v2.0.4
 * http://twitter.github.com/bootstrap/javascript.html#typeahead
 * =============================================================
 * Copyright 2012 Twitter, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============================================================ */


!function($){

  
"use strict"// jshint ;_;


 /* TYPEAHEAD PUBLIC CLASS DEFINITION
  * ================================= */

  
var Typeahead = function (elementoptions) {
    
this.$element = $(element)
    
this.options = $.extend({}, $.fn.typeahead.defaultsoptions)
    
this.matcher this.options.matcher || this.matcher
    this
.sorter this.options.sorter || this.sorter
    this
.highlighter this.options.highlighter || this.highlighter
    this
.updater this.options.updater || this.updater
    this
.$menu = $(this.options.menu).appendTo('body')
    
this.source this.options.source
    this
.shown false
    this
.listen()
  }

  
Typeahead.prototype = {

    
constructorTypeahead

  
select: function () {
      var 
val this.$menu.find('.active').attr('data-value')
      
this.$element
        
.val(this.updater(val))
        .
change()
      return 
this.hide()
    }

  , 
updater: function (item) {
      return 
item
    
}

  , 
show: function () {
      var 
pos = $.extend({}, this.$element.offset(), {
        
heightthis.$element[0].offsetHeight
      
})

      
this.$menu.css({
        
toppos.top pos.height
      
leftpos.left
      
})

      
this.$menu.show()
      
this.shown true
      
return this
    
}

  , 
hide: function () {
      
this.$menu.hide()
      
this.shown false
      
return this
    
}

  , 
lookup: function (event) {
      var 
items

      this
.query this.$element.val()

      if (!
this.query || this.query.length this.options.minLength) {
        return 
this.shown this.hide() : this
      
}

      
items = $.isFunction(this.source) ? this.source(this.query, $.proxy(this.processthis)) : this.source

      
return items this.process(items) : this
    
}

  , 
process: function (items) {
      var 
that this

      items 
= $.grep(items, function (item) {
        return 
that.matcher(item)
      })

      
items this.sorter(items)

      if (!
items.length) {
        return 
this.shown this.hide() : this
      
}

      return 
this.render(items.slice(0this.options.items)).show()
    }

  , 
matcher: function (item) {
      return ~
item.toLowerCase().indexOf(this.query.toLowerCase())
    }

  , 
sorter: function (items) {
      var 
beginswith = []
        , 
caseSensitive = []
        , 
caseInsensitive = []
        , 
item

      
while (item items.shift()) {
        if (!
item.toLowerCase().indexOf(this.query.toLowerCase())) beginswith.push(item)
        else if (~
item.indexOf(this.query)) caseSensitive.push(item)
        else 
caseInsensitive.push(item)
      }

      return 
beginswith.concat(caseSensitivecaseInsensitive)
    }

  , 
highlighter: function (item) {
      var 
query this.query.replace(/[-[]{}()*+?.,\^$|#s]/g, '\$&')
      
return item.replace(new RegExp('(' query ')''ig'), function ($1match) {
        return 
'<strong>' match '</strong>'
      
})
    }

  , 
render: function (items) {
      var 
that this

      items 
= $(items).map(function (iitem) {
        
= $(that.options.item).attr('data-value'item)
        
i.find('a').html(that.highlighter(item))
        return 
i[0]
      })

      
items.first().addClass('active')
      
this.$menu.html(items)
      return 
this
    
}

  , 
next: function (event) {
      var 
active this.$menu.find('.active').removeClass('active')
        , 
next active.next()

      if (!
next.length) {
        
next = $(this.$menu.find('li')[0])
      }

      
next.addClass('active')
    }

  , 
prev: function (event) {
      var 
active this.$menu.find('.active').removeClass('active')
        , 
prev active.prev()

      if (!
prev.length) {
        
prev this.$menu.find('li').last()
      }

      
prev.addClass('active')
    }

  , 
listen: function () {
      
this.$element
        
.on('blur',     $.proxy(this.blurthis))
        .
on('keypress', $.proxy(this.keypressthis))
        .
on('keyup',    $.proxy(this.keyupthis))

      if ($.
browser.webkit || $.browser.msie) {
        
this.$element.on('keydown', $.proxy(this.keydownthis))
      }

      
this.$menu
        
.on('click', $.proxy(this.clickthis))
        .
on('mouseenter''li', $.proxy(this.mouseenterthis))
    }

  , 
move: function (e) {
      if (!
this.shown) return

      switch(
e.keyCode) {
        case 
9// tab
        
case 13// enter
        
case 27// escape
          
e.preventDefault()
          break

        case 
38// up arrow
          
e.preventDefault()
          
this.prev()
          break

        case 
40// down arrow
          
e.preventDefault()
          
this.next()
          break
      }

      
e.stopPropagation()
    }

  , 
keydown: function (e) {
      
this.suppressKeyPressRepeat = !~$.inArray(e.keyCode, [40,38,9,13,27])
      
this.move(e)
    }

  , 
keypress: function (e) {
      if (
this.suppressKeyPressRepeat) return
      
this.move(e)
    }

  , 
keyup: function (e) {
      switch(
e.keyCode) {
        case 
40// down arrow
        
case 38// up arrow
          
break

        case 
9// tab
        
case 13// enter
          
if (!this.shown) return
          
this.select()
          break

        case 
27// escape
          
if (!this.shown) return
          
this.hide()
          break

        default:
          
this.lookup()
      }

      
e.stopPropagation()
      
e.preventDefault()
  }

  , 
blur: function (e) {
      var 
that this
      setTimeout
(function () { that.hide() }, 150)
    }

  , 
click: function (e) {
      
e.stopPropagation()
      
e.preventDefault()
      
this.select()
    }

  , 
mouseenter: function (e) {
      
this.$menu.find('.active').removeClass('active')
      $(
e.currentTarget).addClass('active')
    }

  }


  
/* TYPEAHEAD PLUGIN DEFINITION
   * =========================== */

  
$.fn.typeahead = function (option) {
    return 
this.each(function () {
      var 
$this = $(this)
        , 
data $this.data('typeahead')
        , 
options typeof option == 'object' && option
      
if (!data$this.data('typeahead', (data = new Typeahead(thisoptions)))
      if (
typeof option == 'string'data[option]()
    })
  }

  $.fn.
typeahead.defaults = {
    
source: []
  , 
items8
  
menu'<ul class="typeahead dropdown-menu"></ul>'
  
item'<li><a href="#"></a></li>'
  
minLength1
  
}

  $.fn.
typeahead.Constructor Typeahead


 
/*   TYPEAHEAD DATA-API
  * ================== */

  
$(function () {
    $(
'body').on('focus.typeahead.data-api''[data-provide="typeahead"]', function (e) {
      var 
$this = $(this)
      if (
$this.data('typeahead')) return
      
e.preventDefault()
      
$this.typeahead($this.data())
    })
  })

}(
window.jQuery);
?>
Онлайн: 2
Реклама