1 /* ===================================================
2 * bootstrap-transition.js v2.0.3
3 * http://twitter.github.com/bootstrap/javascript.html#transitions
4 * ===================================================
5 * Copyright 2012 Twitter, Inc.
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ========================================================== */
25 "use strict"; // jshint ;_;
28 /* CSS TRANSITION SUPPORT (http://www.modernizr.com/)
29 * ======================================================= */
31 $.support
.transition
= (function () {
33 var transitionEnd
= (function () {
35 var el
= document
.createElement('bootstrap')
36 , transEndEventNames
= {
37 'WebkitTransition' : 'webkitTransitionEnd'
38 , 'MozTransition' : 'transitionend'
39 , 'OTransition' : 'oTransitionEnd'
40 , 'msTransition' : 'MSTransitionEnd'
41 , 'transition' : 'transitionend'
45 for (name
in transEndEventNames
){
46 if (el
.style
[name
] !== undefined) {
47 return transEndEventNames
[name
]
53 return transitionEnd
&& {
61 }(window
.jQuery
);/* ==========================================================
62 * bootstrap-alert.js v2.0.3
63 * http://twitter.github.com/bootstrap/javascript.html#alerts
64 * ==========================================================
65 * Copyright 2012 Twitter, Inc.
67 * Licensed under the Apache License, Version 2.0 (the "License");
68 * you may not use this file except in compliance with the License.
69 * You may obtain a copy of the License at
71 * http://www.apache.org/licenses/LICENSE-2.0
73 * Unless required by applicable law or agreed to in writing, software
74 * distributed under the License is distributed on an "AS IS" BASIS,
75 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
76 * See the License for the specific language governing permissions and
77 * limitations under the License.
78 * ========================================================== */
83 "use strict"; // jshint ;_;
86 /* ALERT CLASS DEFINITION
87 * ====================== */
89 var dismiss
= '[data-dismiss="alert"]'
90 , Alert = function (el
) {
91 $(el
).on('click', dismiss
, this.close
)
94 Alert
.prototype.close = function (e
) {
96 , selector
= $this.attr('data-target')
100 selector
= $this.attr('href')
101 selector
= selector
&& selector
.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
104 $parent
= $(selector
)
106 e
&& e
.preventDefault()
108 $parent
.length
|| ($parent
= $this.hasClass('alert') ? $this : $this.parent())
110 $parent
.trigger(e
= $.Event('close'))
112 if (e
.isDefaultPrevented()) return
114 $parent
.removeClass('in')
116 function removeElement() {
122 $.support
.transition
&& $parent
.hasClass('fade') ?
123 $parent
.on($.support
.transition
.end
, removeElement
) :
128 /* ALERT PLUGIN DEFINITION
129 * ======================= */
131 $.fn
.alert = function (option
) {
132 return this.each(function () {
134 , data
= $this.data('alert')
135 if (!data
) $this.data('alert', (data
= new Alert(this)))
136 if (typeof option
== 'string') data
[option
].call($this)
140 $.fn
.alert
.Constructor
= Alert
147 $('body').on('click.alert.data-api', dismiss
, Alert
.prototype.close
)
150 }(window
.jQuery
);/* ============================================================
151 * bootstrap-button.js v2.0.3
152 * http://twitter.github.com/bootstrap/javascript.html#buttons
153 * ============================================================
154 * Copyright 2012 Twitter, Inc.
156 * Licensed under the Apache License, Version 2.0 (the "License");
157 * you may not use this file except in compliance with the License.
158 * You may obtain a copy of the License at
160 * http://www.apache.org/licenses/LICENSE-2.0
162 * Unless required by applicable law or agreed to in writing, software
163 * distributed under the License is distributed on an "AS IS" BASIS,
164 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
165 * See the License for the specific language governing permissions and
166 * limitations under the License.
167 * ============================================================ */
172 "use strict"; // jshint ;_;
175 /* BUTTON PUBLIC CLASS DEFINITION
176 * ============================== */
178 var Button = function (element
, options
) {
179 this.$element
= $(element
)
180 this.options
= $.extend({}, $.fn
.button
.defaults
, options
)
183 Button
.prototype.setState = function (state
) {
185 , $el
= this.$element
187 , val
= $el
.is('input') ? 'val' : 'html'
189 state
= state
+ 'Text'
190 data
.resetText
|| $el
.data('resetText', $el
[val
]())
192 $el
[val
](data
[state
] || this.options
[state
])
194 // push to event loop to allow forms to submit
195 setTimeout(function () {
196 state
== 'loadingText' ?
197 $el
.addClass(d
).attr(d
, d
) :
198 $el
.removeClass(d
).removeAttr(d
)
202 Button
.prototype.toggle = function () {
203 var $parent
= this.$element
.parent('[data-toggle="buttons-radio"]')
207 .removeClass('active')
209 this.$element
.toggleClass('active')
213 /* BUTTON PLUGIN DEFINITION
214 * ======================== */
216 $.fn
.button = function (option
) {
217 return this.each(function () {
219 , data
= $this.data('button')
220 , options
= typeof option
== 'object' && option
221 if (!data
) $this.data('button', (data
= new Button(this, options
)))
222 if (option
== 'toggle') data
.toggle()
223 else if (option
) data
.setState(option
)
227 $.fn
.button
.defaults
= {
228 loadingText
: 'loading...'
231 $.fn
.button
.Constructor
= Button
238 $('body').on('click.button.data-api', '[data-toggle^=button]', function ( e
) {
239 var $btn
= $(e
.target
)
240 if (!$btn
.hasClass('btn')) $btn
= $btn
.closest('.btn')
241 $btn
.button('toggle')
245 }(window
.jQuery
);/* ==========================================================
246 * bootstrap-carousel.js v2.0.3
247 * http://twitter.github.com/bootstrap/javascript.html#carousel
248 * ==========================================================
249 * Copyright 2012 Twitter, Inc.
251 * Licensed under the Apache License, Version 2.0 (the "License");
252 * you may not use this file except in compliance with the License.
253 * You may obtain a copy of the License at
255 * http://www.apache.org/licenses/LICENSE-2.0
257 * Unless required by applicable law or agreed to in writing, software
258 * distributed under the License is distributed on an "AS IS" BASIS,
259 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
260 * See the License for the specific language governing permissions and
261 * limitations under the License.
262 * ========================================================== */
267 "use strict"; // jshint ;_;
270 /* CAROUSEL CLASS DEFINITION
271 * ========================= */
273 var Carousel = function (element
, options
) {
274 this.$element
= $(element
)
275 this.options
= options
276 this.options
.slide
&& this.slide(this.options
.slide
)
277 this.options
.pause
== 'hover' && this.$element
278 .on('mouseenter', $.proxy(this.pause
, this))
279 .on('mouseleave', $.proxy(this.cycle
, this))
282 Carousel
.prototype = {
284 cycle: function (e
) {
285 if (!e
) this.paused
= false
286 this.options
.interval
288 && (this.interval
= setInterval($.proxy(this.next
, this), this.options
.interval
))
292 , to: function (pos
) {
293 var $active
= this.$element
.find('.active')
294 , children
= $active
.parent().children()
295 , activePos
= children
.index($active
)
298 if (pos
> (children
.length
- 1) || pos
< 0) return
301 return this.$element
.one('slid', function () {
306 if (activePos
== pos
) {
307 return this.pause().cycle()
310 return this.slide(pos
> activePos
? 'next' : 'prev', $(children
[pos
]))
313 , pause: function (e
) {
314 if (!e
) this.paused
= true
315 clearInterval(this.interval
)
320 , next: function () {
321 if (this.sliding
) return
322 return this.slide('next')
325 , prev: function () {
326 if (this.sliding
) return
327 return this.slide('prev')
330 , slide: function (type
, next
) {
331 var $active
= this.$element
.find('.active')
332 , $next
= next
|| $active
[type
]()
333 , isCycling
= this.interval
334 , direction
= type
== 'next' ? 'left' : 'right'
335 , fallback
= type
== 'next' ? 'first' : 'last'
337 , e
= $.Event('slide')
341 isCycling
&& this.pause()
343 $next
= $next
.length
? $next
: this.$element
.find('.item')[fallback
]()
345 if ($next
.hasClass('active')) return
347 if ($.support
.transition
&& this.$element
.hasClass('slide')) {
348 this.$element
.trigger(e
)
349 if (e
.isDefaultPrevented()) return
351 $next
[0].offsetWidth
// force reflow
352 $active
.addClass(direction
)
353 $next
.addClass(direction
)
354 this.$element
.one($.support
.transition
.end
, function () {
355 $next
.removeClass([type
, direction
].join(' ')).addClass('active')
356 $active
.removeClass(['active', direction
].join(' '))
358 setTimeout(function () { that
.$element
.trigger('slid') }, 0)
361 this.$element
.trigger(e
)
362 if (e
.isDefaultPrevented()) return
363 $active
.removeClass('active')
364 $next
.addClass('active')
366 this.$element
.trigger('slid')
369 isCycling
&& this.cycle()
377 /* CAROUSEL PLUGIN DEFINITION
378 * ========================== */
380 $.fn
.carousel = function (option
) {
381 return this.each(function () {
383 , data
= $this.data('carousel')
384 , options
= $.extend({}, $.fn
.carousel
.defaults
, typeof option
== 'object' && option
)
385 if (!data
) $this.data('carousel', (data
= new Carousel(this, options
)))
386 if (typeof option
== 'number') data
.to(option
)
387 else if (typeof option
== 'string' || (option
= options
.slide
)) data
[option
]()
388 else if (options
.interval
) data
.cycle()
392 $.fn
.carousel
.defaults
= {
397 $.fn
.carousel
.Constructor
= Carousel
401 * ================= */
404 $('body').on('click.carousel.data-api', '[data-slide]', function ( e
) {
405 var $this = $(this), href
406 , $target
= $($this.attr('data-target') || (href
= $this.attr('href')) && href
.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
407 , options
= !$target
.data('modal') && $.extend({}, $target
.data(), $this.data())
408 $target
.carousel(options
)
413 }(window
.jQuery
);/* =============================================================
414 * bootstrap-collapse.js v2.0.3
415 * http://twitter.github.com/bootstrap/javascript.html#collapse
416 * =============================================================
417 * Copyright 2012 Twitter, Inc.
419 * Licensed under the Apache License, Version 2.0 (the "License");
420 * you may not use this file except in compliance with the License.
421 * You may obtain a copy of the License at
423 * http://www.apache.org/licenses/LICENSE-2.0
425 * Unless required by applicable law or agreed to in writing, software
426 * distributed under the License is distributed on an "AS IS" BASIS,
427 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
428 * See the License for the specific language governing permissions and
429 * limitations under the License.
430 * ============================================================ */
435 "use strict"; // jshint ;_;
438 /* COLLAPSE PUBLIC CLASS DEFINITION
439 * ================================ */
441 var Collapse = function (element
, options
) {
442 this.$element
= $(element
)
443 this.options
= $.extend({}, $.fn
.collapse
.defaults
, options
)
445 if (this.options
.parent
) {
446 this.$parent
= $(this.options
.parent
)
449 this.options
.toggle
&& this.toggle()
452 Collapse
.prototype = {
454 constructor: Collapse
456 , dimension: function () {
457 var hasWidth
= this.$element
.hasClass('width')
458 return hasWidth
? 'width' : 'height'
461 , show: function () {
467 if (this.transitioning
) return
469 dimension
= this.dimension()
470 scroll
= $.camelCase(['scroll', dimension
].join('-'))
471 actives
= this.$parent
&& this.$parent
.find('> .accordion-group > .in')
473 if (actives
&& actives
.length
) {
474 hasData
= actives
.data('collapse')
475 if (hasData
&& hasData
.transitioning
) return
476 actives
.collapse('hide')
477 hasData
|| actives
.data('collapse', null)
480 this.$element
[dimension
](0)
481 this.transition('addClass', $.Event('show'), 'shown')
482 this.$element
[dimension
](this.$element
[0][scroll
])
485 , hide: function () {
487 if (this.transitioning
) return
488 dimension
= this.dimension()
489 this.reset(this.$element
[dimension
]())
490 this.transition('removeClass', $.Event('hide'), 'hidden')
491 this.$element
[dimension
](0)
494 , reset: function (size
) {
495 var dimension
= this.dimension()
498 .removeClass('collapse')
499 [dimension
](size
|| 'auto')
502 this.$element
[size
!== null ? 'addClass' : 'removeClass']('collapse')
507 , transition: function (method
, startEvent
, completeEvent
) {
509 , complete = function () {
510 if (startEvent
.type
== 'show') that
.reset()
511 that
.transitioning
= 0
512 that
.$element
.trigger(completeEvent
)
515 this.$element
.trigger(startEvent
)
517 if (startEvent
.isDefaultPrevented()) return
519 this.transitioning
= 1
521 this.$element
[method
]('in')
523 $.support
.transition
&& this.$element
.hasClass('collapse') ?
524 this.$element
.one($.support
.transition
.end
, complete
) :
528 , toggle: function () {
529 this[this.$element
.hasClass('in') ? 'hide' : 'show']()
535 /* COLLAPSIBLE PLUGIN DEFINITION
536 * ============================== */
538 $.fn
.collapse = function (option
) {
539 return this.each(function () {
541 , data
= $this.data('collapse')
542 , options
= typeof option
== 'object' && option
543 if (!data
) $this.data('collapse', (data
= new Collapse(this, options
)))
544 if (typeof option
== 'string') data
[option
]()
548 $.fn
.collapse
.defaults
= {
552 $.fn
.collapse
.Constructor
= Collapse
555 /* COLLAPSIBLE DATA-API
556 * ==================== */
559 $('body').on('click.collapse.data-api', '[data-toggle=collapse]', function ( e
) {
560 var $this = $(this), href
561 , target
= $this.attr('data-target')
562 || e
.preventDefault()
563 || (href
= $this.attr('href')) && href
.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
564 , option
= $(target
).data('collapse') ? 'toggle' : $this.data()
565 $(target
).collapse(option
)
569 }(window
.jQuery
);/* ============================================================
570 * bootstrap-dropdown.js v2.0.3
571 * http://twitter.github.com/bootstrap/javascript.html#dropdowns
572 * ============================================================
573 * Copyright 2012 Twitter, Inc.
575 * Licensed under the Apache License, Version 2.0 (the "License");
576 * you may not use this file except in compliance with the License.
577 * You may obtain a copy of the License at
579 * http://www.apache.org/licenses/LICENSE-2.0
581 * Unless required by applicable law or agreed to in writing, software
582 * distributed under the License is distributed on an "AS IS" BASIS,
583 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
584 * See the License for the specific language governing permissions and
585 * limitations under the License.
586 * ============================================================ */
591 "use strict"; // jshint ;_;
594 /* DROPDOWN CLASS DEFINITION
595 * ========================= */
597 var toggle
= '[data-toggle="dropdown"]'
598 , Dropdown = function (element
) {
599 var $el
= $(element
).on('click.dropdown.data-api', this.toggle
)
600 $('html').on('click.dropdown.data-api', function () {
601 $el
.parent().removeClass('open')
605 Dropdown
.prototype = {
607 constructor: Dropdown
609 , toggle: function (e
) {
615 if ($this.is('.disabled, :disabled')) return
617 selector
= $this.attr('data-target')
620 selector
= $this.attr('href')
621 selector
= selector
&& selector
.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
624 $parent
= $(selector
)
625 $parent
.length
|| ($parent
= $this.parent())
627 isActive
= $parent
.hasClass('open')
631 if (!isActive
) $parent
.toggleClass('open')
638 function clearMenus() {
639 $(toggle
).parent().removeClass('open')
643 /* DROPDOWN PLUGIN DEFINITION
644 * ========================== */
646 $.fn
.dropdown = function (option
) {
647 return this.each(function () {
649 , data
= $this.data('dropdown')
650 if (!data
) $this.data('dropdown', (data
= new Dropdown(this)))
651 if (typeof option
== 'string') data
[option
].call($this)
655 $.fn
.dropdown
.Constructor
= Dropdown
658 /* APPLY TO STANDARD DROPDOWN ELEMENTS
659 * =================================== */
662 $('html').on('click.dropdown.data-api', clearMenus
)
664 .on('click.dropdown', '.dropdown form', function (e
) { e
.stopPropagation() })
665 .on('click.dropdown.data-api', toggle
, Dropdown
.prototype.toggle
)
668 }(window
.jQuery
);/* =========================================================
669 * bootstrap-modal.js v2.0.3
670 * http://twitter.github.com/bootstrap/javascript.html#modals
671 * =========================================================
672 * Copyright 2012 Twitter, Inc.
674 * Licensed under the Apache License, Version 2.0 (the "License");
675 * you may not use this file except in compliance with the License.
676 * You may obtain a copy of the License at
678 * http://www.apache.org/licenses/LICENSE-2.0
680 * Unless required by applicable law or agreed to in writing, software
681 * distributed under the License is distributed on an "AS IS" BASIS,
682 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
683 * See the License for the specific language governing permissions and
684 * limitations under the License.
685 * ========================================================= */
690 "use strict"; // jshint ;_;
693 /* MODAL CLASS DEFINITION
694 * ====================== */
696 var Modal = function (content
, options
) {
697 this.options
= options
698 this.$element
= $(content
)
699 .delegate('[data-dismiss="modal"]', 'click.dismiss.modal', $.proxy(this.hide
, this))
706 , toggle: function () {
707 return this[!this.isShown
? 'show' : 'hide']()
710 , show: function () {
712 , e
= $.Event('show')
714 this.$element
.trigger(e
)
716 if (this.isShown
|| e
.isDefaultPrevented()) return
718 $('body').addClass('modal-open')
723 backdrop
.call(this, function () {
724 var transition
= $.support
.transition
&& that
.$element
.hasClass('fade')
726 if (!that
.$element
.parent().length
) {
727 that
.$element
.appendTo(document
.body
) //don't move modals dom position
734 that
.$element
[0].offsetWidth
// force reflow
737 that
.$element
.addClass('in')
740 that
.$element
.one($.support
.transition
.end
, function () { that
.$element
.trigger('shown') }) :
741 that
.$element
.trigger('shown')
746 , hide: function (e
) {
747 e
&& e
.preventDefault()
753 this.$element
.trigger(e
)
755 if (!this.isShown
|| e
.isDefaultPrevented()) return
759 $('body').removeClass('modal-open')
763 this.$element
.removeClass('in')
765 $.support
.transition
&& this.$element
.hasClass('fade') ?
766 hideWithTransition
.call(this) :
773 /* MODAL PRIVATE METHODS
774 * ===================== */
776 function hideWithTransition() {
778 , timeout
= setTimeout(function () {
779 that
.$element
.off($.support
.transition
.end
)
783 this.$element
.one($.support
.transition
.end
, function () {
784 clearTimeout(timeout
)
789 function hideModal(that
) {
797 function backdrop(callback
) {
799 , animate
= this.$element
.hasClass('fade') ? 'fade' : ''
801 if (this.isShown
&& this.options
.backdrop
) {
802 var doAnimate
= $.support
.transition
&& animate
804 this.$backdrop
= $('<div class="modal-backdrop ' + animate
+ '" />')
805 .appendTo(document
.body
)
807 if (this.options
.backdrop
!= 'static') {
808 this.$backdrop
.click($.proxy(this.hide
, this))
811 if (doAnimate
) this.$backdrop
[0].offsetWidth
// force reflow
813 this.$backdrop
.addClass('in')
816 this.$backdrop
.one($.support
.transition
.end
, callback
) :
819 } else if (!this.isShown
&& this.$backdrop
) {
820 this.$backdrop
.removeClass('in')
822 $.support
.transition
&& this.$element
.hasClass('fade')?
823 this.$backdrop
.one($.support
.transition
.end
, $.proxy(removeBackdrop
, this)) :
824 removeBackdrop
.call(this)
826 } else if (callback
) {
831 function removeBackdrop() {
832 this.$backdrop
.remove()
833 this.$backdrop
= null
838 if (this.isShown
&& this.options
.keyboard
) {
839 $(document
).on('keyup.dismiss.modal', function ( e
) {
840 e
.which
== 27 && that
.hide()
842 } else if (!this.isShown
) {
843 $(document
).off('keyup.dismiss.modal')
848 /* MODAL PLUGIN DEFINITION
849 * ======================= */
851 $.fn
.modal = function (option
) {
852 return this.each(function () {
854 , data
= $this.data('modal')
855 , options
= $.extend({}, $.fn
.modal
.defaults
, $this.data(), typeof option
== 'object' && option
)
856 if (!data
) $this.data('modal', (data
= new Modal(this, options
)))
857 if (typeof option
== 'string') data
[option
]()
858 else if (options
.show
) data
.show()
862 $.fn
.modal
.defaults
= {
868 $.fn
.modal
.Constructor
= Modal
875 $('body').on('click.modal.data-api', '[data-toggle="modal"]', function ( e
) {
876 var $this = $(this), href
877 , $target
= $($this.attr('data-target') || (href
= $this.attr('href')) && href
.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
878 , option
= $target
.data('modal') ? 'toggle' : $.extend({}, $target
.data(), $this.data())
881 $target
.modal(option
)
885 }(window
.jQuery
);/* ===========================================================
886 * bootstrap-tooltip.js v2.0.3
887 * http://twitter.github.com/bootstrap/javascript.html#tooltips
888 * Inspired by the original jQuery.tipsy by Jason Frame
889 * ===========================================================
890 * Copyright 2012 Twitter, Inc.
892 * Licensed under the Apache License, Version 2.0 (the "License");
893 * you may not use this file except in compliance with the License.
894 * You may obtain a copy of the License at
896 * http://www.apache.org/licenses/LICENSE-2.0
898 * Unless required by applicable law or agreed to in writing, software
899 * distributed under the License is distributed on an "AS IS" BASIS,
900 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
901 * See the License for the specific language governing permissions and
902 * limitations under the License.
903 * ========================================================== */
908 "use strict"; // jshint ;_;
911 /* TOOLTIP PUBLIC CLASS DEFINITION
912 * =============================== */
914 var Tooltip = function (element
, options
) {
915 this.init('tooltip', element
, options
)
918 Tooltip
.prototype = {
922 , init: function (type
, element
, options
) {
927 this.$element
= $(element
)
928 this.options
= this.getOptions(options
)
931 if (this.options
.trigger
!= 'manual') {
932 eventIn
= this.options
.trigger
== 'hover' ? 'mouseenter' : 'focus'
933 eventOut
= this.options
.trigger
== 'hover' ? 'mouseleave' : 'blur'
934 this.$element
.on(eventIn
, this.options
.selector
, $.proxy(this.enter
, this))
935 this.$element
.on(eventOut
, this.options
.selector
, $.proxy(this.leave
, this))
938 this.options
.selector
?
939 (this._options
= $.extend({}, this.options
, { trigger
: 'manual', selector
: '' })) :
943 , getOptions: function (options
) {
944 options
= $.extend({}, $.fn
[this.type
].defaults
, options
, this.$element
.data())
946 if (options
.delay
&& typeof options
.delay
== 'number') {
949 , hide
: options
.delay
956 , enter: function (e
) {
957 var self
= $(e
.currentTarget
)[this.type
](this._options
).data(this.type
)
959 if (!self
.options
.delay
|| !self
.options
.delay
.show
) return self
.show()
961 clearTimeout(this.timeout
)
962 self
.hoverState
= 'in'
963 this.timeout
= setTimeout(function() {
964 if (self
.hoverState
== 'in') self
.show()
965 }, self
.options
.delay
.show
)
968 , leave: function (e
) {
969 var self
= $(e
.currentTarget
)[this.type
](this._options
).data(this.type
)
971 if (!self
.options
.delay
|| !self
.options
.delay
.hide
) return self
.hide()
973 clearTimeout(this.timeout
)
974 self
.hoverState
= 'out'
975 this.timeout
= setTimeout(function() {
976 if (self
.hoverState
== 'out') self
.hide()
977 }, self
.options
.delay
.hide
)
980 , show: function () {
989 if (this.hasContent() && this.enabled
) {
993 if (this.options
.animation
) {
994 $tip
.addClass('fade')
997 placement
= typeof this.options
.placement
== 'function' ?
998 this.options
.placement
.call(this, $tip
[0], this.$element
[0]) :
999 this.options
.placement
1001 inside
= /in/.test(placement
)
1005 .css({ top
: 0, left
: 0, display
: 'block' })
1006 .appendTo(inside
? this.$element
: document
.body
)
1008 pos
= this.getPosition(inside
)
1010 actualWidth
= $tip
[0].offsetWidth
1011 actualHeight
= $tip
[0].offsetHeight
1013 switch (inside
? placement
.split(' ')[1] : placement
) {
1015 tp
= {top
: pos
.top
+ pos
.height
, left
: pos
.left
+ pos
.width
/ 2 - actualWidth
/ 2}
1018 tp
= {top
: pos
.top
- actualHeight
, left
: pos
.left
+ pos
.width
/ 2 - actualWidth
/ 2}
1021 tp
= {top
: pos
.top
+ pos
.height
/ 2 - actualHeight
/ 2, left
: pos
.left
- actualWidth
}
1024 tp
= {top
: pos
.top
+ pos
.height
/ 2 - actualHeight
/ 2, left
: pos
.left
+ pos
.width
}
1030 .addClass(placement
)
1035 , isHTML: function(text
) {
1036 // html string detection logic adapted from jQuery
1037 return typeof text
!= 'string'
1038 || ( text
.charAt(0) === "<"
1039 && text
.charAt( text
.length
- 1 ) === ">"
1041 ) || /^(?:[^<]*<[\w\W]+>[^>]*$)/.exec(text
)
1044 , setContent: function () {
1045 var $tip
= this.tip()
1046 , title
= this.getTitle()
1048 $tip
.find('.tooltip-inner')[this.isHTML(title
) ? 'html' : 'text'](title
)
1049 $tip
.removeClass('fade in top bottom left right')
1052 , hide: function () {
1056 $tip
.removeClass('in')
1058 function removeWithAnimation() {
1059 var timeout
= setTimeout(function () {
1060 $tip
.off($.support
.transition
.end
).remove()
1063 $tip
.one($.support
.transition
.end
, function () {
1064 clearTimeout(timeout
)
1069 $.support
.transition
&& this.$tip
.hasClass('fade') ?
1070 removeWithAnimation() :
1074 , fixTitle: function () {
1075 var $e
= this.$element
1076 if ($e
.attr('title') || typeof($e
.attr('data-original-title')) != 'string') {
1077 $e
.attr('data-original-title', $e
.attr('title') || '').removeAttr('title')
1081 , hasContent: function () {
1082 return this.getTitle()
1085 , getPosition: function (inside
) {
1086 return $.extend({}, (inside
? {top
: 0, left
: 0} : this.$element
.offset()), {
1087 width
: this.$element
[0].offsetWidth
1088 , height
: this.$element
[0].offsetHeight
1092 , getTitle: function () {
1094 , $e
= this.$element
1097 title
= $e
.attr('data-original-title')
1098 || (typeof o
.title
== 'function' ? o
.title
.call($e
[0]) : o
.title
)
1103 , tip: function () {
1104 return this.$tip
= this.$tip
|| $(this.options
.template
)
1107 , validate: function () {
1108 if (!this.$element
[0].parentNode
) {
1110 this.$element
= null
1115 , enable: function () {
1119 , disable: function () {
1120 this.enabled
= false
1123 , toggleEnabled: function () {
1124 this.enabled
= !this.enabled
1127 , toggle: function () {
1128 this[this.tip().hasClass('in') ? 'hide' : 'show']()
1134 /* TOOLTIP PLUGIN DEFINITION
1135 * ========================= */
1137 $.fn
.tooltip = function ( option
) {
1138 return this.each(function () {
1140 , data
= $this.data('tooltip')
1141 , options
= typeof option
== 'object' && option
1142 if (!data
) $this.data('tooltip', (data
= new Tooltip(this, options
)))
1143 if (typeof option
== 'string') data
[option
]()
1147 $.fn
.tooltip
.Constructor
= Tooltip
1149 $.fn
.tooltip
.defaults
= {
1153 , template
: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
1159 }(window
.jQuery
);/* ===========================================================
1160 * bootstrap-popover.js v2.0.3
1161 * http://twitter.github.com/bootstrap/javascript.html#popovers
1162 * ===========================================================
1163 * Copyright 2012 Twitter, Inc.
1165 * Licensed under the Apache License, Version 2.0 (the "License");
1166 * you may not use this file except in compliance with the License.
1167 * You may obtain a copy of the License at
1169 * http://www.apache.org/licenses/LICENSE-2.0
1171 * Unless required by applicable law or agreed to in writing, software
1172 * distributed under the License is distributed on an "AS IS" BASIS,
1173 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1174 * See the License for the specific language governing permissions and
1175 * limitations under the License.
1176 * =========================================================== */
1181 "use strict"; // jshint ;_;
1184 /* POPOVER PUBLIC CLASS DEFINITION
1185 * =============================== */
1187 var Popover = function ( element
, options
) {
1188 this.init('popover', element
, options
)
1192 /* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
1193 ========================================== */
1195 Popover
.prototype = $.extend({}, $.fn
.tooltip
.Constructor
.prototype, {
1197 constructor: Popover
1199 , setContent: function () {
1200 var $tip
= this.tip()
1201 , title
= this.getTitle()
1202 , content
= this.getContent()
1204 $tip
.find('.popover-title')[this.isHTML(title
) ? 'html' : 'text'](title
)
1205 $tip
.find('.popover-content > *')[this.isHTML(content
) ? 'html' : 'text'](content
)
1207 $tip
.removeClass('fade top bottom left right in')
1210 , hasContent: function () {
1211 return this.getTitle() || this.getContent()
1214 , getContent: function () {
1216 , $e
= this.$element
1219 content
= $e
.attr('data-content')
1220 || (typeof o
.content
== 'function' ? o
.content
.call($e
[0]) : o
.content
)
1225 , tip: function () {
1227 this.$tip
= $(this.options
.template
)
1235 /* POPOVER PLUGIN DEFINITION
1236 * ======================= */
1238 $.fn
.popover = function (option
) {
1239 return this.each(function () {
1241 , data
= $this.data('popover')
1242 , options
= typeof option
== 'object' && option
1243 if (!data
) $this.data('popover', (data
= new Popover(this, options
)))
1244 if (typeof option
== 'string') data
[option
]()
1248 $.fn
.popover
.Constructor
= Popover
1250 $.fn
.popover
.defaults
= $.extend({} , $.fn
.tooltip
.defaults
, {
1253 , 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>'
1256 }(window
.jQuery
);/* =============================================================
1257 * bootstrap-scrollspy.js v2.0.3
1258 * http://twitter.github.com/bootstrap/javascript.html#scrollspy
1259 * =============================================================
1260 * Copyright 2012 Twitter, Inc.
1262 * Licensed under the Apache License, Version 2.0 (the "License");
1263 * you may not use this file except in compliance with the License.
1264 * You may obtain a copy of the License at
1266 * http://www.apache.org/licenses/LICENSE-2.0
1268 * Unless required by applicable law or agreed to in writing, software
1269 * distributed under the License is distributed on an "AS IS" BASIS,
1270 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1271 * See the License for the specific language governing permissions and
1272 * limitations under the License.
1273 * ============================================================== */
1278 "use strict"; // jshint ;_;
1281 /* SCROLLSPY CLASS DEFINITION
1282 * ========================== */
1284 function ScrollSpy( element
, options
) {
1285 var process
= $.proxy(this.process
, this)
1286 , $element
= $(element
).is('body') ? $(window
) : $(element
)
1288 this.options
= $.extend({}, $.fn
.scrollspy
.defaults
, options
)
1289 this.$scrollElement
= $element
.on('scroll.scroll.data-api', process
)
1290 this.selector
= (this.options
.target
1291 || ((href
= $(element
).attr('href')) && href
.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
1292 || '') + ' .nav li > a'
1293 this.$body
= $('body')
1298 ScrollSpy
.prototype = {
1300 constructor: ScrollSpy
1302 , refresh: function () {
1306 this.offsets
= $([])
1307 this.targets
= $([])
1309 $targets
= this.$body
1310 .find(this.selector
)
1313 , href
= $el
.data('target') || $el
.attr('href')
1314 , $href
= /^#\w/.test(href
) && $(href
)
1317 && [[ $href
.position().top
, href
]] ) || null
1319 .sort(function (a
, b
) { return a
[0] - b
[0] })
1321 self
.offsets
.push(this[0])
1322 self
.targets
.push(this[1])
1326 , process: function () {
1327 var scrollTop
= this.$scrollElement
.scrollTop() + this.options
.offset
1328 , scrollHeight
= this.$scrollElement
[0].scrollHeight
|| this.$body
[0].scrollHeight
1329 , maxScroll
= scrollHeight
- this.$scrollElement
.height()
1330 , offsets
= this.offsets
1331 , targets
= this.targets
1332 , activeTarget
= this.activeTarget
1335 if (scrollTop
>= maxScroll
) {
1336 return activeTarget
!= (i
= targets
.last()[0])
1337 && this.activate ( i
)
1340 for (i
= offsets
.length
; i
--;) {
1341 activeTarget
!= targets
[i
]
1342 && scrollTop
>= offsets
[i
]
1343 && (!offsets
[i
+ 1] || scrollTop
<= offsets
[i
+ 1])
1344 && this.activate( targets
[i
] )
1348 , activate: function (target
) {
1352 this.activeTarget
= target
1356 .removeClass('active')
1358 selector
= this.selector
1359 + '[data-target="' + target
+ '"],'
1360 + this.selector
+ '[href="' + target
+ '"]'
1362 active
= $(selector
)
1366 if (active
.parent('.dropdown-menu')) {
1367 active
= active
.closest('li.dropdown').addClass('active')
1370 active
.trigger('activate')
1376 /* SCROLLSPY PLUGIN DEFINITION
1377 * =========================== */
1379 $.fn
.scrollspy = function ( option
) {
1380 return this.each(function () {
1382 , data
= $this.data('scrollspy')
1383 , options
= typeof option
== 'object' && option
1384 if (!data
) $this.data('scrollspy', (data
= new ScrollSpy(this, options
)))
1385 if (typeof option
== 'string') data
[option
]()
1389 $.fn
.scrollspy
.Constructor
= ScrollSpy
1391 $.fn
.scrollspy
.defaults
= {
1396 /* SCROLLSPY DATA-API
1397 * ================== */
1400 $('[data-spy="scroll"]').each(function () {
1402 $spy
.scrollspy($spy
.data())
1406 }(window
.jQuery
);/* ========================================================
1407 * bootstrap-tab.js v2.0.3
1408 * http://twitter.github.com/bootstrap/javascript.html#tabs
1409 * ========================================================
1410 * Copyright 2012 Twitter, Inc.
1412 * Licensed under the Apache License, Version 2.0 (the "License");
1413 * you may not use this file except in compliance with the License.
1414 * You may obtain a copy of the License at
1416 * http://www.apache.org/licenses/LICENSE-2.0
1418 * Unless required by applicable law or agreed to in writing, software
1419 * distributed under the License is distributed on an "AS IS" BASIS,
1420 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1421 * See the License for the specific language governing permissions and
1422 * limitations under the License.
1423 * ======================================================== */
1428 "use strict"; // jshint ;_;
1431 /* TAB CLASS DEFINITION
1432 * ==================== */
1434 var Tab = function ( element
) {
1435 this.element
= $(element
)
1442 , show: function () {
1443 var $this = this.element
1444 , $ul
= $this.closest('ul:not(.dropdown-menu)')
1445 , selector
= $this.attr('data-target')
1451 selector
= $this.attr('href')
1452 selector
= selector
&& selector
.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
1455 if ( $this.parent('li').hasClass('active') ) return
1457 previous
= $ul
.find('.active a').last()[0]
1459 e
= $.Event('show', {
1460 relatedTarget
: previous
1465 if (e
.isDefaultPrevented()) return
1467 $target
= $(selector
)
1469 this.activate($this.parent('li'), $ul
)
1470 this.activate($target
, $target
.parent(), function () {
1473 , relatedTarget
: previous
1478 , activate: function ( element
, container
, callback
) {
1479 var $active
= container
.find('> .active')
1480 , transition
= callback
1481 && $.support
.transition
1482 && $active
.hasClass('fade')
1486 .removeClass('active')
1487 .find('> .dropdown-menu > .active')
1488 .removeClass('active')
1490 element
.addClass('active')
1493 element
[0].offsetWidth
// reflow for transition
1494 element
.addClass('in')
1496 element
.removeClass('fade')
1499 if ( element
.parent('.dropdown-menu') ) {
1500 element
.closest('li.dropdown').addClass('active')
1503 callback
&& callback()
1507 $active
.one($.support
.transition
.end
, next
) :
1510 $active
.removeClass('in')
1515 /* TAB PLUGIN DEFINITION
1516 * ===================== */
1518 $.fn
.tab = function ( option
) {
1519 return this.each(function () {
1521 , data
= $this.data('tab')
1522 if (!data
) $this.data('tab', (data
= new Tab(this)))
1523 if (typeof option
== 'string') data
[option
]()
1527 $.fn
.tab
.Constructor
= Tab
1534 $('body').on('click.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e
) {
1540 }(window
.jQuery
);/* =============================================================
1541 * bootstrap-typeahead.js v2.0.3
1542 * http://twitter.github.com/bootstrap/javascript.html#typeahead
1543 * =============================================================
1544 * Copyright 2012 Twitter, Inc.
1546 * Licensed under the Apache License, Version 2.0 (the "License");
1547 * you may not use this file except in compliance with the License.
1548 * You may obtain a copy of the License at
1550 * http://www.apache.org/licenses/LICENSE-2.0
1552 * Unless required by applicable law or agreed to in writing, software
1553 * distributed under the License is distributed on an "AS IS" BASIS,
1554 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1555 * See the License for the specific language governing permissions and
1556 * limitations under the License.
1557 * ============================================================ */
1562 "use strict"; // jshint ;_;
1565 /* TYPEAHEAD PUBLIC CLASS DEFINITION
1566 * ================================= */
1568 var Typeahead = function (element
, options
) {
1569 this.$element
= $(element
)
1570 this.options
= $.extend({}, $.fn
.typeahead
.defaults
, options
)
1571 this.matcher
= this.options
.matcher
|| this.matcher
1572 this.sorter
= this.options
.sorter
|| this.sorter
1573 this.highlighter
= this.options
.highlighter
|| this.highlighter
1574 this.updater
= this.options
.updater
|| this.updater
1575 this.$menu
= $(this.options
.menu
).appendTo('body')
1576 this.source
= this.options
.source
1581 Typeahead
.prototype = {
1583 constructor: Typeahead
1585 , select: function () {
1586 var val
= this.$menu
.find('.active').attr('data-value')
1588 .val(this.updater(val
))
1593 , updater: function (item
) {
1597 , show: function () {
1598 var pos
= $.extend({}, this.$element
.offset(), {
1599 height
: this.$element
[0].offsetHeight
1603 top
: pos
.top
+ pos
.height
1612 , hide: function () {
1618 , lookup: function (event
) {
1623 this.query
= this.$element
.val()
1626 return this.shown
? this.hide() : this
1629 items
= $.grep(this.source
, function (item
) {
1630 return that
.matcher(item
)
1633 items
= this.sorter(items
)
1635 if (!items
.length
) {
1636 return this.shown
? this.hide() : this
1639 return this.render(items
.slice(0, this.options
.items
)).show()
1642 , matcher: function (item
) {
1643 return ~item
.toLowerCase().indexOf(this.query
.toLowerCase())
1646 , sorter: function (items
) {
1648 , caseSensitive
= []
1649 , caseInsensitive
= []
1652 while (item
= items
.shift()) {
1653 if (!item
.toLowerCase().indexOf(this.query
.toLowerCase())) beginswith
.push(item
)
1654 else if (~item
.indexOf(this.query
)) caseSensitive
.push(item
)
1655 else caseInsensitive
.push(item
)
1658 return beginswith
.concat(caseSensitive
, caseInsensitive
)
1661 , highlighter: function (item
) {
1662 var query
= this.query
.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g, '\\$&')
1663 return item
.replace(new RegExp('(' + query
+ ')', 'ig'), function ($1, match
) {
1664 return '<strong>' + match
+ '</strong>'
1668 , render: function (items
) {
1671 items
= $(items
).map(function (i
, item
) {
1672 i
= $(that
.options
.item
).attr('data-value', item
)
1673 i
.find('a').html(that
.highlighter(item
))
1677 items
.first().addClass('active')
1678 this.$menu
.html(items
)
1682 , next: function (event
) {
1683 var active
= this.$menu
.find('.active').removeClass('active')
1684 , next
= active
.next()
1687 next
= $(this.$menu
.find('li')[0])
1690 next
.addClass('active')
1693 , prev: function (event
) {
1694 var active
= this.$menu
.find('.active').removeClass('active')
1695 , prev
= active
.prev()
1698 prev
= this.$menu
.find('li').last()
1701 prev
.addClass('active')
1704 , listen: function () {
1706 .on('blur', $.proxy(this.blur
, this))
1707 .on('keypress', $.proxy(this.keypress
, this))
1708 .on('keyup', $.proxy(this.keyup
, this))
1710 if ($.browser
.webkit
|| $.browser
.msie
) {
1711 this.$element
.on('keydown', $.proxy(this.keypress
, this))
1715 .on('click', $.proxy(this.click
, this))
1716 .on('mouseenter', 'li', $.proxy(this.mouseenter
, this))
1719 , keyup: function (e
) {
1721 case 40: // down arrow
1722 case 38: // up arrow
1727 if (!this.shown
) return
1732 if (!this.shown
) return
1744 , keypress: function (e
) {
1745 if (!this.shown
) return
1754 case 38: // up arrow
1755 if (e
.type
!= 'keydown') break
1760 case 40: // down arrow
1761 if (e
.type
!= 'keydown') break
1770 , blur: function (e
) {
1772 setTimeout(function () { that
.hide() }, 150)
1775 , click: function (e
) {
1781 , mouseenter: function (e
) {
1782 this.$menu
.find('.active').removeClass('active')
1783 $(e
.currentTarget
).addClass('active')
1789 /* TYPEAHEAD PLUGIN DEFINITION
1790 * =========================== */
1792 $.fn
.typeahead = function (option
) {
1793 return this.each(function () {
1795 , data
= $this.data('typeahead')
1796 , options
= typeof option
== 'object' && option
1797 if (!data
) $this.data('typeahead', (data
= new Typeahead(this, options
)))
1798 if (typeof option
== 'string') data
[option
]()
1802 $.fn
.typeahead
.defaults
= {
1805 , menu
: '<ul class="typeahead dropdown-menu"></ul>'
1806 , item
: '<li><a href="#"></a></li>'
1809 $.fn
.typeahead
.Constructor
= Typeahead
1812 /* TYPEAHEAD DATA-API
1813 * ================== */
1816 $('body').on('focus.typeahead.data-api', '[data-provide="typeahead"]', function (e
) {
1818 if ($this.data('typeahead')) return
1820 $this.typeahead($this.data())