static/js/bootstrap.js
changeset 51 d68c1b192ade
parent 0 46abfb767ff2
     1.1 --- a/static/js/bootstrap.js	Fri Dec 20 21:55:02 2013 +0100
     1.2 +++ b/static/js/bootstrap.js	Fri Dec 20 21:57:50 2013 +0100
     1.3 @@ -1,9 +1,2006 @@
     1.4  /*!
     1.5 - * Bootstrap v3.0.2 by @fat and @mdo
     1.6 + * Bootstrap v3.0.3 (http://getbootstrap.com)
     1.7   * Copyright 2013 Twitter, Inc.
     1.8   * Licensed under http://www.apache.org/licenses/LICENSE-2.0
     1.9 - *
    1.10 - * Designed and built with all the love in the world by @mdo and @fat.
    1.11   */
    1.12  
    1.13 -if("undefined"==typeof jQuery)throw new Error("Bootstrap requires jQuery");+function(a){"use strict";function b(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"};for(var c in b)if(void 0!==a.style[c])return{end:b[c]}}a.fn.emulateTransitionEnd=function(b){var c=!1,d=this;a(this).one(a.support.transition.end,function(){c=!0});var e=function(){c||a(d).trigger(a.support.transition.end)};return setTimeout(e,b),this},a(function(){a.support.transition=b()})}(jQuery),+function(a){"use strict";var b='[data-dismiss="alert"]',c=function(c){a(c).on("click",b,this.close)};c.prototype.close=function(b){function c(){f.trigger("closed.bs.alert").remove()}var d=a(this),e=d.attr("data-target");e||(e=d.attr("href"),e=e&&e.replace(/.*(?=#[^\s]*$)/,""));var f=a(e);b&&b.preventDefault(),f.length||(f=d.hasClass("alert")?d:d.parent()),f.trigger(b=a.Event("close.bs.alert")),b.isDefaultPrevented()||(f.removeClass("in"),a.support.transition&&f.hasClass("fade")?f.one(a.support.transition.end,c).emulateTransitionEnd(150):c())};var d=a.fn.alert;a.fn.alert=function(b){return this.each(function(){var d=a(this),e=d.data("bs.alert");e||d.data("bs.alert",e=new c(this)),"string"==typeof b&&e[b].call(d)})},a.fn.alert.Constructor=c,a.fn.alert.noConflict=function(){return a.fn.alert=d,this},a(document).on("click.bs.alert.data-api",b,c.prototype.close)}(jQuery),+function(a){"use strict";var b=function(c,d){this.$element=a(c),this.options=a.extend({},b.DEFAULTS,d)};b.DEFAULTS={loadingText:"loading..."},b.prototype.setState=function(a){var b="disabled",c=this.$element,d=c.is("input")?"val":"html",e=c.data();a+="Text",e.resetText||c.data("resetText",c[d]()),c[d](e[a]||this.options[a]),setTimeout(function(){"loadingText"==a?c.addClass(b).attr(b,b):c.removeClass(b).removeAttr(b)},0)},b.prototype.toggle=function(){var a=this.$element.closest('[data-toggle="buttons"]');if(a.length){var b=this.$element.find("input").prop("checked",!this.$element.hasClass("active")).trigger("change");"radio"===b.prop("type")&&a.find(".active").removeClass("active")}this.$element.toggleClass("active")};var c=a.fn.button;a.fn.button=function(c){return this.each(function(){var d=a(this),e=d.data("bs.button"),f="object"==typeof c&&c;e||d.data("bs.button",e=new b(this,f)),"toggle"==c?e.toggle():c&&e.setState(c)})},a.fn.button.Constructor=b,a.fn.button.noConflict=function(){return a.fn.button=c,this},a(document).on("click.bs.button.data-api","[data-toggle^=button]",function(b){var c=a(b.target);c.hasClass("btn")||(c=c.closest(".btn")),c.button("toggle"),b.preventDefault()})}(jQuery),+function(a){"use strict";var b=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.paused=this.sliding=this.interval=this.$active=this.$items=null,"hover"==this.options.pause&&this.$element.on("mouseenter",a.proxy(this.pause,this)).on("mouseleave",a.proxy(this.cycle,this))};b.DEFAULTS={interval:5e3,pause:"hover",wrap:!0},b.prototype.cycle=function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},b.prototype.getActiveIndex=function(){return this.$active=this.$element.find(".item.active"),this.$items=this.$active.parent().children(),this.$items.index(this.$active)},b.prototype.to=function(b){var c=this,d=this.getActiveIndex();return b>this.$items.length-1||0>b?void 0:this.sliding?this.$element.one("slid",function(){c.to(b)}):d==b?this.pause().cycle():this.slide(b>d?"next":"prev",a(this.$items[b]))},b.prototype.pause=function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition.end&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),this.interval=clearInterval(this.interval),this},b.prototype.next=function(){return this.sliding?void 0:this.slide("next")},b.prototype.prev=function(){return this.sliding?void 0:this.slide("prev")},b.prototype.slide=function(b,c){var d=this.$element.find(".item.active"),e=c||d[b](),f=this.interval,g="next"==b?"left":"right",h="next"==b?"first":"last",i=this;if(!e.length){if(!this.options.wrap)return;e=this.$element.find(".item")[h]()}this.sliding=!0,f&&this.pause();var j=a.Event("slide.bs.carousel",{relatedTarget:e[0],direction:g});if(!e.hasClass("active")){if(this.$indicators.length&&(this.$indicators.find(".active").removeClass("active"),this.$element.one("slid",function(){var b=a(i.$indicators.children()[i.getActiveIndex()]);b&&b.addClass("active")})),a.support.transition&&this.$element.hasClass("slide")){if(this.$element.trigger(j),j.isDefaultPrevented())return;e.addClass(b),e[0].offsetWidth,d.addClass(g),e.addClass(g),d.one(a.support.transition.end,function(){e.removeClass([b,g].join(" ")).addClass("active"),d.removeClass(["active",g].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger("slid")},0)}).emulateTransitionEnd(600)}else{if(this.$element.trigger(j),j.isDefaultPrevented())return;d.removeClass("active"),e.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return f&&this.cycle(),this}};var c=a.fn.carousel;a.fn.carousel=function(c){return this.each(function(){var d=a(this),e=d.data("bs.carousel"),f=a.extend({},b.DEFAULTS,d.data(),"object"==typeof c&&c),g="string"==typeof c?c:f.slide;e||d.data("bs.carousel",e=new b(this,f)),"number"==typeof c?e.to(c):g?e[g]():f.interval&&e.pause().cycle()})},a.fn.carousel.Constructor=b,a.fn.carousel.noConflict=function(){return a.fn.carousel=c,this},a(document).on("click.bs.carousel.data-api","[data-slide], [data-slide-to]",function(b){var c,d=a(this),e=a(d.attr("data-target")||(c=d.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,"")),f=a.extend({},e.data(),d.data()),g=d.attr("data-slide-to");g&&(f.interval=!1),e.carousel(f),(g=d.attr("data-slide-to"))&&e.data("bs.carousel").to(g),b.preventDefault()}),a(window).on("load",function(){a('[data-ride="carousel"]').each(function(){var b=a(this);b.carousel(b.data())})})}(jQuery),+function(a){"use strict";var b=function(c,d){this.$element=a(c),this.options=a.extend({},b.DEFAULTS,d),this.transitioning=null,this.options.parent&&(this.$parent=a(this.options.parent)),this.options.toggle&&this.toggle()};b.DEFAULTS={toggle:!0},b.prototype.dimension=function(){var a=this.$element.hasClass("width");return a?"width":"height"},b.prototype.show=function(){if(!this.transitioning&&!this.$element.hasClass("in")){var b=a.Event("show.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.$parent&&this.$parent.find("> .panel > .in");if(c&&c.length){var d=c.data("bs.collapse");if(d&&d.transitioning)return;c.collapse("hide"),d||c.data("bs.collapse",null)}var e=this.dimension();this.$element.removeClass("collapse").addClass("collapsing")[e](0),this.transitioning=1;var f=function(){this.$element.removeClass("collapsing").addClass("in")[e]("auto"),this.transitioning=0,this.$element.trigger("shown.bs.collapse")};if(!a.support.transition)return f.call(this);var g=a.camelCase(["scroll",e].join("-"));this.$element.one(a.support.transition.end,a.proxy(f,this)).emulateTransitionEnd(350)[e](this.$element[0][g])}}},b.prototype.hide=function(){if(!this.transitioning&&this.$element.hasClass("in")){var b=a.Event("hide.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.dimension();this.$element[c](this.$element[c]())[0].offsetHeight,this.$element.addClass("collapsing").removeClass("collapse").removeClass("in"),this.transitioning=1;var d=function(){this.transitioning=0,this.$element.trigger("hidden.bs.collapse").removeClass("collapsing").addClass("collapse")};return a.support.transition?(this.$element[c](0).one(a.support.transition.end,a.proxy(d,this)).emulateTransitionEnd(350),void 0):d.call(this)}}},b.prototype.toggle=function(){this[this.$element.hasClass("in")?"hide":"show"]()};var c=a.fn.collapse;a.fn.collapse=function(c){return this.each(function(){var d=a(this),e=d.data("bs.collapse"),f=a.extend({},b.DEFAULTS,d.data(),"object"==typeof c&&c);e||d.data("bs.collapse",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.collapse.Constructor=b,a.fn.collapse.noConflict=function(){return a.fn.collapse=c,this},a(document).on("click.bs.collapse.data-api","[data-toggle=collapse]",function(b){var c,d=a(this),e=d.attr("data-target")||b.preventDefault()||(c=d.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,""),f=a(e),g=f.data("bs.collapse"),h=g?"toggle":d.data(),i=d.attr("data-parent"),j=i&&a(i);g&&g.transitioning||(j&&j.find('[data-toggle=collapse][data-parent="'+i+'"]').not(d).addClass("collapsed"),d[f.hasClass("in")?"addClass":"removeClass"]("collapsed")),f.collapse(h)})}(jQuery),+function(a){"use strict";function b(){a(d).remove(),a(e).each(function(b){var d=c(a(this));d.hasClass("open")&&(d.trigger(b=a.Event("hide.bs.dropdown")),b.isDefaultPrevented()||d.removeClass("open").trigger("hidden.bs.dropdown"))})}function c(b){var c=b.attr("data-target");c||(c=b.attr("href"),c=c&&/#/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,""));var d=c&&a(c);return d&&d.length?d:b.parent()}var d=".dropdown-backdrop",e="[data-toggle=dropdown]",f=function(b){a(b).on("click.bs.dropdown",this.toggle)};f.prototype.toggle=function(d){var e=a(this);if(!e.is(".disabled, :disabled")){var f=c(e),g=f.hasClass("open");if(b(),!g){if("ontouchstart"in document.documentElement&&!f.closest(".navbar-nav").length&&a('<div class="dropdown-backdrop"/>').insertAfter(a(this)).on("click",b),f.trigger(d=a.Event("show.bs.dropdown")),d.isDefaultPrevented())return;f.toggleClass("open").trigger("shown.bs.dropdown"),e.focus()}return!1}},f.prototype.keydown=function(b){if(/(38|40|27)/.test(b.keyCode)){var d=a(this);if(b.preventDefault(),b.stopPropagation(),!d.is(".disabled, :disabled")){var f=c(d),g=f.hasClass("open");if(!g||g&&27==b.keyCode)return 27==b.which&&f.find(e).focus(),d.click();var h=a("[role=menu] li:not(.divider):visible a",f);if(h.length){var i=h.index(h.filter(":focus"));38==b.keyCode&&i>0&&i--,40==b.keyCode&&i<h.length-1&&i++,~i||(i=0),h.eq(i).focus()}}}};var g=a.fn.dropdown;a.fn.dropdown=function(b){return this.each(function(){var c=a(this),d=c.data("dropdown");d||c.data("dropdown",d=new f(this)),"string"==typeof b&&d[b].call(c)})},a.fn.dropdown.Constructor=f,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=g,this},a(document).on("click.bs.dropdown.data-api",b).on("click.bs.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.bs.dropdown.data-api",e,f.prototype.toggle).on("keydown.bs.dropdown.data-api",e+", [role=menu]",f.prototype.keydown)}(jQuery),+function(a){"use strict";var b=function(b,c){this.options=c,this.$element=a(b),this.$backdrop=this.isShown=null,this.options.remote&&this.$element.load(this.options.remote)};b.DEFAULTS={backdrop:!0,keyboard:!0,show:!0},b.prototype.toggle=function(a){return this[this.isShown?"hide":"show"](a)},b.prototype.show=function(b){var c=this,d=a.Event("show.bs.modal",{relatedTarget:b});this.$element.trigger(d),this.isShown||d.isDefaultPrevented()||(this.isShown=!0,this.escape(),this.$element.on("click.dismiss.modal",'[data-dismiss="modal"]',a.proxy(this.hide,this)),this.backdrop(function(){var d=a.support.transition&&c.$element.hasClass("fade");c.$element.parent().length||c.$element.appendTo(document.body),c.$element.show(),d&&c.$element[0].offsetWidth,c.$element.addClass("in").attr("aria-hidden",!1),c.enforceFocus();var e=a.Event("shown.bs.modal",{relatedTarget:b});d?c.$element.find(".modal-dialog").one(a.support.transition.end,function(){c.$element.focus().trigger(e)}).emulateTransitionEnd(300):c.$element.focus().trigger(e)}))},b.prototype.hide=function(b){b&&b.preventDefault(),b=a.Event("hide.bs.modal"),this.$element.trigger(b),this.isShown&&!b.isDefaultPrevented()&&(this.isShown=!1,this.escape(),a(document).off("focusin.bs.modal"),this.$element.removeClass("in").attr("aria-hidden",!0).off("click.dismiss.modal"),a.support.transition&&this.$element.hasClass("fade")?this.$element.one(a.support.transition.end,a.proxy(this.hideModal,this)).emulateTransitionEnd(300):this.hideModal())},b.prototype.enforceFocus=function(){a(document).off("focusin.bs.modal").on("focusin.bs.modal",a.proxy(function(a){this.$element[0]===a.target||this.$element.has(a.target).length||this.$element.focus()},this))},b.prototype.escape=function(){this.isShown&&this.options.keyboard?this.$element.on("keyup.dismiss.bs.modal",a.proxy(function(a){27==a.which&&this.hide()},this)):this.isShown||this.$element.off("keyup.dismiss.bs.modal")},b.prototype.hideModal=function(){var a=this;this.$element.hide(),this.backdrop(function(){a.removeBackdrop(),a.$element.trigger("hidden.bs.modal")})},b.prototype.removeBackdrop=function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},b.prototype.backdrop=function(b){var c=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var d=a.support.transition&&c;if(this.$backdrop=a('<div class="modal-backdrop '+c+'" />').appendTo(document.body),this.$element.on("click.dismiss.modal",a.proxy(function(a){a.target===a.currentTarget&&("static"==this.options.backdrop?this.$element[0].focus.call(this.$element[0]):this.hide.call(this))},this)),d&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in"),!b)return;d?this.$backdrop.one(a.support.transition.end,b).emulateTransitionEnd(150):b()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(a.support.transition.end,b).emulateTransitionEnd(150):b()):b&&b()};var c=a.fn.modal;a.fn.modal=function(c,d){return this.each(function(){var e=a(this),f=e.data("bs.modal"),g=a.extend({},b.DEFAULTS,e.data(),"object"==typeof c&&c);f||e.data("bs.modal",f=new b(this,g)),"string"==typeof c?f[c](d):g.show&&f.show(d)})},a.fn.modal.Constructor=b,a.fn.modal.noConflict=function(){return a.fn.modal=c,this},a(document).on("click.bs.modal.data-api",'[data-toggle="modal"]',function(b){var c=a(this),d=c.attr("href"),e=a(c.attr("data-target")||d&&d.replace(/.*(?=#[^\s]+$)/,"")),f=e.data("modal")?"toggle":a.extend({remote:!/#/.test(d)&&d},e.data(),c.data());b.preventDefault(),e.modal(f,this).one("hide",function(){c.is(":visible")&&c.focus()})}),a(document).on("show.bs.modal",".modal",function(){a(document.body).addClass("modal-open")}).on("hidden.bs.modal",".modal",function(){a(document.body).removeClass("modal-open")})}(jQuery),+function(a){"use strict";var b=function(a,b){this.type=this.options=this.enabled=this.timeout=this.hoverState=this.$element=null,this.init("tooltip",a,b)};b.DEFAULTS={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1},b.prototype.init=function(b,c,d){this.enabled=!0,this.type=b,this.$element=a(c),this.options=this.getOptions(d);for(var e=this.options.trigger.split(" "),f=e.length;f--;){var g=e[f];if("click"==g)this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this));else if("manual"!=g){var h="hover"==g?"mouseenter":"focus",i="hover"==g?"mouseleave":"blur";this.$element.on(h+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(i+"."+this.type,this.options.selector,a.proxy(this.leave,this))}}this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},b.prototype.getDefaults=function(){return b.DEFAULTS},b.prototype.getOptions=function(b){return b=a.extend({},this.getDefaults(),this.$element.data(),b),b.delay&&"number"==typeof b.delay&&(b.delay={show:b.delay,hide:b.delay}),b},b.prototype.getDelegateOptions=function(){var b={},c=this.getDefaults();return this._options&&a.each(this._options,function(a,d){c[a]!=d&&(b[a]=d)}),b},b.prototype.enter=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget)[this.type](this.getDelegateOptions()).data("bs."+this.type);return clearTimeout(c.timeout),c.hoverState="in",c.options.delay&&c.options.delay.show?(c.timeout=setTimeout(function(){"in"==c.hoverState&&c.show()},c.options.delay.show),void 0):c.show()},b.prototype.leave=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget)[this.type](this.getDelegateOptions()).data("bs."+this.type);return clearTimeout(c.timeout),c.hoverState="out",c.options.delay&&c.options.delay.hide?(c.timeout=setTimeout(function(){"out"==c.hoverState&&c.hide()},c.options.delay.hide),void 0):c.hide()},b.prototype.show=function(){var b=a.Event("show.bs."+this.type);if(this.hasContent()&&this.enabled){if(this.$element.trigger(b),b.isDefaultPrevented())return;var c=this.tip();this.setContent(),this.options.animation&&c.addClass("fade");var d="function"==typeof this.options.placement?this.options.placement.call(this,c[0],this.$element[0]):this.options.placement,e=/\s?auto?\s?/i,f=e.test(d);f&&(d=d.replace(e,"")||"top"),c.detach().css({top:0,left:0,display:"block"}).addClass(d),this.options.container?c.appendTo(this.options.container):c.insertAfter(this.$element);var g=this.getPosition(),h=c[0].offsetWidth,i=c[0].offsetHeight;if(f){var j=this.$element.parent(),k=d,l=document.documentElement.scrollTop||document.body.scrollTop,m="body"==this.options.container?window.innerWidth:j.outerWidth(),n="body"==this.options.container?window.innerHeight:j.outerHeight(),o="body"==this.options.container?0:j.offset().left;d="bottom"==d&&g.top+g.height+i-l>n?"top":"top"==d&&g.top-l-i<0?"bottom":"right"==d&&g.right+h>m?"left":"left"==d&&g.left-h<o?"right":d,c.removeClass(k).addClass(d)}var p=this.getCalculatedOffset(d,g,h,i);this.applyPlacement(p,d),this.$element.trigger("shown.bs."+this.type)}},b.prototype.applyPlacement=function(a,b){var c,d=this.tip(),e=d[0].offsetWidth,f=d[0].offsetHeight,g=parseInt(d.css("margin-top"),10),h=parseInt(d.css("margin-left"),10);isNaN(g)&&(g=0),isNaN(h)&&(h=0),a.top=a.top+g,a.left=a.left+h,d.offset(a).addClass("in");var i=d[0].offsetWidth,j=d[0].offsetHeight;if("top"==b&&j!=f&&(c=!0,a.top=a.top+f-j),/bottom|top/.test(b)){var k=0;a.left<0&&(k=-2*a.left,a.left=0,d.offset(a),i=d[0].offsetWidth,j=d[0].offsetHeight),this.replaceArrow(k-e+i,i,"left")}else this.replaceArrow(j-f,j,"top");c&&d.offset(a)},b.prototype.replaceArrow=function(a,b,c){this.arrow().css(c,a?50*(1-a/b)+"%":"")},b.prototype.setContent=function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},b.prototype.hide=function(){function b(){"in"!=c.hoverState&&d.detach()}var c=this,d=this.tip(),e=a.Event("hide.bs."+this.type);return this.$element.trigger(e),e.isDefaultPrevented()?void 0:(d.removeClass("in"),a.support.transition&&this.$tip.hasClass("fade")?d.one(a.support.transition.end,b).emulateTransitionEnd(150):b(),this.$element.trigger("hidden.bs."+this.type),this)},b.prototype.fixTitle=function(){var a=this.$element;(a.attr("title")||"string"!=typeof a.attr("data-original-title"))&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},b.prototype.hasContent=function(){return this.getTitle()},b.prototype.getPosition=function(){var b=this.$element[0];return a.extend({},"function"==typeof b.getBoundingClientRect?b.getBoundingClientRect():{width:b.offsetWidth,height:b.offsetHeight},this.$element.offset())},b.prototype.getCalculatedOffset=function(a,b,c,d){return"bottom"==a?{top:b.top+b.height,left:b.left+b.width/2-c/2}:"top"==a?{top:b.top-d,left:b.left+b.width/2-c/2}:"left"==a?{top:b.top+b.height/2-d/2,left:b.left-c}:{top:b.top+b.height/2-d/2,left:b.left+b.width}},b.prototype.getTitle=function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||("function"==typeof c.title?c.title.call(b[0]):c.title)},b.prototype.tip=function(){return this.$tip=this.$tip||a(this.options.template)},b.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},b.prototype.validate=function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},b.prototype.enable=function(){this.enabled=!0},b.prototype.disable=function(){this.enabled=!1},b.prototype.toggleEnabled=function(){this.enabled=!this.enabled},b.prototype.toggle=function(b){var c=b?a(b.currentTarget)[this.type](this.getDelegateOptions()).data("bs."+this.type):this;c.tip().hasClass("in")?c.leave(c):c.enter(c)},b.prototype.destroy=function(){this.hide().$element.off("."+this.type).removeData("bs."+this.type)};var c=a.fn.tooltip;a.fn.tooltip=function(c){return this.each(function(){var d=a(this),e=d.data("bs.tooltip"),f="object"==typeof c&&c;e||d.data("bs.tooltip",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.tooltip.Constructor=b,a.fn.tooltip.noConflict=function(){return a.fn.tooltip=c,this}}(jQuery),+function(a){"use strict";var b=function(a,b){this.init("popover",a,b)};if(!a.fn.tooltip)throw new Error("Popover requires tooltip.js");b.DEFAULTS=a.extend({},a.fn.tooltip.Constructor.DEFAULTS,{placement:"right",trigger:"click",content:"",template:'<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),b.prototype=a.extend({},a.fn.tooltip.Constructor.prototype),b.prototype.constructor=b,b.prototype.getDefaults=function(){return b.DEFAULTS},b.prototype.setContent=function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content")[this.options.html?"html":"text"](c),a.removeClass("fade top bottom left right in"),a.find(".popover-title").html()||a.find(".popover-title").hide()},b.prototype.hasContent=function(){return this.getTitle()||this.getContent()},b.prototype.getContent=function(){var a=this.$element,b=this.options;return a.attr("data-content")||("function"==typeof b.content?b.content.call(a[0]):b.content)},b.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".arrow")},b.prototype.tip=function(){return this.$tip||(this.$tip=a(this.options.template)),this.$tip};var c=a.fn.popover;a.fn.popover=function(c){return this.each(function(){var d=a(this),e=d.data("bs.popover"),f="object"==typeof c&&c;e||d.data("bs.popover",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.popover.Constructor=b,a.fn.popover.noConflict=function(){return a.fn.popover=c,this}}(jQuery),+function(a){"use strict";function b(c,d){var e,f=a.proxy(this.process,this);this.$element=a(c).is("body")?a(window):a(c),this.$body=a("body"),this.$scrollElement=this.$element.on("scroll.bs.scroll-spy.data-api",f),this.options=a.extend({},b.DEFAULTS,d),this.selector=(this.options.target||(e=a(c).attr("href"))&&e.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.offsets=a([]),this.targets=a([]),this.activeTarget=null,this.refresh(),this.process()}b.DEFAULTS={offset:10},b.prototype.refresh=function(){var b=this.$element[0]==window?"offset":"position";this.offsets=a([]),this.targets=a([]);var c=this;this.$body.find(this.selector).map(function(){var d=a(this),e=d.data("target")||d.attr("href"),f=/^#\w/.test(e)&&a(e);return f&&f.length&&[[f[b]().top+(!a.isWindow(c.$scrollElement.get(0))&&c.$scrollElement.scrollTop()),e]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){c.offsets.push(this[0]),c.targets.push(this[1])})},b.prototype.process=function(){var a,b=this.$scrollElement.scrollTop()+this.options.offset,c=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,d=c-this.$scrollElement.height(),e=this.offsets,f=this.targets,g=this.activeTarget;if(b>=d)return g!=(a=f.last()[0])&&this.activate(a);for(a=e.length;a--;)g!=f[a]&&b>=e[a]&&(!e[a+1]||b<=e[a+1])&&this.activate(f[a])},b.prototype.activate=function(b){this.activeTarget=b,a(this.selector).parents(".active").removeClass("active");var c=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',d=a(c).parents("li").addClass("active");d.parent(".dropdown-menu").length&&(d=d.closest("li.dropdown").addClass("active")),d.trigger("activate")};var c=a.fn.scrollspy;a.fn.scrollspy=function(c){return this.each(function(){var d=a(this),e=d.data("bs.scrollspy"),f="object"==typeof c&&c;e||d.data("bs.scrollspy",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.scrollspy.Constructor=b,a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=c,this},a(window).on("load",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);b.scrollspy(b.data())})})}(jQuery),+function(a){"use strict";var b=function(b){this.element=a(b)};b.prototype.show=function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.data("target");if(d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),!b.parent("li").hasClass("active")){var e=c.find(".active:last a")[0],f=a.Event("show.bs.tab",{relatedTarget:e});if(b.trigger(f),!f.isDefaultPrevented()){var g=a(d);this.activate(b.parent("li"),c),this.activate(g,g.parent(),function(){b.trigger({type:"shown.bs.tab",relatedTarget:e})})}}},b.prototype.activate=function(b,c,d){function e(){f.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),b.addClass("active"),g?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu")&&b.closest("li.dropdown").addClass("active"),d&&d()}var f=c.find("> .active"),g=d&&a.support.transition&&f.hasClass("fade");g?f.one(a.support.transition.end,e).emulateTransitionEnd(150):e(),f.removeClass("in")};var c=a.fn.tab;a.fn.tab=function(c){return this.each(function(){var d=a(this),e=d.data("bs.tab");e||d.data("bs.tab",e=new b(this)),"string"==typeof c&&e[c]()})},a.fn.tab.Constructor=b,a.fn.tab.noConflict=function(){return a.fn.tab=c,this},a(document).on("click.bs.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(b){b.preventDefault(),a(this).tab("show")})}(jQuery),+function(a){"use strict";var b=function(c,d){this.options=a.extend({},b.DEFAULTS,d),this.$window=a(window).on("scroll.bs.affix.data-api",a.proxy(this.checkPosition,this)).on("click.bs.affix.data-api",a.proxy(this.checkPositionWithEventLoop,this)),this.$element=a(c),this.affixed=this.unpin=null,this.checkPosition()};b.RESET="affix affix-top affix-bottom",b.DEFAULTS={offset:0},b.prototype.checkPositionWithEventLoop=function(){setTimeout(a.proxy(this.checkPosition,this),1)},b.prototype.checkPosition=function(){if(this.$element.is(":visible")){var c=a(document).height(),d=this.$window.scrollTop(),e=this.$element.offset(),f=this.options.offset,g=f.top,h=f.bottom;"object"!=typeof f&&(h=g=f),"function"==typeof g&&(g=f.top()),"function"==typeof h&&(h=f.bottom());var i=null!=this.unpin&&d+this.unpin<=e.top?!1:null!=h&&e.top+this.$element.height()>=c-h?"bottom":null!=g&&g>=d?"top":!1;this.affixed!==i&&(this.unpin&&this.$element.css("top",""),this.affixed=i,this.unpin="bottom"==i?e.top-d:null,this.$element.removeClass(b.RESET).addClass("affix"+(i?"-"+i:"")),"bottom"==i&&this.$element.offset({top:document.body.offsetHeight-h-this.$element.height()}))}};var c=a.fn.affix;a.fn.affix=function(c){return this.each(function(){var d=a(this),e=d.data("bs.affix"),f="object"==typeof c&&c;e||d.data("bs.affix",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.affix.Constructor=b,a.fn.affix.noConflict=function(){return a.fn.affix=c,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var b=a(this),c=b.data();c.offset=c.offset||{},c.offsetBottom&&(c.offset.bottom=c.offsetBottom),c.offsetTop&&(c.offset.top=c.offsetTop),b.affix(c)})})}(jQuery);
    1.14 \ No newline at end of file
    1.15 +if (typeof jQuery === "undefined") { throw new Error("Bootstrap requires jQuery") }
    1.16 +
    1.17 +/* ========================================================================
    1.18 + * Bootstrap: transition.js v3.0.3
    1.19 + * http://getbootstrap.com/javascript/#transitions
    1.20 + * ========================================================================
    1.21 + * Copyright 2013 Twitter, Inc.
    1.22 + *
    1.23 + * Licensed under the Apache License, Version 2.0 (the "License");
    1.24 + * you may not use this file except in compliance with the License.
    1.25 + * You may obtain a copy of the License at
    1.26 + *
    1.27 + * http://www.apache.org/licenses/LICENSE-2.0
    1.28 + *
    1.29 + * Unless required by applicable law or agreed to in writing, software
    1.30 + * distributed under the License is distributed on an "AS IS" BASIS,
    1.31 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    1.32 + * See the License for the specific language governing permissions and
    1.33 + * limitations under the License.
    1.34 + * ======================================================================== */
    1.35 +
    1.36 +
    1.37 ++function ($) { "use strict";
    1.38 +
    1.39 +  // CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
    1.40 +  // ============================================================
    1.41 +
    1.42 +  function transitionEnd() {
    1.43 +    var el = document.createElement('bootstrap')
    1.44 +
    1.45 +    var transEndEventNames = {
    1.46 +      'WebkitTransition' : 'webkitTransitionEnd'
    1.47 +    , 'MozTransition'    : 'transitionend'
    1.48 +    , 'OTransition'      : 'oTransitionEnd otransitionend'
    1.49 +    , 'transition'       : 'transitionend'
    1.50 +    }
    1.51 +
    1.52 +    for (var name in transEndEventNames) {
    1.53 +      if (el.style[name] !== undefined) {
    1.54 +        return { end: transEndEventNames[name] }
    1.55 +      }
    1.56 +    }
    1.57 +  }
    1.58 +
    1.59 +  // http://blog.alexmaccaw.com/css-transitions
    1.60 +  $.fn.emulateTransitionEnd = function (duration) {
    1.61 +    var called = false, $el = this
    1.62 +    $(this).one($.support.transition.end, function () { called = true })
    1.63 +    var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
    1.64 +    setTimeout(callback, duration)
    1.65 +    return this
    1.66 +  }
    1.67 +
    1.68 +  $(function () {
    1.69 +    $.support.transition = transitionEnd()
    1.70 +  })
    1.71 +
    1.72 +}(jQuery);
    1.73 +
    1.74 +/* ========================================================================
    1.75 + * Bootstrap: alert.js v3.0.3
    1.76 + * http://getbootstrap.com/javascript/#alerts
    1.77 + * ========================================================================
    1.78 + * Copyright 2013 Twitter, Inc.
    1.79 + *
    1.80 + * Licensed under the Apache License, Version 2.0 (the "License");
    1.81 + * you may not use this file except in compliance with the License.
    1.82 + * You may obtain a copy of the License at
    1.83 + *
    1.84 + * http://www.apache.org/licenses/LICENSE-2.0
    1.85 + *
    1.86 + * Unless required by applicable law or agreed to in writing, software
    1.87 + * distributed under the License is distributed on an "AS IS" BASIS,
    1.88 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    1.89 + * See the License for the specific language governing permissions and
    1.90 + * limitations under the License.
    1.91 + * ======================================================================== */
    1.92 +
    1.93 +
    1.94 ++function ($) { "use strict";
    1.95 +
    1.96 +  // ALERT CLASS DEFINITION
    1.97 +  // ======================
    1.98 +
    1.99 +  var dismiss = '[data-dismiss="alert"]'
   1.100 +  var Alert   = function (el) {
   1.101 +    $(el).on('click', dismiss, this.close)
   1.102 +  }
   1.103 +
   1.104 +  Alert.prototype.close = function (e) {
   1.105 +    var $this    = $(this)
   1.106 +    var selector = $this.attr('data-target')
   1.107 +
   1.108 +    if (!selector) {
   1.109 +      selector = $this.attr('href')
   1.110 +      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
   1.111 +    }
   1.112 +
   1.113 +    var $parent = $(selector)
   1.114 +
   1.115 +    if (e) e.preventDefault()
   1.116 +
   1.117 +    if (!$parent.length) {
   1.118 +      $parent = $this.hasClass('alert') ? $this : $this.parent()
   1.119 +    }
   1.120 +
   1.121 +    $parent.trigger(e = $.Event('close.bs.alert'))
   1.122 +
   1.123 +    if (e.isDefaultPrevented()) return
   1.124 +
   1.125 +    $parent.removeClass('in')
   1.126 +
   1.127 +    function removeElement() {
   1.128 +      $parent.trigger('closed.bs.alert').remove()
   1.129 +    }
   1.130 +
   1.131 +    $.support.transition && $parent.hasClass('fade') ?
   1.132 +      $parent
   1.133 +        .one($.support.transition.end, removeElement)
   1.134 +        .emulateTransitionEnd(150) :
   1.135 +      removeElement()
   1.136 +  }
   1.137 +
   1.138 +
   1.139 +  // ALERT PLUGIN DEFINITION
   1.140 +  // =======================
   1.141 +
   1.142 +  var old = $.fn.alert
   1.143 +
   1.144 +  $.fn.alert = function (option) {
   1.145 +    return this.each(function () {
   1.146 +      var $this = $(this)
   1.147 +      var data  = $this.data('bs.alert')
   1.148 +
   1.149 +      if (!data) $this.data('bs.alert', (data = new Alert(this)))
   1.150 +      if (typeof option == 'string') data[option].call($this)
   1.151 +    })
   1.152 +  }
   1.153 +
   1.154 +  $.fn.alert.Constructor = Alert
   1.155 +
   1.156 +
   1.157 +  // ALERT NO CONFLICT
   1.158 +  // =================
   1.159 +
   1.160 +  $.fn.alert.noConflict = function () {
   1.161 +    $.fn.alert = old
   1.162 +    return this
   1.163 +  }
   1.164 +
   1.165 +
   1.166 +  // ALERT DATA-API
   1.167 +  // ==============
   1.168 +
   1.169 +  $(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close)
   1.170 +
   1.171 +}(jQuery);
   1.172 +
   1.173 +/* ========================================================================
   1.174 + * Bootstrap: button.js v3.0.3
   1.175 + * http://getbootstrap.com/javascript/#buttons
   1.176 + * ========================================================================
   1.177 + * Copyright 2013 Twitter, Inc.
   1.178 + *
   1.179 + * Licensed under the Apache License, Version 2.0 (the "License");
   1.180 + * you may not use this file except in compliance with the License.
   1.181 + * You may obtain a copy of the License at
   1.182 + *
   1.183 + * http://www.apache.org/licenses/LICENSE-2.0
   1.184 + *
   1.185 + * Unless required by applicable law or agreed to in writing, software
   1.186 + * distributed under the License is distributed on an "AS IS" BASIS,
   1.187 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   1.188 + * See the License for the specific language governing permissions and
   1.189 + * limitations under the License.
   1.190 + * ======================================================================== */
   1.191 +
   1.192 +
   1.193 ++function ($) { "use strict";
   1.194 +
   1.195 +  // BUTTON PUBLIC CLASS DEFINITION
   1.196 +  // ==============================
   1.197 +
   1.198 +  var Button = function (element, options) {
   1.199 +    this.$element = $(element)
   1.200 +    this.options  = $.extend({}, Button.DEFAULTS, options)
   1.201 +  }
   1.202 +
   1.203 +  Button.DEFAULTS = {
   1.204 +    loadingText: 'loading...'
   1.205 +  }
   1.206 +
   1.207 +  Button.prototype.setState = function (state) {
   1.208 +    var d    = 'disabled'
   1.209 +    var $el  = this.$element
   1.210 +    var val  = $el.is('input') ? 'val' : 'html'
   1.211 +    var data = $el.data()
   1.212 +
   1.213 +    state = state + 'Text'
   1.214 +
   1.215 +    if (!data.resetText) $el.data('resetText', $el[val]())
   1.216 +
   1.217 +    $el[val](data[state] || this.options[state])
   1.218 +
   1.219 +    // push to event loop to allow forms to submit
   1.220 +    setTimeout(function () {
   1.221 +      state == 'loadingText' ?
   1.222 +        $el.addClass(d).attr(d, d) :
   1.223 +        $el.removeClass(d).removeAttr(d);
   1.224 +    }, 0)
   1.225 +  }
   1.226 +
   1.227 +  Button.prototype.toggle = function () {
   1.228 +    var $parent = this.$element.closest('[data-toggle="buttons"]')
   1.229 +    var changed = true
   1.230 +
   1.231 +    if ($parent.length) {
   1.232 +      var $input = this.$element.find('input')
   1.233 +      if ($input.prop('type') === 'radio') {
   1.234 +        // see if clicking on current one
   1.235 +        if ($input.prop('checked') && this.$element.hasClass('active'))
   1.236 +          changed = false
   1.237 +        else
   1.238 +          $parent.find('.active').removeClass('active')
   1.239 +      }
   1.240 +      if (changed) $input.prop('checked', !this.$element.hasClass('active')).trigger('change')
   1.241 +    }
   1.242 +
   1.243 +    if (changed) this.$element.toggleClass('active')
   1.244 +  }
   1.245 +
   1.246 +
   1.247 +  // BUTTON PLUGIN DEFINITION
   1.248 +  // ========================
   1.249 +
   1.250 +  var old = $.fn.button
   1.251 +
   1.252 +  $.fn.button = function (option) {
   1.253 +    return this.each(function () {
   1.254 +      var $this   = $(this)
   1.255 +      var data    = $this.data('bs.button')
   1.256 +      var options = typeof option == 'object' && option
   1.257 +
   1.258 +      if (!data) $this.data('bs.button', (data = new Button(this, options)))
   1.259 +
   1.260 +      if (option == 'toggle') data.toggle()
   1.261 +      else if (option) data.setState(option)
   1.262 +    })
   1.263 +  }
   1.264 +
   1.265 +  $.fn.button.Constructor = Button
   1.266 +
   1.267 +
   1.268 +  // BUTTON NO CONFLICT
   1.269 +  // ==================
   1.270 +
   1.271 +  $.fn.button.noConflict = function () {
   1.272 +    $.fn.button = old
   1.273 +    return this
   1.274 +  }
   1.275 +
   1.276 +
   1.277 +  // BUTTON DATA-API
   1.278 +  // ===============
   1.279 +
   1.280 +  $(document).on('click.bs.button.data-api', '[data-toggle^=button]', function (e) {
   1.281 +    var $btn = $(e.target)
   1.282 +    if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
   1.283 +    $btn.button('toggle')
   1.284 +    e.preventDefault()
   1.285 +  })
   1.286 +
   1.287 +}(jQuery);
   1.288 +
   1.289 +/* ========================================================================
   1.290 + * Bootstrap: carousel.js v3.0.3
   1.291 + * http://getbootstrap.com/javascript/#carousel
   1.292 + * ========================================================================
   1.293 + * Copyright 2013 Twitter, Inc.
   1.294 + *
   1.295 + * Licensed under the Apache License, Version 2.0 (the "License");
   1.296 + * you may not use this file except in compliance with the License.
   1.297 + * You may obtain a copy of the License at
   1.298 + *
   1.299 + * http://www.apache.org/licenses/LICENSE-2.0
   1.300 + *
   1.301 + * Unless required by applicable law or agreed to in writing, software
   1.302 + * distributed under the License is distributed on an "AS IS" BASIS,
   1.303 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   1.304 + * See the License for the specific language governing permissions and
   1.305 + * limitations under the License.
   1.306 + * ======================================================================== */
   1.307 +
   1.308 +
   1.309 ++function ($) { "use strict";
   1.310 +
   1.311 +  // CAROUSEL CLASS DEFINITION
   1.312 +  // =========================
   1.313 +
   1.314 +  var Carousel = function (element, options) {
   1.315 +    this.$element    = $(element)
   1.316 +    this.$indicators = this.$element.find('.carousel-indicators')
   1.317 +    this.options     = options
   1.318 +    this.paused      =
   1.319 +    this.sliding     =
   1.320 +    this.interval    =
   1.321 +    this.$active     =
   1.322 +    this.$items      = null
   1.323 +
   1.324 +    this.options.pause == 'hover' && this.$element
   1.325 +      .on('mouseenter', $.proxy(this.pause, this))
   1.326 +      .on('mouseleave', $.proxy(this.cycle, this))
   1.327 +  }
   1.328 +
   1.329 +  Carousel.DEFAULTS = {
   1.330 +    interval: 5000
   1.331 +  , pause: 'hover'
   1.332 +  , wrap: true
   1.333 +  }
   1.334 +
   1.335 +  Carousel.prototype.cycle =  function (e) {
   1.336 +    e || (this.paused = false)
   1.337 +
   1.338 +    this.interval && clearInterval(this.interval)
   1.339 +
   1.340 +    this.options.interval
   1.341 +      && !this.paused
   1.342 +      && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
   1.343 +
   1.344 +    return this
   1.345 +  }
   1.346 +
   1.347 +  Carousel.prototype.getActiveIndex = function () {
   1.348 +    this.$active = this.$element.find('.item.active')
   1.349 +    this.$items  = this.$active.parent().children()
   1.350 +
   1.351 +    return this.$items.index(this.$active)
   1.352 +  }
   1.353 +
   1.354 +  Carousel.prototype.to = function (pos) {
   1.355 +    var that        = this
   1.356 +    var activeIndex = this.getActiveIndex()
   1.357 +
   1.358 +    if (pos > (this.$items.length - 1) || pos < 0) return
   1.359 +
   1.360 +    if (this.sliding)       return this.$element.one('slid.bs.carousel', function () { that.to(pos) })
   1.361 +    if (activeIndex == pos) return this.pause().cycle()
   1.362 +
   1.363 +    return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))
   1.364 +  }
   1.365 +
   1.366 +  Carousel.prototype.pause = function (e) {
   1.367 +    e || (this.paused = true)
   1.368 +
   1.369 +    if (this.$element.find('.next, .prev').length && $.support.transition.end) {
   1.370 +      this.$element.trigger($.support.transition.end)
   1.371 +      this.cycle(true)
   1.372 +    }
   1.373 +
   1.374 +    this.interval = clearInterval(this.interval)
   1.375 +
   1.376 +    return this
   1.377 +  }
   1.378 +
   1.379 +  Carousel.prototype.next = function () {
   1.380 +    if (this.sliding) return
   1.381 +    return this.slide('next')
   1.382 +  }
   1.383 +
   1.384 +  Carousel.prototype.prev = function () {
   1.385 +    if (this.sliding) return
   1.386 +    return this.slide('prev')
   1.387 +  }
   1.388 +
   1.389 +  Carousel.prototype.slide = function (type, next) {
   1.390 +    var $active   = this.$element.find('.item.active')
   1.391 +    var $next     = next || $active[type]()
   1.392 +    var isCycling = this.interval
   1.393 +    var direction = type == 'next' ? 'left' : 'right'
   1.394 +    var fallback  = type == 'next' ? 'first' : 'last'
   1.395 +    var that      = this
   1.396 +
   1.397 +    if (!$next.length) {
   1.398 +      if (!this.options.wrap) return
   1.399 +      $next = this.$element.find('.item')[fallback]()
   1.400 +    }
   1.401 +
   1.402 +    this.sliding = true
   1.403 +
   1.404 +    isCycling && this.pause()
   1.405 +
   1.406 +    var e = $.Event('slide.bs.carousel', { relatedTarget: $next[0], direction: direction })
   1.407 +
   1.408 +    if ($next.hasClass('active')) return
   1.409 +
   1.410 +    if (this.$indicators.length) {
   1.411 +      this.$indicators.find('.active').removeClass('active')
   1.412 +      this.$element.one('slid.bs.carousel', function () {
   1.413 +        var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()])
   1.414 +        $nextIndicator && $nextIndicator.addClass('active')
   1.415 +      })
   1.416 +    }
   1.417 +
   1.418 +    if ($.support.transition && this.$element.hasClass('slide')) {
   1.419 +      this.$element.trigger(e)
   1.420 +      if (e.isDefaultPrevented()) return
   1.421 +      $next.addClass(type)
   1.422 +      $next[0].offsetWidth // force reflow
   1.423 +      $active.addClass(direction)
   1.424 +      $next.addClass(direction)
   1.425 +      $active
   1.426 +        .one($.support.transition.end, function () {
   1.427 +          $next.removeClass([type, direction].join(' ')).addClass('active')
   1.428 +          $active.removeClass(['active', direction].join(' '))
   1.429 +          that.sliding = false
   1.430 +          setTimeout(function () { that.$element.trigger('slid.bs.carousel') }, 0)
   1.431 +        })
   1.432 +        .emulateTransitionEnd(600)
   1.433 +    } else {
   1.434 +      this.$element.trigger(e)
   1.435 +      if (e.isDefaultPrevented()) return
   1.436 +      $active.removeClass('active')
   1.437 +      $next.addClass('active')
   1.438 +      this.sliding = false
   1.439 +      this.$element.trigger('slid.bs.carousel')
   1.440 +    }
   1.441 +
   1.442 +    isCycling && this.cycle()
   1.443 +
   1.444 +    return this
   1.445 +  }
   1.446 +
   1.447 +
   1.448 +  // CAROUSEL PLUGIN DEFINITION
   1.449 +  // ==========================
   1.450 +
   1.451 +  var old = $.fn.carousel
   1.452 +
   1.453 +  $.fn.carousel = function (option) {
   1.454 +    return this.each(function () {
   1.455 +      var $this   = $(this)
   1.456 +      var data    = $this.data('bs.carousel')
   1.457 +      var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option)
   1.458 +      var action  = typeof option == 'string' ? option : options.slide
   1.459 +
   1.460 +      if (!data) $this.data('bs.carousel', (data = new Carousel(this, options)))
   1.461 +      if (typeof option == 'number') data.to(option)
   1.462 +      else if (action) data[action]()
   1.463 +      else if (options.interval) data.pause().cycle()
   1.464 +    })
   1.465 +  }
   1.466 +
   1.467 +  $.fn.carousel.Constructor = Carousel
   1.468 +
   1.469 +
   1.470 +  // CAROUSEL NO CONFLICT
   1.471 +  // ====================
   1.472 +
   1.473 +  $.fn.carousel.noConflict = function () {
   1.474 +    $.fn.carousel = old
   1.475 +    return this
   1.476 +  }
   1.477 +
   1.478 +
   1.479 +  // CAROUSEL DATA-API
   1.480 +  // =================
   1.481 +
   1.482 +  $(document).on('click.bs.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {
   1.483 +    var $this   = $(this), href
   1.484 +    var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
   1.485 +    var options = $.extend({}, $target.data(), $this.data())
   1.486 +    var slideIndex = $this.attr('data-slide-to')
   1.487 +    if (slideIndex) options.interval = false
   1.488 +
   1.489 +    $target.carousel(options)
   1.490 +
   1.491 +    if (slideIndex = $this.attr('data-slide-to')) {
   1.492 +      $target.data('bs.carousel').to(slideIndex)
   1.493 +    }
   1.494 +
   1.495 +    e.preventDefault()
   1.496 +  })
   1.497 +
   1.498 +  $(window).on('load', function () {
   1.499 +    $('[data-ride="carousel"]').each(function () {
   1.500 +      var $carousel = $(this)
   1.501 +      $carousel.carousel($carousel.data())
   1.502 +    })
   1.503 +  })
   1.504 +
   1.505 +}(jQuery);
   1.506 +
   1.507 +/* ========================================================================
   1.508 + * Bootstrap: collapse.js v3.0.3
   1.509 + * http://getbootstrap.com/javascript/#collapse
   1.510 + * ========================================================================
   1.511 + * Copyright 2013 Twitter, Inc.
   1.512 + *
   1.513 + * Licensed under the Apache License, Version 2.0 (the "License");
   1.514 + * you may not use this file except in compliance with the License.
   1.515 + * You may obtain a copy of the License at
   1.516 + *
   1.517 + * http://www.apache.org/licenses/LICENSE-2.0
   1.518 + *
   1.519 + * Unless required by applicable law or agreed to in writing, software
   1.520 + * distributed under the License is distributed on an "AS IS" BASIS,
   1.521 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   1.522 + * See the License for the specific language governing permissions and
   1.523 + * limitations under the License.
   1.524 + * ======================================================================== */
   1.525 +
   1.526 +
   1.527 ++function ($) { "use strict";
   1.528 +
   1.529 +  // COLLAPSE PUBLIC CLASS DEFINITION
   1.530 +  // ================================
   1.531 +
   1.532 +  var Collapse = function (element, options) {
   1.533 +    this.$element      = $(element)
   1.534 +    this.options       = $.extend({}, Collapse.DEFAULTS, options)
   1.535 +    this.transitioning = null
   1.536 +
   1.537 +    if (this.options.parent) this.$parent = $(this.options.parent)
   1.538 +    if (this.options.toggle) this.toggle()
   1.539 +  }
   1.540 +
   1.541 +  Collapse.DEFAULTS = {
   1.542 +    toggle: true
   1.543 +  }
   1.544 +
   1.545 +  Collapse.prototype.dimension = function () {
   1.546 +    var hasWidth = this.$element.hasClass('width')
   1.547 +    return hasWidth ? 'width' : 'height'
   1.548 +  }
   1.549 +
   1.550 +  Collapse.prototype.show = function () {
   1.551 +    if (this.transitioning || this.$element.hasClass('in')) return
   1.552 +
   1.553 +    var startEvent = $.Event('show.bs.collapse')
   1.554 +    this.$element.trigger(startEvent)
   1.555 +    if (startEvent.isDefaultPrevented()) return
   1.556 +
   1.557 +    var actives = this.$parent && this.$parent.find('> .panel > .in')
   1.558 +
   1.559 +    if (actives && actives.length) {
   1.560 +      var hasData = actives.data('bs.collapse')
   1.561 +      if (hasData && hasData.transitioning) return
   1.562 +      actives.collapse('hide')
   1.563 +      hasData || actives.data('bs.collapse', null)
   1.564 +    }
   1.565 +
   1.566 +    var dimension = this.dimension()
   1.567 +
   1.568 +    this.$element
   1.569 +      .removeClass('collapse')
   1.570 +      .addClass('collapsing')
   1.571 +      [dimension](0)
   1.572 +
   1.573 +    this.transitioning = 1
   1.574 +
   1.575 +    var complete = function () {
   1.576 +      this.$element
   1.577 +        .removeClass('collapsing')
   1.578 +        .addClass('in')
   1.579 +        [dimension]('auto')
   1.580 +      this.transitioning = 0
   1.581 +      this.$element.trigger('shown.bs.collapse')
   1.582 +    }
   1.583 +
   1.584 +    if (!$.support.transition) return complete.call(this)
   1.585 +
   1.586 +    var scrollSize = $.camelCase(['scroll', dimension].join('-'))
   1.587 +
   1.588 +    this.$element
   1.589 +      .one($.support.transition.end, $.proxy(complete, this))
   1.590 +      .emulateTransitionEnd(350)
   1.591 +      [dimension](this.$element[0][scrollSize])
   1.592 +  }
   1.593 +
   1.594 +  Collapse.prototype.hide = function () {
   1.595 +    if (this.transitioning || !this.$element.hasClass('in')) return
   1.596 +
   1.597 +    var startEvent = $.Event('hide.bs.collapse')
   1.598 +    this.$element.trigger(startEvent)
   1.599 +    if (startEvent.isDefaultPrevented()) return
   1.600 +
   1.601 +    var dimension = this.dimension()
   1.602 +
   1.603 +    this.$element
   1.604 +      [dimension](this.$element[dimension]())
   1.605 +      [0].offsetHeight
   1.606 +
   1.607 +    this.$element
   1.608 +      .addClass('collapsing')
   1.609 +      .removeClass('collapse')
   1.610 +      .removeClass('in')
   1.611 +
   1.612 +    this.transitioning = 1
   1.613 +
   1.614 +    var complete = function () {
   1.615 +      this.transitioning = 0
   1.616 +      this.$element
   1.617 +        .trigger('hidden.bs.collapse')
   1.618 +        .removeClass('collapsing')
   1.619 +        .addClass('collapse')
   1.620 +    }
   1.621 +
   1.622 +    if (!$.support.transition) return complete.call(this)
   1.623 +
   1.624 +    this.$element
   1.625 +      [dimension](0)
   1.626 +      .one($.support.transition.end, $.proxy(complete, this))
   1.627 +      .emulateTransitionEnd(350)
   1.628 +  }
   1.629 +
   1.630 +  Collapse.prototype.toggle = function () {
   1.631 +    this[this.$element.hasClass('in') ? 'hide' : 'show']()
   1.632 +  }
   1.633 +
   1.634 +
   1.635 +  // COLLAPSE PLUGIN DEFINITION
   1.636 +  // ==========================
   1.637 +
   1.638 +  var old = $.fn.collapse
   1.639 +
   1.640 +  $.fn.collapse = function (option) {
   1.641 +    return this.each(function () {
   1.642 +      var $this   = $(this)
   1.643 +      var data    = $this.data('bs.collapse')
   1.644 +      var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
   1.645 +
   1.646 +      if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
   1.647 +      if (typeof option == 'string') data[option]()
   1.648 +    })
   1.649 +  }
   1.650 +
   1.651 +  $.fn.collapse.Constructor = Collapse
   1.652 +
   1.653 +
   1.654 +  // COLLAPSE NO CONFLICT
   1.655 +  // ====================
   1.656 +
   1.657 +  $.fn.collapse.noConflict = function () {
   1.658 +    $.fn.collapse = old
   1.659 +    return this
   1.660 +  }
   1.661 +
   1.662 +
   1.663 +  // COLLAPSE DATA-API
   1.664 +  // =================
   1.665 +
   1.666 +  $(document).on('click.bs.collapse.data-api', '[data-toggle=collapse]', function (e) {
   1.667 +    var $this   = $(this), href
   1.668 +    var target  = $this.attr('data-target')
   1.669 +        || e.preventDefault()
   1.670 +        || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
   1.671 +    var $target = $(target)
   1.672 +    var data    = $target.data('bs.collapse')
   1.673 +    var option  = data ? 'toggle' : $this.data()
   1.674 +    var parent  = $this.attr('data-parent')
   1.675 +    var $parent = parent && $(parent)
   1.676 +
   1.677 +    if (!data || !data.transitioning) {
   1.678 +      if ($parent) $parent.find('[data-toggle=collapse][data-parent="' + parent + '"]').not($this).addClass('collapsed')
   1.679 +      $this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
   1.680 +    }
   1.681 +
   1.682 +    $target.collapse(option)
   1.683 +  })
   1.684 +
   1.685 +}(jQuery);
   1.686 +
   1.687 +/* ========================================================================
   1.688 + * Bootstrap: dropdown.js v3.0.3
   1.689 + * http://getbootstrap.com/javascript/#dropdowns
   1.690 + * ========================================================================
   1.691 + * Copyright 2013 Twitter, Inc.
   1.692 + *
   1.693 + * Licensed under the Apache License, Version 2.0 (the "License");
   1.694 + * you may not use this file except in compliance with the License.
   1.695 + * You may obtain a copy of the License at
   1.696 + *
   1.697 + * http://www.apache.org/licenses/LICENSE-2.0
   1.698 + *
   1.699 + * Unless required by applicable law or agreed to in writing, software
   1.700 + * distributed under the License is distributed on an "AS IS" BASIS,
   1.701 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   1.702 + * See the License for the specific language governing permissions and
   1.703 + * limitations under the License.
   1.704 + * ======================================================================== */
   1.705 +
   1.706 +
   1.707 ++function ($) { "use strict";
   1.708 +
   1.709 +  // DROPDOWN CLASS DEFINITION
   1.710 +  // =========================
   1.711 +
   1.712 +  var backdrop = '.dropdown-backdrop'
   1.713 +  var toggle   = '[data-toggle=dropdown]'
   1.714 +  var Dropdown = function (element) {
   1.715 +    $(element).on('click.bs.dropdown', this.toggle)
   1.716 +  }
   1.717 +
   1.718 +  Dropdown.prototype.toggle = function (e) {
   1.719 +    var $this = $(this)
   1.720 +
   1.721 +    if ($this.is('.disabled, :disabled')) return
   1.722 +
   1.723 +    var $parent  = getParent($this)
   1.724 +    var isActive = $parent.hasClass('open')
   1.725 +
   1.726 +    clearMenus()
   1.727 +
   1.728 +    if (!isActive) {
   1.729 +      if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
   1.730 +        // if mobile we use a backdrop because click events don't delegate
   1.731 +        $('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus)
   1.732 +      }
   1.733 +
   1.734 +      $parent.trigger(e = $.Event('show.bs.dropdown'))
   1.735 +
   1.736 +      if (e.isDefaultPrevented()) return
   1.737 +
   1.738 +      $parent
   1.739 +        .toggleClass('open')
   1.740 +        .trigger('shown.bs.dropdown')
   1.741 +
   1.742 +      $this.focus()
   1.743 +    }
   1.744 +
   1.745 +    return false
   1.746 +  }
   1.747 +
   1.748 +  Dropdown.prototype.keydown = function (e) {
   1.749 +    if (!/(38|40|27)/.test(e.keyCode)) return
   1.750 +
   1.751 +    var $this = $(this)
   1.752 +
   1.753 +    e.preventDefault()
   1.754 +    e.stopPropagation()
   1.755 +
   1.756 +    if ($this.is('.disabled, :disabled')) return
   1.757 +
   1.758 +    var $parent  = getParent($this)
   1.759 +    var isActive = $parent.hasClass('open')
   1.760 +
   1.761 +    if (!isActive || (isActive && e.keyCode == 27)) {
   1.762 +      if (e.which == 27) $parent.find(toggle).focus()
   1.763 +      return $this.click()
   1.764 +    }
   1.765 +
   1.766 +    var $items = $('[role=menu] li:not(.divider):visible a', $parent)
   1.767 +
   1.768 +    if (!$items.length) return
   1.769 +
   1.770 +    var index = $items.index($items.filter(':focus'))
   1.771 +
   1.772 +    if (e.keyCode == 38 && index > 0)                 index--                        // up
   1.773 +    if (e.keyCode == 40 && index < $items.length - 1) index++                        // down
   1.774 +    if (!~index)                                      index=0
   1.775 +
   1.776 +    $items.eq(index).focus()
   1.777 +  }
   1.778 +
   1.779 +  function clearMenus() {
   1.780 +    $(backdrop).remove()
   1.781 +    $(toggle).each(function (e) {
   1.782 +      var $parent = getParent($(this))
   1.783 +      if (!$parent.hasClass('open')) return
   1.784 +      $parent.trigger(e = $.Event('hide.bs.dropdown'))
   1.785 +      if (e.isDefaultPrevented()) return
   1.786 +      $parent.removeClass('open').trigger('hidden.bs.dropdown')
   1.787 +    })
   1.788 +  }
   1.789 +
   1.790 +  function getParent($this) {
   1.791 +    var selector = $this.attr('data-target')
   1.792 +
   1.793 +    if (!selector) {
   1.794 +      selector = $this.attr('href')
   1.795 +      selector = selector && /#/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
   1.796 +    }
   1.797 +
   1.798 +    var $parent = selector && $(selector)
   1.799 +
   1.800 +    return $parent && $parent.length ? $parent : $this.parent()
   1.801 +  }
   1.802 +
   1.803 +
   1.804 +  // DROPDOWN PLUGIN DEFINITION
   1.805 +  // ==========================
   1.806 +
   1.807 +  var old = $.fn.dropdown
   1.808 +
   1.809 +  $.fn.dropdown = function (option) {
   1.810 +    return this.each(function () {
   1.811 +      var $this = $(this)
   1.812 +      var data  = $this.data('bs.dropdown')
   1.813 +
   1.814 +      if (!data) $this.data('bs.dropdown', (data = new Dropdown(this)))
   1.815 +      if (typeof option == 'string') data[option].call($this)
   1.816 +    })
   1.817 +  }
   1.818 +
   1.819 +  $.fn.dropdown.Constructor = Dropdown
   1.820 +
   1.821 +
   1.822 +  // DROPDOWN NO CONFLICT
   1.823 +  // ====================
   1.824 +
   1.825 +  $.fn.dropdown.noConflict = function () {
   1.826 +    $.fn.dropdown = old
   1.827 +    return this
   1.828 +  }
   1.829 +
   1.830 +
   1.831 +  // APPLY TO STANDARD DROPDOWN ELEMENTS
   1.832 +  // ===================================
   1.833 +
   1.834 +  $(document)
   1.835 +    .on('click.bs.dropdown.data-api', clearMenus)
   1.836 +    .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
   1.837 +    .on('click.bs.dropdown.data-api'  , toggle, Dropdown.prototype.toggle)
   1.838 +    .on('keydown.bs.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown)
   1.839 +
   1.840 +}(jQuery);
   1.841 +
   1.842 +/* ========================================================================
   1.843 + * Bootstrap: modal.js v3.0.3
   1.844 + * http://getbootstrap.com/javascript/#modals
   1.845 + * ========================================================================
   1.846 + * Copyright 2013 Twitter, Inc.
   1.847 + *
   1.848 + * Licensed under the Apache License, Version 2.0 (the "License");
   1.849 + * you may not use this file except in compliance with the License.
   1.850 + * You may obtain a copy of the License at
   1.851 + *
   1.852 + * http://www.apache.org/licenses/LICENSE-2.0
   1.853 + *
   1.854 + * Unless required by applicable law or agreed to in writing, software
   1.855 + * distributed under the License is distributed on an "AS IS" BASIS,
   1.856 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   1.857 + * See the License for the specific language governing permissions and
   1.858 + * limitations under the License.
   1.859 + * ======================================================================== */
   1.860 +
   1.861 +
   1.862 ++function ($) { "use strict";
   1.863 +
   1.864 +  // MODAL CLASS DEFINITION
   1.865 +  // ======================
   1.866 +
   1.867 +  var Modal = function (element, options) {
   1.868 +    this.options   = options
   1.869 +    this.$element  = $(element)
   1.870 +    this.$backdrop =
   1.871 +    this.isShown   = null
   1.872 +
   1.873 +    if (this.options.remote) this.$element.load(this.options.remote)
   1.874 +  }
   1.875 +
   1.876 +  Modal.DEFAULTS = {
   1.877 +      backdrop: true
   1.878 +    , keyboard: true
   1.879 +    , show: true
   1.880 +  }
   1.881 +
   1.882 +  Modal.prototype.toggle = function (_relatedTarget) {
   1.883 +    return this[!this.isShown ? 'show' : 'hide'](_relatedTarget)
   1.884 +  }
   1.885 +
   1.886 +  Modal.prototype.show = function (_relatedTarget) {
   1.887 +    var that = this
   1.888 +    var e    = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
   1.889 +
   1.890 +    this.$element.trigger(e)
   1.891 +
   1.892 +    if (this.isShown || e.isDefaultPrevented()) return
   1.893 +
   1.894 +    this.isShown = true
   1.895 +
   1.896 +    this.escape()
   1.897 +
   1.898 +    this.$element.on('click.dismiss.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
   1.899 +
   1.900 +    this.backdrop(function () {
   1.901 +      var transition = $.support.transition && that.$element.hasClass('fade')
   1.902 +
   1.903 +      if (!that.$element.parent().length) {
   1.904 +        that.$element.appendTo(document.body) // don't move modals dom position
   1.905 +      }
   1.906 +
   1.907 +      that.$element.show()
   1.908 +
   1.909 +      if (transition) {
   1.910 +        that.$element[0].offsetWidth // force reflow
   1.911 +      }
   1.912 +
   1.913 +      that.$element
   1.914 +        .addClass('in')
   1.915 +        .attr('aria-hidden', false)
   1.916 +
   1.917 +      that.enforceFocus()
   1.918 +
   1.919 +      var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
   1.920 +
   1.921 +      transition ?
   1.922 +        that.$element.find('.modal-dialog') // wait for modal to slide in
   1.923 +          .one($.support.transition.end, function () {
   1.924 +            that.$element.focus().trigger(e)
   1.925 +          })
   1.926 +          .emulateTransitionEnd(300) :
   1.927 +        that.$element.focus().trigger(e)
   1.928 +    })
   1.929 +  }
   1.930 +
   1.931 +  Modal.prototype.hide = function (e) {
   1.932 +    if (e) e.preventDefault()
   1.933 +
   1.934 +    e = $.Event('hide.bs.modal')
   1.935 +
   1.936 +    this.$element.trigger(e)
   1.937 +
   1.938 +    if (!this.isShown || e.isDefaultPrevented()) return
   1.939 +
   1.940 +    this.isShown = false
   1.941 +
   1.942 +    this.escape()
   1.943 +
   1.944 +    $(document).off('focusin.bs.modal')
   1.945 +
   1.946 +    this.$element
   1.947 +      .removeClass('in')
   1.948 +      .attr('aria-hidden', true)
   1.949 +      .off('click.dismiss.modal')
   1.950 +
   1.951 +    $.support.transition && this.$element.hasClass('fade') ?
   1.952 +      this.$element
   1.953 +        .one($.support.transition.end, $.proxy(this.hideModal, this))
   1.954 +        .emulateTransitionEnd(300) :
   1.955 +      this.hideModal()
   1.956 +  }
   1.957 +
   1.958 +  Modal.prototype.enforceFocus = function () {
   1.959 +    $(document)
   1.960 +      .off('focusin.bs.modal') // guard against infinite focus loop
   1.961 +      .on('focusin.bs.modal', $.proxy(function (e) {
   1.962 +        if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
   1.963 +          this.$element.focus()
   1.964 +        }
   1.965 +      }, this))
   1.966 +  }
   1.967 +
   1.968 +  Modal.prototype.escape = function () {
   1.969 +    if (this.isShown && this.options.keyboard) {
   1.970 +      this.$element.on('keyup.dismiss.bs.modal', $.proxy(function (e) {
   1.971 +        e.which == 27 && this.hide()
   1.972 +      }, this))
   1.973 +    } else if (!this.isShown) {
   1.974 +      this.$element.off('keyup.dismiss.bs.modal')
   1.975 +    }
   1.976 +  }
   1.977 +
   1.978 +  Modal.prototype.hideModal = function () {
   1.979 +    var that = this
   1.980 +    this.$element.hide()
   1.981 +    this.backdrop(function () {
   1.982 +      that.removeBackdrop()
   1.983 +      that.$element.trigger('hidden.bs.modal')
   1.984 +    })
   1.985 +  }
   1.986 +
   1.987 +  Modal.prototype.removeBackdrop = function () {
   1.988 +    this.$backdrop && this.$backdrop.remove()
   1.989 +    this.$backdrop = null
   1.990 +  }
   1.991 +
   1.992 +  Modal.prototype.backdrop = function (callback) {
   1.993 +    var that    = this
   1.994 +    var animate = this.$element.hasClass('fade') ? 'fade' : ''
   1.995 +
   1.996 +    if (this.isShown && this.options.backdrop) {
   1.997 +      var doAnimate = $.support.transition && animate
   1.998 +
   1.999 +      this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
  1.1000 +        .appendTo(document.body)
  1.1001 +
  1.1002 +      this.$element.on('click.dismiss.modal', $.proxy(function (e) {
  1.1003 +        if (e.target !== e.currentTarget) return
  1.1004 +        this.options.backdrop == 'static'
  1.1005 +          ? this.$element[0].focus.call(this.$element[0])
  1.1006 +          : this.hide.call(this)
  1.1007 +      }, this))
  1.1008 +
  1.1009 +      if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
  1.1010 +
  1.1011 +      this.$backdrop.addClass('in')
  1.1012 +
  1.1013 +      if (!callback) return
  1.1014 +
  1.1015 +      doAnimate ?
  1.1016 +        this.$backdrop
  1.1017 +          .one($.support.transition.end, callback)
  1.1018 +          .emulateTransitionEnd(150) :
  1.1019 +        callback()
  1.1020 +
  1.1021 +    } else if (!this.isShown && this.$backdrop) {
  1.1022 +      this.$backdrop.removeClass('in')
  1.1023 +
  1.1024 +      $.support.transition && this.$element.hasClass('fade')?
  1.1025 +        this.$backdrop
  1.1026 +          .one($.support.transition.end, callback)
  1.1027 +          .emulateTransitionEnd(150) :
  1.1028 +        callback()
  1.1029 +
  1.1030 +    } else if (callback) {
  1.1031 +      callback()
  1.1032 +    }
  1.1033 +  }
  1.1034 +
  1.1035 +
  1.1036 +  // MODAL PLUGIN DEFINITION
  1.1037 +  // =======================
  1.1038 +
  1.1039 +  var old = $.fn.modal
  1.1040 +
  1.1041 +  $.fn.modal = function (option, _relatedTarget) {
  1.1042 +    return this.each(function () {
  1.1043 +      var $this   = $(this)
  1.1044 +      var data    = $this.data('bs.modal')
  1.1045 +      var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)
  1.1046 +
  1.1047 +      if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
  1.1048 +      if (typeof option == 'string') data[option](_relatedTarget)
  1.1049 +      else if (options.show) data.show(_relatedTarget)
  1.1050 +    })
  1.1051 +  }
  1.1052 +
  1.1053 +  $.fn.modal.Constructor = Modal
  1.1054 +
  1.1055 +
  1.1056 +  // MODAL NO CONFLICT
  1.1057 +  // =================
  1.1058 +
  1.1059 +  $.fn.modal.noConflict = function () {
  1.1060 +    $.fn.modal = old
  1.1061 +    return this
  1.1062 +  }
  1.1063 +
  1.1064 +
  1.1065 +  // MODAL DATA-API
  1.1066 +  // ==============
  1.1067 +
  1.1068 +  $(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
  1.1069 +    var $this   = $(this)
  1.1070 +    var href    = $this.attr('href')
  1.1071 +    var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
  1.1072 +    var option  = $target.data('modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
  1.1073 +
  1.1074 +    e.preventDefault()
  1.1075 +
  1.1076 +    $target
  1.1077 +      .modal(option, this)
  1.1078 +      .one('hide', function () {
  1.1079 +        $this.is(':visible') && $this.focus()
  1.1080 +      })
  1.1081 +  })
  1.1082 +
  1.1083 +  $(document)
  1.1084 +    .on('show.bs.modal',  '.modal', function () { $(document.body).addClass('modal-open') })
  1.1085 +    .on('hidden.bs.modal', '.modal', function () { $(document.body).removeClass('modal-open') })
  1.1086 +
  1.1087 +}(jQuery);
  1.1088 +
  1.1089 +/* ========================================================================
  1.1090 + * Bootstrap: tooltip.js v3.0.3
  1.1091 + * http://getbootstrap.com/javascript/#tooltip
  1.1092 + * Inspired by the original jQuery.tipsy by Jason Frame
  1.1093 + * ========================================================================
  1.1094 + * Copyright 2013 Twitter, Inc.
  1.1095 + *
  1.1096 + * Licensed under the Apache License, Version 2.0 (the "License");
  1.1097 + * you may not use this file except in compliance with the License.
  1.1098 + * You may obtain a copy of the License at
  1.1099 + *
  1.1100 + * http://www.apache.org/licenses/LICENSE-2.0
  1.1101 + *
  1.1102 + * Unless required by applicable law or agreed to in writing, software
  1.1103 + * distributed under the License is distributed on an "AS IS" BASIS,
  1.1104 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1.1105 + * See the License for the specific language governing permissions and
  1.1106 + * limitations under the License.
  1.1107 + * ======================================================================== */
  1.1108 +
  1.1109 +
  1.1110 ++function ($) { "use strict";
  1.1111 +
  1.1112 +  // TOOLTIP PUBLIC CLASS DEFINITION
  1.1113 +  // ===============================
  1.1114 +
  1.1115 +  var Tooltip = function (element, options) {
  1.1116 +    this.type       =
  1.1117 +    this.options    =
  1.1118 +    this.enabled    =
  1.1119 +    this.timeout    =
  1.1120 +    this.hoverState =
  1.1121 +    this.$element   = null
  1.1122 +
  1.1123 +    this.init('tooltip', element, options)
  1.1124 +  }
  1.1125 +
  1.1126 +  Tooltip.DEFAULTS = {
  1.1127 +    animation: true
  1.1128 +  , placement: 'top'
  1.1129 +  , selector: false
  1.1130 +  , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
  1.1131 +  , trigger: 'hover focus'
  1.1132 +  , title: ''
  1.1133 +  , delay: 0
  1.1134 +  , html: false
  1.1135 +  , container: false
  1.1136 +  }
  1.1137 +
  1.1138 +  Tooltip.prototype.init = function (type, element, options) {
  1.1139 +    this.enabled  = true
  1.1140 +    this.type     = type
  1.1141 +    this.$element = $(element)
  1.1142 +    this.options  = this.getOptions(options)
  1.1143 +
  1.1144 +    var triggers = this.options.trigger.split(' ')
  1.1145 +
  1.1146 +    for (var i = triggers.length; i--;) {
  1.1147 +      var trigger = triggers[i]
  1.1148 +
  1.1149 +      if (trigger == 'click') {
  1.1150 +        this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
  1.1151 +      } else if (trigger != 'manual') {
  1.1152 +        var eventIn  = trigger == 'hover' ? 'mouseenter' : 'focus'
  1.1153 +        var eventOut = trigger == 'hover' ? 'mouseleave' : 'blur'
  1.1154 +
  1.1155 +        this.$element.on(eventIn  + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
  1.1156 +        this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
  1.1157 +      }
  1.1158 +    }
  1.1159 +
  1.1160 +    this.options.selector ?
  1.1161 +      (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
  1.1162 +      this.fixTitle()
  1.1163 +  }
  1.1164 +
  1.1165 +  Tooltip.prototype.getDefaults = function () {
  1.1166 +    return Tooltip.DEFAULTS
  1.1167 +  }
  1.1168 +
  1.1169 +  Tooltip.prototype.getOptions = function (options) {
  1.1170 +    options = $.extend({}, this.getDefaults(), this.$element.data(), options)
  1.1171 +
  1.1172 +    if (options.delay && typeof options.delay == 'number') {
  1.1173 +      options.delay = {
  1.1174 +        show: options.delay
  1.1175 +      , hide: options.delay
  1.1176 +      }
  1.1177 +    }
  1.1178 +
  1.1179 +    return options
  1.1180 +  }
  1.1181 +
  1.1182 +  Tooltip.prototype.getDelegateOptions = function () {
  1.1183 +    var options  = {}
  1.1184 +    var defaults = this.getDefaults()
  1.1185 +
  1.1186 +    this._options && $.each(this._options, function (key, value) {
  1.1187 +      if (defaults[key] != value) options[key] = value
  1.1188 +    })
  1.1189 +
  1.1190 +    return options
  1.1191 +  }
  1.1192 +
  1.1193 +  Tooltip.prototype.enter = function (obj) {
  1.1194 +    var self = obj instanceof this.constructor ?
  1.1195 +      obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
  1.1196 +
  1.1197 +    clearTimeout(self.timeout)
  1.1198 +
  1.1199 +    self.hoverState = 'in'
  1.1200 +
  1.1201 +    if (!self.options.delay || !self.options.delay.show) return self.show()
  1.1202 +
  1.1203 +    self.timeout = setTimeout(function () {
  1.1204 +      if (self.hoverState == 'in') self.show()
  1.1205 +    }, self.options.delay.show)
  1.1206 +  }
  1.1207 +
  1.1208 +  Tooltip.prototype.leave = function (obj) {
  1.1209 +    var self = obj instanceof this.constructor ?
  1.1210 +      obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
  1.1211 +
  1.1212 +    clearTimeout(self.timeout)
  1.1213 +
  1.1214 +    self.hoverState = 'out'
  1.1215 +
  1.1216 +    if (!self.options.delay || !self.options.delay.hide) return self.hide()
  1.1217 +
  1.1218 +    self.timeout = setTimeout(function () {
  1.1219 +      if (self.hoverState == 'out') self.hide()
  1.1220 +    }, self.options.delay.hide)
  1.1221 +  }
  1.1222 +
  1.1223 +  Tooltip.prototype.show = function () {
  1.1224 +    var e = $.Event('show.bs.'+ this.type)
  1.1225 +
  1.1226 +    if (this.hasContent() && this.enabled) {
  1.1227 +      this.$element.trigger(e)
  1.1228 +
  1.1229 +      if (e.isDefaultPrevented()) return
  1.1230 +
  1.1231 +      var $tip = this.tip()
  1.1232 +
  1.1233 +      this.setContent()
  1.1234 +
  1.1235 +      if (this.options.animation) $tip.addClass('fade')
  1.1236 +
  1.1237 +      var placement = typeof this.options.placement == 'function' ?
  1.1238 +        this.options.placement.call(this, $tip[0], this.$element[0]) :
  1.1239 +        this.options.placement
  1.1240 +
  1.1241 +      var autoToken = /\s?auto?\s?/i
  1.1242 +      var autoPlace = autoToken.test(placement)
  1.1243 +      if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
  1.1244 +
  1.1245 +      $tip
  1.1246 +        .detach()
  1.1247 +        .css({ top: 0, left: 0, display: 'block' })
  1.1248 +        .addClass(placement)
  1.1249 +
  1.1250 +      this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
  1.1251 +
  1.1252 +      var pos          = this.getPosition()
  1.1253 +      var actualWidth  = $tip[0].offsetWidth
  1.1254 +      var actualHeight = $tip[0].offsetHeight
  1.1255 +
  1.1256 +      if (autoPlace) {
  1.1257 +        var $parent = this.$element.parent()
  1.1258 +
  1.1259 +        var orgPlacement = placement
  1.1260 +        var docScroll    = document.documentElement.scrollTop || document.body.scrollTop
  1.1261 +        var parentWidth  = this.options.container == 'body' ? window.innerWidth  : $parent.outerWidth()
  1.1262 +        var parentHeight = this.options.container == 'body' ? window.innerHeight : $parent.outerHeight()
  1.1263 +        var parentLeft   = this.options.container == 'body' ? 0 : $parent.offset().left
  1.1264 +
  1.1265 +        placement = placement == 'bottom' && pos.top   + pos.height  + actualHeight - docScroll > parentHeight  ? 'top'    :
  1.1266 +                    placement == 'top'    && pos.top   - docScroll   - actualHeight < 0                         ? 'bottom' :
  1.1267 +                    placement == 'right'  && pos.right + actualWidth > parentWidth                              ? 'left'   :
  1.1268 +                    placement == 'left'   && pos.left  - actualWidth < parentLeft                               ? 'right'  :
  1.1269 +                    placement
  1.1270 +
  1.1271 +        $tip
  1.1272 +          .removeClass(orgPlacement)
  1.1273 +          .addClass(placement)
  1.1274 +      }
  1.1275 +
  1.1276 +      var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight)
  1.1277 +
  1.1278 +      this.applyPlacement(calculatedOffset, placement)
  1.1279 +      this.$element.trigger('shown.bs.' + this.type)
  1.1280 +    }
  1.1281 +  }
  1.1282 +
  1.1283 +  Tooltip.prototype.applyPlacement = function(offset, placement) {
  1.1284 +    var replace
  1.1285 +    var $tip   = this.tip()
  1.1286 +    var width  = $tip[0].offsetWidth
  1.1287 +    var height = $tip[0].offsetHeight
  1.1288 +
  1.1289 +    // manually read margins because getBoundingClientRect includes difference
  1.1290 +    var marginTop = parseInt($tip.css('margin-top'), 10)
  1.1291 +    var marginLeft = parseInt($tip.css('margin-left'), 10)
  1.1292 +
  1.1293 +    // we must check for NaN for ie 8/9
  1.1294 +    if (isNaN(marginTop))  marginTop  = 0
  1.1295 +    if (isNaN(marginLeft)) marginLeft = 0
  1.1296 +
  1.1297 +    offset.top  = offset.top  + marginTop
  1.1298 +    offset.left = offset.left + marginLeft
  1.1299 +
  1.1300 +    $tip
  1.1301 +      .offset(offset)
  1.1302 +      .addClass('in')
  1.1303 +
  1.1304 +    // check to see if placing tip in new offset caused the tip to resize itself
  1.1305 +    var actualWidth  = $tip[0].offsetWidth
  1.1306 +    var actualHeight = $tip[0].offsetHeight
  1.1307 +
  1.1308 +    if (placement == 'top' && actualHeight != height) {
  1.1309 +      replace = true
  1.1310 +      offset.top = offset.top + height - actualHeight
  1.1311 +    }
  1.1312 +
  1.1313 +    if (/bottom|top/.test(placement)) {
  1.1314 +      var delta = 0
  1.1315 +
  1.1316 +      if (offset.left < 0) {
  1.1317 +        delta       = offset.left * -2
  1.1318 +        offset.left = 0
  1.1319 +
  1.1320 +        $tip.offset(offset)
  1.1321 +
  1.1322 +        actualWidth  = $tip[0].offsetWidth
  1.1323 +        actualHeight = $tip[0].offsetHeight
  1.1324 +      }
  1.1325 +
  1.1326 +      this.replaceArrow(delta - width + actualWidth, actualWidth, 'left')
  1.1327 +    } else {
  1.1328 +      this.replaceArrow(actualHeight - height, actualHeight, 'top')
  1.1329 +    }
  1.1330 +
  1.1331 +    if (replace) $tip.offset(offset)
  1.1332 +  }
  1.1333 +
  1.1334 +  Tooltip.prototype.replaceArrow = function(delta, dimension, position) {
  1.1335 +    this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + "%") : '')
  1.1336 +  }
  1.1337 +
  1.1338 +  Tooltip.prototype.setContent = function () {
  1.1339 +    var $tip  = this.tip()
  1.1340 +    var title = this.getTitle()
  1.1341 +
  1.1342 +    $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
  1.1343 +    $tip.removeClass('fade in top bottom left right')
  1.1344 +  }
  1.1345 +
  1.1346 +  Tooltip.prototype.hide = function () {
  1.1347 +    var that = this
  1.1348 +    var $tip = this.tip()
  1.1349 +    var e    = $.Event('hide.bs.' + this.type)
  1.1350 +
  1.1351 +    function complete() {
  1.1352 +      if (that.hoverState != 'in') $tip.detach()
  1.1353 +    }
  1.1354 +
  1.1355 +    this.$element.trigger(e)
  1.1356 +
  1.1357 +    if (e.isDefaultPrevented()) return
  1.1358 +
  1.1359 +    $tip.removeClass('in')
  1.1360 +
  1.1361 +    $.support.transition && this.$tip.hasClass('fade') ?
  1.1362 +      $tip
  1.1363 +        .one($.support.transition.end, complete)
  1.1364 +        .emulateTransitionEnd(150) :
  1.1365 +      complete()
  1.1366 +
  1.1367 +    this.$element.trigger('hidden.bs.' + this.type)
  1.1368 +
  1.1369 +    return this
  1.1370 +  }
  1.1371 +
  1.1372 +  Tooltip.prototype.fixTitle = function () {
  1.1373 +    var $e = this.$element
  1.1374 +    if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
  1.1375 +      $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
  1.1376 +    }
  1.1377 +  }
  1.1378 +
  1.1379 +  Tooltip.prototype.hasContent = function () {
  1.1380 +    return this.getTitle()
  1.1381 +  }
  1.1382 +
  1.1383 +  Tooltip.prototype.getPosition = function () {
  1.1384 +    var el = this.$element[0]
  1.1385 +    return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : {
  1.1386 +      width: el.offsetWidth
  1.1387 +    , height: el.offsetHeight
  1.1388 +    }, this.$element.offset())
  1.1389 +  }
  1.1390 +
  1.1391 +  Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) {
  1.1392 +    return placement == 'bottom' ? { top: pos.top + pos.height,   left: pos.left + pos.width / 2 - actualWidth / 2  } :
  1.1393 +           placement == 'top'    ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2  } :
  1.1394 +           placement == 'left'   ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } :
  1.1395 +        /* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width   }
  1.1396 +  }
  1.1397 +
  1.1398 +  Tooltip.prototype.getTitle = function () {
  1.1399 +    var title
  1.1400 +    var $e = this.$element
  1.1401 +    var o  = this.options
  1.1402 +
  1.1403 +    title = $e.attr('data-original-title')
  1.1404 +      || (typeof o.title == 'function' ? o.title.call($e[0]) :  o.title)
  1.1405 +
  1.1406 +    return title
  1.1407 +  }
  1.1408 +
  1.1409 +  Tooltip.prototype.tip = function () {
  1.1410 +    return this.$tip = this.$tip || $(this.options.template)
  1.1411 +  }
  1.1412 +
  1.1413 +  Tooltip.prototype.arrow = function () {
  1.1414 +    return this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow')
  1.1415 +  }
  1.1416 +
  1.1417 +  Tooltip.prototype.validate = function () {
  1.1418 +    if (!this.$element[0].parentNode) {
  1.1419 +      this.hide()
  1.1420 +      this.$element = null
  1.1421 +      this.options  = null
  1.1422 +    }
  1.1423 +  }
  1.1424 +
  1.1425 +  Tooltip.prototype.enable = function () {
  1.1426 +    this.enabled = true
  1.1427 +  }
  1.1428 +
  1.1429 +  Tooltip.prototype.disable = function () {
  1.1430 +    this.enabled = false
  1.1431 +  }
  1.1432 +
  1.1433 +  Tooltip.prototype.toggleEnabled = function () {
  1.1434 +    this.enabled = !this.enabled
  1.1435 +  }
  1.1436 +
  1.1437 +  Tooltip.prototype.toggle = function (e) {
  1.1438 +    var self = e ? $(e.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) : this
  1.1439 +    self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
  1.1440 +  }
  1.1441 +
  1.1442 +  Tooltip.prototype.destroy = function () {
  1.1443 +    this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
  1.1444 +  }
  1.1445 +
  1.1446 +
  1.1447 +  // TOOLTIP PLUGIN DEFINITION
  1.1448 +  // =========================
  1.1449 +
  1.1450 +  var old = $.fn.tooltip
  1.1451 +
  1.1452 +  $.fn.tooltip = function (option) {
  1.1453 +    return this.each(function () {
  1.1454 +      var $this   = $(this)
  1.1455 +      var data    = $this.data('bs.tooltip')
  1.1456 +      var options = typeof option == 'object' && option
  1.1457 +
  1.1458 +      if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
  1.1459 +      if (typeof option == 'string') data[option]()
  1.1460 +    })
  1.1461 +  }
  1.1462 +
  1.1463 +  $.fn.tooltip.Constructor = Tooltip
  1.1464 +
  1.1465 +
  1.1466 +  // TOOLTIP NO CONFLICT
  1.1467 +  // ===================
  1.1468 +
  1.1469 +  $.fn.tooltip.noConflict = function () {
  1.1470 +    $.fn.tooltip = old
  1.1471 +    return this
  1.1472 +  }
  1.1473 +
  1.1474 +}(jQuery);
  1.1475 +
  1.1476 +/* ========================================================================
  1.1477 + * Bootstrap: popover.js v3.0.3
  1.1478 + * http://getbootstrap.com/javascript/#popovers
  1.1479 + * ========================================================================
  1.1480 + * Copyright 2013 Twitter, Inc.
  1.1481 + *
  1.1482 + * Licensed under the Apache License, Version 2.0 (the "License");
  1.1483 + * you may not use this file except in compliance with the License.
  1.1484 + * You may obtain a copy of the License at
  1.1485 + *
  1.1486 + * http://www.apache.org/licenses/LICENSE-2.0
  1.1487 + *
  1.1488 + * Unless required by applicable law or agreed to in writing, software
  1.1489 + * distributed under the License is distributed on an "AS IS" BASIS,
  1.1490 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1.1491 + * See the License for the specific language governing permissions and
  1.1492 + * limitations under the License.
  1.1493 + * ======================================================================== */
  1.1494 +
  1.1495 +
  1.1496 ++function ($) { "use strict";
  1.1497 +
  1.1498 +  // POPOVER PUBLIC CLASS DEFINITION
  1.1499 +  // ===============================
  1.1500 +
  1.1501 +  var Popover = function (element, options) {
  1.1502 +    this.init('popover', element, options)
  1.1503 +  }
  1.1504 +
  1.1505 +  if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js')
  1.1506 +
  1.1507 +  Popover.DEFAULTS = $.extend({} , $.fn.tooltip.Constructor.DEFAULTS, {
  1.1508 +    placement: 'right'
  1.1509 +  , trigger: 'click'
  1.1510 +  , content: ''
  1.1511 +  , template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
  1.1512 +  })
  1.1513 +
  1.1514 +
  1.1515 +  // NOTE: POPOVER EXTENDS tooltip.js
  1.1516 +  // ================================
  1.1517 +
  1.1518 +  Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
  1.1519 +
  1.1520 +  Popover.prototype.constructor = Popover
  1.1521 +
  1.1522 +  Popover.prototype.getDefaults = function () {
  1.1523 +    return Popover.DEFAULTS
  1.1524 +  }
  1.1525 +
  1.1526 +  Popover.prototype.setContent = function () {
  1.1527 +    var $tip    = this.tip()
  1.1528 +    var title   = this.getTitle()
  1.1529 +    var content = this.getContent()
  1.1530 +
  1.1531 +    $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
  1.1532 +    $tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
  1.1533 +
  1.1534 +    $tip.removeClass('fade top bottom left right in')
  1.1535 +
  1.1536 +    // IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
  1.1537 +    // this manually by checking the contents.
  1.1538 +    if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide()
  1.1539 +  }
  1.1540 +
  1.1541 +  Popover.prototype.hasContent = function () {
  1.1542 +    return this.getTitle() || this.getContent()
  1.1543 +  }
  1.1544 +
  1.1545 +  Popover.prototype.getContent = function () {
  1.1546 +    var $e = this.$element
  1.1547 +    var o  = this.options
  1.1548 +
  1.1549 +    return $e.attr('data-content')
  1.1550 +      || (typeof o.content == 'function' ?
  1.1551 +            o.content.call($e[0]) :
  1.1552 +            o.content)
  1.1553 +  }
  1.1554 +
  1.1555 +  Popover.prototype.arrow = function () {
  1.1556 +    return this.$arrow = this.$arrow || this.tip().find('.arrow')
  1.1557 +  }
  1.1558 +
  1.1559 +  Popover.prototype.tip = function () {
  1.1560 +    if (!this.$tip) this.$tip = $(this.options.template)
  1.1561 +    return this.$tip
  1.1562 +  }
  1.1563 +
  1.1564 +
  1.1565 +  // POPOVER PLUGIN DEFINITION
  1.1566 +  // =========================
  1.1567 +
  1.1568 +  var old = $.fn.popover
  1.1569 +
  1.1570 +  $.fn.popover = function (option) {
  1.1571 +    return this.each(function () {
  1.1572 +      var $this   = $(this)
  1.1573 +      var data    = $this.data('bs.popover')
  1.1574 +      var options = typeof option == 'object' && option
  1.1575 +
  1.1576 +      if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
  1.1577 +      if (typeof option == 'string') data[option]()
  1.1578 +    })
  1.1579 +  }
  1.1580 +
  1.1581 +  $.fn.popover.Constructor = Popover
  1.1582 +
  1.1583 +
  1.1584 +  // POPOVER NO CONFLICT
  1.1585 +  // ===================
  1.1586 +
  1.1587 +  $.fn.popover.noConflict = function () {
  1.1588 +    $.fn.popover = old
  1.1589 +    return this
  1.1590 +  }
  1.1591 +
  1.1592 +}(jQuery);
  1.1593 +
  1.1594 +/* ========================================================================
  1.1595 + * Bootstrap: scrollspy.js v3.0.3
  1.1596 + * http://getbootstrap.com/javascript/#scrollspy
  1.1597 + * ========================================================================
  1.1598 + * Copyright 2013 Twitter, Inc.
  1.1599 + *
  1.1600 + * Licensed under the Apache License, Version 2.0 (the "License");
  1.1601 + * you may not use this file except in compliance with the License.
  1.1602 + * You may obtain a copy of the License at
  1.1603 + *
  1.1604 + * http://www.apache.org/licenses/LICENSE-2.0
  1.1605 + *
  1.1606 + * Unless required by applicable law or agreed to in writing, software
  1.1607 + * distributed under the License is distributed on an "AS IS" BASIS,
  1.1608 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1.1609 + * See the License for the specific language governing permissions and
  1.1610 + * limitations under the License.
  1.1611 + * ======================================================================== */
  1.1612 +
  1.1613 +
  1.1614 ++function ($) { "use strict";
  1.1615 +
  1.1616 +  // SCROLLSPY CLASS DEFINITION
  1.1617 +  // ==========================
  1.1618 +
  1.1619 +  function ScrollSpy(element, options) {
  1.1620 +    var href
  1.1621 +    var process  = $.proxy(this.process, this)
  1.1622 +
  1.1623 +    this.$element       = $(element).is('body') ? $(window) : $(element)
  1.1624 +    this.$body          = $('body')
  1.1625 +    this.$scrollElement = this.$element.on('scroll.bs.scroll-spy.data-api', process)
  1.1626 +    this.options        = $.extend({}, ScrollSpy.DEFAULTS, options)
  1.1627 +    this.selector       = (this.options.target
  1.1628 +      || ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
  1.1629 +      || '') + ' .nav li > a'
  1.1630 +    this.offsets        = $([])
  1.1631 +    this.targets        = $([])
  1.1632 +    this.activeTarget   = null
  1.1633 +
  1.1634 +    this.refresh()
  1.1635 +    this.process()
  1.1636 +  }
  1.1637 +
  1.1638 +  ScrollSpy.DEFAULTS = {
  1.1639 +    offset: 10
  1.1640 +  }
  1.1641 +
  1.1642 +  ScrollSpy.prototype.refresh = function () {
  1.1643 +    var offsetMethod = this.$element[0] == window ? 'offset' : 'position'
  1.1644 +
  1.1645 +    this.offsets = $([])
  1.1646 +    this.targets = $([])
  1.1647 +
  1.1648 +    var self     = this
  1.1649 +    var $targets = this.$body
  1.1650 +      .find(this.selector)
  1.1651 +      .map(function () {
  1.1652 +        var $el   = $(this)
  1.1653 +        var href  = $el.data('target') || $el.attr('href')
  1.1654 +        var $href = /^#\w/.test(href) && $(href)
  1.1655 +
  1.1656 +        return ($href
  1.1657 +          && $href.length
  1.1658 +          && [[ $href[offsetMethod]().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]]) || null
  1.1659 +      })
  1.1660 +      .sort(function (a, b) { return a[0] - b[0] })
  1.1661 +      .each(function () {
  1.1662 +        self.offsets.push(this[0])
  1.1663 +        self.targets.push(this[1])
  1.1664 +      })
  1.1665 +  }
  1.1666 +
  1.1667 +  ScrollSpy.prototype.process = function () {
  1.1668 +    var scrollTop    = this.$scrollElement.scrollTop() + this.options.offset
  1.1669 +    var scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
  1.1670 +    var maxScroll    = scrollHeight - this.$scrollElement.height()
  1.1671 +    var offsets      = this.offsets
  1.1672 +    var targets      = this.targets
  1.1673 +    var activeTarget = this.activeTarget
  1.1674 +    var i
  1.1675 +
  1.1676 +    if (scrollTop >= maxScroll) {
  1.1677 +      return activeTarget != (i = targets.last()[0]) && this.activate(i)
  1.1678 +    }
  1.1679 +
  1.1680 +    for (i = offsets.length; i--;) {
  1.1681 +      activeTarget != targets[i]
  1.1682 +        && scrollTop >= offsets[i]
  1.1683 +        && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
  1.1684 +        && this.activate( targets[i] )
  1.1685 +    }
  1.1686 +  }
  1.1687 +
  1.1688 +  ScrollSpy.prototype.activate = function (target) {
  1.1689 +    this.activeTarget = target
  1.1690 +
  1.1691 +    $(this.selector)
  1.1692 +      .parents('.active')
  1.1693 +      .removeClass('active')
  1.1694 +
  1.1695 +    var selector = this.selector
  1.1696 +      + '[data-target="' + target + '"],'
  1.1697 +      + this.selector + '[href="' + target + '"]'
  1.1698 +
  1.1699 +    var active = $(selector)
  1.1700 +      .parents('li')
  1.1701 +      .addClass('active')
  1.1702 +
  1.1703 +    if (active.parent('.dropdown-menu').length)  {
  1.1704 +      active = active
  1.1705 +        .closest('li.dropdown')
  1.1706 +        .addClass('active')
  1.1707 +    }
  1.1708 +
  1.1709 +    active.trigger('activate.bs.scrollspy')
  1.1710 +  }
  1.1711 +
  1.1712 +
  1.1713 +  // SCROLLSPY PLUGIN DEFINITION
  1.1714 +  // ===========================
  1.1715 +
  1.1716 +  var old = $.fn.scrollspy
  1.1717 +
  1.1718 +  $.fn.scrollspy = function (option) {
  1.1719 +    return this.each(function () {
  1.1720 +      var $this   = $(this)
  1.1721 +      var data    = $this.data('bs.scrollspy')
  1.1722 +      var options = typeof option == 'object' && option
  1.1723 +
  1.1724 +      if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
  1.1725 +      if (typeof option == 'string') data[option]()
  1.1726 +    })
  1.1727 +  }
  1.1728 +
  1.1729 +  $.fn.scrollspy.Constructor = ScrollSpy
  1.1730 +
  1.1731 +
  1.1732 +  // SCROLLSPY NO CONFLICT
  1.1733 +  // =====================
  1.1734 +
  1.1735 +  $.fn.scrollspy.noConflict = function () {
  1.1736 +    $.fn.scrollspy = old
  1.1737 +    return this
  1.1738 +  }
  1.1739 +
  1.1740 +
  1.1741 +  // SCROLLSPY DATA-API
  1.1742 +  // ==================
  1.1743 +
  1.1744 +  $(window).on('load', function () {
  1.1745 +    $('[data-spy="scroll"]').each(function () {
  1.1746 +      var $spy = $(this)
  1.1747 +      $spy.scrollspy($spy.data())
  1.1748 +    })
  1.1749 +  })
  1.1750 +
  1.1751 +}(jQuery);
  1.1752 +
  1.1753 +/* ========================================================================
  1.1754 + * Bootstrap: tab.js v3.0.3
  1.1755 + * http://getbootstrap.com/javascript/#tabs
  1.1756 + * ========================================================================
  1.1757 + * Copyright 2013 Twitter, Inc.
  1.1758 + *
  1.1759 + * Licensed under the Apache License, Version 2.0 (the "License");
  1.1760 + * you may not use this file except in compliance with the License.
  1.1761 + * You may obtain a copy of the License at
  1.1762 + *
  1.1763 + * http://www.apache.org/licenses/LICENSE-2.0
  1.1764 + *
  1.1765 + * Unless required by applicable law or agreed to in writing, software
  1.1766 + * distributed under the License is distributed on an "AS IS" BASIS,
  1.1767 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1.1768 + * See the License for the specific language governing permissions and
  1.1769 + * limitations under the License.
  1.1770 + * ======================================================================== */
  1.1771 +
  1.1772 +
  1.1773 ++function ($) { "use strict";
  1.1774 +
  1.1775 +  // TAB CLASS DEFINITION
  1.1776 +  // ====================
  1.1777 +
  1.1778 +  var Tab = function (element) {
  1.1779 +    this.element = $(element)
  1.1780 +  }
  1.1781 +
  1.1782 +  Tab.prototype.show = function () {
  1.1783 +    var $this    = this.element
  1.1784 +    var $ul      = $this.closest('ul:not(.dropdown-menu)')
  1.1785 +    var selector = $this.data('target')
  1.1786 +
  1.1787 +    if (!selector) {
  1.1788 +      selector = $this.attr('href')
  1.1789 +      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
  1.1790 +    }
  1.1791 +
  1.1792 +    if ($this.parent('li').hasClass('active')) return
  1.1793 +
  1.1794 +    var previous = $ul.find('.active:last a')[0]
  1.1795 +    var e        = $.Event('show.bs.tab', {
  1.1796 +      relatedTarget: previous
  1.1797 +    })
  1.1798 +
  1.1799 +    $this.trigger(e)
  1.1800 +
  1.1801 +    if (e.isDefaultPrevented()) return
  1.1802 +
  1.1803 +    var $target = $(selector)
  1.1804 +
  1.1805 +    this.activate($this.parent('li'), $ul)
  1.1806 +    this.activate($target, $target.parent(), function () {
  1.1807 +      $this.trigger({
  1.1808 +        type: 'shown.bs.tab'
  1.1809 +      , relatedTarget: previous
  1.1810 +      })
  1.1811 +    })
  1.1812 +  }
  1.1813 +
  1.1814 +  Tab.prototype.activate = function (element, container, callback) {
  1.1815 +    var $active    = container.find('> .active')
  1.1816 +    var transition = callback
  1.1817 +      && $.support.transition
  1.1818 +      && $active.hasClass('fade')
  1.1819 +
  1.1820 +    function next() {
  1.1821 +      $active
  1.1822 +        .removeClass('active')
  1.1823 +        .find('> .dropdown-menu > .active')
  1.1824 +        .removeClass('active')
  1.1825 +
  1.1826 +      element.addClass('active')
  1.1827 +
  1.1828 +      if (transition) {
  1.1829 +        element[0].offsetWidth // reflow for transition
  1.1830 +        element.addClass('in')
  1.1831 +      } else {
  1.1832 +        element.removeClass('fade')
  1.1833 +      }
  1.1834 +
  1.1835 +      if (element.parent('.dropdown-menu')) {
  1.1836 +        element.closest('li.dropdown').addClass('active')
  1.1837 +      }
  1.1838 +
  1.1839 +      callback && callback()
  1.1840 +    }
  1.1841 +
  1.1842 +    transition ?
  1.1843 +      $active
  1.1844 +        .one($.support.transition.end, next)
  1.1845 +        .emulateTransitionEnd(150) :
  1.1846 +      next()
  1.1847 +
  1.1848 +    $active.removeClass('in')
  1.1849 +  }
  1.1850 +
  1.1851 +
  1.1852 +  // TAB PLUGIN DEFINITION
  1.1853 +  // =====================
  1.1854 +
  1.1855 +  var old = $.fn.tab
  1.1856 +
  1.1857 +  $.fn.tab = function ( option ) {
  1.1858 +    return this.each(function () {
  1.1859 +      var $this = $(this)
  1.1860 +      var data  = $this.data('bs.tab')
  1.1861 +
  1.1862 +      if (!data) $this.data('bs.tab', (data = new Tab(this)))
  1.1863 +      if (typeof option == 'string') data[option]()
  1.1864 +    })
  1.1865 +  }
  1.1866 +
  1.1867 +  $.fn.tab.Constructor = Tab
  1.1868 +
  1.1869 +
  1.1870 +  // TAB NO CONFLICT
  1.1871 +  // ===============
  1.1872 +
  1.1873 +  $.fn.tab.noConflict = function () {
  1.1874 +    $.fn.tab = old
  1.1875 +    return this
  1.1876 +  }
  1.1877 +
  1.1878 +
  1.1879 +  // TAB DATA-API
  1.1880 +  // ============
  1.1881 +
  1.1882 +  $(document).on('click.bs.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) {
  1.1883 +    e.preventDefault()
  1.1884 +    $(this).tab('show')
  1.1885 +  })
  1.1886 +
  1.1887 +}(jQuery);
  1.1888 +
  1.1889 +/* ========================================================================
  1.1890 + * Bootstrap: affix.js v3.0.3
  1.1891 + * http://getbootstrap.com/javascript/#affix
  1.1892 + * ========================================================================
  1.1893 + * Copyright 2013 Twitter, Inc.
  1.1894 + *
  1.1895 + * Licensed under the Apache License, Version 2.0 (the "License");
  1.1896 + * you may not use this file except in compliance with the License.
  1.1897 + * You may obtain a copy of the License at
  1.1898 + *
  1.1899 + * http://www.apache.org/licenses/LICENSE-2.0
  1.1900 + *
  1.1901 + * Unless required by applicable law or agreed to in writing, software
  1.1902 + * distributed under the License is distributed on an "AS IS" BASIS,
  1.1903 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  1.1904 + * See the License for the specific language governing permissions and
  1.1905 + * limitations under the License.
  1.1906 + * ======================================================================== */
  1.1907 +
  1.1908 +
  1.1909 ++function ($) { "use strict";
  1.1910 +
  1.1911 +  // AFFIX CLASS DEFINITION
  1.1912 +  // ======================
  1.1913 +
  1.1914 +  var Affix = function (element, options) {
  1.1915 +    this.options = $.extend({}, Affix.DEFAULTS, options)
  1.1916 +    this.$window = $(window)
  1.1917 +      .on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))
  1.1918 +      .on('click.bs.affix.data-api',  $.proxy(this.checkPositionWithEventLoop, this))
  1.1919 +
  1.1920 +    this.$element = $(element)
  1.1921 +    this.affixed  =
  1.1922 +    this.unpin    = null
  1.1923 +
  1.1924 +    this.checkPosition()
  1.1925 +  }
  1.1926 +
  1.1927 +  Affix.RESET = 'affix affix-top affix-bottom'
  1.1928 +
  1.1929 +  Affix.DEFAULTS = {
  1.1930 +    offset: 0
  1.1931 +  }
  1.1932 +
  1.1933 +  Affix.prototype.checkPositionWithEventLoop = function () {
  1.1934 +    setTimeout($.proxy(this.checkPosition, this), 1)
  1.1935 +  }
  1.1936 +
  1.1937 +  Affix.prototype.checkPosition = function () {
  1.1938 +    if (!this.$element.is(':visible')) return
  1.1939 +
  1.1940 +    var scrollHeight = $(document).height()
  1.1941 +    var scrollTop    = this.$window.scrollTop()
  1.1942 +    var position     = this.$element.offset()
  1.1943 +    var offset       = this.options.offset
  1.1944 +    var offsetTop    = offset.top
  1.1945 +    var offsetBottom = offset.bottom
  1.1946 +
  1.1947 +    if (typeof offset != 'object')         offsetBottom = offsetTop = offset
  1.1948 +    if (typeof offsetTop == 'function')    offsetTop    = offset.top()
  1.1949 +    if (typeof offsetBottom == 'function') offsetBottom = offset.bottom()
  1.1950 +
  1.1951 +    var affix = this.unpin   != null && (scrollTop + this.unpin <= position.top) ? false :
  1.1952 +                offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? 'bottom' :
  1.1953 +                offsetTop    != null && (scrollTop <= offsetTop) ? 'top' : false
  1.1954 +
  1.1955 +    if (this.affixed === affix) return
  1.1956 +    if (this.unpin) this.$element.css('top', '')
  1.1957 +
  1.1958 +    this.affixed = affix
  1.1959 +    this.unpin   = affix == 'bottom' ? position.top - scrollTop : null
  1.1960 +
  1.1961 +    this.$element.removeClass(Affix.RESET).addClass('affix' + (affix ? '-' + affix : ''))
  1.1962 +
  1.1963 +    if (affix == 'bottom') {
  1.1964 +      this.$element.offset({ top: document.body.offsetHeight - offsetBottom - this.$element.height() })
  1.1965 +    }
  1.1966 +  }
  1.1967 +
  1.1968 +
  1.1969 +  // AFFIX PLUGIN DEFINITION
  1.1970 +  // =======================
  1.1971 +
  1.1972 +  var old = $.fn.affix
  1.1973 +
  1.1974 +  $.fn.affix = function (option) {
  1.1975 +    return this.each(function () {
  1.1976 +      var $this   = $(this)
  1.1977 +      var data    = $this.data('bs.affix')
  1.1978 +      var options = typeof option == 'object' && option
  1.1979 +
  1.1980 +      if (!data) $this.data('bs.affix', (data = new Affix(this, options)))
  1.1981 +      if (typeof option == 'string') data[option]()
  1.1982 +    })
  1.1983 +  }
  1.1984 +
  1.1985 +  $.fn.affix.Constructor = Affix
  1.1986 +
  1.1987 +
  1.1988 +  // AFFIX NO CONFLICT
  1.1989 +  // =================
  1.1990 +
  1.1991 +  $.fn.affix.noConflict = function () {
  1.1992 +    $.fn.affix = old
  1.1993 +    return this
  1.1994 +  }
  1.1995 +
  1.1996 +
  1.1997 +  // AFFIX DATA-API
  1.1998 +  // ==============
  1.1999 +
  1.2000 +  $(window).on('load', function () {
  1.2001 +    $('[data-spy="affix"]').each(function () {
  1.2002 +      var $spy = $(this)
  1.2003 +      var data = $spy.data()
  1.2004 +
  1.2005 +      data.offset = data.offset || {}
  1.2006 +
  1.2007 +      if (data.offsetBottom) data.offset.bottom = data.offsetBottom
  1.2008 +      if (data.offsetTop)    data.offset.top    = data.offsetTop
  1.2009 +
  1.2010 +      $spy.affix(data)
  1.2011 +    })
  1.2012 +  })
  1.2013 +
  1.2014 +}(jQuery);
Impressum Datenschutzerklärung