Updated foundation template to 4.3.2
Manuite
committed Oct 18, 2013
commit b6aab6e2cd062564e57eb86eb8729bd3b6e27545
Showing 28
changed files with
7608 additions
and 6519 deletions
generators/foundation/app/views/pages/index.liquid
+13
-18
| @@ | @@ -3,20 +3,15 @@ title: Home page |
| published: true | |
| --- | |
| <!DOCTYPE html> | |
| - | <!--[if IE 8]> <html class="no-js lt-ie9" lang="en"> <![endif]--> |
| - | <!--[if gt IE 8]><!--> <html class="no-js" lang="en"> <!--<![endif]--> |
| + | <!--[if IE 8]> <html class="no-js lt-ie9" lang="en" > <![endif]--> |
| + | <!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]--> |
| <head> | |
| - | <meta charset="utf-8" /> |
| - | <meta name="viewport" content="width=device-width, initial-scale=1.0" /> |
| + | <meta charset="utf-8"> |
| + | <meta name="viewport" content="width=device-width"> |
| <title>{{ page.title }}</title> | |
| - | |
| - | {{ 'normalize.css' | stylesheet_tag }} |
| - | |
| {{ 'foundation.css' | stylesheet_tag }} | |
| - | |
| {{ 'vendor/custom.modernizr.js' | javascript_tag }} | |
| - | |
| {% inline_editor %} | |
| </head> | |
| <body> | |
| @@ | @@ -24,13 +19,11 @@ published: true |
| <div class="row"> | |
| <div class="large-12 columns"> | |
| <h2>Welcome to Foundation</h2> | |
| - | <p>This is version 4.2.1</p> |
| + | <p>This is version 4.3.2.</p> |
| <hr /> | |
| </div> | |
| </div> | |
| - | |
| {% block 'main' %} | |
| - | |
| <div class="row"> | |
| <div class="large-8 columns"> | |
| <h3>The Grid</h3> | |
| @@ | @@ -112,8 +105,8 @@ published: true |
| ('__proto__' in {} ? '{{ 'vendor/zepto.js' | javascript_url }}' : '{{ 'vendor/jquery.js' | javascript_url }}') + | |
| '><\/script>') | |
| </script> | |
| + | |
| {{ 'foundation.min.js' | javascript_tag }} | |
| - | |
| <!-- | |
| {{ 'foundation/foundation.js' | javascript_tag }} | |
| @@ | @@ -134,8 +127,6 @@ published: true |
| {{ 'foundation/foundation.orbit.js' | javascript_tag }} | |
| - | {{ 'foundation/foundation.placeholder.js' | javascript_tag }} |
| - | |
| {{ 'foundation/foundation.reveal.js' | javascript_tag }} | |
| {{ 'foundation/foundation.section.js' | javascript_tag }} | |
| @@ | @@ -146,10 +137,14 @@ published: true |
| {{ 'foundation/foundation.interchange.js' | javascript_tag }} | |
| + | {{ 'foundation/foundation.placeholder.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.abide.js' | javascript_tag }} |
| + | |
| --> | |
| - | <script> |
| - | $(document).foundation(); |
| - | </script> |
| + | <script> |
| + | $(document).foundation(); |
| + | </script> |
| </body> | |
| </html> | |
generators/foundation/app/views/pages/index.liquid.haml
+51
-58
| @@ | @@ -3,26 +3,23 @@ title: Home page |
| published: true | |
| --- | |
| !!! | |
| - | /[if IE 8] <html class="no-js lt-ie9" lang="en"> |
| + | /[if IE 8] <html class="no-js lt-ie9" lang="en" > |
| / [if gt IE 8]><! | |
| - | %html.no-js{:lang => "en"} |
| + | %html.no-js{lang: "en"} |
| / <![endif] | |
| %head | |
| - | %meta{:charset => "utf-8"}/ |
| - | %meta{:content => "width=device-width, initial-scale=1.0", :name => "viewport"}/ |
| + | %meta{charset: "utf-8"}/ |
| + | %meta{content: "width=device-width", name: "viewport"}/ |
| %title {{ page.title }} | |
| - | {{ 'normalize.css' | stylesheet_tag }} |
| - | |
| - | {{ 'foundation.css' | stylesheet_tag }} |
| - | |
| - | {{ 'vendor/custom.modernizr.js' | javascript_tag }} |
| - | |
| - | {% inline_editor %} |
| %body | |
| + | %p |
| + | {{ 'foundation.css' | stylesheet_tag }} |
| + | {{ 'vendor/custom.modernizr.js' | javascript_tag }} |
| + | {% inline_editor %} |
| .row | |
| .large-12.columns | |
| %h2 Welcome to Foundation | |
| - | %p This is version 4.2.1 |
| + | %p This is version 4.3.2. |
| %hr/ | |
| {% block 'main' %} | |
| .row | |
| @@ | @@ -54,18 +51,18 @@ published: true |
| .row | |
| .large-6.columns | |
| %p | |
| - | %a.small.button{:href => "#"} Small Button |
| + | %a.small.button{href: "#"} Small Button |
| %p | |
| - | %a.button{:href => "#"} Medium Button |
| + | %a.button{href: "#"} Medium Button |
| %p | |
| - | %a.large.button{:href => "#"} Large Button |
| + | %a.large.button{href: "#"} Large Button |
| .large-6.columns | |
| %p | |
| - | %a.small.alert.button{:href => "#"} Small Alert Button |
| + | %a.small.alert.button{href: "#"} Small Alert Button |
| %p | |
| - | %a.success.button{:href => "#"} Medium Success Button |
| + | %a.success.button{href: "#"} Medium Success Button |
| %p | |
| - | %a.large.secondary.button{:href => "#"} Large Secondary Button |
| + | %a.large.secondary.button{href: "#"} Large Secondary Button |
| .large-4.columns | |
| %h4 Getting Started | |
| %p We're stoked you want to try Foundation! To get going, this file (index.html) includes some basic styles you can modify, play around with, or totally destroy to get going. | |
| @@ | @@ -73,60 +70,56 @@ published: true |
| %p Once you've exhausted the fun in this document, you should check out: | |
| %ul.disc | |
| %li | |
| - | %a{:href => "http://foundation.zurb.com/docs"} Foundation Documentation |
| + | %a{href: "http://foundation.zurb.com/docs"} Foundation Documentation |
| = succeed "Everything" do | |
| %br/ | |
| - | you need to know about using the framework. |
| %li | |
| - | %a{:href => "http://github.com/zurb/foundation"} Foundation on Github |
| + | %a{href: "http://github.com/zurb/foundation"} Foundation on Github |
| = succeed "Latest" do | |
| %br/ | |
| - | code, issue reports, feature requests and more. |
| %li | |
| - | %a{:href => "http://twitter.com/foundationzurb"} @foundationzurb |
| + | %a{href: "http://twitter.com/foundationzurb"} @foundationzurb |
| = succeed "Ping" do | |
| %br/ | |
| - | us on Twitter if you have questions. If you build something with this we'd love to see it (and send you a totally boss sticker). |
| {% endblock %} | |
| - | |
| + | |
| {% include footer %} | |
| - | |
| :javascript | |
| document.write('<script src=' + | |
| ('__proto__' in {} ? '{{ 'vendor/zepto.js' | javascript_url }}' : '{{ 'vendor/jquery.js' | javascript_url }}') + | |
| '><\/script>') | |
| - | |
| {{ 'foundation.min.js' | javascript_tag }} | |
| - | |
| - | / {{ 'foundation/foundation.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.alerts.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.clearing.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.cookie.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.dropdown.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.forms.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.joyride.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.magellan.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.orbit.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.placeholder.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.reveal.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.section.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.tooltips.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.topbar.js' | javascript_tag }} |
| - | |
| - | / {{ 'foundation/foundation.interchange.js' | javascript_tag }} |
| - | |
| + | / |
| + | {{ 'foundation/foundation.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.alerts.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.clearing.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.cookie.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.dropdown.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.forms.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.joyride.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.magellan.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.orbit.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.reveal.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.section.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.tooltips.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.topbar.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.interchange.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.placeholder.js' | javascript_tag }} |
| + | |
| + | {{ 'foundation/foundation.abide.js' | javascript_tag }} |
| :javascript | |
| $(document).foundation(); | |
generators/foundation/app/views/snippets/footer.liquid
+12
-12
| @@ | @@ -1,16 +1,16 @@ |
| <footer class="row full-width"> | |
| - | <div class="large-5 columns"> |
| - | <h6><strong>Made by ZURB</strong></h6> |
| - | <p>Foundation is made by <a href="http://www.zurb.com/">ZURB</a>, a product design company in Campbell, California. We've put more than 14 years of experience building web products, services and websites into this framework. <a href="http://foundation.zurb.com/about.php">Foundation Info and Goodies →</a></p> |
| - | </div> |
| + | <div class="large-5 columns"> |
| + | <h6><strong>Made by ZURB</strong></h6> |
| + | <p>Foundation is made by <a href="http://www.zurb.com/">ZURB</a>, a product design company in Campbell, California. We've put more than 14 years of experience building web products, services and websites into this framework. <a href="http://foundation.zurb.com/about.php">Foundation Info and Goodies →</a></p> |
| + | </div> |
| - | <div class="large-3 columns"> |
| - | <h6><strong>Using Foundation?</strong></h6> |
| - | <p>Let us know how you're using Foundation and we might feature you as an example! <a href="mailto:foundation@zurb.com?subject=I'm%20using%20Foundation">Get in touch →</a></p> |
| - | </div> |
| + | <div class="large-3 columns"> |
| + | <h6><strong>Using Foundation?</strong></h6> |
| + | <p>Let us know how you're using Foundation and we might feature you as an example! <a href="mailto:foundation@zurb.com?subject=I'm%20using%20Foundation">Get in touch →</a></p> |
| + | </div> |
| - | <div class="large-4 columns"> |
| - | <h6><strong>Need some help?</strong></h6> |
| - | <p>For answers or help visit the <a href="http://foundation.zurb.com/docs/support.html">Support page</a>.</p> |
| - | </div> |
| + | <div class="large-4 columns"> |
| + | <h6><strong>Need some help?</strong></h6> |
| + | <p>For answers or help visit the <a href="http://foundation.zurb.com/docs/support.html">Support page</a>.</p> |
| + | </div> |
| </footer> | |
| \ No newline at end of file | |
generators/foundation/app/views/snippets/footer.liquid.haml
+4
-5
| @@ | @@ -5,19 +5,18 @@ |
| %p | |
| Foundation is made by | |
| = succeed "," do | |
| - | %a{:href => "http://www.zurb.com/"} ZURB |
| - | a product design company in Campbell, California. We've put more than 14 years of experience building web products, services and websites into this framework. |
| - | %a{:href => "http://foundation.zurb.com/about.php"} Foundation Info and Goodies → |
| + | %a{href: "http://www.zurb.com/"} ZURB |
| + | %a{href: "http://foundation.zurb.com/about.php"} Foundation Info and Goodies → |
| .large-3.columns | |
| %h6 | |
| %strong Using Foundation? | |
| %p | |
| Let us know how you're using Foundation and we might feature you as an example! | |
| - | %a{:href => "mailto:foundation@zurb.com?subject=I'm%20using%20Foundation"} Get in touch → |
| + | %a{href: "mailto:foundation@zurb.com?subject=I'm%20using%20Foundation"} Get in touch → |
| .large-4.columns | |
| %h6 | |
| %strong Need some help? | |
| %p | |
| For answers or help visit the | |
| = succeed "." do | |
| - | %a{:href => "http://foundation.zurb.com/docs/support.html"} Support page |
| + | %a{href: "http://foundation.zurb.com/docs/support.html"} Support page |
generators/foundation/public/javascripts/foundation.min.js
+15
-32
| @@ | @@ -1,32 +1,15 @@ |
| - | var libFuncName=null;if(typeof jQuery==="undefined"&&typeof Zepto==="undefined"&&typeof $==="function"){libFuncName=$;}else{if(typeof jQuery==="function"){libFuncName=jQuery; |
| - | }else{if(typeof Zepto==="function"){libFuncName=Zepto;}else{throw new TypeError();}}}(function(c,b,a,d){b.matchMedia=b.matchMedia||(function(i,j){var g,e=i.documentElement,f=e.firstElementChild||e.firstChild,h=i.createElement("body"),k=i.createElement("div"); |
| - | k.id="mq-test-1";k.style.cssText="position:absolute;top:-100em";h.style.background="none";h.appendChild(k);return function(l){k.innerHTML='­<style media="'+l+'"> #mq-test-1 { width: 42px; }</style>'; |
| - | e.insertBefore(h,f);g=k.offsetWidth===42;e.removeChild(h);return{matches:g,media:l};};}(a));if(!Array.prototype.filter){Array.prototype.filter=function(f){if(this==null){throw new TypeError(); |
| - | }var k=Object(this),e=k.length>>>0;if(typeof f!="function"){return;}var j=[],h=arguments[1];for(var g=0;g<e;g++){if(g in k){var l=k[g];if(f&&f.call(h,l,g,k)){j.push(l); |
| - | }}}return j;};}if(!Function.prototype.bind){Function.prototype.bind=function(e){if(typeof this!=="function"){throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable"); |
| - | }var i=Array.prototype.slice.call(arguments,1),h=this,f=function(){},g=function(){return h.apply(this instanceof f&&e?this:e,i.concat(Array.prototype.slice.call(arguments))); |
| - | };f.prototype=this.prototype;g.prototype=new f();return g;};}if(!Array.prototype.indexOf){Array.prototype.indexOf=function(g){if(this==null){throw new TypeError(); |
| - | }var h=Object(this);var e=h.length>>>0;if(e===0){return -1;}var i=0;if(arguments.length>1){i=Number(arguments[1]);if(i!=i){i=0;}else{if(i!=0&&i!=Infinity&&i!=-Infinity){i=(i>0||-1)*Math.floor(Math.abs(i)); |
| - | }}}if(i>=e){return -1;}var f=i>=0?i:Math.max(e-Math.abs(i),0);for(;f<e;f++){if(f in h&&h[f]===g){return f;}}return -1;};}c.fn.stop=c.fn.stop||function(){return this; |
| - | };b.Foundation={name:"Foundation",version:"4.2.0",cache:{},init:function(o,l,e,p,f,h){var j,m=[o,e,p,f],k=[],h=h||false;if(h){this.nc=h;}this.rtl=/rtl/i.test(c("html").attr("dir")); |
| - | this.scope=o||this.scope;if(l&&typeof l==="string"&&!/reflow/i.test(l)){if(/off/i.test(l)){return this.off();}j=l.split(" ");if(j.length>0){for(var g=j.length-1; |
| - | g>=0;g--){k.push(this.init_lib(j[g],m));}}}else{if(/reflow/i.test(l)){m[1]="reflow";}for(var n in this.libs){k.push(this.init_lib(n,m));}}if(typeof l==="function"){m.unshift(l); |
| - | }return this.response_obj(k,m);},response_obj:function(f,g){for(var h=0,e=g.length;h<e;h++){if(typeof g[h]==="function"){return g[h]({errors:f.filter(function(i){if(typeof i==="string"){return i; |
| - | }})});}}return f;},init_lib:function(f,e){return this.trap(function(){if(this.libs.hasOwnProperty(f)){this.patch(this.libs[f]);return this.libs[f].init.apply(this.libs[f],e); |
| - | }else{return function(){};}}.bind(this),f);},trap:function(f,h){if(!this.nc){try{return f();}catch(g){return this.error({name:h,message:"could not be initialized",more:g.name+" "+g.message}); |
| - | }}return f();},patch:function(e){this.fix_outer(e);e.scope=this.scope;e.rtl=this.rtl;},inherit:function(h,f){var e=f.split(" ");for(var g=e.length-1;g>=0; |
| - | g--){if(this.lib_methods.hasOwnProperty(e[g])){this.libs[h.name][e[g]]=this.lib_methods[e[g]];}}},random_str:function(g){var f="0123456789ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz".split(""); |
| - | if(!g){g=Math.floor(Math.random()*f.length);}var h="";for(var e=0;e<g;e++){h+=f[Math.floor(Math.random()*f.length)];}return h;},libs:{},lib_methods:{set_data:function(e,f){var g=[this.name,+new Date(),Foundation.random_str(5)].join("-"); |
| - | Foundation.cache[g]=f;e.attr("data-"+this.name+"-id",g);return f;},get_data:function(e){return Foundation.cache[e.attr("data-"+this.name+"-id")];},remove_data:function(e){if(e){delete Foundation.cache[e.attr("data-"+this.name+"-id")]; |
| - | e.attr("data-"+this.name+"-id","");}else{c("[data-"+this.name+"-id]").each(function(){delete Foundation.cache[c(this).attr("data-"+this.name+"-id")];c(this).attr("data-"+this.name+"-id",""); |
| - | });}},throttle:function(e,f){var g=null;return function(){var i=this,h=arguments;clearTimeout(g);g=setTimeout(function(){e.apply(i,h);},f);};},data_options:function(j){var k={},i,l,h=(j.attr("data-options")||":").split(";"),g=h.length; |
| - | function f(m){return !isNaN(m-0)&&m!==null&&m!==""&&m!==false&&m!==true;}function e(m){if(typeof m==="string"){return c.trim(m);}return m;}for(i=g-1;i>=0; |
| - | i--){l=h[i].split(":");if(/true/i.test(l[1])){l[1]=true;}if(/false/i.test(l[1])){l[1]=false;}if(f(l[1])){l[1]=parseInt(l[1],10);}if(l.length===2&&l[0].length>0){k[e(l[0])]=e(l[1]); |
| - | }}return k;},delay:function(e,f){return setTimeout(e,f);},scrollTo:function(f,i,g){if(g<0){return;}var h=i-c(b).scrollTop();var e=h/g*10;this.scrollToTimerCache=setTimeout(function(){if(!isNaN(parseInt(e,10))){b.scrollTo(0,c(b).scrollTop()+e); |
| - | this.scrollTo(f,i,g-10);}}.bind(this),10);},scrollLeft:function(e){if(!e.length){return;}return("scrollLeft" in e[0])?e[0].scrollLeft:e[0].pageXOffset; |
| - | },empty:function(f){if(f.length&&f.length>0){return false;}if(f.length&&f.length===0){return true;}for(var e in f){if(hasOwnProperty.call(f,e)){return false; |
| - | }}return true;}},fix_outer:function(e){e.outerHeight=function(g,f){if(typeof Zepto==="function"){return g.height();}if(typeof f!=="undefined"){return g.outerHeight(f); |
| - | }return g.outerHeight();};e.outerWidth=function(f){if(typeof Zepto==="function"){return f.width();}if(typeof bool!=="undefined"){return f.outerWidth(bool); |
| - | }return f.outerWidth();};},error:function(e){return e.name+" "+e.message+"; "+e.more;},off:function(){c(this.scope).off(".fndtn");c(b).off(".fndtn");return true; |
| - | },zj:function(){if(typeof Zepto!=="undefined"){return Zepto;}else{return jQuery;}}()};c.fn.foundation=function(){var e=Array.prototype.slice.call(arguments,0); |
| - | return this.each(function(){Foundation.init.apply(Foundation,[this].concat(e));return this;});};}(libFuncName,this,this.document)); |
| \ No newline at end of file | |
| + | /* |
| + | * Foundation Responsive Library |
| + | * http://foundation.zurb.com |
| + | * Copyright 2013, ZURB |
| + | * Free to use under the MIT license. |
| + | * http://www.opensource.org/licenses/mit-license.php |
| + | */ |
| + | /*jslint unparam: true, browser: true, indent: 2 */ |
| + | // Accommodate running jQuery or Zepto in noConflict() mode by |
| + | // using an anonymous function to redefine the $ shorthand name. |
| + | // See http://docs.jquery.com/Using_jQuery_with_Other_Libraries |
| + | // and http://zeptojs.com/ |
| + | var libFuncName=null;if(typeof jQuery=="undefined"&&typeof Zepto=="undefined"&&typeof $=="function")libFuncName=$;else if(typeof jQuery=="function")libFuncName=jQuery;else{if(typeof Zepto!="function")throw new TypeError;libFuncName=Zepto}(function(e,t,n,r){"use strict";e("head").append('<meta class="foundation-mq-small">'),e("head").append('<meta class="foundation-mq-medium">'),e("head").append('<meta class="foundation-mq-large">'),t.matchMedia=t.matchMedia||function(e,t){var n,r=e.documentElement,i=r.firstElementChild||r.firstChild,s=e.createElement("body"),o=e.createElement("div");return o.id="mq-test-1",o.style.cssText="position:absolute;top:-100em",s.style.background="none",s.appendChild(o),function(e){return o.innerHTML='­<style media="'+e+'"> #mq-test-1 { width: 42px; }</style>',r.insertBefore(s,i),n=o.offsetWidth===42,r.removeChild(s),{matches:n,media:e}}}(n),Array.prototype.filter||(Array.prototype.filter=function(e){if(this==null)throw new TypeError;var t=Object(this),n=t.length>>>0;if(typeof e!="function")return;var r=[],i=arguments[1];for(var s=0;s<n;s++)if(s in t){var o=t[s];e&&e.call(i,o,s,t)&&r.push(o)}return r}),Function.prototype.bind||(Function.prototype.bind=function(e){if(typeof this!="function")throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");var t=Array.prototype.slice.call(arguments,1),n=this,r=function(){},i=function(){return n.apply(this instanceof r&&e?this:e,t.concat(Array.prototype.slice.call(arguments)))};return r.prototype=this.prototype,i.prototype=new r,i}),Array.prototype.indexOf||(Array.prototype.indexOf=function(e){if(this==null)throw new TypeError;var t=Object(this),n=t.length>>>0;if(n===0)return-1;var r=0;arguments.length>1&&(r=Number(arguments[1]),r!=r?r=0:r!=0&&r!=Infinity&&r!=-Infinity&&(r=(r>0||-1)*Math.floor(Math.abs(r))));if(r>=n)return-1;var i=r>=0?r:Math.max(n-Math.abs(r),0);for(;i<n;i++)if(i in t&&t[i]===e)return i;return-1}),e.fn.stop=e.fn.stop||function(){return this},t.Foundation={name:"Foundation",version:"4.3.2",cache:{},media_queries:{small:e(".foundation-mq-small").css("font-family").replace(/\'/g,""),medium:e(".foundation-mq-medium").css("font-family").replace(/\'/g,""),large:e(".foundation-mq-large").css("font-family").replace(/\'/g,"")},stylesheet:e("<style></style>").appendTo("head")[0].sheet,init:function(t,n,r,i,s,o){var u,a=[t,r,i,s],f=[],o=o||!1;o&&(this.nc=o),this.rtl=/rtl/i.test(e("html").attr("dir")),this.scope=t||this.scope;if(n&&typeof n=="string"&&!/reflow/i.test(n)){if(/off/i.test(n))return this.off();u=n.split(" ");if(u.length>0)for(var l=u.length-1;l>=0;l--)f.push(this.init_lib(u[l],a))}else{/reflow/i.test(n)&&(a[1]="reflow");for(var c in this.libs)f.push(this.init_lib(c,a))}return typeof n=="function"&&a.unshift(n),this.response_obj(f,a)},response_obj:function(e,t){for(var n=0,r=t.length;n<r;n++)if(typeof t[n]=="function")return t[n]({errors:e.filter(function(e){if(typeof e=="string")return e})});return e},init_lib:function(e,t){return this.trap(function(){return this.libs.hasOwnProperty(e)?(this.patch(this.libs[e]),this.libs[e].init.apply(this.libs[e],t)):function(){}}.bind(this),e)},trap:function(e,t){if(!this.nc)try{return e()}catch(n){return this.error({name:t,message:"could not be initialized",more:n.name+" "+n.message})}return e()},patch:function(e){this.fix_outer(e),e.scope=this.scope,e.rtl=this.rtl},inherit:function(e,t){var n=t.split(" ");for(var r=n.length-1;r>=0;r--)this.lib_methods.hasOwnProperty(n[r])&&(this.libs[e.name][n[r]]=this.lib_methods[n[r]])},random_str:function(e){var t="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");e||(e=Math.floor(Math.random()*t.length));var n="";for(var r=0;r<e;r++)n+=t[Math.floor(Math.random()*t.length)];return n},libs:{},lib_methods:{set_data:function(e,t){var n=[this.name,+(new Date),Foundation.random_str(5)].join("-");return Foundation.cache[n]=t,e.attr("data-"+this.name+"-id",n),t},get_data:function(e){return Foundation.cache[e.attr("data-"+this.name+"-id")]},remove_data:function(t){t?(delete Foundation.cache[t.attr("data-"+this.name+"-id")],t.attr("data-"+this.name+"-id","")):e("[data-"+this.name+"-id]").each(function(){delete Foundation.cache[e(this).attr("data-"+this.name+"-id")],e(this).attr("data-"+this.name+"-id","")})},throttle:function(e,t){var n=null;return function(){var r=this,i=arguments;clearTimeout(n),n=setTimeout(function(){e.apply(r,i)},t)}},data_options:function(t){function u(e){return!isNaN(e-0)&&e!==null&&e!==""&&e!==!1&&e!==!0}function a(t){return typeof t=="string"?e.trim(t):t}var n={},r,i,s=(t.attr("data-options")||":").split(";"),o=s.length;for(r=o-1;r>=0;r--)i=s[r].split(":"),/true/i.test(i[1])&&(i[1]=!0),/false/i.test(i[1])&&(i[1]=!1),u(i[1])&&(i[1]=parseInt(i[1],10)),i.length===2&&i[0].length>0&&(n[a(i[0])]=a(i[1]));return n},delay:function(e,t){return setTimeout(e,t)},scrollTo:function(n,r,i){if(i<0)return;var s=r-e(t).scrollTop(),o=s/i*10;this.scrollToTimerCache=setTimeout(function(){isNaN(parseInt(o,10))||(t.scrollTo(0,e(t).scrollTop()+o),this.scrollTo(n,r,i-10))}.bind(this),10)},scrollLeft:function(e){if(!e.length)return;return"scrollLeft"in e[0]?e[0].scrollLeft:e[0].pageXOffset},empty:function(e){if(e.length&&e.length>0)return!1;if(e.length&&e.length===0)return!0;for(var t in e)if(hasOwnProperty.call(e,t))return!1;return!0},addCustomRule:function(e,t){if(t===r)Foundation.stylesheet.insertRule(e,Foundation.stylesheet.cssRules.length);else{var n=Foundation.media_queries[t];n!==r&&Foundation.stylesheet.insertRule("@media "+Foundation.media_queries[t]+"{ "+e+" }")}}},fix_outer:function(e){e.outerHeight=function(e,t){return typeof Zepto=="function"?e.height():typeof t!="undefined"?e.outerHeight(t):e.outerHeight()},e.outerWidth=function(e,t){return typeof Zepto=="function"?e.width():typeof t!="undefined"?e.outerWidth(t):e.outerWidth()}},error:function(e){return e.name+" "+e.message+"; "+e.more},off:function(){return e(this.scope).off(".fndtn"),e(t).off(".fndtn"),!0},zj:e},e.fn.foundation=function(){var e=Array.prototype.slice.call(arguments,0);return this.each(function(){return Foundation.init.apply(Foundation,[this].concat(e)),this})}})(libFuncName,this,this.document),function(e,t,n,r){"use strict";Foundation.libs.alerts={name:"alerts",version:"4.3.2",settings:{animation:"fadeOut",speed:300,callback:function(){}},init:function(t,n,r){return this.scope=t||this.scope,Foundation.inherit(this,"data_options"),typeof n=="object"&&e.extend(!0,this.settings,n),typeof n!="string"?(this.settings.init||this.events(),this.settings.init):this[n].call(this,r)},events:function(){var t=this;e(this.scope).on("click.fndtn.alerts","[data-alert] a.close",function(n){var r=e(this).closest("[data-alert]"),i=e.extend({},t.settings,t.data_options(r));n.preventDefault(),r[i.animation](i.speed,function(){e(this).remove(),i.callback()})}),this.settings.init=!0},off:function(){e(this.scope).off(".fndtn.alerts")},reflow:function(){}}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";Foundation.libs.clearing={name:"clearing",version:"4.3.2",settings:{templates:{viewing:'<a href="#" class="clearing-close">×</a><div class="visible-img" style="display: none"><img src="//:0"><p class="clearing-caption"></p><a href="#" class="clearing-main-prev"><span></span></a><a href="#" class="clearing-main-next"><span></span></a></div>'},close_selectors:".clearing-close",init:!1,locked:!1},init:function(t,n,r){var i=this;return Foundation.inherit(this,"set_data get_data remove_data throttle data_options"),typeof n=="object"&&(r=e.extend(!0,this.settings,n)),typeof n!="string"?(e(this.scope).find("ul[data-clearing]").each(function(){var t=e(this),n=n||{},r=t.find("li"),s=i.get_data(t);!s&&r.length>0&&(n.$parent=t.parent(),i.set_data(t,e.extend({},i.settings,n,i.data_options(t))),i.assemble(t.find("li")),i.settings.init||i.events().swipe_events())}),this.settings.init):this[n].call(this,r)},events:function(){var n=this;return e(this.scope).on("click.fndtn.clearing","ul[data-clearing] li",function(t,r,i){var r=r||e(this),i=i||r,s=r.next("li"),o=n.get_data(r.parent()),u=e(t.target);t.preventDefault(),o||n.init(),i.hasClass("visible")&&r[0]===i[0]&&s.length>0&&n.is_open(r)&&(i=s,u=i.find("img")),n.open(u,r,i),n.update_paddles(i)}).on("click.fndtn.clearing",".clearing-main-next",function(e){this.nav(e,"next")}.bind(this)).on("click.fndtn.clearing",".clearing-main-prev",function(e){this.nav(e,"prev")}.bind(this)).on("click.fndtn.clearing",this.settings.close_selectors,function(e){Foundation.libs.clearing.close(e,this)}).on("keydown.fndtn.clearing",function(e){this.keydown(e)}.bind(this)),e(t).on("resize.fndtn.clearing",function(){this.resize()}.bind(this)),this.settings.init=!0,this},swipe_events:function(){var t=this;e(this.scope).on("touchstart.fndtn.clearing",".visible-img",function(t){t.touches||(t=t.originalEvent);var n={start_page_x:t.touches[0].pageX,start_page_y:t.touches[0].pageY,start_time:(new Date).getTime(),delta_x:0,is_scrolling:r};e(this).data("swipe-transition",n),t.stopPropagation()}).on("touchmove.fndtn.clearing",".visible-img",function(n){n.touches||(n=n.originalEvent);if(n.touches.length>1||n.scale&&n.scale!==1)return;var r=e(this).data("swipe-transition");typeof r=="undefined"&&(r={}),r.delta_x=n.touches[0].pageX-r.start_page_x,typeof r.is_scrolling=="undefined"&&(r.is_scrolling=!!(r.is_scrolling||Math.abs(r.delta_x)<Math.abs(n.touches[0].pageY-r.start_page_y)));if(!r.is_scrolling&&!r.active){n.preventDefault();var i=r.delta_x<0?"next":"prev";r.active=!0,t.nav(n,i)}}).on("touchend.fndtn.clearing",".visible-img",function(t){e(this).data("swipe-transition",{}),t.stopPropagation()})},assemble:function(t){var n=t.parent();n.after('<div id="foundationClearingHolder"></div>');var r=e("#foundationClearingHolder"),i=this.get_data(n),s=n.detach(),o={grid:'<div class="carousel">'+this.outerHTML(s[0])+"</div>",viewing:i.templates.viewing},u='<div class="clearing-assembled"><div>'+o.viewing+o.grid+"</div></div>";return r.after(u).remove()},open:function(e,t,n){var r=n.closest(".clearing-assembled"),i=r.find("div").first(),s=i.find(".visible-img"),o=s.find("img").not(e);this.locked()||(o.attr("src",this.load(e)).css("visibility","hidden"),this.loaded(o,function(){o.css("visibility","visible"),r.addClass("clearing-blackout"),i.addClass("clearing-container"),s.show(),this.fix_height(n).caption(s.find(".clearing-caption"),e).center(o).shift(t,n,function(){n.siblings().removeClass("visible"),n.addClass("visible")})}.bind(this)))},close:function(t,n){t.preventDefault();var r=function(e){return/blackout/.test(e.selector)?e:e.closest(".clearing-blackout")}(e(n)),i,s;return n===t.target&&r&&(i=r.find("div").first(),s=i.find(".visible-img"),this.settings.prev_index=0,r.find("ul[data-clearing]").attr("style","").closest(".clearing-blackout").removeClass("clearing-blackout"),i.removeClass("clearing-container"),s.hide()),!1},is_open:function(e){return e.parent().prop("style").length>0},keydown:function(t){var n=e(".clearing-blackout").find("ul[data-clearing]");t.which===39&&this.go(n,"next"),t.which===37&&this.go(n,"prev"),t.which===27&&e("a.clearing-close").trigger("click")},nav:function(t,n){var r=e(".clearing-blackout").find("ul[data-clearing]");t.preventDefault(),this.go(r,n)},resize:function(){var t=e(".clearing-blackout .visible-img").find("img");t.length&&this.center(t)},fix_height:function(t){var n=t.parent().children(),r=this;return n.each(function(){var t=e(this),n=t.find("img");t.height()>r.outerHeight(n)&&t.addClass("fix-height")}).closest("ul").width(n.length*100+"%"),this},update_paddles:function(e){var t=e.closest(".carousel").siblings(".visible-img");e.next().length>0?t.find(".clearing-main-next").removeClass("disabled"):t.find(".clearing-main-next").addClass("disabled"),e.prev().length>0?t.find(".clearing-main-prev").removeClass("disabled"):t.find(".clearing-main-prev").addClass("disabled")},center:function(e){return this.rtl?e.css({marginRight:-(this.outerWidth(e)/2),marginTop:-(this.outerHeight(e)/2)}):e.css({marginLeft:-(this.outerWidth(e)/2),marginTop:-(this.outerHeight(e)/2)}),this},load:function(e){if(e[0].nodeName==="A")var t=e.attr("href");else var t=e.parent().attr("href");return this.preload(e),t?t:e.attr("src")},preload:function(e){this.img(e.closest("li").next()).img(e.closest("li").prev())},loaded:function(e,t){function n(){t()}function r(){this.one("load",n);if(/MSIE (\d+\.\d+);/.test(navigator.userAgent)){var e=this.attr("src"),t=e.match(/\?/)?"&":"?";t+="random="+(new Date).getTime(),this.attr("src",e+t)}}if(!e.attr("src")){n();return}e[0].complete||e[0].readyState===4?n():r.call(e)},img:function(e){if(e.length){var t=new Image,n=e.find("a");n.length?t.src=n.attr("href"):t.src=e.find("img").attr("src")}return this},caption:function(e,t){var n=t.data("caption");return n?e.html(n).show():e.text("").hide(),this},go:function(e,t){var n=e.find(".visible"),r=n[t]();r.length&&r.find("img").trigger("click",[n,r])},shift:function(e,t,n){var r=t.parent(),i=this.settings.prev_index||t.index(),s=this.direction(r,e,t),o=parseInt(r.css("left"),10),u=this.outerWidth(t),a;t.index()!==i&&!/skip/.test(s)?/left/.test(s)?(this.lock(),r.animate({left:o+u},300,this.unlock())):/right/.test(s)&&(this.lock(),r.animate({left:o-u},300,this.unlock())):/skip/.test(s)&&(a=t.index()-this.settings.up_count,this.lock(),a>0?r.animate({left:-(a*u)},300,this.unlock()):r.animate({left:0},300,this.unlock())),n()},direction:function(t,n,r){var i=t.find("li"),s=this.outerWidth(i)+this.outerWidth(i)/4,o=Math.floor(this.outerWidth(e(".clearing-container"))/s)-1,u=i.index(r),a;return this.settings.up_count=o,this.adjacent(this.settings.prev_index,u)?u>o&&u>this.settings.prev_index?a="right":u>o-1&&u<=this.settings.prev_index?a="left":a=!1:a="skip",this.settings.prev_index=u,a},adjacent:function(e,t){for(var n=t+1;n>=t-1;n--)if(n===e)return!0;return!1},lock:function(){this.settings.locked=!0},unlock:function(){this.settings.locked=!1},locked:function(){return this.settings.locked},outerHTML:function(e){return e.outerHTML||(new XMLSerializer).serializeToString(e)},off:function(){e(this.scope).off(".fndtn.clearing"),e(t).off(".fndtn.clearing"),this.remove_data(),this.settings.init=!1},reflow:function(){this.init()}}}(Foundation.zj,this,this.document),function(e,t,n){function i(e){return e}function s(e){return decodeURIComponent(e.replace(r," "))}var r=/\+/g,o=e.cookie=function(r,u,a){if(u!==n){a=e.extend({},o.defaults,a),u===null&&(a.expires=-1);if(typeof a.expires=="number"){var f=a.expires,l=a.expires=new Date;l.setDate(l.getDate()+f)}return u=o.json?JSON.stringify(u):String(u),t.cookie=[encodeURIComponent(r),"=",o.raw?u:encodeURIComponent(u),a.expires?"; expires="+a.expires.toUTCString():"",a.path?"; path="+a.path:"",a.domain?"; domain="+a.domain:"",a.secure?"; secure":""].join("")}var c=o.raw?i:s,h=t.cookie.split("; ");for(var p=0,d=h.length;p<d;p++){var v=h[p].split("=");if(c(v.shift())===r){var m=c(v.join("="));return o.json?JSON.parse(m):m}}return null};o.defaults={},e.removeCookie=function(t,n){return e.cookie(t)!==null?(e.cookie(t,null,n),!0):!1}}(Foundation.zj,document),function(e,t,n,r){"use strict";Foundation.libs.dropdown={name:"dropdown",version:"4.3.2",settings:{activeClass:"open",is_hover:!1,opened:function(){},closed:function(){}},init:function(t,n,r){return this.scope=t||this.scope,Foundation.inherit(this,"throttle scrollLeft data_options"),typeof n=="object"&&e.extend(!0,this.settings,n),typeof n!="string"?(this.settings.init||this.events(),this.settings.init):this[n].call(this,r)},events:function(){var r=this;e(this.scope).on("click.fndtn.dropdown","[data-dropdown]",function(t){var n=e.extend({},r.settings,r.data_options(e(this)));t.preventDefault(),n.is_hover||r.toggle(e(this))}).on("mouseenter","[data-dropdown]",function(t){var n=e.extend({},r.settings,r.data_options(e(this)));n.is_hover&&r.toggle(e(this))}).on("mouseleave","[data-dropdown-content]",function(t){var n=e('[data-dropdown="'+e(this).attr("id")+'"]'),i=e.extend({},r.settings,r.data_options(n));i.is_hover&&r.close.call(r,e(this))}).on("opened.fndtn.dropdown","[data-dropdown-content]",this.settings.opened).on("closed.fndtn.dropdown","[data-dropdown-content]",this.settings.closed),e(n).on("click.fndtn.dropdown",function(t){var n=e(t.target).closest("[data-dropdown-content]");if(e(t.target).data("dropdown")||e(t.target).parent().data("dropdown"))return;if(!e(t.target).data("revealId")&&n.length>0&&(e(t.target).is("[data-dropdown-content]")||e.contains(n.first()[0],t.target))){t.stopPropagation();return}r.close.call(r,e("[data-dropdown-content]"))}),e(t).on("resize.fndtn.dropdown",r.throttle(function(){r.resize.call(r)},50)).trigger("resize"),this.settings.init=!0},close:function(t){var n=this;t.each(function(){e(this).hasClass(n.settings.activeClass)&&(e(this).css(Foundation.rtl?"right":"left","-99999px").removeClass(n.settings.activeClass),e(this).trigger("closed"))})},open:function(e,t){this.css(e.addClass(this.settings.activeClass),t),e.trigger("opened")},toggle:function(t){var n=e("#"+t.data("dropdown"));if(n.length===0)return;this.close.call(this,e("[data-dropdown-content]").not(n)),n.hasClass(this.settings.activeClass)?this.close.call(this,n):(this.close.call(this,e("[data-dropdown-content]")),this.open.call(this,n,t))},resize:function(){var t=e("[data-dropdown-content].open"),n=e("[data-dropdown='"+t.attr("id")+"']");t.length&&n.length&&this.css(t,n)},css:function(n,r){var i=n.offsetParent(),s=r.offset();s.top-=i.offset().top,s.left-=i.offset().left;if(this.small())n.css({position:"absolute",width:"95%","max-width":"none",top:s.top+this.outerHeight(r)}),n.css(Foundation.rtl?"right":"left","2.5%");else{if(!Foundation.rtl&&e(t).width()>this.outerWidth(n)+r.offset().left&&!this.data_options(r).align_right){var o=s.left;n.hasClass("right")&&n.removeClass("right")}else{n.hasClass("right")||n.addClass("right");var o=s.left-(this.outerWidth(n)-this.outerWidth(r))}n.attr("style","").css({position:"absolute",top:s.top+this.outerHeight(r),left:o})}return n},small:function(){return e(t).width()<768||e("html").hasClass("lt-ie9")},off:function(){e(this.scope).off(".fndtn.dropdown"),e("html, body").off(".fndtn.dropdown"),e(t).off(".fndtn.dropdown"),e("[data-dropdown-content]").off(".fndtn.dropdown"),this.settings.init=!1},reflow:function(){}}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";Foundation.libs.forms={name:"forms",version:"4.3.2",cache:{},settings:{disable_class:"no-custom",last_combo:null},init:function(t,n,r){return typeof n=="object"&&e.extend(!0,this.settings,n),typeof n!="string"?(this.settings.init||this.events(),this.assemble(),this.settings.init):this[n].call(this,r)},assemble:function(){var t=this;e('form.custom input[type="radio"],[type="checkbox"]',e(this.scope)).not('[data-customforms="disabled"]').not("."+this.settings.disable_class).each(function(e,n){t.set_custom_markup(n)}).change(function(){t.set_custom_markup(this)}),e("form.custom select",e(this.scope)).not('[data-customforms="disabled"]').not("."+this.settings.disable_class).not("[multiple=multiple]").each(this.append_custom_select)},events:function(){var r=this;e(this.scope).on("click.fndtn.forms","form.custom span.custom.checkbox",function(t){t.preventDefault(),t.stopPropagation(),r.toggle_checkbox(e(this))}).on("click.fndtn.forms","form.custom span.custom.radio",function(t){t.preventDefault(),t.stopPropagation(),r.toggle_radio(e(this))}).on("change.fndtn.forms","form.custom select",function(t,n){if(e(this).is('[data-customforms="disabled"]'))return;r.refresh_custom_select(e(this),n)}).on("click.fndtn.forms","form.custom label",function(t){if(e(t.target).is("label")){var n=e("#"+r.escape(e(this).attr("for"))).not('[data-customforms="disabled"]'),i,s;n.length!==0&&(n.attr("type")==="checkbox"?(t.preventDefault(),i=e(this).find("span.custom.checkbox"),i.length===0&&(i=n.add(this).siblings("span.custom.checkbox").first()),r.toggle_checkbox(i)):n.attr("type")==="radio"&&(t.preventDefault(),s=e(this).find("span.custom.radio"),s.length===0&&(s=n.add(this).siblings("span.custom.radio").first()),r.toggle_radio(s)))}}).on("mousedown.fndtn.forms","form.custom div.custom.dropdown",function(){return!1}).on("click.fndtn.forms","form.custom div.custom.dropdown a.current, form.custom div.custom.dropdown a.selector",function(t){var n=e(this),s=n.closest("div.custom.dropdown"),o=i(s,"select");s.hasClass("open")||e(r.scope).trigger("click"),t.preventDefault();if(!1===o.is(":disabled"))return s.toggleClass("open"),s.hasClass("open")?e(r.scope).on("click.fndtn.forms.customdropdown",function(){s.removeClass("open"),e(r.scope).off(".fndtn.forms.customdropdown")}):e(r.scope).on(".fndtn.forms.customdropdown"),!1}).on("click.fndtn.forms touchend.fndtn.forms","form.custom div.custom.dropdown li",function(t){var r=e(this),s=r.closest("div.custom.dropdown"),o=i(s,"select"),u=0;t.preventDefault(),t.stopPropagation();if(!e(this).hasClass("disabled")){e("div.dropdown").not(s).removeClass("open");var a=r.closest("ul").find("li.selected");a.removeClass("selected"),r.addClass("selected"),s.removeClass("open").find("a.current").text(r.text()),r.closest("ul").find("li").each(function(e){r[0]===this&&(u=e)}),o[0].selectedIndex=u,o.data("prevalue",a.html());if(typeof n.createEvent!="undefined"){var f=n.createEvent("HTMLEvents");f.initEvent("change",!0,!0),o[0].dispatchEvent(f)}else o[0].fireEvent("onchange")}}),e(t).on("keydown",function(t){var r=n.activeElement,s=Foundation.libs.forms,o=e(".custom.dropdown"),u=i(o,"select"),a=e("input,select,textarea,button");if(o.length>0&&o.hasClass("open")){t.preventDefault(),t.which===9&&(e(a[e(a).index(u)+1]).focus(),o.removeClass("open")),t.which===13&&o.find("li.selected").trigger("click"),t.which===27&&o.removeClass("open");if(t.which>=65&&t.which<=90){var f=s.go_to(o,t.which),l=o.find("li.selected");f&&(l.removeClass("selected"),s.scrollTo(f.addClass("selected"),300))}if(t.which===38){var l=o.find("li.selected"),c=l.prev(":not(.disabled)");c.length>0&&(c.parent()[0].scrollTop=c.parent().scrollTop()-s.outerHeight(c),l.removeClass("selected"),c.addClass("selected"))}else if(t.which===40){var l=o.find("li.selected"),f=l.next(":not(.disabled)");f.length>0&&(f.parent()[0].scrollTop=f.parent().scrollTop()+s.outerHeight(f),l.removeClass("selected"),f.addClass("selected"))}}}),e(t).on("keyup",function(t){var r=n.activeElement,i=e(".custom.dropdown");r===i.find(".current")[0]&&i.find(".selector").focus().click()}),this.settings.init=!0},go_to:function(e,t){var n=e.find("li"),r=n.length;if(r>0)for(var i=0;i<r;i++){var s=n.eq(i).text().charAt(0).toLowerCase();if(s===String.fromCharCode(t).toLowerCase())return n.eq(i)}},scrollTo:function(e,t){if(t<0)return;var n=e.parent(),r=this.outerHeight(e),i=r*e.index()-n.scrollTop(),s=i/t*10;this.scrollToTimerCache=setTimeout(function(){isNaN(parseInt(s,10))||(n[0].scrollTop=n.scrollTop()+s,this.scrollTo(e,t-10))}.bind(this),10)},set_custom_markup:function(t){var n=e(t),r=n.attr("type"),i=n.next("span.custom."+r);n.parent().hasClass("switch")||n.addClass("hidden-field"),i.length===0&&(i=e('<span class="custom '+r+'"></span>').insertAfter(n)),i.toggleClass("checked",n.is(":checked")),i.toggleClass("disabled",n.is(":disabled"))},append_custom_select:function(t,n){var r=Foundation.libs.forms,i=e(n),s=i.next("div.custom.dropdown"),o=s.find("ul"),u=s.find(".current"),a=s.find(".selector"),f=i.find("option"),l=f.filter(":selected"),c=i.attr("class")?i.attr("class").split(" "):[],h=0,p="",d,v=!1;if(s.length===0){var m=i.hasClass("small")?"small":i.hasClass("medium")?"medium":i.hasClass("large")?"large":i.hasClass("expand")?"expand":"";s=e('<div class="'+["custom","dropdown",m].concat(c).filter(function(e,t,n){return e===""?!1:n.indexOf(e)===t}).join(" ")+'"><a href="#" class="selector"></a><ul /></div>'),a=s.find(".selector"),o=s.find("ul"),p=f.map(function(){var t=e(this).attr("class")?e(this).attr("class"):"";return"<li class='"+t+"'>"+e(this).html()+"</li>"}).get().join(""),o.append(p),v=s.prepend('<a href="#" class="current">'+(l.html()||"")+"</a>").find(".current"),i.after(s).addClass("hidden-field")}else p=f.map(function(){return"<li>"+e(this).html()+"</li>"}).get().join(""),o.html("").append(p);r.assign_id(i,s),s.toggleClass("disabled",i.is(":disabled")),d=o.find("li"),r.cache[s.data("id")]=d.length,f.each(function(t){this.selected&&(d.eq(t).addClass("selected"),v&&v.html(e(this).html())),e(this).is(":disabled")&&d.eq(t).addClass("disabled")});if(!s.is(".small, .medium, .large, .expand")){s.addClass("open");var r=Foundation.libs.forms;r.hidden_fix.adjust(o),h=r.outerWidth(d)>h?r.outerWidth(d):h,Foundation.libs.forms.hidden_fix.reset(),s.removeClass("open")}},assign_id:function(e,t){var n=[+(new Date),Foundation.random_str(5)].join("-");e.attr("data-id",n),t.attr("data-id",n)},refresh_custom_select:function(t,n){var r=this,i=0,s=t.next(),o=t.find("option"),u=s.find("ul"),a=s.find("li");if(o.length!==this.cache[s.data("id")]||n){u.html("");var f="";o.each(function(){var t=e(this),n=t.html(),r=this.selected;f+='<li class="'+(r?" selected ":"")+(t.is(":disabled")?" disabled ":"")+'">'+n+"</li>",r&&s.find(".current").html(n)}),u.html(f),s.removeAttr("style"),u.removeAttr("style"),s.find("li").each(function(){s.addClass("open"),r.outerWidth(e(this))>i&&(i=r.outerWidth(e(this))),s.removeClass("open")}),a=s.find("li"),this.cache[s.data("id")]=a.length}},refresh_custom_selection:function(t){var n=e("option:selected",t).text();e("a.current",t.next()).text(n)},toggle_checkbox:function(e){var t=e.prev(),n=t[0];!1===t.is(":disabled")&&(n.checked=n.checked?!1:!0,e.toggleClass("checked"),t.trigger("change"))},toggle_radio:function(e){var t=e.prev(),n=t.closest("form.custom"),r=t[0];!1===t.is(":disabled")&&(n.find('input[type="radio"][name="'+this.escape(t.attr("name"))+'"]').next().not(e).removeClass("checked"),e.hasClass("checked")||e.toggleClass("checked"),r.checked=e.hasClass("checked"),t.trigger("change"))},escape:function(e){return e?e.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"):""},hidden_fix:{tmp:[],hidden:null,adjust:function(t){var n=this;n.hidden=t.parents(),n.hidden=n.hidden.add(t).filter(":hidden"),n.hidden.each(function(){var t=e(this);n.tmp.push(t.attr("style")),t.css({visibility:"hidden",display:"block"})})},reset:function(){var t=this;t.hidden.each(function(n){var i=e(this),s=t.tmp[n];s===r?i.removeAttr("style"):i.attr("style",s)}),t.tmp=[],t.hidden=null}},off:function(){e(this.scope).off(".fndtn.forms")},reflow:function(){}};var i=function(t,n){var t=t.prev();while(t.length){if(t.is(n))return t;t=t.prev()}return e()}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";var i=i||!1;Foundation.libs.joyride={name:"joyride",version:"4.3.2",defaults:{expose:!1,modal:!1,tipLocation:"bottom",nubPosition:"auto",scrollSpeed:300,timer:0,startTimerOnClick:!0,startOffset:0,nextButton:!0,tipAnimation:"fade",pauseAfter:[],exposed:[],tipAnimationFadeSpeed:300,cookieMonster:!1,cookieName:"joyride",cookieDomain:!1,cookieExpires:365,tipContainer:"body",postRideCallback:function(){},postStepCallback:function(){},preStepCallback:function(){},preRideCallback:function(){},postExposeCallback:function(){},template:{link:'<a href="#close" class="joyride-close-tip">×</a>',timer:'<div class="joyride-timer-indicator-wrap"><span class="joyride-timer-indicator"></span></div>',tip:'<div class="joyride-tip-guide"><span class="joyride-nub"></span></div>',wrapper:'<div class="joyride-content-wrapper"></div>',button:'<a href="#" class="small button joyride-next-tip"></a>',modal:'<div class="joyride-modal-bg"></div>',expose:'<div class="joyride-expose-wrapper"></div>',exposeCover:'<div class="joyride-expose-cover"></div>'},exposeAddClass:""},settings:{},init:function(t,n,r){return this.scope=t||this.scope,Foundation.inherit(this,"throttle data_options scrollTo scrollLeft delay"),typeof n=="object"?e.extend(!0,this.settings,this.defaults,n):e.extend(!0,this.settings,this.defaults,r),typeof n!="string"?(this.settings.init||this.events(),this.settings.init):this[n].call(this,r)},events:function(){var n=this;e(this.scope).on("click.joyride",".joyride-next-tip, .joyride-modal-bg",function(e){e.preventDefault(),this.settings.$li.next().length<1?this.end():this.settings.timer>0?(clearTimeout(this.settings.automate),this.hide(),this.show(),this.startTimer()):(this.hide(),this.show())}.bind(this)).on("click.joyride",".joyride-close-tip",function(e){e.preventDefault(),this.end()}.bind(this)),e(t).on("resize.fndtn.joyride",n.throttle(function(){if(e("[data-joyride]").length>0&&n.settings.$next_tip){if(n.settings.exposed.length>0){var t=e(n.settings.exposed);t.each(function(){var t=e(this);n.un_expose(t),n.expose(t)})}n.is_phone()?n.pos_phone():n.pos_default(!1,!0)}},100)),this.settings.init=!0},start:function(){var t=this,n=e(this.scope).find("[data-joyride]"),r=["timer","scrollSpeed","startOffset","tipAnimationFadeSpeed","cookieExpires"],i=r.length;this.settings.init||this.events(),this.settings.$content_el=n,this.settings.$body=e(this.settings.tipContainer),this.settings.body_offset=e(this.settings.tipContainer).position(),this.settings.$tip_content=this.settings.$content_el.find("> li"),this.settings.paused=!1,this.settings.attempts=0,this.settings.tipLocationPatterns={top:["bottom"],bottom:[],left:["right","top","bottom"],right:["left","top","bottom"]},typeof e.cookie!="function"&&(this.settings.cookieMonster=!1);if(!this.settings.cookieMonster||this.settings.cookieMonster&&e.cookie(this.settings.cookieName)===null)this.settings.$tip_content.each(function(n){var s=e(this);e.extend(!0,t.settings,t.data_options(s));for(var o=i-1;o>=0;o--)t.settings[r[o]]=parseInt(t.settings[r[o]],10);t.create({$li:s,index:n})}),!this.settings.startTimerOnClick&&this.settings.timer>0?(this.show("init"),this.startTimer()):this.show("init")},resume:function(){this.set_li(),this.show()},tip_template:function(t){var n,r;return t.tip_class=t.tip_class||"",n=e(this.settings.template.tip).addClass(t.tip_class),r=e.trim(e(t.li).html())+this.button_text(t.button_text)+this.settings.template.link+this.timer_instance(t.index),n.append(e(this.settings.template.wrapper)),n.first().attr("data-index",t.index),e(".joyride-content-wrapper",n).append(r),n[0]},timer_instance:function(t){var n;return t===0&&this.settings.startTimerOnClick&&this.settings.timer>0||this.settings.timer===0?n="":n=this.outerHTML(e(this.settings.template.timer)[0]),n},button_text:function(t){return this.settings.nextButton?(t=e.trim(t)||"Next",t=this.outerHTML(e(this.settings.template.button).append(t)[0])):t="",t},create:function(t){var n=t.$li.attr("data-button")||t.$li.attr("data-text"),r=t.$li.attr("class"),i=e(this.tip_template({tip_class:r,index:t.index,button_text:n,li:t.$li}));e(this.settings.tipContainer).append(i)},show:function(t){var n=null;this.settings.$li===r||e.inArray(this.settings.$li.index(),this.settings.pauseAfter)===-1?(this.settings.paused?this.settings.paused=!1:this.set_li(t),this.settings.attempts=0,this.settings.$li.length&&this.settings.$target.length>0?(t&&(this.settings.preRideCallback(this.settings.$li.index(),this.settings.$next_tip),this.settings.modal&&this.show_modal()),this.settings.preStepCallback(this.settings.$li.index(),this.settings.$next_tip),this.settings.modal&&this.settings.expose&&this.expose(),this.settings.tipSettings=e.extend(this.settings,this.data_options(this.settings.$li)),this.settings.timer=parseInt(this.settings.timer,10),this.settings.tipSettings.tipLocationPattern=this.settings.tipLocationPatterns[this.settings.tipSettings.tipLocation],/body/i.test(this.settings.$target.selector)||this.scroll_to(),this.is_phone()?this.pos_phone(!0):this.pos_default(!0),n=this.settings.$next_tip.find(".joyride-timer-indicator"),/pop/i.test(this.settings.tipAnimation)?(n.width(0),this.settings.timer>0?(this.settings.$next_tip.show(),this.delay(function(){n.animate({width:n.parent().width()},this.settings.timer,"linear")}.bind(this),this.settings.tipAnimationFadeSpeed)):this.settings.$next_tip.show()):/fade/i.test(this.settings.tipAnimation)&&(n.width(0),this.settings.timer>0?(this.settings.$next_tip.fadeIn(this.settings.tipAnimationFadeSpeed).show(),this.delay(function(){n.animate({width:n.parent().width()},this.settings.timer,"linear")}.bind(this),this.settings |
| + | .tipAnimationFadeSpeed)):this.settings.$next_tip.fadeIn(this.settings.tipAnimationFadeSpeed)),this.settings.$current_tip=this.settings.$next_tip):this.settings.$li&&this.settings.$target.length<1?this.show():this.end()):this.settings.paused=!0},is_phone:function(){return i?i.mq("only screen and (max-width: 767px)")||e(".lt-ie9").length>0:e(t).width()<767},hide:function(){this.settings.modal&&this.settings.expose&&this.un_expose(),this.settings.modal||e(".joyride-modal-bg").hide(),this.settings.$current_tip.css("visibility","hidden"),setTimeout(e.proxy(function(){this.hide(),this.css("visibility","visible")},this.settings.$current_tip),0),this.settings.postStepCallback(this.settings.$li.index(),this.settings.$current_tip)},set_li:function(e){e?(this.settings.$li=this.settings.$tip_content.eq(this.settings.startOffset),this.set_next_tip(),this.settings.$current_tip=this.settings.$next_tip):(this.settings.$li=this.settings.$li.next(),this.set_next_tip()),this.set_target()},set_next_tip:function(){this.settings.$next_tip=e(".joyride-tip-guide[data-index='"+this.settings.$li.index()+"']"),this.settings.$next_tip.data("closed","")},set_target:function(){var t=this.settings.$li.attr("data-class"),r=this.settings.$li.attr("data-id"),i=function(){return r?e(n.getElementById(r)):t?e("."+t).first():e("body")};this.settings.$target=i()},scroll_to:function(){var n,r;n=e(t).height()/2,r=Math.ceil(this.settings.$target.offset().top-n+this.outerHeight(this.settings.$next_tip)),r>0&&this.scrollTo(e("html, body"),r,this.settings.scrollSpeed)},paused:function(){return e.inArray(this.settings.$li.index()+1,this.settings.pauseAfter)===-1},restart:function(){this.hide(),this.settings.$li=r,this.show("init")},pos_default:function(n,r){var i=Math.ceil(e(t).height()/2),s=this.settings.$next_tip.offset(),o=this.settings.$next_tip.find(".joyride-nub"),u=Math.ceil(this.outerWidth(o)/2),a=Math.ceil(this.outerHeight(o)/2),f=n||!1;f&&(this.settings.$next_tip.css("visibility","hidden"),this.settings.$next_tip.show()),typeof r=="undefined"&&(r=!1);if(!/body/i.test(this.settings.$target.selector)){if(this.bottom()){var l=this.settings.$target.offset().left;Foundation.rtl&&(l=this.settings.$target.offset().width-this.settings.$next_tip.width()+l),this.settings.$next_tip.css({top:this.settings.$target.offset().top+a+this.outerHeight(this.settings.$target),left:l}),this.nub_position(o,this.settings.tipSettings.nubPosition,"top")}else if(this.top()){var l=this.settings.$target.offset().left;Foundation.rtl&&(l=this.settings.$target.offset().width-this.settings.$next_tip.width()+l),this.settings.$next_tip.css({top:this.settings.$target.offset().top-this.outerHeight(this.settings.$next_tip)-a,left:l}),this.nub_position(o,this.settings.tipSettings.nubPosition,"bottom")}else this.right()?(this.settings.$next_tip.css({top:this.settings.$target.offset().top,left:this.outerWidth(this.settings.$target)+this.settings.$target.offset().left+u}),this.nub_position(o,this.settings.tipSettings.nubPosition,"left")):this.left()&&(this.settings.$next_tip.css({top:this.settings.$target.offset().top,left:this.settings.$target.offset().left-this.outerWidth(this.settings.$next_tip)-u}),this.nub_position(o,this.settings.tipSettings.nubPosition,"right"));!this.visible(this.corners(this.settings.$next_tip))&&this.settings.attempts<this.settings.tipSettings.tipLocationPattern.length&&(o.removeClass("bottom").removeClass("top").removeClass("right").removeClass("left"),this.settings.tipSettings.tipLocation=this.settings.tipSettings.tipLocationPattern[this.settings.attempts],this.settings.attempts++,this.pos_default())}else this.settings.$li.length&&this.pos_modal(o);f&&(this.settings.$next_tip.hide(),this.settings.$next_tip.css("visibility","visible"))},pos_phone:function(t){var n=this.outerHeight(this.settings.$next_tip),r=this.settings.$next_tip.offset(),i=this.outerHeight(this.settings.$target),s=e(".joyride-nub",this.settings.$next_tip),o=Math.ceil(this.outerHeight(s)/2),u=t||!1;s.removeClass("bottom").removeClass("top").removeClass("right").removeClass("left"),u&&(this.settings.$next_tip.css("visibility","hidden"),this.settings.$next_tip.show()),/body/i.test(this.settings.$target.selector)?this.settings.$li.length&&this.pos_modal(s):this.top()?(this.settings.$next_tip.offset({top:this.settings.$target.offset().top-n-o}),s.addClass("bottom")):(this.settings.$next_tip.offset({top:this.settings.$target.offset().top+i+o}),s.addClass("top")),u&&(this.settings.$next_tip.hide(),this.settings.$next_tip.css("visibility","visible"))},pos_modal:function(e){this.center(),e.hide(),this.show_modal()},show_modal:function(){if(!this.settings.$next_tip.data("closed")){var t=e(".joyride-modal-bg");t.length<1&&e("body").append(this.settings.template.modal).show(),/pop/i.test(this.settings.tipAnimation)?t.show():t.fadeIn(this.settings.tipAnimationFadeSpeed)}},expose:function(){var n,r,i,s,o,u="expose-"+Math.floor(Math.random()*1e4);if(arguments.length>0&&arguments[0]instanceof e)i=arguments[0];else{if(!this.settings.$target||!!/body/i.test(this.settings.$target.selector))return!1;i=this.settings.$target}if(i.length<1)return t.console&&console.error("element not valid",i),!1;n=e(this.settings.template.expose),this.settings.$body.append(n),n.css({top:i.offset().top,left:i.offset().left,width:this.outerWidth(i,!0),height:this.outerHeight(i,!0)}),r=e(this.settings.template.exposeCover),s={zIndex:i.css("z-index"),position:i.css("position")},o=i.attr("class")==null?"":i.attr("class"),i.css("z-index",parseInt(n.css("z-index"))+1),s.position=="static"&&i.css("position","relative"),i.data("expose-css",s),i.data("orig-class",o),i.attr("class",o+" "+this.settings.exposeAddClass),r.css({top:i.offset().top,left:i.offset().left,width:this.outerWidth(i,!0),height:this.outerHeight(i,!0)}),this.settings.$body.append(r),n.addClass(u),r.addClass(u),i.data("expose",u),this.settings.postExposeCallback(this.settings.$li.index(),this.settings.$next_tip,i),this.add_exposed(i)},un_expose:function(){var n,r,i,s,o,u=!1;if(arguments.length>0&&arguments[0]instanceof e)r=arguments[0];else{if(!this.settings.$target||!!/body/i.test(this.settings.$target.selector))return!1;r=this.settings.$target}if(r.length<1)return t.console&&console.error("element not valid",r),!1;n=r.data("expose"),i=e("."+n),arguments.length>1&&(u=arguments[1]),u===!0?e(".joyride-expose-wrapper,.joyride-expose-cover").remove():i.remove(),s=r.data("expose-css"),s.zIndex=="auto"?r.css("z-index",""):r.css("z-index",s.zIndex),s.position!=r.css("position")&&(s.position=="static"?r.css("position",""):r.css("position",s.position)),o=r.data("orig-class"),r.attr("class",o),r.removeData("orig-classes"),r.removeData("expose"),r.removeData("expose-z-index"),this.remove_exposed(r)},add_exposed:function(t){this.settings.exposed=this.settings.exposed||[],t instanceof e||typeof t=="object"?this.settings.exposed.push(t[0]):typeof t=="string"&&this.settings.exposed.push(t)},remove_exposed:function(t){var n,r;t instanceof e?n=t[0]:typeof t=="string"&&(n=t),this.settings.exposed=this.settings.exposed||[],r=this.settings.exposed.length;for(var i=0;i<r;i++)if(this.settings.exposed[i]==n){this.settings.exposed.splice(i,1);return}},center:function(){var n=e(t);return this.settings.$next_tip.css({top:(n.height()-this.outerHeight(this.settings.$next_tip))/2+n.scrollTop(),left:(n.width()-this.outerWidth(this.settings.$next_tip))/2+this.scrollLeft(n)}),!0},bottom:function(){return/bottom/i.test(this.settings.tipSettings.tipLocation)},top:function(){return/top/i.test(this.settings.tipSettings.tipLocation)},right:function(){return/right/i.test(this.settings.tipSettings.tipLocation)},left:function(){return/left/i.test(this.settings.tipSettings.tipLocation)},corners:function(n){var r=e(t),i=r.height()/2,s=Math.ceil(this.settings.$target.offset().top-i+this.settings.$next_tip.outerHeight()),o=r.width()+this.scrollLeft(r),u=r.height()+s,a=r.height()+r.scrollTop(),f=r.scrollTop();return s<f&&(s<0?f=0:f=s),u>a&&(a=u),[n.offset().top<f,o<n.offset().left+n.outerWidth(),a<n.offset().top+n.outerHeight(),this.scrollLeft(r)>n.offset().left]},visible:function(e){var t=e.length;while(t--)if(e[t])return!1;return!0},nub_position:function(e,t,n){t==="auto"?e.addClass(n):e.addClass(t)},startTimer:function(){this.settings.$li.length?this.settings.automate=setTimeout(function(){this.hide(),this.show(),this.startTimer()}.bind(this),this.settings.timer):clearTimeout(this.settings.automate)},end:function(){this.settings.cookieMonster&&e.cookie(this.settings.cookieName,"ridden",{expires:this.settings.cookieExpires,domain:this.settings.cookieDomain}),this.settings.timer>0&&clearTimeout(this.settings.automate),this.settings.modal&&this.settings.expose&&this.un_expose(),this.settings.$next_tip.data("closed",!0),e(".joyride-modal-bg").hide(),this.settings.$current_tip.hide(),this.settings.postStepCallback(this.settings.$li.index(),this.settings.$current_tip),this.settings.postRideCallback(this.settings.$li.index(),this.settings.$current_tip),e(".joyride-tip-guide").remove()},outerHTML:function(e){return e.outerHTML||(new XMLSerializer).serializeToString(e)},off:function(){e(this.scope).off(".joyride"),e(t).off(".joyride"),e(".joyride-close-tip, .joyride-next-tip, .joyride-modal-bg").off(".joyride"),e(".joyride-tip-guide, .joyride-modal-bg").remove(),clearTimeout(this.settings.automate),this.settings={}},reflow:function(){}}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";Foundation.libs.magellan={name:"magellan",version:"4.3.2",settings:{activeClass:"active",threshold:0},init:function(t,n,r){return this.scope=t||this.scope,Foundation.inherit(this,"data_options"),typeof n=="object"&&e.extend(!0,this.settings,n),typeof n!="string"?(this.settings.init||(this.fixed_magellan=e("[data-magellan-expedition]"),this.set_threshold(),this.last_destination=e("[data-magellan-destination]").last(),this.events()),this.settings.init):this[n].call(this,r)},events:function(){var n=this;e(this.scope).on("arrival.fndtn.magellan","[data-magellan-arrival]",function(t){var r=e(this),i=r.closest("[data-magellan-expedition]"),s=i.attr("data-magellan-active-class")||n.settings.activeClass;r.closest("[data-magellan-expedition]").find("[data-magellan-arrival]").not(r).removeClass(s),r.addClass(s)}),this.fixed_magellan.on("update-position.fndtn.magellan",function(){var t=e(this)}).trigger("update-position"),e(t).on("resize.fndtn.magellan",function(){this.fixed_magellan.trigger("update-position")}.bind(this)).on("scroll.fndtn.magellan",function(){var r=e(t).scrollTop();n.fixed_magellan.each(function(){var t=e(this);typeof t.data("magellan-top-offset")=="undefined"&&t.data("magellan-top-offset",t.offset().top),typeof t.data("magellan-fixed-position")=="undefined"&&t.data("magellan-fixed-position",!1);var i=r+n.settings.threshold>t.data("magellan-top-offset"),s=t.attr("data-magellan-top-offset");t.data("magellan-fixed-position")!=i&&(t.data("magellan-fixed-position",i),i?(t.addClass("fixed"),t.css({position:"fixed",top:0})):(t.removeClass("fixed"),t.css({position:"",top:""})),i&&typeof s!="undefined"&&s!=0&&t.css({position:"fixed",top:s+"px"}))})}),this.last_destination.length>0&&e(t).on("scroll.fndtn.magellan",function(r){var i=e(t).scrollTop(),s=i+e(t).height(),o=Math.ceil(n.last_destination.offset().top);e("[data-magellan-destination]").each(function(){var t=e(this),r=t.attr("data-magellan-destination"),u=t.offset().top-i;u<=n.settings.threshold&&e("[data-magellan-arrival='"+r+"']").trigger("arrival"),s>=e(n.scope).height()&&o>i&&o<s&&e("[data-magellan-arrival]").last().trigger("arrival")})}),this.settings.init=!0},set_threshold:function(){typeof this.settings.threshold!="number"&&(this.settings.threshold=this.fixed_magellan.length>0?this.outerHeight(this.fixed_magellan,!0):0)},off:function(){e(this.scope).off(".fndtn.magellan"),e(t).off(".fndtn.magellan")},reflow:function(){}}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";var i=function(){},s=function(i,s){if(i.hasClass(s.slides_container_class))return this;var f=this,l,c=i,h,p,d,v=0,m,g,y=!1,b=!1;c.children().first().addClass(s.active_slide_class),f.update_slide_number=function(t){s.slide_number&&(h.find("span:first").text(parseInt(t)+1),h.find("span:last").text(c.children().length)),s.bullets&&(p.children().removeClass(s.bullets_active_class),e(p.children().get(t)).addClass(s.bullets_active_class))},f.update_active_link=function(t){var n=e('a[data-orbit-link="'+c.children().eq(t).attr("data-orbit-slide")+'"]');n.parents("ul").find("[data-orbit-link]").removeClass(s.bullets_active_class),n.addClass(s.bullets_active_class)},f.build_markup=function(){c.wrap('<div class="'+s.container_class+'"></div>'),l=c.parent(),c.addClass(s.slides_container_class),s.navigation_arrows&&(l.append(e('<a href="#"><span></span></a>').addClass(s.prev_class)),l.append(e('<a href="#"><span></span></a>').addClass(s.next_class))),s.timer&&(d=e("<div>").addClass(s.timer_container_class),d.append("<span>"),d.append(e("<div>").addClass(s.timer_progress_class)),d.addClass(s.timer_paused_class),l.append(d)),s.slide_number&&(h=e("<div>").addClass(s.slide_number_class),h.append("<span></span> "+s.slide_number_text+" <span></span>"),l.append(h)),s.bullets&&(p=e("<ol>").addClass(s.bullets_container_class),l.append(p),c.children().each(function(t,n){var r=e("<li>").attr("data-orbit-slide",t);p.append(r)})),s.stack_on_small&&l.addClass(s.stack_on_small_class),f.update_slide_number(0),f.update_active_link(0)},f._goto=function(t,n){if(t===v)return!1;typeof g=="object"&&g.restart();var r=c.children(),i="next";y=!0,t<v&&(i="prev"),t>=r.length?t=0:t<0&&(t=r.length-1);var o=e(r.get(v)),u=e(r.get(t));o.css("zIndex",2),o.removeClass(s.active_slide_class),u.css("zIndex",4).addClass(s.active_slide_class),c.trigger("orbit:before-slide-change"),s.before_slide_change(),f.update_active_link(t);var a=function(){var e=function(){v=t,y=!1,n===!0&&(g=f.create_timer(),g.start()),f.update_slide_number(v),c.trigger("orbit:after-slide-change",[{slide_number:v,total_slides:r.length}]),s.after_slide_change(v,r.length)};c.height()!=u.height()&&s.variable_height?c.animate({height:u.height()},250,"linear",e):e()};if(r.length===1)return a(),!1;var l=function(){i==="next"&&m.next(o,u,a),i==="prev"&&m.prev(o,u,a)};u.height()>c.height()&&s.variable_height?c.animate({height:u.height()},250,"linear",l):l()},f.next=function(e){e.stopImmediatePropagation(),e.preventDefault(),f._goto(v+1)},f.prev=function(e){e.stopImmediatePropagation(),e.preventDefault(),f._goto(v-1)},f.link_custom=function(t){t.preventDefault();var n=e(this).attr("data-orbit-link");if(typeof n=="string"&&(n=e.trim(n))!=""){var r=l.find("[data-orbit-slide="+n+"]");r.index()!=-1&&f._goto(r.index())}},f.link_bullet=function(t){var n=e(this).attr("data-orbit-slide");typeof n=="string"&&(n=e.trim(n))!=""&&f._goto(parseInt(n))},f.timer_callback=function(){f._goto(v+1,!0)},f.compute_dimensions=function(){var t=e(c.children().get(v)),n=t.height();s.variable_height||c.children().each(function(){e(this).height()>n&&(n=e(this).height())}),c.height(n)},f.create_timer=function(){var e=new o(l.find("."+s.timer_container_class),s,f.timer_callback);return e},f.stop_timer=function(){typeof g=="object"&&g.stop()},f.toggle_timer=function(){var e=l.find("."+s.timer_container_class);e.hasClass(s.timer_paused_class)?(typeof g=="undefined"&&(g=f.create_timer()),g.start()):typeof g=="object"&&g.stop()},f.init=function(){f.build_markup(),s.timer&&(g=f.create_timer(),g.start()),m=new a(s,c),s.animation==="slide"&&(m=new u(s,c)),l.on("click","."+s.next_class,f.next),l.on("click","."+s.prev_class,f.prev),l.on("click","[data-orbit-slide]",f.link_bullet),l.on("click",f.toggle_timer),s.swipe&&l.on("touchstart.fndtn.orbit",function(e){e.touches||(e=e.originalEvent);var t={start_page_x:e.touches[0].pageX,start_page_y:e.touches[0].pageY,start_time:(new Date).getTime(),delta_x:0,is_scrolling:r};l.data("swipe-transition",t),e.stopPropagation()}).on("touchmove.fndtn.orbit",function(e){e.touches||(e=e.originalEvent);if(e.touches.length>1||e.scale&&e.scale!==1)return;var t=l.data("swipe-transition");typeof t=="undefined"&&(t={}),t.delta_x=e.touches[0].pageX-t.start_page_x,typeof t.is_scrolling=="undefined"&&(t.is_scrolling=!!(t.is_scrolling||Math.abs(t.delta_x)<Math.abs(e.touches[0].pageY-t.start_page_y)));if(!t.is_scrolling&&!t.active){e.preventDefault();var n=t.delta_x<0?v+1:v-1;t.active=!0,f._goto(n)}}).on("touchend.fndtn.orbit",function(e){l.data("swipe-transition",{}),e.stopPropagation()}),l.on("mouseenter.fndtn.orbit",function(e){s.timer&&s.pause_on_hover&&f.stop_timer()}).on("mouseleave.fndtn.orbit",function(e){s.timer&&s.resume_on_mouseout&&g.start()}),e(n).on("click","[data-orbit-link]",f.link_custom),e(t).on("resize",f.compute_dimensions),e(t).on("load",f.compute_dimensions),e(t).on("load",function(){l.prev(".preloader").css("display","none")}),c.trigger("orbit:ready")},f.init()},o=function(e,t,n){var r=this,i=t.timer_speed,s=e.find("."+t.timer_progress_class),o,u,a=-1;this.update_progress=function(e){var t=s.clone();t.attr("style",""),t.css("width",e+"%"),s.replaceWith(t),s=t},this.restart=function(){clearTimeout(u),e.addClass(t.timer_paused_class),a=-1,r.update_progress(0)},this.start=function(){if(!e.hasClass(t.timer_paused_class))return!0;a=a===-1?i:a,e.removeClass(t.timer_paused_class),o=(new Date).getTime(),s.animate({width:"100%"},a,"linear"),u=setTimeout(function(){r.restart(),n()},a),e.trigger("orbit:timer-started")},this.stop=function(){if(e.hasClass(t.timer_paused_class))return!0;clearTimeout(u),e.addClass(t.timer_paused_class);var n=(new Date).getTime();a-=n-o;var s=100-a/i*100;r.update_progress(s),e.trigger("orbit:timer-stopped")}},u=function(t,n){var r=t.animation_speed,i=e("html[dir=rtl]").length===1,s=i?"marginRight":"marginLeft",o={};o[s]="0%",this.next=function(e,t,n){t.animate(o,r,"linear",function(){e.css(s,"100%"),n()})},this.prev=function(e,t,n){t.css(s,"-100%"),t.animate(o,r,"linear",function(){e.css(s,"100%"),n()})}},a=function(t,n){var r=t.animation_speed,i=e("html[dir=rtl]").length===1,s=i?"marginRight":"marginLeft";this.next=function(e,t,n){t.css({margin:"0%",opacity:"0.01"}),t.animate({opacity:"1"},r,"linear",function(){e.css("margin","100%"),n()})},this.prev=function(e,t,n){t.css({margin:"0%",opacity:"0.01"}),t.animate({opacity:"1"},r,"linear",function(){e.css("margin","100%"),n()})}};Foundation.libs=Foundation.libs||{},Foundation.libs.orbit={name:"orbit",version:"4.3.2",settings:{animation:"slide",timer_speed:1e4,pause_on_hover:!0,resume_on_mouseout:!1,animation_speed:500,stack_on_small:!1,navigation_arrows:!0,slide_number:!0,slide_number_text:"of",container_class:"orbit-container",stack_on_small_class:"orbit-stack-on-small",next_class:"orbit-next",prev_class:"orbit-prev",timer_container_class:"orbit-timer",timer_paused_class:"paused",timer_progress_class:"orbit-progress",slides_container_class:"orbit-slides-container",bullets_container_class:"orbit-bullets",bullets_active_class:"active",slide_number_class:"orbit-slide-number",caption_class:"orbit-caption",active_slide_class:"active",orbit_transition_class:"orbit-transitioning",bullets:!0,timer:!0,variable_height:!1,swipe:!0,before_slide_change:i,after_slide_change:i},init:function(t,n,r){var i=this;Foundation.inherit(i,"data_options"),typeof n=="object"&&e.extend(!0,i.settings,n);if(e(t).is("[data-orbit]")){var o=e(t),u=i.data_options(o);new s(o,e.extend({},i.settings,u))}e("[data-orbit]",t).each(function(t,n){var r=e(n),o=i.data_options(r);new s(r,e.extend({},i.settings,o))})}}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";Foundation.libs.reveal={name:"reveal",version:"4.3.2",locked:!1,settings:{animation:"fadeAndPop",animationSpeed:250,closeOnBackgroundClick:!0,closeOnEsc:!0,dismissModalClass:"close-reveal-modal",bgClass:"reveal-modal-bg",open:function(){},opened:function(){},close:function(){},closed:function(){},bg:e(".reveal-modal-bg"),css:{open:{opacity:0,visibility:"visible",display:"block"},close:{opacity:1,visibility:"hidden",display:"none"}}},init:function(t,n,r){return Foundation.inherit(this,"data_options delay"),typeof n=="object"?e.extend(!0,this.settings,n):typeof r!="undefined"&&e.extend(!0,this.settings,r),typeof n!="string"?(this.events(),this.settings.init):this[n].call(this,r)},events:function(){var t=this;return e(this.scope).off(".fndtn.reveal").on("click.fndtn.reveal","[data-reveal-id]",function(n){n.preventDefault();if(!t.locked){var r=e(this),i=r.data("reveal-ajax");t.locked=!0;if(typeof i=="undefined")t.open.call(t,r);else{var s=i===!0?r.attr("href"):i;t.open.call(t,r,{url:s})}}}).on("click.fndtn.reveal touchend",this.close_targets(),function(n){n.preventDefault();if(!t.locked){var r=e.extend({},t.settings,t.data_options(e(".reveal-modal.open"))),i=e(n.target)[0]===e("."+r.bgClass)[0];if(i&&!r.closeOnBackgroundClick)return;t.locked=!0,t.close.call(t,i?e(".reveal-modal.open"):e(this).closest(".reveal-modal"))}}),e(this.scope).hasClass("reveal-modal")?e(this.scope).on("open.fndtn.reveal",this.settings.open).on("opened.fndtn.reveal",this.settings.opened).on("opened.fndtn.reveal",this.open_video).on("close.fndtn.reveal",this.settings.close).on("closed.fndtn.reveal",this.settings.closed).on("closed.fndtn.reveal",this.close_video):e(this.scope).on("open.fndtn.reveal",".reveal-modal",this.settings.open).on("opened.fndtn.reveal",".reveal-modal",this.settings.opened).on("opened.fndtn.reveal",".reveal-modal",this.open_video).on("close.fndtn.reveal",".reveal-modal",this.settings.close).on("closed.fndtn.reveal",".reveal-modal",this.settings.closed).on("closed.fndtn.reveal",".reveal-modal",this.close_video),e("body").bind("keyup.reveal",function(n){var r=e(".reveal-modal.open"),i=e.extend({},t.settings,t.data_options(r));n.which===27&&i.closeOnEsc&&r.foundation("reveal","close")}),!0},open:function(t,n){if(t)if(typeof t.selector!="undefined")var r=e("#"+t.data("reveal-id"));else{var r=e(this.scope);n=t}else var r=e(this.scope);if(!r.hasClass("open")){var i=e(".reveal-modal.open");typeof r.data("css-top")=="undefined"&&r.data("css-top",parseInt(r.css("top"),10)).data("offset",this.cache_offset(r)),r.trigger("open"),i.length<1&&this.toggle_bg();if(typeof n=="undefined"||!n.url)this.hide(i,this.settings.css.close),this.show(r,this.settings.css.open);else{var s=this,o=typeof n.success!="undefined"?n.success:null;e.extend(n,{success:function(t,n,u){e.isFunction(o)&&o(t,n,u),r.html(t),e(r).foundation("section","reflow"),s.hide(i,s.settings.css.close),s.show(r,s.settings.css.open)}}),e.ajax(n)}}},close:function(t){var t=t&&t.length?t:e(this.scope),n=e(".reveal-modal.open");n.length>0&&(this.locked=!0,t.trigger("close"),this.toggle_bg(),this.hide(n,this.settings.css.close))},close_targets:function(){var e="."+this.settings.dismissModalClass;return this.settings.closeOnBackgroundClick?e+", ."+this.settings.bgClass:e},toggle_bg:function(){e("."+this.settings.bgClass).length===0&&(this.settings.bg=e("<div />",{"class":this.settings.bgClass}).appendTo("body")),this.settings.bg.filter(":visible").length>0?this.hide(this.settings.bg):this.show(this.settings.bg)},show:function(n,r){if(r){if(n.parent("body").length===0){var i=n.wrap('<div style="display: none;" />').parent();n.on("closed.fndtn.reveal.wrapped",function(){n.detach().appendTo(i),n.unwrap().unbind("closed.fndtn.reveal.wrapped")}),n.detach().appendTo("body")}if(/pop/i.test(this.settings.animation)){r.top=e(t).scrollTop()-n.data("offset")+"px";var s={top:e(t).scrollTop()+n.data("css-top")+"px",opacity:1};return this.delay(function(){return n.css(r).animate(s,this.settings.animationSpeed,"linear",function(){this.locked=!1,n.trigger("opened")}.bind(this)).addClass("open")}.bind(this),this.settings.animationSpeed/2)}if(/fade/i.test(this.settings.animation)){var s={opacity:1};return this.delay(function(){return n.css(r).animate(s,this.settings.animationSpeed,"linear",function(){this.locked=!1,n.trigger("opened")}.bind(this)).addClass("open")}.bind(this),this.settings.animationSpeed/2)}return n.css(r).show().css({opacity:1}).addClass("open").trigger("opened")}return/fade/i.test(this.settings.animation)?n.fadeIn(this.settings.animationSpeed/2):n.show()},hide:function(n,r){if(r){if(/pop/i.test(this.settings.animation)){var i={top:-e(t).scrollTop()-n.data("offset")+"px",opacity:0};return this.delay(function(){return n.animate(i,this.settings.animationSpeed,"linear",function(){this.locked=!1,n.css(r).trigger("closed")}.bind(this)).removeClass("open")}.bind(this),this.settings.animationSpeed/2)}if(/fade/i.test(this.settings.animation)){var i={opacity:0};return this.delay(function(){return n.animate(i,this.settings.animationSpeed,"linear",function(){this.locked=!1,n.css(r).trigger("closed")}.bind(this)).removeClass("open")}.bind(this),this.settings.animationSpeed/2)}return n.hide().css(r).removeClass("open").trigger("closed")}return/fade/i.test(this.settings.animation)?n.fadeOut(this.settings.animationSpeed/2):n.hide()},close_video:function(t){var n=e(this).find(".flex-video"),r=n.find("iframe");r.length>0&&(r.attr("data-src",r[0].src),r.attr("src","about:blank"),n.hide())},open_video:function(t){var n=e(this).find(".flex-video"),i=n.find("iframe");if(i.length>0){var s=i.attr("data-src");if(typeof s=="string")i[0].src=i.attr("data-src");else{var o=i[0].src;i[0].src=r,i[0].src=o}n.show()}},cache_offset:function(e){var t=e.show().height()+parseInt(e.css("top"),10);return e.hide(),t},off:function(){e(this.scope).off(".fndtn.reveal")},reflow:function(){}}}(Foundation.zj,this,this.document),function(e,t,n){"use strict";Foundation.libs.section={name:"section",version:"4.3.2",settings:{deep_linking:!1,small_breakpoint:768,one_up:!0,multi_expand:!1,section_selector:"[data-section]",region_selector:"section, .section, [data-section-region]",title_selector:".title, [data-section-title]",resized_data_attr:"data-section-resized",small_style_data_attr:"data-section-small-style",content_selector:".content, [data-section-content]",nav_selector:'[data-section="vertical-nav"], [data-section="horizontal-nav"]',active_class:"active",callback:function(){}},init:function(t,n,r){var i=this;return Foundation.inherit(this,"throttle data_options position_right offset_right"),typeof n=="object"&&e.extend(!0,i.settings,n),typeof n!="string"?(this.events(),!0):this[n].call(this,r)},events:function(){var r=this,i=[],s=r.settings.section_selector,o=r.settings.region_selector.split(","),u=r.settings.title_selector.split(",");for(var a=0,f=o.length;a<f;a++){var l=o[a];for(var c=0,h=u.length;c<h;c++){var p=s+">"+l+">"+u[c];i.push(p+" a"),i.push(p)}}e(r.scope).on("click.fndtn.section",i.join(","),function(t){var n=e(this).closest(r.settings.title_selector);r.close_navs(n),n.siblings(r.settings.content_selector).length>0&&r.toggle_active.call(n[0],t)}),e(t).on("resize.fndtn.section",r.throttle(function(){r.resize()},30)).on("hashchange.fndtn.section",r.set_active_from_hash),e(n).on("click.fndtn.section",function(t){if(t.isPropagationStopped&&t.isPropagationStopped())return;if(t.target===n)return;r.close_navs(e(t.target).closest(r.settings.title_selector))}),e(t).triggerHandler("resize.fndtn.section"),e(t).triggerHandler("hashchange.fndtn.section")},close_navs:function(t){var n=Foundation.libs.section,r=e(n.settings.nav_selector).filter(function(){return!e.extend({},n.settings,n.data_options(e(this))).one_up});if(t.length>0){var i=t.parent().parent();if(n.is_horizontal_nav(i)||n.is_vertical_nav(i))r=r.filter(function(){return this!==i[0]})}r.children(n.settings.region_selector).removeClass(n.settings.active_class)},toggle_active:function(t){var n=e(this),r=Foundation.libs.section,i=n.parent(),s=n.siblings(r.settings.content_selector),o=i.parent(),u=e.extend({},r.settings,r.data_options(o)),a=o.children(r.settings.region_selector).filter("."+r.settings.active_class);!u.deep_linking&&s.length>0&&t.preventDefault(),t.stopPropagation();if(!i.hasClass(r.settings.active_class)){if(!r.is_accordion(o)||r.is_accordion(o)&&!r.settings.multi_expand)a.removeClass(r.settings.active_class),a.trigger("closed.fndtn.section");i.addClass(r.settings.active_class),r.resize(i.find(r.settings.section_selector).not("["+r.settings.resized_data_attr+"]"),!0),i.trigger("opened.fndtn.section")}else if(i.hasClass(r.settings.active_class)&&r.is_accordion(o)||!u.one_up&&(r.small(o)||r.is_vertical_nav(o)||r.is_horizontal_nav(o)||r.is_accordion(o)))i.removeClass(r.settings.active_class),i.trigger("closed.fndtn.section");u.callback(o)},check_resize_timer:null,resize:function(t,n){var r=Foundation.libs.section,i=e(r.settings.section_selector),s=r.small(i),o=function(e,t){return!r.is_accordion(e)&&!e.is("["+r.settings.resized_data_attr+"]")&&(!s||r.is_horizontal_tabs(e))&&t===(e.css("display")==="none"||!e.parent().is(":visible"))};t=t||e(r.settings.section_selector),clearTimeout(r.check_resize_timer),s||t.removeAttr(r.settings.small_style_data_attr),t.filter(function(){return o(e(this),!1)}).each(function(){var t=e(this),i=t.children(r.settings.region_selector),s=i.children(r.settings.title_selector),o=i.children(r.settings.content_selector),u=0;if(n&&t.children(r.settings.region_selector).filter("."+r.settings.active_class).length==0){var a=e.extend({},r.settings,r.data_options(t));!a.deep_linking&&(a.one_up||!r.is_horizontal_nav(t)&&!r.is_vertical_nav(t)&&!r.is_accordion(t))&&i.filter(":visible").first().addClass(r.settings.active_class)}if(r.is_horizontal_tabs(t)||r.is_auto(t)){var f=0;s.each(function(){var t=e(this);if(t.is(":visible")){t.css(r.rtl?"right":"left",f);var n=parseInt(t.css("border-"+(r.rtl?"left":"right")+"-width"),10);n.toString()==="Nan"&&(n=0),f+=r.outerWidth(t)-n,u=Math.max(u,r.outerHeight(t))}}),s.css("height",u),i.each(function(){var t=e(this),n=t.children(r.settings.content_selector),i=parseInt(n.css("border-top-width"),10);i.toString()==="Nan"&&(i=0),t.css("padding-top",u-i)}),t.css("min-height",u)}else if(r.is_horizontal_nav(t)){var l=!0;s.each(function(){u=Math.max(u,r.outerHeight(e(this)))}),i.each(function(){var n=e(this);n.css("margin-left","-"+(l?t:n.children(r.settings.title_selector)).css("border-left-width")),l=!1}),i.css("margin-top","-"+t.css("border-top-width")),s.css("height",u),o.css("top",u),t.css("min-height",u)}else if(r.is_vertical_tabs(t)){var c=0;s.each(function(){var t=e(this);if(t.is(":visible")){t.css("top",c);var n=parseInt(t.css("border-top-width"),10);n.toString()==="Nan"&&(n=0),c+=r.outerHeight(t)-n}}),o.css("min-height",c+1)}else if(r.is_vertical_nav(t)){var h=0,p=!0;s.each(function(){h=Math.max(h,r.outerWidth(e(this)))}),i.each(function(){var n=e(this);n.css("margin-top","-"+(p?t:n.children(r.settings.title_selector)).css("border-top-width")),p=!1}),s.css("width",h),o.css(r.rtl?"right":"left",h),t.css("width",h)}t.attr(r.settings.resized_data_attr,!0)}),e(r.settings.section_selector).filter(function(){return o(e(this),!0)}).length>0&&(r.check_resize_timer=setTimeout(function(){r.resize(t.filter(function(){return o(e(this),!1)}),!0)},700)),s&&t.attr(r.settings.small_style_data_attr,!0)},is_vertical_nav:function(e){return/vertical-nav/i.test(e.data("section"))},is_horizontal_nav:function(e){return/horizontal-nav/i.test(e.data("section"))},is_accordion:function(e){return/accordion/i.test(e.data("section"))},is_horizontal_tabs:function(e){return/^tabs$/i.test(e.data("section"))},is_vertical_tabs:function(e){return/vertical-tabs/i.test(e.data("section"))},is_auto:function(e){var t=e.data("section");return t===""||/auto/i.test(t)},set_active_from_hash:function(){var n=Foundation.libs.section,r=t.location.hash.substring(1),i=e(n.settings.section_selector),s;i.each(function(){var t=e(this),i=t.children(n.settings.region_selector);i.each(function(){var i=e(this),o=i.children(n.settings.content_selector).data("slug");if((new RegExp(o,"i")).test(r))return s=t,!1});if(s!=null)return!1}),s!=null&&i.each(function(){if(s==e(this)){var t=e(this),i=e.extend({},n.settings,n.data_options(t)),o=t.children(n.settings.region_selector),u=i.deep_linking&&r.length>0,a=!1;o.each(function(){var t=e(this);if(a)t.removeClass(n.settings.active_class);else if(u){var i=t.children(n.settings.content_selector).data("slug");i&&(new RegExp(i,"i")).test(r)?(t.hasClass(n.settings.active_class)||t.addClass(n.settings.active_class),a=!0):t.removeClass(n.settings.active_class)}else t.hasClass(n.settings.active_class)&&(a=!0)}),!a&&(i.one_up||!n.is_horizontal_nav(t)&&!n.is_vertical_nav(t)&&!n.is_accordion(t))&&o.filter(":visible").first().addClass(n.settings.active_class)}})},reflow:function(){var t=Foundation.libs.section;e(t.settings.section_selector).removeAttr(t.settings.resized_data_attr),t.throttle(function(){t.resize()},30)()},small:function(t){var n=e.extend({},this.settings,this.data_options(t));return this |
| + | .is_horizontal_tabs(t)?!1:t&&this.is_accordion(t)?!0:e("html").hasClass("lt-ie9")?!0:e("html").hasClass("ie8compat")?!0:e(this.scope).width()<n.small_breakpoint},off:function(){e(this.scope).off(".fndtn.section"),e(t).off(".fndtn.section"),e(n).off(".fndtn.section")}},e.fn.reflow_section=function(e){var t=this,n=Foundation.libs.section;return t.removeAttr(n.settings.resized_data_attr),n.throttle(function(){n.resize(t,e)},30)(),this}}(Foundation.zj,window,document),function(e,t,n,r){"use strict";Foundation.libs.tooltips={name:"tooltips",version:"4.3.2",settings:{selector:".has-tip",additionalInheritableClasses:[],tooltipClass:".tooltip",touchCloseText:"tap to close",appendTo:"body","disable-for-touch":!1,tipTemplate:function(e,t){return'<span data-selector="'+e+'" class="'+Foundation.libs.tooltips.settings.tooltipClass.substring(1)+'">'+t+'<span class="nub"></span></span>'}},cache:{},init:function(t,n,r){Foundation.inherit(this,"data_options");var i=this;typeof n=="object"?e.extend(!0,this.settings,n):typeof r!="undefined"&&e.extend(!0,this.settings,r);if(typeof n=="string")return this[n].call(this,r);Modernizr.touch?e(this.scope).on("click.fndtn.tooltip touchstart.fndtn.tooltip touchend.fndtn.tooltip","[data-tooltip]",function(t){var n=e.extend({},i.settings,i.data_options(e(this)));n["disable-for-touch"]||(t.preventDefault(),e(n.tooltipClass).hide(),i.showOrCreateTip(e(this)))}).on("click.fndtn.tooltip touchstart.fndtn.tooltip touchend.fndtn.tooltip",this.settings.tooltipClass,function(t){t.preventDefault(),e(this).fadeOut(150)}):e(this.scope).on("mouseenter.fndtn.tooltip mouseleave.fndtn.tooltip","[data-tooltip]",function(t){var n=e(this);/enter|over/i.test(t.type)?i.showOrCreateTip(n):(t.type==="mouseout"||t.type==="mouseleave")&&i.hide(n)})},showOrCreateTip:function(e){var t=this.getTip(e);return t&&t.length>0?this.show(e):this.create(e)},getTip:function(t){var n=this.selector(t),r=null;return n&&(r=e('span[data-selector="'+n+'"]'+this.settings.tooltipClass)),typeof r=="object"?r:!1},selector:function(e){var t=e.attr("id"),n=e.attr("data-tooltip")||e.attr("data-selector");return(t&&t.length<1||!t)&&typeof n!="string"&&(n="tooltip"+Math.random().toString(36).substring(7),e.attr("data-selector",n)),t&&t.length>0?t:n},create:function(t){var n=e(this.settings.tipTemplate(this.selector(t),e("<div></div>").html(t.attr("title")).html())),r=this.inheritable_classes(t);n.addClass(r).appendTo(this.settings.appendTo),Modernizr.touch&&n.append('<span class="tap-to-close">'+this.settings.touchCloseText+"</span>"),t.removeAttr("title").attr("title",""),this.show(t)},reposition:function(n,r,i){var s,o,u,a,f,l;r.css("visibility","hidden").show(),s=n.data("width"),o=r.children(".nub"),u=this.outerHeight(o),a=this.outerHeight(o),l=function(e,t,n,r,i,s){return e.css({top:t?t:"auto",bottom:r?r:"auto",left:i?i:"auto",right:n?n:"auto",width:s?s:"auto"}).end()},l(r,n.offset().top+this.outerHeight(n)+10,"auto","auto",n.offset().left,s);if(e(t).width()<767)l(r,n.offset().top+this.outerHeight(n)+10,"auto","auto",12.5,e(this.scope).width()),r.addClass("tip-override"),l(o,-u,"auto","auto",n.offset().left);else{var c=n.offset().left;Foundation.rtl&&(c=n.offset().left+n.offset().width-this.outerWidth(r)),l(r,n.offset().top+this.outerHeight(n)+10,"auto","auto",c,s),r.removeClass("tip-override"),i&&i.indexOf("tip-top")>-1?l(r,n.offset().top-this.outerHeight(r),"auto","auto",c,s).removeClass("tip-override"):i&&i.indexOf("tip-left")>-1?l(r,n.offset().top+this.outerHeight(n)/2-u*2.5,"auto","auto",n.offset().left-this.outerWidth(r)-u,s).removeClass("tip-override"):i&&i.indexOf("tip-right")>-1&&l(r,n.offset().top+this.outerHeight(n)/2-u*2.5,"auto","auto",n.offset().left+this.outerWidth(n)+u,s).removeClass("tip-override")}r.css("visibility","visible").hide()},inheritable_classes:function(t){var n=["tip-top","tip-left","tip-bottom","tip-right","noradius"].concat(this.settings.additionalInheritableClasses),r=t.attr("class"),i=r?e.map(r.split(" "),function(t,r){if(e.inArray(t,n)!==-1)return t}).join(" "):"";return e.trim(i)},show:function(e){var t=this.getTip(e);this.reposition(e,t,e.attr("class")),t.fadeIn(150)},hide:function(e){var t=this.getTip(e);t.fadeOut(150)},reload:function(){var t=e(this);return t.data("fndtn-tooltips")?t.foundationTooltips("destroy").foundationTooltips("init"):t.foundationTooltips("init")},off:function(){e(this.scope).off(".fndtn.tooltip"),e(this.settings.tooltipClass).each(function(t){e("[data-tooltip]").get(t).attr("title",e(this).text())}).remove()},reflow:function(){}}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";Foundation.libs.topbar={name:"topbar",version:"4.3.2",settings:{index:0,stickyClass:"sticky",custom_back_text:!0,back_text:"Back",is_hover:!0,mobile_show_parent_link:!1,scrolltop:!0,init:!1},init:function(n,r,i){Foundation.inherit(this,"data_options addCustomRule");var s=this;return typeof r=="object"?e.extend(!0,this.settings,r):typeof i!="undefined"&&e.extend(!0,this.settings,i),typeof r!="string"?(e(".top-bar, [data-topbar]").each(function(){e.extend(!0,s.settings,s.data_options(e(this))),s.settings.$w=e(t),s.settings.$topbar=e(this),s.settings.$section=s.settings.$topbar.find("section"),s.settings.$titlebar=s.settings.$topbar.children("ul").first(),s.settings.$topbar.data("index",0);var n=s.settings.$topbar.parent();n.hasClass("fixed")||n.hasClass(s.settings.stickyClass)?(s.settings.$topbar.data("height",s.outerHeight(n)),s.settings.$topbar.data("stickyoffset",n.offset().top)):s.settings.$topbar.data("height",s.outerHeight(s.settings.$topbar));var r=e("<div class='top-bar-js-breakpoint'/>").insertAfter(s.settings.$topbar);s.settings.breakPoint=r.width(),r.remove(),s.assemble(),s.settings.is_hover&&s.settings.$topbar.find(".has-dropdown").addClass("not-click"),s.addCustomRule(".f-topbar-fixed { padding-top: "+s.settings.$topbar.data("height")+"px }"),s.settings.$topbar.parent().hasClass("fixed")&&e("body").addClass("f-topbar-fixed")}),s.settings.init||this.events(),this.settings.init):this[r].call(this,i)},toggle:function(){var n=this,r=e(".top-bar, [data-topbar]"),i=r.find("section, .section");n.breakpoint()&&(n.rtl?(i.css({right:"0%"}),i.find(">.name").css({right:"100%"})):(i.css({left:"0%"}),i.find(">.name").css({left:"100%"})),i.find("li.moved").removeClass("moved"),r.data("index",0),r.toggleClass("expanded").css("height","")),n.settings.scrolltop?r.hasClass("expanded")?r.parent().hasClass("fixed")&&(n.settings.scrolltop?(r.parent().removeClass("fixed"),r.addClass("fixed"),e("body").removeClass("f-topbar-fixed"),t.scrollTo(0,0)):r.parent().removeClass("expanded")):r.hasClass("fixed")&&(r.parent().addClass("fixed"),r.removeClass("fixed"),e("body").addClass("f-topbar-fixed")):(r.parent().hasClass(n.settings.stickyClass)&&r.parent().addClass("fixed"),r.parent().hasClass("fixed")&&(r.hasClass("expanded")?(r.addClass("fixed"),r.parent().addClass("expanded")):(r.removeClass("fixed"),r.parent().removeClass("expanded"),n.updateStickyPositioning())))},timer:null,events:function(){var r=this;e(this.scope).off(".fndtn.topbar").on("click.fndtn.topbar",".top-bar .toggle-topbar, [data-topbar] .toggle-topbar",function(e){e.preventDefault(),r.toggle()}).on("click.fndtn.topbar",".top-bar li.has-dropdown",function(t){var n=e(this),i=e(t.target),s=n.closest("[data-topbar], .top-bar"),o=s.data("topbar");if(i.data("revealId")){r.toggle();return}if(r.breakpoint())return;if(r.settings.is_hover&&!Modernizr.touch)return;t.stopImmediatePropagation(),i[0].nodeName==="A"&&i.parent().hasClass("has-dropdown")&&t.preventDefault(),n.hasClass("hover")?(n.removeClass("hover").find("li").removeClass("hover"),n.parents("li.hover").removeClass("hover")):n.addClass("hover")}).on("click.fndtn.topbar",".top-bar .has-dropdown>a, [data-topbar] .has-dropdown>a",function(n){if(r.breakpoint()&&e(t).width()!=r.settings.breakPoint){n.preventDefault();var i=e(this),s=i.closest(".top-bar, [data-topbar]"),o=s.find("section, .section"),u=i.next(".dropdown").outerHeight(),a=i.closest("li");s.data("index",s.data("index")+1),a.addClass("moved"),r.rtl?(o.css({right:-(100*s.data("index"))+"%"}),o.find(">.name").css({right:100*s.data("index")+"%"})):(o.css({left:-(100*s.data("index"))+"%"}),o.find(">.name").css({left:100*s.data("index")+"%"})),s.css("height",r.outerHeight(i.siblings("ul"),!0)+r.settings.$topbar.data("height"))}}),e(t).on("resize.fndtn.topbar",function(){if(typeof r.settings.$topbar=="undefined")return;var t=r.settings.$topbar.parent("."+this.settings.stickyClass),i;if(!r.breakpoint()){var s=r.settings.$topbar.hasClass("expanded");e(".top-bar, [data-topbar]").css("height","").removeClass("expanded").find("li").removeClass("hover"),s&&r.toggle()}t.length>0&&(t.hasClass("fixed")?(t.removeClass("fixed"),i=t.offset().top,e(n.body).hasClass("f-topbar-fixed")&&(i-=r.settings.$topbar.data("height")),r.settings.$topbar.data("stickyoffset",i),t.addClass("fixed")):(i=t.offset().top,r.settings.$topbar.data("stickyoffset",i)))}.bind(this)),e("body").on("click.fndtn.topbar",function(t){var n=e(t.target).closest("li").closest("li.hover");if(n.length>0)return;e(".top-bar li, [data-topbar] li").removeClass("hover")}),e(this.scope).on("click.fndtn",".top-bar .has-dropdown .back, [data-topbar] .has-dropdown .back",function(t){t.preventDefault();var n=e(this),i=n.closest(".top-bar, [data-topbar]"),s=i.find("section, .section"),o=n.closest("li.moved"),u=o.parent();i.data("index",i.data("index")-1),r.rtl?(s.css({right:-(100*i.data("index"))+"%"}),s.find(">.name").css({right:100*i.data("index")+"%"})):(s.css({left:-(100*i.data("index"))+"%"}),s.find(">.name").css({left:100*i.data("index")+"%"})),i.data("index")===0?i.css("height",""):i.css("height",r.outerHeight(u,!0)+r.settings.$topbar.data("height")),setTimeout(function(){o.removeClass("moved")},300)})},breakpoint:function(){return e(n).width()<=this.settings.breakPoint||e("html").hasClass("lt-ie9")},assemble:function(){var t=this;this.settings.$section.detach(),this.settings.$section.find(".has-dropdown>a").each(function(){var n=e(this),r=n.siblings(".dropdown"),i=n.attr("href");if(t.settings.mobile_show_parent_link&&i&&i.length>1)var s=e('<li class="title back js-generated"><h5><a href="#"></a></h5></li><li><a class="parent-link js-generated" href="'+i+'">'+n.text()+"</a></li>");else var s=e('<li class="title back js-generated"><h5><a href="#"></a></h5></li>');t.settings.custom_back_text==1?s.find("h5>a").html(t.settings.back_text):s.find("h5>a").html("« "+n.html()),r.prepend(s)}),this.settings.$section.appendTo(this.settings.$topbar),this.sticky()},height:function(t){var n=0,r=this;return t.find("> li").each(function(){n+=r.outerHeight(e(this),!0)}),n},sticky:function(){var n=e(t),r=this;n.scroll(function(){r.updateStickyPositioning()})},updateStickyPositioning:function(){var n="."+this.settings.stickyClass,r=e(t);if(e(n).length>0){var i=this.settings.$topbar.data("stickyoffset");e(n).hasClass("expanded")||(r.scrollTop()>i?e(n).hasClass("fixed")||(e(n).addClass("fixed"),e("body").addClass("f-topbar-fixed")):r.scrollTop()<=i&&e(n).hasClass("fixed")&&(e(n).removeClass("fixed"),e("body").removeClass("f-topbar-fixed")))}},off:function(){e(this.scope).off(".fndtn.topbar"),e(t).off(".fndtn.topbar")},reflow:function(){}}}(Foundation.zj,this,this.document),function(e,t,n,r){"use strict";Foundation.libs.interchange={name:"interchange",version:"4.2.4",cache:{},images_loaded:!1,settings:{load_attr:"interchange",named_queries:{"default":"only screen and (min-width: 1px)",small:"only screen and (min-width: 768px)",medium:"only screen and (min-width: 1280px)",large:"only screen and (min-width: 1440px)",landscape:"only screen and (orientation: landscape)",portrait:"only screen and (orientation: portrait)",retina:"only screen and (-webkit-min-device-pixel-ratio: 2),only screen and (min--moz-device-pixel-ratio: 2),only screen and (-o-min-device-pixel-ratio: 2/1),only screen and (min-device-pixel-ratio: 2),only screen and (min-resolution: 192dpi),only screen and (min-resolution: 2dppx)"},directives:{replace:function(e,t){if(/IMG/.test(e[0].nodeName)){var n=e[0].src;if((new RegExp(t,"i")).test(n))return;return e[0].src=t,e.trigger("replace",[e[0].src,n])}}}},init:function(t,n,r){return Foundation.inherit(this,"throttle"),typeof n=="object"&&e.extend(!0,this.settings,n),this.events(),this.images(),typeof n!="string"?this.settings.init:this[n].call(this,r)},events:function(){var n=this;e(t).on("resize.fndtn.interchange",n.throttle(function(){n.resize.call(n)},50))},resize:function(){var t=this.cache;if(!this.images_loaded){setTimeout(e.proxy(this.resize,this),50);return}for(var n in t)if(t.hasOwnProperty(n)){var r=this.results(n,t[n]);r&&this.settings.directives[r.scenario[1]](r.el,r.scenario[0])}},results:function(t,n){var r=n.length;if(r>0){var i=e('[data-uuid="'+t+'"]');for(var s=r-1;s>=0;s--){var o,u=n[s][2];this.settings.named_queries.hasOwnProperty(u)?o=matchMedia(this.settings.named_queries[u]):o=matchMedia(u);if(o.matches)return{el:i,scenario:n[s]}}}return!1},images:function(e){return typeof this.cached_images=="undefined"||e?this.update_images():this.cached_images},update_images:function(){var t=n.getElementsByTagName("img"),r=t.length,i=0,s="data-"+this.settings.load_attr;this.cached_images=[],this.images_loaded=!1;for(var o=r-1;o>=0;o--)this.loaded(e(t[o]),function(e){i++;if(e){var t=e.getAttribute(s)||"";t.length>0&&this.cached_images.push(e)}i===r&&(this.images_loaded=!0,this.enhance())}.bind(this));return"deferred"},loaded:function(e,t){function n(){t(e[0])}function r(){this.one("load",n);if(/MSIE (\d+\.\d+);/.test(navigator.userAgent)){var e=this.attr("src"),t=e.match(/\?/)?"&":"?";t+="random="+(new Date).getTime(),this.attr("src",e+t)}}if(!e.attr("src")){n();return}e[0].complete||e[0].readyState===4?n():r.call(e)},enhance:function(){var n=this.images().length;for(var r=n-1;r>=0;r--)this._object(e(this.images()[r]));return e(t).trigger("resize")},parse_params:function(e,t,n){return[this.trim(e),this.convert_directive(t),this.trim(n)]},convert_directive:function(e){var t=this.trim(e);return t.length>0?t:"replace"},_object:function(e){var t=this.parse_data_attr(e),n=[],r=t.length;if(r>0)for(var i=r-1;i>=0;i--){var s=t[i].split(/\((.*?)(\))$/);if(s.length>1){var o=s[0].split(","),u=this.parse_params(o[0],o[1],s[1]);n.push(u)}}return this.store(e,n)},uuid:function(e){function n(){return((1+Math.random())*65536|0).toString(16).substring(1)}var t=e||"-";return n()+n()+t+n()+t+n()+t+n()+t+n()+n()+n()},store:function(e,t){var n=this.uuid(),r=e.data("uuid");return r?this.cache[r]:(e.attr("data-uuid",n),this.cache[n]=t)},trim:function(t){return typeof t=="string"?e.trim(t):t},parse_data_attr:function(e){var t=e.data(this.settings.load_attr).split(/\[(.*?)\]/),n=t.length,r=[];for(var i=n-1;i>=0;i--)t[i].replace(/[\W\d]+/,"").length>4&&r.push(t[i]);return r},reflow:function(){this.images(!0)}}}(Foundation.zj,this,this.document),function(e){"use strict";function t(e,t,n){if(e.addEventListener)return e.addEventListener(t,n,!1);if(e.attachEvent)return e.attachEvent("on"+t,n)}function n(e,t){var n,r;for(n=0,r=e.length;n<r;n++)if(e[n]===t)return!0;return!1}function r(e,t){var n;e.createTextRange?(n=e.createTextRange(),n.move("character",t),n.select()):e.selectionStart&&(e.focus(),e.setSelectionRange(t,t))}function i(e,t){try{return e.type=t,!0}catch(n){return!1}}e.Placeholders={Utils:{addEventListener:t,inArray:n,moveCaret:r,changeType:i}}}(this),function(e){"use strict";function M(){}function _(e){var t;return e.value===e.getAttribute(a)&&e.getAttribute(f)==="true"?(e.setAttribute(f,"false"),e.value="",e.className=e.className.replace(s,""),t=e.getAttribute(l),t&&(e.type=t),!0):!1}function D(e){var t,n=e.getAttribute(a);return e.value===""&&n?(e.setAttribute(f,"true"),e.value=n,e.className+=" "+i,t=e.getAttribute(l),t?e.type="text":e.type==="password"&&b.changeType(e,"text")&&e.setAttribute(l,"password"),!0):!1}function P(e,t){var n,r,i,s,f;if(e&&e.getAttribute(a))t(e);else{n=e?e.getElementsByTagName("input"):o,r=e?e.getElementsByTagName("textarea"):u;for(f=0,s=n.length+r.length;f<s;f++)i=f<n.length?n[f]:r[f-n.length],t(i)}}function H(e){P(e,_)}function B(e){P(e,D)}function j(e){return function(){w&&e.value===e.getAttribute(a)&&e.getAttribute(f)==="true"?b.moveCaret(e,0):_(e)}}function F(e){return function(){D(e)}}function I(e){return function(t){S=e.value;if(e.getAttribute(f)==="true"&&S===e.getAttribute(a)&&b.inArray(n,t.keyCode))return t.preventDefault&&t.preventDefault(),!1}}function q(e){return function(){var t;e.getAttribute(f)==="true"&&e.value!==S&&(e.className=e.className.replace(s,""),e.value=e.value.replace(e.getAttribute(a),""),e.setAttribute(f,!1),t=e.getAttribute(l),t&&(e.type=t)),e.value===""&&(e.blur(),b.moveCaret(e,0))}}function R(e){return function(){e===document.activeElement&&e.value===e.getAttribute(a)&&e.getAttribute(f)==="true"&&b.moveCaret(e,0)}}function U(e){return function(){H(e)}}function z(e){e.form&&(k=e.form,k.getAttribute(c)||(b.addEventListener(k,"submit",U(k)),k.setAttribute(c,"true"))),b.addEventListener(e,"focus",j(e)),b.addEventListener(e,"blur",F(e)),w&&(b.addEventListener(e,"keydown",I(e)),b.addEventListener(e,"keyup",q(e)),b.addEventListener(e,"click",R(e))),e.setAttribute(h,"true"),e.setAttribute(a,N),D(e)}var t=["text","search","url","tel","email","password","number","textarea"],n=[27,33,34,35,36,37,38,39,40,8,46],r="#ccc",i="placeholdersjs",s=new RegExp("(?:^|\\s)"+i+"(?!\\S)"),o,u,a="data-placeholder-value",f="data-placeholder-active",l="data-placeholder-type",c="data-placeholder-submit",h="data-placeholder-bound",p="data-placeholder-focus",d="data-placeholder-live",v=document.createElement("input"),m=document.getElementsByTagName("head")[0],g=document.documentElement,y=e.Placeholders,b=y.Utils,w,E,S,x,T,N,C,k,L,A,O;y.nativeSupport=v.placeholder!==void 0;if(!y.nativeSupport){o=document.getElementsByTagName("input"),u=document.getElementsByTagName("textarea"),w=g.getAttribute(p)==="false",E=g.getAttribute(d)!=="false",x=document.createElement("style"),x.type="text/css",T=document.createTextNode("."+i+" { color:"+r+"; }"),x.styleSheet?x.styleSheet.cssText=T.nodeValue:x.appendChild(T),m.insertBefore(x,m.firstChild);for(O=0,A=o.length+u.length;O<A;O++)L=O<o.length?o[O]:u[O-o.length],N=L.attributes.placeholder,N&&(N=N.nodeValue,N&&b.inArray(t,L.type)&&z(L));C=setInterval(function(){for(O=0,A=o.length+u.length;O<A;O++){L=O<o.length?o[O]:u[O-o.length],N=L.attributes.placeholder;if(N){N=N.nodeValue;if(N&&b.inArray(t,L.type)){L.getAttribute(h)||z(L);if(N!==L.getAttribute(a)||L.type==="password"&&!L.getAttribute(l))L.type==="password"&&!L.getAttribute(l)&&b.changeType(L,"text")&&L.setAttribute(l,"password"),L.value===L.getAttribute(a)&&(L.value=N),L.setAttribute(a,N)}}}E||clearInterval(C)},100)}y.disable=y.nativeSupport?M:H,y.enable=y.nativeSupport?M:B}(this),function(e,t,n,r){"use strict";Foundation.libs.abide={name:"abide",version:"4.3.2",settings:{live_validate:!0,focus_on_invalid:!0,timeout:1e3,patterns:{alpha:/[a-zA-Z]+/,alpha_numeric:/[a-zA-Z0-9]+/,integer:/-?\d+/,number:/-?(?:\d+|\d{1,3}(?:,\d{3})+)?(?:\.\d+)?/,password:/(?=^.{8,}$)((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$/,card:/^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,cvv:/^([0-9]){3,4}$/,email:/^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/,url:/(https?|ftp|file|ssh):\/\/(((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?/,domain:/^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}$/,datetime:/([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))/,date:/(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))/,time:/(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}/,dateISO:/\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}/,month_day_year:/(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.](19|20)\d\d/,color:/^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/}},timer:null,init:function(t,n,r){typeof n=="object"&&e.extend(!0,this.settings,n);if(typeof n=="string")return this[n].call(this,r);this.settings.init||this.events()},events:function(){var t=this,n=e("form[data-abide]",this.scope).attr("novalidate","novalidate");n.on("submit validate",function(n){return t.validate(e(this).find("input, textarea, select").get(),n)}),this.settings.init=!0;if(!this.settings.live_validate)return;n.find("input, textarea, select").on("blur change",function(e){t.validate([this],e)}).on("keydown",function(e){clearTimeout(t.timer),t.timer=setTimeout(function(){t.validate([this],e)}.bind(this),t.settings.timeout)})},validate:function(t,n){var r=this.parse_patterns(t),i=r.length,s=e(t[0]).closest("form");for(var o=0;o<i;o++)if(!r[o]&&/submit/.test(n.type))return this.settings.focus_on_invalid&&t[o].focus(),s.trigger("invalid"),e(t[o]).closest("form").attr("data-invalid",""),!1;return/submit/.test(n.type)&&s.trigger("valid"),s.removeAttr("data-invalid"),!0},parse_patterns:function(e){var t=e.length,n=[];for(var r=t-1;r>=0;r--)n.push(this.pattern(e[r]));return this.check_validation_and_apply_styles(n)},pattern:function(e){var t=e.getAttribute("type"),n=typeof e.getAttribute("required")=="string";if(this.settings.patterns.hasOwnProperty(t))return[e,this.settings.patterns[t],n];var r=e.getAttribute("pattern")||"";return this.settings.patterns.hasOwnProperty(r)&&r.length>0?[e,this.settings.patterns[r],n]:r.length>0?[e,new RegExp(r),n]:(r=/.*/,[e,r,n])},check_validation_and_apply_styles:function(t){var n=t.length,r=[];for(var i=n-1;i>=0;i--){var s=t[i][0],o=t[i][2],u=s.value,a=s.type==="radio",f=o?s.value.length>0:!0;a&&o?r.push(this.valid_radio(s,o)):t[i][1].test(u)&&f||!o&&s.value.length<1?(e(s).removeAttr("data-invalid").parent().removeClass("error"),r.push(!0)):(e(s).attr("data-invalid","").parent().addClass("error"),r.push(!1))}return r},valid_radio:function(t,r){var i=t.getAttribute("name"),s=n.getElementsByName(i),o=s.length,u=!1;for(var a=0;a<o;a++)s[a].checked&&(u=!0);for(var a=0;a<o;a++)u?e(s[a]).removeAttr("data-invalid").parent().removeClass("error"):e(s[a]).attr("data-invalid","").parent().addClass("error");return u}}}(Foundation.zj,this,this.document); |
generators/foundation/public/javascripts/foundation/foundation.abide.js
+194
-0
| @@ | @@ -0,0 +1,194 @@ |
| + | /*jslint unparam: true, browser: true, indent: 2 */ |
| + | |
| + | ;(function ($, window, document, undefined) { |
| + | 'use strict'; |
| + | |
| + | Foundation.libs.abide = { |
| + | name : 'abide', |
| + | |
| + | version : '4.3.2', |
| + | |
| + | settings : { |
| + | live_validate : true, |
| + | focus_on_invalid : true, |
| + | timeout : 1000, |
| + | patterns : { |
| + | alpha: /[a-zA-Z]+/, |
| + | alpha_numeric : /[a-zA-Z0-9]+/, |
| + | integer: /-?\d+/, |
| + | number: /-?(?:\d+|\d{1,3}(?:,\d{3})+)?(?:\.\d+)?/, |
| + | |
| + | // generic password: upper-case, lower-case, number/special character, and min 8 characters |
| + | password : /(?=^.{8,}$)((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$/, |
| + | |
| + | // amex, visa, diners |
| + | card : /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/, |
| + | cvv : /^([0-9]){3,4}$/, |
| + | |
| + | // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address |
| + | email : /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/, |
| + | |
| + | url: /(https?|ftp|file|ssh):\/\/(((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?/, |
| + | // abc.de |
| + | domain: /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}$/, |
| + | |
| + | datetime: /([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))/, |
| + | // YYYY-MM-DD |
| + | date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))/, |
| + | // HH:MM:SS |
| + | time : /(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}/, |
| + | dateISO: /\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}/, |
| + | // MM/DD/YYYY |
| + | month_day_year : /(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.](19|20)\d\d/, |
| + | |
| + | // #FFF or #FFFFFF |
| + | color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/ |
| + | } |
| + | }, |
| + | |
| + | timer : null, |
| + | |
| + | init : function (scope, method, options) { |
| + | if (typeof method === 'object') { |
| + | $.extend(true, this.settings, method); |
| + | } |
| + | |
| + | if (typeof method !== 'string') { |
| + | if (!this.settings.init) { this.events(); } |
| + | |
| + | } else { |
| + | return this[method].call(this, options); |
| + | } |
| + | }, |
| + | |
| + | events : function () { |
| + | var self = this, |
| + | forms = $('form[data-abide]', this.scope).attr('novalidate', 'novalidate'); |
| + | |
| + | forms |
| + | .on('submit validate', function (e) { |
| + | return self.validate($(this).find('input, textarea, select').get(), e); |
| + | }); |
| + | |
| + | this.settings.init = true; |
| + | |
| + | if (!this.settings.live_validate) return; |
| + | |
| + | forms |
| + | .find('input, textarea, select') |
| + | .on('blur change', function (e) { |
| + | self.validate([this], e); |
| + | }) |
| + | .on('keydown', function (e) { |
| + | clearTimeout(self.timer); |
| + | self.timer = setTimeout(function () { |
| + | self.validate([this], e); |
| + | }.bind(this), self.settings.timeout); |
| + | }); |
| + | }, |
| + | |
| + | validate : function (els, e) { |
| + | var validations = this.parse_patterns(els), |
| + | validation_count = validations.length, |
| + | form = $(els[0]).closest('form'); |
| + | |
| + | for (var i=0; i < validation_count; i++) { |
| + | if (!validations[i] && /submit/.test(e.type)) { |
| + | if (this.settings.focus_on_invalid) els[i].focus(); |
| + | form.trigger('invalid'); |
| + | $(els[i]).closest('form').attr('data-invalid', ''); |
| + | return false; |
| + | } |
| + | } |
| + | |
| + | if (/submit/.test(e.type)) { |
| + | form.trigger('valid'); |
| + | } |
| + | |
| + | form.removeAttr('data-invalid'); |
| + | |
| + | return true; |
| + | }, |
| + | |
| + | parse_patterns : function (els) { |
| + | var count = els.length, |
| + | el_patterns = []; |
| + | |
| + | for (var i = count - 1; i >= 0; i--) { |
| + | el_patterns.push(this.pattern(els[i])); |
| + | } |
| + | |
| + | return this.check_validation_and_apply_styles(el_patterns); |
| + | }, |
| + | |
| + | pattern : function (el) { |
| + | var type = el.getAttribute('type'), |
| + | required = typeof el.getAttribute('required') === 'string'; |
| + | |
| + | if (this.settings.patterns.hasOwnProperty(type)) { |
| + | return [el, this.settings.patterns[type], required]; |
| + | } |
| + | |
| + | var pattern = el.getAttribute('pattern') || ''; |
| + | |
| + | if (this.settings.patterns.hasOwnProperty(pattern) && pattern.length > 0) { |
| + | return [el, this.settings.patterns[pattern], required]; |
| + | } else if (pattern.length > 0) { |
| + | return [el, new RegExp(pattern), required]; |
| + | } |
| + | |
| + | pattern = /.*/; |
| + | |
| + | return [el, pattern, required]; |
| + | }, |
| + | |
| + | check_validation_and_apply_styles : function (el_patterns) { |
| + | var count = el_patterns.length, |
| + | validations = []; |
| + | |
| + | for (var i = count - 1; i >= 0; i--) { |
| + | var el = el_patterns[i][0], |
| + | required = el_patterns[i][2], |
| + | value = el.value, |
| + | is_radio = el.type === "radio", |
| + | valid_length = (required) ? (el.value.length > 0) : true; |
| + | |
| + | if (is_radio && required) { |
| + | validations.push(this.valid_radio(el, required)); |
| + | } else { |
| + | if (el_patterns[i][1].test(value) && valid_length || |
| + | !required && el.value.length < 1) { |
| + | $(el).removeAttr('data-invalid').parent().removeClass('error'); |
| + | validations.push(true); |
| + | } else { |
| + | $(el).attr('data-invalid', '').parent().addClass('error'); |
| + | validations.push(false); |
| + | } |
| + | } |
| + | } |
| + | |
| + | return validations; |
| + | }, |
| + | |
| + | valid_radio : function (el, required) { |
| + | var name = el.getAttribute('name'), |
| + | group = document.getElementsByName(name), |
| + | count = group.length, |
| + | valid = false; |
| + | |
| + | for (var i=0; i < count; i++) { |
| + | if (group[i].checked) valid = true; |
| + | } |
| + | |
| + | for (var i=0; i < count; i++) { |
| + | if (valid) { |
| + | $(group[i]).removeAttr('data-invalid').parent().removeClass('error'); |
| + | } else { |
| + | $(group[i]).attr('data-invalid', '').parent().addClass('error'); |
| + | } |
| + | } |
| + | |
| + | return valid; |
| + | } |
| + | }; |
| + | }(Foundation.zj, this, this.document)); |
generators/foundation/public/javascripts/foundation/foundation.alerts.js
+11
-6
| @@ | @@ -6,22 +6,24 @@ |
| Foundation.libs.alerts = { | |
| name : 'alerts', | |
| - | version : '4.0.0', |
| + | version : '4.3.2', |
| settings : { | |
| + | animation: 'fadeOut', |
| speed: 300, // fade out speed | |
| callback: function (){} | |
| }, | |
| init : function (scope, method, options) { | |
| this.scope = scope || this.scope; | |
| + | Foundation.inherit(this, 'data_options'); |
| if (typeof method === 'object') { | |
| $.extend(true, this.settings, method); | |
| } | |
| - | if (typeof method != 'string') { |
| - | if (!this.settings.init) this.events(); |
| + | if (typeof method !== 'string') { |
| + | if (!this.settings.init) { this.events(); } |
| return this.settings.init; | |
| } else { | |
| @@ | @@ -33,10 +35,13 @@ |
| var self = this; | |
| $(this.scope).on('click.fndtn.alerts', '[data-alert] a.close', function (e) { | |
| + | var alertBox = $(this).closest("[data-alert]"), |
| + | settings = $.extend({}, self.settings, self.data_options(alertBox)); |
| + | |
| e.preventDefault(); | |
| - | $(this).closest("[data-alert]").fadeOut(self.speed, function () { |
| + | alertBox[settings.animation](settings.speed, function () { |
| $(this).remove(); | |
| - | self.settings.callback(); |
| + | settings.callback(); |
| }); | |
| }); | |
| @@ | @@ -49,4 +54,4 @@ |
| reflow : function () {} | |
| }; | |
| - | }(Foundation.zj, this, this.document)); |
| \ No newline at end of file | |
| + | }(Foundation.zj, this, this.document)); |
generators/foundation/public/javascripts/foundation/foundation.clearing.js
+6
-6
| @@ | @@ -6,7 +6,7 @@ |
| Foundation.libs.clearing = { | |
| name : 'clearing', | |
| - | version : '4.1.3', |
| + | version: '4.3.2', |
| settings : { | |
| templates : { | |
| @@ | @@ -33,7 +33,7 @@ |
| options = $.extend(true, this.settings, method); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| $(this.scope).find('ul[data-clearing]').each(function () { | |
| var $el = $(this), | |
| options = options || {}, | |
| @@ | @@ -79,9 +79,9 @@ |
| // if clearing is open and the current image is | |
| // clicked, go to the next image in sequence | |
| - | if (target.hasClass('visible') |
| - | && current[0] === target[0] |
| - | && next.length > 0 && self.is_open(current)) { |
| + | if (target.hasClass('visible') && |
| + | current[0] === target[0] && |
| + | next.length > 0 && self.is_open(current)) { |
| target = next; | |
| image = target.find('img'); | |
| } | |
| @@ | @@ -228,7 +228,7 @@ |
| }, | |
| is_open : function (current) { | |
| - | return current.parent().attr('style').length > 0; |
| + | return current.parent().prop('style').length > 0; |
| }, | |
| keydown : function (e) { | |
generators/foundation/public/javascripts/foundation/foundation.cookie.js
+1
-1
| @@ | @@ -71,4 +71,4 @@ |
| return false; | |
| }; | |
| - | })(Foundation.zj, document); |
| \ No newline at end of file | |
| + | })(Foundation.zj, document); |
generators/foundation/public/javascripts/foundation/foundation.dropdown.js
+19
-14
| @@ | @@ -6,7 +6,7 @@ |
| Foundation.libs.dropdown = { | |
| name : 'dropdown', | |
| - | version : '4.2.0', |
| + | version : '4.3.2', |
| settings : { | |
| activeClass: 'open', | |
| @@ | @@ -23,7 +23,7 @@ |
| $.extend(true, this.settings, method); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| if (!this.settings.init) { | |
| this.events(); | |
| @@ | @@ -57,13 +57,15 @@ |
| .on('opened.fndtn.dropdown', '[data-dropdown-content]', this.settings.opened) | |
| .on('closed.fndtn.dropdown', '[data-dropdown-content]', this.settings.closed); | |
| - | $('body').on('click.fndtn.dropdown', function (e) { |
| + | $(document).on('click.fndtn.dropdown', function (e) { |
| var parent = $(e.target).closest('[data-dropdown-content]'); | |
| - | if ($(e.target).data('dropdown')) { |
| + | if ($(e.target).data('dropdown') || $(e.target).parent().data('dropdown')) { |
| return; | |
| } | |
| - | if (parent.length > 0 && ($(e.target).is('[data-dropdown-content]') || $.contains(parent.first()[0], e.target))) { |
| + | if (!($(e.target).data('revealId')) && |
| + | (parent.length > 0 && ($(e.target).is('[data-dropdown-content]') || |
| + | $.contains(parent.first()[0], e.target)))) { |
| e.stopPropagation(); | |
| return; | |
| } | |
| @@ | @@ -99,6 +101,10 @@ |
| toggle : function (target) { | |
| var dropdown = $('#' + target.data('dropdown')); | |
| + | if (dropdown.length === 0) { |
| + | // No dropdown found, not continuing |
| + | return; |
| + | } |
| this.close.call(this, $('[data-dropdown-content]').not(dropdown)); | |
| @@ | @@ -121,25 +127,24 @@ |
| css : function (dropdown, target) { | |
| var offset_parent = dropdown.offsetParent(); | |
| - | // temporary workaround until 4.2 |
| - | if (offset_parent.length > 0 && /body/i.test(dropdown.offsetParent()[0].nodeName)) { |
| + | // if (offset_parent.length > 0 && /body/i.test(dropdown.offsetParent()[0].nodeName)) { |
| var position = target.offset(); | |
| - | position.top -= dropdown.offsetParent().offset().top; |
| - | position.left -= dropdown.offsetParent().offset().left; |
| - | } else { |
| - | var position = target.position(); |
| - | } |
| + | position.top -= offset_parent.offset().top; |
| + | position.left -= offset_parent.offset().left; |
| + | // } else { |
| + | // var position = target.position(); |
| + | // } |
| if (this.small()) { | |
| dropdown.css({ | |
| position : 'absolute', | |
| width: '95%', | |
| - | left: '2.5%', |
| 'max-width': 'none', | |
| top: position.top + this.outerHeight(target) | |
| }); | |
| + | dropdown.css(Foundation.rtl ? 'right':'left', '2.5%'); |
| } else { | |
| - | if (!Foundation.rtl && $(window).width() > this.outerWidth(dropdown) + target.offset().left) { |
| + | if (!Foundation.rtl && $(window).width() > this.outerWidth(dropdown) + target.offset().left && !this.data_options(target).align_right) { |
| var left = position.left; | |
| if (dropdown.hasClass('right')) { | |
| dropdown.removeClass('right'); | |
generators/foundation/public/javascripts/foundation/foundation.forms.js
+77
-37
| @@ | @@ -2,9 +2,9 @@ |
| 'use strict'; | |
| Foundation.libs.forms = { | |
| - | name: 'forms', |
| + | name : 'forms', |
| - | version: '4.2.1', |
| + | version: '4.3.2', |
| cache: {}, | |
| @@ | @@ -19,7 +19,7 @@ |
| $.extend(true, this.settings, method); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| if (!this.settings.init) { | |
| this.events(); | |
| } | |
| @@ | @@ -33,12 +33,22 @@ |
| }, | |
| assemble: function () { | |
| - | $('form.custom input[type="radio"]', $(this.scope)).not('[data-customforms="disabled"]') |
| - | .each(this.append_custom_markup); |
| - | $('form.custom input[type="checkbox"]', $(this.scope)).not('[data-customforms="disabled"]') |
| - | .each(this.append_custom_markup); |
| + | |
| + | var forms = this; |
| + | |
| + | $('form.custom input[type="radio"],[type="checkbox"]', $(this.scope)) |
| + | .not('[data-customforms="disabled"]') |
| + | .not('.' + this.settings.disable_class) |
| + | .each(function(idx, sel){ |
| + | forms.set_custom_markup(sel); |
| + | }) |
| + | .change(function(){ |
| + | forms.set_custom_markup(this); |
| + | }); |
| + | |
| $('form.custom select', $(this.scope)) | |
| .not('[data-customforms="disabled"]') | |
| + | .not('.' + this.settings.disable_class) |
| .not('[multiple=multiple]') | |
| .each(this.append_custom_select); | |
| }, | |
| @@ | @@ -57,12 +67,13 @@ |
| e.stopPropagation(); | |
| self.toggle_radio($(this)); | |
| }) | |
| - | .on('change.fndtn.forms', 'form.custom select:not([data-customforms="disabled"])', function (e, force_refresh) { |
| + | .on('change.fndtn.forms', 'form.custom select', function (e, force_refresh) { |
| + | if ($(this).is('[data-customforms="disabled"]')) return; |
| self.refresh_custom_select($(this), force_refresh); | |
| }) | |
| .on('click.fndtn.forms', 'form.custom label', function (e) { | |
| if ($(e.target).is('label')) { | |
| - | var $associatedElement = $('#' + self.escape($(this).attr('for')) + ':not([data-customforms="disabled"])'), |
| + | var $associatedElement = $('#' + self.escape($(this).attr('for'))).not('[data-customforms="disabled"]'), |
| $customCheckbox, | |
| $customRadio; | |
| @@ | @@ -71,7 +82,7 @@ |
| e.preventDefault(); | |
| $customCheckbox = $(this).find('span.custom.checkbox'); | |
| //the checkbox might be outside after the label or inside of another element | |
| - | if ($customCheckbox.length == 0) { |
| + | if ($customCheckbox.length === 0) { |
| $customCheckbox = $associatedElement.add(this).siblings('span.custom.checkbox').first(); | |
| } | |
| self.toggle_checkbox($customCheckbox); | |
| @@ | @@ -79,7 +90,7 @@ |
| e.preventDefault(); | |
| $customRadio = $(this).find('span.custom.radio'); | |
| //the radio might be outside after the label or inside of another element | |
| - | if ($customRadio.length == 0) { |
| + | if ($customRadio.length === 0) { |
| $customRadio = $associatedElement.add(this).siblings('span.custom.radio').first(); | |
| } | |
| self.toggle_radio($customRadio); | |
| @@ | @@ -136,7 +147,7 @@ |
| .text($this.text()); | |
| $this.closest('ul').find('li').each(function (index) { | |
| - | if ($this[0] == this) { |
| + | if ($this[0] === this) { |
| selectedIndex = index; | |
| } | |
| }); | |
| @@ | @@ -144,18 +155,33 @@ |
| //store the old value in data | |
| $select.data('prevalue', $oldThis.html()); | |
| - | $select.trigger('change'); |
| + | |
| + | // Kick off full DOM change event |
| + | if (typeof (document.createEvent) != 'undefined') { |
| + | var event = document.createEvent('HTMLEvents'); |
| + | event.initEvent('change', true, true); |
| + | $select[0].dispatchEvent(event); |
| + | } else { |
| + | $select[0].fireEvent('onchange'); // for IE |
| + | } |
| } | |
| }); | |
| $(window).on('keydown', function (e) { | |
| var focus = document.activeElement, | |
| self = Foundation.libs.forms, | |
| - | dropdown = $('.custom.dropdown.open'); |
| + | dropdown = $('.custom.dropdown'), |
| + | select = getFirstPrevSibling(dropdown, 'select'), |
| + | inputs = $('input,select,textarea,button'); // Zepto-compatible jQuery(":input") |
| - | if (dropdown.length > 0) { |
| + | if (dropdown.length > 0 && dropdown.hasClass('open')) { |
| e.preventDefault(); | |
| + | if (e.which === 9) { |
| + | $(inputs[$(inputs).index(select) + 1]).focus(); |
| + | dropdown.removeClass('open'); |
| + | } |
| + | |
| if (e.which === 13) { | |
| dropdown.find('li.selected').trigger('click'); | |
| } | |
| @@ | @@ -196,6 +222,15 @@ |
| } | |
| }); | |
| + | $(window).on('keyup', function (e) { |
| + | var focus = document.activeElement, |
| + | dropdown = $('.custom.dropdown'); |
| + | |
| + | if (focus === dropdown.find('.current')[0]) { |
| + | dropdown.find('.selector').focus().click(); |
| + | } |
| + | }); |
| + | |
| this.settings.init = true; | |
| }, | |
| @@ | @@ -226,10 +261,14 @@ |
| }.bind(this), 10); | |
| }, | |
| - | append_custom_markup: function (idx, sel) { |
| + | set_custom_markup: function (sel) { |
| var $this = $(sel), | |
| type = $this.attr('type'), | |
| $span = $this.next('span.custom.' + type); | |
| + | |
| + | if (!$this.parent().hasClass('switch')) { |
| + | $this.addClass('hidden-field'); |
| + | } |
| if ($span.length === 0) { | |
| $span = $('<span class="custom ' + type + '"></span>').insertAfter($this); | |
| @@ | @@ -254,14 +293,12 @@ |
| $listItems, | |
| $currentSelect = false; | |
| - | if ($this.hasClass(self.settings.disable_class)) return; |
| - | |
| if ($customSelect.length === 0) { | |
| var customSelectSize = $this.hasClass('small') ? 'small' : $this.hasClass('medium') ? 'medium' : $this.hasClass('large') ? 'large' : $this.hasClass('expand') ? 'expand' : ''; | |
| $customSelect = $('<div class="' + ['custom', 'dropdown', customSelectSize].concat(copyClasses).filter(function (item, idx, arr) { | |
| - | if (item == '') return false; |
| - | return arr.indexOf(item) == idx; |
| + | if (item === '') return false; |
| + | return arr.indexOf(item) === idx; |
| }).join(' ') + '"><a href="#" class="selector"></a><ul /></div>'); | |
| $selector = $customSelect.find(".selector"); | |
| @@ | @@ -275,7 +312,7 @@ |
| $customList.append(liHtml); | |
| $currentSelect = $customSelect | |
| - | .prepend('<a href="#" class="current">' + $selectedOption.html() + '</a>') |
| + | .prepend('<a href="#" class="current">' + ($selectedOption.html() || '') + '</a>') |
| .find(".current"); | |
| $this.after($customSelect) | |
| @@ | @@ -353,30 +390,27 @@ |
| var maxWidth = 0, | |
| $customSelect = $select.next(), | |
| $options = $select.find('option'), | |
| + | $customList = $customSelect.find('ul'), |
| $listItems = $customSelect.find('li'); | |
| - | if ($listItems.length != this.cache[$customSelect.data('id')] || force_refresh) { |
| - | $customSelect.find('ul').html(''); |
| + | if ($options.length !== this.cache[$customSelect.data('id')] || force_refresh) { |
| + | $customList.html(''); |
| + | // rebuild and re-populate all at once |
| + | var customSelectHtml = ''; |
| $options.each(function () { | |
| - | var $li = $('<li>' + $(this).html() + '</li>'); |
| - | $customSelect.find('ul').append($li); |
| - | }); |
| - | |
| - | // re-populate |
| - | $options.each(function (index) { |
| - | if (this.selected) { |
| - | $customSelect.find('li').eq(index).addClass('selected'); |
| - | $customSelect.find('.current').html($(this).html()); |
| - | } |
| - | if ($(this).is(':disabled')) { |
| - | $customSelect.find('li').eq(index).addClass('disabled'); |
| + | var $this = $(this), thisHtml = $this.html(), thisSelected = this.selected; |
| + | customSelectHtml += '<li class="' + (thisSelected ? ' selected ' : '') + ($this.is(':disabled') ? ' disabled ' : '') + '">' + thisHtml + '</li>'; |
| + | if (thisSelected) { |
| + | $customSelect.find('.current').html(thisHtml); |
| } | |
| }); | |
| + | $customList.html(customSelectHtml); |
| + | |
| // fix width | |
| - | $customSelect.removeAttr('style') |
| - | .find('ul').removeAttr('style'); |
| + | $customSelect.removeAttr('style'); |
| + | $customList.removeAttr('style'); |
| $customSelect.find('li').each(function () { | |
| $customSelect.addClass('open'); | |
| if (self.outerWidth($(this)) > maxWidth) { | |
| @@ | @@ -390,6 +424,11 @@ |
| this.cache[$customSelect.data('id')] = $listItems.length; | |
| } | |
| }, | |
| + | |
| + | refresh_custom_selection: function ($select) { |
| + | var selectedValue = $('option:selected', $select).text(); |
| + | $('a.current', $select.next()).text(selectedValue); |
| + | }, |
| toggle_checkbox: function ($element) { | |
| var $input = $element.prev(), | |
| @@ | @@ -423,6 +462,7 @@ |
| }, | |
| escape: function (text) { | |
| + | if (!text) return ''; |
| return text.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&"); | |
| }, | |
generators/foundation/public/javascripts/foundation/foundation.interchange.js
+33
-24
| @@ | @@ -6,10 +6,12 @@ |
| Foundation.libs.interchange = { | |
| name : 'interchange', | |
| - | version : '4.2.1', |
| + | version : '4.2.4', |
| cache : {}, | |
| + | images_loaded : false, |
| + | |
| settings : { | |
| load_attr : 'interchange', | |
| @@ | @@ -20,22 +22,20 @@ |
| large : 'only screen and (min-width: 1440px)', | |
| landscape : 'only screen and (orientation: landscape)', | |
| portrait : 'only screen and (orientation: portrait)', | |
| - | retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' |
| - | + 'only screen and (min--moz-device-pixel-ratio: 2),' |
| - | + 'only screen and (-o-min-device-pixel-ratio: 2/1),' |
| - | + 'only screen and (min-device-pixel-ratio: 2),' |
| - | + 'only screen and (min-resolution: 192dpi),' |
| - | + 'only screen and (min-resolution: 2dppx)' |
| + | retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' + |
| + | 'only screen and (min--moz-device-pixel-ratio: 2),' + |
| + | 'only screen and (-o-min-device-pixel-ratio: 2/1),' + |
| + | 'only screen and (min-device-pixel-ratio: 2),' + |
| + | 'only screen and (min-resolution: 192dpi),' + |
| + | 'only screen and (min-resolution: 2dppx)' |
| }, | |
| directives : { | |
| - | replace : function (el, path) { |
| + | replace: function (el, path) { |
| if (/IMG/.test(el[0].nodeName)) { | |
| - | var path_parts = path.split('/'), |
| - | path_file = path_parts[path_parts.length - 1], |
| - | orig_path = el[0].src; |
| + | var orig_path = el[0].src; |
| - | if (new RegExp(path_file, 'i').test(el[0].src)) return; |
| + | if (new RegExp(path, 'i').test(orig_path)) return; |
| el[0].src = path; | |
| @@ | @@ -55,7 +55,7 @@ |
| this.events(); | |
| this.images(); | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| return this.settings.init; | |
| } else { | |
| return this[method].call(this, options); | |
| @@ | @@ -73,6 +73,11 @@ |
| resize : function () { | |
| var cache = this.cache; | |
| + | if(!this.images_loaded) { |
| + | setTimeout($.proxy(this.resize, this), 50); |
| + | return; |
| + | } |
| + | |
| for (var uuid in cache) { | |
| if (cache.hasOwnProperty(uuid)) { | |
| var passed = this.results(uuid, cache[uuid]); | |
| @@ | @@ -87,18 +92,17 @@ |
| }, | |
| results : function (uuid, scenarios) { | |
| - | var count = scenarios.length, |
| - | results_arr = []; |
| + | var count = scenarios.length; |
| if (count > 0) { | |
| var el = $('[data-uuid="' + uuid + '"]'); | |
| for (var i = count - 1; i >= 0; i--) { | |
| - | var rule = scenarios[i][2]; |
| + | var mq, rule = scenarios[i][2]; |
| if (this.settings.named_queries.hasOwnProperty(rule)) { | |
| - | var mq = matchMedia(this.settings.named_queries[rule]); |
| + | mq = matchMedia(this.settings.named_queries[rule]); |
| } else { | |
| - | var mq = matchMedia(scenarios[i][2]); |
| + | mq = matchMedia(rule); |
| } | |
| if (mq.matches) { | |
| return {el: el, scenario: scenarios[i]}; | |
| @@ | @@ -120,12 +124,15 @@ |
| update_images : function () { | |
| var images = document.getElementsByTagName('img'), | |
| count = images.length, | |
| + | loaded_count = 0, |
| data_attr = 'data-' + this.settings.load_attr; | |
| this.cached_images = []; | |
| + | this.images_loaded = false; |
| for (var i = count - 1; i >= 0; i--) { | |
| - | this.loaded($(images[i]), (i === 0), function (image, last) { |
| + | this.loaded($(images[i]), function (image) { |
| + | loaded_count++; |
| if (image) { | |
| var str = image.getAttribute(data_attr) || ''; | |
| @@ | @@ -134,8 +141,10 @@ |
| } | |
| } | |
| - | if (last) this.enhance(); |
| - | |
| + | if(loaded_count === count) { |
| + | this.images_loaded = true; |
| + | this.enhance(); |
| + | } |
| }.bind(this)); | |
| } | |
| @@ | @@ -145,9 +154,9 @@ |
| // based on jquery.imageready.js | |
| // @weblinc, @jsantell, (c) 2012 | |
| - | loaded : function (image, last, callback) { |
| + | loaded : function (image, callback) { |
| function loaded () { | |
| - | callback(image[0], last); |
| + | callback(image[0]); |
| } | |
| function bindLoad () { | |
| @@ | @@ -268,4 +277,4 @@ |
| }; | |
| - | }(Foundation.zj, this, this.document)); |
| \ No newline at end of file | |
| + | }(Foundation.zj, this, this.document)); |
generators/foundation/public/javascripts/foundation/foundation.joyride.js
+17
-9
| @@ | @@ -3,10 +3,12 @@ |
| (function ($, window, document, undefined) { | |
| 'use strict'; | |
| + | var Modernizr = Modernizr || false; |
| + | |
| Foundation.libs.joyride = { | |
| - | name: 'joyride', |
| + | name : 'joyride', |
| - | version : '4.2.0', |
| + | version : '4.3.2', |
| defaults : { | |
| expose : false, // turn on or off the expose feature | |
| @@ | @@ -42,7 +44,7 @@ |
| expose : '<div class="joyride-expose-wrapper"></div>', | |
| exposeCover: '<div class="joyride-expose-cover"></div>' | |
| }, | |
| - | exposeAddClass : '' // One or more space-separated class names to be added to exposed element |
| + | exposeAddClass : '' // One or more space-separated class names to be added to exposed element |
| }, | |
| settings : {}, | |
| @@ | @@ -57,7 +59,7 @@ |
| $.extend(true, this.settings, this.defaults, options); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| if (!this.settings.init) this.events(); | |
| return this.settings.init; | |
| @@ | @@ -121,7 +123,7 @@ |
| integer_settings = ['timer', 'scrollSpeed', 'startOffset', 'tipAnimationFadeSpeed', 'cookieExpires'], | |
| int_settings_count = integer_settings.length; | |
| - | if (!this.settings.init) this.init(); |
| + | if (!this.settings.init) this.events(); |
| // non configureable settings | |
| this.settings.$content_el = $this; | |
| @@ | @@ -339,7 +341,7 @@ |
| return Modernizr.mq('only screen and (max-width: 767px)') || $('.lt-ie9').length > 0; | |
| } | |
| - | return (this.settings.$window.width() < 767); |
| + | return ($(window).width() < 767); |
| }, | |
| hide : function () { | |
| @@ | @@ -350,7 +352,13 @@ |
| if (!this.settings.modal) { | |
| $('.joyride-modal-bg').hide(); | |
| } | |
| - | this.settings.$current_tip.hide(); |
| + | |
| + | // Prevent scroll bouncing...wait to remove from layout |
| + | this.settings.$current_tip.css('visibility', 'hidden'); |
| + | setTimeout($.proxy(function() { |
| + | this.hide(); |
| + | this.css('visibility', 'visible'); |
| + | }, this.settings.$current_tip), 0); |
| this.settings.postStepCallback(this.settings.$li.index(), | |
| this.settings.$current_tip); | |
| }, | |
| @@ | @@ -599,7 +607,7 @@ |
| zIndex: el.css('z-index'), | |
| position: el.css('position') | |
| }; | |
| - | |
| + | |
| origClasses = el.attr('class') == null ? '' : el.attr('class'); | |
| el.css('z-index',parseInt(expose.css('z-index'))+1); | |
| @@ | @@ -678,7 +686,7 @@ |
| el.css('position', origCSS.position); | |
| } | |
| } | |
| - | |
| + | |
| origClasses = el.data('orig-class'); | |
| el.attr('class', origClasses); | |
| el.removeData('orig-classes'); | |
generators/foundation/public/javascripts/foundation/foundation.js
+30
-13
| @@ | @@ -38,6 +38,10 @@ if (typeof jQuery === "undefined" && |
| https://github.com/paulirish/matchMedia.js | |
| */ | |
| + | $('head').append('<meta class="foundation-mq-small">'); |
| + | $('head').append('<meta class="foundation-mq-medium">'); |
| + | $('head').append('<meta class="foundation-mq-large">'); |
| + | |
| window.matchMedia = window.matchMedia || (function( doc, undefined ) { | |
| "use strict"; | |
| @@ | @@ -82,7 +86,7 @@ if (typeof jQuery === "undefined" && |
| var t = Object(this), | |
| len = t.length >>> 0; | |
| - | if (typeof fun != "function") { |
| + | if (typeof fun !== "function") { |
| return; | |
| } | |
| @@ | @@ -166,10 +170,18 @@ if (typeof jQuery === "undefined" && |
| window.Foundation = { | |
| name : 'Foundation', | |
| - | version : '4.2.0', |
| + | version : '4.3.2', |
| cache : {}, | |
| + | media_queries : { |
| + | small : $('.foundation-mq-small').css('font-family').replace(/\'/g, ''), |
| + | medium : $('.foundation-mq-medium').css('font-family').replace(/\'/g, ''), |
| + | large : $('.foundation-mq-large').css('font-family').replace(/\'/g, '') |
| + | }, |
| + | |
| + | stylesheet : $('<style></style>').appendTo('head')[0].sheet, |
| + | |
| init : function (scope, libraries, method, options, response, /* internal */ nc) { | |
| var library_arr, | |
| args = [scope, method, options, response], | |
| @@ | @@ -231,8 +243,7 @@ if (typeof jQuery === "undefined" && |
| if (this.libs.hasOwnProperty(lib)) { | |
| this.patch(this.libs[lib]); | |
| return this.libs[lib].init.apply(this.libs[lib], args); | |
| - | } |
| - | else { |
| + | } else { |
| return function () {}; | |
| } | |
| }.bind(this), lib); | |
| @@ | @@ -267,7 +278,7 @@ if (typeof jQuery === "undefined" && |
| }, | |
| random_str : function (length) { | |
| - | var chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz'.split(''); |
| + | var chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split(''); |
| if (!length) { | |
| length = Math.floor(Math.random() * chars.length); | |
| @@ | @@ -386,6 +397,18 @@ if (typeof jQuery === "undefined" && |
| } | |
| return true; | |
| + | }, |
| + | |
| + | addCustomRule : function(rule, media) { |
| + | if(media === undefined) { |
| + | Foundation.stylesheet.insertRule(rule, Foundation.stylesheet.cssRules.length); |
| + | } else { |
| + | var query = Foundation.media_queries[media]; |
| + | if(query !== undefined) { |
| + | Foundation.stylesheet.insertRule('@media ' + |
| + | Foundation.media_queries[media] + '{ ' + rule + ' }'); |
| + | } |
| + | } |
| } | |
| }, | |
| @@ | @@ -402,7 +425,7 @@ if (typeof jQuery === "undefined" && |
| return el.outerHeight(); | |
| }; | |
| - | lib.outerWidth = function (el) { |
| + | lib.outerWidth = function (el, bool) { |
| if (typeof Zepto === 'function') { | |
| return el.width(); | |
| } | |
| @@ | @@ -426,13 +449,7 @@ if (typeof jQuery === "undefined" && |
| return true; | |
| }, | |
| - | zj : function () { |
| - | if (typeof Zepto !== 'undefined') { |
| - | return Zepto; |
| - | } else { |
| - | return jQuery; |
| - | } |
| - | }() |
| + | zj : $ |
| }; | |
| $.fn.foundation = function () { | |
generators/foundation/public/javascripts/foundation/foundation.magellan.js
+9
-5
| @@ | @@ -6,10 +6,11 @@ |
| Foundation.libs.magellan = { | |
| name : 'magellan', | |
| - | version : '4.2.0', |
| + | version : '4.3.2', |
| settings : { | |
| - | activeClass: 'active' |
| + | activeClass: 'active', |
| + | threshold: 0 |
| }, | |
| init : function (scope, method, options) { | |
| @@ | @@ -20,7 +21,7 @@ |
| $.extend(true, this.settings, method); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| if (!this.settings.init) { | |
| this.fixed_magellan = $("[data-magellan-expedition]"); | |
| this.set_threshold(); | |
| @@ | @@ -79,8 +80,10 @@ |
| if ($expedition.data("magellan-fixed-position") != fixed_position) { | |
| $expedition.data("magellan-fixed-position", fixed_position); | |
| if (fixed_position) { | |
| + | $expedition.addClass('fixed'); |
| $expedition.css({position:"fixed", top:0}); | |
| } else { | |
| + | $expedition.removeClass('fixed'); |
| $expedition.css({position:"", top:""}); | |
| } | |
| if (fixed_position && typeof attr != 'undefined' && attr != false) { | |
| @@ | @@ -117,7 +120,7 @@ |
| }, | |
| set_threshold : function () { | |
| - | if (!this.settings.threshold) { |
| + | if (typeof this.settings.threshold !== 'number') { |
| this.settings.threshold = (this.fixed_magellan.length > 0) ? | |
| this.outerHeight(this.fixed_magellan, true) : 0; | |
| } | |
| @@ | @@ -125,8 +128,9 @@ |
| off : function () { | |
| $(this.scope).off('.fndtn.magellan'); | |
| + | $(window).off('.fndtn.magellan'); |
| }, | |
| reflow : function () {} | |
| }; | |
| - | }(Foundation.zj, this, this.document)); |
| \ No newline at end of file | |
| + | }(Foundation.zj, this, this.document)); |
generators/foundation/public/javascripts/foundation/foundation.orbit.js
+361
-319
| @@ | @@ -1,214 +1,219 @@ |
| ;(function ($, window, document, undefined) { | |
| 'use strict'; | |
| - | Foundation.libs = Foundation.libs || {}; |
| + | var noop = function() {}; |
| - | Foundation.libs.orbit = { |
| - | name: 'orbit', |
| + | var Orbit = function(el, settings) { |
| + | // Don't reinitialize plugin |
| + | if (el.hasClass(settings.slides_container_class)) { |
| + | return this; |
| + | } |
| - | version: '4.2.0', |
| + | var self = this, |
| + | container, |
| + | slides_container = el, |
| + | number_container, |
| + | bullets_container, |
| + | timer_container, |
| + | idx = 0, |
| + | animate, |
| + | timer, |
| + | locked = false, |
| + | adjust_height_after = false; |
| + | |
| + | slides_container.children().first().addClass(settings.active_slide_class); |
| + | |
| + | self.update_slide_number = function(index) { |
| + | if (settings.slide_number) { |
| + | number_container.find('span:first').text(parseInt(index)+1); |
| + | number_container.find('span:last').text(slides_container.children().length); |
| + | } |
| + | if (settings.bullets) { |
| + | bullets_container.children().removeClass(settings.bullets_active_class); |
| + | $(bullets_container.children().get(index)).addClass(settings.bullets_active_class); |
| + | } |
| + | }; |
| + | |
| + | self.update_active_link = function(index) { |
| + | var link = $('a[data-orbit-link="'+slides_container.children().eq(index).attr('data-orbit-slide')+'"]'); |
| + | link.parents('ul').find('[data-orbit-link]').removeClass(settings.bullets_active_class); |
| + | link.addClass(settings.bullets_active_class); |
| + | }; |
| + | |
| + | self.build_markup = function() { |
| + | slides_container.wrap('<div class="'+settings.container_class+'"></div>'); |
| + | container = slides_container.parent(); |
| + | slides_container.addClass(settings.slides_container_class); |
| + | |
| + | if (settings.navigation_arrows) { |
| + | container.append($('<a href="#"><span></span></a>').addClass(settings.prev_class)); |
| + | container.append($('<a href="#"><span></span></a>').addClass(settings.next_class)); |
| + | } |
| - | settings: { |
| - | timer_speed: 10000, |
| - | pause_on_hover: true, |
| - | resume_on_mouseout: false, |
| - | animation_speed: 500, |
| - | bullets: true, |
| - | stack_on_small: true, |
| - | navigation_arrows: true, |
| - | slide_number: true, |
| - | container_class: 'orbit-container', |
| - | stack_on_small_class: 'orbit-stack-on-small', |
| - | next_class: 'orbit-next', |
| - | prev_class: 'orbit-prev', |
| - | timer_container_class: 'orbit-timer', |
| - | timer_paused_class: 'paused', |
| - | timer_progress_class: 'orbit-progress', |
| - | slides_container_class: 'orbit-slides-container', |
| - | bullets_container_class: 'orbit-bullets', |
| - | bullets_active_class: 'active', |
| - | slide_number_class: 'orbit-slide-number', |
| - | caption_class: 'orbit-caption', |
| - | active_slide_class: 'active', |
| - | orbit_transition_class: 'orbit-transitioning' |
| - | }, |
| + | if (settings.timer) { |
| + | timer_container = $('<div>').addClass(settings.timer_container_class); |
| + | timer_container.append('<span>'); |
| + | timer_container.append($('<div>').addClass(settings.timer_progress_class)); |
| + | timer_container.addClass(settings.timer_paused_class); |
| + | container.append(timer_container); |
| + | } |
| - | init: function (scope, method, options) { |
| - | var self = this; |
| - | Foundation.inherit(self, 'data_options'); |
| + | if (settings.slide_number) { |
| + | number_container = $('<div>').addClass(settings.slide_number_class); |
| + | number_container.append('<span></span> ' + settings.slide_number_text + ' <span></span>'); |
| + | container.append(number_container); |
| + | } |
| - | if (typeof method === 'object') { |
| - | $.extend(true, self.settings, method); |
| + | if (settings.bullets) { |
| + | bullets_container = $('<ol>').addClass(settings.bullets_container_class); |
| + | container.append(bullets_container); |
| + | slides_container.children().each(function(idx, el) { |
| + | var bullet = $('<li>').attr('data-orbit-slide', idx); |
| + | bullets_container.append(bullet); |
| + | }); |
| } | |
| - | if ($(scope).is('[data-orbit]')) { |
| - | var scoped_self = $.extend(true, {}, self); |
| - | scoped_self._init(idx, el); |
| + | if (settings.stack_on_small) { |
| + | container.addClass(settings.stack_on_small_class); |
| } | |
| - | $('[data-orbit]', scope).each(function(idx, el) { |
| - | var scoped_self = $.extend(true, {}, self); |
| - | scoped_self._init(idx, el); |
| - | }); |
| - | }, |
| + | self.update_slide_number(0); |
| + | self.update_active_link(0); |
| + | }; |
| + | |
| + | self._goto = function(next_idx, start_timer) { |
| + | // if (locked) {return false;} |
| + | if (next_idx === idx) {return false;} |
| + | if (typeof timer === 'object') {timer.restart();} |
| + | var slides = slides_container.children(); |
| + | |
| + | var dir = 'next'; |
| + | locked = true; |
| + | if (next_idx < idx) {dir = 'prev';} |
| + | if (next_idx >= slides.length) {next_idx = 0;} |
| + | else if (next_idx < 0) {next_idx = slides.length - 1;} |
| + | |
| + | var current = $(slides.get(idx)); |
| + | var next = $(slides.get(next_idx)); |
| - | _container_html: function() { |
| - | var self = this; |
| - | return '<div class="' + self.settings.container_class + '"></div>'; |
| - | }, |
| + | current.css('zIndex', 2); |
| + | current.removeClass(settings.active_slide_class); |
| + | next.css('zIndex', 4).addClass(settings.active_slide_class); |
| - | _bullets_container_html: function($slides) { |
| - | var self = this, |
| - | $list = $('<ol class="' + self.settings.bullets_container_class + '"></ol>'); |
| - | $slides.each(function(idx, slide) { |
| - | var $item = $('<li data-orbit-slide-number="' + (idx+1) + '" class=""></li>'); |
| - | if (idx === 0) { |
| - | $item.addClass(self.settings.bullets_active_class); |
| + | slides_container.trigger('orbit:before-slide-change'); |
| + | settings.before_slide_change(); |
| + | self.update_active_link(next_idx); |
| + | |
| + | var callback = function() { |
| + | var unlock = function() { |
| + | idx = next_idx; |
| + | locked = false; |
| + | if (start_timer === true) {timer = self.create_timer(); timer.start();} |
| + | self.update_slide_number(idx); |
| + | slides_container.trigger('orbit:after-slide-change',[{slide_number: idx, total_slides: slides.length}]); |
| + | settings.after_slide_change(idx, slides.length); |
| + | }; |
| + | if (slides_container.height() != next.height() && settings.variable_height) { |
| + | slides_container.animate({'height': next.height()}, 250, 'linear', unlock); |
| + | } else { |
| + | unlock(); |
| } | |
| - | $list.append($item); |
| - | }); |
| - | return $list; |
| - | }, |
| + | }; |
| - | _slide_number_html: function(slide_number, total_slides) { |
| - | var self = this, |
| - | $container = $('<div class="' + self.settings.slide_number_class + '"></div>'); |
| - | $container.append('<span>' + slide_number + '</span> of <span>' + total_slides + '</span>'); |
| - | return $container; |
| - | }, |
| + | if (slides.length === 1) {callback(); return false;} |
| - | _timer_html: function() { |
| - | var self = this; |
| - | if (typeof self.settings.timer_speed === 'number' && self.settings.timer_speed > 0) { |
| - | return '<div class="' + self.settings.timer_container_class |
| - | + '"><span></span><div class="' + self.settings.timer_progress_class |
| - | + '"></div></div>'; |
| + | var start_animation = function() { |
| + | if (dir === 'next') {animate.next(current, next, callback);} |
| + | if (dir === 'prev') {animate.prev(current, next, callback);} |
| + | }; |
| + | |
| + | if (next.height() > slides_container.height() && settings.variable_height) { |
| + | slides_container.animate({'height': next.height()}, 250, 'linear', start_animation); |
| } else { | |
| - | return ''; |
| + | start_animation(); |
| } | |
| - | }, |
| - | |
| - | _next_html: function() { |
| - | var self = this; |
| - | return '<a href="#" class="' + self.settings.next_class + '">Next <span></span></a>'; |
| - | }, |
| - | |
| - | _prev_html: function() { |
| - | var self = this; |
| - | return '<a href="#" class="' + self.settings.prev_class + '">Prev <span></span></a>'; |
| - | }, |
| - | |
| - | _init: function (idx, slider) { |
| - | var self = this, |
| - | $slides_container = $(slider), |
| - | $container = $slides_container.wrap(self._container_html()).parent(), |
| - | $slides = $slides_container.children(); |
| - | |
| - | $.extend(true, self.settings, self.data_options($slides_container)); |
| + | }; |
| + | |
| + | self.next = function(e) { |
| + | e.stopImmediatePropagation(); |
| + | e.preventDefault(); |
| + | self._goto(idx + 1); |
| + | }; |
| + | |
| + | self.prev = function(e) { |
| + | e.stopImmediatePropagation(); |
| + | e.preventDefault(); |
| + | self._goto(idx - 1); |
| + | }; |
| + | |
| + | self.link_custom = function(e) { |
| + | e.preventDefault(); |
| + | var link = $(this).attr('data-orbit-link'); |
| + | if ((typeof link === 'string') && (link = $.trim(link)) != "") { |
| + | var slide = container.find('[data-orbit-slide='+link+']'); |
| + | if (slide.index() != -1) {self._goto(slide.index());} |
| + | } |
| + | }; |
| - | if (self.settings.navigation_arrows) { |
| - | $container.append(self._prev_html()); |
| - | $container.append(self._next_html()); |
| + | self.link_bullet = function(e) { |
| + | var index = $(this).attr('data-orbit-slide'); |
| + | if ((typeof index === 'string') && (index = $.trim(index)) != "") { |
| + | self._goto(parseInt(index)); |
| } | |
| - | $slides_container.addClass(self.settings.slides_container_class); |
| - | if (self.settings.stack_on_small) { |
| - | $container.addClass(self.settings.stack_on_small_class); |
| + | } |
| + | |
| + | self.timer_callback = function() { |
| + | self._goto(idx + 1, true); |
| + | } |
| + | |
| + | self.compute_dimensions = function() { |
| + | var current = $(slides_container.children().get(idx)); |
| + | var h = current.height(); |
| + | if (!settings.variable_height) { |
| + | slides_container.children().each(function(){ |
| + | if ($(this).height() > h) { h = $(this).height(); } |
| + | }); |
| } | |
| - | if (self.settings.slide_number) { |
| - | $container.append(self._slide_number_html(1, $slides.length)); |
| + | slides_container.height(h); |
| + | }; |
| + | |
| + | self.create_timer = function() { |
| + | var t = new Timer( |
| + | container.find('.'+settings.timer_container_class), |
| + | settings, |
| + | self.timer_callback |
| + | ); |
| + | return t; |
| + | }; |
| + | |
| + | self.stop_timer = function() { |
| + | if (typeof timer === 'object') timer.stop(); |
| + | }; |
| + | |
| + | self.toggle_timer = function() { |
| + | var t = container.find('.'+settings.timer_container_class); |
| + | if (t.hasClass(settings.timer_paused_class)) { |
| + | if (typeof timer === 'undefined') {timer = self.create_timer();} |
| + | timer.start(); |
| } | |
| - | $container.append(self._timer_html()); |
| - | if (self.settings.bullets) { |
| - | $container.after(self._bullets_container_html($slides)); |
| + | else { |
| + | if (typeof timer === 'object') {timer.stop();} |
| } | |
| - | // To better support the "sliding" effect it's easier |
| - | // if we just clone the first and last slides |
| - | $slides_container.append($slides.first().clone().attr('data-orbit-slide','')); |
| - | $slides_container.prepend($slides.last().clone().attr('data-orbit-slide','')); |
| - | // Make the first "real" slide active |
| - | $slides_container.css(Foundation.rtl ? 'marginRight' : 'marginLeft', '-100%'); |
| - | $slides.first().addClass(self.settings.active_slide_class); |
| - | |
| - | self._init_events($slides_container); |
| - | self._init_dimensions($slides_container); |
| - | self._start_timer($slides_container); |
| - | }, |
| - | |
| - | _init_events: function ($slides_container) { |
| - | var self = this, |
| - | $container = $slides_container.parent(); |
| - | |
| - | $(window) |
| - | .on('load.fndtn.orbit', function() { |
| - | $slides_container.height(''); |
| - | $slides_container.height($slides_container.height($container.height())); |
| - | $slides_container.trigger('orbit:ready'); |
| - | }) |
| - | .on('resize.fndtn.orbit', function() { |
| - | $slides_container.height(''); |
| - | $slides_container.height($slides_container.height($container.height())); |
| - | }); |
| - | |
| - | $(document).on('click.fndtn.orbit', '[data-orbit-link]', function(e) { |
| - | e.preventDefault(); |
| - | var id = $(e.currentTarget).attr('data-orbit-link'), |
| - | $slide = $slides_container.find('[data-orbit-slide=' + id + ']').first(); |
| - | |
| - | if ($slide.length === 1) { |
| - | self._reset_timer($slides_container, true); |
| - | self._goto($slides_container, $slide.index(), function() {}); |
| - | } |
| - | }); |
| - | |
| - | $container.siblings('.' + self.settings.bullets_container_class) |
| - | .on('click.fndtn.orbit', '[data-orbit-slide-number]', function(e) { |
| - | e.preventDefault(); |
| - | self._reset_timer($slides_container, true); |
| - | self._goto($slides_container, $(e.currentTarget).data('orbit-slide-number'),function() {}); |
| - | }); |
| - | |
| - | $container |
| - | .on('mouseenter.fndtn.orbit', function(e) { |
| - | if (self.settings.pause_on_hover) { |
| - | self._stop_timer($slides_container); |
| - | } |
| - | }) |
| - | .on('mouseleave.fndtn.orbit', function(e) { |
| - | if (self.settings.resume_on_mouseout) { |
| - | self._start_timer($slides_container); |
| - | } |
| - | }) |
| - | .on('orbit:after-slide-change.fndtn.orbit', function(e, orbit) { |
| - | var $slide_number = $container.find('.' + self.settings.slide_number_class); |
| - | |
| - | if ($slide_number.length === 1) { |
| - | $slide_number.replaceWith(self._slide_number_html(orbit.slide_number, orbit.total_slides)); |
| - | } |
| - | }) |
| - | .on('orbit:next-slide.fndtn.orbit click.fndtn.orbit', '.' + self.settings.next_class, function(e) { |
| - | e.preventDefault(); |
| - | self._reset_timer($slides_container, true); |
| - | self._goto($slides_container, 'next', function() {}); |
| - | }) |
| - | .on('orbit:prev-slide.fndtn.orbit click.fndtn.orbit', '.' + self.settings.prev_class, function(e) { |
| - | e.preventDefault(); |
| - | self._reset_timer($slides_container, true); |
| - | self._goto($slides_container, 'prev', function() {}); |
| - | }) |
| - | .on('orbit:toggle-play-pause.fndtn.orbit click.fndtn.orbit touchstart.fndtn.orbit', '.' + self.settings.timer_container_class, function(e) { |
| - | e.preventDefault(); |
| - | var $timer = $(e.currentTarget).toggleClass(self.settings.timer_paused_class), |
| - | $slides_container = $timer.closest('.' + self.settings.container_class) |
| - | .find('.' + self.settings.slides_container_class); |
| - | |
| - | if ($timer.hasClass(self.settings.timer_paused_class)) { |
| - | self._stop_timer($slides_container); |
| - | } else { |
| - | self._start_timer($slides_container); |
| - | } |
| - | }) |
| - | .on('touchstart.fndtn.orbit', function(e) { |
| - | if (!e.touches) { e = e.originalEvent; } |
| + | }; |
| + | |
| + | self.init = function() { |
| + | self.build_markup(); |
| + | if (settings.timer) {timer = self.create_timer(); timer.start();} |
| + | animate = new FadeAnimation(settings, slides_container); |
| + | if (settings.animation === 'slide') |
| + | animate = new SlideAnimation(settings, slides_container); |
| + | container.on('click', '.'+settings.next_class, self.next); |
| + | container.on('click', '.'+settings.prev_class, self.prev); |
| + | container.on('click', '[data-orbit-slide]', self.link_bullet); |
| + | container.on('click', self.toggle_timer); |
| + | if (settings.swipe) { |
| + | container.on('touchstart.fndtn.orbit', function(e) { |
| + | if (!e.touches) {e = e.originalEvent;} |
| var data = { | |
| start_page_x: e.touches[0].pageX, | |
| start_page_y: e.touches[0].pageY, | |
| @@ | @@ -216,7 +221,7 @@ |
| delta_x: 0, | |
| is_scrolling: undefined | |
| }; | |
| - | $container.data('swipe-transition', data); |
| + | container.data('swipe-transition', data); |
| e.stopPropagation(); | |
| }) | |
| .on('touchmove.fndtn.orbit', function(e) { | |
| @@ | @@ -224,10 +229,8 @@ |
| // Ignore pinch/zoom events | |
| if(e.touches.length > 1 || e.scale && e.scale !== 1) return; | |
| - | var data = $container.data('swipe-transition'); |
| - | if (typeof data === 'undefined') { |
| - | data = {}; |
| - | } |
| + | var data = container.data('swipe-transition'); |
| + | if (typeof data === 'undefined') {data = {};} |
| data.delta_x = e.touches[0].pageX - data.start_page_x; | |
| @@ | @@ -237,154 +240,193 @@ |
| if (!data.is_scrolling && !data.active) { | |
| e.preventDefault(); | |
| - | self._stop_timer($slides_container); |
| - | var direction = (data.delta_x < 0) ? 'next' : 'prev'; |
| + | var direction = (data.delta_x < 0) ? (idx+1) : (idx-1); |
| data.active = true; | |
| - | self._goto($slides_container, direction, function() {}); |
| + | self._goto(direction); |
| } | |
| }) | |
| .on('touchend.fndtn.orbit', function(e) { | |
| - | $container.data('swipe-transition', {}); |
| + | container.data('swipe-transition', {}); |
| e.stopPropagation(); | |
| - | }); |
| - | }, |
| + | }) |
| + | } |
| + | container.on('mouseenter.fndtn.orbit', function(e) { |
| + | if (settings.timer && settings.pause_on_hover) { |
| + | self.stop_timer(); |
| + | } |
| + | }) |
| + | .on('mouseleave.fndtn.orbit', function(e) { |
| + | if (settings.timer && settings.resume_on_mouseout) { |
| + | timer.start(); |
| + | } |
| + | }); |
| + | |
| + | $(document).on('click', '[data-orbit-link]', self.link_custom); |
| + | $(window).on('resize', self.compute_dimensions); |
| + | $(window).on('load', self.compute_dimensions); |
| + | $(window).on('load', function(){ |
| + | container.prev('.preloader').css('display', 'none'); |
| + | }); |
| + | slides_container.trigger('orbit:ready'); |
| + | }; |
| - | _init_dimensions: function ($slides_container) { |
| - | var $container = $slides_container.parent(), |
| - | $slides = $slides_container.children(); |
| + | self.init(); |
| + | }; |
| - | $slides_container.css('width', $slides.length * 100 + '%'); |
| - | $slides.css('width', 100 / $slides.length + '%'); |
| - | $slides_container.height($container.height()); |
| - | $slides_container.css('width', $slides.length * 100 + '%'); |
| - | }, |
| + | var Timer = function(el, settings, callback) { |
| + | var self = this, |
| + | duration = settings.timer_speed, |
| + | progress = el.find('.'+settings.timer_progress_class), |
| + | start, |
| + | timeout, |
| + | left = -1; |
| + | |
| + | this.update_progress = function(w) { |
| + | var new_progress = progress.clone(); |
| + | new_progress.attr('style', ''); |
| + | new_progress.css('width', w+'%'); |
| + | progress.replaceWith(new_progress); |
| + | progress = new_progress; |
| + | }; |
| + | |
| + | this.restart = function() { |
| + | clearTimeout(timeout); |
| + | el.addClass(settings.timer_paused_class); |
| + | left = -1; |
| + | self.update_progress(0); |
| + | }; |
| + | |
| + | this.start = function() { |
| + | if (!el.hasClass(settings.timer_paused_class)) {return true;} |
| + | left = (left === -1) ? duration : left; |
| + | el.removeClass(settings.timer_paused_class); |
| + | start = new Date().getTime(); |
| + | progress.animate({'width': '100%'}, left, 'linear'); |
| + | timeout = setTimeout(function() { |
| + | self.restart(); |
| + | callback(); |
| + | }, left); |
| + | el.trigger('orbit:timer-started') |
| + | }; |
| + | |
| + | this.stop = function() { |
| + | if (el.hasClass(settings.timer_paused_class)) {return true;} |
| + | clearTimeout(timeout); |
| + | el.addClass(settings.timer_paused_class); |
| + | var end = new Date().getTime(); |
| + | left = left - (end - start); |
| + | var w = 100 - ((left / duration) * 100); |
| + | self.update_progress(w); |
| + | el.trigger('orbit:timer-stopped'); |
| + | }; |
| + | }; |
| + | |
| + | var SlideAnimation = function(settings, container) { |
| + | var duration = settings.animation_speed; |
| + | var is_rtl = ($('html[dir=rtl]').length === 1); |
| + | var margin = is_rtl ? 'marginRight' : 'marginLeft'; |
| + | var animMargin = {}; |
| + | animMargin[margin] = '0%'; |
| + | |
| + | this.next = function(current, next, callback) { |
| + | next.animate(animMargin, duration, 'linear', function() { |
| + | current.css(margin, '100%'); |
| + | callback(); |
| + | }); |
| + | }; |
| - | _start_timer: function ($slides_container) { |
| - | var self = this, |
| - | $container = $slides_container.parent(); |
| + | this.prev = function(current, prev, callback) { |
| + | prev.css(margin, '-100%'); |
| + | prev.animate(animMargin, duration, 'linear', function() { |
| + | current.css(margin, '100%'); |
| + | callback(); |
| + | }); |
| + | }; |
| + | }; |
| - | var callback = function() { |
| - | self._reset_timer($slides_container, false); |
| - | self._goto($slides_container, 'next', function() { |
| - | self._start_timer($slides_container); |
| - | }); |
| - | }; |
| + | var FadeAnimation = function(settings, container) { |
| + | var duration = settings.animation_speed; |
| + | var is_rtl = ($('html[dir=rtl]').length === 1); |
| + | var margin = is_rtl ? 'marginRight' : 'marginLeft'; |
| - | var $timer = $container.find('.' + self.settings.timer_container_class), |
| - | $progress = $timer.find('.' + self.settings.timer_progress_class), |
| - | progress_pct = ($progress.width() / $timer.width()), |
| - | delay = self.settings.timer_speed - (progress_pct * self.settings.timer_speed); |
| + | this.next = function(current, next, callback) { |
| + | next.css({'margin':'0%', 'opacity':'0.01'}); |
| + | next.animate({'opacity':'1'}, duration, 'linear', function() { |
| + | current.css('margin', '100%'); |
| + | callback(); |
| + | }); |
| + | }; |
| - | $progress.animate({'width': '100%'}, delay, 'linear', callback); |
| - | $slides_container.trigger('orbit:timer-started'); |
| - | }, |
| + | this.prev = function(current, prev, callback) { |
| + | prev.css({'margin':'0%', 'opacity':'0.01'}); |
| + | prev.animate({'opacity':'1'}, duration, 'linear', function() { |
| + | current.css('margin', '100%'); |
| + | callback(); |
| + | }); |
| + | }; |
| + | }; |
| - | _stop_timer: function ($slides_container) { |
| - | var self = this, |
| - | $container = $slides_container.parent(), |
| - | $timer = $container.find('.' + self.settings.timer_container_class), |
| - | $progress = $timer.find('.' + self.settings.timer_progress_class), |
| - | progress_pct = $progress.width() / $timer.width(); |
| - | self._rebuild_timer($container, progress_pct * 100 + '%'); |
| - | // $progress.stop(); |
| - | $slides_container.trigger('orbit:timer-stopped'); |
| - | $timer = $container.find('.' + self.settings.timer_container_class); |
| - | $timer.addClass(self.settings.timer_paused_class); |
| - | }, |
| - | _reset_timer: function($slides_container, is_paused) { |
| - | var self = this, |
| - | $container = $slides_container.parent(); |
| - | self._rebuild_timer($container, '0%'); |
| - | if (typeof is_paused === 'boolean' && is_paused) { |
| - | var $timer = $container.find('.' + self.settings.timer_container_class); |
| - | $timer.addClass(self.settings.timer_paused_class); |
| - | } |
| - | }, |
| + | Foundation.libs = Foundation.libs || {}; |
| - | _rebuild_timer: function ($container, width_pct) { |
| - | // Zepto is unable to stop animations since they |
| - | // are css-based. This is a workaround for that |
| - | // limitation, which rebuilds the dom element |
| - | // thus stopping the animation |
| - | var self = this, |
| - | $timer = $container.find('.' + self.settings.timer_container_class), |
| - | $new_timer = $(self._timer_html()), |
| - | $new_timer_progress = $new_timer.find('.' + self.settings.timer_progress_class); |
| - | |
| - | if (typeof Zepto === 'function') { |
| - | $timer.remove(); |
| - | $container.append($new_timer); |
| - | $new_timer_progress.css('width', width_pct); |
| - | } else if (typeof jQuery === 'function') { |
| - | var $progress = $timer.find('.' + self.settings.timer_progress_class); |
| - | $progress.css('width', width_pct); |
| - | $progress.stop(); |
| - | } |
| + | Foundation.libs.orbit = { |
| + | name: 'orbit', |
| + | |
| + | version: '4.3.2', |
| + | |
| + | settings: { |
| + | animation: 'slide', |
| + | timer_speed: 10000, |
| + | pause_on_hover: true, |
| + | resume_on_mouseout: false, |
| + | animation_speed: 500, |
| + | stack_on_small: false, |
| + | navigation_arrows: true, |
| + | slide_number: true, |
| + | slide_number_text: 'of', |
| + | container_class: 'orbit-container', |
| + | stack_on_small_class: 'orbit-stack-on-small', |
| + | next_class: 'orbit-next', |
| + | prev_class: 'orbit-prev', |
| + | timer_container_class: 'orbit-timer', |
| + | timer_paused_class: 'paused', |
| + | timer_progress_class: 'orbit-progress', |
| + | slides_container_class: 'orbit-slides-container', |
| + | bullets_container_class: 'orbit-bullets', |
| + | bullets_active_class: 'active', |
| + | slide_number_class: 'orbit-slide-number', |
| + | caption_class: 'orbit-caption', |
| + | active_slide_class: 'active', |
| + | orbit_transition_class: 'orbit-transitioning', |
| + | bullets: true, |
| + | timer: true, |
| + | variable_height: false, |
| + | swipe: true, |
| + | before_slide_change: noop, |
| + | after_slide_change: noop |
| }, | |
| - | _goto: function($slides_container, index_or_direction, callback) { |
| - | var self = this, |
| - | $container = $slides_container.parent(), |
| - | $slides = $slides_container.children(), |
| - | $active_slide = $slides_container.find('.' + self.settings.active_slide_class), |
| - | active_index = $active_slide.index(), |
| - | margin_position = Foundation.rtl ? 'marginRight' : 'marginLeft'; |
| + | init: function (scope, method, options) { |
| + | var self = this; |
| + | Foundation.inherit(self, 'data_options'); |
| - | if ($container.hasClass(self.settings.orbit_transition_class)) { |
| - | return false; |
| + | if (typeof method === 'object') { |
| + | $.extend(true, self.settings, method); |
| } | |
| - | if (index_or_direction === 'prev') { |
| - | if (active_index === 0) { |
| - | active_index = $slides.length - 1; |
| - | } |
| - | else { |
| - | active_index--; |
| - | } |
| - | } |
| - | else if (index_or_direction === 'next') { |
| - | active_index = (active_index+1) % $slides.length; |
| - | } |
| - | else if (typeof index_or_direction === 'number') { |
| - | active_index = (index_or_direction % $slides.length); |
| - | } |
| - | if (active_index === ($slides.length - 1) && index_or_direction === 'next') { |
| - | $slides_container.css(margin_position, '0%'); |
| - | active_index = 1; |
| - | } |
| - | else if (active_index === 0 && index_or_direction === 'prev') { |
| - | $slides_container.css(margin_position, '-' + ($slides.length - 1) * 100 + '%'); |
| - | active_index = $slides.length - 2; |
| - | } |
| - | // Start transition, make next slide active |
| - | $container.addClass(self.settings.orbit_transition_class); |
| - | $active_slide.removeClass(self.settings.active_slide_class); |
| - | $($slides[active_index]).addClass(self.settings.active_slide_class); |
| - | // Make next bullet active |
| - | var $bullets = $container.siblings('.' + self.settings.bullets_container_class); |
| - | if ($bullets.length === 1) { |
| - | $bullets.children().removeClass(self.settings.bullets_active_class); |
| - | $($bullets.children()[active_index-1]).addClass(self.settings.bullets_active_class); |
| + | if ($(scope).is('[data-orbit]')) { |
| + | var $el = $(scope); |
| + | var opts = self.data_options($el); |
| + | new Orbit($el, $.extend({},self.settings, opts)); |
| } | |
| - | var new_margin_left = '-' + (active_index * 100) + '%'; |
| - | // Check to see if animation will occur, otherwise perform |
| - | // callbacks manually |
| - | $slides_container.trigger('orbit:before-slide-change'); |
| - | if ($slides_container.css(margin_position) === new_margin_left) { |
| - | $container.removeClass(self.settings.orbit_transition_class); |
| - | $slides_container.trigger('orbit:after-slide-change', [{slide_number: active_index, total_slides: $slides_container.children().length - 2}]); |
| - | callback(); |
| - | } else { |
| - | var properties = {}; |
| - | properties[margin_position] = new_margin_left; |
| - | $slides_container.animate(properties, self.settings.animation_speed, 'linear', function() { |
| - | $container.removeClass(self.settings.orbit_transition_class); |
| - | $slides_container.trigger('orbit:after-slide-change', [{slide_number: active_index, total_slides: $slides_container.children().length - 2}]); |
| - | callback(); |
| - | }); |
| - | } |
| + | $('[data-orbit]', scope).each(function(idx, el) { |
| + | var $el = $(el); |
| + | var opts = self.data_options($el); |
| + | new Orbit($el, $.extend({},self.settings, opts)); |
| + | }); |
| } | |
| }; | |
| + | |
| + | |
| }(Foundation.zj, this, this.document)); | |
generators/foundation/public/javascripts/foundation/foundation.placeholder.js
+426
-159
| @@ | @@ -1,159 +1,426 @@ |
| - | /*! http://mths.be/placeholder v2.0.7 by @mathias |
| - | Modified to work with Zepto.js by ZURB |
| - | */ |
| - | ;(function(window, document, $) { |
| - | |
| - | var isInputSupported = 'placeholder' in document.createElement('input'), |
| - | isTextareaSupported = 'placeholder' in document.createElement('textarea'), |
| - | prototype = $.fn, |
| - | valHooks = $.valHooks, |
| - | hooks, |
| - | placeholder; |
| - | |
| - | if (isInputSupported && isTextareaSupported) { |
| - | |
| - | placeholder = prototype.placeholder = function() { |
| - | return this; |
| - | }; |
| - | |
| - | placeholder.input = placeholder.textarea = true; |
| - | |
| - | } else { |
| - | |
| - | placeholder = prototype.placeholder = function() { |
| - | var $this = this; |
| - | $this |
| - | .filter((isInputSupported ? 'textarea' : ':input') + '[placeholder]') |
| - | .not('.placeholder') |
| - | .bind({ |
| - | 'focus.placeholder': clearPlaceholder, |
| - | 'blur.placeholder': setPlaceholder |
| - | }) |
| - | .data('placeholder-enabled', true) |
| - | .trigger('blur.placeholder'); |
| - | return $this; |
| - | }; |
| - | |
| - | placeholder.input = isInputSupported; |
| - | placeholder.textarea = isTextareaSupported; |
| - | |
| - | hooks = { |
| - | 'get': function(element) { |
| - | var $element = $(element); |
| - | return $element.data('placeholder-enabled') && $element.hasClass('placeholder') ? '' : element.value; |
| - | }, |
| - | 'set': function(element, value) { |
| - | var $element = $(element); |
| - | if (!$element.data('placeholder-enabled')) { |
| - | return element.value = value; |
| - | } |
| - | if (value == '') { |
| - | element.value = value; |
| - | // Issue #56: Setting the placeholder causes problems if the element continues to have focus. |
| - | if (element != document.activeElement) { |
| - | // We can't use `triggerHandler` here because of dummy text/password inputs :( |
| - | setPlaceholder.call(element); |
| - | } |
| - | } else if ($element.hasClass('placeholder')) { |
| - | clearPlaceholder.call(element, true, value) || (element.value = value); |
| - | } else { |
| - | element.value = value; |
| - | } |
| - | // `set` can not return `undefined`; see http://jsapi.info/jquery/1.7.1/val#L2363 |
| - | return $element; |
| - | } |
| - | }; |
| - | |
| - | isInputSupported || (valHooks.input = hooks); |
| - | isTextareaSupported || (valHooks.textarea = hooks); |
| - | |
| - | $(function() { |
| - | // Look for forms |
| - | $(document).delegate('form', 'submit.placeholder', function() { |
| - | // Clear the placeholder values so they don't get submitted |
| - | var $inputs = $('.placeholder', this).each(clearPlaceholder); |
| - | setTimeout(function() { |
| - | $inputs.each(setPlaceholder); |
| - | }, 10); |
| - | }); |
| - | }); |
| - | |
| - | // Clear placeholder values upon page reload |
| - | $(window).bind('beforeunload.placeholder', function() { |
| - | $('.placeholder').each(function() { |
| - | this.value = ''; |
| - | }); |
| - | }); |
| - | |
| - | } |
| - | |
| - | function args(elem) { |
| - | // Return an object of element attributes |
| - | var newAttrs = {}, |
| - | rinlinejQuery = /^jQuery\d+$/; |
| - | $.each(elem.attributes, function(i, attr) { |
| - | if (attr.specified && !rinlinejQuery.test(attr.name)) { |
| - | newAttrs[attr.name] = attr.value; |
| - | } |
| - | }); |
| - | return newAttrs; |
| - | } |
| - | |
| - | function clearPlaceholder(event, value) { |
| - | var input = this, |
| - | $input = $(input); |
| - | if (input.value == $input.attr('placeholder') && $input.hasClass('placeholder')) { |
| - | if ($input.data('placeholder-password')) { |
| - | $input = $input.hide().next().show().attr('id', $input.removeAttr('id').data('placeholder-id')); |
| - | // If `clearPlaceholder` was called from `$.valHooks.input.set` |
| - | if (event === true) { |
| - | return $input[0].value = value; |
| - | } |
| - | $input.focus(); |
| - | } else { |
| - | input.value = ''; |
| - | $input.removeClass('placeholder'); |
| - | input == document.activeElement && input.select(); |
| - | } |
| - | } |
| - | } |
| - | |
| - | function setPlaceholder() { |
| - | var $replacement, |
| - | input = this, |
| - | $input = $(input), |
| - | $origInput = $input, |
| - | id = this.id; |
| - | if (input.value == '') { |
| - | if (input.type == 'password') { |
| - | if (!$input.data('placeholder-textinput')) { |
| - | try { |
| - | $replacement = $input.clone().attr({ 'type': 'text' }); |
| - | } catch(e) { |
| - | $replacement = $('<input>').attr($.extend(args(this), { 'type': 'text' })); |
| - | } |
| - | $replacement |
| - | .removeAttr('name') |
| - | .data({ |
| - | 'placeholder-password': true, |
| - | 'placeholder-id': id |
| - | }) |
| - | .bind('focus.placeholder', clearPlaceholder); |
| - | $input |
| - | .data({ |
| - | 'placeholder-textinput': $replacement, |
| - | 'placeholder-id': id |
| - | }) |
| - | .before($replacement); |
| - | } |
| - | $input = $input.removeAttr('id').hide().prev().attr('id', id).show(); |
| - | // Note: `$input[0] != input` now! |
| - | } |
| - | $input.addClass('placeholder'); |
| - | $input[0].value = $input.attr('placeholder'); |
| - | } else { |
| - | $input.removeClass('placeholder'); |
| - | } |
| - | } |
| - | |
| - | }(this, document, Foundation.zj)); |
| \ No newline at end of file | |
| + | /* |
| + | * The MIT License |
| + | * |
| + | * Copyright (c) 2012 James Allardice |
| + | * |
| + | * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), |
| + | * to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, |
| + | * and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: |
| + | * |
| + | * The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. |
| + | * |
| + | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| + | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| + | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
| + | * THE SOFTWARE. |
| + | */ |
| + | |
| + | // Defines the global Placeholders object along with various utility methods |
| + | (function (global) { |
| + | |
| + | "use strict"; |
| + | |
| + | // Cross-browser DOM event binding |
| + | function addEventListener(elem, event, fn) { |
| + | if (elem.addEventListener) { |
| + | return elem.addEventListener(event, fn, false); |
| + | } |
| + | if (elem.attachEvent) { |
| + | return elem.attachEvent("on" + event, fn); |
| + | } |
| + | } |
| + | |
| + | // Check whether an item is in an array (we don't use Array.prototype.indexOf so we don't clobber any existing polyfills - this is a really simple alternative) |
| + | function inArray(arr, item) { |
| + | var i, len; |
| + | for (i = 0, len = arr.length; i < len; i++) { |
| + | if (arr[i] === item) { |
| + | return true; |
| + | } |
| + | } |
| + | return false; |
| + | } |
| + | |
| + | // Move the caret to the index position specified. Assumes that the element has focus |
| + | function moveCaret(elem, index) { |
| + | var range; |
| + | if (elem.createTextRange) { |
| + | range = elem.createTextRange(); |
| + | range.move("character", index); |
| + | range.select(); |
| + | } else if (elem.selectionStart) { |
| + | elem.focus(); |
| + | elem.setSelectionRange(index, index); |
| + | } |
| + | } |
| + | |
| + | // Attempt to change the type property of an input element |
| + | function changeType(elem, type) { |
| + | try { |
| + | elem.type = type; |
| + | return true; |
| + | } catch (e) { |
| + | // You can't change input type in IE8 and below |
| + | return false; |
| + | } |
| + | } |
| + | |
| + | // Expose public methods |
| + | global.Placeholders = { |
| + | Utils: { |
| + | addEventListener: addEventListener, |
| + | inArray: inArray, |
| + | moveCaret: moveCaret, |
| + | changeType: changeType |
| + | } |
| + | }; |
| + | |
| + | }(this)); |
| + | |
| + | (function (global) { |
| + | |
| + | "use strict"; |
| + | |
| + | var validTypes = [ |
| + | "text", |
| + | "search", |
| + | "url", |
| + | "tel", |
| + | "email", |
| + | "password", |
| + | "number", |
| + | "textarea" |
| + | ], |
| + | |
| + | // The list of keycodes that are not allowed when the polyfill is configured to hide-on-input |
| + | badKeys = [ |
| + | |
| + | // The following keys all cause the caret to jump to the end of the input value |
| + | 27, // Escape |
| + | 33, // Page up |
| + | 34, // Page down |
| + | 35, // End |
| + | 36, // Home |
| + | |
| + | // Arrow keys allow you to move the caret manually, which should be prevented when the placeholder is visible |
| + | 37, // Left |
| + | 38, // Up |
| + | 39, // Right |
| + | 40, // Down |
| + | |
| + | // The following keys allow you to modify the placeholder text by removing characters, which should be prevented when the placeholder is visible |
| + | 8, // Backspace |
| + | 46 // Delete |
| + | ], |
| + | |
| + | // Styling variables |
| + | placeholderStyleColor = "#ccc", |
| + | placeholderClassName = "placeholdersjs", |
| + | classNameRegExp = new RegExp("(?:^|\\s)" + placeholderClassName + "(?!\\S)"), |
| + | |
| + | // These will hold references to all elements that can be affected. NodeList objects are live, so we only need to get those references once |
| + | inputs, textareas, |
| + | |
| + | // The various data-* attributes used by the polyfill |
| + | ATTR_CURRENT_VAL = "data-placeholder-value", |
| + | ATTR_ACTIVE = "data-placeholder-active", |
| + | ATTR_INPUT_TYPE = "data-placeholder-type", |
| + | ATTR_FORM_HANDLED = "data-placeholder-submit", |
| + | ATTR_EVENTS_BOUND = "data-placeholder-bound", |
| + | ATTR_OPTION_FOCUS = "data-placeholder-focus", |
| + | ATTR_OPTION_LIVE = "data-placeholder-live", |
| + | |
| + | // Various other variables used throughout the rest of the script |
| + | test = document.createElement("input"), |
| + | head = document.getElementsByTagName("head")[0], |
| + | root = document.documentElement, |
| + | Placeholders = global.Placeholders, |
| + | Utils = Placeholders.Utils, |
| + | hideOnInput, liveUpdates, keydownVal, styleElem, styleRules, placeholder, timer, form, elem, len, i; |
| + | |
| + | // No-op (used in place of public methods when native support is detected) |
| + | function noop() {} |
| + | |
| + | // Hide the placeholder value on a single element. Returns true if the placeholder was hidden and false if it was not (because it wasn't visible in the first place) |
| + | function hidePlaceholder(elem) { |
| + | var type; |
| + | if (elem.value === elem.getAttribute(ATTR_CURRENT_VAL) && elem.getAttribute(ATTR_ACTIVE) === "true") { |
| + | elem.setAttribute(ATTR_ACTIVE, "false"); |
| + | elem.value = ""; |
| + | elem.className = elem.className.replace(classNameRegExp, ""); |
| + | |
| + | // If the polyfill has changed the type of the element we need to change it back |
| + | type = elem.getAttribute(ATTR_INPUT_TYPE); |
| + | if (type) { |
| + | elem.type = type; |
| + | } |
| + | return true; |
| + | } |
| + | return false; |
| + | } |
| + | |
| + | // Show the placeholder value on a single element. Returns true if the placeholder was shown and false if it was not (because it was already visible) |
| + | function showPlaceholder(elem) { |
| + | var type, |
| + | val = elem.getAttribute(ATTR_CURRENT_VAL); |
| + | if (elem.value === "" && val) { |
| + | elem.setAttribute(ATTR_ACTIVE, "true"); |
| + | elem.value = val; |
| + | elem.className += " " + placeholderClassName; |
| + | |
| + | // If the type of element needs to change, change it (e.g. password inputs) |
| + | type = elem.getAttribute(ATTR_INPUT_TYPE); |
| + | if (type) { |
| + | elem.type = "text"; |
| + | } else if (elem.type === "password") { |
| + | if (Utils.changeType(elem, "text")) { |
| + | elem.setAttribute(ATTR_INPUT_TYPE, "password"); |
| + | } |
| + | } |
| + | return true; |
| + | } |
| + | return false; |
| + | } |
| + | |
| + | function handleElem(node, callback) { |
| + | |
| + | var handleInputs, handleTextareas, elem, len, i; |
| + | |
| + | // Check if the passed in node is an input/textarea (in which case it can't have any affected descendants) |
| + | if (node && node.getAttribute(ATTR_CURRENT_VAL)) { |
| + | callback(node); |
| + | } else { |
| + | |
| + | // If an element was passed in, get all affected descendants. Otherwise, get all affected elements in document |
| + | handleInputs = node ? node.getElementsByTagName("input") : inputs; |
| + | handleTextareas = node ? node.getElementsByTagName("textarea") : textareas; |
| + | |
| + | // Run the callback for each element |
| + | for (i = 0, len = handleInputs.length + handleTextareas.length; i < len; i++) { |
| + | elem = i < handleInputs.length ? handleInputs[i] : handleTextareas[i - handleInputs.length]; |
| + | callback(elem); |
| + | } |
| + | } |
| + | } |
| + | |
| + | // Return all affected elements to their normal state (remove placeholder value if present) |
| + | function disablePlaceholders(node) { |
| + | handleElem(node, hidePlaceholder); |
| + | } |
| + | |
| + | // Show the placeholder value on all appropriate elements |
| + | function enablePlaceholders(node) { |
| + | handleElem(node, showPlaceholder); |
| + | } |
| + | |
| + | // Returns a function that is used as a focus event handler |
| + | function makeFocusHandler(elem) { |
| + | return function () { |
| + | |
| + | // Only hide the placeholder value if the (default) hide-on-focus behaviour is enabled |
| + | if (hideOnInput && elem.value === elem.getAttribute(ATTR_CURRENT_VAL) && elem.getAttribute(ATTR_ACTIVE) === "true") { |
| + | |
| + | // Move the caret to the start of the input (this mimics the behaviour of all browsers that do not hide the placeholder on focus) |
| + | Utils.moveCaret(elem, 0); |
| + | |
| + | } else { |
| + | |
| + | // Remove the placeholder |
| + | hidePlaceholder(elem); |
| + | } |
| + | }; |
| + | } |
| + | |
| + | // Returns a function that is used as a blur event handler |
| + | function makeBlurHandler(elem) { |
| + | return function () { |
| + | showPlaceholder(elem); |
| + | }; |
| + | } |
| + | |
| + | // Functions that are used as a event handlers when the hide-on-input behaviour has been activated - very basic implementation of the "input" event |
| + | function makeKeydownHandler(elem) { |
| + | return function (e) { |
| + | keydownVal = elem.value; |
| + | |
| + | //Prevent the use of the arrow keys (try to keep the cursor before the placeholder) |
| + | if (elem.getAttribute(ATTR_ACTIVE) === "true") { |
| + | if (keydownVal === elem.getAttribute(ATTR_CURRENT_VAL) && Utils.inArray(badKeys, e.keyCode)) { |
| + | if (e.preventDefault) { |
| + | e.preventDefault(); |
| + | } |
| + | return false; |
| + | } |
| + | } |
| + | }; |
| + | } |
| + | function makeKeyupHandler(elem) { |
| + | return function () { |
| + | var type; |
| + | |
| + | if (elem.getAttribute(ATTR_ACTIVE) === "true" && elem.value !== keydownVal) { |
| + | |
| + | // Remove the placeholder |
| + | elem.className = elem.className.replace(classNameRegExp, ""); |
| + | elem.value = elem.value.replace(elem.getAttribute(ATTR_CURRENT_VAL), ""); |
| + | elem.setAttribute(ATTR_ACTIVE, false); |
| + | |
| + | // If the type of element needs to change, change it (e.g. password inputs) |
| + | type = elem.getAttribute(ATTR_INPUT_TYPE); |
| + | if (type) { |
| + | elem.type = type; |
| + | } |
| + | } |
| + | |
| + | // If the element is now empty we need to show the placeholder |
| + | if (elem.value === "") { |
| + | elem.blur(); |
| + | Utils.moveCaret(elem, 0); |
| + | } |
| + | }; |
| + | } |
| + | function makeClickHandler(elem) { |
| + | return function () { |
| + | if (elem === document.activeElement && elem.value === elem.getAttribute(ATTR_CURRENT_VAL) && elem.getAttribute(ATTR_ACTIVE) === "true") { |
| + | Utils.moveCaret(elem, 0); |
| + | } |
| + | }; |
| + | } |
| + | |
| + | // Returns a function that is used as a submit event handler on form elements that have children affected by this polyfill |
| + | function makeSubmitHandler(form) { |
| + | return function () { |
| + | |
| + | // Turn off placeholders on all appropriate descendant elements |
| + | disablePlaceholders(form); |
| + | }; |
| + | } |
| + | |
| + | // Bind event handlers to an element that we need to affect with the polyfill |
| + | function newElement(elem) { |
| + | |
| + | // If the element is part of a form, make sure the placeholder string is not submitted as a value |
| + | if (elem.form) { |
| + | form = elem.form; |
| + | |
| + | // Set a flag on the form so we know it's been handled (forms can contain multiple inputs) |
| + | if (!form.getAttribute(ATTR_FORM_HANDLED)) { |
| + | Utils.addEventListener(form, "submit", makeSubmitHandler(form)); |
| + | form.setAttribute(ATTR_FORM_HANDLED, "true"); |
| + | } |
| + | } |
| + | |
| + | // Bind event handlers to the element so we can hide/show the placeholder as appropriate |
| + | Utils.addEventListener(elem, "focus", makeFocusHandler(elem)); |
| + | Utils.addEventListener(elem, "blur", makeBlurHandler(elem)); |
| + | |
| + | // If the placeholder should hide on input rather than on focus we need additional event handlers |
| + | if (hideOnInput) { |
| + | Utils.addEventListener(elem, "keydown", makeKeydownHandler(elem)); |
| + | Utils.addEventListener(elem, "keyup", makeKeyupHandler(elem)); |
| + | Utils.addEventListener(elem, "click", makeClickHandler(elem)); |
| + | } |
| + | |
| + | // Remember that we've bound event handlers to this element |
| + | elem.setAttribute(ATTR_EVENTS_BOUND, "true"); |
| + | elem.setAttribute(ATTR_CURRENT_VAL, placeholder); |
| + | |
| + | // If the element doesn't have a value, set it to the placeholder string |
| + | showPlaceholder(elem); |
| + | } |
| + | |
| + | Placeholders.nativeSupport = test.placeholder !== void 0; |
| + | |
| + | if (!Placeholders.nativeSupport) { |
| + | |
| + | // Get references to all the input and textarea elements currently in the DOM (live NodeList objects to we only need to do this once) |
| + | inputs = document.getElementsByTagName("input"); |
| + | textareas = document.getElementsByTagName("textarea"); |
| + | |
| + | // Get any settings declared as data-* attributes on the root element (currently the only options are whether to hide the placeholder on focus or input and whether to auto-update) |
| + | hideOnInput = root.getAttribute(ATTR_OPTION_FOCUS) === "false"; |
| + | liveUpdates = root.getAttribute(ATTR_OPTION_LIVE) !== "false"; |
| + | |
| + | // Create style element for placeholder styles (instead of directly setting style properties on elements - allows for better flexibility alongside user-defined styles) |
| + | styleElem = document.createElement("style"); |
| + | styleElem.type = "text/css"; |
| + | |
| + | // Create style rules as text node |
| + | styleRules = document.createTextNode("." + placeholderClassName + " { color:" + placeholderStyleColor + "; }"); |
| + | |
| + | // Append style rules to newly created stylesheet |
| + | if (styleElem.styleSheet) { |
| + | styleElem.styleSheet.cssText = styleRules.nodeValue; |
| + | } else { |
| + | styleElem.appendChild(styleRules); |
| + | } |
| + | |
| + | // Prepend new style element to the head (before any existing stylesheets, so user-defined rules take precedence) |
| + | head.insertBefore(styleElem, head.firstChild); |
| + | |
| + | // Set up the placeholders |
| + | for (i = 0, len = inputs.length + textareas.length; i < len; i++) { |
| + | elem = i < inputs.length ? inputs[i] : textareas[i - inputs.length]; |
| + | |
| + | // Get the value of the placeholder attribute, if any. IE10 emulating IE7 fails with getAttribute, hence the use of the attributes node |
| + | placeholder = elem.attributes.placeholder; |
| + | if (placeholder) { |
| + | |
| + | // IE returns an empty object instead of undefined if the attribute is not present |
| + | placeholder = placeholder.nodeValue; |
| + | |
| + | // Only apply the polyfill if this element is of a type that supports placeholders, and has a placeholder attribute with a non-empty value |
| + | if (placeholder && Utils.inArray(validTypes, elem.type)) { |
| + | newElement(elem); |
| + | } |
| + | } |
| + | } |
| + | |
| + | // If enabled, the polyfill will repeatedly check for changed/added elements and apply to those as well |
| + | timer = setInterval(function () { |
| + | for (i = 0, len = inputs.length + textareas.length; i < len; i++) { |
| + | elem = i < inputs.length ? inputs[i] : textareas[i - inputs.length]; |
| + | |
| + | // Only apply the polyfill if this element is of a type that supports placeholders, and has a placeholder attribute with a non-empty value |
| + | placeholder = elem.attributes.placeholder; |
| + | if (placeholder) { |
| + | placeholder = placeholder.nodeValue; |
| + | if (placeholder && Utils.inArray(validTypes, elem.type)) { |
| + | |
| + | // If the element hasn't had event handlers bound to it then add them |
| + | if (!elem.getAttribute(ATTR_EVENTS_BOUND)) { |
| + | newElement(elem); |
| + | } |
| + | |
| + | // If the placeholder value has changed or not been initialised yet we need to update the display |
| + | if (placeholder !== elem.getAttribute(ATTR_CURRENT_VAL) || (elem.type === "password" && !elem.getAttribute(ATTR_INPUT_TYPE))) { |
| + | |
| + | // Attempt to change the type of password inputs (fails in IE < 9) |
| + | if (elem.type === "password" && !elem.getAttribute(ATTR_INPUT_TYPE) && Utils.changeType(elem, "text")) { |
| + | elem.setAttribute(ATTR_INPUT_TYPE, "password"); |
| + | } |
| + | |
| + | // If the placeholder value has changed and the placeholder is currently on display we need to change it |
| + | if (elem.value === elem.getAttribute(ATTR_CURRENT_VAL)) { |
| + | elem.value = placeholder; |
| + | } |
| + | |
| + | // Keep a reference to the current placeholder value in case it changes via another script |
| + | elem.setAttribute(ATTR_CURRENT_VAL, placeholder); |
| + | } |
| + | } |
| + | } |
| + | } |
| + | |
| + | // If live updates are not enabled cancel the timer |
| + | if (!liveUpdates) { |
| + | clearInterval(timer); |
| + | } |
| + | }, 100); |
| + | } |
| + | |
| + | // Expose public methods |
| + | Placeholders.disable = Placeholders.nativeSupport ? noop : disablePlaceholders; |
| + | Placeholders.enable = Placeholders.nativeSupport ? noop : enablePlaceholders; |
| + | |
| + | }(this)); |
generators/foundation/public/javascripts/foundation/foundation.reveal.js
+42
-19
| @@ | @@ -4,9 +4,9 @@ |
| 'use strict'; | |
| Foundation.libs.reveal = { | |
| - | name: 'reveal', |
| + | name : 'reveal', |
| - | version : '4.2.0', |
| + | version : '4.3.2', |
| locked : false, | |
| @@ | @@ -45,7 +45,7 @@ |
| $.extend(true, this.settings, options); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| this.events(); | |
| return this.settings.init; | |
| @@ | @@ -77,24 +77,37 @@ |
| } | |
| } | |
| }) | |
| - | .on('click.fndtn.reveal touchend.click.fndtn.reveal', this.close_targets(), function (e) { |
| + | .on('click.fndtn.reveal touchend', this.close_targets(), function (e) { |
| e.preventDefault(); | |
| if (!self.locked) { | |
| - | var settings = $.extend({}, self.settings, self.data_options($('.reveal-modal.open'))); |
| - | if ($(e.target)[0] === $('.' + settings.bgClass)[0] && !settings.closeOnBackgroundClick) { |
| + | var settings = $.extend({}, self.settings, self.data_options($('.reveal-modal.open'))), |
| + | bgClicked = $(e.target)[0] === $('.' + settings.bgClass)[0]; |
| + | if (bgClicked && !settings.closeOnBackgroundClick) { |
| return; | |
| } | |
| self.locked = true; | |
| - | self.close.call(self, $(this).closest('.reveal-modal')); |
| + | self.close.call(self, bgClicked ? $('.reveal-modal.open') : $(this).closest('.reveal-modal')); |
| } | |
| - | }) |
| - | .on('open.fndtn.reveal', '.reveal-modal', this.settings.open) |
| - | .on('opened.fndtn.reveal', '.reveal-modal', this.settings.opened) |
| - | .on('opened.fndtn.reveal', '.reveal-modal', this.open_video) |
| - | .on('close.fndtn.reveal', '.reveal-modal', this.settings.close) |
| - | .on('closed.fndtn.reveal', '.reveal-modal', this.settings.closed) |
| - | .on('closed.fndtn.reveal', '.reveal-modal', this.close_video); |
| + | }); |
| + | |
| + | if($(this.scope).hasClass('reveal-modal')) { |
| + | $(this.scope) |
| + | .on('open.fndtn.reveal', this.settings.open) |
| + | .on('opened.fndtn.reveal', this.settings.opened) |
| + | .on('opened.fndtn.reveal', this.open_video) |
| + | .on('close.fndtn.reveal', this.settings.close) |
| + | .on('closed.fndtn.reveal', this.settings.closed) |
| + | .on('closed.fndtn.reveal', this.close_video); |
| + | } else { |
| + | $(this.scope) |
| + | .on('open.fndtn.reveal', '.reveal-modal', this.settings.open) |
| + | .on('opened.fndtn.reveal', '.reveal-modal', this.settings.opened) |
| + | .on('opened.fndtn.reveal', '.reveal-modal', this.open_video) |
| + | .on('close.fndtn.reveal', '.reveal-modal', this.settings.close) |
| + | .on('closed.fndtn.reveal', '.reveal-modal', this.settings.closed) |
| + | .on('closed.fndtn.reveal', '.reveal-modal', this.close_video); |
| + | } |
| $( 'body' ).bind( 'keyup.reveal', function ( event ) { | |
| var open_modal = $('.reveal-modal.open'), | |
| @@ | @@ -131,7 +144,7 @@ |
| modal.trigger('open'); | |
| if (open_modal.length < 1) { | |
| - | this.toggle_bg(modal); |
| + | this.toggle_bg(); |
| } | |
| if (typeof ajax_settings === 'undefined' || !ajax_settings.url) { | |
| @@ | @@ -168,7 +181,7 @@ |
| if (open_modals.length > 0) { | |
| this.locked = true; | |
| modal.trigger('close'); | |
| - | this.toggle_bg(modal); |
| + | this.toggle_bg(); |
| this.hide(open_modals, this.settings.css.close); | |
| } | |
| }, | |
| @@ | @@ -183,8 +196,8 @@ |
| return base; | |
| }, | |
| - | toggle_bg : function (modal) { |
| - | if ($('.reveal-modal-bg').length === 0) { |
| + | toggle_bg : function () { |
| + | if ($('.' + this.settings.bgClass).length === 0) { |
| this.settings.bg = $('<div />', {'class': this.settings.bgClass}) | |
| .appendTo('body'); | |
| } | |
| @@ | @@ -199,6 +212,16 @@ |
| show : function (el, css) { | |
| // is modal | |
| if (css) { | |
| + | if (el.parent('body').length === 0) { |
| + | var placeholder = el.wrap('<div style="display: none;" />').parent(); |
| + | el.on('closed.fndtn.reveal.wrapped', function() { |
| + | el.detach().appendTo(placeholder); |
| + | el.unwrap().unbind('closed.fndtn.reveal.wrapped'); |
| + | }); |
| + | |
| + | el.detach().appendTo('body'); |
| + | } |
| + | |
| if (/pop/i.test(this.settings.animation)) { | |
| css.top = $(window).scrollTop() - el.data('offset') + 'px'; | |
| var end_css = { | |
| @@ | @@ -327,4 +350,4 @@ |
| reflow : function () {} | |
| }; | |
| - | }(Foundation.zj, this, this.document)); |
| \ No newline at end of file | |
| + | }(Foundation.zj, this, this.document)); |
generators/foundation/public/javascripts/foundation/foundation.section.js
+322
-308
| @@ | @@ -1,26 +1,33 @@ |
| /*jslint unparam: true, browser: true, indent: 2 */ | |
| - | ;(function ($, window, document, undefined) { |
| + | ; |
| + | (function($, window, document) { |
| 'use strict'; | |
| Foundation.libs.section = { | |
| - | name: 'section', |
| + | name : 'section', |
| - | version : '4.2.0', |
| + | version : '4.3.2', |
| - | settings : { |
| + | settings: { |
| deep_linking: false, | |
| + | small_breakpoint: 768, |
| one_up: true, | |
| - | section_selector : '[data-section]', |
| - | region_selector : 'section, .section, [data-section-region]', |
| - | title_selector : '.title, [data-section-title]', |
| - | active_region_selector : 'section.active, .section.active, .active[data-section-region]', |
| - | content_selector : '.content, [data-section-content]', |
| - | nav_selector : '[data-section="vertical-nav"], [data-section="horizontal-nav"]', |
| - | callback: function (){} |
| + | multi_expand: false, |
| + | section_selector: '[data-section]', |
| + | region_selector: 'section, .section, [data-section-region]', |
| + | title_selector: '.title, [data-section-title]', |
| + | //marker: container is resized |
| + | resized_data_attr: 'data-section-resized', |
| + | //marker: container should apply accordion style |
| + | small_style_data_attr: 'data-section-small-style', |
| + | content_selector: '.content, [data-section-content]', |
| + | nav_selector: '[data-section="vertical-nav"], [data-section="horizontal-nav"]', |
| + | active_class: 'active', |
| + | callback: function() {} |
| }, | |
| - | init : function (scope, method, options) { |
| + | init: function(scope, method, options) { |
| var self = this; | |
| Foundation.inherit(this, 'throttle data_options position_right offset_right'); | |
| @@ | @@ -28,368 +35,364 @@ |
| $.extend(true, self.settings, method); | |
| } | |
| - | if (typeof method != 'string') { |
| - | this.set_active_from_hash(); |
| + | if (typeof method !== 'string') { |
| this.events(); | |
| - | |
| return true; | |
| } else { | |
| return this[method].call(this, options); | |
| } | |
| }, | |
| - | events : function () { |
| + | events: function() { |
| var self = this; | |
| - | $(this.scope) |
| - | .on('click.fndtn.section', '[data-section] .title, [data-section] [data-section-title]', function (e) { |
| - | var $this = $(this), |
| - | section = $this.closest(self.settings.region_selector); |
| + | //combine titles selector from settings for click event binding |
| + | var click_title_selectors = [], |
| + | section_selector = self.settings.section_selector, |
| + | region_selectors = self.settings.region_selector.split(","), |
| + | title_selectors = self.settings.title_selector.split(","); |
| + | |
| + | for (var i = 0, len = region_selectors.length; i < len; i++) { |
| + | var region_selector = region_selectors[i]; |
| + | |
| + | for (var j = 0, len1 = title_selectors.length; j < len1; j++) { |
| + | var title_selector = section_selector + ">" + region_selector + ">" + title_selectors[j]; |
| + | |
| + | click_title_selectors.push(title_selector + " a"); //or we can not do preventDefault for click event of <a> |
| + | click_title_selectors.push(title_selector); |
| + | } |
| + | } |
| + | |
| + | $(self.scope) |
| + | .on('click.fndtn.section', click_title_selectors.join(","), function(e) { |
| + | var title = $(this).closest(self.settings.title_selector); |
| - | if (section.children(self.settings.content_selector).length > 0) { |
| - | self.toggle_active.call(this, e, self); |
| - | self.reflow(); |
| + | self.close_navs(title); |
| + | if (title.siblings(self.settings.content_selector).length > 0) { |
| + | self.toggle_active.call(title[0], e); |
| } | |
| }); | |
| $(window) | |
| - | .on('resize.fndtn.section', self.throttle(function () { |
| - | self.resize.call(this); |
| - | }, 30)) |
| - | .on('hashchange', function () { |
| - | if (!self.settings.toggled){ |
| - | self.set_active_from_hash(); |
| - | $(this).trigger('resize'); |
| - | } |
| - | }).trigger('resize'); |
| - | |
| - | $(document) |
| - | .on('click.fndtn.section', function (e) { |
| - | if ($(e.target).closest(self.settings.title_selector).length < 1) { |
| - | $(self.settings.nav_selector) |
| - | .children(self.settings.region_selector) |
| - | .removeClass('active') |
| - | .attr('style', ''); |
| - | } |
| - | }); |
| + | .on('resize.fndtn.section', self.throttle(function() { self.resize(); }, 30)) |
| + | .on('hashchange.fndtn.section', self.set_active_from_hash); |
| + | $(document).on('click.fndtn.section', function (e) { |
| + | if (e.isPropagationStopped && e.isPropagationStopped()) return; |
| + | if (e.target === document) return; |
| + | self.close_navs($(e.target).closest(self.settings.title_selector)); |
| + | }); |
| + | |
| + | $(window).triggerHandler('resize.fndtn.section'); |
| + | $(window).triggerHandler('hashchange.fndtn.section'); |
| }, | |
| + | |
| + | //close nav !one_up on click elsewhere |
| + | close_navs: function(except_nav_with_title) { |
| + | var self = Foundation.libs.section, |
| + | navsToClose = $(self.settings.nav_selector) |
| + | .filter(function() { return !$.extend({}, |
| + | self.settings, self.data_options($(this))).one_up; }); |
| + | |
| + | if (except_nav_with_title.length > 0) { |
| + | var section = except_nav_with_title.parent().parent(); |
| - | toggle_active : function (e, self) { |
| + | if (self.is_horizontal_nav(section) || self.is_vertical_nav(section)) { |
| + | //exclude current nav from list |
| + | navsToClose = navsToClose.filter(function() { return this !== section[0]; }); |
| + | } |
| + | } |
| + | //close navs on click on title |
| + | navsToClose.children(self.settings.region_selector).removeClass(self.settings.active_class); |
| + | }, |
| + | |
| + | toggle_active: function(e) { |
| var $this = $(this), | |
| self = Foundation.libs.section, | |
| - | region = $this.closest(self.settings.region_selector), |
| + | region = $this.parent(), |
| content = $this.siblings(self.settings.content_selector), | |
| - | parent = region.parent(), |
| - | settings = $.extend({}, self.settings, self.data_options(parent)), |
| - | prev_active_section = parent |
| - | .children(self.settings.active_region_selector); |
| - | |
| - | self.settings.toggled = true; |
| + | section = region.parent(), |
| + | settings = $.extend({}, self.settings, self.data_options(section)), |
| + | prev_active_region = section.children(self.settings.region_selector).filter("." + self.settings.active_class); |
| + | //for anchors inside [data-section-title] |
| if (!settings.deep_linking && content.length > 0) { | |
| e.preventDefault(); | |
| } | |
| - | if (region.hasClass('active')) { |
| - | // this is causing the style flash. |
| - | if (self.small(parent) |
| - | || self.is_vertical_nav(parent) |
| - | || self.is_horizontal_nav(parent) |
| - | || self.is_accordion(parent)) { |
| - | if (prev_active_section[0] !== region[0] |
| - | || (prev_active_section[0] === region[0] && !settings.one_up)) { |
| - | region |
| - | .removeClass('active') |
| - | .attr('style', ''); |
| - | } |
| - | } |
| - | } else { |
| - | var prev_active_section = parent |
| - | .children(self.settings.active_region_selector), |
| - | title_height = self.outerHeight(region |
| - | .children(self.settings.title_selector)); |
| - | |
| - | if (self.small(parent) || settings.one_up) { |
| - | |
| - | if (self.small(parent)) { |
| - | prev_active_section.attr('style', ''); |
| - | } else { |
| - | prev_active_section.attr('style', |
| - | 'visibility: hidden; padding-top: '+title_height+'px;'); |
| - | } |
| - | } |
| - | |
| - | if (self.small(parent)) { |
| - | region.attr('style', ''); |
| - | } else { |
| - | region.css('padding-top', title_height); |
| - | } |
| - | |
| - | region.addClass('active'); |
| + | e.stopPropagation(); //do not catch same click again on parent |
| - | if (prev_active_section.length > 0) { |
| - | prev_active_section |
| - | .removeClass('active') |
| - | .attr('style', ''); |
| - | } |
| - | |
| - | // Toggle the content display attribute. This is done to |
| - | // ensure accurate outerWidth measurements that account for |
| - | // the scrollbar. |
| - | if (self.is_vertical_tabs(parent)) { |
| - | content.css('display', 'block'); |
| - | |
| - | if (prev_active_section !== null) { |
| - | prev_active_section |
| - | .children(self.settings.content_selector) |
| - | .css('display', 'none'); |
| - | } |
| + | if (!region.hasClass(self.settings.active_class)) { |
| + | if (!self.is_accordion(section) || (self.is_accordion(section) && !self.settings.multi_expand)) { |
| + | prev_active_region.removeClass(self.settings.active_class); |
| + | prev_active_region.trigger('closed.fndtn.section'); |
| } | |
| + | region.addClass(self.settings.active_class); |
| + | //force resize for better performance (do not wait timer) |
| + | self.resize(region.find(self.settings.section_selector).not("[" + self.settings.resized_data_attr + "]"), true); |
| + | region.trigger('opened.fndtn.section'); |
| + | } else if (region.hasClass(self.settings.active_class) && self.is_accordion(section) || !settings.one_up && (self.small(section) || self.is_vertical_nav(section) || self.is_horizontal_nav(section) || self.is_accordion(section))) { |
| + | region.removeClass(self.settings.active_class); |
| + | region.trigger('closed.fndtn.section'); |
| } | |
| + | settings.callback(section); |
| + | }, |
| - | setTimeout(function () { |
| - | self.settings.toggled = false; |
| - | }, 300); |
| + | check_resize_timer: null, |
| - | settings.callback(); |
| - | }, |
| + | //main function that sets title and content positions; runs for :not(.resized) and :visible once when window width is medium up |
| + | //sections: |
| + | // selected sections to resize, are defined on resize forced by visibility changes |
| + | //ensure_has_active_region: |
| + | // is true when we force resize for no resized sections that were hidden and became visible, |
| + | // these sections can have no selected region, because all regions were hidden along with section on executing set_active_from_hash |
| + | resize: function(sections, ensure_has_active_region) { |
| - | resize : function () { |
| var self = Foundation.libs.section, | |
| - | sections = $(self.settings.section_selector); |
| + | section_container = $(self.settings.section_selector), |
| + | is_small_window = self.small(section_container), |
| + | //filter for section resize |
| + | should_be_resized = function (section, now_is_hidden) { |
| + | return !self.is_accordion(section) && |
| + | !section.is("[" + self.settings.resized_data_attr + "]") && |
| + | (!is_small_window || self.is_horizontal_tabs(section)) && |
| + | now_is_hidden === (section.css('display') === 'none' || |
| + | !section.parent().is(':visible')); |
| + | }; |
| + | |
| + | sections = sections || $(self.settings.section_selector); |
| + | |
| + | clearTimeout(self.check_resize_timer); |
| + | |
| + | if (!is_small_window) { |
| + | sections.removeAttr(self.settings.small_style_data_attr); |
| + | } |
| - | sections.each(function() { |
| - | var $this = $(this), |
| - | active_section = $this |
| - | .children(self.settings.active_region_selector), |
| - | settings = $.extend({}, self.settings, self.data_options($this)); |
| - | |
| - | if (active_section.length > 1) { |
| - | active_section |
| - | .not(':first') |
| - | .removeClass('active') |
| - | .attr('style', ''); |
| - | } else if (active_section.length < 1 |
| - | && !self.is_vertical_nav($this) |
| - | && !self.is_horizontal_nav($this) |
| - | && !self.is_accordion($this)) { |
| - | |
| - | var first = $this.children(self.settings.region_selector).first(); |
| - | |
| - | if (settings.one_up || !self.small($this)) { |
| - | first.addClass('active'); |
| + | //resize |
| + | sections.filter(function() { return should_be_resized($(this), false); }) |
| + | .each(function() { |
| + | var section = $(this), |
| + | regions = section.children(self.settings.region_selector), |
| + | titles = regions.children(self.settings.title_selector), |
| + | content = regions.children(self.settings.content_selector), |
| + | titles_max_height = 0; |
| + | |
| + | if (ensure_has_active_region && |
| + | section.children(self.settings.region_selector).filter("." + self.settings.active_class).length == 0) { |
| + | var settings = $.extend({}, self.settings, self.data_options(section)); |
| + | |
| + | if (!settings.deep_linking && (settings.one_up || !self.is_horizontal_nav(section) && |
| + | !self.is_vertical_nav(section) && !self.is_accordion(section))) { |
| + | regions.filter(":visible").first().addClass(self.settings.active_class); |
| + | } |
| } | |
| - | if (self.small($this)) { |
| - | first.attr('style', ''); |
| - | } else { |
| - | first.css('padding-top', self.outerHeight(first |
| - | .children(self.settings.title_selector))); |
| - | } |
| - | } |
| + | if (self.is_horizontal_tabs(section) || self.is_auto(section)) { |
| + | // region: position relative |
| + | // title: position absolute |
| + | // content: position static |
| + | var titles_sum_width = 0; |
| - | if (self.small($this)) { |
| - | active_section.attr('style', ''); |
| - | } else { |
| - | active_section.css('padding-top', self.outerHeight(active_section |
| - | .children(self.settings.title_selector))); |
| - | } |
| + | titles.each(function() { |
| + | var title = $(this); |
| - | self.position_titles($this); |
| + | if (title.is(":visible")) { |
| + | title.css(!self.rtl ? 'left' : 'right', titles_sum_width); |
| + | var title_h_border_width = parseInt(title.css("border-" + (self.rtl ? 'left' : 'right') + "-width"), 10); |
| - | if ( (self.is_horizontal_nav($this) && !self.small($this)) |
| - | || self.is_vertical_tabs($this) && !self.small($this)) { |
| - | self.position_content($this); |
| - | } else { |
| - | self.position_content($this, false); |
| - | } |
| - | }); |
| - | }, |
| + | if (title_h_border_width.toString() === 'Nan') { |
| + | title_h_border_width = 0; |
| + | } |
| - | is_vertical_nav : function (el) { |
| - | return /vertical-nav/i.test(el.data('section')); |
| - | }, |
| + | titles_sum_width += self.outerWidth(title) - title_h_border_width; |
| + | titles_max_height = Math.max(titles_max_height, self.outerHeight(title)); |
| + | } |
| + | }); |
| + | titles.css('height', titles_max_height); |
| + | regions.each(function() { |
| + | var region = $(this), |
| + | region_content = region.children(self.settings.content_selector), |
| + | content_top_border_width = parseInt(region_content.css("border-top-width"), 10); |
| - | is_horizontal_nav : function (el) { |
| - | return /horizontal-nav/i.test(el.data('section')); |
| - | }, |
| + | if (content_top_border_width.toString() === 'Nan') { |
| + | content_top_border_width = 0; |
| + | } |
| - | is_accordion : function (el) { |
| - | return /accordion/i.test(el.data('section')); |
| - | }, |
| + | region.css('padding-top', titles_max_height - content_top_border_width); |
| + | }); |
| - | is_horizontal_tabs : function (el) { |
| - | return /^tabs$/i.test(el.data('section')); |
| - | }, |
| + | section.css("min-height", titles_max_height); |
| + | } else if (self.is_horizontal_nav(section)) { |
| + | var first = true; |
| + | // region: positon relative, float left |
| + | // title: position static |
| + | // content: position absolute |
| + | titles.each(function() { |
| + | titles_max_height = Math.max(titles_max_height, self.outerHeight($(this))); |
| + | }); |
| - | is_vertical_tabs : function (el) { |
| - | return /vertical-tabs/i.test(el.data('section')); |
| - | }, |
| + | regions.each(function() { |
| + | var region = $(this); |
| - | set_active_from_hash : function () { |
| - | var hash = window.location.hash.substring(1), |
| - | sections = $('[data-section]'), |
| - | self = this; |
| - | sections.each(function () { |
| - | var section = $(this), |
| - | settings = $.extend({}, self.settings, self.data_options(section)); |
| - | |
| - | if (hash.length > 0 && settings.deep_linking) { |
| - | var regions = section |
| - | .children(self.settings.region_selector) |
| - | .attr('style', '') |
| - | .removeClass('active'); |
| - | |
| - | var hash_regions = regions.map(function () { |
| - | var content = $(self.settings.content_selector, this), |
| - | content_slug = content.data('slug'); |
| - | |
| - | if (new RegExp(content_slug, 'i').test(hash)) |
| - | return content; |
| + | region.css("margin-left", "-" + (first ? section : region.children(self.settings.title_selector)).css("border-left-width")); |
| + | first = false; |
| }); | |
| + | regions.css("margin-top", "-" + section.css("border-top-width")); |
| + | titles.css('height', titles_max_height); |
| + | content.css('top', titles_max_height); |
| + | section.css("min-height", titles_max_height); |
| + | } else if (self.is_vertical_tabs(section)) { |
| + | var titles_sum_height = 0; |
| + | // region: position relative, for .active: fixed padding==title.width |
| + | // title: fixed width, position absolute |
| + | // content: position static |
| + | titles.each(function() { |
| + | var title = $(this); |
| + | |
| + | if (title.is(":visible")) { |
| + | title.css('top', titles_sum_height); |
| + | var title_top_border_width = parseInt(title.css("border-top-width"), 10); |
| + | |
| + | if (title_top_border_width.toString() === 'Nan') { |
| + | title_top_border_width = 0; |
| + | } |
| + | |
| + | titles_sum_height += self.outerHeight(title) - title_top_border_width; |
| + | } |
| + | }); |
| - | var count = hash_regions.length; |
| - | |
| - | for (var i = count - 1; i >= 0; i--) { |
| - | $(hash_regions[i]).parent().addClass('active'); |
| - | } |
| - | } |
| - | }); |
| - | }, |
| + | content.css('min-height', titles_sum_height + 1); |
| + | } else if (self.is_vertical_nav(section)) { |
| + | var titles_max_width = 0, |
| + | first1 = true; |
| + | // region: positon relative |
| + | // title: position static |
| + | // content: position absolute |
| + | titles.each(function() { |
| + | titles_max_width = Math.max(titles_max_width, self.outerWidth($(this))); |
| + | }); |
| - | position_titles : function (section, off) { |
| - | var self = this, |
| - | titles = section |
| - | .children(this.settings.region_selector) |
| - | .map(function () { |
| - | return $(this).children(self.settings.title_selector); |
| - | }), |
| - | previous_width = 0, |
| - | previous_height = 0, |
| - | self = this; |
| + | regions.each(function () { |
| + | var region = $(this); |
| - | if (typeof off === 'boolean') { |
| - | titles.attr('style', ''); |
| + | region.css("margin-top", "-" + (first1 ? section : region.children(self.settings.title_selector)).css("border-top-width")); |
| + | first1 = false; |
| + | }); |
| - | } else { |
| - | titles.each(function () { |
| - | if (self.is_vertical_tabs(section)) { |
| - | $(this).css('top', previous_height); |
| - | previous_height += self.outerHeight($(this)); |
| - | } else { |
| - | if (!self.rtl) { |
| - | $(this).css('left', previous_width); |
| - | } else { |
| - | $(this).css('right', previous_width); |
| - | } |
| - | previous_width += self.outerWidth($(this)); |
| + | titles.css('width', titles_max_width); |
| + | content.css(!self.rtl ? 'left' : 'right', titles_max_width); |
| + | section.css('width', titles_max_width); |
| } | |
| - | }); |
| - | } |
| - | }, |
| - | position_content : function (section, off) { |
| - | var self = this, |
| - | regions = section.children(self.settings.region_selector), |
| - | titles = regions |
| - | .map(function () { |
| - | return $(this).children(self.settings.title_selector); |
| - | }), |
| - | content = regions |
| - | .map(function () { |
| - | return $(this).children(self.settings.content_selector); |
| - | }); |
| + | section.attr(self.settings.resized_data_attr, true); |
| + | }); |
| - | if (typeof off === 'boolean') { |
| - | content.attr('style', ''); |
| - | section.attr('style', ''); |
| - | } else { |
| - | if (self.is_vertical_tabs(section) |
| - | && !self.small(section)) { |
| - | var content_min_height = 0, |
| - | content_min_width = Number.MAX_VALUE, |
| - | title_width = null; |
| + | //wait elements to become visible then resize |
| + | if ($(self.settings.section_selector).filter(function() { return should_be_resized($(this), true); }).length > 0) |
| + | self.check_resize_timer = setTimeout(function() { |
| + | self.resize(sections.filter(function() { return should_be_resized($(this), false); }), true); |
| + | }, 700); |
| - | regions.each(function () { |
| - | var region = $(this), |
| - | title = region.children(self.settings.title_selector), |
| - | content = region.children(self.settings.content_selector), |
| - | content_width = 0; |
| + | if (is_small_window) { |
| + | sections.attr(self.settings.small_style_data_attr, true); |
| + | } |
| + | }, |
| - | title_width = self.outerWidth(title); |
| - | content_width = self.outerWidth(section) - title_width; |
| + | is_vertical_nav: function(el) { |
| + | return /vertical-nav/i.test(el.data('section')); |
| + | }, |
| - | if (content_width < content_min_width) { |
| - | content_min_width = content_width; |
| - | } |
| + | is_horizontal_nav: function(el) { |
| + | return /horizontal-nav/i.test(el.data('section')); |
| + | }, |
| - | // Increment the minimum height of the content region |
| - | // to align with the height of the titles. |
| - | content_min_height += self.outerHeight(title); |
| + | is_accordion: function(el) { |
| + | return /accordion/i.test(el.data('section')); |
| + | }, |
| - | // Set all of the inactive tabs to 'display: none' |
| - | // The CSS sets all of the tabs as 'display: block' |
| - | // in order to account for scrollbars when measuring the width |
| - | // of the content regions. |
| - | if (!$(this).hasClass('active')) { |
| - | content.css('display', 'none'); |
| - | } |
| - | }); |
| + | is_horizontal_tabs: function(el) { |
| + | return /^tabs$/i.test(el.data('section')); |
| + | }, |
| - | regions.each(function () { |
| - | var content = $(this).children(self.settings.content_selector); |
| - | content.css('minHeight', content_min_height); |
| + | is_vertical_tabs: function(el) { |
| + | return /vertical-tabs/i.test(el.data('section')); |
| + | }, |
| + | |
| + | is_auto: function (el) { |
| + | var data_section = el.data('section'); |
| + | return data_section === '' || /auto/i.test(data_section); |
| + | }, |
| - | // Remove 2 pixels to account for the right-shift in the CSS |
| - | content.css('maxWidth', content_min_width - 2); |
| - | }); |
| + | set_active_from_hash: function() { |
| + | var self = Foundation.libs.section, |
| + | hash = window.location.hash.substring(1), |
| + | sections = $(self.settings.section_selector); |
| - | } else { |
| - | regions.each(function () { |
| + | var selectedSection; |
| + | |
| + | sections.each(function() { |
| + | var section = $(this), |
| + | regions = section.children(self.settings.region_selector); |
| + | regions.each(function() { |
| var region = $(this), | |
| - | title = region.children(self.settings.title_selector), |
| - | content = region.children(self.settings.content_selector); |
| - | if (!self.rtl) { |
| - | content |
| - | .css({left: title.position().left - 1, |
| - | top: self.outerHeight(title) - 2}); |
| - | } else { |
| - | content |
| - | .css({right: self.position_right(title) + 1, |
| - | top: self.outerHeight(title) - 2}); |
| - | } |
| + | data_slug = region.children(self.settings.content_selector).data('slug'); |
| + | if (new RegExp(data_slug, 'i').test(hash)) { |
| + | selectedSection=section; |
| + | return false; |
| + | } |
| }); | |
| - | |
| - | // temporary work around for Zepto outerheight calculation issues. |
| - | if (typeof Zepto === 'function') { |
| - | section.height(this.outerHeight($(titles[0]))); |
| - | } else { |
| - | section.height(this.outerHeight($(titles[0])) - 2); |
| + | |
| + | if (selectedSection != null) { |
| + | return false; |
| } | |
| - | } |
| + | }); |
| + | |
| + | if (selectedSection != null) { |
| + | sections.each(function() { |
| + | if (selectedSection == $(this)) { |
| + | var section = $(this), |
| + | settings = $.extend({}, self.settings, self.data_options(section)), |
| + | regions = section.children(self.settings.region_selector), |
| + | set_active_from_hash = settings.deep_linking && hash.length > 0, |
| + | selected = false; |
| + | |
| + | regions.each(function() { |
| + | var region = $(this); |
| + | |
| + | if (selected) { |
| + | region.removeClass(self.settings.active_class); |
| + | } else if (set_active_from_hash) { |
| + | var data_slug = region.children(self.settings.content_selector).data('slug'); |
| + | |
| + | if (data_slug && new RegExp(data_slug, 'i').test(hash)) { |
| + | if (!region.hasClass(self.settings.active_class)) |
| + | region.addClass(self.settings.active_class); |
| + | selected = true; |
| + | } else { |
| + | region.removeClass(self.settings.active_class); |
| + | } |
| + | } else if (region.hasClass(self.settings.active_class)) { |
| + | selected = true; |
| + | } |
| + | }); |
| + | |
| + | if (!selected && (settings.one_up || !self.is_horizontal_nav(section) && |
| + | !self.is_vertical_nav(section) && !self.is_accordion(section))) |
| + | regions.filter(":visible").first().addClass(self.settings.active_class); |
| + | } |
| + | }); |
| } | |
| }, | |
| - | position_right : function (el) { |
| - | var self = this, |
| - | section = el.closest(this.settings.section_selector), |
| - | regions = section.children(this.settings.region_selector), |
| - | section_width = el.closest(this.settings.section_selector).width(), |
| - | offset = regions |
| - | .map(function () { |
| - | return $(this).children(self.settings.title_selector); |
| - | }).length; |
| - | return (section_width - el.position().left - el.width() * (el.index() + 1) - offset); |
| - | }, |
| + | reflow: function() { |
| + | var self = Foundation.libs.section; |
| - | reflow : function (scope) { |
| - | var scope = scope || document; |
| - | $(this.settings.section_selector, scope).trigger('resize'); |
| + | $(self.settings.section_selector).removeAttr(self.settings.resized_data_attr); |
| + | self.throttle(function() { self.resize(); }, 30)(); |
| }, | |
| - | small : function (el) { |
| + | small: function(el) { |
| var settings = $.extend({}, this.settings, this.data_options(el)); | |
| if (this.is_horizontal_tabs(el)) { | |
| @@ | @@ -404,13 +407,24 @@ |
| if ($('html').hasClass('ie8compat')) { | |
| return true; | |
| } | |
| - | return $(this.scope).width() < 768; |
| + | return $(this.scope).width() < settings.small_breakpoint; |
| }, | |
| - | off : function () { |
| + | off: function() { |
| $(this.scope).off('.fndtn.section'); | |
| $(window).off('.fndtn.section'); | |
| - | $(document).off('.fndtn.section') |
| + | $(document).off('.fndtn.section'); |
| } | |
| }; | |
| - | }(Foundation.zj, this, this.document)); |
| + | |
| + | //resize selected sections |
| + | $.fn.reflow_section = function(ensure_has_active_region) { |
| + | var section = this, |
| + | self = Foundation.libs.section; |
| + | |
| + | section.removeAttr(self.settings.resized_data_attr); |
| + | self.throttle(function() { self.resize(section, ensure_has_active_region); }, 30)(); |
| + | return this; |
| + | }; |
| + | |
| + | }(Foundation.zj, window, document)); |
generators/foundation/public/javascripts/foundation/foundation.tooltips.js
+5
-4
| @@ | @@ -4,14 +4,15 @@ |
| 'use strict'; | |
| Foundation.libs.tooltips = { | |
| - | name: 'tooltips', |
| + | name : 'tooltips', |
| - | version : '4.2.0', |
| + | version : '4.3.2', |
| settings : { | |
| selector : '.has-tip', | |
| additionalInheritableClasses : [], | |
| tooltipClass : '.tooltip', | |
| + | touchCloseText: 'tap to close', |
| appendTo: 'body', | |
| 'disable-for-touch': false, | |
| tipTemplate : function (selector, content) { | |
| @@ | @@ -33,7 +34,7 @@ |
| $.extend(true, this.settings, options); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| if (Modernizr.touch) { | |
| $(this.scope) | |
| .on('click.fndtn.tooltip touchstart.fndtn.tooltip touchend.fndtn.tooltip', | |
| @@ | @@ -110,7 +111,7 @@ |
| $tip.addClass(classes).appendTo(this.settings.appendTo); | |
| if (Modernizr.touch) { | |
| - | $tip.append('<span class="tap-to-close">tap to close </span>'); |
| + | $tip.append('<span class="tap-to-close">'+this.settings.touchCloseText+'</span>'); |
| } | |
| $target.removeAttr('title').attr('title',''); | |
| this.show($target); | |
generators/foundation/public/javascripts/foundation/foundation.topbar.js
+144
-71
| @@ | @@ -6,7 +6,7 @@ |
| Foundation.libs.topbar = { | |
| name : 'topbar', | |
| - | version : '4.2.0', |
| + | version: '4.3.2', |
| settings : { | |
| index : 0, | |
| @@ | @@ -14,12 +14,13 @@ |
| custom_back_text: true, | |
| back_text: 'Back', | |
| is_hover: true, | |
| + | mobile_show_parent_link: false, |
| scrolltop : true, // jump to top when sticky nav menu toggle is clicked | |
| init : false | |
| }, | |
| init : function (section, method, options) { | |
| - | Foundation.inherit(this, 'data_options'); |
| + | Foundation.inherit(this, 'data_options addCustomRule'); |
| var self = this; | |
| if (typeof method === 'object') { | |
| @@ | @@ -28,7 +29,7 @@ |
| $.extend(true, this.settings, options); | |
| } | |
| - | if (typeof method != 'string') { |
| + | if (typeof method !== 'string') { |
| $('.top-bar, [data-topbar]').each(function () { | |
| $.extend(true, self.settings, self.data_options($(this))); | |
| @@ | @@ -38,14 +39,29 @@ |
| self.settings.$titlebar = self.settings.$topbar.children('ul').first(); | |
| self.settings.$topbar.data('index', 0); | |
| + | var topbarContainer = self.settings.$topbar.parent(); |
| + | if(topbarContainer.hasClass('fixed') || topbarContainer.hasClass(self.settings.stickyClass)) { |
| + | self.settings.$topbar.data('height', self.outerHeight(topbarContainer)); |
| + | self.settings.$topbar.data('stickyoffset', topbarContainer.offset().top); |
| + | } else { |
| + | self.settings.$topbar.data('height', self.outerHeight(self.settings.$topbar)); |
| + | } |
| + | |
| var breakpoint = $("<div class='top-bar-js-breakpoint'/>").insertAfter(self.settings.$topbar); | |
| self.settings.breakPoint = breakpoint.width(); | |
| breakpoint.remove(); | |
| self.assemble(); | |
| + | if (self.settings.is_hover) { |
| + | self.settings.$topbar.find('.has-dropdown').addClass('not-click'); |
| + | } |
| + | |
| + | // Pad body when sticky (scrolled) or fixed. |
| + | self.addCustomRule('.f-topbar-fixed { padding-top: ' + self.settings.$topbar.data('height') + 'px }'); |
| + | |
| if (self.settings.$topbar.parent().hasClass('fixed')) { | |
| - | $('body').css('padding-top', self.outerHeight(self.settings.$topbar)); |
| + | $('body').addClass('f-topbar-fixed'); |
| } | |
| }); | |
| @@ | @@ -60,70 +76,88 @@ |
| } | |
| }, | |
| - | events : function () { |
| + | toggle: function() { |
| var self = this; | |
| - | var offst = this.outerHeight($('.top-bar, [data-topbar]')); |
| - | $(this.scope) |
| - | .off('.fndtn.topbar') |
| - | .on('click.fndtn.topbar', '.top-bar .toggle-topbar, [data-topbar] .toggle-topbar', function (e) { |
| - | var topbar = $(this).closest('.top-bar, [data-topbar]'), |
| - | section = topbar.find('section, .section'), |
| - | titlebar = topbar.children('ul').first(); |
| + | var topbar = $('.top-bar, [data-topbar]'), |
| + | section = topbar.find('section, .section'); |
| - | e.preventDefault(); |
| + | if (self.breakpoint()) { |
| + | if (!self.rtl) { |
| + | section.css({left: '0%'}); |
| + | section.find('>.name').css({left: '100%'}); |
| + | } else { |
| + | section.css({right: '0%'}); |
| + | section.find('>.name').css({right: '100%'}); |
| + | } |
| - | if (self.breakpoint()) { |
| - | if (!self.rtl) { |
| - | section.css({left: '0%'}); |
| - | section.find('>.name').css({left: '100%'}); |
| - | } else { |
| - | section.css({right: '0%'}); |
| - | section.find('>.name').css({right: '100%'}); |
| - | } |
| + | section.find('li.moved').removeClass('moved'); |
| + | topbar.data('index', 0); |
| - | section.find('li.moved').removeClass('moved'); |
| - | topbar.data('index', 0); |
| + | topbar |
| + | .toggleClass('expanded') |
| + | .css('height', ''); |
| + | } |
| - | topbar |
| - | .toggleClass('expanded') |
| - | .css('min-height', ''); |
| + | if(self.settings.scrolltop) |
| + | { |
| + | if (!topbar.hasClass('expanded')) { |
| + | if (topbar.hasClass('fixed')) { |
| + | topbar.parent().addClass('fixed'); |
| + | topbar.removeClass('fixed'); |
| + | $('body').addClass('f-topbar-fixed'); |
| } | |
| - | |
| - | if (!topbar.hasClass('expanded')) { |
| - | if (topbar.hasClass('fixed')) { |
| - | topbar.parent().addClass('fixed'); |
| - | topbar.removeClass('fixed'); |
| - | $('body').css('padding-top',offst); |
| - | } |
| - | } else if (topbar.parent().hasClass('fixed')) { |
| + | } else if (topbar.parent().hasClass('fixed')) { |
| + | if (self.settings.scrolltop) { |
| topbar.parent().removeClass('fixed'); | |
| topbar.addClass('fixed'); | |
| - | $('body').css('padding-top','0'); |
| + | $('body').removeClass('f-topbar-fixed'); |
| - | if (self.settings.scrolltop) { |
| - | window.scrollTo(0,0); |
| - | } |
| + | window.scrollTo(0,0); |
| + | } else { |
| + | topbar.parent().removeClass('expanded'); |
| } | |
| - | }) |
| - | |
| - | .on('mouseenter mouseleave', '.top-bar li', function (e) { |
| - | if (!self.settings.is_hover) return; |
| + | } |
| + | } else { |
| + | if(topbar.parent().hasClass(self.settings.stickyClass)) { |
| + | topbar.parent().addClass('fixed'); |
| + | } |
| - | if (/enter|over/i.test(e.type)) { |
| - | $(this).addClass('hover'); |
| + | if(topbar.parent().hasClass('fixed')) { |
| + | if (!topbar.hasClass('expanded')) { |
| + | topbar.removeClass('fixed'); |
| + | topbar.parent().removeClass('expanded'); |
| + | self.updateStickyPositioning(); |
| } else { | |
| - | $(this).removeClass('hover'); |
| + | topbar.addClass('fixed'); |
| + | topbar.parent().addClass('expanded'); |
| } | |
| + | } |
| + | } |
| + | }, |
| + | |
| + | timer : null, |
| + | |
| + | events : function () { |
| + | var self = this; |
| + | $(this.scope) |
| + | .off('.fndtn.topbar') |
| + | .on('click.fndtn.topbar', '.top-bar .toggle-topbar, [data-topbar] .toggle-topbar', function (e) { |
| + | e.preventDefault(); |
| + | self.toggle(); |
| }) | |
| .on('click.fndtn.topbar', '.top-bar li.has-dropdown', function (e) { | |
| - | if (self.breakpoint()) return; |
| - | |
| var li = $(this), | |
| target = $(e.target), | |
| topbar = li.closest('[data-topbar], .top-bar'), | |
| is_hover = topbar.data('topbar'); | |
| + | if(target.data('revealId')) { |
| + | self.toggle(); |
| + | return; |
| + | } |
| + | |
| + | if (self.breakpoint()) return; |
| if (self.settings.is_hover && !Modernizr.touch) return; | |
| e.stopImmediatePropagation(); | |
| @@ | @@ -137,19 +171,22 @@ |
| .removeClass('hover') | |
| .find('li') | |
| .removeClass('hover'); | |
| + | |
| + | li.parents('li.hover') |
| + | .removeClass('hover'); |
| } else { | |
| li.addClass('hover'); | |
| } | |
| }) | |
| .on('click.fndtn.topbar', '.top-bar .has-dropdown>a, [data-topbar] .has-dropdown>a', function (e) { | |
| - | if (self.breakpoint()) { |
| + | if (self.breakpoint() && $(window).width() != self.settings.breakPoint) { |
| + | |
| e.preventDefault(); | |
| var $this = $(this), | |
| topbar = $this.closest('.top-bar, [data-topbar]'), | |
| section = topbar.find('section, .section'), | |
| - | titlebar = topbar.children('ul').first(), |
| dropdownHeight = $this.next('.dropdown').outerHeight(), | |
| $selectedLi = $this.closest('li'); | |
| @@ | @@ -164,22 +201,49 @@ |
| section.find('>.name').css({right: 100 * topbar.data('index') + '%'}); | |
| } | |
| - | topbar.css('min-height', self.height($this.siblings('ul')) + self.outerHeight(titlebar, true)); |
| + | topbar.css('height', self.outerHeight($this.siblings('ul'), true) + self.settings.$topbar.data('height')); |
| } | |
| }); | |
| $(window).on('resize.fndtn.topbar', function () { | |
| + | if (typeof self.settings.$topbar === 'undefined') { return; } |
| + | var stickyContainer = self.settings.$topbar.parent('.' + this.settings.stickyClass); |
| + | var stickyOffset; |
| + | |
| if (!self.breakpoint()) { | |
| + | var doToggle = self.settings.$topbar.hasClass('expanded'); |
| $('.top-bar, [data-topbar]') | |
| - | .css('min-height', '') |
| + | .css('height', '') |
| .removeClass('expanded') | |
| .find('li') | |
| .removeClass('hover'); | |
| + | |
| + | if(doToggle) { |
| + | self.toggle(); |
| + | } |
| + | } |
| + | |
| + | if(stickyContainer.length > 0) { |
| + | if(stickyContainer.hasClass('fixed')) { |
| + | // Remove the fixed to allow for correct calculation of the offset. |
| + | stickyContainer.removeClass('fixed'); |
| + | |
| + | stickyOffset = stickyContainer.offset().top; |
| + | if($(document.body).hasClass('f-topbar-fixed')) { |
| + | stickyOffset -= self.settings.$topbar.data('height'); |
| + | } |
| + | |
| + | self.settings.$topbar.data('stickyoffset', stickyOffset); |
| + | stickyContainer.addClass('fixed'); |
| + | } else { |
| + | stickyOffset = stickyContainer.offset().top; |
| + | self.settings.$topbar.data('stickyoffset', stickyOffset); |
| + | } |
| } | |
| }.bind(this)); | |
| $('body').on('click.fndtn.topbar', function (e) { | |
| - | var parent = $(e.target).closest('[data-topbar], .top-bar'); |
| + | var parent = $(e.target).closest('li').closest('li.hover'); |
| if (parent.length > 0) { | |
| return; | |
| @@ | @@ -194,7 +258,6 @@ |
| var $this = $(this), | |
| topbar = $this.closest('.top-bar, [data-topbar]'), | |
| - | titlebar = topbar.children('ul').first(), |
| section = topbar.find('section, .section'), | |
| $movedLi = $this.closest('li.moved'), | |
| $previousLevelUl = $movedLi.parent(); | |
| @@ | @@ -210,9 +273,9 @@ |
| } | |
| if (topbar.data('index') === 0) { | |
| - | topbar.css('min-height', 0); |
| + | topbar.css('height', ''); |
| } else { | |
| - | topbar.css('min-height', self.height($previousLevelUl) + self.outerHeight(titlebar, true)); |
| + | topbar.css('height', self.outerHeight($previousLevelUl, true) + self.settings.$topbar.data('height')); |
| } | |
| setTimeout(function () { | |
| @@ | @@ -222,7 +285,7 @@ |
| }, | |
| breakpoint : function () { | |
| - | return $(window).width() <= this.settings.breakPoint || $('html').hasClass('lt-ie9'); |
| + | return $(document).width() <= this.settings.breakPoint || $('html').hasClass('lt-ie9'); |
| }, | |
| assemble : function () { | |
| @@ | @@ -235,7 +298,7 @@ |
| $dropdown = $link.siblings('.dropdown'), | |
| url = $link.attr('href'); | |
| - | if (url && url.length > 1) { |
| + | if (self.settings.mobile_show_parent_link && url && url.length > 1) { |
| var $titleLi = $('<li class="title back js-generated"><h5><a href="#"></a></h5></li><li><a class="parent-link js-generated" href="' + url + '">' + $link.text() +'</a></li>'); | |
| } else { | |
| var $titleLi = $('<li class="title back js-generated"><h5><a href="#"></a></h5></li>'); | |
| @@ | @@ -243,7 +306,7 @@ |
| // Copy link to subnav | |
| if (self.settings.custom_back_text == true) { | |
| - | $titleLi.find('h5>a').html('« ' + self.settings.back_text); |
| + | $titleLi.find('h5>a').html(self.settings.back_text); |
| } else { | |
| $titleLi.find('h5>a').html('« ' + $link.html()); | |
| } | |
| @@ | @@ -267,23 +330,33 @@ |
| }, | |
| sticky : function () { | |
| + | var $window = $(window), |
| + | self = this; |
| + | |
| + | $window.scroll(function() { |
| + | self.updateStickyPositioning(); |
| + | }); |
| + | }, |
| + | |
| + | updateStickyPositioning: function() { |
| var klass = '.' + this.settings.stickyClass; | |
| + | var $window = $(window); |
| + | |
| if ($(klass).length > 0) { | |
| - | var distance = $(klass).length ? $(klass).offset().top: 0, |
| - | $window = $(window); |
| - | var offst = this.outerHeight($('.top-bar')); |
| - | |
| - | $window.scroll(function() { |
| - | if ($window.scrollTop() >= (distance)) { |
| - | $(klass).addClass("fixed"); |
| - | $('body').css('padding-top',offst); |
| + | var distance = this.settings.$topbar.data('stickyoffset'); |
| + | if (!$(klass).hasClass('expanded')) { |
| + | if ($window.scrollTop() > (distance)) { |
| + | if (!$(klass).hasClass('fixed')) { |
| + | $(klass).addClass('fixed'); |
| + | $('body').addClass('f-topbar-fixed'); |
| } | |
| - | |
| - | else if ($window.scrollTop() < distance) { |
| - | $(klass).removeClass("fixed"); |
| - | $('body').css('padding-top','0'); |
| + | } else if ($window.scrollTop() <= distance) { |
| + | if ($(klass).hasClass('fixed')) { |
| + | $(klass).removeClass('fixed'); |
| + | $('body').removeClass('f-topbar-fixed'); |
| } | |
| - | }); |
| + | } |
| + | } |
| } | |
| }, | |
generators/foundation/public/javascripts/vendor/custom.modernizr.js
+1
-1
| @@ | @@ -1,4 +1,4 @@ |
| /* Modernizr 2.6.2 (Custom Build) | MIT & BSD | |
| * Build: http://modernizr.com/download/#-inlinesvg-svg-svgclippaths-touch-shiv-mq-cssclasses-teststyles-prefixes-ie8compat-load | |
| */ | |
| - | ;window.Modernizr=function(a,b,c){function y(a){j.cssText=a}function z(a,b){return y(m.join(a+";")+(b||""))}function A(a,b){return typeof a===b}function B(a,b){return!!~(""+a).indexOf(b)}function C(a,b,d){for(var e in a){var f=b[a[e]];if(f!==c)return d===!1?a[e]:A(f,"function")?f.bind(d||b):f}return!1}var d="2.6.2",e={},f=!0,g=b.documentElement,h="modernizr",i=b.createElement(h),j=i.style,k,l={}.toString,m=" -webkit- -moz- -o- -ms- ".split(" "),n={svg:"http://www.w3.org/2000/svg"},o={},p={},q={},r=[],s=r.slice,t,u=function(a,c,d,e){var f,i,j,k,l=b.createElement("div"),m=b.body,n=m||b.createElement("body");if(parseInt(d,10))while(d--)j=b.createElement("div"),j.id=e?e[d]:h+(d+1),l.appendChild(j);return f=["­",'<style id="s',h,'">',a,"</style>"].join(""),l.id=h,(m?l:n).innerHTML+=f,n.appendChild(l),m||(n.style.background="",n.style.overflow="hidden",k=g.style.overflow,g.style.overflow="hidden",g.appendChild(n)),i=c(l,a),m?l.parentNode.removeChild(l):(n.parentNode.removeChild(n),g.style.overflow=k),!!i},v=function(b){var c=a.matchMedia||a.msMatchMedia;if(c)return c(b).matches;var d;return u("@media "+b+" { #"+h+" { position: absolute; } }",function(b){d=(a.getComputedStyle?getComputedStyle(b,null):b.currentStyle)["position"]=="absolute"}),d},w={}.hasOwnProperty,x;!A(w,"undefined")&&!A(w.call,"undefined")?x=function(a,b){return w.call(a,b)}:x=function(a,b){return b in a&&A(a.constructor.prototype[b],"undefined")},Function.prototype.bind||(Function.prototype.bind=function(b){var c=this;if(typeof c!="function")throw new TypeError;var d=s.call(arguments,1),e=function(){if(this instanceof e){var a=function(){};a.prototype=c.prototype;var f=new a,g=c.apply(f,d.concat(s.call(arguments)));return Object(g)===g?g:f}return c.apply(b,d.concat(s.call(arguments)))};return e}),o.touch=function(){var c;return"ontouchstart"in a||a.DocumentTouch&&b instanceof DocumentTouch?c=!0:u(["@media (",m.join("touch-enabled),("),h,")","{#modernizr{top:9px;position:absolute}}"].join(""),function(a){c=a.offsetTop===9}),c},o.svg=function(){return!!b.createElementNS&&!!b.createElementNS(n.svg,"svg").createSVGRect},o.inlinesvg=function(){var a=b.createElement("div");return a.innerHTML="<svg/>",(a.firstChild&&a.firstChild.namespaceURI)==n.svg},o.svgclippaths=function(){return!!b.createElementNS&&/SVGClipPath/.test(l.call(b.createElementNS(n.svg,"clipPath")))};for(var D in o)x(o,D)&&(t=D.toLowerCase(),e[t]=o[D](),r.push((e[t]?"":"no-")+t));return e.addTest=function(a,b){if(typeof a=="object")for(var d in a)x(a,d)&&e.addTest(d,a[d]);else{a=a.toLowerCase();if(e[a]!==c)return e;b=typeof b=="function"?b():b,typeof f!="undefined"&&f&&(g.className+=" "+(b?"":"no-")+a),e[a]=b}return e},y(""),i=k=null,function(a,b){function k(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function l(){var a=r.elements;return typeof a=="string"?a.split(" "):a}function m(a){var b=i[a[g]];return b||(b={},h++,a[g]=h,i[h]=b),b}function n(a,c,f){c||(c=b);if(j)return c.createElement(a);f||(f=m(c));var g;return f.cache[a]?g=f.cache[a].cloneNode():e.test(a)?g=(f.cache[a]=f.createElem(a)).cloneNode():g=f.createElem(a),g.canHaveChildren&&!d.test(a)?f.frag.appendChild(g):g}function o(a,c){a||(a=b);if(j)return a.createDocumentFragment();c=c||m(a);var d=c.frag.cloneNode(),e=0,f=l(),g=f.length;for(;e<g;e++)d.createElement(f[e]);return d}function p(a,b){b.cache||(b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag()),a.createElement=function(c){return r.shivMethods?n(c,a,b):b.createElem(c)},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+l().join().replace(/\w+/g,function(a){return b.createElem(a),b.frag.createElement(a),'c("'+a+'")'})+");return n}")(r,b.frag)}function q(a){a||(a=b);var c=m(a);return r.shivCSS&&!f&&!c.hasCSS&&(c.hasCSS=!!k(a,"article,aside,figcaption,figure,footer,header,hgroup,nav,section{display:block}mark{background:#FF0;color:#000}")),j||p(a,c),a}var c=a.html5||{},d=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,e=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,f,g="_html5shiv",h=0,i={},j;(function(){try{var a=b.createElement("a");a.innerHTML="<xyz></xyz>",f="hidden"in a,j=a.childNodes.length==1||function(){b.createElement("a");var a=b.createDocumentFragment();return typeof a.cloneNode=="undefined"||typeof a.createDocumentFragment=="undefined"||typeof a.createElement=="undefined"}()}catch(c){f=!0,j=!0}})();var r={elements:c.elements||"abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup mark meter nav output progress section summary time video",shivCSS:c.shivCSS!==!1,supportsUnknownElements:j,shivMethods:c.shivMethods!==!1,type:"default",shivDocument:q,createElement:n,createDocumentFragment:o};a.html5=r,q(b)}(this,b),e._version=d,e._prefixes=m,e.mq=v,e.testStyles=u,g.className=g.className.replace(/(^|\s)no-js(\s|$)/,"$1$2")+(f?" js "+r.join(" "):""),e}(this,this.document),function(a,b,c){function d(a){return"[object Function]"==o.call(a)}function e(a){return"string"==typeof a}function f(){}function g(a){return!a||"loaded"==a||"complete"==a||"uninitialized"==a}function h(){var a=p.shift();q=1,a?a.t?m(function(){("c"==a.t?B.injectCss:B.injectJs)(a.s,0,a.a,a.x,a.e,1)},0):(a(),h()):q=0}function i(a,c,d,e,f,i,j){function k(b){if(!o&&g(l.readyState)&&(u.r=o=1,!q&&h(),l.onload=l.onreadystatechange=null,b)){"img"!=a&&m(function(){t.removeChild(l)},50);for(var d in y[c])y[c].hasOwnProperty(d)&&y[c][d].onload()}}var j=j||B.errorTimeout,l=b.createElement(a),o=0,r=0,u={t:d,s:c,e:f,a:i,x:j};1===y[c]&&(r=1,y[c]=[]),"object"==a?l.data=c:(l.src=c,l.type=a),l.width=l.height="0",l.onerror=l.onload=l.onreadystatechange=function(){k.call(this,r)},p.splice(e,0,u),"img"!=a&&(r||2===y[c]?(t.insertBefore(l,s?null:n),m(k,j)):y[c].push(l))}function j(a,b,c,d,f){return q=0,b=b||"j",e(a)?i("c"==b?v:u,a,b,this.i++,c,d,f):(p.splice(this.i++,0,a),1==p.length&&h()),this}function k(){var a=B;return a.loader={load:j,i:0},a}var l=b.documentElement,m=a.setTimeout,n=b.getElementsByTagName("script")[0],o={}.toString,p=[],q=0,r="MozAppearance"in l.style,s=r&&!!b.createRange().compareNode,t=s?l:n.parentNode,l=a.opera&&"[object Opera]"==o.call(a.opera),l=!!b.attachEvent&&!l,u=r?"object":l?"script":"img",v=l?"script":u,w=Array.isArray||function(a){return"[object Array]"==o.call(a)},x=[],y={},z={timeout:function(a,b){return b.length&&(a.timeout=b[0]),a}},A,B;B=function(a){function b(a){var a=a.split("!"),b=x.length,c=a.pop(),d=a.length,c={url:c,origUrl:c,prefixes:a},e,f,g;for(f=0;f<d;f++)g=a[f].split("="),(e=z[g.shift()])&&(c=e(c,g));for(f=0;f<b;f++)c=x[f](c);return c}function g(a,e,f,g,h){var i=b(a),j=i.autoCallback;i.url.split(".").pop().split("?").shift(),i.bypass||(e&&(e=d(e)?e:e[a]||e[g]||e[a.split("/").pop().split("?")[0]]),i.instead?i.instead(a,e,f,g,h):(y[i.url]?i.noexec=!0:y[i.url]=1,f.load(i.url,i.forceCSS||!i.forceJS&&"css"==i.url.split(".").pop().split("?").shift()?"c":c,i.noexec,i.attrs,i.timeout),(d(e)||d(j))&&f.load(function(){k(),e&&e(i.origUrl,h,g),j&&j(i.origUrl,h,g),y[i.url]=2})))}function h(a,b){function c(a,c){if(a){if(e(a))c||(j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}),g(a,j,b,0,h);else if(Object(a)===a)for(n in m=function(){var b=0,c;for(c in a)a.hasOwnProperty(c)&&b++;return b}(),a)a.hasOwnProperty(n)&&(!c&&!--m&&(d(j)?j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}:j[n]=function(a){return function(){var b=[].slice.call(arguments);a&&a.apply(this,b),l()}}(k[n])),g(a[n],j,b,n,h))}else!c&&l()}var h=!!a.test,i=a.load||a.both,j=a.callback||f,k=j,l=a.complete||f,m,n;c(h?a.yep:a.nope,!!i),i&&c(i)}var i,j,l=this.yepnope.loader;if(e(a))g(a,0,l,0);else if(w(a))for(i=0;i<a.length;i++)j=a[i],e(j)?g(j,0,l,0):w(j)?B(j):Object(j)===j&&h(j,l);else Object(a)===a&&h(a,l)},B.addPrefix=function(a,b){z[a]=b},B.addFilter=function(a){x.push(a)},B.errorTimeout=1e4,null==b.readyState&&b.addEventListener&&(b.readyState="loading",b.addEventListener("DOMContentLoaded",A=function(){b.removeEventListener("DOMContentLoaded",A,0),b.readyState="complete"},0)),a.yepnope=k(),a.yepnope.executeStack=h,a.yepnope.injectJs=function(a,c,d,e,i,j){var k=b.createElement("script"),l,o,e=e||B.errorTimeout;k.src=a;for(o in d)k.setAttribute(o,d[o]);c=j?h:c||f,k.onreadystatechange=k.onload=function(){!l&&g(k.readyState)&&(l=1,c(),k.onload=k.onreadystatechange=null)},m(function(){l||(l=1,c(1))},e),i?k.onload():n.parentNode.insertBefore(k,n)},a.yepnope.injectCss=function(a,c,d,e,g,i){var e=b.createElement("link"),j,c=i?h:c||f;e.href=a,e.rel="stylesheet",e.type="text/css";for(j in d)e.setAttribute(j,d[j]);g||(n.parentNode.insertBefore(e,n),m(c,0))}}(this,document),Modernizr.load=function(){yepnope.apply(window,[].slice.call(arguments,0))},Modernizr.addTest("ie8compat",function(){return!window.addEventListener&&document.documentMode&&document.documentMode===7}); |
| \ No newline at end of file | |
| + | ;window.Modernizr=function(a,b,c){function y(a){j.cssText=a}function z(a,b){return y(m.join(a+";")+(b||""))}function A(a,b){return typeof a===b}function B(a,b){return!!~(""+a).indexOf(b)}function C(a,b,d){for(var e in a){var f=b[a[e]];if(f!==c)return d===!1?a[e]:A(f,"function")?f.bind(d||b):f}return!1}var d="2.6.2",e={},f=!0,g=b.documentElement,h="modernizr",i=b.createElement(h),j=i.style,k,l={}.toString,m=" -webkit- -moz- -o- -ms- ".split(" "),n={svg:"http://www.w3.org/2000/svg"},o={},p={},q={},r=[],s=r.slice,t,u=function(a,c,d,e){var f,i,j,k,l=b.createElement("div"),m=b.body,n=m||b.createElement("body");if(parseInt(d,10))while(d--)j=b.createElement("div"),j.id=e?e[d]:h+(d+1),l.appendChild(j);return f=["­",'<style id="s',h,'">',a,"</style>"].join(""),l.id=h,(m?l:n).innerHTML+=f,n.appendChild(l),m||(n.style.background="",n.style.overflow="hidden",k=g.style.overflow,g.style.overflow="hidden",g.appendChild(n)),i=c(l,a),m?l.parentNode.removeChild(l):(n.parentNode.removeChild(n),g.style.overflow=k),!!i},v=function(b){var c=a.matchMedia||a.msMatchMedia;if(c)return c(b).matches;var d;return u("@media "+b+" { #"+h+" { position: absolute; } }",function(b){d=(a.getComputedStyle?getComputedStyle(b,null):b.currentStyle)["position"]=="absolute"}),d},w={}.hasOwnProperty,x;!A(w,"undefined")&&!A(w.call,"undefined")?x=function(a,b){return w.call(a,b)}:x=function(a,b){return b in a&&A(a.constructor.prototype[b],"undefined")},Function.prototype.bind||(Function.prototype.bind=function(b){var c=this;if(typeof c!="function")throw new TypeError;var d=s.call(arguments,1),e=function(){if(this instanceof e){var a=function(){};a.prototype=c.prototype;var f=new a,g=c.apply(f,d.concat(s.call(arguments)));return Object(g)===g?g:f}return c.apply(b,d.concat(s.call(arguments)))};return e}),o.touch=function(){var c;return"ontouchstart"in a||a.DocumentTouch&&b instanceof DocumentTouch?c=!0:u(["@media (",m.join("touch-enabled),("),h,")","{#modernizr{top:9px;position:absolute}}"].join(""),function(a){c=a.offsetTop===9}),c},o.svg=function(){return!!b.createElementNS&&!!b.createElementNS(n.svg,"svg").createSVGRect},o.inlinesvg=function(){var a=b.createElement("div");return a.innerHTML="<svg/>",(a.firstChild&&a.firstChild.namespaceURI)==n.svg},o.svgclippaths=function(){return!!b.createElementNS&&/SVGClipPath/.test(l.call(b.createElementNS(n.svg,"clipPath")))};for(var D in o)x(o,D)&&(t=D.toLowerCase(),e[t]=o[D](),r.push((e[t]?"":"no-")+t));return e.addTest=function(a,b){if(typeof a=="object")for(var d in a)x(a,d)&&e.addTest(d,a[d]);else{a=a.toLowerCase();if(e[a]!==c)return e;b=typeof b=="function"?b():b,typeof f!="undefined"&&f&&(g.className+=" "+(b?"":"no-")+a),e[a]=b}return e},y(""),i=k=null,function(a,b){function k(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function l(){var a=r.elements;return typeof a=="string"?a.split(" "):a}function m(a){var b=i[a[g]];return b||(b={},h++,a[g]=h,i[h]=b),b}function n(a,c,f){c||(c=b);if(j)return c.createElement(a);f||(f=m(c));var g;return f.cache[a]?g=f.cache[a].cloneNode():e.test(a)?g=(f.cache[a]=f.createElem(a)).cloneNode():g=f.createElem(a),g.canHaveChildren&&!d.test(a)?f.frag.appendChild(g):g}function o(a,c){a||(a=b);if(j)return a.createDocumentFragment();c=c||m(a);var d=c.frag.cloneNode(),e=0,f=l(),g=f.length;for(;e<g;e++)d.createElement(f[e]);return d}function p(a,b){b.cache||(b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag()),a.createElement=function(c){return r.shivMethods?n(c,a,b):b.createElem(c)},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+l().join().replace(/\w+/g,function(a){return b.createElem(a),b.frag.createElement(a),'c("'+a+'")'})+");return n}")(r,b.frag)}function q(a){a||(a=b);var c=m(a);return r.shivCSS&&!f&&!c.hasCSS&&(c.hasCSS=!!k(a,"article,aside,figcaption,figure,footer,header,hgroup,nav,section{display:block}mark{background:#FF0;color:#000}")),j||p(a,c),a}var c=a.html5||{},d=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,e=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,f,g="_html5shiv",h=0,i={},j;(function(){try{var a=b.createElement("a");a.innerHTML="<xyz></xyz>",f="hidden"in a,j=a.childNodes.length==1||function(){b.createElement("a");var a=b.createDocumentFragment();return typeof a.cloneNode=="undefined"||typeof a.createDocumentFragment=="undefined"||typeof a.createElement=="undefined"}()}catch(c){f=!0,j=!0}})();var r={elements:c.elements||"abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup mark meter nav output progress section summary time video",shivCSS:c.shivCSS!==!1,supportsUnknownElements:j,shivMethods:c.shivMethods!==!1,type:"default",shivDocument:q,createElement:n,createDocumentFragment:o};a.html5=r,q(b)}(this,b),e._version=d,e._prefixes=m,e.mq=v,e.testStyles=u,g.className=g.className.replace(/(^|\s)no-js(\s|$)/,"$1$2")+(f?" js "+r.join(" "):""),e}(this,this.document),function(a,b,c){function d(a){return"[object Function]"==o.call(a)}function e(a){return"string"==typeof a}function f(){}function g(a){return!a||"loaded"==a||"complete"==a||"uninitialized"==a}function h(){var a=p.shift();q=1,a?a.t?m(function(){("c"==a.t?B.injectCss:B.injectJs)(a.s,0,a.a,a.x,a.e,1)},0):(a(),h()):q=0}function i(a,c,d,e,f,i,j){function k(b){if(!o&&g(l.readyState)&&(u.r=o=1,!q&&h(),l.onload=l.onreadystatechange=null,b)){"img"!=a&&m(function(){t.removeChild(l)},50);for(var d in y[c])y[c].hasOwnProperty(d)&&y[c][d].onload()}}var j=j||B.errorTimeout,l=b.createElement(a),o=0,r=0,u={t:d,s:c,e:f,a:i,x:j};1===y[c]&&(r=1,y[c]=[]),"object"==a?l.data=c:(l.src=c,l.type=a),l.width=l.height="0",l.onerror=l.onload=l.onreadystatechange=function(){k.call(this,r)},p.splice(e,0,u),"img"!=a&&(r||2===y[c]?(t.insertBefore(l,s?null:n),m(k,j)):y[c].push(l))}function j(a,b,c,d,f){return q=0,b=b||"j",e(a)?i("c"==b?v:u,a,b,this.i++,c,d,f):(p.splice(this.i++,0,a),1==p.length&&h()),this}function k(){var a=B;return a.loader={load:j,i:0},a}var l=b.documentElement,m=a.setTimeout,n=b.getElementsByTagName("script")[0],o={}.toString,p=[],q=0,r="MozAppearance"in l.style,s=r&&!!b.createRange().compareNode,t=s?l:n.parentNode,l=a.opera&&"[object Opera]"==o.call(a.opera),l=!!b.attachEvent&&!l,u=r?"object":l?"script":"img",v=l?"script":u,w=Array.isArray||function(a){return"[object Array]"==o.call(a)},x=[],y={},z={timeout:function(a,b){return b.length&&(a.timeout=b[0]),a}},A,B;B=function(a){function b(a){var a=a.split("!"),b=x.length,c=a.pop(),d=a.length,c={url:c,origUrl:c,prefixes:a},e,f,g;for(f=0;f<d;f++)g=a[f].split("="),(e=z[g.shift()])&&(c=e(c,g));for(f=0;f<b;f++)c=x[f](c);return c}function g(a,e,f,g,h){var i=b(a),j=i.autoCallback;i.url.split(".").pop().split("?").shift(),i.bypass||(e&&(e=d(e)?e:e[a]||e[g]||e[a.split("/").pop().split("?")[0]]),i.instead?i.instead(a,e,f,g,h):(y[i.url]?i.noexec=!0:y[i.url]=1,f.load(i.url,i.forceCSS||!i.forceJS&&"css"==i.url.split(".").pop().split("?").shift()?"c":c,i.noexec,i.attrs,i.timeout),(d(e)||d(j))&&f.load(function(){k(),e&&e(i.origUrl,h,g),j&&j(i.origUrl,h,g),y[i.url]=2})))}function h(a,b){function c(a,c){if(a){if(e(a))c||(j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}),g(a,j,b,0,h);else if(Object(a)===a)for(n in m=function(){var b=0,c;for(c in a)a.hasOwnProperty(c)&&b++;return b}(),a)a.hasOwnProperty(n)&&(!c&&!--m&&(d(j)?j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}:j[n]=function(a){return function(){var b=[].slice.call(arguments);a&&a.apply(this,b),l()}}(k[n])),g(a[n],j,b,n,h))}else!c&&l()}var h=!!a.test,i=a.load||a.both,j=a.callback||f,k=j,l=a.complete||f,m,n;c(h?a.yep:a.nope,!!i),i&&c(i)}var i,j,l=this.yepnope.loader;if(e(a))g(a,0,l,0);else if(w(a))for(i=0;i<a.length;i++)j=a[i],e(j)?g(j,0,l,0):w(j)?B(j):Object(j)===j&&h(j,l);else Object(a)===a&&h(a,l)},B.addPrefix=function(a,b){z[a]=b},B.addFilter=function(a){x.push(a)},B.errorTimeout=1e4,null==b.readyState&&b.addEventListener&&(b.readyState="loading",b.addEventListener("DOMContentLoaded",A=function(){b.removeEventListener("DOMContentLoaded",A,0),b.readyState="complete"},0)),a.yepnope=k(),a.yepnope.executeStack=h,a.yepnope.injectJs=function(a,c,d,e,i,j){var k=b.createElement("script"),l,o,e=e||B.errorTimeout;k.src=a;for(o in d)k.setAttribute(o,d[o]);c=j?h:c||f,k.onreadystatechange=k.onload=function(){!l&&g(k.readyState)&&(l=1,c(),k.onload=k.onreadystatechange=null)},m(function(){l||(l=1,c(1))},e),i?k.onload():n.parentNode.insertBefore(k,n)},a.yepnope.injectCss=function(a,c,d,e,g,i){var e=b.createElement("link"),j,c=i?h:c||f;e.href=a,e.rel="stylesheet",e.type="text/css";for(j in d)e.setAttribute(j,d[j]);g||(n.parentNode.insertBefore(e,n),m(c,0))}}(this,document),Modernizr.load=function(){yepnope.apply(window,[].slice.call(arguments,0))},Modernizr.addTest("ie8compat",function(){return!window.addEventListener&&document.documentMode&&document.documentMode===7}); |
generators/foundation/public/javascripts/vendor/jquery.js
+4389
-4197
| @@ | @@ -1,15 +1,15 @@ |
| /*! | |
| - | * jQuery JavaScript Library v1.9.1 |
| + | * jQuery JavaScript Library v1.10.2 |
| * http://jquery.com/ | |
| * | |
| * Includes Sizzle.js | |
| * http://sizzlejs.com/ | |
| * | |
| - | * Copyright 2005, 2012 jQuery Foundation, Inc. and other contributors |
| + | * Copyright 2005, 2013 jQuery Foundation, Inc. and other contributors |
| * Released under the MIT license | |
| * http://jquery.org/license | |
| * | |
| - | * Date: 2013-2-4 |
| + | * Date: 2013-07-03T13:48Z |
| */ | |
| (function( window, undefined ) { | |
| @@ | @@ -25,13 +25,14 @@ var |
| // A central reference to the root jQuery(document) | |
| rootjQuery, | |
| - | // Support: IE<9 |
| - | // For `typeof node.method` instead of `node.method !== undefined` |
| + | // Support: IE<10 |
| + | // For `typeof xmlNode.method` instead of `xmlNode.method !== undefined` |
| core_strundefined = typeof undefined, | |
| // Use the correct document accordingly with window argument (sandbox) | |
| - | document = window.document, |
| location = window.location, | |
| + | document = window.document, |
| + | docElem = document.documentElement, |
| // Map over jQuery in case of overwrite | |
| _jQuery = window.jQuery, | |
| @@ | @@ -45,7 +46,7 @@ var |
| // List of deleted data cache ids, so we can reuse them | |
| core_deletedIds = [], | |
| - | core_version = "1.9.1", |
| + | core_version = "1.10.2", |
| // Save a reference to some core methods | |
| core_concat = core_deletedIds.concat, | |
| @@ | @@ -74,7 +75,7 @@ var |
| // A simple way to check for HTML strings | |
| // Prioritize #id over <tag> to avoid XSS via location.hash (#9521) | |
| // Strict HTML recognition (#11290: must start with <) | |
| - | rquickExpr = /^(?:(<[\w\W]+>)[^>]*|#([\w-]*))$/, |
| + | rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/, |
| // Match a standalone tag | |
| rsingleTag = /^<(\w+)\s*\/?>(?:<\/\1>|)$/, | |
| @@ | @@ -227,11 +228,6 @@ jQuery.fn = jQuery.prototype = { |
| // The default length of a jQuery object is 0 | |
| length: 0, | |
| - | // The number of elements contained in the matched element set |
| - | size: function() { |
| - | return this.length; |
| - | }, |
| - | |
| toArray: function() { | |
| return core_slice.call( this ); | |
| }, | |
| @@ | @@ -380,6 +376,10 @@ jQuery.extend = jQuery.fn.extend = function() { |
| }; | |
| jQuery.extend({ | |
| + | // Unique for each copy of jQuery on the page |
| + | // Non-digits removed to match rinlinejQuery |
| + | expando: "jQuery" + ( core_version + Math.random() ).replace( /\D/g, "" ), |
| + | |
| noConflict: function( deep ) { | |
| if ( window.$ === jQuery ) { | |
| window.$ = _$; | |
| @@ | @@ -450,6 +450,7 @@ jQuery.extend({ |
| }, | |
| isWindow: function( obj ) { | |
| + | /* jshint eqeqeq: false */ |
| return obj != null && obj == obj.window; | |
| }, | |
| @@ | @@ -467,6 +468,8 @@ jQuery.extend({ |
| }, | |
| isPlainObject: function( obj ) { | |
| + | var key; |
| + | |
| // Must be an Object. | |
| // Because of IE, we also have to check the presence of the constructor property. | |
| // Make sure that DOM nodes and window objects don't pass through, as well | |
| @@ | @@ -486,10 +489,16 @@ jQuery.extend({ |
| return false; | |
| } | |
| + | // Support: IE<9 |
| + | // Handle iteration over inherited properties before own properties. |
| + | if ( jQuery.support.ownLast ) { |
| + | for ( key in obj ) { |
| + | return core_hasOwn.call( obj, key ); |
| + | } |
| + | } |
| + | |
| // Own properties are enumerated firstly, so to speed up, | |
| // if last one is own, then all properties are own. | |
| - | |
| - | var key; |
| for ( key in obj ) {} | |
| return key === undefined || core_hasOwn.call( obj, key ); | |
| @@ | @@ -879,6 +888,29 @@ jQuery.extend({ |
| now: function() { | |
| return ( new Date() ).getTime(); | |
| + | }, |
| + | |
| + | // A method for quickly swapping in/out CSS properties to get correct calculations. |
| + | // Note: this method belongs to the css module but it's needed here for the support module. |
| + | // If support gets modularized, this method should be moved back to the css module. |
| + | swap: function( elem, options, callback, args ) { |
| + | var ret, name, |
| + | old = {}; |
| + | |
| + | // Remember the old values, and insert the new ones |
| + | for ( name in options ) { |
| + | old[ name ] = elem.style[ name ]; |
| + | elem.style[ name ] = options[ name ]; |
| + | } |
| + | |
| + | ret = callback.apply( elem, args || [] ); |
| + | |
| + | // Revert the old values |
| + | for ( name in options ) { |
| + | elem.style[ name ] = old[ name ]; |
| + | } |
| + | |
| + | return ret; |
| } | |
| }); | |
| @@ | @@ -967,4585 +999,4707 @@ function isArraylike( obj ) { |
| // All jQuery objects should point back to these | |
| rootjQuery = jQuery(document); | |
| - | // String to Object options format cache |
| - | var optionsCache = {}; |
| - | |
| - | // Convert String-formatted options into Object-formatted ones and store in cache |
| - | function createOptions( options ) { |
| - | var object = optionsCache[ options ] = {}; |
| - | jQuery.each( options.match( core_rnotwhite ) || [], function( _, flag ) { |
| - | object[ flag ] = true; |
| - | }); |
| - | return object; |
| - | } |
| - | |
| - | /* |
| - | * Create a callback list using the following parameters: |
| - | * |
| - | * options: an optional list of space-separated options that will change how |
| - | * the callback list behaves or a more traditional option object |
| - | * |
| - | * By default a callback list will act like an event callback list and can be |
| - | * "fired" multiple times. |
| - | * |
| - | * Possible options: |
| - | * |
| - | * once: will ensure the callback list can only be fired once (like a Deferred) |
| - | * |
| - | * memory: will keep track of previous values and will call any callback added |
| - | * after the list has been fired right away with the latest "memorized" |
| - | * values (like a Deferred) |
| - | * |
| - | * unique: will ensure a callback can only be added once (no duplicate in the list) |
| + | /*! |
| + | * Sizzle CSS Selector Engine v1.10.2 |
| + | * http://sizzlejs.com/ |
| * | |
| - | * stopOnFalse: interrupt callings when a callback returns false |
| + | * Copyright 2013 jQuery Foundation, Inc. and other contributors |
| + | * Released under the MIT license |
| + | * http://jquery.org/license |
| * | |
| + | * Date: 2013-07-03 |
| */ | |
| - | jQuery.Callbacks = function( options ) { |
| - | |
| - | // Convert options from String-formatted to Object-formatted if needed |
| - | // (we check in cache first) |
| - | options = typeof options === "string" ? |
| - | ( optionsCache[ options ] || createOptions( options ) ) : |
| - | jQuery.extend( {}, options ); |
| + | (function( window, undefined ) { |
| - | var // Flag to know if list is currently firing |
| - | firing, |
| - | // Last fire value (for non-forgettable lists) |
| - | memory, |
| - | // Flag to know if list was already fired |
| - | fired, |
| - | // End of the loop when firing |
| - | firingLength, |
| - | // Index of currently firing callback (modified by remove if needed) |
| - | firingIndex, |
| - | // First callback to fire (used internally by add and fireWith) |
| - | firingStart, |
| - | // Actual callback list |
| - | list = [], |
| - | // Stack of fire calls for repeatable lists |
| - | stack = !options.once && [], |
| - | // Fire callbacks |
| - | fire = function( data ) { |
| - | memory = options.memory && data; |
| - | fired = true; |
| - | firingIndex = firingStart || 0; |
| - | firingStart = 0; |
| - | firingLength = list.length; |
| - | firing = true; |
| - | for ( ; list && firingIndex < firingLength; firingIndex++ ) { |
| - | if ( list[ firingIndex ].apply( data[ 0 ], data[ 1 ] ) === false && options.stopOnFalse ) { |
| - | memory = false; // To prevent further calls using add |
| - | break; |
| - | } |
| - | } |
| - | firing = false; |
| - | if ( list ) { |
| - | if ( stack ) { |
| - | if ( stack.length ) { |
| - | fire( stack.shift() ); |
| - | } |
| - | } else if ( memory ) { |
| - | list = []; |
| - | } else { |
| - | self.disable(); |
| - | } |
| - | } |
| - | }, |
| - | // Actual Callbacks object |
| - | self = { |
| - | // Add a callback or a collection of callbacks to the list |
| - | add: function() { |
| - | if ( list ) { |
| - | // First, we save the current length |
| - | var start = list.length; |
| - | (function add( args ) { |
| - | jQuery.each( args, function( _, arg ) { |
| - | var type = jQuery.type( arg ); |
| - | if ( type === "function" ) { |
| - | if ( !options.unique || !self.has( arg ) ) { |
| - | list.push( arg ); |
| - | } |
| - | } else if ( arg && arg.length && type !== "string" ) { |
| - | // Inspect recursively |
| - | add( arg ); |
| - | } |
| - | }); |
| - | })( arguments ); |
| - | // Do we need to add the callbacks to the |
| - | // current firing batch? |
| - | if ( firing ) { |
| - | firingLength = list.length; |
| - | // With memory, if we're not firing then |
| - | // we should call right away |
| - | } else if ( memory ) { |
| - | firingStart = start; |
| - | fire( memory ); |
| - | } |
| - | } |
| - | return this; |
| - | }, |
| - | // Remove a callback from the list |
| - | remove: function() { |
| - | if ( list ) { |
| - | jQuery.each( arguments, function( _, arg ) { |
| - | var index; |
| - | while( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { |
| - | list.splice( index, 1 ); |
| - | // Handle firing indexes |
| - | if ( firing ) { |
| - | if ( index <= firingLength ) { |
| - | firingLength--; |
| - | } |
| - | if ( index <= firingIndex ) { |
| - | firingIndex--; |
| - | } |
| - | } |
| - | } |
| - | }); |
| - | } |
| - | return this; |
| - | }, |
| - | // Check if a given callback is in the list. |
| - | // If no argument is given, return whether or not list has callbacks attached. |
| - | has: function( fn ) { |
| - | return fn ? jQuery.inArray( fn, list ) > -1 : !!( list && list.length ); |
| - | }, |
| - | // Remove all callbacks from the list |
| - | empty: function() { |
| - | list = []; |
| - | return this; |
| - | }, |
| - | // Have the list do nothing anymore |
| - | disable: function() { |
| - | list = stack = memory = undefined; |
| - | return this; |
| - | }, |
| - | // Is it disabled? |
| - | disabled: function() { |
| - | return !list; |
| - | }, |
| - | // Lock the list in its current state |
| - | lock: function() { |
| - | stack = undefined; |
| - | if ( !memory ) { |
| - | self.disable(); |
| - | } |
| - | return this; |
| - | }, |
| - | // Is it locked? |
| - | locked: function() { |
| - | return !stack; |
| - | }, |
| - | // Call all callbacks with the given context and arguments |
| - | fireWith: function( context, args ) { |
| - | args = args || []; |
| - | args = [ context, args.slice ? args.slice() : args ]; |
| - | if ( list && ( !fired || stack ) ) { |
| - | if ( firing ) { |
| - | stack.push( args ); |
| - | } else { |
| - | fire( args ); |
| - | } |
| - | } |
| - | return this; |
| - | }, |
| - | // Call all the callbacks with the given arguments |
| - | fire: function() { |
| - | self.fireWith( this, arguments ); |
| - | return this; |
| - | }, |
| - | // To know if the callbacks have already been called at least once |
| - | fired: function() { |
| - | return !!fired; |
| - | } |
| - | }; |
| + | var i, |
| + | support, |
| + | cachedruns, |
| + | Expr, |
| + | getText, |
| + | isXML, |
| + | compile, |
| + | outermostContext, |
| + | sortInput, |
| - | return self; |
| - | }; |
| - | jQuery.extend({ |
| + | // Local document vars |
| + | setDocument, |
| + | document, |
| + | docElem, |
| + | documentIsHTML, |
| + | rbuggyQSA, |
| + | rbuggyMatches, |
| + | matches, |
| + | contains, |
| - | Deferred: function( func ) { |
| - | var tuples = [ |
| - | // action, add listener, listener list, final state |
| - | [ "resolve", "done", jQuery.Callbacks("once memory"), "resolved" ], |
| - | [ "reject", "fail", jQuery.Callbacks("once memory"), "rejected" ], |
| - | [ "notify", "progress", jQuery.Callbacks("memory") ] |
| - | ], |
| - | state = "pending", |
| - | promise = { |
| - | state: function() { |
| - | return state; |
| - | }, |
| - | always: function() { |
| - | deferred.done( arguments ).fail( arguments ); |
| - | return this; |
| - | }, |
| - | then: function( /* fnDone, fnFail, fnProgress */ ) { |
| - | var fns = arguments; |
| - | return jQuery.Deferred(function( newDefer ) { |
| - | jQuery.each( tuples, function( i, tuple ) { |
| - | var action = tuple[ 0 ], |
| - | fn = jQuery.isFunction( fns[ i ] ) && fns[ i ]; |
| - | // deferred[ done | fail | progress ] for forwarding actions to newDefer |
| - | deferred[ tuple[1] ](function() { |
| - | var returned = fn && fn.apply( this, arguments ); |
| - | if ( returned && jQuery.isFunction( returned.promise ) ) { |
| - | returned.promise() |
| - | .done( newDefer.resolve ) |
| - | .fail( newDefer.reject ) |
| - | .progress( newDefer.notify ); |
| - | } else { |
| - | newDefer[ action + "With" ]( this === promise ? newDefer.promise() : this, fn ? [ returned ] : arguments ); |
| - | } |
| - | }); |
| - | }); |
| - | fns = null; |
| - | }).promise(); |
| - | }, |
| - | // Get a promise for this deferred |
| - | // If obj is provided, the promise aspect is added to the object |
| - | promise: function( obj ) { |
| - | return obj != null ? jQuery.extend( obj, promise ) : promise; |
| - | } |
| - | }, |
| - | deferred = {}; |
| - | |
| - | // Keep pipe for back-compat |
| - | promise.pipe = promise.then; |
| + | // Instance-specific data |
| + | expando = "sizzle" + -(new Date()), |
| + | preferredDoc = window.document, |
| + | dirruns = 0, |
| + | done = 0, |
| + | classCache = createCache(), |
| + | tokenCache = createCache(), |
| + | compilerCache = createCache(), |
| + | hasDuplicate = false, |
| + | sortOrder = function( a, b ) { |
| + | if ( a === b ) { |
| + | hasDuplicate = true; |
| + | return 0; |
| + | } |
| + | return 0; |
| + | }, |
| - | // Add list-specific methods |
| - | jQuery.each( tuples, function( i, tuple ) { |
| - | var list = tuple[ 2 ], |
| - | stateString = tuple[ 3 ]; |
| + | // General-purpose constants |
| + | strundefined = typeof undefined, |
| + | MAX_NEGATIVE = 1 << 31, |
| - | // promise[ done | fail | progress ] = list.add |
| - | promise[ tuple[1] ] = list.add; |
| + | // Instance methods |
| + | hasOwn = ({}).hasOwnProperty, |
| + | arr = [], |
| + | pop = arr.pop, |
| + | push_native = arr.push, |
| + | push = arr.push, |
| + | slice = arr.slice, |
| + | // Use a stripped-down indexOf if we can't use a native one |
| + | indexOf = arr.indexOf || function( elem ) { |
| + | var i = 0, |
| + | len = this.length; |
| + | for ( ; i < len; i++ ) { |
| + | if ( this[i] === elem ) { |
| + | return i; |
| + | } |
| + | } |
| + | return -1; |
| + | }, |
| - | // Handle state |
| - | if ( stateString ) { |
| - | list.add(function() { |
| - | // state = [ resolved | rejected ] |
| - | state = stateString; |
| + | booleans = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped", |
| - | // [ reject_list | resolve_list ].disable; progress_list.lock |
| - | }, tuples[ i ^ 1 ][ 2 ].disable, tuples[ 2 ][ 2 ].lock ); |
| - | } |
| + | // Regular expressions |
| - | // deferred[ resolve | reject | notify ] |
| - | deferred[ tuple[0] ] = function() { |
| - | deferred[ tuple[0] + "With" ]( this === deferred ? promise : this, arguments ); |
| - | return this; |
| - | }; |
| - | deferred[ tuple[0] + "With" ] = list.fireWith; |
| - | }); |
| + | // Whitespace characters http://www.w3.org/TR/css3-selectors/#whitespace |
| + | whitespace = "[\\x20\\t\\r\\n\\f]", |
| + | // http://www.w3.org/TR/css3-syntax/#characters |
| + | characterEncoding = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+", |
| - | // Make the deferred a promise |
| - | promise.promise( deferred ); |
| + | // Loosely modeled on CSS identifier characters |
| + | // An unquoted value should be a CSS identifier http://www.w3.org/TR/css3-selectors/#attribute-selectors |
| + | // Proper syntax: http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier |
| + | identifier = characterEncoding.replace( "w", "w#" ), |
| - | // Call given func if any |
| - | if ( func ) { |
| - | func.call( deferred, deferred ); |
| - | } |
| + | // Acceptable operators http://www.w3.org/TR/selectors/#attribute-selectors |
| + | attributes = "\\[" + whitespace + "*(" + characterEncoding + ")" + whitespace + |
| + | "*(?:([*^$|!~]?=)" + whitespace + "*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|(" + identifier + ")|)|)" + whitespace + "*\\]", |
| - | // All done! |
| - | return deferred; |
| - | }, |
| + | // Prefer arguments quoted, |
| + | // then not containing pseudos/brackets, |
| + | // then attribute selectors/non-parenthetical expressions, |
| + | // then anything else |
| + | // These preferences are here to reduce the number of selectors |
| + | // needing tokenize in the PSEUDO preFilter |
| + | pseudos = ":(" + characterEncoding + ")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|" + attributes.replace( 3, 8 ) + ")*)|.*)\\)|)", |
| - | // Deferred helper |
| - | when: function( subordinate /* , ..., subordinateN */ ) { |
| - | var i = 0, |
| - | resolveValues = core_slice.call( arguments ), |
| - | length = resolveValues.length, |
| + | // Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter |
| + | rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + whitespace + "+$", "g" ), |
| - | // the count of uncompleted subordinates |
| - | remaining = length !== 1 || ( subordinate && jQuery.isFunction( subordinate.promise ) ) ? length : 0, |
| + | rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ), |
| + | rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + "*" ), |
| - | // the master Deferred. If resolveValues consist of only a single Deferred, just use that. |
| - | deferred = remaining === 1 ? subordinate : jQuery.Deferred(), |
| + | rsibling = new RegExp( whitespace + "*[+~]" ), |
| + | rattributeQuotes = new RegExp( "=" + whitespace + "*([^\\]'\"]*)" + whitespace + "*\\]", "g" ), |
| - | // Update function for both resolve and progress values |
| - | updateFunc = function( i, contexts, values ) { |
| - | return function( value ) { |
| - | contexts[ i ] = this; |
| - | values[ i ] = arguments.length > 1 ? core_slice.call( arguments ) : value; |
| - | if( values === progressValues ) { |
| - | deferred.notifyWith( contexts, values ); |
| - | } else if ( !( --remaining ) ) { |
| - | deferred.resolveWith( contexts, values ); |
| - | } |
| - | }; |
| - | }, |
| + | rpseudo = new RegExp( pseudos ), |
| + | ridentifier = new RegExp( "^" + identifier + "$" ), |
| - | progressValues, progressContexts, resolveContexts; |
| + | matchExpr = { |
| + | "ID": new RegExp( "^#(" + characterEncoding + ")" ), |
| + | "CLASS": new RegExp( "^\\.(" + characterEncoding + ")" ), |
| + | "TAG": new RegExp( "^(" + characterEncoding.replace( "w", "w*" ) + ")" ), |
| + | "ATTR": new RegExp( "^" + attributes ), |
| + | "PSEUDO": new RegExp( "^" + pseudos ), |
| + | "CHILD": new RegExp( "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + whitespace + |
| + | "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" + whitespace + |
| + | "*(\\d+)|))" + whitespace + "*\\)|)", "i" ), |
| + | "bool": new RegExp( "^(?:" + booleans + ")$", "i" ), |
| + | // For use in libraries implementing .is() |
| + | // We use this for POS matching in `select` |
| + | "needsContext": new RegExp( "^" + whitespace + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + |
| + | whitespace + "*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i" ) |
| + | }, |
| - | // add listeners to Deferred subordinates; treat others as resolved |
| - | if ( length > 1 ) { |
| - | progressValues = new Array( length ); |
| - | progressContexts = new Array( length ); |
| - | resolveContexts = new Array( length ); |
| - | for ( ; i < length; i++ ) { |
| - | if ( resolveValues[ i ] && jQuery.isFunction( resolveValues[ i ].promise ) ) { |
| - | resolveValues[ i ].promise() |
| - | .done( updateFunc( i, resolveContexts, resolveValues ) ) |
| - | .fail( deferred.reject ) |
| - | .progress( updateFunc( i, progressContexts, progressValues ) ); |
| - | } else { |
| - | --remaining; |
| - | } |
| - | } |
| - | } |
| + | rnative = /^[^{]+\{\s*\[native \w/, |
| - | // if we're not waiting on anything, resolve the master |
| - | if ( !remaining ) { |
| - | deferred.resolveWith( resolveContexts, resolveValues ); |
| - | } |
| + | // Easily-parseable/retrievable ID or TAG or CLASS selectors |
| + | rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, |
| - | return deferred.promise(); |
| - | } |
| - | }); |
| - | jQuery.support = (function() { |
| + | rinputs = /^(?:input|select|textarea|button)$/i, |
| + | rheader = /^h\d$/i, |
| - | var support, all, a, |
| - | input, select, fragment, |
| - | opt, eventName, isSupported, i, |
| - | div = document.createElement("div"); |
| + | rescape = /'|\\/g, |
| - | // Setup |
| - | div.setAttribute( "className", "t" ); |
| - | div.innerHTML = " <link/><table></table><a href='/a'>a</a><input type='checkbox'/>"; |
| + | // CSS escapes http://www.w3.org/TR/CSS21/syndata.html#escaped-characters |
| + | runescape = new RegExp( "\\\\([\\da-f]{1,6}" + whitespace + "?|(" + whitespace + ")|.)", "ig" ), |
| + | funescape = function( _, escaped, escapedWhitespace ) { |
| + | var high = "0x" + escaped - 0x10000; |
| + | // NaN means non-codepoint |
| + | // Support: Firefox |
| + | // Workaround erroneous numeric interpretation of +"0x" |
| + | return high !== high || escapedWhitespace ? |
| + | escaped : |
| + | // BMP codepoint |
| + | high < 0 ? |
| + | String.fromCharCode( high + 0x10000 ) : |
| + | // Supplemental Plane codepoint (surrogate pair) |
| + | String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 ); |
| + | }; |
| - | // Support tests won't run in some limited or non-browser environments |
| - | all = div.getElementsByTagName("*"); |
| - | a = div.getElementsByTagName("a")[ 0 ]; |
| - | if ( !all || !a || !all.length ) { |
| - | return {}; |
| - | } |
| + | // Optimize for push.apply( _, NodeList ) |
| + | try { |
| + | push.apply( |
| + | (arr = slice.call( preferredDoc.childNodes )), |
| + | preferredDoc.childNodes |
| + | ); |
| + | // Support: Android<4.0 |
| + | // Detect silently failing push.apply |
| + | arr[ preferredDoc.childNodes.length ].nodeType; |
| + | } catch ( e ) { |
| + | push = { apply: arr.length ? |
| - | // First batch of tests |
| - | select = document.createElement("select"); |
| - | opt = select.appendChild( document.createElement("option") ); |
| - | input = div.getElementsByTagName("input")[ 0 ]; |
| + | // Leverage slice if possible |
| + | function( target, els ) { |
| + | push_native.apply( target, slice.call(els) ); |
| + | } : |
| - | a.style.cssText = "top:1px;float:left;opacity:.5"; |
| - | support = { |
| - | // Test setAttribute on camelCase class. If it works, we need attrFixes when doing get/setAttribute (ie6/7) |
| - | getSetAttribute: div.className !== "t", |
| - | |
| - | // IE strips leading whitespace when .innerHTML is used |
| - | leadingWhitespace: div.firstChild.nodeType === 3, |
| - | |
| - | // Make sure that tbody elements aren't automatically inserted |
| - | // IE will insert them into empty tables |
| - | tbody: !div.getElementsByTagName("tbody").length, |
| - | |
| - | // Make sure that link elements get serialized correctly by innerHTML |
| - | // This requires a wrapper element in IE |
| - | htmlSerialize: !!div.getElementsByTagName("link").length, |
| - | |
| - | // Get the style information from getAttribute |
| - | // (IE uses .cssText instead) |
| - | style: /top/.test( a.getAttribute("style") ), |
| - | |
| - | // Make sure that URLs aren't manipulated |
| - | // (IE normalizes it by default) |
| - | hrefNormalized: a.getAttribute("href") === "/a", |
| - | |
| - | // Make sure that element opacity exists |
| - | // (IE uses filter instead) |
| - | // Use a regex to work around a WebKit issue. See #5145 |
| - | opacity: /^0.5/.test( a.style.opacity ), |
| - | |
| - | // Verify style float existence |
| - | // (IE uses styleFloat instead of cssFloat) |
| - | cssFloat: !!a.style.cssFloat, |
| - | |
| - | // Check the default checkbox/radio value ("" on WebKit; "on" elsewhere) |
| - | checkOn: !!input.value, |
| - | |
| - | // Make sure that a selected-by-default option has a working selected property. |
| - | // (WebKit defaults to false instead of true, IE too, if it's in an optgroup) |
| - | optSelected: opt.selected, |
| - | |
| - | // Tests for enctype support on a form (#6743) |
| - | enctype: !!document.createElement("form").enctype, |
| - | |
| - | // Makes sure cloning an html5 element does not cause problems |
| - | // Where outerHTML is undefined, this still works |
| - | html5Clone: document.createElement("nav").cloneNode( true ).outerHTML !== "<:nav></:nav>", |
| - | |
| - | // jQuery.support.boxModel DEPRECATED in 1.8 since we don't support Quirks Mode |
| - | boxModel: document.compatMode === "CSS1Compat", |
| - | |
| - | // Will be defined later |
| - | deleteExpando: true, |
| - | noCloneEvent: true, |
| - | inlineBlockNeedsLayout: false, |
| - | shrinkWrapBlocks: false, |
| - | reliableMarginRight: true, |
| - | boxSizingReliable: true, |
| - | pixelPosition: false |
| + | // Support: IE<9 |
| + | // Otherwise append directly |
| + | function( target, els ) { |
| + | var j = target.length, |
| + | i = 0; |
| + | // Can't trust NodeList.length |
| + | while ( (target[j++] = els[i++]) ) {} |
| + | target.length = j - 1; |
| + | } |
| }; | |
| + | } |
| - | // Make sure checked status is properly cloned |
| - | input.checked = true; |
| - | support.noCloneChecked = input.cloneNode( true ).checked; |
| - | |
| - | // Make sure that the options inside disabled selects aren't marked as disabled |
| - | // (WebKit marks them as disabled) |
| - | select.disabled = true; |
| - | support.optDisabled = !opt.disabled; |
| + | function Sizzle( selector, context, results, seed ) { |
| + | var match, elem, m, nodeType, |
| + | // QSA vars |
| + | i, groups, old, nid, newContext, newSelector; |
| - | // Support: IE<9 |
| - | try { |
| - | delete div.test; |
| - | } catch( e ) { |
| - | support.deleteExpando = false; |
| + | if ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) { |
| + | setDocument( context ); |
| } | |
| - | // Check if we can trust getAttribute("value") |
| - | input = document.createElement("input"); |
| - | input.setAttribute( "value", "" ); |
| - | support.input = input.getAttribute( "value" ) === ""; |
| + | context = context || document; |
| + | results = results || []; |
| - | // Check if an input maintains its value after becoming a radio |
| - | input.value = "t"; |
| - | input.setAttribute( "type", "radio" ); |
| - | support.radioValue = input.value === "t"; |
| + | if ( !selector || typeof selector !== "string" ) { |
| + | return results; |
| + | } |
| - | // #11217 - WebKit loses check when the name is after the checked attribute |
| - | input.setAttribute( "checked", "t" ); |
| - | input.setAttribute( "name", "t" ); |
| + | if ( (nodeType = context.nodeType) !== 1 && nodeType !== 9 ) { |
| + | return []; |
| + | } |
| - | fragment = document.createDocumentFragment(); |
| - | fragment.appendChild( input ); |
| + | if ( documentIsHTML && !seed ) { |
| - | // Check if a disconnected checkbox will retain its checked |
| - | // value of true after appended to the DOM (IE6/7) |
| - | support.appendChecked = input.checked; |
| - | |
| - | // WebKit doesn't clone checked state correctly in fragments |
| - | support.checkClone = fragment.cloneNode( true ).cloneNode( true ).lastChild.checked; |
| - | |
| - | // Support: IE<9 |
| - | // Opera does not clone events (and typeof div.attachEvent === undefined). |
| - | // IE9-10 clones events bound via attachEvent, but they don't trigger with .click() |
| - | if ( div.attachEvent ) { |
| - | div.attachEvent( "onclick", function() { |
| - | support.noCloneEvent = false; |
| - | }); |
| - | |
| - | div.cloneNode( true ).click(); |
| - | } |
| - | |
| - | // Support: IE<9 (lack submit/change bubble), Firefox 17+ (lack focusin event) |
| - | // Beware of CSP restrictions (https://developer.mozilla.org/en/Security/CSP), test/csp.php |
| - | for ( i in { submit: true, change: true, focusin: true }) { |
| - | div.setAttribute( eventName = "on" + i, "t" ); |
| - | |
| - | support[ i + "Bubbles" ] = eventName in window || div.attributes[ eventName ].expando === false; |
| - | } |
| - | |
| - | div.style.backgroundClip = "content-box"; |
| - | div.cloneNode( true ).style.backgroundClip = ""; |
| - | support.clearCloneStyle = div.style.backgroundClip === "content-box"; |
| + | // Shortcuts |
| + | if ( (match = rquickExpr.exec( selector )) ) { |
| + | // Speed-up: Sizzle("#ID") |
| + | if ( (m = match[1]) ) { |
| + | if ( nodeType === 9 ) { |
| + | elem = context.getElementById( m ); |
| + | // Check parentNode to catch when Blackberry 4.6 returns |
| + | // nodes that are no longer in the document #6963 |
| + | if ( elem && elem.parentNode ) { |
| + | // Handle the case where IE, Opera, and Webkit return items |
| + | // by name instead of ID |
| + | if ( elem.id === m ) { |
| + | results.push( elem ); |
| + | return results; |
| + | } |
| + | } else { |
| + | return results; |
| + | } |
| + | } else { |
| + | // Context is not a document |
| + | if ( context.ownerDocument && (elem = context.ownerDocument.getElementById( m )) && |
| + | contains( context, elem ) && elem.id === m ) { |
| + | results.push( elem ); |
| + | return results; |
| + | } |
| + | } |
| - | // Run tests that need a body at doc ready |
| - | jQuery(function() { |
| - | var container, marginDiv, tds, |
| - | divReset = "padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;", |
| - | body = document.getElementsByTagName("body")[0]; |
| + | // Speed-up: Sizzle("TAG") |
| + | } else if ( match[2] ) { |
| + | push.apply( results, context.getElementsByTagName( selector ) ); |
| + | return results; |
| - | if ( !body ) { |
| - | // Return for frameset docs that don't have a body |
| - | return; |
| + | // Speed-up: Sizzle(".CLASS") |
| + | } else if ( (m = match[3]) && support.getElementsByClassName && context.getElementsByClassName ) { |
| + | push.apply( results, context.getElementsByClassName( m ) ); |
| + | return results; |
| + | } |
| } | |
| - | container = document.createElement("div"); |
| - | container.style.cssText = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px"; |
| - | |
| - | body.appendChild( container ).appendChild( div ); |
| - | |
| - | // Support: IE8 |
| - | // Check if table cells still have offsetWidth/Height when they are set |
| - | // to display:none and there are still other visible table cells in a |
| - | // table row; if so, offsetWidth/Height are not reliable for use when |
| - | // determining if an element has been hidden directly using |
| - | // display:none (it is still safe to use offsets if a parent element is |
| - | // hidden; don safety goggles and see bug #4512 for more information). |
| - | div.innerHTML = "<table><tr><td></td><td>t</td></tr></table>"; |
| - | tds = div.getElementsByTagName("td"); |
| - | tds[ 0 ].style.cssText = "padding:0;margin:0;border:0;display:none"; |
| - | isSupported = ( tds[ 0 ].offsetHeight === 0 ); |
| - | |
| - | tds[ 0 ].style.display = ""; |
| - | tds[ 1 ].style.display = "none"; |
| - | |
| - | // Support: IE8 |
| - | // Check if empty table cells still have offsetWidth/Height |
| - | support.reliableHiddenOffsets = isSupported && ( tds[ 0 ].offsetHeight === 0 ); |
| - | |
| - | // Check box-sizing and margin behavior |
| - | div.innerHTML = ""; |
| - | div.style.cssText = "box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;"; |
| - | support.boxSizing = ( div.offsetWidth === 4 ); |
| - | support.doesNotIncludeMarginInBodyOffset = ( body.offsetTop !== 1 ); |
| - | |
| - | // Use window.getComputedStyle because jsdom on node.js will break without it. |
| - | if ( window.getComputedStyle ) { |
| - | support.pixelPosition = ( window.getComputedStyle( div, null ) || {} ).top !== "1%"; |
| - | support.boxSizingReliable = ( window.getComputedStyle( div, null ) || { width: "4px" } ).width === "4px"; |
| - | |
| - | // Check if div with explicit width and no margin-right incorrectly |
| - | // gets computed margin-right based on width of container. (#3333) |
| - | // Fails in WebKit before Feb 2011 nightlies |
| - | // WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right |
| - | marginDiv = div.appendChild( document.createElement("div") ); |
| - | marginDiv.style.cssText = div.style.cssText = divReset; |
| - | marginDiv.style.marginRight = marginDiv.style.width = "0"; |
| - | div.style.width = "1px"; |
| + | // QSA path |
| + | if ( support.qsa && (!rbuggyQSA || !rbuggyQSA.test( selector )) ) { |
| + | nid = old = expando; |
| + | newContext = context; |
| + | newSelector = nodeType === 9 && selector; |
| - | support.reliableMarginRight = |
| - | !parseFloat( ( window.getComputedStyle( marginDiv, null ) || {} ).marginRight ); |
| - | } |
| + | // qSA works strangely on Element-rooted queries |
| + | // We can work around this by specifying an extra ID on the root |
| + | // and working up from there (Thanks to Andrew Dupont for the technique) |
| + | // IE 8 doesn't work on object elements |
| + | if ( nodeType === 1 && context.nodeName.toLowerCase() !== "object" ) { |
| + | groups = tokenize( selector ); |
| - | if ( typeof div.style.zoom !== core_strundefined ) { |
| - | // Support: IE<8 |
| - | // Check if natively block-level elements act like inline-block |
| - | // elements when setting their display to 'inline' and giving |
| - | // them layout |
| - | div.innerHTML = ""; |
| - | div.style.cssText = divReset + "width:1px;padding:1px;display:inline;zoom:1"; |
| - | support.inlineBlockNeedsLayout = ( div.offsetWidth === 3 ); |
| + | if ( (old = context.getAttribute("id")) ) { |
| + | nid = old.replace( rescape, "\\$&" ); |
| + | } else { |
| + | context.setAttribute( "id", nid ); |
| + | } |
| + | nid = "[id='" + nid + "'] "; |
| - | // Support: IE6 |
| - | // Check if elements with layout shrink-wrap their children |
| - | div.style.display = "block"; |
| - | div.innerHTML = "<div></div>"; |
| - | div.firstChild.style.width = "5px"; |
| - | support.shrinkWrapBlocks = ( div.offsetWidth !== 3 ); |
| + | i = groups.length; |
| + | while ( i-- ) { |
| + | groups[i] = nid + toSelector( groups[i] ); |
| + | } |
| + | newContext = rsibling.test( selector ) && context.parentNode || context; |
| + | newSelector = groups.join(","); |
| + | } |
| - | if ( support.inlineBlockNeedsLayout ) { |
| - | // Prevent IE 6 from affecting layout for positioned elements #11048 |
| - | // Prevent IE from shrinking the body in IE 7 mode #12869 |
| - | // Support: IE<8 |
| - | body.style.zoom = 1; |
| + | if ( newSelector ) { |
| + | try { |
| + | push.apply( results, |
| + | newContext.querySelectorAll( newSelector ) |
| + | ); |
| + | return results; |
| + | } catch(qsaError) { |
| + | } finally { |
| + | if ( !old ) { |
| + | context.removeAttribute("id"); |
| + | } |
| + | } |
| } | |
| } | |
| + | } |
| - | body.removeChild( container ); |
| + | // All others |
| + | return select( selector.replace( rtrim, "$1" ), context, results, seed ); |
| + | } |
| - | // Null elements to avoid leaks in IE |
| - | container = div = tds = marginDiv = null; |
| - | }); |
| + | /** |
| + | * Create key-value caches of limited size |
| + | * @returns {Function(string, Object)} Returns the Object data after storing it on itself with |
| + | * property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength) |
| + | * deleting the oldest entry |
| + | */ |
| + | function createCache() { |
| + | var keys = []; |
| - | // Null elements to avoid leaks in IE |
| - | all = select = fragment = opt = a = input = null; |
| + | function cache( key, value ) { |
| + | // Use (key + " ") to avoid collision with native prototype properties (see Issue #157) |
| + | if ( keys.push( key += " " ) > Expr.cacheLength ) { |
| + | // Only keep the most recent entries |
| + | delete cache[ keys.shift() ]; |
| + | } |
| + | return (cache[ key ] = value); |
| + | } |
| + | return cache; |
| + | } |
| - | return support; |
| - | })(); |
| + | /** |
| + | * Mark a function for special use by Sizzle |
| + | * @param {Function} fn The function to mark |
| + | */ |
| + | function markFunction( fn ) { |
| + | fn[ expando ] = true; |
| + | return fn; |
| + | } |
| - | var rbrace = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/, |
| - | rmultiDash = /([A-Z])/g; |
| + | /** |
| + | * Support testing using an element |
| + | * @param {Function} fn Passed the created div and expects a boolean result |
| + | */ |
| + | function assert( fn ) { |
| + | var div = document.createElement("div"); |
| - | function internalData( elem, name, data, pvt /* Internal Use Only */ ){ |
| - | if ( !jQuery.acceptData( elem ) ) { |
| - | return; |
| + | try { |
| + | return !!fn( div ); |
| + | } catch (e) { |
| + | return false; |
| + | } finally { |
| + | // Remove from its parent by default |
| + | if ( div.parentNode ) { |
| + | div.parentNode.removeChild( div ); |
| + | } |
| + | // release memory in IE |
| + | div = null; |
| } | |
| + | } |
| - | var thisCache, ret, |
| - | internalKey = jQuery.expando, |
| - | getByName = typeof name === "string", |
| - | |
| - | // We have to handle DOM nodes and JS objects differently because IE6-7 |
| - | // can't GC object references properly across the DOM-JS boundary |
| - | isNode = elem.nodeType, |
| + | /** |
| + | * Adds the same handler for all of the specified attrs |
| + | * @param {String} attrs Pipe-separated list of attributes |
| + | * @param {Function} handler The method that will be applied |
| + | */ |
| + | function addHandle( attrs, handler ) { |
| + | var arr = attrs.split("|"), |
| + | i = attrs.length; |
| - | // Only DOM nodes need the global jQuery cache; JS object data is |
| - | // attached directly to the object so GC can occur automatically |
| - | cache = isNode ? jQuery.cache : elem, |
| + | while ( i-- ) { |
| + | Expr.attrHandle[ arr[i] ] = handler; |
| + | } |
| + | } |
| - | // Only defining an ID for JS objects if its cache already exists allows |
| - | // the code to shortcut on the same path as a DOM node with no cache |
| - | id = isNode ? elem[ internalKey ] : elem[ internalKey ] && internalKey; |
| + | /** |
| + | * Checks document order of two siblings |
| + | * @param {Element} a |
| + | * @param {Element} b |
| + | * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b |
| + | */ |
| + | function siblingCheck( a, b ) { |
| + | var cur = b && a, |
| + | diff = cur && a.nodeType === 1 && b.nodeType === 1 && |
| + | ( ~b.sourceIndex || MAX_NEGATIVE ) - |
| + | ( ~a.sourceIndex || MAX_NEGATIVE ); |
| - | // Avoid doing any more work than we need to when trying to get data on an |
| - | // object that has no data at all |
| - | if ( (!id || !cache[id] || (!pvt && !cache[id].data)) && getByName && data === undefined ) { |
| - | return; |
| + | // Use IE sourceIndex if available on both nodes |
| + | if ( diff ) { |
| + | return diff; |
| } | |
| - | if ( !id ) { |
| - | // Only DOM nodes need a new unique ID for each element since their data |
| - | // ends up in the global cache |
| - | if ( isNode ) { |
| - | elem[ internalKey ] = id = core_deletedIds.pop() || jQuery.guid++; |
| - | } else { |
| - | id = internalKey; |
| + | // Check if b follows a |
| + | if ( cur ) { |
| + | while ( (cur = cur.nextSibling) ) { |
| + | if ( cur === b ) { |
| + | return -1; |
| + | } |
| } | |
| } | |
| - | if ( !cache[ id ] ) { |
| - | cache[ id ] = {}; |
| + | return a ? 1 : -1; |
| + | } |
| - | // Avoids exposing jQuery metadata on plain JS objects when the object |
| - | // is serialized using JSON.stringify |
| - | if ( !isNode ) { |
| - | cache[ id ].toJSON = jQuery.noop; |
| - | } |
| - | } |
| - | |
| - | // An object can be passed to jQuery.data instead of a key/value pair; this gets |
| - | // shallow copied over onto the existing cache |
| - | if ( typeof name === "object" || typeof name === "function" ) { |
| - | if ( pvt ) { |
| - | cache[ id ] = jQuery.extend( cache[ id ], name ); |
| - | } else { |
| - | cache[ id ].data = jQuery.extend( cache[ id ].data, name ); |
| - | } |
| - | } |
| - | |
| - | thisCache = cache[ id ]; |
| + | /** |
| + | * Returns a function to use in pseudos for input types |
| + | * @param {String} type |
| + | */ |
| + | function createInputPseudo( type ) { |
| + | return function( elem ) { |
| + | var name = elem.nodeName.toLowerCase(); |
| + | return name === "input" && elem.type === type; |
| + | }; |
| + | } |
| - | // jQuery data() is stored in a separate object inside the object's internal data |
| - | // cache in order to avoid key collisions between internal data and user-defined |
| - | // data. |
| - | if ( !pvt ) { |
| - | if ( !thisCache.data ) { |
| - | thisCache.data = {}; |
| - | } |
| + | /** |
| + | * Returns a function to use in pseudos for buttons |
| + | * @param {String} type |
| + | */ |
| + | function createButtonPseudo( type ) { |
| + | return function( elem ) { |
| + | var name = elem.nodeName.toLowerCase(); |
| + | return (name === "input" || name === "button") && elem.type === type; |
| + | }; |
| + | } |
| - | thisCache = thisCache.data; |
| - | } |
| + | /** |
| + | * Returns a function to use in pseudos for positionals |
| + | * @param {Function} fn |
| + | */ |
| + | function createPositionalPseudo( fn ) { |
| + | return markFunction(function( argument ) { |
| + | argument = +argument; |
| + | return markFunction(function( seed, matches ) { |
| + | var j, |
| + | matchIndexes = fn( [], seed.length, argument ), |
| + | i = matchIndexes.length; |
| - | if ( data !== undefined ) { |
| - | thisCache[ jQuery.camelCase( name ) ] = data; |
| - | } |
| + | // Match elements found at the specified indexes |
| + | while ( i-- ) { |
| + | if ( seed[ (j = matchIndexes[i]) ] ) { |
| + | seed[j] = !(matches[j] = seed[j]); |
| + | } |
| + | } |
| + | }); |
| + | }); |
| + | } |
| - | // Check for both converted-to-camel and non-converted data property names |
| - | // If a data property was specified |
| - | if ( getByName ) { |
| + | /** |
| + | * Detect xml |
| + | * @param {Element|Object} elem An element or a document |
| + | */ |
| + | isXML = Sizzle.isXML = function( elem ) { |
| + | // documentElement is verified for cases where it doesn't yet exist |
| + | // (such as loading iframes in IE - #4833) |
| + | var documentElement = elem && (elem.ownerDocument || elem).documentElement; |
| + | return documentElement ? documentElement.nodeName !== "HTML" : false; |
| + | }; |
| - | // First Try to find as-is property data |
| - | ret = thisCache[ name ]; |
| + | // Expose support vars for convenience |
| + | support = Sizzle.support = {}; |
| - | // Test for null|undefined property data |
| - | if ( ret == null ) { |
| + | /** |
| + | * Sets document-related variables once based on the current document |
| + | * @param {Element|Object} [doc] An element or document object to use to set the document |
| + | * @returns {Object} Returns the current document |
| + | */ |
| + | setDocument = Sizzle.setDocument = function( node ) { |
| + | var doc = node ? node.ownerDocument || node : preferredDoc, |
| + | parent = doc.defaultView; |
| - | // Try to find the camelCased property |
| - | ret = thisCache[ jQuery.camelCase( name ) ]; |
| - | } |
| - | } else { |
| - | ret = thisCache; |
| + | // If no document and documentElement is available, return |
| + | if ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) { |
| + | return document; |
| } | |
| - | return ret; |
| - | } |
| + | // Set our document |
| + | document = doc; |
| + | docElem = doc.documentElement; |
| - | function internalRemoveData( elem, name, pvt ) { |
| - | if ( !jQuery.acceptData( elem ) ) { |
| - | return; |
| + | // Support tests |
| + | documentIsHTML = !isXML( doc ); |
| + | |
| + | // Support: IE>8 |
| + | // If iframe document is assigned to "document" variable and if iframe has been reloaded, |
| + | // IE will throw "permission denied" error when accessing "document" variable, see jQuery #13936 |
| + | // IE6-8 do not support the defaultView property so parent will be undefined |
| + | if ( parent && parent.attachEvent && parent !== parent.top ) { |
| + | parent.attachEvent( "onbeforeunload", function() { |
| + | setDocument(); |
| + | }); |
| } | |
| - | var i, l, thisCache, |
| - | isNode = elem.nodeType, |
| + | /* Attributes |
| + | ---------------------------------------------------------------------- */ |
| - | // See jQuery.data for more information |
| - | cache = isNode ? jQuery.cache : elem, |
| - | id = isNode ? elem[ jQuery.expando ] : jQuery.expando; |
| + | // Support: IE<8 |
| + | // Verify that getAttribute really returns attributes and not properties (excepting IE8 booleans) |
| + | support.attributes = assert(function( div ) { |
| + | div.className = "i"; |
| + | return !div.getAttribute("className"); |
| + | }); |
| - | // If there is already no cache entry for this object, there is no |
| - | // purpose in continuing |
| - | if ( !cache[ id ] ) { |
| - | return; |
| - | } |
| + | /* getElement(s)By* |
| + | ---------------------------------------------------------------------- */ |
| - | if ( name ) { |
| + | // Check if getElementsByTagName("*") returns only elements |
| + | support.getElementsByTagName = assert(function( div ) { |
| + | div.appendChild( doc.createComment("") ); |
| + | return !div.getElementsByTagName("*").length; |
| + | }); |
| - | thisCache = pvt ? cache[ id ] : cache[ id ].data; |
| + | // Check if getElementsByClassName can be trusted |
| + | support.getElementsByClassName = assert(function( div ) { |
| + | div.innerHTML = "<div class='a'></div><div class='a i'></div>"; |
| + | |
| + | // Support: Safari<4 |
| + | // Catch class over-caching |
| + | div.firstChild.className = "i"; |
| + | // Support: Opera<10 |
| + | // Catch gEBCN failure to find non-leading classes |
| + | return div.getElementsByClassName("i").length === 2; |
| + | }); |
| - | if ( thisCache ) { |
| + | // Support: IE<10 |
| + | // Check if getElementById returns elements by name |
| + | // The broken getElementById methods don't pick up programatically-set names, |
| + | // so use a roundabout getElementsByName test |
| + | support.getById = assert(function( div ) { |
| + | docElem.appendChild( div ).id = expando; |
| + | return !doc.getElementsByName || !doc.getElementsByName( expando ).length; |
| + | }); |
| - | // Support array or space separated string names for data keys |
| - | if ( !jQuery.isArray( name ) ) { |
| + | // ID find and filter |
| + | if ( support.getById ) { |
| + | Expr.find["ID"] = function( id, context ) { |
| + | if ( typeof context.getElementById !== strundefined && documentIsHTML ) { |
| + | var m = context.getElementById( id ); |
| + | // Check parentNode to catch when Blackberry 4.6 returns |
| + | // nodes that are no longer in the document #6963 |
| + | return m && m.parentNode ? [m] : []; |
| + | } |
| + | }; |
| + | Expr.filter["ID"] = function( id ) { |
| + | var attrId = id.replace( runescape, funescape ); |
| + | return function( elem ) { |
| + | return elem.getAttribute("id") === attrId; |
| + | }; |
| + | }; |
| + | } else { |
| + | // Support: IE6/7 |
| + | // getElementById is not reliable as a find shortcut |
| + | delete Expr.find["ID"]; |
| - | // try the string as a key before any manipulation |
| - | if ( name in thisCache ) { |
| - | name = [ name ]; |
| - | } else { |
| + | Expr.filter["ID"] = function( id ) { |
| + | var attrId = id.replace( runescape, funescape ); |
| + | return function( elem ) { |
| + | var node = typeof elem.getAttributeNode !== strundefined && elem.getAttributeNode("id"); |
| + | return node && node.value === attrId; |
| + | }; |
| + | }; |
| + | } |
| - | // split the camel cased version by spaces unless a key with the spaces exists |
| - | name = jQuery.camelCase( name ); |
| - | if ( name in thisCache ) { |
| - | name = [ name ]; |
| - | } else { |
| - | name = name.split(" "); |
| + | // Tag |
| + | Expr.find["TAG"] = support.getElementsByTagName ? |
| + | function( tag, context ) { |
| + | if ( typeof context.getElementsByTagName !== strundefined ) { |
| + | return context.getElementsByTagName( tag ); |
| + | } |
| + | } : |
| + | function( tag, context ) { |
| + | var elem, |
| + | tmp = [], |
| + | i = 0, |
| + | results = context.getElementsByTagName( tag ); |
| + | |
| + | // Filter out possible comments |
| + | if ( tag === "*" ) { |
| + | while ( (elem = results[i++]) ) { |
| + | if ( elem.nodeType === 1 ) { |
| + | tmp.push( elem ); |
| } | |
| } | |
| - | } else { |
| - | // If "name" is an array of keys... |
| - | // When data is initially created, via ("key", "val") signature, |
| - | // keys will be converted to camelCase. |
| - | // Since there is no way to tell _how_ a key was added, remove |
| - | // both plain key and camelCase key. #12786 |
| - | // This will only penalize the array argument path. |
| - | name = name.concat( jQuery.map( name, jQuery.camelCase ) ); |
| - | } |
| - | for ( i = 0, l = name.length; i < l; i++ ) { |
| - | delete thisCache[ name[i] ]; |
| + | return tmp; |
| } | |
| + | return results; |
| + | }; |
| - | // If there is no data left in the cache, we want to continue |
| - | // and let the cache object itself get destroyed |
| - | if ( !( pvt ? isEmptyDataObject : jQuery.isEmptyObject )( thisCache ) ) { |
| - | return; |
| - | } |
| + | // Class |
| + | Expr.find["CLASS"] = support.getElementsByClassName && function( className, context ) { |
| + | if ( typeof context.getElementsByClassName !== strundefined && documentIsHTML ) { |
| + | return context.getElementsByClassName( className ); |
| } | |
| - | } |
| + | }; |
| - | // See jQuery.data for more information |
| - | if ( !pvt ) { |
| - | delete cache[ id ].data; |
| + | /* QSA/matchesSelector |
| + | ---------------------------------------------------------------------- */ |
| - | // Don't destroy the parent cache unless the internal data object |
| - | // had been the only thing left in it |
| - | if ( !isEmptyDataObject( cache[ id ] ) ) { |
| - | return; |
| - | } |
| - | } |
| + | // QSA and matchesSelector support |
| - | // Destroy the cache |
| - | if ( isNode ) { |
| - | jQuery.cleanData( [ elem ], true ); |
| + | // matchesSelector(:active) reports false when true (IE9/Opera 11.5) |
| + | rbuggyMatches = []; |
| - | // Use delete when supported for expandos or `cache` is not a window per isWindow (#10080) |
| - | } else if ( jQuery.support.deleteExpando || cache != cache.window ) { |
| - | delete cache[ id ]; |
| + | // qSa(:focus) reports false when true (Chrome 21) |
| + | // We allow this because of a bug in IE8/9 that throws an error |
| + | // whenever `document.activeElement` is accessed on an iframe |
| + | // So, we allow :focus to pass through QSA all the time to avoid the IE error |
| + | // See http://bugs.jquery.com/ticket/13378 |
| + | rbuggyQSA = []; |
| - | // When all else fails, null |
| - | } else { |
| - | cache[ id ] = null; |
| - | } |
| - | } |
| + | if ( (support.qsa = rnative.test( doc.querySelectorAll )) ) { |
| + | // Build QSA regex |
| + | // Regex strategy adopted from Diego Perini |
| + | assert(function( div ) { |
| + | // Select is set to empty string on purpose |
| + | // This is to test IE's treatment of not explicitly |
| + | // setting a boolean content attribute, |
| + | // since its presence should be enough |
| + | // http://bugs.jquery.com/ticket/12359 |
| + | div.innerHTML = "<select><option selected=''></option></select>"; |
| - | jQuery.extend({ |
| - | cache: {}, |
| + | // Support: IE8 |
| + | // Boolean attributes and "value" are not treated correctly |
| + | if ( !div.querySelectorAll("[selected]").length ) { |
| + | rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" ); |
| + | } |
| - | // Unique for each copy of jQuery on the page |
| - | // Non-digits removed to match rinlinejQuery |
| - | expando: "jQuery" + ( core_version + Math.random() ).replace( /\D/g, "" ), |
| + | // Webkit/Opera - :checked should return selected option elements |
| + | // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked |
| + | // IE8 throws error here and will not see later tests |
| + | if ( !div.querySelectorAll(":checked").length ) { |
| + | rbuggyQSA.push(":checked"); |
| + | } |
| + | }); |
| - | // The following elements throw uncatchable exceptions if you |
| - | // attempt to add expando properties to them. |
| - | noData: { |
| - | "embed": true, |
| - | // Ban all objects except for Flash (which handle expandos) |
| - | "object": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000", |
| - | "applet": true |
| - | }, |
| + | assert(function( div ) { |
| - | hasData: function( elem ) { |
| - | elem = elem.nodeType ? jQuery.cache[ elem[jQuery.expando] ] : elem[ jQuery.expando ]; |
| - | return !!elem && !isEmptyDataObject( elem ); |
| - | }, |
| + | // Support: Opera 10-12/IE8 |
| + | // ^= $= *= and empty values |
| + | // Should not select anything |
| + | // Support: Windows 8 Native Apps |
| + | // The type attribute is restricted during .innerHTML assignment |
| + | var input = doc.createElement("input"); |
| + | input.setAttribute( "type", "hidden" ); |
| + | div.appendChild( input ).setAttribute( "t", "" ); |
| - | data: function( elem, name, data ) { |
| - | return internalData( elem, name, data ); |
| - | }, |
| - | |
| - | removeData: function( elem, name ) { |
| - | return internalRemoveData( elem, name ); |
| - | }, |
| + | if ( div.querySelectorAll("[t^='']").length ) { |
| + | rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" ); |
| + | } |
| - | // For internal use only. |
| - | _data: function( elem, name, data ) { |
| - | return internalData( elem, name, data, true ); |
| - | }, |
| + | // FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled) |
| + | // IE8 throws error here and will not see later tests |
| + | if ( !div.querySelectorAll(":enabled").length ) { |
| + | rbuggyQSA.push( ":enabled", ":disabled" ); |
| + | } |
| - | _removeData: function( elem, name ) { |
| - | return internalRemoveData( elem, name, true ); |
| - | }, |
| + | // Opera 10-11 does not throw on post-comma invalid pseudos |
| + | div.querySelectorAll("*,:x"); |
| + | rbuggyQSA.push(",.*:"); |
| + | }); |
| + | } |
| - | // A method for determining if a DOM node can handle the data expando |
| - | acceptData: function( elem ) { |
| - | // Do not set data on non-element because it will not be cleared (#8335). |
| - | if ( elem.nodeType && elem.nodeType !== 1 && elem.nodeType !== 9 ) { |
| - | return false; |
| - | } |
| + | if ( (support.matchesSelector = rnative.test( (matches = docElem.webkitMatchesSelector || |
| + | docElem.mozMatchesSelector || |
| + | docElem.oMatchesSelector || |
| + | docElem.msMatchesSelector) )) ) { |
| - | var noData = elem.nodeName && jQuery.noData[ elem.nodeName.toLowerCase() ]; |
| + | assert(function( div ) { |
| + | // Check to see if it's possible to do matchesSelector |
| + | // on a disconnected node (IE 9) |
| + | support.disconnectedMatch = matches.call( div, "div" ); |
| - | // nodes accept data unless otherwise specified; rejection can be conditional |
| - | return !noData || noData !== true && elem.getAttribute("classid") === noData; |
| + | // This should fail with an exception |
| + | // Gecko does not error, returns false instead |
| + | matches.call( div, "[s!='']:x" ); |
| + | rbuggyMatches.push( "!=", pseudos ); |
| + | }); |
| } | |
| - | }); |
| - | |
| - | jQuery.fn.extend({ |
| - | data: function( key, value ) { |
| - | var attrs, name, |
| - | elem = this[0], |
| - | i = 0, |
| - | data = null; |
| - | |
| - | // Gets all values |
| - | if ( key === undefined ) { |
| - | if ( this.length ) { |
| - | data = jQuery.data( elem ); |
| - | if ( elem.nodeType === 1 && !jQuery._data( elem, "parsedAttrs" ) ) { |
| - | attrs = elem.attributes; |
| - | for ( ; i < attrs.length; i++ ) { |
| - | name = attrs[i].name; |
| + | rbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join("|") ); |
| + | rbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join("|") ); |
| - | if ( !name.indexOf( "data-" ) ) { |
| - | name = jQuery.camelCase( name.slice(5) ); |
| + | /* Contains |
| + | ---------------------------------------------------------------------- */ |
| - | dataAttr( elem, name, data[ name ] ); |
| - | } |
| + | // Element contains another |
| + | // Purposefully does not implement inclusive descendent |
| + | // As in, an element does not contain itself |
| + | contains = rnative.test( docElem.contains ) || docElem.compareDocumentPosition ? |
| + | function( a, b ) { |
| + | var adown = a.nodeType === 9 ? a.documentElement : a, |
| + | bup = b && b.parentNode; |
| + | return a === bup || !!( bup && bup.nodeType === 1 && ( |
| + | adown.contains ? |
| + | adown.contains( bup ) : |
| + | a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16 |
| + | )); |
| + | } : |
| + | function( a, b ) { |
| + | if ( b ) { |
| + | while ( (b = b.parentNode) ) { |
| + | if ( b === a ) { |
| + | return true; |
| } | |
| - | jQuery._data( elem, "parsedAttrs", true ); |
| } | |
| } | |
| + | return false; |
| + | }; |
| - | return data; |
| - | } |
| + | /* Sorting |
| + | ---------------------------------------------------------------------- */ |
| - | // Sets multiple values |
| - | if ( typeof key === "object" ) { |
| - | return this.each(function() { |
| - | jQuery.data( this, key ); |
| - | }); |
| - | } |
| + | // Document order sorting |
| + | sortOrder = docElem.compareDocumentPosition ? |
| + | function( a, b ) { |
| - | return jQuery.access( this, function( value ) { |
| + | // Flag for duplicate removal |
| + | if ( a === b ) { |
| + | hasDuplicate = true; |
| + | return 0; |
| + | } |
| - | if ( value === undefined ) { |
| - | // Try to fetch any internally stored data first |
| - | return elem ? dataAttr( elem, key, jQuery.data( elem, key ) ) : null; |
| - | } |
| + | var compare = b.compareDocumentPosition && a.compareDocumentPosition && a.compareDocumentPosition( b ); |
| - | this.each(function() { |
| - | jQuery.data( this, key, value ); |
| - | }); |
| - | }, null, value, arguments.length > 1, null, true ); |
| - | }, |
| + | if ( compare ) { |
| + | // Disconnected nodes |
| + | if ( compare & 1 || |
| + | (!support.sortDetached && b.compareDocumentPosition( a ) === compare) ) { |
| - | removeData: function( key ) { |
| - | return this.each(function() { |
| - | jQuery.removeData( this, key ); |
| - | }); |
| - | } |
| - | }); |
| + | // Choose the first element that is related to our preferred document |
| + | if ( a === doc || contains(preferredDoc, a) ) { |
| + | return -1; |
| + | } |
| + | if ( b === doc || contains(preferredDoc, b) ) { |
| + | return 1; |
| + | } |
| - | function dataAttr( elem, key, data ) { |
| - | // If nothing was found internally, try to fetch any |
| - | // data from the HTML5 data-* attribute |
| - | if ( data === undefined && elem.nodeType === 1 ) { |
| + | // Maintain original order |
| + | return sortInput ? |
| + | ( indexOf.call( sortInput, a ) - indexOf.call( sortInput, b ) ) : |
| + | 0; |
| + | } |
| - | var name = "data-" + key.replace( rmultiDash, "-$1" ).toLowerCase(); |
| + | return compare & 4 ? -1 : 1; |
| + | } |
| - | data = elem.getAttribute( name ); |
| + | // Not directly comparable, sort on existence of method |
| + | return a.compareDocumentPosition ? -1 : 1; |
| + | } : |
| + | function( a, b ) { |
| + | var cur, |
| + | i = 0, |
| + | aup = a.parentNode, |
| + | bup = b.parentNode, |
| + | ap = [ a ], |
| + | bp = [ b ]; |
| - | if ( typeof data === "string" ) { |
| - | try { |
| - | data = data === "true" ? true : |
| - | data === "false" ? false : |
| - | data === "null" ? null : |
| - | // Only convert to a number if it doesn't change the string |
| - | +data + "" === data ? +data : |
| - | rbrace.test( data ) ? jQuery.parseJSON( data ) : |
| - | data; |
| - | } catch( e ) {} |
| + | // Exit early if the nodes are identical |
| + | if ( a === b ) { |
| + | hasDuplicate = true; |
| + | return 0; |
| - | // Make sure we set the data so it isn't changed later |
| - | jQuery.data( elem, key, data ); |
| + | // Parentless nodes are either documents or disconnected |
| + | } else if ( !aup || !bup ) { |
| + | return a === doc ? -1 : |
| + | b === doc ? 1 : |
| + | aup ? -1 : |
| + | bup ? 1 : |
| + | sortInput ? |
| + | ( indexOf.call( sortInput, a ) - indexOf.call( sortInput, b ) ) : |
| + | 0; |
| - | } else { |
| - | data = undefined; |
| + | // If the nodes are siblings, we can do a quick check |
| + | } else if ( aup === bup ) { |
| + | return siblingCheck( a, b ); |
| } | |
| - | } |
| - | return data; |
| - | } |
| - | |
| - | // checks a cache object for emptiness |
| - | function isEmptyDataObject( obj ) { |
| - | var name; |
| - | for ( name in obj ) { |
| - | |
| - | // if the public data object is empty, the private is still empty |
| - | if ( name === "data" && jQuery.isEmptyObject( obj[name] ) ) { |
| - | continue; |
| + | // Otherwise we need full lists of their ancestors for comparison |
| + | cur = a; |
| + | while ( (cur = cur.parentNode) ) { |
| + | ap.unshift( cur ); |
| } | |
| - | if ( name !== "toJSON" ) { |
| - | return false; |
| + | cur = b; |
| + | while ( (cur = cur.parentNode) ) { |
| + | bp.unshift( cur ); |
| } | |
| - | } |
| - | |
| - | return true; |
| - | } |
| - | jQuery.extend({ |
| - | queue: function( elem, type, data ) { |
| - | var queue; |
| - | |
| - | if ( elem ) { |
| - | type = ( type || "fx" ) + "queue"; |
| - | queue = jQuery._data( elem, type ); |
| - | // Speed up dequeue by getting out quickly if this is just a lookup |
| - | if ( data ) { |
| - | if ( !queue || jQuery.isArray(data) ) { |
| - | queue = jQuery._data( elem, type, jQuery.makeArray(data) ); |
| - | } else { |
| - | queue.push( data ); |
| - | } |
| - | } |
| - | return queue || []; |
| + | // Walk down the tree looking for a discrepancy |
| + | while ( ap[i] === bp[i] ) { |
| + | i++; |
| } | |
| - | }, |
| - | dequeue: function( elem, type ) { |
| - | type = type || "fx"; |
| + | return i ? |
| + | // Do a sibling check if the nodes have a common ancestor |
| + | siblingCheck( ap[i], bp[i] ) : |
| - | var queue = jQuery.queue( elem, type ), |
| - | startLength = queue.length, |
| - | fn = queue.shift(), |
| - | hooks = jQuery._queueHooks( elem, type ), |
| - | next = function() { |
| - | jQuery.dequeue( elem, type ); |
| - | }; |
| + | // Otherwise nodes in our document sort first |
| + | ap[i] === preferredDoc ? -1 : |
| + | bp[i] === preferredDoc ? 1 : |
| + | 0; |
| + | }; |
| - | // If the fx queue is dequeued, always remove the progress sentinel |
| - | if ( fn === "inprogress" ) { |
| - | fn = queue.shift(); |
| - | startLength--; |
| - | } |
| + | return doc; |
| + | }; |
| - | hooks.cur = fn; |
| - | if ( fn ) { |
| + | Sizzle.matches = function( expr, elements ) { |
| + | return Sizzle( expr, null, null, elements ); |
| + | }; |
| - | // Add a progress sentinel to prevent the fx queue from being |
| - | // automatically dequeued |
| - | if ( type === "fx" ) { |
| - | queue.unshift( "inprogress" ); |
| - | } |
| + | Sizzle.matchesSelector = function( elem, expr ) { |
| + | // Set document vars if needed |
| + | if ( ( elem.ownerDocument || elem ) !== document ) { |
| + | setDocument( elem ); |
| + | } |
| - | // clear up the last queue stop function |
| - | delete hooks.stop; |
| - | fn.call( elem, next, hooks ); |
| - | } |
| + | // Make sure that attribute selectors are quoted |
| + | expr = expr.replace( rattributeQuotes, "='$1']" ); |
| - | if ( !startLength && hooks ) { |
| - | hooks.empty.fire(); |
| - | } |
| - | }, |
| + | if ( support.matchesSelector && documentIsHTML && |
| + | ( !rbuggyMatches || !rbuggyMatches.test( expr ) ) && |
| + | ( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) { |
| - | // not intended for public consumption - generates a queueHooks object, or returns the current one |
| - | _queueHooks: function( elem, type ) { |
| - | var key = type + "queueHooks"; |
| - | return jQuery._data( elem, key ) || jQuery._data( elem, key, { |
| - | empty: jQuery.Callbacks("once memory").add(function() { |
| - | jQuery._removeData( elem, type + "queue" ); |
| - | jQuery._removeData( elem, key ); |
| - | }) |
| - | }); |
| + | try { |
| + | var ret = matches.call( elem, expr ); |
| + | |
| + | // IE 9's matchesSelector returns false on disconnected nodes |
| + | if ( ret || support.disconnectedMatch || |
| + | // As well, disconnected nodes are said to be in a document |
| + | // fragment in IE 9 |
| + | elem.document && elem.document.nodeType !== 11 ) { |
| + | return ret; |
| + | } |
| + | } catch(e) {} |
| } | |
| - | }); |
| - | jQuery.fn.extend({ |
| - | queue: function( type, data ) { |
| - | var setter = 2; |
| + | return Sizzle( expr, document, null, [elem] ).length > 0; |
| + | }; |
| - | if ( typeof type !== "string" ) { |
| - | data = type; |
| - | type = "fx"; |
| - | setter--; |
| - | } |
| + | Sizzle.contains = function( context, elem ) { |
| + | // Set document vars if needed |
| + | if ( ( context.ownerDocument || context ) !== document ) { |
| + | setDocument( context ); |
| + | } |
| + | return contains( context, elem ); |
| + | }; |
| - | if ( arguments.length < setter ) { |
| - | return jQuery.queue( this[0], type ); |
| - | } |
| + | Sizzle.attr = function( elem, name ) { |
| + | // Set document vars if needed |
| + | if ( ( elem.ownerDocument || elem ) !== document ) { |
| + | setDocument( elem ); |
| + | } |
| - | return data === undefined ? |
| - | this : |
| - | this.each(function() { |
| - | var queue = jQuery.queue( this, type, data ); |
| + | var fn = Expr.attrHandle[ name.toLowerCase() ], |
| + | // Don't get fooled by Object.prototype properties (jQuery #13807) |
| + | val = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ? |
| + | fn( elem, name, !documentIsHTML ) : |
| + | undefined; |
| - | // ensure a hooks for this queue |
| - | jQuery._queueHooks( this, type ); |
| + | return val === undefined ? |
| + | support.attributes || !documentIsHTML ? |
| + | elem.getAttribute( name ) : |
| + | (val = elem.getAttributeNode(name)) && val.specified ? |
| + | val.value : |
| + | null : |
| + | val; |
| + | }; |
| - | if ( type === "fx" && queue[0] !== "inprogress" ) { |
| - | jQuery.dequeue( this, type ); |
| - | } |
| - | }); |
| - | }, |
| - | dequeue: function( type ) { |
| - | return this.each(function() { |
| - | jQuery.dequeue( this, type ); |
| - | }); |
| - | }, |
| - | // Based off of the plugin by Clint Helfers, with permission. |
| - | // http://blindsignals.com/index.php/2009/07/jquery-delay/ |
| - | delay: function( time, type ) { |
| - | time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time; |
| - | type = type || "fx"; |
| + | Sizzle.error = function( msg ) { |
| + | throw new Error( "Syntax error, unrecognized expression: " + msg ); |
| + | }; |
| - | return this.queue( type, function( next, hooks ) { |
| - | var timeout = setTimeout( next, time ); |
| - | hooks.stop = function() { |
| - | clearTimeout( timeout ); |
| - | }; |
| - | }); |
| - | }, |
| - | clearQueue: function( type ) { |
| - | return this.queue( type || "fx", [] ); |
| - | }, |
| - | // Get a promise resolved when queues of a certain type |
| - | // are emptied (fx is the type by default) |
| - | promise: function( type, obj ) { |
| - | var tmp, |
| - | count = 1, |
| - | defer = jQuery.Deferred(), |
| - | elements = this, |
| - | i = this.length, |
| - | resolve = function() { |
| - | if ( !( --count ) ) { |
| - | defer.resolveWith( elements, [ elements ] ); |
| - | } |
| - | }; |
| + | /** |
| + | * Document sorting and removing duplicates |
| + | * @param {ArrayLike} results |
| + | */ |
| + | Sizzle.uniqueSort = function( results ) { |
| + | var elem, |
| + | duplicates = [], |
| + | j = 0, |
| + | i = 0; |
| - | if ( typeof type !== "string" ) { |
| - | obj = type; |
| - | type = undefined; |
| - | } |
| - | type = type || "fx"; |
| + | // Unless we *know* we can detect duplicates, assume their presence |
| + | hasDuplicate = !support.detectDuplicates; |
| + | sortInput = !support.sortStable && results.slice( 0 ); |
| + | results.sort( sortOrder ); |
| - | while( i-- ) { |
| - | tmp = jQuery._data( elements[ i ], type + "queueHooks" ); |
| - | if ( tmp && tmp.empty ) { |
| - | count++; |
| - | tmp.empty.add( resolve ); |
| + | if ( hasDuplicate ) { |
| + | while ( (elem = results[i++]) ) { |
| + | if ( elem === results[ i ] ) { |
| + | j = duplicates.push( i ); |
| } | |
| } | |
| - | resolve(); |
| - | return defer.promise( obj ); |
| + | while ( j-- ) { |
| + | results.splice( duplicates[ j ], 1 ); |
| + | } |
| } | |
| - | }); |
| - | var nodeHook, boolHook, |
| - | rclass = /[\t\r\n]/g, |
| - | rreturn = /\r/g, |
| - | rfocusable = /^(?:input|select|textarea|button|object)$/i, |
| - | rclickable = /^(?:a|area)$/i, |
| - | rboolean = /^(?:checked|selected|autofocus|autoplay|async|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped)$/i, |
| - | ruseDefault = /^(?:checked|selected)$/i, |
| - | getSetAttribute = jQuery.support.getSetAttribute, |
| - | getSetInput = jQuery.support.input; |
| - | jQuery.fn.extend({ |
| - | attr: function( name, value ) { |
| - | return jQuery.access( this, jQuery.attr, name, value, arguments.length > 1 ); |
| - | }, |
| + | return results; |
| + | }; |
| - | removeAttr: function( name ) { |
| - | return this.each(function() { |
| - | jQuery.removeAttr( this, name ); |
| - | }); |
| - | }, |
| + | /** |
| + | * Utility function for retrieving the text value of an array of DOM nodes |
| + | * @param {Array|Element} elem |
| + | */ |
| + | getText = Sizzle.getText = function( elem ) { |
| + | var node, |
| + | ret = "", |
| + | i = 0, |
| + | nodeType = elem.nodeType; |
| - | prop: function( name, value ) { |
| - | return jQuery.access( this, jQuery.prop, name, value, arguments.length > 1 ); |
| - | }, |
| + | if ( !nodeType ) { |
| + | // If no nodeType, this is expected to be an array |
| + | for ( ; (node = elem[i]); i++ ) { |
| + | // Do not traverse comment nodes |
| + | ret += getText( node ); |
| + | } |
| + | } else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) { |
| + | // Use textContent for elements |
| + | // innerText usage removed for consistency of new lines (see #11153) |
| + | if ( typeof elem.textContent === "string" ) { |
| + | return elem.textContent; |
| + | } else { |
| + | // Traverse its children |
| + | for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { |
| + | ret += getText( elem ); |
| + | } |
| + | } |
| + | } else if ( nodeType === 3 || nodeType === 4 ) { |
| + | return elem.nodeValue; |
| + | } |
| + | // Do not include comment or processing instruction nodes |
| - | removeProp: function( name ) { |
| - | name = jQuery.propFix[ name ] || name; |
| - | return this.each(function() { |
| - | // try/catch handles cases where IE balks (such as removing a property on window) |
| - | try { |
| - | this[ name ] = undefined; |
| - | delete this[ name ]; |
| - | } catch( e ) {} |
| - | }); |
| - | }, |
| + | return ret; |
| + | }; |
| - | addClass: function( value ) { |
| - | var classes, elem, cur, clazz, j, |
| - | i = 0, |
| - | len = this.length, |
| - | proceed = typeof value === "string" && value; |
| + | Expr = Sizzle.selectors = { |
| - | if ( jQuery.isFunction( value ) ) { |
| - | return this.each(function( j ) { |
| - | jQuery( this ).addClass( value.call( this, j, this.className ) ); |
| - | }); |
| - | } |
| + | // Can be adjusted by the user |
| + | cacheLength: 50, |
| - | if ( proceed ) { |
| - | // The disjunction here is for better compressibility (see removeClass) |
| - | classes = ( value || "" ).match( core_rnotwhite ) || []; |
| + | createPseudo: markFunction, |
| - | for ( ; i < len; i++ ) { |
| - | elem = this[ i ]; |
| - | cur = elem.nodeType === 1 && ( elem.className ? |
| - | ( " " + elem.className + " " ).replace( rclass, " " ) : |
| - | " " |
| - | ); |
| + | match: matchExpr, |
| - | if ( cur ) { |
| - | j = 0; |
| - | while ( (clazz = classes[j++]) ) { |
| - | if ( cur.indexOf( " " + clazz + " " ) < 0 ) { |
| - | cur += clazz + " "; |
| - | } |
| - | } |
| - | elem.className = jQuery.trim( cur ); |
| + | attrHandle: {}, |
| - | } |
| - | } |
| - | } |
| + | find: {}, |
| - | return this; |
| + | relative: { |
| + | ">": { dir: "parentNode", first: true }, |
| + | " ": { dir: "parentNode" }, |
| + | "+": { dir: "previousSibling", first: true }, |
| + | "~": { dir: "previousSibling" } |
| }, | |
| - | removeClass: function( value ) { |
| - | var classes, elem, cur, clazz, j, |
| - | i = 0, |
| - | len = this.length, |
| - | proceed = arguments.length === 0 || typeof value === "string" && value; |
| + | preFilter: { |
| + | "ATTR": function( match ) { |
| + | match[1] = match[1].replace( runescape, funescape ); |
| - | if ( jQuery.isFunction( value ) ) { |
| - | return this.each(function( j ) { |
| - | jQuery( this ).removeClass( value.call( this, j, this.className ) ); |
| - | }); |
| - | } |
| - | if ( proceed ) { |
| - | classes = ( value || "" ).match( core_rnotwhite ) || []; |
| + | // Move the given value to match[3] whether quoted or unquoted |
| + | match[3] = ( match[4] || match[5] || "" ).replace( runescape, funescape ); |
| - | for ( ; i < len; i++ ) { |
| - | elem = this[ i ]; |
| - | // This expression is here for better compressibility (see addClass) |
| - | cur = elem.nodeType === 1 && ( elem.className ? |
| - | ( " " + elem.className + " " ).replace( rclass, " " ) : |
| - | "" |
| - | ); |
| + | if ( match[2] === "~=" ) { |
| + | match[3] = " " + match[3] + " "; |
| + | } |
| - | if ( cur ) { |
| - | j = 0; |
| - | while ( (clazz = classes[j++]) ) { |
| - | // Remove *all* instances |
| - | while ( cur.indexOf( " " + clazz + " " ) >= 0 ) { |
| - | cur = cur.replace( " " + clazz + " ", " " ); |
| - | } |
| - | } |
| - | elem.className = value ? jQuery.trim( cur ) : ""; |
| - | } |
| - | } |
| - | } |
| - | |
| - | return this; |
| - | }, |
| - | |
| - | toggleClass: function( value, stateVal ) { |
| - | var type = typeof value, |
| - | isBool = typeof stateVal === "boolean"; |
| - | |
| - | if ( jQuery.isFunction( value ) ) { |
| - | return this.each(function( i ) { |
| - | jQuery( this ).toggleClass( value.call(this, i, this.className, stateVal), stateVal ); |
| - | }); |
| - | } |
| - | |
| - | return this.each(function() { |
| - | if ( type === "string" ) { |
| - | // toggle individual class names |
| - | var className, |
| - | i = 0, |
| - | self = jQuery( this ), |
| - | state = stateVal, |
| - | classNames = value.match( core_rnotwhite ) || []; |
| + | return match.slice( 0, 4 ); |
| + | }, |
| - | while ( (className = classNames[ i++ ]) ) { |
| - | // check each className given, space separated list |
| - | state = isBool ? state : !self.hasClass( className ); |
| - | self[ state ? "addClass" : "removeClass" ]( className ); |
| - | } |
| + | "CHILD": function( match ) { |
| + | /* matches from matchExpr["CHILD"] |
| + | 1 type (only|nth|...) |
| + | 2 what (child|of-type) |
| + | 3 argument (even|odd|\d*|\d*n([+-]\d+)?|...) |
| + | 4 xn-component of xn+y argument ([+-]?\d*n|) |
| + | 5 sign of xn-component |
| + | 6 x of xn-component |
| + | 7 sign of y-component |
| + | 8 y of y-component |
| + | */ |
| + | match[1] = match[1].toLowerCase(); |
| - | // Toggle whole class name |
| - | } else if ( type === core_strundefined || type === "boolean" ) { |
| - | if ( this.className ) { |
| - | // store className if set |
| - | jQuery._data( this, "__className__", this.className ); |
| + | if ( match[1].slice( 0, 3 ) === "nth" ) { |
| + | // nth-* requires argument |
| + | if ( !match[3] ) { |
| + | Sizzle.error( match[0] ); |
| } | |
| - | // If the element has a class name or if we're passed "false", |
| - | // then remove the whole classname (if there was one, the above saved it). |
| - | // Otherwise bring back whatever was previously saved (if anything), |
| - | // falling back to the empty string if nothing was stored. |
| - | this.className = this.className || value === false ? "" : jQuery._data( this, "__className__" ) || ""; |
| - | } |
| - | }); |
| - | }, |
| + | // numeric x and y parameters for Expr.filter.CHILD |
| + | // remember that false/true cast respectively to 0/1 |
| + | match[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === "even" || match[3] === "odd" ) ); |
| + | match[5] = +( ( match[7] + match[8] ) || match[3] === "odd" ); |
| - | hasClass: function( selector ) { |
| - | var className = " " + selector + " ", |
| - | i = 0, |
| - | l = this.length; |
| - | for ( ; i < l; i++ ) { |
| - | if ( this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) >= 0 ) { |
| - | return true; |
| + | // other types prohibit arguments |
| + | } else if ( match[3] ) { |
| + | Sizzle.error( match[0] ); |
| } | |
| - | } |
| - | return false; |
| - | }, |
| + | return match; |
| + | }, |
| - | val: function( value ) { |
| - | var ret, hooks, isFunction, |
| - | elem = this[0]; |
| + | "PSEUDO": function( match ) { |
| + | var excess, |
| + | unquoted = !match[5] && match[2]; |
| - | if ( !arguments.length ) { |
| - | if ( elem ) { |
| - | hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; |
| + | if ( matchExpr["CHILD"].test( match[0] ) ) { |
| + | return null; |
| + | } |
| - | if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { |
| - | return ret; |
| - | } |
| + | // Accept quoted arguments as-is |
| + | if ( match[3] && match[4] !== undefined ) { |
| + | match[2] = match[4]; |
| - | ret = elem.value; |
| + | // Strip excess characters from unquoted arguments |
| + | } else if ( unquoted && rpseudo.test( unquoted ) && |
| + | // Get excess from tokenize (recursively) |
| + | (excess = tokenize( unquoted, true )) && |
| + | // advance to the next closing parenthesis |
| + | (excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length) ) { |
| - | return typeof ret === "string" ? |
| - | // handle most common string cases |
| - | ret.replace(rreturn, "") : |
| - | // handle cases where value is null/undef or number |
| - | ret == null ? "" : ret; |
| + | // excess is a negative index |
| + | match[0] = match[0].slice( 0, excess ); |
| + | match[2] = unquoted.slice( 0, excess ); |
| } | |
| - | return; |
| + | // Return only captures needed by the pseudo filter method (type and argument) |
| + | return match.slice( 0, 3 ); |
| } | |
| + | }, |
| - | isFunction = jQuery.isFunction( value ); |
| - | |
| - | return this.each(function( i ) { |
| - | var val, |
| - | self = jQuery(this); |
| + | filter: { |
| - | if ( this.nodeType !== 1 ) { |
| - | return; |
| - | } |
| + | "TAG": function( nodeNameSelector ) { |
| + | var nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase(); |
| + | return nodeNameSelector === "*" ? |
| + | function() { return true; } : |
| + | function( elem ) { |
| + | return elem.nodeName && elem.nodeName.toLowerCase() === nodeName; |
| + | }; |
| + | }, |
| - | if ( isFunction ) { |
| - | val = value.call( this, i, self.val() ); |
| - | } else { |
| - | val = value; |
| - | } |
| + | "CLASS": function( className ) { |
| + | var pattern = classCache[ className + " " ]; |
| - | // Treat null/undefined as ""; convert numbers to string |
| - | if ( val == null ) { |
| - | val = ""; |
| - | } else if ( typeof val === "number" ) { |
| - | val += ""; |
| - | } else if ( jQuery.isArray( val ) ) { |
| - | val = jQuery.map(val, function ( value ) { |
| - | return value == null ? "" : value + ""; |
| + | return pattern || |
| + | (pattern = new RegExp( "(^|" + whitespace + ")" + className + "(" + whitespace + "|$)" )) && |
| + | classCache( className, function( elem ) { |
| + | return pattern.test( typeof elem.className === "string" && elem.className || typeof elem.getAttribute !== strundefined && elem.getAttribute("class") || "" ); |
| }); | |
| - | } |
| + | }, |
| - | hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; |
| + | "ATTR": function( name, operator, check ) { |
| + | return function( elem ) { |
| + | var result = Sizzle.attr( elem, name ); |
| - | // If set returns undefined, fall back to normal setting |
| - | if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { |
| - | this.value = val; |
| - | } |
| - | }); |
| - | } |
| - | }); |
| + | if ( result == null ) { |
| + | return operator === "!="; |
| + | } |
| + | if ( !operator ) { |
| + | return true; |
| + | } |
| - | jQuery.extend({ |
| - | valHooks: { |
| - | option: { |
| - | get: function( elem ) { |
| - | // attributes.value is undefined in Blackberry 4.7 but |
| - | // uses .value. See #6932 |
| - | var val = elem.attributes.value; |
| - | return !val || val.specified ? elem.value : elem.text; |
| - | } |
| + | result += ""; |
| + | |
| + | return operator === "=" ? result === check : |
| + | operator === "!=" ? result !== check : |
| + | operator === "^=" ? check && result.indexOf( check ) === 0 : |
| + | operator === "*=" ? check && result.indexOf( check ) > -1 : |
| + | operator === "$=" ? check && result.slice( -check.length ) === check : |
| + | operator === "~=" ? ( " " + result + " " ).indexOf( check ) > -1 : |
| + | operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" : |
| + | false; |
| + | }; |
| }, | |
| - | select: { |
| - | get: function( elem ) { |
| - | var value, option, |
| - | options = elem.options, |
| - | index = elem.selectedIndex, |
| - | one = elem.type === "select-one" || index < 0, |
| - | values = one ? null : [], |
| - | max = one ? index + 1 : options.length, |
| - | i = index < 0 ? |
| - | max : |
| - | one ? index : 0; |
| - | // Loop through all the selected options |
| - | for ( ; i < max; i++ ) { |
| - | option = options[ i ]; |
| + | "CHILD": function( type, what, argument, first, last ) { |
| + | var simple = type.slice( 0, 3 ) !== "nth", |
| + | forward = type.slice( -4 ) !== "last", |
| + | ofType = what === "of-type"; |
| - | // oldIE doesn't update selected after form reset (#2551) |
| - | if ( ( option.selected || i === index ) && |
| - | // Don't return options that are disabled or in a disabled optgroup |
| - | ( jQuery.support.optDisabled ? !option.disabled : option.getAttribute("disabled") === null ) && |
| - | ( !option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" ) ) ) { |
| + | return first === 1 && last === 0 ? |
| - | // Get the specific value for the option |
| - | value = jQuery( option ).val(); |
| + | // Shortcut for :nth-*(n) |
| + | function( elem ) { |
| + | return !!elem.parentNode; |
| + | } : |
| - | // We don't need an array for one selects |
| - | if ( one ) { |
| - | return value; |
| - | } |
| + | function( elem, context, xml ) { |
| + | var cache, outerCache, node, diff, nodeIndex, start, |
| + | dir = simple !== forward ? "nextSibling" : "previousSibling", |
| + | parent = elem.parentNode, |
| + | name = ofType && elem.nodeName.toLowerCase(), |
| + | useCache = !xml && !ofType; |
| - | // Multi-Selects return an array |
| - | values.push( value ); |
| - | } |
| - | } |
| + | if ( parent ) { |
| - | return values; |
| - | }, |
| + | // :(first|last|only)-(child|of-type) |
| + | if ( simple ) { |
| + | while ( dir ) { |
| + | node = elem; |
| + | while ( (node = node[ dir ]) ) { |
| + | if ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) { |
| + | return false; |
| + | } |
| + | } |
| + | // Reverse direction for :only-* (if we haven't yet done so) |
| + | start = dir = type === "only" && !start && "nextSibling"; |
| + | } |
| + | return true; |
| + | } |
| - | set: function( elem, value ) { |
| - | var values = jQuery.makeArray( value ); |
| + | start = [ forward ? parent.firstChild : parent.lastChild ]; |
| - | jQuery(elem).find("option").each(function() { |
| - | this.selected = jQuery.inArray( jQuery(this).val(), values ) >= 0; |
| - | }); |
| + | // non-xml :nth-child(...) stores cache data on `parent` |
| + | if ( forward && useCache ) { |
| + | // Seek `elem` from a previously-cached index |
| + | outerCache = parent[ expando ] || (parent[ expando ] = {}); |
| + | cache = outerCache[ type ] || []; |
| + | nodeIndex = cache[0] === dirruns && cache[1]; |
| + | diff = cache[0] === dirruns && cache[2]; |
| + | node = nodeIndex && parent.childNodes[ nodeIndex ]; |
| - | if ( !values.length ) { |
| - | elem.selectedIndex = -1; |
| - | } |
| - | return values; |
| - | } |
| - | } |
| - | }, |
| + | while ( (node = ++nodeIndex && node && node[ dir ] || |
| - | attr: function( elem, name, value ) { |
| - | var hooks, notxml, ret, |
| - | nType = elem.nodeType; |
| + | // Fallback to seeking `elem` from the start |
| + | (diff = nodeIndex = 0) || start.pop()) ) { |
| - | // don't get/set attributes on text, comment and attribute nodes |
| - | if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
| - | return; |
| - | } |
| + | // When found, cache indexes on `parent` and break |
| + | if ( node.nodeType === 1 && ++diff && node === elem ) { |
| + | outerCache[ type ] = [ dirruns, nodeIndex, diff ]; |
| + | break; |
| + | } |
| + | } |
| - | // Fallback to prop when attributes are not supported |
| - | if ( typeof elem.getAttribute === core_strundefined ) { |
| - | return jQuery.prop( elem, name, value ); |
| - | } |
| + | // Use previously-cached element index if available |
| + | } else if ( useCache && (cache = (elem[ expando ] || (elem[ expando ] = {}))[ type ]) && cache[0] === dirruns ) { |
| + | diff = cache[1]; |
| - | notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); |
| + | // xml :nth-child(...) or :nth-last-child(...) or :nth(-last)?-of-type(...) |
| + | } else { |
| + | // Use the same loop as above to seek `elem` from the start |
| + | while ( (node = ++nodeIndex && node && node[ dir ] || |
| + | (diff = nodeIndex = 0) || start.pop()) ) { |
| - | // All attributes are lowercase |
| - | // Grab necessary hook if one is defined |
| - | if ( notxml ) { |
| - | name = name.toLowerCase(); |
| - | hooks = jQuery.attrHooks[ name ] || ( rboolean.test( name ) ? boolHook : nodeHook ); |
| - | } |
| + | if ( ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) && ++diff ) { |
| + | // Cache the index of each encountered element |
| + | if ( useCache ) { |
| + | (node[ expando ] || (node[ expando ] = {}))[ type ] = [ dirruns, diff ]; |
| + | } |
| - | if ( value !== undefined ) { |
| + | if ( node === elem ) { |
| + | break; |
| + | } |
| + | } |
| + | } |
| + | } |
| - | if ( value === null ) { |
| - | jQuery.removeAttr( elem, name ); |
| + | // Incorporate the offset, then check against cycle size |
| + | diff -= last; |
| + | return diff === first || ( diff % first === 0 && diff / first >= 0 ); |
| + | } |
| + | }; |
| + | }, |
| - | } else if ( hooks && notxml && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { |
| - | return ret; |
| + | "PSEUDO": function( pseudo, argument ) { |
| + | // pseudo-class names are case-insensitive |
| + | // http://www.w3.org/TR/selectors/#pseudo-classes |
| + | // Prioritize by case sensitivity in case custom pseudos are added with uppercase letters |
| + | // Remember that setFilters inherits from pseudos |
| + | var args, |
| + | fn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] || |
| + | Sizzle.error( "unsupported pseudo: " + pseudo ); |
| - | } else { |
| - | elem.setAttribute( name, value + "" ); |
| - | return value; |
| + | // The user may use createPseudo to indicate that |
| + | // arguments are needed to create the filter function |
| + | // just as Sizzle does |
| + | if ( fn[ expando ] ) { |
| + | return fn( argument ); |
| } | |
| - | } else if ( hooks && notxml && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { |
| - | return ret; |
| - | |
| - | } else { |
| - | |
| - | // In IE9+, Flash objects don't have .getAttribute (#12945) |
| - | // Support: IE9+ |
| - | if ( typeof elem.getAttribute !== core_strundefined ) { |
| - | ret = elem.getAttribute( name ); |
| + | // But maintain support for old signatures |
| + | if ( fn.length > 1 ) { |
| + | args = [ pseudo, pseudo, "", argument ]; |
| + | return Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ? |
| + | markFunction(function( seed, matches ) { |
| + | var idx, |
| + | matched = fn( seed, argument ), |
| + | i = matched.length; |
| + | while ( i-- ) { |
| + | idx = indexOf.call( seed, matched[i] ); |
| + | seed[ idx ] = !( matches[ idx ] = matched[i] ); |
| + | } |
| + | }) : |
| + | function( elem ) { |
| + | return fn( elem, 0, args ); |
| + | }; |
| } | |
| - | // Non-existent attributes return null, we normalize to undefined |
| - | return ret == null ? |
| - | undefined : |
| - | ret; |
| + | return fn; |
| } | |
| }, | |
| - | removeAttr: function( elem, value ) { |
| - | var name, propName, |
| - | i = 0, |
| - | attrNames = value && value.match( core_rnotwhite ); |
| + | pseudos: { |
| + | // Potentially complex pseudos |
| + | "not": markFunction(function( selector ) { |
| + | // Trim the selector passed to compile |
| + | // to avoid treating leading and trailing |
| + | // spaces as combinators |
| + | var input = [], |
| + | results = [], |
| + | matcher = compile( selector.replace( rtrim, "$1" ) ); |
| - | if ( attrNames && elem.nodeType === 1 ) { |
| - | while ( (name = attrNames[i++]) ) { |
| - | propName = jQuery.propFix[ name ] || name; |
| + | return matcher[ expando ] ? |
| + | markFunction(function( seed, matches, context, xml ) { |
| + | var elem, |
| + | unmatched = matcher( seed, null, xml, [] ), |
| + | i = seed.length; |
| - | // Boolean attributes get special treatment (#10870) |
| - | if ( rboolean.test( name ) ) { |
| - | // Set corresponding property to false for boolean attributes |
| - | // Also clear defaultChecked/defaultSelected (if appropriate) for IE<8 |
| - | if ( !getSetAttribute && ruseDefault.test( name ) ) { |
| - | elem[ jQuery.camelCase( "default-" + name ) ] = |
| - | elem[ propName ] = false; |
| - | } else { |
| - | elem[ propName ] = false; |
| + | // Match elements unmatched by `matcher` |
| + | while ( i-- ) { |
| + | if ( (elem = unmatched[i]) ) { |
| + | seed[i] = !(matches[i] = elem); |
| + | } |
| } | |
| + | }) : |
| + | function( elem, context, xml ) { |
| + | input[0] = elem; |
| + | matcher( input, null, xml, results ); |
| + | return !results.pop(); |
| + | }; |
| + | }), |
| - | // See #9699 for explanation of this approach (setting first, then removal) |
| - | } else { |
| - | jQuery.attr( elem, name, "" ); |
| - | } |
| + | "has": markFunction(function( selector ) { |
| + | return function( elem ) { |
| + | return Sizzle( selector, elem ).length > 0; |
| + | }; |
| + | }), |
| - | elem.removeAttribute( getSetAttribute ? name : propName ); |
| + | "contains": markFunction(function( text ) { |
| + | return function( elem ) { |
| + | return ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1; |
| + | }; |
| + | }), |
| + | |
| + | // "Whether an element is represented by a :lang() selector |
| + | // is based solely on the element's language value |
| + | // being equal to the identifier C, |
| + | // or beginning with the identifier C immediately followed by "-". |
| + | // The matching of C against the element's language value is performed case-insensitively. |
| + | // The identifier C does not have to be a valid language name." |
| + | // http://www.w3.org/TR/selectors/#lang-pseudo |
| + | "lang": markFunction( function( lang ) { |
| + | // lang value must be a valid identifier |
| + | if ( !ridentifier.test(lang || "") ) { |
| + | Sizzle.error( "unsupported lang: " + lang ); |
| } | |
| - | } |
| - | }, |
| + | lang = lang.replace( runescape, funescape ).toLowerCase(); |
| + | return function( elem ) { |
| + | var elemLang; |
| + | do { |
| + | if ( (elemLang = documentIsHTML ? |
| + | elem.lang : |
| + | elem.getAttribute("xml:lang") || elem.getAttribute("lang")) ) { |
| - | attrHooks: { |
| - | type: { |
| - | set: function( elem, value ) { |
| - | if ( !jQuery.support.radioValue && value === "radio" && jQuery.nodeName(elem, "input") ) { |
| - | // Setting the type on a radio button after the value resets the value in IE6-9 |
| - | // Reset value to default in case type is set after value during creation |
| - | var val = elem.value; |
| - | elem.setAttribute( "type", value ); |
| - | if ( val ) { |
| - | elem.value = val; |
| + | elemLang = elemLang.toLowerCase(); |
| + | return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0; |
| } | |
| - | return value; |
| - | } |
| - | } |
| - | } |
| - | }, |
| + | } while ( (elem = elem.parentNode) && elem.nodeType === 1 ); |
| + | return false; |
| + | }; |
| + | }), |
| - | propFix: { |
| - | tabindex: "tabIndex", |
| - | readonly: "readOnly", |
| - | "for": "htmlFor", |
| - | "class": "className", |
| - | maxlength: "maxLength", |
| - | cellspacing: "cellSpacing", |
| - | cellpadding: "cellPadding", |
| - | rowspan: "rowSpan", |
| - | colspan: "colSpan", |
| - | usemap: "useMap", |
| - | frameborder: "frameBorder", |
| - | contenteditable: "contentEditable" |
| - | }, |
| + | // Miscellaneous |
| + | "target": function( elem ) { |
| + | var hash = window.location && window.location.hash; |
| + | return hash && hash.slice( 1 ) === elem.id; |
| + | }, |
| - | prop: function( elem, name, value ) { |
| - | var ret, hooks, notxml, |
| - | nType = elem.nodeType; |
| + | "root": function( elem ) { |
| + | return elem === docElem; |
| + | }, |
| - | // don't get/set properties on text, comment and attribute nodes |
| - | if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
| - | return; |
| - | } |
| + | "focus": function( elem ) { |
| + | return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex); |
| + | }, |
| - | notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); |
| + | // Boolean properties |
| + | "enabled": function( elem ) { |
| + | return elem.disabled === false; |
| + | }, |
| - | if ( notxml ) { |
| - | // Fix name and attach hooks |
| - | name = jQuery.propFix[ name ] || name; |
| - | hooks = jQuery.propHooks[ name ]; |
| - | } |
| + | "disabled": function( elem ) { |
| + | return elem.disabled === true; |
| + | }, |
| - | if ( value !== undefined ) { |
| - | if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { |
| - | return ret; |
| + | "checked": function( elem ) { |
| + | // In CSS3, :checked should return both checked and selected elements |
| + | // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked |
| + | var nodeName = elem.nodeName.toLowerCase(); |
| + | return (nodeName === "input" && !!elem.checked) || (nodeName === "option" && !!elem.selected); |
| + | }, |
| - | } else { |
| - | return ( elem[ name ] = value ); |
| + | "selected": function( elem ) { |
| + | // Accessing this property makes selected-by-default |
| + | // options in Safari work properly |
| + | if ( elem.parentNode ) { |
| + | elem.parentNode.selectedIndex; |
| } | |
| - | } else { |
| - | if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { |
| - | return ret; |
| + | return elem.selected === true; |
| + | }, |
| - | } else { |
| - | return elem[ name ]; |
| + | // Contents |
| + | "empty": function( elem ) { |
| + | // http://www.w3.org/TR/selectors/#empty-pseudo |
| + | // :empty is only affected by element nodes and content nodes(including text(3), cdata(4)), |
| + | // not comment, processing instructions, or others |
| + | // Thanks to Diego Perini for the nodeName shortcut |
| + | // Greater than "@" means alpha characters (specifically not starting with "#" or "?") |
| + | for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { |
| + | if ( elem.nodeName > "@" || elem.nodeType === 3 || elem.nodeType === 4 ) { |
| + | return false; |
| + | } |
| } | |
| - | } |
| - | }, |
| + | return true; |
| + | }, |
| - | propHooks: { |
| - | tabIndex: { |
| - | get: function( elem ) { |
| - | // elem.tabIndex doesn't always return the correct value when it hasn't been explicitly set |
| - | // http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ |
| - | var attributeNode = elem.getAttributeNode("tabindex"); |
| - | |
| - | return attributeNode && attributeNode.specified ? |
| - | parseInt( attributeNode.value, 10 ) : |
| - | rfocusable.test( elem.nodeName ) || rclickable.test( elem.nodeName ) && elem.href ? |
| - | 0 : |
| - | undefined; |
| - | } |
| - | } |
| - | } |
| - | }); |
| - | |
| - | // Hook for boolean attributes |
| - | boolHook = { |
| - | get: function( elem, name ) { |
| - | var |
| - | // Use .prop to determine if this attribute is understood as boolean |
| - | prop = jQuery.prop( elem, name ), |
| - | |
| - | // Fetch it accordingly |
| - | attr = typeof prop === "boolean" && elem.getAttribute( name ), |
| - | detail = typeof prop === "boolean" ? |
| - | |
| - | getSetInput && getSetAttribute ? |
| - | attr != null : |
| - | // oldIE fabricates an empty string for missing boolean attributes |
| - | // and conflates checked/selected into attroperties |
| - | ruseDefault.test( name ) ? |
| - | elem[ jQuery.camelCase( "default-" + name ) ] : |
| - | !!attr : |
| - | |
| - | // fetch an attribute node for properties not recognized as boolean |
| - | elem.getAttributeNode( name ); |
| - | |
| - | return detail && detail.value !== false ? |
| - | name.toLowerCase() : |
| - | undefined; |
| - | }, |
| - | set: function( elem, value, name ) { |
| - | if ( value === false ) { |
| - | // Remove boolean attributes when set to false |
| - | jQuery.removeAttr( elem, name ); |
| - | } else if ( getSetInput && getSetAttribute || !ruseDefault.test( name ) ) { |
| - | // IE<8 needs the *property* name |
| - | elem.setAttribute( !getSetAttribute && jQuery.propFix[ name ] || name, name ); |
| - | |
| - | // Use defaultChecked and defaultSelected for oldIE |
| - | } else { |
| - | elem[ jQuery.camelCase( "default-" + name ) ] = elem[ name ] = true; |
| - | } |
| - | |
| - | return name; |
| - | } |
| - | }; |
| - | |
| - | // fix oldIE value attroperty |
| - | if ( !getSetInput || !getSetAttribute ) { |
| - | jQuery.attrHooks.value = { |
| - | get: function( elem, name ) { |
| - | var ret = elem.getAttributeNode( name ); |
| - | return jQuery.nodeName( elem, "input" ) ? |
| + | "parent": function( elem ) { |
| + | return !Expr.pseudos["empty"]( elem ); |
| + | }, |
| - | // Ignore the value *property* by using defaultValue |
| - | elem.defaultValue : |
| + | // Element/input types |
| + | "header": function( elem ) { |
| + | return rheader.test( elem.nodeName ); |
| + | }, |
| - | ret && ret.specified ? ret.value : undefined; |
| + | "input": function( elem ) { |
| + | return rinputs.test( elem.nodeName ); |
| }, | |
| - | set: function( elem, value, name ) { |
| - | if ( jQuery.nodeName( elem, "input" ) ) { |
| - | // Does not return so that setAttribute is also used |
| - | elem.defaultValue = value; |
| - | } else { |
| - | // Use nodeHook if defined (#1954); otherwise setAttribute is fine |
| - | return nodeHook && nodeHook.set( elem, value, name ); |
| - | } |
| - | } |
| - | }; |
| - | } |
| - | // IE6/7 do not support getting/setting some attributes with get/setAttribute |
| - | if ( !getSetAttribute ) { |
| + | "button": function( elem ) { |
| + | var name = elem.nodeName.toLowerCase(); |
| + | return name === "input" && elem.type === "button" || name === "button"; |
| + | }, |
| - | // Use this for any attribute in IE6/7 |
| - | // This fixes almost every IE6/7 issue |
| - | nodeHook = jQuery.valHooks.button = { |
| - | get: function( elem, name ) { |
| - | var ret = elem.getAttributeNode( name ); |
| - | return ret && ( name === "id" || name === "name" || name === "coords" ? ret.value !== "" : ret.specified ) ? |
| - | ret.value : |
| - | undefined; |
| + | "text": function( elem ) { |
| + | var attr; |
| + | // IE6 and 7 will map elem.type to 'text' for new HTML5 types (search, etc) |
| + | // use getAttribute instead to test this case |
| + | return elem.nodeName.toLowerCase() === "input" && |
| + | elem.type === "text" && |
| + | ( (attr = elem.getAttribute("type")) == null || attr.toLowerCase() === elem.type ); |
| }, | |
| - | set: function( elem, value, name ) { |
| - | // Set the existing or create a new attribute node |
| - | var ret = elem.getAttributeNode( name ); |
| - | if ( !ret ) { |
| - | elem.setAttributeNode( |
| - | (ret = elem.ownerDocument.createAttribute( name )) |
| - | ); |
| - | } |
| - | ret.value = value += ""; |
| + | // Position-in-collection |
| + | "first": createPositionalPseudo(function() { |
| + | return [ 0 ]; |
| + | }), |
| - | // Break association with cloned elements by also using setAttribute (#9646) |
| - | return name === "value" || value === elem.getAttribute( name ) ? |
| - | value : |
| - | undefined; |
| - | } |
| - | }; |
| + | "last": createPositionalPseudo(function( matchIndexes, length ) { |
| + | return [ length - 1 ]; |
| + | }), |
| - | // Set contenteditable to false on removals(#10429) |
| - | // Setting to empty string throws an error as an invalid value |
| - | jQuery.attrHooks.contenteditable = { |
| - | get: nodeHook.get, |
| - | set: function( elem, value, name ) { |
| - | nodeHook.set( elem, value === "" ? false : value, name ); |
| - | } |
| - | }; |
| + | "eq": createPositionalPseudo(function( matchIndexes, length, argument ) { |
| + | return [ argument < 0 ? argument + length : argument ]; |
| + | }), |
| - | // Set width and height to auto instead of 0 on empty string( Bug #8150 ) |
| - | // This is for removals |
| - | jQuery.each([ "width", "height" ], function( i, name ) { |
| - | jQuery.attrHooks[ name ] = jQuery.extend( jQuery.attrHooks[ name ], { |
| - | set: function( elem, value ) { |
| - | if ( value === "" ) { |
| - | elem.setAttribute( name, "auto" ); |
| - | return value; |
| - | } |
| + | "even": createPositionalPseudo(function( matchIndexes, length ) { |
| + | var i = 0; |
| + | for ( ; i < length; i += 2 ) { |
| + | matchIndexes.push( i ); |
| } | |
| - | }); |
| - | }); |
| - | } |
| + | return matchIndexes; |
| + | }), |
| + | "odd": createPositionalPseudo(function( matchIndexes, length ) { |
| + | var i = 1; |
| + | for ( ; i < length; i += 2 ) { |
| + | matchIndexes.push( i ); |
| + | } |
| + | return matchIndexes; |
| + | }), |
| - | // Some attributes require a special call on IE |
| - | // http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx |
| - | if ( !jQuery.support.hrefNormalized ) { |
| - | jQuery.each([ "href", "src", "width", "height" ], function( i, name ) { |
| - | jQuery.attrHooks[ name ] = jQuery.extend( jQuery.attrHooks[ name ], { |
| - | get: function( elem ) { |
| - | var ret = elem.getAttribute( name, 2 ); |
| - | return ret == null ? undefined : ret; |
| + | "lt": createPositionalPseudo(function( matchIndexes, length, argument ) { |
| + | var i = argument < 0 ? argument + length : argument; |
| + | for ( ; --i >= 0; ) { |
| + | matchIndexes.push( i ); |
| } | |
| - | }); |
| - | }); |
| + | return matchIndexes; |
| + | }), |
| - | // href/src property should get the full normalized URL (#10299/#12915) |
| - | jQuery.each([ "href", "src" ], function( i, name ) { |
| - | jQuery.propHooks[ name ] = { |
| - | get: function( elem ) { |
| - | return elem.getAttribute( name, 4 ); |
| + | "gt": createPositionalPseudo(function( matchIndexes, length, argument ) { |
| + | var i = argument < 0 ? argument + length : argument; |
| + | for ( ; ++i < length; ) { |
| + | matchIndexes.push( i ); |
| } | |
| - | }; |
| - | }); |
| - | } |
| + | return matchIndexes; |
| + | }) |
| + | } |
| + | }; |
| - | if ( !jQuery.support.style ) { |
| - | jQuery.attrHooks.style = { |
| - | get: function( elem ) { |
| - | // Return undefined in the case of empty string |
| - | // Note: IE uppercases css property names, but if we were to .toLowerCase() |
| - | // .cssText, that would destroy case senstitivity in URL's, like in "background" |
| - | return elem.style.cssText || undefined; |
| - | }, |
| - | set: function( elem, value ) { |
| - | return ( elem.style.cssText = value + "" ); |
| - | } |
| - | }; |
| + | Expr.pseudos["nth"] = Expr.pseudos["eq"]; |
| + | |
| + | // Add button/input type pseudos |
| + | for ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) { |
| + | Expr.pseudos[ i ] = createInputPseudo( i ); |
| + | } |
| + | for ( i in { submit: true, reset: true } ) { |
| + | Expr.pseudos[ i ] = createButtonPseudo( i ); |
| } | |
| - | // Safari mis-reports the default selected property of an option |
| - | // Accessing the parent's selectedIndex property fixes it |
| - | if ( !jQuery.support.optSelected ) { |
| - | jQuery.propHooks.selected = jQuery.extend( jQuery.propHooks.selected, { |
| - | get: function( elem ) { |
| - | var parent = elem.parentNode; |
| + | // Easy API for creating new setFilters |
| + | function setFilters() {} |
| + | setFilters.prototype = Expr.filters = Expr.pseudos; |
| + | Expr.setFilters = new setFilters(); |
| - | if ( parent ) { |
| - | parent.selectedIndex; |
| + | function tokenize( selector, parseOnly ) { |
| + | var matched, match, tokens, type, |
| + | soFar, groups, preFilters, |
| + | cached = tokenCache[ selector + " " ]; |
| - | // Make sure that it also works with optgroups, see #5701 |
| - | if ( parent.parentNode ) { |
| - | parent.parentNode.selectedIndex; |
| - | } |
| - | } |
| - | return null; |
| - | } |
| - | }); |
| - | } |
| + | if ( cached ) { |
| + | return parseOnly ? 0 : cached.slice( 0 ); |
| + | } |
| - | // IE6/7 call enctype encoding |
| - | if ( !jQuery.support.enctype ) { |
| - | jQuery.propFix.enctype = "encoding"; |
| - | } |
| + | soFar = selector; |
| + | groups = []; |
| + | preFilters = Expr.preFilter; |
| - | // Radios and checkboxes getter/setter |
| - | if ( !jQuery.support.checkOn ) { |
| - | jQuery.each([ "radio", "checkbox" ], function() { |
| - | jQuery.valHooks[ this ] = { |
| - | get: function( elem ) { |
| - | // Handle the case where in Webkit "" is returned instead of "on" if a value isn't specified |
| - | return elem.getAttribute("value") === null ? "on" : elem.value; |
| - | } |
| - | }; |
| - | }); |
| - | } |
| - | jQuery.each([ "radio", "checkbox" ], function() { |
| - | jQuery.valHooks[ this ] = jQuery.extend( jQuery.valHooks[ this ], { |
| - | set: function( elem, value ) { |
| - | if ( jQuery.isArray( value ) ) { |
| - | return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) >= 0 ); |
| + | while ( soFar ) { |
| + | |
| + | // Comma and first run |
| + | if ( !matched || (match = rcomma.exec( soFar )) ) { |
| + | if ( match ) { |
| + | // Don't consume trailing commas as valid |
| + | soFar = soFar.slice( match[0].length ) || soFar; |
| } | |
| + | groups.push( tokens = [] ); |
| } | |
| - | }); |
| - | }); |
| - | var rformElems = /^(?:input|select|textarea)$/i, |
| - | rkeyEvent = /^key/, |
| - | rmouseEvent = /^(?:mouse|contextmenu)|click/, |
| - | rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, |
| - | rtypenamespace = /^([^.]*)(?:\.(.+)|)$/; |
| - | function returnTrue() { |
| - | return true; |
| - | } |
| + | matched = false; |
| - | function returnFalse() { |
| - | return false; |
| - | } |
| + | // Combinators |
| + | if ( (match = rcombinators.exec( soFar )) ) { |
| + | matched = match.shift(); |
| + | tokens.push({ |
| + | value: matched, |
| + | // Cast descendant combinators to space |
| + | type: match[0].replace( rtrim, " " ) |
| + | }); |
| + | soFar = soFar.slice( matched.length ); |
| + | } |
| - | /* |
| - | * Helper functions for managing events -- not part of the public interface. |
| - | * Props to Dean Edwards' addEvent library for many of the ideas. |
| - | */ |
| - | jQuery.event = { |
| - | |
| - | global: {}, |
| - | |
| - | add: function( elem, types, handler, data, selector ) { |
| - | var tmp, events, t, handleObjIn, |
| - | special, eventHandle, handleObj, |
| - | handlers, type, namespaces, origType, |
| - | elemData = jQuery._data( elem ); |
| - | |
| - | // Don't attach events to noData or text/comment nodes (but allow plain objects) |
| - | if ( !elemData ) { |
| - | return; |
| - | } |
| - | |
| - | // Caller can pass in an object of custom data in lieu of the handler |
| - | if ( handler.handler ) { |
| - | handleObjIn = handler; |
| - | handler = handleObjIn.handler; |
| - | selector = handleObjIn.selector; |
| - | } |
| - | |
| - | // Make sure that the handler has a unique ID, used to find/remove it later |
| - | if ( !handler.guid ) { |
| - | handler.guid = jQuery.guid++; |
| + | // Filters |
| + | for ( type in Expr.filter ) { |
| + | if ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] || |
| + | (match = preFilters[ type ]( match ))) ) { |
| + | matched = match.shift(); |
| + | tokens.push({ |
| + | value: matched, |
| + | type: type, |
| + | matches: match |
| + | }); |
| + | soFar = soFar.slice( matched.length ); |
| + | } |
| } | |
| - | // Init the element's event structure and main handler, if this is the first |
| - | if ( !(events = elemData.events) ) { |
| - | events = elemData.events = {}; |
| - | } |
| - | if ( !(eventHandle = elemData.handle) ) { |
| - | eventHandle = elemData.handle = function( e ) { |
| - | // Discard the second event of a jQuery.event.trigger() and |
| - | // when an event is called after a page has unloaded |
| - | return typeof jQuery !== core_strundefined && (!e || jQuery.event.triggered !== e.type) ? |
| - | jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : |
| - | undefined; |
| - | }; |
| - | // Add elem as a property of the handle fn to prevent a memory leak with IE non-native events |
| - | eventHandle.elem = elem; |
| + | if ( !matched ) { |
| + | break; |
| } | |
| + | } |
| - | // Handle multiple events separated by a space |
| - | // jQuery(...).bind("mouseover mouseout", fn); |
| - | types = ( types || "" ).match( core_rnotwhite ) || [""]; |
| - | t = types.length; |
| - | while ( t-- ) { |
| - | tmp = rtypenamespace.exec( types[t] ) || []; |
| - | type = origType = tmp[1]; |
| - | namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
| - | |
| - | // If event changes its type, use the special event handlers for the changed type |
| - | special = jQuery.event.special[ type ] || {}; |
| - | |
| - | // If selector defined, determine special event api type, otherwise given type |
| - | type = ( selector ? special.delegateType : special.bindType ) || type; |
| + | // Return the length of the invalid excess |
| + | // if we're just parsing |
| + | // Otherwise, throw an error or return tokens |
| + | return parseOnly ? |
| + | soFar.length : |
| + | soFar ? |
| + | Sizzle.error( selector ) : |
| + | // Cache the tokens |
| + | tokenCache( selector, groups ).slice( 0 ); |
| + | } |
| - | // Update special based on newly reset type |
| - | special = jQuery.event.special[ type ] || {}; |
| + | function toSelector( tokens ) { |
| + | var i = 0, |
| + | len = tokens.length, |
| + | selector = ""; |
| + | for ( ; i < len; i++ ) { |
| + | selector += tokens[i].value; |
| + | } |
| + | return selector; |
| + | } |
| - | // handleObj is passed to all event handlers |
| - | handleObj = jQuery.extend({ |
| - | type: type, |
| - | origType: origType, |
| - | data: data, |
| - | handler: handler, |
| - | guid: handler.guid, |
| - | selector: selector, |
| - | needsContext: selector && jQuery.expr.match.needsContext.test( selector ), |
| - | namespace: namespaces.join(".") |
| - | }, handleObjIn ); |
| + | function addCombinator( matcher, combinator, base ) { |
| + | var dir = combinator.dir, |
| + | checkNonElements = base && dir === "parentNode", |
| + | doneName = done++; |
| - | // Init the event handler queue if we're the first |
| - | if ( !(handlers = events[ type ]) ) { |
| - | handlers = events[ type ] = []; |
| - | handlers.delegateCount = 0; |
| + | return combinator.first ? |
| + | // Check against closest ancestor/preceding element |
| + | function( elem, context, xml ) { |
| + | while ( (elem = elem[ dir ]) ) { |
| + | if ( elem.nodeType === 1 || checkNonElements ) { |
| + | return matcher( elem, context, xml ); |
| + | } |
| + | } |
| + | } : |
| - | // Only use addEventListener/attachEvent if the special events handler returns false |
| - | if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { |
| - | // Bind the global event handler to the element |
| - | if ( elem.addEventListener ) { |
| - | elem.addEventListener( type, eventHandle, false ); |
| + | // Check against all ancestor/preceding elements |
| + | function( elem, context, xml ) { |
| + | var data, cache, outerCache, |
| + | dirkey = dirruns + " " + doneName; |
| - | } else if ( elem.attachEvent ) { |
| - | elem.attachEvent( "on" + type, eventHandle ); |
| + | // We can't set arbitrary data on XML nodes, so they don't benefit from dir caching |
| + | if ( xml ) { |
| + | while ( (elem = elem[ dir ]) ) { |
| + | if ( elem.nodeType === 1 || checkNonElements ) { |
| + | if ( matcher( elem, context, xml ) ) { |
| + | return true; |
| + | } |
| + | } |
| + | } |
| + | } else { |
| + | while ( (elem = elem[ dir ]) ) { |
| + | if ( elem.nodeType === 1 || checkNonElements ) { |
| + | outerCache = elem[ expando ] || (elem[ expando ] = {}); |
| + | if ( (cache = outerCache[ dir ]) && cache[0] === dirkey ) { |
| + | if ( (data = cache[1]) === true || data === cachedruns ) { |
| + | return data === true; |
| + | } |
| + | } else { |
| + | cache = outerCache[ dir ] = [ dirkey ]; |
| + | cache[1] = matcher( elem, context, xml ) || cachedruns; |
| + | if ( cache[1] === true ) { |
| + | return true; |
| + | } |
| + | } |
| } | |
| } | |
| } | |
| + | }; |
| + | } |
| - | if ( special.add ) { |
| - | special.add.call( elem, handleObj ); |
| - | |
| - | if ( !handleObj.handler.guid ) { |
| - | handleObj.handler.guid = handler.guid; |
| + | function elementMatcher( matchers ) { |
| + | return matchers.length > 1 ? |
| + | function( elem, context, xml ) { |
| + | var i = matchers.length; |
| + | while ( i-- ) { |
| + | if ( !matchers[i]( elem, context, xml ) ) { |
| + | return false; |
| } | |
| } | |
| + | return true; |
| + | } : |
| + | matchers[0]; |
| + | } |
| - | // Add to the element's handler list, delegates in front |
| - | if ( selector ) { |
| - | handlers.splice( handlers.delegateCount++, 0, handleObj ); |
| - | } else { |
| - | handlers.push( handleObj ); |
| - | } |
| + | function condense( unmatched, map, filter, context, xml ) { |
| + | var elem, |
| + | newUnmatched = [], |
| + | i = 0, |
| + | len = unmatched.length, |
| + | mapped = map != null; |
| - | // Keep track of which events have ever been used, for event optimization |
| - | jQuery.event.global[ type ] = true; |
| + | for ( ; i < len; i++ ) { |
| + | if ( (elem = unmatched[i]) ) { |
| + | if ( !filter || filter( elem, context, xml ) ) { |
| + | newUnmatched.push( elem ); |
| + | if ( mapped ) { |
| + | map.push( i ); |
| + | } |
| + | } |
| } | |
| + | } |
| - | // Nullify elem to prevent memory leaks in IE |
| - | elem = null; |
| - | }, |
| + | return newUnmatched; |
| + | } |
| - | // Detach an event or set of events from an element |
| - | remove: function( elem, types, handler, selector, mappedTypes ) { |
| - | var j, handleObj, tmp, |
| - | origCount, t, events, |
| - | special, handlers, type, |
| - | namespaces, origType, |
| - | elemData = jQuery.hasData( elem ) && jQuery._data( elem ); |
| + | function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) { |
| + | if ( postFilter && !postFilter[ expando ] ) { |
| + | postFilter = setMatcher( postFilter ); |
| + | } |
| + | if ( postFinder && !postFinder[ expando ] ) { |
| + | postFinder = setMatcher( postFinder, postSelector ); |
| + | } |
| + | return markFunction(function( seed, results, context, xml ) { |
| + | var temp, i, elem, |
| + | preMap = [], |
| + | postMap = [], |
| + | preexisting = results.length, |
| - | if ( !elemData || !(events = elemData.events) ) { |
| - | return; |
| - | } |
| + | // Get initial elements from seed or context |
| + | elems = seed || multipleContexts( selector || "*", context.nodeType ? [ context ] : context, [] ), |
| - | // Once for each type.namespace in types; type may be omitted |
| - | types = ( types || "" ).match( core_rnotwhite ) || [""]; |
| - | t = types.length; |
| - | while ( t-- ) { |
| - | tmp = rtypenamespace.exec( types[t] ) || []; |
| - | type = origType = tmp[1]; |
| - | namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
| + | // Prefilter to get matcher input, preserving a map for seed-results synchronization |
| + | matcherIn = preFilter && ( seed || !selector ) ? |
| + | condense( elems, preMap, preFilter, context, xml ) : |
| + | elems, |
| - | // Unbind all events (on this namespace, if provided) for the element |
| - | if ( !type ) { |
| - | for ( type in events ) { |
| - | jQuery.event.remove( elem, type + types[ t ], handler, selector, true ); |
| - | } |
| - | continue; |
| - | } |
| + | matcherOut = matcher ? |
| + | // If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results, |
| + | postFinder || ( seed ? preFilter : preexisting || postFilter ) ? |
| - | special = jQuery.event.special[ type ] || {}; |
| - | type = ( selector ? special.delegateType : special.bindType ) || type; |
| - | handlers = events[ type ] || []; |
| - | tmp = tmp[2] && new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ); |
| + | // ...intermediate processing is necessary |
| + | [] : |
| - | // Remove matching events |
| - | origCount = j = handlers.length; |
| - | while ( j-- ) { |
| - | handleObj = handlers[ j ]; |
| + | // ...otherwise use results directly |
| + | results : |
| + | matcherIn; |
| - | if ( ( mappedTypes || origType === handleObj.origType ) && |
| - | ( !handler || handler.guid === handleObj.guid ) && |
| - | ( !tmp || tmp.test( handleObj.namespace ) ) && |
| - | ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) { |
| - | handlers.splice( j, 1 ); |
| + | // Find primary matches |
| + | if ( matcher ) { |
| + | matcher( matcherIn, matcherOut, context, xml ); |
| + | } |
| - | if ( handleObj.selector ) { |
| - | handlers.delegateCount--; |
| - | } |
| - | if ( special.remove ) { |
| - | special.remove.call( elem, handleObj ); |
| - | } |
| + | // Apply postFilter |
| + | if ( postFilter ) { |
| + | temp = condense( matcherOut, postMap ); |
| + | postFilter( temp, [], context, xml ); |
| + | |
| + | // Un-match failing elements by moving them back to matcherIn |
| + | i = temp.length; |
| + | while ( i-- ) { |
| + | if ( (elem = temp[i]) ) { |
| + | matcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem); |
| } | |
| } | |
| + | } |
| - | // Remove generic event handler if we removed something and no more handlers exist |
| - | // (avoids potential for endless recursion during removal of special event handlers) |
| - | if ( origCount && !handlers.length ) { |
| - | if ( !special.teardown || special.teardown.call( elem, namespaces, elemData.handle ) === false ) { |
| - | jQuery.removeEvent( elem, type, elemData.handle ); |
| + | if ( seed ) { |
| + | if ( postFinder || preFilter ) { |
| + | if ( postFinder ) { |
| + | // Get the final matcherOut by condensing this intermediate into postFinder contexts |
| + | temp = []; |
| + | i = matcherOut.length; |
| + | while ( i-- ) { |
| + | if ( (elem = matcherOut[i]) ) { |
| + | // Restore matcherIn since elem is not yet a final match |
| + | temp.push( (matcherIn[i] = elem) ); |
| + | } |
| + | } |
| + | postFinder( null, (matcherOut = []), temp, xml ); |
| } | |
| - | delete events[ type ]; |
| + | // Move matched elements from seed to results to keep them synchronized |
| + | i = matcherOut.length; |
| + | while ( i-- ) { |
| + | if ( (elem = matcherOut[i]) && |
| + | (temp = postFinder ? indexOf.call( seed, elem ) : preMap[i]) > -1 ) { |
| + | |
| + | seed[temp] = !(results[temp] = elem); |
| + | } |
| + | } |
| + | } |
| + | |
| + | // Add elements to results, through postFinder if defined |
| + | } else { |
| + | matcherOut = condense( |
| + | matcherOut === results ? |
| + | matcherOut.splice( preexisting, matcherOut.length ) : |
| + | matcherOut |
| + | ); |
| + | if ( postFinder ) { |
| + | postFinder( null, results, matcherOut, xml ); |
| + | } else { |
| + | push.apply( results, matcherOut ); |
| } | |
| } | |
| + | }); |
| + | } |
| - | // Remove the expando if it's no longer used |
| - | if ( jQuery.isEmptyObject( events ) ) { |
| - | delete elemData.handle; |
| + | function matcherFromTokens( tokens ) { |
| + | var checkContext, matcher, j, |
| + | len = tokens.length, |
| + | leadingRelative = Expr.relative[ tokens[0].type ], |
| + | implicitRelative = leadingRelative || Expr.relative[" "], |
| + | i = leadingRelative ? 1 : 0, |
| - | // removeData also checks for emptiness and clears the expando if empty |
| - | // so use it instead of delete |
| - | jQuery._removeData( elem, "events" ); |
| + | // The foundational matcher ensures that elements are reachable from top-level context(s) |
| + | matchContext = addCombinator( function( elem ) { |
| + | return elem === checkContext; |
| + | }, implicitRelative, true ), |
| + | matchAnyContext = addCombinator( function( elem ) { |
| + | return indexOf.call( checkContext, elem ) > -1; |
| + | }, implicitRelative, true ), |
| + | matchers = [ function( elem, context, xml ) { |
| + | return ( !leadingRelative && ( xml || context !== outermostContext ) ) || ( |
| + | (checkContext = context).nodeType ? |
| + | matchContext( elem, context, xml ) : |
| + | matchAnyContext( elem, context, xml ) ); |
| + | } ]; |
| + | |
| + | for ( ; i < len; i++ ) { |
| + | if ( (matcher = Expr.relative[ tokens[i].type ]) ) { |
| + | matchers = [ addCombinator(elementMatcher( matchers ), matcher) ]; |
| + | } else { |
| + | matcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches ); |
| + | |
| + | // Return special upon seeing a positional matcher |
| + | if ( matcher[ expando ] ) { |
| + | // Find the next relative operator (if any) for proper handling |
| + | j = ++i; |
| + | for ( ; j < len; j++ ) { |
| + | if ( Expr.relative[ tokens[j].type ] ) { |
| + | break; |
| + | } |
| + | } |
| + | return setMatcher( |
| + | i > 1 && elementMatcher( matchers ), |
| + | i > 1 && toSelector( |
| + | // If the preceding token was a descendant combinator, insert an implicit any-element `*` |
| + | tokens.slice( 0, i - 1 ).concat({ value: tokens[ i - 2 ].type === " " ? "*" : "" }) |
| + | ).replace( rtrim, "$1" ), |
| + | matcher, |
| + | i < j && matcherFromTokens( tokens.slice( i, j ) ), |
| + | j < len && matcherFromTokens( (tokens = tokens.slice( j )) ), |
| + | j < len && toSelector( tokens ) |
| + | ); |
| + | } |
| + | matchers.push( matcher ); |
| } | |
| - | }, |
| + | } |
| - | trigger: function( event, data, elem, onlyHandlers ) { |
| - | var handle, ontype, cur, |
| - | bubbleType, special, tmp, i, |
| - | eventPath = [ elem || document ], |
| - | type = core_hasOwn.call( event, "type" ) ? event.type : event, |
| - | namespaces = core_hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : []; |
| + | return elementMatcher( matchers ); |
| + | } |
| - | cur = tmp = elem = elem || document; |
| + | function matcherFromGroupMatchers( elementMatchers, setMatchers ) { |
| + | // A counter to specify which element is currently being matched |
| + | var matcherCachedRuns = 0, |
| + | bySet = setMatchers.length > 0, |
| + | byElement = elementMatchers.length > 0, |
| + | superMatcher = function( seed, context, xml, results, expandContext ) { |
| + | var elem, j, matcher, |
| + | setMatched = [], |
| + | matchedCount = 0, |
| + | i = "0", |
| + | unmatched = seed && [], |
| + | outermost = expandContext != null, |
| + | contextBackup = outermostContext, |
| + | // We must always have either seed elements or context |
| + | elems = seed || byElement && Expr.find["TAG"]( "*", expandContext && context.parentNode || context ), |
| + | // Use integer dirruns iff this is the outermost matcher |
| + | dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1); |
| - | // Don't do events on text and comment nodes |
| - | if ( elem.nodeType === 3 || elem.nodeType === 8 ) { |
| - | return; |
| - | } |
| + | if ( outermost ) { |
| + | outermostContext = context !== document && context; |
| + | cachedruns = matcherCachedRuns; |
| + | } |
| - | // focus/blur morphs to focusin/out; ensure we're not firing them right now |
| - | if ( rfocusMorph.test( type + jQuery.event.triggered ) ) { |
| - | return; |
| - | } |
| + | // Add elements passing elementMatchers directly to results |
| + | // Keep `i` a string if there are no elements so `matchedCount` will be "00" below |
| + | for ( ; (elem = elems[i]) != null; i++ ) { |
| + | if ( byElement && elem ) { |
| + | j = 0; |
| + | while ( (matcher = elementMatchers[j++]) ) { |
| + | if ( matcher( elem, context, xml ) ) { |
| + | results.push( elem ); |
| + | break; |
| + | } |
| + | } |
| + | if ( outermost ) { |
| + | dirruns = dirrunsUnique; |
| + | cachedruns = ++matcherCachedRuns; |
| + | } |
| + | } |
| - | if ( type.indexOf(".") >= 0 ) { |
| - | // Namespaced trigger; create a regexp to match event type in handle() |
| - | namespaces = type.split("."); |
| - | type = namespaces.shift(); |
| - | namespaces.sort(); |
| - | } |
| - | ontype = type.indexOf(":") < 0 && "on" + type; |
| + | // Track unmatched elements for set filters |
| + | if ( bySet ) { |
| + | // They will have gone through all possible matchers |
| + | if ( (elem = !matcher && elem) ) { |
| + | matchedCount--; |
| + | } |
| - | // Caller can pass in a jQuery.Event object, Object, or just an event type string |
| - | event = event[ jQuery.expando ] ? |
| - | event : |
| - | new jQuery.Event( type, typeof event === "object" && event ); |
| + | // Lengthen the array for every element, matched or not |
| + | if ( seed ) { |
| + | unmatched.push( elem ); |
| + | } |
| + | } |
| + | } |
| - | event.isTrigger = true; |
| - | event.namespace = namespaces.join("."); |
| - | event.namespace_re = event.namespace ? |
| - | new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) : |
| - | null; |
| + | // Apply set filters to unmatched elements |
| + | matchedCount += i; |
| + | if ( bySet && i !== matchedCount ) { |
| + | j = 0; |
| + | while ( (matcher = setMatchers[j++]) ) { |
| + | matcher( unmatched, setMatched, context, xml ); |
| + | } |
| - | // Clean up the event in case it is being reused |
| - | event.result = undefined; |
| - | if ( !event.target ) { |
| - | event.target = elem; |
| - | } |
| + | if ( seed ) { |
| + | // Reintegrate element matches to eliminate the need for sorting |
| + | if ( matchedCount > 0 ) { |
| + | while ( i-- ) { |
| + | if ( !(unmatched[i] || setMatched[i]) ) { |
| + | setMatched[i] = pop.call( results ); |
| + | } |
| + | } |
| + | } |
| - | // Clone any incoming data and prepend the event, creating the handler arg list |
| - | data = data == null ? |
| - | [ event ] : |
| - | jQuery.makeArray( data, [ event ] ); |
| + | // Discard index placeholder values to get only actual matches |
| + | setMatched = condense( setMatched ); |
| + | } |
| - | // Allow special events to draw outside the lines |
| - | special = jQuery.event.special[ type ] || {}; |
| - | if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) { |
| - | return; |
| - | } |
| + | // Add matches to results |
| + | push.apply( results, setMatched ); |
| - | // Determine event propagation path in advance, per W3C events spec (#9951) |
| - | // Bubble up to document, then to window; watch for a global ownerDocument var (#9724) |
| - | if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) { |
| + | // Seedless set matches succeeding multiple successful matchers stipulate sorting |
| + | if ( outermost && !seed && setMatched.length > 0 && |
| + | ( matchedCount + setMatchers.length ) > 1 ) { |
| - | bubbleType = special.delegateType || type; |
| - | if ( !rfocusMorph.test( bubbleType + type ) ) { |
| - | cur = cur.parentNode; |
| - | } |
| - | for ( ; cur; cur = cur.parentNode ) { |
| - | eventPath.push( cur ); |
| - | tmp = cur; |
| + | Sizzle.uniqueSort( results ); |
| + | } |
| } | |
| - | // Only add window if we got to document (e.g., not plain obj or detached DOM) |
| - | if ( tmp === (elem.ownerDocument || document) ) { |
| - | eventPath.push( tmp.defaultView || tmp.parentWindow || window ); |
| + | // Override manipulation of globals by nested matchers |
| + | if ( outermost ) { |
| + | dirruns = dirrunsUnique; |
| + | outermostContext = contextBackup; |
| } | |
| - | } |
| - | // Fire handlers on the event path |
| - | i = 0; |
| - | while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) { |
| + | return unmatched; |
| + | }; |
| - | event.type = i > 1 ? |
| - | bubbleType : |
| - | special.bindType || type; |
| + | return bySet ? |
| + | markFunction( superMatcher ) : |
| + | superMatcher; |
| + | } |
| - | // jQuery handler |
| - | handle = ( jQuery._data( cur, "events" ) || {} )[ event.type ] && jQuery._data( cur, "handle" ); |
| - | if ( handle ) { |
| - | handle.apply( cur, data ); |
| - | } |
| + | compile = Sizzle.compile = function( selector, group /* Internal Use Only */ ) { |
| + | var i, |
| + | setMatchers = [], |
| + | elementMatchers = [], |
| + | cached = compilerCache[ selector + " " ]; |
| - | // Native handler |
| - | handle = ontype && cur[ ontype ]; |
| - | if ( handle && jQuery.acceptData( cur ) && handle.apply && handle.apply( cur, data ) === false ) { |
| - | event.preventDefault(); |
| + | if ( !cached ) { |
| + | // Generate a function of recursive functions that can be used to check each element |
| + | if ( !group ) { |
| + | group = tokenize( selector ); |
| + | } |
| + | i = group.length; |
| + | while ( i-- ) { |
| + | cached = matcherFromTokens( group[i] ); |
| + | if ( cached[ expando ] ) { |
| + | setMatchers.push( cached ); |
| + | } else { |
| + | elementMatchers.push( cached ); |
| } | |
| } | |
| - | event.type = type; |
| - | // If nobody prevented the default action, do it now |
| - | if ( !onlyHandlers && !event.isDefaultPrevented() ) { |
| - | |
| - | if ( (!special._default || special._default.apply( elem.ownerDocument, data ) === false) && |
| - | !(type === "click" && jQuery.nodeName( elem, "a" )) && jQuery.acceptData( elem ) ) { |
| + | // Cache the compiled function |
| + | cached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) ); |
| + | } |
| + | return cached; |
| + | }; |
| - | // Call a native DOM method on the target with the same name name as the event. |
| - | // Can't use an .isFunction() check here because IE6/7 fails that test. |
| - | // Don't do default actions on window, that's where global variables be (#6170) |
| - | if ( ontype && elem[ type ] && !jQuery.isWindow( elem ) ) { |
| + | function multipleContexts( selector, contexts, results ) { |
| + | var i = 0, |
| + | len = contexts.length; |
| + | for ( ; i < len; i++ ) { |
| + | Sizzle( selector, contexts[i], results ); |
| + | } |
| + | return results; |
| + | } |
| - | // Don't re-trigger an onFOO event when we call its FOO() method |
| - | tmp = elem[ ontype ]; |
| + | function select( selector, context, results, seed ) { |
| + | var i, tokens, token, type, find, |
| + | match = tokenize( selector ); |
| - | if ( tmp ) { |
| - | elem[ ontype ] = null; |
| - | } |
| + | if ( !seed ) { |
| + | // Try to minimize operations if there is only one group |
| + | if ( match.length === 1 ) { |
| - | // Prevent re-triggering of the same event, since we already bubbled it above |
| - | jQuery.event.triggered = type; |
| - | try { |
| - | elem[ type ](); |
| - | } catch ( e ) { |
| - | // IE<9 dies on focus/blur to hidden element (#1486,#12518) |
| - | // only reproducible on winXP IE8 native, not IE9 in IE8 mode |
| - | } |
| - | jQuery.event.triggered = undefined; |
| + | // Take a shortcut and set the context if the root selector is an ID |
| + | tokens = match[0] = match[0].slice( 0 ); |
| + | if ( tokens.length > 2 && (token = tokens[0]).type === "ID" && |
| + | support.getById && context.nodeType === 9 && documentIsHTML && |
| + | Expr.relative[ tokens[1].type ] ) { |
| - | if ( tmp ) { |
| - | elem[ ontype ] = tmp; |
| - | } |
| + | context = ( Expr.find["ID"]( token.matches[0].replace(runescape, funescape), context ) || [] )[0]; |
| + | if ( !context ) { |
| + | return results; |
| } | |
| + | selector = selector.slice( tokens.shift().value.length ); |
| } | |
| - | } |
| - | |
| - | return event.result; |
| - | }, |
| - | |
| - | dispatch: function( event ) { |
| - | |
| - | // Make a writable jQuery.Event from the native event object |
| - | event = jQuery.event.fix( event ); |
| - | |
| - | var i, ret, handleObj, matched, j, |
| - | handlerQueue = [], |
| - | args = core_slice.call( arguments ), |
| - | handlers = ( jQuery._data( this, "events" ) || {} )[ event.type ] || [], |
| - | special = jQuery.event.special[ event.type ] || {}; |
| - | |
| - | // Use the fix-ed jQuery.Event rather than the (read-only) native event |
| - | args[0] = event; |
| - | event.delegateTarget = this; |
| - | |
| - | // Call the preDispatch hook for the mapped type, and let it bail if desired |
| - | if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) { |
| - | return; |
| - | } |
| - | |
| - | // Determine handlers |
| - | handlerQueue = jQuery.event.handlers.call( this, event, handlers ); |
| - | |
| - | // Run delegates first; they may want to stop propagation beneath us |
| - | i = 0; |
| - | while ( (matched = handlerQueue[ i++ ]) && !event.isPropagationStopped() ) { |
| - | event.currentTarget = matched.elem; |
| - | |
| - | j = 0; |
| - | while ( (handleObj = matched.handlers[ j++ ]) && !event.isImmediatePropagationStopped() ) { |
| - | |
| - | // Triggered event must either 1) have no namespace, or |
| - | // 2) have namespace(s) a subset or equal to those in the bound event (both can have no namespace). |
| - | if ( !event.namespace_re || event.namespace_re.test( handleObj.namespace ) ) { |
| - | event.handleObj = handleObj; |
| - | event.data = handleObj.data; |
| + | // Fetch a seed set for right-to-left matching |
| + | i = matchExpr["needsContext"].test( selector ) ? 0 : tokens.length; |
| + | while ( i-- ) { |
| + | token = tokens[i]; |
| - | ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || handleObj.handler ) |
| - | .apply( matched.elem, args ); |
| + | // Abort if we hit a combinator |
| + | if ( Expr.relative[ (type = token.type) ] ) { |
| + | break; |
| + | } |
| + | if ( (find = Expr.find[ type ]) ) { |
| + | // Search, expanding context for leading sibling combinators |
| + | if ( (seed = find( |
| + | token.matches[0].replace( runescape, funescape ), |
| + | rsibling.test( tokens[0].type ) && context.parentNode || context |
| + | )) ) { |
| - | if ( ret !== undefined ) { |
| - | if ( (event.result = ret) === false ) { |
| - | event.preventDefault(); |
| - | event.stopPropagation(); |
| + | // If seed is empty or no tokens remain, we can return early |
| + | tokens.splice( i, 1 ); |
| + | selector = seed.length && toSelector( tokens ); |
| + | if ( !selector ) { |
| + | push.apply( results, seed ); |
| + | return results; |
| } | |
| + | |
| + | break; |
| } | |
| } | |
| } | |
| } | |
| + | } |
| - | // Call the postDispatch hook for the mapped type |
| - | if ( special.postDispatch ) { |
| - | special.postDispatch.call( this, event ); |
| - | } |
| - | |
| - | return event.result; |
| - | }, |
| + | // Compile and execute a filtering function |
| + | // Provide `match` to avoid retokenization if we modified the selector above |
| + | compile( selector, match )( |
| + | seed, |
| + | context, |
| + | !documentIsHTML, |
| + | results, |
| + | rsibling.test( selector ) |
| + | ); |
| + | return results; |
| + | } |
| - | handlers: function( event, handlers ) { |
| - | var sel, handleObj, matches, i, |
| - | handlerQueue = [], |
| - | delegateCount = handlers.delegateCount, |
| - | cur = event.target; |
| + | // One-time assignments |
| - | // Find delegate handlers |
| - | // Black-hole SVG <use> instance trees (#13180) |
| - | // Avoid non-left-click bubbling in Firefox (#3861) |
| - | if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) { |
| + | // Sort stability |
| + | support.sortStable = expando.split("").sort( sortOrder ).join("") === expando; |
| - | for ( ; cur != this; cur = cur.parentNode || this ) { |
| + | // Support: Chrome<14 |
| + | // Always assume duplicates if they aren't passed to the comparison function |
| + | support.detectDuplicates = hasDuplicate; |
| - | // Don't check non-elements (#13208) |
| - | // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) |
| - | if ( cur.nodeType === 1 && (cur.disabled !== true || event.type !== "click") ) { |
| - | matches = []; |
| - | for ( i = 0; i < delegateCount; i++ ) { |
| - | handleObj = handlers[ i ]; |
| + | // Initialize against the default document |
| + | setDocument(); |
| - | // Don't conflict with Object.prototype properties (#13203) |
| - | sel = handleObj.selector + " "; |
| + | // Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27) |
| + | // Detached nodes confoundingly follow *each other* |
| + | support.sortDetached = assert(function( div1 ) { |
| + | // Should return 1, but returns 4 (following) |
| + | return div1.compareDocumentPosition( document.createElement("div") ) & 1; |
| + | }); |
| - | if ( matches[ sel ] === undefined ) { |
| - | matches[ sel ] = handleObj.needsContext ? |
| - | jQuery( sel, this ).index( cur ) >= 0 : |
| - | jQuery.find( sel, this, null, [ cur ] ).length; |
| - | } |
| - | if ( matches[ sel ] ) { |
| - | matches.push( handleObj ); |
| - | } |
| - | } |
| - | if ( matches.length ) { |
| - | handlerQueue.push({ elem: cur, handlers: matches }); |
| - | } |
| - | } |
| - | } |
| + | // Support: IE<8 |
| + | // Prevent attribute/property "interpolation" |
| + | // http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx |
| + | if ( !assert(function( div ) { |
| + | div.innerHTML = "<a href='#'></a>"; |
| + | return div.firstChild.getAttribute("href") === "#" ; |
| + | }) ) { |
| + | addHandle( "type|href|height|width", function( elem, name, isXML ) { |
| + | if ( !isXML ) { |
| + | return elem.getAttribute( name, name.toLowerCase() === "type" ? 1 : 2 ); |
| } | |
| + | }); |
| + | } |
| - | // Add the remaining (directly-bound) handlers |
| - | if ( delegateCount < handlers.length ) { |
| - | handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) }); |
| + | // Support: IE<9 |
| + | // Use defaultValue in place of getAttribute("value") |
| + | if ( !support.attributes || !assert(function( div ) { |
| + | div.innerHTML = "<input/>"; |
| + | div.firstChild.setAttribute( "value", "" ); |
| + | return div.firstChild.getAttribute( "value" ) === ""; |
| + | }) ) { |
| + | addHandle( "value", function( elem, name, isXML ) { |
| + | if ( !isXML && elem.nodeName.toLowerCase() === "input" ) { |
| + | return elem.defaultValue; |
| } | |
| + | }); |
| + | } |
| - | return handlerQueue; |
| - | }, |
| - | |
| - | fix: function( event ) { |
| - | if ( event[ jQuery.expando ] ) { |
| - | return event; |
| + | // Support: IE<9 |
| + | // Use getAttributeNode to fetch booleans when getAttribute lies |
| + | if ( !assert(function( div ) { |
| + | return div.getAttribute("disabled") == null; |
| + | }) ) { |
| + | addHandle( booleans, function( elem, name, isXML ) { |
| + | var val; |
| + | if ( !isXML ) { |
| + | return (val = elem.getAttributeNode( name )) && val.specified ? |
| + | val.value : |
| + | elem[ name ] === true ? name.toLowerCase() : null; |
| } | |
| + | }); |
| + | } |
| - | // Create a writable copy of the event object and normalize some properties |
| - | var i, prop, copy, |
| - | type = event.type, |
| - | originalEvent = event, |
| - | fixHook = this.fixHooks[ type ]; |
| - | |
| - | if ( !fixHook ) { |
| - | this.fixHooks[ type ] = fixHook = |
| - | rmouseEvent.test( type ) ? this.mouseHooks : |
| - | rkeyEvent.test( type ) ? this.keyHooks : |
| - | {}; |
| - | } |
| - | copy = fixHook.props ? this.props.concat( fixHook.props ) : this.props; |
| + | jQuery.find = Sizzle; |
| + | jQuery.expr = Sizzle.selectors; |
| + | jQuery.expr[":"] = jQuery.expr.pseudos; |
| + | jQuery.unique = Sizzle.uniqueSort; |
| + | jQuery.text = Sizzle.getText; |
| + | jQuery.isXMLDoc = Sizzle.isXML; |
| + | jQuery.contains = Sizzle.contains; |
| - | event = new jQuery.Event( originalEvent ); |
| - | i = copy.length; |
| - | while ( i-- ) { |
| - | prop = copy[ i ]; |
| - | event[ prop ] = originalEvent[ prop ]; |
| - | } |
| + | })( window ); |
| + | // String to Object options format cache |
| + | var optionsCache = {}; |
| - | // Support: IE<9 |
| - | // Fix target property (#1925) |
| - | if ( !event.target ) { |
| - | event.target = originalEvent.srcElement || document; |
| + | // Convert String-formatted options into Object-formatted ones and store in cache |
| + | function createOptions( options ) { |
| + | var object = optionsCache[ options ] = {}; |
| + | jQuery.each( options.match( core_rnotwhite ) || [], function( _, flag ) { |
| + | object[ flag ] = true; |
| + | }); |
| + | return object; |
| + | } |
| + | |
| + | /* |
| + | * Create a callback list using the following parameters: |
| + | * |
| + | * options: an optional list of space-separated options that will change how |
| + | * the callback list behaves or a more traditional option object |
| + | * |
| + | * By default a callback list will act like an event callback list and can be |
| + | * "fired" multiple times. |
| + | * |
| + | * Possible options: |
| + | * |
| + | * once: will ensure the callback list can only be fired once (like a Deferred) |
| + | * |
| + | * memory: will keep track of previous values and will call any callback added |
| + | * after the list has been fired right away with the latest "memorized" |
| + | * values (like a Deferred) |
| + | * |
| + | * unique: will ensure a callback can only be added once (no duplicate in the list) |
| + | * |
| + | * stopOnFalse: interrupt callings when a callback returns false |
| + | * |
| + | */ |
| + | jQuery.Callbacks = function( options ) { |
| + | |
| + | // Convert options from String-formatted to Object-formatted if needed |
| + | // (we check in cache first) |
| + | options = typeof options === "string" ? |
| + | ( optionsCache[ options ] || createOptions( options ) ) : |
| + | jQuery.extend( {}, options ); |
| + | |
| + | var // Flag to know if list is currently firing |
| + | firing, |
| + | // Last fire value (for non-forgettable lists) |
| + | memory, |
| + | // Flag to know if list was already fired |
| + | fired, |
| + | // End of the loop when firing |
| + | firingLength, |
| + | // Index of currently firing callback (modified by remove if needed) |
| + | firingIndex, |
| + | // First callback to fire (used internally by add and fireWith) |
| + | firingStart, |
| + | // Actual callback list |
| + | list = [], |
| + | // Stack of fire calls for repeatable lists |
| + | stack = !options.once && [], |
| + | // Fire callbacks |
| + | fire = function( data ) { |
| + | memory = options.memory && data; |
| + | fired = true; |
| + | firingIndex = firingStart || 0; |
| + | firingStart = 0; |
| + | firingLength = list.length; |
| + | firing = true; |
| + | for ( ; list && firingIndex < firingLength; firingIndex++ ) { |
| + | if ( list[ firingIndex ].apply( data[ 0 ], data[ 1 ] ) === false && options.stopOnFalse ) { |
| + | memory = false; // To prevent further calls using add |
| + | break; |
| + | } |
| + | } |
| + | firing = false; |
| + | if ( list ) { |
| + | if ( stack ) { |
| + | if ( stack.length ) { |
| + | fire( stack.shift() ); |
| + | } |
| + | } else if ( memory ) { |
| + | list = []; |
| + | } else { |
| + | self.disable(); |
| + | } |
| + | } |
| + | }, |
| + | // Actual Callbacks object |
| + | self = { |
| + | // Add a callback or a collection of callbacks to the list |
| + | add: function() { |
| + | if ( list ) { |
| + | // First, we save the current length |
| + | var start = list.length; |
| + | (function add( args ) { |
| + | jQuery.each( args, function( _, arg ) { |
| + | var type = jQuery.type( arg ); |
| + | if ( type === "function" ) { |
| + | if ( !options.unique || !self.has( arg ) ) { |
| + | list.push( arg ); |
| + | } |
| + | } else if ( arg && arg.length && type !== "string" ) { |
| + | // Inspect recursively |
| + | add( arg ); |
| + | } |
| + | }); |
| + | })( arguments ); |
| + | // Do we need to add the callbacks to the |
| + | // current firing batch? |
| + | if ( firing ) { |
| + | firingLength = list.length; |
| + | // With memory, if we're not firing then |
| + | // we should call right away |
| + | } else if ( memory ) { |
| + | firingStart = start; |
| + | fire( memory ); |
| + | } |
| + | } |
| + | return this; |
| + | }, |
| + | // Remove a callback from the list |
| + | remove: function() { |
| + | if ( list ) { |
| + | jQuery.each( arguments, function( _, arg ) { |
| + | var index; |
| + | while( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { |
| + | list.splice( index, 1 ); |
| + | // Handle firing indexes |
| + | if ( firing ) { |
| + | if ( index <= firingLength ) { |
| + | firingLength--; |
| + | } |
| + | if ( index <= firingIndex ) { |
| + | firingIndex--; |
| + | } |
| + | } |
| + | } |
| + | }); |
| + | } |
| + | return this; |
| + | }, |
| + | // Check if a given callback is in the list. |
| + | // If no argument is given, return whether or not list has callbacks attached. |
| + | has: function( fn ) { |
| + | return fn ? jQuery.inArray( fn, list ) > -1 : !!( list && list.length ); |
| + | }, |
| + | // Remove all callbacks from the list |
| + | empty: function() { |
| + | list = []; |
| + | firingLength = 0; |
| + | return this; |
| + | }, |
| + | // Have the list do nothing anymore |
| + | disable: function() { |
| + | list = stack = memory = undefined; |
| + | return this; |
| + | }, |
| + | // Is it disabled? |
| + | disabled: function() { |
| + | return !list; |
| + | }, |
| + | // Lock the list in its current state |
| + | lock: function() { |
| + | stack = undefined; |
| + | if ( !memory ) { |
| + | self.disable(); |
| + | } |
| + | return this; |
| + | }, |
| + | // Is it locked? |
| + | locked: function() { |
| + | return !stack; |
| + | }, |
| + | // Call all callbacks with the given context and arguments |
| + | fireWith: function( context, args ) { |
| + | if ( list && ( !fired || stack ) ) { |
| + | args = args || []; |
| + | args = [ context, args.slice ? args.slice() : args ]; |
| + | if ( firing ) { |
| + | stack.push( args ); |
| + | } else { |
| + | fire( args ); |
| + | } |
| + | } |
| + | return this; |
| + | }, |
| + | // Call all the callbacks with the given arguments |
| + | fire: function() { |
| + | self.fireWith( this, arguments ); |
| + | return this; |
| + | }, |
| + | // To know if the callbacks have already been called at least once |
| + | fired: function() { |
| + | return !!fired; |
| + | } |
| + | }; |
| + | |
| + | return self; |
| + | }; |
| + | jQuery.extend({ |
| + | |
| + | Deferred: function( func ) { |
| + | var tuples = [ |
| + | // action, add listener, listener list, final state |
| + | [ "resolve", "done", jQuery.Callbacks("once memory"), "resolved" ], |
| + | [ "reject", "fail", jQuery.Callbacks("once memory"), "rejected" ], |
| + | [ "notify", "progress", jQuery.Callbacks("memory") ] |
| + | ], |
| + | state = "pending", |
| + | promise = { |
| + | state: function() { |
| + | return state; |
| + | }, |
| + | always: function() { |
| + | deferred.done( arguments ).fail( arguments ); |
| + | return this; |
| + | }, |
| + | then: function( /* fnDone, fnFail, fnProgress */ ) { |
| + | var fns = arguments; |
| + | return jQuery.Deferred(function( newDefer ) { |
| + | jQuery.each( tuples, function( i, tuple ) { |
| + | var action = tuple[ 0 ], |
| + | fn = jQuery.isFunction( fns[ i ] ) && fns[ i ]; |
| + | // deferred[ done | fail | progress ] for forwarding actions to newDefer |
| + | deferred[ tuple[1] ](function() { |
| + | var returned = fn && fn.apply( this, arguments ); |
| + | if ( returned && jQuery.isFunction( returned.promise ) ) { |
| + | returned.promise() |
| + | .done( newDefer.resolve ) |
| + | .fail( newDefer.reject ) |
| + | .progress( newDefer.notify ); |
| + | } else { |
| + | newDefer[ action + "With" ]( this === promise ? newDefer.promise() : this, fn ? [ returned ] : arguments ); |
| + | } |
| + | }); |
| + | }); |
| + | fns = null; |
| + | }).promise(); |
| + | }, |
| + | // Get a promise for this deferred |
| + | // If obj is provided, the promise aspect is added to the object |
| + | promise: function( obj ) { |
| + | return obj != null ? jQuery.extend( obj, promise ) : promise; |
| + | } |
| + | }, |
| + | deferred = {}; |
| + | |
| + | // Keep pipe for back-compat |
| + | promise.pipe = promise.then; |
| + | |
| + | // Add list-specific methods |
| + | jQuery.each( tuples, function( i, tuple ) { |
| + | var list = tuple[ 2 ], |
| + | stateString = tuple[ 3 ]; |
| + | |
| + | // promise[ done | fail | progress ] = list.add |
| + | promise[ tuple[1] ] = list.add; |
| + | |
| + | // Handle state |
| + | if ( stateString ) { |
| + | list.add(function() { |
| + | // state = [ resolved | rejected ] |
| + | state = stateString; |
| + | |
| + | // [ reject_list | resolve_list ].disable; progress_list.lock |
| + | }, tuples[ i ^ 1 ][ 2 ].disable, tuples[ 2 ][ 2 ].lock ); |
| + | } |
| + | |
| + | // deferred[ resolve | reject | notify ] |
| + | deferred[ tuple[0] ] = function() { |
| + | deferred[ tuple[0] + "With" ]( this === deferred ? promise : this, arguments ); |
| + | return this; |
| + | }; |
| + | deferred[ tuple[0] + "With" ] = list.fireWith; |
| + | }); |
| + | |
| + | // Make the deferred a promise |
| + | promise.promise( deferred ); |
| + | |
| + | // Call given func if any |
| + | if ( func ) { |
| + | func.call( deferred, deferred ); |
| } | |
| - | // Support: Chrome 23+, Safari? |
| - | // Target should not be a text node (#504, #13143) |
| - | if ( event.target.nodeType === 3 ) { |
| - | event.target = event.target.parentNode; |
| + | // All done! |
| + | return deferred; |
| + | }, |
| + | |
| + | // Deferred helper |
| + | when: function( subordinate /* , ..., subordinateN */ ) { |
| + | var i = 0, |
| + | resolveValues = core_slice.call( arguments ), |
| + | length = resolveValues.length, |
| + | |
| + | // the count of uncompleted subordinates |
| + | remaining = length !== 1 || ( subordinate && jQuery.isFunction( subordinate.promise ) ) ? length : 0, |
| + | |
| + | // the master Deferred. If resolveValues consist of only a single Deferred, just use that. |
| + | deferred = remaining === 1 ? subordinate : jQuery.Deferred(), |
| + | |
| + | // Update function for both resolve and progress values |
| + | updateFunc = function( i, contexts, values ) { |
| + | return function( value ) { |
| + | contexts[ i ] = this; |
| + | values[ i ] = arguments.length > 1 ? core_slice.call( arguments ) : value; |
| + | if( values === progressValues ) { |
| + | deferred.notifyWith( contexts, values ); |
| + | } else if ( !( --remaining ) ) { |
| + | deferred.resolveWith( contexts, values ); |
| + | } |
| + | }; |
| + | }, |
| + | |
| + | progressValues, progressContexts, resolveContexts; |
| + | |
| + | // add listeners to Deferred subordinates; treat others as resolved |
| + | if ( length > 1 ) { |
| + | progressValues = new Array( length ); |
| + | progressContexts = new Array( length ); |
| + | resolveContexts = new Array( length ); |
| + | for ( ; i < length; i++ ) { |
| + | if ( resolveValues[ i ] && jQuery.isFunction( resolveValues[ i ].promise ) ) { |
| + | resolveValues[ i ].promise() |
| + | .done( updateFunc( i, resolveContexts, resolveValues ) ) |
| + | .fail( deferred.reject ) |
| + | .progress( updateFunc( i, progressContexts, progressValues ) ); |
| + | } else { |
| + | --remaining; |
| + | } |
| + | } |
| } | |
| - | // Support: IE<9 |
| - | // For mouse/key events, metaKey==false if it's undefined (#3368, #11328) |
| - | event.metaKey = !!event.metaKey; |
| + | // if we're not waiting on anything, resolve the master |
| + | if ( !remaining ) { |
| + | deferred.resolveWith( resolveContexts, resolveValues ); |
| + | } |
| + | |
| + | return deferred.promise(); |
| + | } |
| + | }); |
| + | jQuery.support = (function( support ) { |
| + | |
| + | var all, a, input, select, fragment, opt, eventName, isSupported, i, |
| + | div = document.createElement("div"); |
| + | |
| + | // Setup |
| + | div.setAttribute( "className", "t" ); |
| + | div.innerHTML = " <link/><table></table><a href='/a'>a</a><input type='checkbox'/>"; |
| + | |
| + | // Finish early in limited (non-browser) environments |
| + | all = div.getElementsByTagName("*") || []; |
| + | a = div.getElementsByTagName("a")[ 0 ]; |
| + | if ( !a || !a.style || !all.length ) { |
| + | return support; |
| + | } |
| + | |
| + | // First batch of tests |
| + | select = document.createElement("select"); |
| + | opt = select.appendChild( document.createElement("option") ); |
| + | input = div.getElementsByTagName("input")[ 0 ]; |
| + | |
| + | a.style.cssText = "top:1px;float:left;opacity:.5"; |
| + | |
| + | // Test setAttribute on camelCase class. If it works, we need attrFixes when doing get/setAttribute (ie6/7) |
| + | support.getSetAttribute = div.className !== "t"; |
| + | |
| + | // IE strips leading whitespace when .innerHTML is used |
| + | support.leadingWhitespace = div.firstChild.nodeType === 3; |
| + | |
| + | // Make sure that tbody elements aren't automatically inserted |
| + | // IE will insert them into empty tables |
| + | support.tbody = !div.getElementsByTagName("tbody").length; |
| + | |
| + | // Make sure that link elements get serialized correctly by innerHTML |
| + | // This requires a wrapper element in IE |
| + | support.htmlSerialize = !!div.getElementsByTagName("link").length; |
| + | |
| + | // Get the style information from getAttribute |
| + | // (IE uses .cssText instead) |
| + | support.style = /top/.test( a.getAttribute("style") ); |
| + | |
| + | // Make sure that URLs aren't manipulated |
| + | // (IE normalizes it by default) |
| + | support.hrefNormalized = a.getAttribute("href") === "/a"; |
| + | |
| + | // Make sure that element opacity exists |
| + | // (IE uses filter instead) |
| + | // Use a regex to work around a WebKit issue. See #5145 |
| + | support.opacity = /^0.5/.test( a.style.opacity ); |
| + | |
| + | // Verify style float existence |
| + | // (IE uses styleFloat instead of cssFloat) |
| + | support.cssFloat = !!a.style.cssFloat; |
| + | |
| + | // Check the default checkbox/radio value ("" on WebKit; "on" elsewhere) |
| + | support.checkOn = !!input.value; |
| + | |
| + | // Make sure that a selected-by-default option has a working selected property. |
| + | // (WebKit defaults to false instead of true, IE too, if it's in an optgroup) |
| + | support.optSelected = opt.selected; |
| + | |
| + | // Tests for enctype support on a form (#6743) |
| + | support.enctype = !!document.createElement("form").enctype; |
| + | |
| + | // Makes sure cloning an html5 element does not cause problems |
| + | // Where outerHTML is undefined, this still works |
| + | support.html5Clone = document.createElement("nav").cloneNode( true ).outerHTML !== "<:nav></:nav>"; |
| + | |
| + | // Will be defined later |
| + | support.inlineBlockNeedsLayout = false; |
| + | support.shrinkWrapBlocks = false; |
| + | support.pixelPosition = false; |
| + | support.deleteExpando = true; |
| + | support.noCloneEvent = true; |
| + | support.reliableMarginRight = true; |
| + | support.boxSizingReliable = true; |
| + | |
| + | // Make sure checked status is properly cloned |
| + | input.checked = true; |
| + | support.noCloneChecked = input.cloneNode( true ).checked; |
| + | |
| + | // Make sure that the options inside disabled selects aren't marked as disabled |
| + | // (WebKit marks them as disabled) |
| + | select.disabled = true; |
| + | support.optDisabled = !opt.disabled; |
| + | |
| + | // Support: IE<9 |
| + | try { |
| + | delete div.test; |
| + | } catch( e ) { |
| + | support.deleteExpando = false; |
| + | } |
| + | |
| + | // Check if we can trust getAttribute("value") |
| + | input = document.createElement("input"); |
| + | input.setAttribute( "value", "" ); |
| + | support.input = input.getAttribute( "value" ) === ""; |
| + | |
| + | // Check if an input maintains its value after becoming a radio |
| + | input.value = "t"; |
| + | input.setAttribute( "type", "radio" ); |
| + | support.radioValue = input.value === "t"; |
| + | |
| + | // #11217 - WebKit loses check when the name is after the checked attribute |
| + | input.setAttribute( "checked", "t" ); |
| + | input.setAttribute( "name", "t" ); |
| + | |
| + | fragment = document.createDocumentFragment(); |
| + | fragment.appendChild( input ); |
| + | |
| + | // Check if a disconnected checkbox will retain its checked |
| + | // value of true after appended to the DOM (IE6/7) |
| + | support.appendChecked = input.checked; |
| + | |
| + | // WebKit doesn't clone checked state correctly in fragments |
| + | support.checkClone = fragment.cloneNode( true ).cloneNode( true ).lastChild.checked; |
| - | return fixHook.filter ? fixHook.filter( event, originalEvent ) : event; |
| - | }, |
| + | // Support: IE<9 |
| + | // Opera does not clone events (and typeof div.attachEvent === undefined). |
| + | // IE9-10 clones events bound via attachEvent, but they don't trigger with .click() |
| + | if ( div.attachEvent ) { |
| + | div.attachEvent( "onclick", function() { |
| + | support.noCloneEvent = false; |
| + | }); |
| - | // Includes some event props shared by KeyEvent and MouseEvent |
| - | props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), |
| + | div.cloneNode( true ).click(); |
| + | } |
| - | fixHooks: {}, |
| + | // Support: IE<9 (lack submit/change bubble), Firefox 17+ (lack focusin event) |
| + | // Beware of CSP restrictions (https://developer.mozilla.org/en/Security/CSP) |
| + | for ( i in { submit: true, change: true, focusin: true }) { |
| + | div.setAttribute( eventName = "on" + i, "t" ); |
| - | keyHooks: { |
| - | props: "char charCode key keyCode".split(" "), |
| - | filter: function( event, original ) { |
| + | support[ i + "Bubbles" ] = eventName in window || div.attributes[ eventName ].expando === false; |
| + | } |
| - | // Add which for key events |
| - | if ( event.which == null ) { |
| - | event.which = original.charCode != null ? original.charCode : original.keyCode; |
| - | } |
| + | div.style.backgroundClip = "content-box"; |
| + | div.cloneNode( true ).style.backgroundClip = ""; |
| + | support.clearCloneStyle = div.style.backgroundClip === "content-box"; |
| - | return event; |
| + | // Support: IE<9 |
| + | // Iteration over object's inherited properties before its own. |
| + | for ( i in jQuery( support ) ) { |
| + | break; |
| + | } |
| + | support.ownLast = i !== "0"; |
| + | |
| + | // Run tests that need a body at doc ready |
| + | jQuery(function() { |
| + | var container, marginDiv, tds, |
| + | divReset = "padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;", |
| + | body = document.getElementsByTagName("body")[0]; |
| + | |
| + | if ( !body ) { |
| + | // Return for frameset docs that don't have a body |
| + | return; |
| } | |
| - | }, |
| - | mouseHooks: { |
| - | props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "), |
| - | filter: function( event, original ) { |
| - | var body, eventDoc, doc, |
| - | button = original.button, |
| - | fromElement = original.fromElement; |
| + | container = document.createElement("div"); |
| + | container.style.cssText = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px"; |
| - | // Calculate pageX/Y if missing and clientX/Y available |
| - | if ( event.pageX == null && original.clientX != null ) { |
| - | eventDoc = event.target.ownerDocument || document; |
| - | doc = eventDoc.documentElement; |
| - | body = eventDoc.body; |
| + | body.appendChild( container ).appendChild( div ); |
| - | event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft || body && body.clientLeft || 0 ); |
| - | event.pageY = original.clientY + ( doc && doc.scrollTop || body && body.scrollTop || 0 ) - ( doc && doc.clientTop || body && body.clientTop || 0 ); |
| - | } |
| + | // Support: IE8 |
| + | // Check if table cells still have offsetWidth/Height when they are set |
| + | // to display:none and there are still other visible table cells in a |
| + | // table row; if so, offsetWidth/Height are not reliable for use when |
| + | // determining if an element has been hidden directly using |
| + | // display:none (it is still safe to use offsets if a parent element is |
| + | // hidden; don safety goggles and see bug #4512 for more information). |
| + | div.innerHTML = "<table><tr><td></td><td>t</td></tr></table>"; |
| + | tds = div.getElementsByTagName("td"); |
| + | tds[ 0 ].style.cssText = "padding:0;margin:0;border:0;display:none"; |
| + | isSupported = ( tds[ 0 ].offsetHeight === 0 ); |
| - | // Add relatedTarget, if necessary |
| - | if ( !event.relatedTarget && fromElement ) { |
| - | event.relatedTarget = fromElement === event.target ? original.toElement : fromElement; |
| - | } |
| + | tds[ 0 ].style.display = ""; |
| + | tds[ 1 ].style.display = "none"; |
| - | // Add which for click: 1 === left; 2 === middle; 3 === right |
| - | // Note: button is not normalized, so don't use it |
| - | if ( !event.which && button !== undefined ) { |
| - | event.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) ); |
| - | } |
| + | // Support: IE8 |
| + | // Check if empty table cells still have offsetWidth/Height |
| + | support.reliableHiddenOffsets = isSupported && ( tds[ 0 ].offsetHeight === 0 ); |
| - | return event; |
| - | } |
| - | }, |
| + | // Check box-sizing and margin behavior. |
| + | div.innerHTML = ""; |
| + | div.style.cssText = "box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;"; |
| - | special: { |
| - | load: { |
| - | // Prevent triggered image.load events from bubbling to window.load |
| - | noBubble: true |
| - | }, |
| - | click: { |
| - | // For checkbox, fire native event so checked state will be right |
| - | trigger: function() { |
| - | if ( jQuery.nodeName( this, "input" ) && this.type === "checkbox" && this.click ) { |
| - | this.click(); |
| - | return false; |
| - | } |
| - | } |
| - | }, |
| - | focus: { |
| - | // Fire native event if possible so blur/focus sequence is correct |
| - | trigger: function() { |
| - | if ( this !== document.activeElement && this.focus ) { |
| - | try { |
| - | this.focus(); |
| - | return false; |
| - | } catch ( e ) { |
| - | // Support: IE<9 |
| - | // If we error on focus to hidden element (#1486, #12518), |
| - | // let .trigger() run the handlers |
| - | } |
| - | } |
| - | }, |
| - | delegateType: "focusin" |
| - | }, |
| - | blur: { |
| - | trigger: function() { |
| - | if ( this === document.activeElement && this.blur ) { |
| - | this.blur(); |
| - | return false; |
| - | } |
| - | }, |
| - | delegateType: "focusout" |
| - | }, |
| + | // Workaround failing boxSizing test due to offsetWidth returning wrong value |
| + | // with some non-1 values of body zoom, ticket #13543 |
| + | jQuery.swap( body, body.style.zoom != null ? { zoom: 1 } : {}, function() { |
| + | support.boxSizing = div.offsetWidth === 4; |
| + | }); |
| - | beforeunload: { |
| - | postDispatch: function( event ) { |
| + | // Use window.getComputedStyle because jsdom on node.js will break without it. |
| + | if ( window.getComputedStyle ) { |
| + | support.pixelPosition = ( window.getComputedStyle( div, null ) || {} ).top !== "1%"; |
| + | support.boxSizingReliable = ( window.getComputedStyle( div, null ) || { width: "4px" } ).width === "4px"; |
| - | // Even when returnValue equals to undefined Firefox will still show alert |
| - | if ( event.result !== undefined ) { |
| - | event.originalEvent.returnValue = event.result; |
| - | } |
| - | } |
| + | // Check if div with explicit width and no margin-right incorrectly |
| + | // gets computed margin-right based on width of container. (#3333) |
| + | // Fails in WebKit before Feb 2011 nightlies |
| + | // WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right |
| + | marginDiv = div.appendChild( document.createElement("div") ); |
| + | marginDiv.style.cssText = div.style.cssText = divReset; |
| + | marginDiv.style.marginRight = marginDiv.style.width = "0"; |
| + | div.style.width = "1px"; |
| + | |
| + | support.reliableMarginRight = |
| + | !parseFloat( ( window.getComputedStyle( marginDiv, null ) || {} ).marginRight ); |
| } | |
| - | }, |
| - | simulate: function( type, elem, event, bubble ) { |
| - | // Piggyback on a donor event to simulate a different one. |
| - | // Fake originalEvent to avoid donor's stopPropagation, but if the |
| - | // simulated event prevents default then we do the same on the donor. |
| - | var e = jQuery.extend( |
| - | new jQuery.Event(), |
| - | event, |
| - | { type: type, |
| - | isSimulated: true, |
| - | originalEvent: {} |
| + | if ( typeof div.style.zoom !== core_strundefined ) { |
| + | // Support: IE<8 |
| + | // Check if natively block-level elements act like inline-block |
| + | // elements when setting their display to 'inline' and giving |
| + | // them layout |
| + | div.innerHTML = ""; |
| + | div.style.cssText = divReset + "width:1px;padding:1px;display:inline;zoom:1"; |
| + | support.inlineBlockNeedsLayout = ( div.offsetWidth === 3 ); |
| + | |
| + | // Support: IE6 |
| + | // Check if elements with layout shrink-wrap their children |
| + | div.style.display = "block"; |
| + | div.innerHTML = "<div></div>"; |
| + | div.firstChild.style.width = "5px"; |
| + | support.shrinkWrapBlocks = ( div.offsetWidth !== 3 ); |
| + | |
| + | if ( support.inlineBlockNeedsLayout ) { |
| + | // Prevent IE 6 from affecting layout for positioned elements #11048 |
| + | // Prevent IE from shrinking the body in IE 7 mode #12869 |
| + | // Support: IE<8 |
| + | body.style.zoom = 1; |
| } | |
| - | ); |
| - | if ( bubble ) { |
| - | jQuery.event.trigger( e, null, elem ); |
| - | } else { |
| - | jQuery.event.dispatch.call( elem, e ); |
| - | } |
| - | if ( e.isDefaultPrevented() ) { |
| - | event.preventDefault(); |
| } | |
| + | |
| + | body.removeChild( container ); |
| + | |
| + | // Null elements to avoid leaks in IE |
| + | container = div = tds = marginDiv = null; |
| + | }); |
| + | |
| + | // Null elements to avoid leaks in IE |
| + | all = select = fragment = opt = a = input = null; |
| + | |
| + | return support; |
| + | })({}); |
| + | |
| + | var rbrace = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/, |
| + | rmultiDash = /([A-Z])/g; |
| + | |
| + | function internalData( elem, name, data, pvt /* Internal Use Only */ ){ |
| + | if ( !jQuery.acceptData( elem ) ) { |
| + | return; |
| } | |
| - | }; |
| - | jQuery.removeEvent = document.removeEventListener ? |
| - | function( elem, type, handle ) { |
| - | if ( elem.removeEventListener ) { |
| - | elem.removeEventListener( type, handle, false ); |
| - | } |
| - | } : |
| - | function( elem, type, handle ) { |
| - | var name = "on" + type; |
| + | var ret, thisCache, |
| + | internalKey = jQuery.expando, |
| - | if ( elem.detachEvent ) { |
| + | // We have to handle DOM nodes and JS objects differently because IE6-7 |
| + | // can't GC object references properly across the DOM-JS boundary |
| + | isNode = elem.nodeType, |
| - | // #8545, #7054, preventing memory leaks for custom events in IE6-8 |
| - | // detachEvent needed property on element, by name of that event, to properly expose it to GC |
| - | if ( typeof elem[ name ] === core_strundefined ) { |
| - | elem[ name ] = null; |
| - | } |
| + | // Only DOM nodes need the global jQuery cache; JS object data is |
| + | // attached directly to the object so GC can occur automatically |
| + | cache = isNode ? jQuery.cache : elem, |
| - | elem.detachEvent( name, handle ); |
| + | // Only defining an ID for JS objects if its cache already exists allows |
| + | // the code to shortcut on the same path as a DOM node with no cache |
| + | id = isNode ? elem[ internalKey ] : elem[ internalKey ] && internalKey; |
| + | |
| + | // Avoid doing any more work than we need to when trying to get data on an |
| + | // object that has no data at all |
| + | if ( (!id || !cache[id] || (!pvt && !cache[id].data)) && data === undefined && typeof name === "string" ) { |
| + | return; |
| + | } |
| + | |
| + | if ( !id ) { |
| + | // Only DOM nodes need a new unique ID for each element since their data |
| + | // ends up in the global cache |
| + | if ( isNode ) { |
| + | id = elem[ internalKey ] = core_deletedIds.pop() || jQuery.guid++; |
| + | } else { |
| + | id = internalKey; |
| } | |
| - | }; |
| + | } |
| + | |
| + | if ( !cache[ id ] ) { |
| + | // Avoid exposing jQuery metadata on plain JS objects when the object |
| + | // is serialized using JSON.stringify |
| + | cache[ id ] = isNode ? {} : { toJSON: jQuery.noop }; |
| + | } |
| - | jQuery.Event = function( src, props ) { |
| - | // Allow instantiation without the 'new' keyword |
| - | if ( !(this instanceof jQuery.Event) ) { |
| - | return new jQuery.Event( src, props ); |
| + | // An object can be passed to jQuery.data instead of a key/value pair; this gets |
| + | // shallow copied over onto the existing cache |
| + | if ( typeof name === "object" || typeof name === "function" ) { |
| + | if ( pvt ) { |
| + | cache[ id ] = jQuery.extend( cache[ id ], name ); |
| + | } else { |
| + | cache[ id ].data = jQuery.extend( cache[ id ].data, name ); |
| + | } |
| } | |
| - | // Event object |
| - | if ( src && src.type ) { |
| - | this.originalEvent = src; |
| - | this.type = src.type; |
| + | thisCache = cache[ id ]; |
| - | // Events bubbling up the document may have been marked as prevented |
| - | // by a handler lower down the tree; reflect the correct value. |
| - | this.isDefaultPrevented = ( src.defaultPrevented || src.returnValue === false || |
| - | src.getPreventDefault && src.getPreventDefault() ) ? returnTrue : returnFalse; |
| + | // jQuery data() is stored in a separate object inside the object's internal data |
| + | // cache in order to avoid key collisions between internal data and user-defined |
| + | // data. |
| + | if ( !pvt ) { |
| + | if ( !thisCache.data ) { |
| + | thisCache.data = {}; |
| + | } |
| - | // Event type |
| - | } else { |
| - | this.type = src; |
| + | thisCache = thisCache.data; |
| } | |
| - | // Put explicitly provided properties onto the event object |
| - | if ( props ) { |
| - | jQuery.extend( this, props ); |
| + | if ( data !== undefined ) { |
| + | thisCache[ jQuery.camelCase( name ) ] = data; |
| } | |
| - | // Create a timestamp if incoming event doesn't have one |
| - | this.timeStamp = src && src.timeStamp || jQuery.now(); |
| - | |
| - | // Mark it as fixed |
| - | this[ jQuery.expando ] = true; |
| - | }; |
| + | // Check for both converted-to-camel and non-converted data property names |
| + | // If a data property was specified |
| + | if ( typeof name === "string" ) { |
| - | // jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding |
| - | // http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html |
| - | jQuery.Event.prototype = { |
| - | isDefaultPrevented: returnFalse, |
| - | isPropagationStopped: returnFalse, |
| - | isImmediatePropagationStopped: returnFalse, |
| + | // First Try to find as-is property data |
| + | ret = thisCache[ name ]; |
| - | preventDefault: function() { |
| - | var e = this.originalEvent; |
| + | // Test for null|undefined property data |
| + | if ( ret == null ) { |
| - | this.isDefaultPrevented = returnTrue; |
| - | if ( !e ) { |
| - | return; |
| + | // Try to find the camelCased property |
| + | ret = thisCache[ jQuery.camelCase( name ) ]; |
| } | |
| + | } else { |
| + | ret = thisCache; |
| + | } |
| - | // If preventDefault exists, run it on the original event |
| - | if ( e.preventDefault ) { |
| - | e.preventDefault(); |
| + | return ret; |
| + | } |
| - | // Support: IE |
| - | // Otherwise set the returnValue property of the original event to false |
| - | } else { |
| - | e.returnValue = false; |
| - | } |
| - | }, |
| - | stopPropagation: function() { |
| - | var e = this.originalEvent; |
| + | function internalRemoveData( elem, name, pvt ) { |
| + | if ( !jQuery.acceptData( elem ) ) { |
| + | return; |
| + | } |
| - | this.isPropagationStopped = returnTrue; |
| - | if ( !e ) { |
| - | return; |
| - | } |
| - | // If stopPropagation exists, run it on the original event |
| - | if ( e.stopPropagation ) { |
| - | e.stopPropagation(); |
| - | } |
| + | var thisCache, i, |
| + | isNode = elem.nodeType, |
| - | // Support: IE |
| - | // Set the cancelBubble property of the original event to true |
| - | e.cancelBubble = true; |
| - | }, |
| - | stopImmediatePropagation: function() { |
| - | this.isImmediatePropagationStopped = returnTrue; |
| - | this.stopPropagation(); |
| + | // See jQuery.data for more information |
| + | cache = isNode ? jQuery.cache : elem, |
| + | id = isNode ? elem[ jQuery.expando ] : jQuery.expando; |
| + | |
| + | // If there is already no cache entry for this object, there is no |
| + | // purpose in continuing |
| + | if ( !cache[ id ] ) { |
| + | return; |
| } | |
| - | }; |
| - | // Create mouseenter/leave events using mouseover/out and event-time checks |
| - | jQuery.each({ |
| - | mouseenter: "mouseover", |
| - | mouseleave: "mouseout" |
| - | }, function( orig, fix ) { |
| - | jQuery.event.special[ orig ] = { |
| - | delegateType: fix, |
| - | bindType: fix, |
| + | if ( name ) { |
| - | handle: function( event ) { |
| - | var ret, |
| - | target = this, |
| - | related = event.relatedTarget, |
| - | handleObj = event.handleObj; |
| + | thisCache = pvt ? cache[ id ] : cache[ id ].data; |
| - | // For mousenter/leave call the handler if related is outside the target. |
| - | // NB: No relatedTarget if the mouse left/entered the browser window |
| - | if ( !related || (related !== target && !jQuery.contains( target, related )) ) { |
| - | event.type = handleObj.origType; |
| - | ret = handleObj.handler.apply( this, arguments ); |
| - | event.type = fix; |
| - | } |
| - | return ret; |
| - | } |
| - | }; |
| - | }); |
| + | if ( thisCache ) { |
| - | // IE submit delegation |
| - | if ( !jQuery.support.submitBubbles ) { |
| + | // Support array or space separated string names for data keys |
| + | if ( !jQuery.isArray( name ) ) { |
| - | jQuery.event.special.submit = { |
| - | setup: function() { |
| - | // Only need this for delegated form submit events |
| - | if ( jQuery.nodeName( this, "form" ) ) { |
| - | return false; |
| - | } |
| + | // try the string as a key before any manipulation |
| + | if ( name in thisCache ) { |
| + | name = [ name ]; |
| + | } else { |
| - | // Lazy-add a submit handler when a descendant form may potentially be submitted |
| - | jQuery.event.add( this, "click._submit keypress._submit", function( e ) { |
| - | // Node name check avoids a VML-related crash in IE (#9807) |
| - | var elem = e.target, |
| - | form = jQuery.nodeName( elem, "input" ) || jQuery.nodeName( elem, "button" ) ? elem.form : undefined; |
| - | if ( form && !jQuery._data( form, "submitBubbles" ) ) { |
| - | jQuery.event.add( form, "submit._submit", function( event ) { |
| - | event._submit_bubble = true; |
| - | }); |
| - | jQuery._data( form, "submitBubbles", true ); |
| + | // split the camel cased version by spaces unless a key with the spaces exists |
| + | name = jQuery.camelCase( name ); |
| + | if ( name in thisCache ) { |
| + | name = [ name ]; |
| + | } else { |
| + | name = name.split(" "); |
| + | } |
| } | |
| - | }); |
| - | // return undefined since we don't need an event listener |
| - | }, |
| + | } else { |
| + | // If "name" is an array of keys... |
| + | // When data is initially created, via ("key", "val") signature, |
| + | // keys will be converted to camelCase. |
| + | // Since there is no way to tell _how_ a key was added, remove |
| + | // both plain key and camelCase key. #12786 |
| + | // This will only penalize the array argument path. |
| + | name = name.concat( jQuery.map( name, jQuery.camelCase ) ); |
| + | } |
| - | postDispatch: function( event ) { |
| - | // If form was submitted by the user, bubble the event up the tree |
| - | if ( event._submit_bubble ) { |
| - | delete event._submit_bubble; |
| - | if ( this.parentNode && !event.isTrigger ) { |
| - | jQuery.event.simulate( "submit", this.parentNode, event, true ); |
| - | } |
| + | i = name.length; |
| + | while ( i-- ) { |
| + | delete thisCache[ name[i] ]; |
| } | |
| - | }, |
| - | teardown: function() { |
| - | // Only need this for delegated form submit events |
| - | if ( jQuery.nodeName( this, "form" ) ) { |
| - | return false; |
| + | // If there is no data left in the cache, we want to continue |
| + | // and let the cache object itself get destroyed |
| + | if ( pvt ? !isEmptyDataObject(thisCache) : !jQuery.isEmptyObject(thisCache) ) { |
| + | return; |
| } | |
| + | } |
| + | } |
| - | // Remove delegated handlers; cleanData eventually reaps submit handlers attached above |
| - | jQuery.event.remove( this, "._submit" ); |
| + | // See jQuery.data for more information |
| + | if ( !pvt ) { |
| + | delete cache[ id ].data; |
| + | |
| + | // Don't destroy the parent cache unless the internal data object |
| + | // had been the only thing left in it |
| + | if ( !isEmptyDataObject( cache[ id ] ) ) { |
| + | return; |
| } | |
| - | }; |
| - | } |
| + | } |
| - | // IE change delegation and checkbox/radio fix |
| - | if ( !jQuery.support.changeBubbles ) { |
| + | // Destroy the cache |
| + | if ( isNode ) { |
| + | jQuery.cleanData( [ elem ], true ); |
| - | jQuery.event.special.change = { |
| + | // Use delete when supported for expandos or `cache` is not a window per isWindow (#10080) |
| + | /* jshint eqeqeq: false */ |
| + | } else if ( jQuery.support.deleteExpando || cache != cache.window ) { |
| + | /* jshint eqeqeq: true */ |
| + | delete cache[ id ]; |
| - | setup: function() { |
| + | // When all else fails, null |
| + | } else { |
| + | cache[ id ] = null; |
| + | } |
| + | } |
| - | if ( rformElems.test( this.nodeName ) ) { |
| - | // IE doesn't fire change on a check/radio until blur; trigger it on click |
| - | // after a propertychange. Eat the blur-change in special.change.handle. |
| - | // This still fires onchange a second time for check/radio after blur. |
| - | if ( this.type === "checkbox" || this.type === "radio" ) { |
| - | jQuery.event.add( this, "propertychange._change", function( event ) { |
| - | if ( event.originalEvent.propertyName === "checked" ) { |
| - | this._just_changed = true; |
| - | } |
| - | }); |
| - | jQuery.event.add( this, "click._change", function( event ) { |
| - | if ( this._just_changed && !event.isTrigger ) { |
| - | this._just_changed = false; |
| - | } |
| - | // Allow triggered, simulated change events (#11500) |
| - | jQuery.event.simulate( "change", this, event, true ); |
| - | }); |
| - | } |
| - | return false; |
| - | } |
| - | // Delegated event; lazy-add a change handler on descendant inputs |
| - | jQuery.event.add( this, "beforeactivate._change", function( e ) { |
| - | var elem = e.target; |
| + | jQuery.extend({ |
| + | cache: {}, |
| + | |
| + | // The following elements throw uncatchable exceptions if you |
| + | // attempt to add expando properties to them. |
| + | noData: { |
| + | "applet": true, |
| + | "embed": true, |
| + | // Ban all objects except for Flash (which handle expandos) |
| + | "object": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" |
| + | }, |
| - | if ( rformElems.test( elem.nodeName ) && !jQuery._data( elem, "changeBubbles" ) ) { |
| - | jQuery.event.add( elem, "change._change", function( event ) { |
| - | if ( this.parentNode && !event.isSimulated && !event.isTrigger ) { |
| - | jQuery.event.simulate( "change", this.parentNode, event, true ); |
| - | } |
| - | }); |
| - | jQuery._data( elem, "changeBubbles", true ); |
| - | } |
| - | }); |
| - | }, |
| + | hasData: function( elem ) { |
| + | elem = elem.nodeType ? jQuery.cache[ elem[jQuery.expando] ] : elem[ jQuery.expando ]; |
| + | return !!elem && !isEmptyDataObject( elem ); |
| + | }, |
| - | handle: function( event ) { |
| - | var elem = event.target; |
| + | data: function( elem, name, data ) { |
| + | return internalData( elem, name, data ); |
| + | }, |
| - | // Swallow native change events from checkbox/radio, we already triggered them above |
| - | if ( this !== elem || event.isSimulated || event.isTrigger || (elem.type !== "radio" && elem.type !== "checkbox") ) { |
| - | return event.handleObj.handler.apply( this, arguments ); |
| - | } |
| - | }, |
| + | removeData: function( elem, name ) { |
| + | return internalRemoveData( elem, name ); |
| + | }, |
| - | teardown: function() { |
| - | jQuery.event.remove( this, "._change" ); |
| + | // For internal use only. |
| + | _data: function( elem, name, data ) { |
| + | return internalData( elem, name, data, true ); |
| + | }, |
| - | return !rformElems.test( this.nodeName ); |
| - | } |
| - | }; |
| - | } |
| + | _removeData: function( elem, name ) { |
| + | return internalRemoveData( elem, name, true ); |
| + | }, |
| - | // Create "bubbling" focus and blur events |
| - | if ( !jQuery.support.focusinBubbles ) { |
| - | jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { |
| + | // A method for determining if a DOM node can handle the data expando |
| + | acceptData: function( elem ) { |
| + | // Do not set data on non-element because it will not be cleared (#8335). |
| + | if ( elem.nodeType && elem.nodeType !== 1 && elem.nodeType !== 9 ) { |
| + | return false; |
| + | } |
| - | // Attach a single capturing handler while someone wants focusin/focusout |
| - | var attaches = 0, |
| - | handler = function( event ) { |
| - | jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ), true ); |
| - | }; |
| + | var noData = elem.nodeName && jQuery.noData[ elem.nodeName.toLowerCase() ]; |
| - | jQuery.event.special[ fix ] = { |
| - | setup: function() { |
| - | if ( attaches++ === 0 ) { |
| - | document.addEventListener( orig, handler, true ); |
| - | } |
| - | }, |
| - | teardown: function() { |
| - | if ( --attaches === 0 ) { |
| - | document.removeEventListener( orig, handler, true ); |
| - | } |
| - | } |
| - | }; |
| - | }); |
| - | } |
| + | // nodes accept data unless otherwise specified; rejection can be conditional |
| + | return !noData || noData !== true && elem.getAttribute("classid") === noData; |
| + | } |
| + | }); |
| jQuery.fn.extend({ | |
| + | data: function( key, value ) { |
| + | var attrs, name, |
| + | data = null, |
| + | i = 0, |
| + | elem = this[0]; |
| - | on: function( types, selector, data, fn, /*INTERNAL*/ one ) { |
| - | var type, origFn; |
| + | // Special expections of .data basically thwart jQuery.access, |
| + | // so implement the relevant behavior ourselves |
| - | // Types can be a map of types/handlers |
| - | if ( typeof types === "object" ) { |
| - | // ( types-Object, selector, data ) |
| - | if ( typeof selector !== "string" ) { |
| - | // ( types-Object, data ) |
| - | data = data || selector; |
| - | selector = undefined; |
| - | } |
| - | for ( type in types ) { |
| - | this.on( type, selector, data, types[ type ], one ); |
| - | } |
| - | return this; |
| - | } |
| + | // Gets all values |
| + | if ( key === undefined ) { |
| + | if ( this.length ) { |
| + | data = jQuery.data( elem ); |
| - | if ( data == null && fn == null ) { |
| - | // ( types, fn ) |
| - | fn = selector; |
| - | data = selector = undefined; |
| - | } else if ( fn == null ) { |
| - | if ( typeof selector === "string" ) { |
| - | // ( types, selector, fn ) |
| - | fn = data; |
| - | data = undefined; |
| - | } else { |
| - | // ( types, data, fn ) |
| - | fn = data; |
| - | data = selector; |
| - | selector = undefined; |
| - | } |
| - | } |
| - | if ( fn === false ) { |
| - | fn = returnFalse; |
| - | } else if ( !fn ) { |
| - | return this; |
| - | } |
| + | if ( elem.nodeType === 1 && !jQuery._data( elem, "parsedAttrs" ) ) { |
| + | attrs = elem.attributes; |
| + | for ( ; i < attrs.length; i++ ) { |
| + | name = attrs[i].name; |
| - | if ( one === 1 ) { |
| - | origFn = fn; |
| - | fn = function( event ) { |
| - | // Can use an empty set, since event contains the info |
| - | jQuery().off( event ); |
| - | return origFn.apply( this, arguments ); |
| - | }; |
| - | // Use same guid so caller can remove using origFn |
| - | fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); |
| - | } |
| - | return this.each( function() { |
| - | jQuery.event.add( this, types, fn, data, selector ); |
| - | }); |
| - | }, |
| - | one: function( types, selector, data, fn ) { |
| - | return this.on( types, selector, data, fn, 1 ); |
| - | }, |
| - | off: function( types, selector, fn ) { |
| - | var handleObj, type; |
| - | if ( types && types.preventDefault && types.handleObj ) { |
| - | // ( event ) dispatched jQuery.Event |
| - | handleObj = types.handleObj; |
| - | jQuery( types.delegateTarget ).off( |
| - | handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, |
| - | handleObj.selector, |
| - | handleObj.handler |
| - | ); |
| - | return this; |
| - | } |
| - | if ( typeof types === "object" ) { |
| - | // ( types-object [, selector] ) |
| - | for ( type in types ) { |
| - | this.off( type, selector, types[ type ] ); |
| + | if ( name.indexOf("data-") === 0 ) { |
| + | name = jQuery.camelCase( name.slice(5) ); |
| + | |
| + | dataAttr( elem, name, data[ name ] ); |
| + | } |
| + | } |
| + | jQuery._data( elem, "parsedAttrs", true ); |
| + | } |
| } | |
| - | return this; |
| - | } |
| - | if ( selector === false || typeof selector === "function" ) { |
| - | // ( types [, fn] ) |
| - | fn = selector; |
| - | selector = undefined; |
| + | |
| + | return data; |
| } | |
| - | if ( fn === false ) { |
| - | fn = returnFalse; |
| + | |
| + | // Sets multiple values |
| + | if ( typeof key === "object" ) { |
| + | return this.each(function() { |
| + | jQuery.data( this, key ); |
| + | }); |
| } | |
| - | return this.each(function() { |
| - | jQuery.event.remove( this, types, fn, selector ); |
| - | }); |
| - | }, |
| - | bind: function( types, data, fn ) { |
| - | return this.on( types, null, data, fn ); |
| - | }, |
| - | unbind: function( types, fn ) { |
| - | return this.off( types, null, fn ); |
| - | }, |
| + | return arguments.length > 1 ? |
| - | delegate: function( selector, types, data, fn ) { |
| - | return this.on( types, selector, data, fn ); |
| - | }, |
| - | undelegate: function( selector, types, fn ) { |
| - | // ( namespace ) or ( selector, types [, fn] ) |
| - | return arguments.length === 1 ? this.off( selector, "**" ) : this.off( types, selector || "**", fn ); |
| + | // Sets one value |
| + | this.each(function() { |
| + | jQuery.data( this, key, value ); |
| + | }) : |
| + | |
| + | // Gets one value |
| + | // Try to fetch any internally stored data first |
| + | elem ? dataAttr( elem, key, jQuery.data( elem, key ) ) : null; |
| }, | |
| - | trigger: function( type, data ) { |
| + | removeData: function( key ) { |
| return this.each(function() { | |
| - | jQuery.event.trigger( type, data, this ); |
| + | jQuery.removeData( this, key ); |
| }); | |
| - | }, |
| - | triggerHandler: function( type, data ) { |
| - | var elem = this[0]; |
| - | if ( elem ) { |
| - | return jQuery.event.trigger( type, data, elem, true ); |
| - | } |
| } | |
| }); | |
| - | /*! |
| - | * Sizzle CSS Selector Engine |
| - | * Copyright 2012 jQuery Foundation and other contributors |
| - | * Released under the MIT license |
| - | * http://sizzlejs.com/ |
| - | */ |
| - | (function( window, undefined ) { |
| - | var i, |
| - | cachedruns, |
| - | Expr, |
| - | getText, |
| - | isXML, |
| - | compile, |
| - | hasDuplicate, |
| - | outermostContext, |
| + | function dataAttr( elem, key, data ) { |
| + | // If nothing was found internally, try to fetch any |
| + | // data from the HTML5 data-* attribute |
| + | if ( data === undefined && elem.nodeType === 1 ) { |
| - | // Local document vars |
| - | setDocument, |
| - | document, |
| - | docElem, |
| - | documentIsXML, |
| - | rbuggyQSA, |
| - | rbuggyMatches, |
| - | matches, |
| - | contains, |
| - | sortOrder, |
| + | var name = "data-" + key.replace( rmultiDash, "-$1" ).toLowerCase(); |
| + | |
| + | data = elem.getAttribute( name ); |
| + | |
| + | if ( typeof data === "string" ) { |
| + | try { |
| + | data = data === "true" ? true : |
| + | data === "false" ? false : |
| + | data === "null" ? null : |
| + | // Only convert to a number if it doesn't change the string |
| + | +data + "" === data ? +data : |
| + | rbrace.test( data ) ? jQuery.parseJSON( data ) : |
| + | data; |
| + | } catch( e ) {} |
| + | |
| + | // Make sure we set the data so it isn't changed later |
| + | jQuery.data( elem, key, data ); |
| + | |
| + | } else { |
| + | data = undefined; |
| + | } |
| + | } |
| + | |
| + | return data; |
| + | } |
| + | |
| + | // checks a cache object for emptiness |
| + | function isEmptyDataObject( obj ) { |
| + | var name; |
| + | for ( name in obj ) { |
| - | // Instance-specific data |
| - | expando = "sizzle" + -(new Date()), |
| - | preferredDoc = window.document, |
| - | support = {}, |
| - | dirruns = 0, |
| - | done = 0, |
| - | classCache = createCache(), |
| - | tokenCache = createCache(), |
| - | compilerCache = createCache(), |
| + | // if the public data object is empty, the private is still empty |
| + | if ( name === "data" && jQuery.isEmptyObject( obj[name] ) ) { |
| + | continue; |
| + | } |
| + | if ( name !== "toJSON" ) { |
| + | return false; |
| + | } |
| + | } |
| - | // General-purpose constants |
| - | strundefined = typeof undefined, |
| - | MAX_NEGATIVE = 1 << 31, |
| + | return true; |
| + | } |
| + | jQuery.extend({ |
| + | queue: function( elem, type, data ) { |
| + | var queue; |
| - | // Array methods |
| - | arr = [], |
| - | pop = arr.pop, |
| - | push = arr.push, |
| - | slice = arr.slice, |
| - | // Use a stripped-down indexOf if we can't use a native one |
| - | indexOf = arr.indexOf || function( elem ) { |
| - | var i = 0, |
| - | len = this.length; |
| - | for ( ; i < len; i++ ) { |
| - | if ( this[i] === elem ) { |
| - | return i; |
| + | if ( elem ) { |
| + | type = ( type || "fx" ) + "queue"; |
| + | queue = jQuery._data( elem, type ); |
| + | |
| + | // Speed up dequeue by getting out quickly if this is just a lookup |
| + | if ( data ) { |
| + | if ( !queue || jQuery.isArray(data) ) { |
| + | queue = jQuery._data( elem, type, jQuery.makeArray(data) ); |
| + | } else { |
| + | queue.push( data ); |
| + | } |
| } | |
| + | return queue || []; |
| } | |
| - | return -1; |
| }, | |
| + | dequeue: function( elem, type ) { |
| + | type = type || "fx"; |
| - | // Regular expressions |
| + | var queue = jQuery.queue( elem, type ), |
| + | startLength = queue.length, |
| + | fn = queue.shift(), |
| + | hooks = jQuery._queueHooks( elem, type ), |
| + | next = function() { |
| + | jQuery.dequeue( elem, type ); |
| + | }; |
| - | // Whitespace characters http://www.w3.org/TR/css3-selectors/#whitespace |
| - | whitespace = "[\\x20\\t\\r\\n\\f]", |
| - | // http://www.w3.org/TR/css3-syntax/#characters |
| - | characterEncoding = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+", |
| + | // If the fx queue is dequeued, always remove the progress sentinel |
| + | if ( fn === "inprogress" ) { |
| + | fn = queue.shift(); |
| + | startLength--; |
| + | } |
| - | // Loosely modeled on CSS identifier characters |
| - | // An unquoted value should be a CSS identifier http://www.w3.org/TR/css3-selectors/#attribute-selectors |
| - | // Proper syntax: http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier |
| - | identifier = characterEncoding.replace( "w", "w#" ), |
| + | if ( fn ) { |
| - | // Acceptable operators http://www.w3.org/TR/selectors/#attribute-selectors |
| - | operators = "([*^$|!~]?=)", |
| - | attributes = "\\[" + whitespace + "*(" + characterEncoding + ")" + whitespace + |
| - | "*(?:" + operators + whitespace + "*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|(" + identifier + ")|)|)" + whitespace + "*\\]", |
| + | // Add a progress sentinel to prevent the fx queue from being |
| + | // automatically dequeued |
| + | if ( type === "fx" ) { |
| + | queue.unshift( "inprogress" ); |
| + | } |
| - | // Prefer arguments quoted, |
| - | // then not containing pseudos/brackets, |
| - | // then attribute selectors/non-parenthetical expressions, |
| - | // then anything else |
| - | // These preferences are here to reduce the number of selectors |
| - | // needing tokenize in the PSEUDO preFilter |
| - | pseudos = ":(" + characterEncoding + ")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|" + attributes.replace( 3, 8 ) + ")*)|.*)\\)|)", |
| + | // clear up the last queue stop function |
| + | delete hooks.stop; |
| + | fn.call( elem, next, hooks ); |
| + | } |
| - | // Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter |
| - | rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + whitespace + "+$", "g" ), |
| + | if ( !startLength && hooks ) { |
| + | hooks.empty.fire(); |
| + | } |
| + | }, |
| - | rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ), |
| - | rcombinators = new RegExp( "^" + whitespace + "*([\\x20\\t\\r\\n\\f>+~])" + whitespace + "*" ), |
| - | rpseudo = new RegExp( pseudos ), |
| - | ridentifier = new RegExp( "^" + identifier + "$" ), |
| + | // not intended for public consumption - generates a queueHooks object, or returns the current one |
| + | _queueHooks: function( elem, type ) { |
| + | var key = type + "queueHooks"; |
| + | return jQuery._data( elem, key ) || jQuery._data( elem, key, { |
| + | empty: jQuery.Callbacks("once memory").add(function() { |
| + | jQuery._removeData( elem, type + "queue" ); |
| + | jQuery._removeData( elem, key ); |
| + | }) |
| + | }); |
| + | } |
| + | }); |
| - | matchExpr = { |
| - | "ID": new RegExp( "^#(" + characterEncoding + ")" ), |
| - | "CLASS": new RegExp( "^\\.(" + characterEncoding + ")" ), |
| - | "NAME": new RegExp( "^\\[name=['\"]?(" + characterEncoding + ")['\"]?\\]" ), |
| - | "TAG": new RegExp( "^(" + characterEncoding.replace( "w", "w*" ) + ")" ), |
| - | "ATTR": new RegExp( "^" + attributes ), |
| - | "PSEUDO": new RegExp( "^" + pseudos ), |
| - | "CHILD": new RegExp( "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + whitespace + |
| - | "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" + whitespace + |
| - | "*(\\d+)|))" + whitespace + "*\\)|)", "i" ), |
| - | // For use in libraries implementing .is() |
| - | // We use this for POS matching in `select` |
| - | "needsContext": new RegExp( "^" + whitespace + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + |
| - | whitespace + "*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i" ) |
| - | }, |
| + | jQuery.fn.extend({ |
| + | queue: function( type, data ) { |
| + | var setter = 2; |
| - | rsibling = /[\x20\t\r\n\f]*[+~]/, |
| + | if ( typeof type !== "string" ) { |
| + | data = type; |
| + | type = "fx"; |
| + | setter--; |
| + | } |
| - | rnative = /^[^{]+\{\s*\[native code/, |
| + | if ( arguments.length < setter ) { |
| + | return jQuery.queue( this[0], type ); |
| + | } |
| - | // Easily-parseable/retrievable ID or TAG or CLASS selectors |
| - | rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, |
| + | return data === undefined ? |
| + | this : |
| + | this.each(function() { |
| + | var queue = jQuery.queue( this, type, data ); |
| - | rinputs = /^(?:input|select|textarea|button)$/i, |
| - | rheader = /^h\d$/i, |
| + | // ensure a hooks for this queue |
| + | jQuery._queueHooks( this, type ); |
| - | rescape = /'|\\/g, |
| - | rattributeQuotes = /\=[\x20\t\r\n\f]*([^'"\]]*)[\x20\t\r\n\f]*\]/g, |
| + | if ( type === "fx" && queue[0] !== "inprogress" ) { |
| + | jQuery.dequeue( this, type ); |
| + | } |
| + | }); |
| + | }, |
| + | dequeue: function( type ) { |
| + | return this.each(function() { |
| + | jQuery.dequeue( this, type ); |
| + | }); |
| + | }, |
| + | // Based off of the plugin by Clint Helfers, with permission. |
| + | // http://blindsignals.com/index.php/2009/07/jquery-delay/ |
| + | delay: function( time, type ) { |
| + | time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time; |
| + | type = type || "fx"; |
| - | // CSS escapes http://www.w3.org/TR/CSS21/syndata.html#escaped-characters |
| - | runescape = /\\([\da-fA-F]{1,6}[\x20\t\r\n\f]?|.)/g, |
| - | funescape = function( _, escaped ) { |
| - | var high = "0x" + escaped - 0x10000; |
| - | // NaN means non-codepoint |
| - | return high !== high ? |
| - | escaped : |
| - | // BMP codepoint |
| - | high < 0 ? |
| - | String.fromCharCode( high + 0x10000 ) : |
| - | // Supplemental Plane codepoint (surrogate pair) |
| - | String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 ); |
| - | }; |
| + | return this.queue( type, function( next, hooks ) { |
| + | var timeout = setTimeout( next, time ); |
| + | hooks.stop = function() { |
| + | clearTimeout( timeout ); |
| + | }; |
| + | }); |
| + | }, |
| + | clearQueue: function( type ) { |
| + | return this.queue( type || "fx", [] ); |
| + | }, |
| + | // Get a promise resolved when queues of a certain type |
| + | // are emptied (fx is the type by default) |
| + | promise: function( type, obj ) { |
| + | var tmp, |
| + | count = 1, |
| + | defer = jQuery.Deferred(), |
| + | elements = this, |
| + | i = this.length, |
| + | resolve = function() { |
| + | if ( !( --count ) ) { |
| + | defer.resolveWith( elements, [ elements ] ); |
| + | } |
| + | }; |
| - | // Use a stripped-down slice if we can't use a native one |
| - | try { |
| - | slice.call( preferredDoc.documentElement.childNodes, 0 )[0].nodeType; |
| - | } catch ( e ) { |
| - | slice = function( i ) { |
| - | var elem, |
| - | results = []; |
| - | while ( (elem = this[i++]) ) { |
| - | results.push( elem ); |
| + | if ( typeof type !== "string" ) { |
| + | obj = type; |
| + | type = undefined; |
| } | |
| - | return results; |
| - | }; |
| - | } |
| + | type = type || "fx"; |
| - | /** |
| - | * For feature detection |
| - | * @param {Function} fn The function to test for native support |
| - | */ |
| - | function isNative( fn ) { |
| - | return rnative.test( fn + "" ); |
| - | } |
| + | while( i-- ) { |
| + | tmp = jQuery._data( elements[ i ], type + "queueHooks" ); |
| + | if ( tmp && tmp.empty ) { |
| + | count++; |
| + | tmp.empty.add( resolve ); |
| + | } |
| + | } |
| + | resolve(); |
| + | return defer.promise( obj ); |
| + | } |
| + | }); |
| + | var nodeHook, boolHook, |
| + | rclass = /[\t\r\n\f]/g, |
| + | rreturn = /\r/g, |
| + | rfocusable = /^(?:input|select|textarea|button|object)$/i, |
| + | rclickable = /^(?:a|area)$/i, |
| + | ruseDefault = /^(?:checked|selected)$/i, |
| + | getSetAttribute = jQuery.support.getSetAttribute, |
| + | getSetInput = jQuery.support.input; |
| - | /** |
| - | * Create key-value caches of limited size |
| - | * @returns {Function(string, Object)} Returns the Object data after storing it on itself with |
| - | * property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength) |
| - | * deleting the oldest entry |
| - | */ |
| - | function createCache() { |
| - | var cache, |
| - | keys = []; |
| + | jQuery.fn.extend({ |
| + | attr: function( name, value ) { |
| + | return jQuery.access( this, jQuery.attr, name, value, arguments.length > 1 ); |
| + | }, |
| + | |
| + | removeAttr: function( name ) { |
| + | return this.each(function() { |
| + | jQuery.removeAttr( this, name ); |
| + | }); |
| + | }, |
| + | |
| + | prop: function( name, value ) { |
| + | return jQuery.access( this, jQuery.prop, name, value, arguments.length > 1 ); |
| + | }, |
| + | |
| + | removeProp: function( name ) { |
| + | name = jQuery.propFix[ name ] || name; |
| + | return this.each(function() { |
| + | // try/catch handles cases where IE balks (such as removing a property on window) |
| + | try { |
| + | this[ name ] = undefined; |
| + | delete this[ name ]; |
| + | } catch( e ) {} |
| + | }); |
| + | }, |
| - | return (cache = function( key, value ) { |
| - | // Use (key + " ") to avoid collision with native prototype properties (see Issue #157) |
| - | if ( keys.push( key += " " ) > Expr.cacheLength ) { |
| - | // Only keep the most recent entries |
| - | delete cache[ keys.shift() ]; |
| - | } |
| - | return (cache[ key ] = value); |
| - | }); |
| - | } |
| + | addClass: function( value ) { |
| + | var classes, elem, cur, clazz, j, |
| + | i = 0, |
| + | len = this.length, |
| + | proceed = typeof value === "string" && value; |
| - | /** |
| - | * Mark a function for special use by Sizzle |
| - | * @param {Function} fn The function to mark |
| - | */ |
| - | function markFunction( fn ) { |
| - | fn[ expando ] = true; |
| - | return fn; |
| - | } |
| + | if ( jQuery.isFunction( value ) ) { |
| + | return this.each(function( j ) { |
| + | jQuery( this ).addClass( value.call( this, j, this.className ) ); |
| + | }); |
| + | } |
| - | /** |
| - | * Support testing using an element |
| - | * @param {Function} fn Passed the created div and expects a boolean result |
| - | */ |
| - | function assert( fn ) { |
| - | var div = document.createElement("div"); |
| + | if ( proceed ) { |
| + | // The disjunction here is for better compressibility (see removeClass) |
| + | classes = ( value || "" ).match( core_rnotwhite ) || []; |
| - | try { |
| - | return fn( div ); |
| - | } catch (e) { |
| - | return false; |
| - | } finally { |
| - | // release memory in IE |
| - | div = null; |
| - | } |
| - | } |
| + | for ( ; i < len; i++ ) { |
| + | elem = this[ i ]; |
| + | cur = elem.nodeType === 1 && ( elem.className ? |
| + | ( " " + elem.className + " " ).replace( rclass, " " ) : |
| + | " " |
| + | ); |
| - | function Sizzle( selector, context, results, seed ) { |
| - | var match, elem, m, nodeType, |
| - | // QSA vars |
| - | i, groups, old, nid, newContext, newSelector; |
| + | if ( cur ) { |
| + | j = 0; |
| + | while ( (clazz = classes[j++]) ) { |
| + | if ( cur.indexOf( " " + clazz + " " ) < 0 ) { |
| + | cur += clazz + " "; |
| + | } |
| + | } |
| + | elem.className = jQuery.trim( cur ); |
| - | if ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) { |
| - | setDocument( context ); |
| - | } |
| + | } |
| + | } |
| + | } |
| - | context = context || document; |
| - | results = results || []; |
| + | return this; |
| + | }, |
| - | if ( !selector || typeof selector !== "string" ) { |
| - | return results; |
| - | } |
| + | removeClass: function( value ) { |
| + | var classes, elem, cur, clazz, j, |
| + | i = 0, |
| + | len = this.length, |
| + | proceed = arguments.length === 0 || typeof value === "string" && value; |
| - | if ( (nodeType = context.nodeType) !== 1 && nodeType !== 9 ) { |
| - | return []; |
| - | } |
| + | if ( jQuery.isFunction( value ) ) { |
| + | return this.each(function( j ) { |
| + | jQuery( this ).removeClass( value.call( this, j, this.className ) ); |
| + | }); |
| + | } |
| + | if ( proceed ) { |
| + | classes = ( value || "" ).match( core_rnotwhite ) || []; |
| - | if ( !documentIsXML && !seed ) { |
| + | for ( ; i < len; i++ ) { |
| + | elem = this[ i ]; |
| + | // This expression is here for better compressibility (see addClass) |
| + | cur = elem.nodeType === 1 && ( elem.className ? |
| + | ( " " + elem.className + " " ).replace( rclass, " " ) : |
| + | "" |
| + | ); |
| - | // Shortcuts |
| - | if ( (match = rquickExpr.exec( selector )) ) { |
| - | // Speed-up: Sizzle("#ID") |
| - | if ( (m = match[1]) ) { |
| - | if ( nodeType === 9 ) { |
| - | elem = context.getElementById( m ); |
| - | // Check parentNode to catch when Blackberry 4.6 returns |
| - | // nodes that are no longer in the document #6963 |
| - | if ( elem && elem.parentNode ) { |
| - | // Handle the case where IE, Opera, and Webkit return items |
| - | // by name instead of ID |
| - | if ( elem.id === m ) { |
| - | results.push( elem ); |
| - | return results; |
| + | if ( cur ) { |
| + | j = 0; |
| + | while ( (clazz = classes[j++]) ) { |
| + | // Remove *all* instances |
| + | while ( cur.indexOf( " " + clazz + " " ) >= 0 ) { |
| + | cur = cur.replace( " " + clazz + " ", " " ); |
| } | |
| - | } else { |
| - | return results; |
| - | } |
| - | } else { |
| - | // Context is not a document |
| - | if ( context.ownerDocument && (elem = context.ownerDocument.getElementById( m )) && |
| - | contains( context, elem ) && elem.id === m ) { |
| - | results.push( elem ); |
| - | return results; |
| } | |
| + | elem.className = value ? jQuery.trim( cur ) : ""; |
| } | |
| + | } |
| + | } |
| - | // Speed-up: Sizzle("TAG") |
| - | } else if ( match[2] ) { |
| - | push.apply( results, slice.call(context.getElementsByTagName( selector ), 0) ); |
| - | return results; |
| + | return this; |
| + | }, |
| - | // Speed-up: Sizzle(".CLASS") |
| - | } else if ( (m = match[3]) && support.getByClassName && context.getElementsByClassName ) { |
| - | push.apply( results, slice.call(context.getElementsByClassName( m ), 0) ); |
| - | return results; |
| - | } |
| + | toggleClass: function( value, stateVal ) { |
| + | var type = typeof value; |
| + | |
| + | if ( typeof stateVal === "boolean" && type === "string" ) { |
| + | return stateVal ? this.addClass( value ) : this.removeClass( value ); |
| } | |
| - | // QSA path |
| - | if ( support.qsa && !rbuggyQSA.test(selector) ) { |
| - | old = true; |
| - | nid = expando; |
| - | newContext = context; |
| - | newSelector = nodeType === 9 && selector; |
| + | if ( jQuery.isFunction( value ) ) { |
| + | return this.each(function( i ) { |
| + | jQuery( this ).toggleClass( value.call(this, i, this.className, stateVal), stateVal ); |
| + | }); |
| + | } |
| - | // qSA works strangely on Element-rooted queries |
| - | // We can work around this by specifying an extra ID on the root |
| - | // and working up from there (Thanks to Andrew Dupont for the technique) |
| - | // IE 8 doesn't work on object elements |
| - | if ( nodeType === 1 && context.nodeName.toLowerCase() !== "object" ) { |
| - | groups = tokenize( selector ); |
| + | return this.each(function() { |
| + | if ( type === "string" ) { |
| + | // toggle individual class names |
| + | var className, |
| + | i = 0, |
| + | self = jQuery( this ), |
| + | classNames = value.match( core_rnotwhite ) || []; |
| - | if ( (old = context.getAttribute("id")) ) { |
| - | nid = old.replace( rescape, "\\$&" ); |
| - | } else { |
| - | context.setAttribute( "id", nid ); |
| + | while ( (className = classNames[ i++ ]) ) { |
| + | // check each className given, space separated list |
| + | if ( self.hasClass( className ) ) { |
| + | self.removeClass( className ); |
| + | } else { |
| + | self.addClass( className ); |
| + | } |
| } | |
| - | nid = "[id='" + nid + "'] "; |
| - | i = groups.length; |
| - | while ( i-- ) { |
| - | groups[i] = nid + toSelector( groups[i] ); |
| + | // Toggle whole class name |
| + | } else if ( type === core_strundefined || type === "boolean" ) { |
| + | if ( this.className ) { |
| + | // store className if set |
| + | jQuery._data( this, "__className__", this.className ); |
| } | |
| - | newContext = rsibling.test( selector ) && context.parentNode || context; |
| - | newSelector = groups.join(","); |
| + | |
| + | // If the element has a class name or if we're passed "false", |
| + | // then remove the whole classname (if there was one, the above saved it). |
| + | // Otherwise bring back whatever was previously saved (if anything), |
| + | // falling back to the empty string if nothing was stored. |
| + | this.className = this.className || value === false ? "" : jQuery._data( this, "__className__" ) || ""; |
| } | |
| + | }); |
| + | }, |
| - | if ( newSelector ) { |
| - | try { |
| - | push.apply( results, slice.call( newContext.querySelectorAll( |
| - | newSelector |
| - | ), 0 ) ); |
| - | return results; |
| - | } catch(qsaError) { |
| - | } finally { |
| - | if ( !old ) { |
| - | context.removeAttribute("id"); |
| - | } |
| - | } |
| + | hasClass: function( selector ) { |
| + | var className = " " + selector + " ", |
| + | i = 0, |
| + | l = this.length; |
| + | for ( ; i < l; i++ ) { |
| + | if ( this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) >= 0 ) { |
| + | return true; |
| } | |
| } | |
| - | } |
| - | // All others |
| - | return select( selector.replace( rtrim, "$1" ), context, results, seed ); |
| - | } |
| - | |
| - | /** |
| - | * Detect xml |
| - | * @param {Element|Object} elem An element or a document |
| - | */ |
| - | isXML = Sizzle.isXML = function( elem ) { |
| - | // documentElement is verified for cases where it doesn't yet exist |
| - | // (such as loading iframes in IE - #4833) |
| - | var documentElement = elem && (elem.ownerDocument || elem).documentElement; |
| - | return documentElement ? documentElement.nodeName !== "HTML" : false; |
| - | }; |
| - | |
| - | /** |
| - | * Sets document-related variables once based on the current document |
| - | * @param {Element|Object} [doc] An element or document object to use to set the document |
| - | * @returns {Object} Returns the current document |
| - | */ |
| - | setDocument = Sizzle.setDocument = function( node ) { |
| - | var doc = node ? node.ownerDocument || node : preferredDoc; |
| + | return false; |
| + | }, |
| - | // If no document and documentElement is available, return |
| - | if ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) { |
| - | return document; |
| - | } |
| + | val: function( value ) { |
| + | var ret, hooks, isFunction, |
| + | elem = this[0]; |
| - | // Set our document |
| - | document = doc; |
| - | docElem = doc.documentElement; |
| + | if ( !arguments.length ) { |
| + | if ( elem ) { |
| + | hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; |
| - | // Support tests |
| - | documentIsXML = isXML( doc ); |
| + | if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { |
| + | return ret; |
| + | } |
| - | // Check if getElementsByTagName("*") returns only elements |
| - | support.tagNameNoComments = assert(function( div ) { |
| - | div.appendChild( doc.createComment("") ); |
| - | return !div.getElementsByTagName("*").length; |
| - | }); |
| + | ret = elem.value; |
| - | // Check if attributes should be retrieved by attribute nodes |
| - | support.attributes = assert(function( div ) { |
| - | div.innerHTML = "<select></select>"; |
| - | var type = typeof div.lastChild.getAttribute("multiple"); |
| - | // IE8 returns a string for some attributes even when not present |
| - | return type !== "boolean" && type !== "string"; |
| - | }); |
| + | return typeof ret === "string" ? |
| + | // handle most common string cases |
| + | ret.replace(rreturn, "") : |
| + | // handle cases where value is null/undef or number |
| + | ret == null ? "" : ret; |
| + | } |
| - | // Check if getElementsByClassName can be trusted |
| - | support.getByClassName = assert(function( div ) { |
| - | // Opera can't find a second classname (in 9.6) |
| - | div.innerHTML = "<div class='hidden e'></div><div class='hidden'></div>"; |
| - | if ( !div.getElementsByClassName || !div.getElementsByClassName("e").length ) { |
| - | return false; |
| + | return; |
| } | |
| - | // Safari 3.2 caches class attributes and doesn't catch changes |
| - | div.lastChild.className = "e"; |
| - | return div.getElementsByClassName("e").length === 2; |
| - | }); |
| + | isFunction = jQuery.isFunction( value ); |
| - | // Check if getElementById returns elements by name |
| - | // Check if getElementsByName privileges form controls or returns elements by ID |
| - | support.getByName = assert(function( div ) { |
| - | // Inject content |
| - | div.id = expando + 0; |
| - | div.innerHTML = "<a name='" + expando + "'></a><div name='" + expando + "'></div>"; |
| - | docElem.insertBefore( div, docElem.firstChild ); |
| - | |
| - | // Test |
| - | var pass = doc.getElementsByName && |
| - | // buggy browsers will return fewer than the correct 2 |
| - | doc.getElementsByName( expando ).length === 2 + |
| - | // buggy browsers will return more than the correct 0 |
| - | doc.getElementsByName( expando + 0 ).length; |
| - | support.getIdNotName = !doc.getElementById( expando ); |
| - | |
| - | // Cleanup |
| - | docElem.removeChild( div ); |
| - | |
| - | return pass; |
| - | }); |
| + | return this.each(function( i ) { |
| + | var val; |
| - | // IE6/7 return modified attributes |
| - | Expr.attrHandle = assert(function( div ) { |
| - | div.innerHTML = "<a href='#'></a>"; |
| - | return div.firstChild && typeof div.firstChild.getAttribute !== strundefined && |
| - | div.firstChild.getAttribute("href") === "#"; |
| - | }) ? |
| - | {} : |
| - | { |
| - | "href": function( elem ) { |
| - | return elem.getAttribute( "href", 2 ); |
| - | }, |
| - | "type": function( elem ) { |
| - | return elem.getAttribute("type"); |
| + | if ( this.nodeType !== 1 ) { |
| + | return; |
| } | |
| - | }; |
| - | // ID find and filter |
| - | if ( support.getIdNotName ) { |
| - | Expr.find["ID"] = function( id, context ) { |
| - | if ( typeof context.getElementById !== strundefined && !documentIsXML ) { |
| - | var m = context.getElementById( id ); |
| - | // Check parentNode to catch when Blackberry 4.6 returns |
| - | // nodes that are no longer in the document #6963 |
| - | return m && m.parentNode ? [m] : []; |
| + | if ( isFunction ) { |
| + | val = value.call( this, i, jQuery( this ).val() ); |
| + | } else { |
| + | val = value; |
| } | |
| - | }; |
| - | Expr.filter["ID"] = function( id ) { |
| - | var attrId = id.replace( runescape, funescape ); |
| - | return function( elem ) { |
| - | return elem.getAttribute("id") === attrId; |
| - | }; |
| - | }; |
| - | } else { |
| - | Expr.find["ID"] = function( id, context ) { |
| - | if ( typeof context.getElementById !== strundefined && !documentIsXML ) { |
| - | var m = context.getElementById( id ); |
| - | return m ? |
| - | m.id === id || typeof m.getAttributeNode !== strundefined && m.getAttributeNode("id").value === id ? |
| - | [m] : |
| - | undefined : |
| - | []; |
| + | // Treat null/undefined as ""; convert numbers to string |
| + | if ( val == null ) { |
| + | val = ""; |
| + | } else if ( typeof val === "number" ) { |
| + | val += ""; |
| + | } else if ( jQuery.isArray( val ) ) { |
| + | val = jQuery.map(val, function ( value ) { |
| + | return value == null ? "" : value + ""; |
| + | }); |
| } | |
| - | }; |
| - | Expr.filter["ID"] = function( id ) { |
| - | var attrId = id.replace( runescape, funescape ); |
| - | return function( elem ) { |
| - | var node = typeof elem.getAttributeNode !== strundefined && elem.getAttributeNode("id"); |
| - | return node && node.value === attrId; |
| - | }; |
| - | }; |
| + | |
| + | hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; |
| + | |
| + | // If set returns undefined, fall back to normal setting |
| + | if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { |
| + | this.value = val; |
| + | } |
| + | }); |
| } | |
| + | }); |
| - | // Tag |
| - | Expr.find["TAG"] = support.tagNameNoComments ? |
| - | function( tag, context ) { |
| - | if ( typeof context.getElementsByTagName !== strundefined ) { |
| - | return context.getElementsByTagName( tag ); |
| + | jQuery.extend({ |
| + | valHooks: { |
| + | option: { |
| + | get: function( elem ) { |
| + | // Use proper attribute retrieval(#6932, #12072) |
| + | var val = jQuery.find.attr( elem, "value" ); |
| + | return val != null ? |
| + | val : |
| + | elem.text; |
| } | |
| - | } : |
| - | function( tag, context ) { |
| - | var elem, |
| - | tmp = [], |
| - | i = 0, |
| - | results = context.getElementsByTagName( tag ); |
| + | }, |
| + | select: { |
| + | get: function( elem ) { |
| + | var value, option, |
| + | options = elem.options, |
| + | index = elem.selectedIndex, |
| + | one = elem.type === "select-one" || index < 0, |
| + | values = one ? null : [], |
| + | max = one ? index + 1 : options.length, |
| + | i = index < 0 ? |
| + | max : |
| + | one ? index : 0; |
| - | // Filter out possible comments |
| - | if ( tag === "*" ) { |
| - | while ( (elem = results[i++]) ) { |
| - | if ( elem.nodeType === 1 ) { |
| - | tmp.push( elem ); |
| + | // Loop through all the selected options |
| + | for ( ; i < max; i++ ) { |
| + | option = options[ i ]; |
| + | |
| + | // oldIE doesn't update selected after form reset (#2551) |
| + | if ( ( option.selected || i === index ) && |
| + | // Don't return options that are disabled or in a disabled optgroup |
| + | ( jQuery.support.optDisabled ? !option.disabled : option.getAttribute("disabled") === null ) && |
| + | ( !option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" ) ) ) { |
| + | |
| + | // Get the specific value for the option |
| + | value = jQuery( option ).val(); |
| + | |
| + | // We don't need an array for one selects |
| + | if ( one ) { |
| + | return value; |
| + | } |
| + | |
| + | // Multi-Selects return an array |
| + | values.push( value ); |
| } | |
| } | |
| - | return tmp; |
| - | } |
| - | return results; |
| - | }; |
| + | return values; |
| + | }, |
| - | // Name |
| - | Expr.find["NAME"] = support.getByName && function( tag, context ) { |
| - | if ( typeof context.getElementsByName !== strundefined ) { |
| - | return context.getElementsByName( name ); |
| - | } |
| - | }; |
| + | set: function( elem, value ) { |
| + | var optionSet, option, |
| + | options = elem.options, |
| + | values = jQuery.makeArray( value ), |
| + | i = options.length; |
| - | // Class |
| - | Expr.find["CLASS"] = support.getByClassName && function( className, context ) { |
| - | if ( typeof context.getElementsByClassName !== strundefined && !documentIsXML ) { |
| - | return context.getElementsByClassName( className ); |
| - | } |
| - | }; |
| + | while ( i-- ) { |
| + | option = options[ i ]; |
| + | if ( (option.selected = jQuery.inArray( jQuery(option).val(), values ) >= 0) ) { |
| + | optionSet = true; |
| + | } |
| + | } |
| - | // QSA and matchesSelector support |
| + | // force browsers to behave consistently when non-matching value is set |
| + | if ( !optionSet ) { |
| + | elem.selectedIndex = -1; |
| + | } |
| + | return values; |
| + | } |
| + | } |
| + | }, |
| - | // matchesSelector(:active) reports false when true (IE9/Opera 11.5) |
| - | rbuggyMatches = []; |
| + | attr: function( elem, name, value ) { |
| + | var hooks, ret, |
| + | nType = elem.nodeType; |
| - | // qSa(:focus) reports false when true (Chrome 21), |
| - | // no need to also add to buggyMatches since matches checks buggyQSA |
| - | // A support test would require too much code (would include document ready) |
| - | rbuggyQSA = [ ":focus" ]; |
| + | // don't get/set attributes on text, comment and attribute nodes |
| + | if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
| + | return; |
| + | } |
| - | if ( (support.qsa = isNative(doc.querySelectorAll)) ) { |
| - | // Build QSA regex |
| - | // Regex strategy adopted from Diego Perini |
| - | assert(function( div ) { |
| - | // Select is set to empty string on purpose |
| - | // This is to test IE's treatment of not explictly |
| - | // setting a boolean content attribute, |
| - | // since its presence should be enough |
| - | // http://bugs.jquery.com/ticket/12359 |
| - | div.innerHTML = "<select><option selected=''></option></select>"; |
| + | // Fallback to prop when attributes are not supported |
| + | if ( typeof elem.getAttribute === core_strundefined ) { |
| + | return jQuery.prop( elem, name, value ); |
| + | } |
| - | // IE8 - Some boolean attributes are not treated correctly |
| - | if ( !div.querySelectorAll("[selected]").length ) { |
| - | rbuggyQSA.push( "\\[" + whitespace + "*(?:checked|disabled|ismap|multiple|readonly|selected|value)" ); |
| - | } |
| + | // All attributes are lowercase |
| + | // Grab necessary hook if one is defined |
| + | if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) { |
| + | name = name.toLowerCase(); |
| + | hooks = jQuery.attrHooks[ name ] || |
| + | ( jQuery.expr.match.bool.test( name ) ? boolHook : nodeHook ); |
| + | } |
| - | // Webkit/Opera - :checked should return selected option elements |
| - | // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked |
| - | // IE8 throws error here and will not see later tests |
| - | if ( !div.querySelectorAll(":checked").length ) { |
| - | rbuggyQSA.push(":checked"); |
| - | } |
| - | }); |
| + | if ( value !== undefined ) { |
| - | assert(function( div ) { |
| + | if ( value === null ) { |
| + | jQuery.removeAttr( elem, name ); |
| - | // Opera 10-12/IE8 - ^= $= *= and empty values |
| - | // Should not select anything |
| - | div.innerHTML = "<input type='hidden' i=''/>"; |
| - | if ( div.querySelectorAll("[i^='']").length ) { |
| - | rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:\"\"|'')" ); |
| - | } |
| + | } else if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { |
| + | return ret; |
| - | // FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled) |
| - | // IE8 throws error here and will not see later tests |
| - | if ( !div.querySelectorAll(":enabled").length ) { |
| - | rbuggyQSA.push( ":enabled", ":disabled" ); |
| + | } else { |
| + | elem.setAttribute( name, value + "" ); |
| + | return value; |
| } | |
| - | // Opera 10-11 does not throw on post-comma invalid pseudos |
| - | div.querySelectorAll("*,:x"); |
| - | rbuggyQSA.push(",.*:"); |
| - | }); |
| - | } |
| + | } else if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { |
| + | return ret; |
| - | if ( (support.matchesSelector = isNative( (matches = docElem.matchesSelector || |
| - | docElem.mozMatchesSelector || |
| - | docElem.webkitMatchesSelector || |
| - | docElem.oMatchesSelector || |
| - | docElem.msMatchesSelector) )) ) { |
| + | } else { |
| + | ret = jQuery.find.attr( elem, name ); |
| - | assert(function( div ) { |
| - | // Check to see if it's possible to do matchesSelector |
| - | // on a disconnected node (IE 9) |
| - | support.disconnectedMatch = matches.call( div, "div" ); |
| + | // Non-existent attributes return null, we normalize to undefined |
| + | return ret == null ? |
| + | undefined : |
| + | ret; |
| + | } |
| + | }, |
| - | // This should fail with an exception |
| - | // Gecko does not error, returns false instead |
| - | matches.call( div, "[s!='']:x" ); |
| - | rbuggyMatches.push( "!=", pseudos ); |
| - | }); |
| - | } |
| + | removeAttr: function( elem, value ) { |
| + | var name, propName, |
| + | i = 0, |
| + | attrNames = value && value.match( core_rnotwhite ); |
| - | rbuggyQSA = new RegExp( rbuggyQSA.join("|") ); |
| - | rbuggyMatches = new RegExp( rbuggyMatches.join("|") ); |
| + | if ( attrNames && elem.nodeType === 1 ) { |
| + | while ( (name = attrNames[i++]) ) { |
| + | propName = jQuery.propFix[ name ] || name; |
| - | // Element contains another |
| - | // Purposefully does not implement inclusive descendent |
| - | // As in, an element does not contain itself |
| - | contains = isNative(docElem.contains) || docElem.compareDocumentPosition ? |
| - | function( a, b ) { |
| - | var adown = a.nodeType === 9 ? a.documentElement : a, |
| - | bup = b && b.parentNode; |
| - | return a === bup || !!( bup && bup.nodeType === 1 && ( |
| - | adown.contains ? |
| - | adown.contains( bup ) : |
| - | a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16 |
| - | )); |
| - | } : |
| - | function( a, b ) { |
| - | if ( b ) { |
| - | while ( (b = b.parentNode) ) { |
| - | if ( b === a ) { |
| - | return true; |
| + | // Boolean attributes get special treatment (#10870) |
| + | if ( jQuery.expr.match.bool.test( name ) ) { |
| + | // Set corresponding property to false |
| + | if ( getSetInput && getSetAttribute || !ruseDefault.test( name ) ) { |
| + | elem[ propName ] = false; |
| + | // Support: IE<9 |
| + | // Also clear defaultChecked/defaultSelected (if appropriate) |
| + | } else { |
| + | elem[ jQuery.camelCase( "default-" + name ) ] = |
| + | elem[ propName ] = false; |
| } | |
| - | } |
| - | } |
| - | return false; |
| - | }; |
| - | // Document order sorting |
| - | sortOrder = docElem.compareDocumentPosition ? |
| - | function( a, b ) { |
| - | var compare; |
| + | // See #9699 for explanation of this approach (setting first, then removal) |
| + | } else { |
| + | jQuery.attr( elem, name, "" ); |
| + | } |
| - | if ( a === b ) { |
| - | hasDuplicate = true; |
| - | return 0; |
| + | elem.removeAttribute( getSetAttribute ? name : propName ); |
| + | } |
| } | |
| + | }, |
| - | if ( (compare = b.compareDocumentPosition && a.compareDocumentPosition && a.compareDocumentPosition( b )) ) { |
| - | if ( compare & 1 || a.parentNode && a.parentNode.nodeType === 11 ) { |
| - | if ( a === doc || contains( preferredDoc, a ) ) { |
| - | return -1; |
| - | } |
| - | if ( b === doc || contains( preferredDoc, b ) ) { |
| - | return 1; |
| + | attrHooks: { |
| + | type: { |
| + | set: function( elem, value ) { |
| + | if ( !jQuery.support.radioValue && value === "radio" && jQuery.nodeName(elem, "input") ) { |
| + | // Setting the type on a radio button after the value resets the value in IE6-9 |
| + | // Reset value to default in case type is set after value during creation |
| + | var val = elem.value; |
| + | elem.setAttribute( "type", value ); |
| + | if ( val ) { |
| + | elem.value = val; |
| + | } |
| + | return value; |
| } | |
| - | return 0; |
| } | |
| - | return compare & 4 ? -1 : 1; |
| } | |
| + | }, |
| - | return a.compareDocumentPosition ? -1 : 1; |
| - | } : |
| - | function( a, b ) { |
| - | var cur, |
| - | i = 0, |
| - | aup = a.parentNode, |
| - | bup = b.parentNode, |
| - | ap = [ a ], |
| - | bp = [ b ]; |
| - | |
| - | // Exit early if the nodes are identical |
| - | if ( a === b ) { |
| - | hasDuplicate = true; |
| - | return 0; |
| + | propFix: { |
| + | "for": "htmlFor", |
| + | "class": "className" |
| + | }, |
| - | // Parentless nodes are either documents or disconnected |
| - | } else if ( !aup || !bup ) { |
| - | return a === doc ? -1 : |
| - | b === doc ? 1 : |
| - | aup ? -1 : |
| - | bup ? 1 : |
| - | 0; |
| + | prop: function( elem, name, value ) { |
| + | var ret, hooks, notxml, |
| + | nType = elem.nodeType; |
| - | // If the nodes are siblings, we can do a quick check |
| - | } else if ( aup === bup ) { |
| - | return siblingCheck( a, b ); |
| + | // don't get/set properties on text, comment and attribute nodes |
| + | if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
| + | return; |
| } | |
| - | // Otherwise we need full lists of their ancestors for comparison |
| - | cur = a; |
| - | while ( (cur = cur.parentNode) ) { |
| - | ap.unshift( cur ); |
| - | } |
| - | cur = b; |
| - | while ( (cur = cur.parentNode) ) { |
| - | bp.unshift( cur ); |
| - | } |
| + | notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); |
| - | // Walk down the tree looking for a discrepancy |
| - | while ( ap[i] === bp[i] ) { |
| - | i++; |
| + | if ( notxml ) { |
| + | // Fix name and attach hooks |
| + | name = jQuery.propFix[ name ] || name; |
| + | hooks = jQuery.propHooks[ name ]; |
| } | |
| - | return i ? |
| - | // Do a sibling check if the nodes have a common ancestor |
| - | siblingCheck( ap[i], bp[i] ) : |
| + | if ( value !== undefined ) { |
| + | return hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ? |
| + | ret : |
| + | ( elem[ name ] = value ); |
| - | // Otherwise nodes in our document sort first |
| - | ap[i] === preferredDoc ? -1 : |
| - | bp[i] === preferredDoc ? 1 : |
| - | 0; |
| - | }; |
| + | } else { |
| + | return hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ? |
| + | ret : |
| + | elem[ name ]; |
| + | } |
| + | }, |
| - | // Always assume the presence of duplicates if sort doesn't |
| - | // pass them to our comparison function (as in Google Chrome). |
| - | hasDuplicate = false; |
| - | [0, 0].sort( sortOrder ); |
| - | support.detectDuplicates = hasDuplicate; |
| + | propHooks: { |
| + | tabIndex: { |
| + | get: function( elem ) { |
| + | // elem.tabIndex doesn't always return the correct value when it hasn't been explicitly set |
| + | // http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ |
| + | // Use proper attribute retrieval(#12072) |
| + | var tabindex = jQuery.find.attr( elem, "tabindex" ); |
| - | return document; |
| - | }; |
| + | return tabindex ? |
| + | parseInt( tabindex, 10 ) : |
| + | rfocusable.test( elem.nodeName ) || rclickable.test( elem.nodeName ) && elem.href ? |
| + | 0 : |
| + | -1; |
| + | } |
| + | } |
| + | } |
| + | }); |
| - | Sizzle.matches = function( expr, elements ) { |
| - | return Sizzle( expr, null, null, elements ); |
| - | }; |
| + | // Hooks for boolean attributes |
| + | boolHook = { |
| + | set: function( elem, value, name ) { |
| + | if ( value === false ) { |
| + | // Remove boolean attributes when set to false |
| + | jQuery.removeAttr( elem, name ); |
| + | } else if ( getSetInput && getSetAttribute || !ruseDefault.test( name ) ) { |
| + | // IE<8 needs the *property* name |
| + | elem.setAttribute( !getSetAttribute && jQuery.propFix[ name ] || name, name ); |
| - | Sizzle.matchesSelector = function( elem, expr ) { |
| - | // Set document vars if needed |
| - | if ( ( elem.ownerDocument || elem ) !== document ) { |
| - | setDocument( elem ); |
| + | // Use defaultChecked and defaultSelected for oldIE |
| + | } else { |
| + | elem[ jQuery.camelCase( "default-" + name ) ] = elem[ name ] = true; |
| + | } |
| + | |
| + | return name; |
| } | |
| + | }; |
| + | jQuery.each( jQuery.expr.match.bool.source.match( /\w+/g ), function( i, name ) { |
| + | var getter = jQuery.expr.attrHandle[ name ] || jQuery.find.attr; |
| + | |
| + | jQuery.expr.attrHandle[ name ] = getSetInput && getSetAttribute || !ruseDefault.test( name ) ? |
| + | function( elem, name, isXML ) { |
| + | var fn = jQuery.expr.attrHandle[ name ], |
| + | ret = isXML ? |
| + | undefined : |
| + | /* jshint eqeqeq: false */ |
| + | (jQuery.expr.attrHandle[ name ] = undefined) != |
| + | getter( elem, name, isXML ) ? |
| + | |
| + | name.toLowerCase() : |
| + | null; |
| + | jQuery.expr.attrHandle[ name ] = fn; |
| + | return ret; |
| + | } : |
| + | function( elem, name, isXML ) { |
| + | return isXML ? |
| + | undefined : |
| + | elem[ jQuery.camelCase( "default-" + name ) ] ? |
| + | name.toLowerCase() : |
| + | null; |
| + | }; |
| + | }); |
| - | // Make sure that attribute selectors are quoted |
| - | expr = expr.replace( rattributeQuotes, "='$1']" ); |
| + | // fix oldIE attroperties |
| + | if ( !getSetInput || !getSetAttribute ) { |
| + | jQuery.attrHooks.value = { |
| + | set: function( elem, value, name ) { |
| + | if ( jQuery.nodeName( elem, "input" ) ) { |
| + | // Does not return so that setAttribute is also used |
| + | elem.defaultValue = value; |
| + | } else { |
| + | // Use nodeHook if defined (#1954); otherwise setAttribute is fine |
| + | return nodeHook && nodeHook.set( elem, value, name ); |
| + | } |
| + | } |
| + | }; |
| + | } |
| - | // rbuggyQSA always contains :focus, so no need for an existence check |
| - | if ( support.matchesSelector && !documentIsXML && (!rbuggyMatches || !rbuggyMatches.test(expr)) && !rbuggyQSA.test(expr) ) { |
| - | try { |
| - | var ret = matches.call( elem, expr ); |
| + | // IE6/7 do not support getting/setting some attributes with get/setAttribute |
| + | if ( !getSetAttribute ) { |
| - | // IE 9's matchesSelector returns false on disconnected nodes |
| - | if ( ret || support.disconnectedMatch || |
| - | // As well, disconnected nodes are said to be in a document |
| - | // fragment in IE 9 |
| - | elem.document && elem.document.nodeType !== 11 ) { |
| - | return ret; |
| + | // Use this for any attribute in IE6/7 |
| + | // This fixes almost every IE6/7 issue |
| + | nodeHook = { |
| + | set: function( elem, value, name ) { |
| + | // Set the existing or create a new attribute node |
| + | var ret = elem.getAttributeNode( name ); |
| + | if ( !ret ) { |
| + | elem.setAttributeNode( |
| + | (ret = elem.ownerDocument.createAttribute( name )) |
| + | ); |
| } | |
| - | } catch(e) {} |
| - | } |
| - | return Sizzle( expr, document, null, [elem] ).length > 0; |
| - | }; |
| + | ret.value = value += ""; |
| - | Sizzle.contains = function( context, elem ) { |
| - | // Set document vars if needed |
| - | if ( ( context.ownerDocument || context ) !== document ) { |
| - | setDocument( context ); |
| - | } |
| - | return contains( context, elem ); |
| - | }; |
| + | // Break association with cloned elements by also using setAttribute (#9646) |
| + | return name === "value" || value === elem.getAttribute( name ) ? |
| + | value : |
| + | undefined; |
| + | } |
| + | }; |
| + | jQuery.expr.attrHandle.id = jQuery.expr.attrHandle.name = jQuery.expr.attrHandle.coords = |
| + | // Some attributes are constructed with empty-string values when not defined |
| + | function( elem, name, isXML ) { |
| + | var ret; |
| + | return isXML ? |
| + | undefined : |
| + | (ret = elem.getAttributeNode( name )) && ret.value !== "" ? |
| + | ret.value : |
| + | null; |
| + | }; |
| + | jQuery.valHooks.button = { |
| + | get: function( elem, name ) { |
| + | var ret = elem.getAttributeNode( name ); |
| + | return ret && ret.specified ? |
| + | ret.value : |
| + | undefined; |
| + | }, |
| + | set: nodeHook.set |
| + | }; |
| - | Sizzle.attr = function( elem, name ) { |
| - | var val; |
| + | // Set contenteditable to false on removals(#10429) |
| + | // Setting to empty string throws an error as an invalid value |
| + | jQuery.attrHooks.contenteditable = { |
| + | set: function( elem, value, name ) { |
| + | nodeHook.set( elem, value === "" ? false : value, name ); |
| + | } |
| + | }; |
| - | // Set document vars if needed |
| - | if ( ( elem.ownerDocument || elem ) !== document ) { |
| - | setDocument( elem ); |
| - | } |
| + | // Set width and height to auto instead of 0 on empty string( Bug #8150 ) |
| + | // This is for removals |
| + | jQuery.each([ "width", "height" ], function( i, name ) { |
| + | jQuery.attrHooks[ name ] = { |
| + | set: function( elem, value ) { |
| + | if ( value === "" ) { |
| + | elem.setAttribute( name, "auto" ); |
| + | return value; |
| + | } |
| + | } |
| + | }; |
| + | }); |
| + | } |
| - | if ( !documentIsXML ) { |
| - | name = name.toLowerCase(); |
| - | } |
| - | if ( (val = Expr.attrHandle[ name ]) ) { |
| - | return val( elem ); |
| - | } |
| - | if ( documentIsXML || support.attributes ) { |
| - | return elem.getAttribute( name ); |
| - | } |
| - | return ( (val = elem.getAttributeNode( name )) || elem.getAttribute( name ) ) && elem[ name ] === true ? |
| - | name : |
| - | val && val.specified ? val.value : null; |
| - | }; |
| - | Sizzle.error = function( msg ) { |
| - | throw new Error( "Syntax error, unrecognized expression: " + msg ); |
| - | }; |
| + | // Some attributes require a special call on IE |
| + | // http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx |
| + | if ( !jQuery.support.hrefNormalized ) { |
| + | // href/src property should get the full normalized URL (#10299/#12915) |
| + | jQuery.each([ "href", "src" ], function( i, name ) { |
| + | jQuery.propHooks[ name ] = { |
| + | get: function( elem ) { |
| + | return elem.getAttribute( name, 4 ); |
| + | } |
| + | }; |
| + | }); |
| + | } |
| - | // Document sorting and removing duplicates |
| - | Sizzle.uniqueSort = function( results ) { |
| - | var elem, |
| - | duplicates = [], |
| - | i = 1, |
| - | j = 0; |
| + | if ( !jQuery.support.style ) { |
| + | jQuery.attrHooks.style = { |
| + | get: function( elem ) { |
| + | // Return undefined in the case of empty string |
| + | // Note: IE uppercases css property names, but if we were to .toLowerCase() |
| + | // .cssText, that would destroy case senstitivity in URL's, like in "background" |
| + | return elem.style.cssText || undefined; |
| + | }, |
| + | set: function( elem, value ) { |
| + | return ( elem.style.cssText = value + "" ); |
| + | } |
| + | }; |
| + | } |
| - | // Unless we *know* we can detect duplicates, assume their presence |
| - | hasDuplicate = !support.detectDuplicates; |
| - | results.sort( sortOrder ); |
| + | // Safari mis-reports the default selected property of an option |
| + | // Accessing the parent's selectedIndex property fixes it |
| + | if ( !jQuery.support.optSelected ) { |
| + | jQuery.propHooks.selected = { |
| + | get: function( elem ) { |
| + | var parent = elem.parentNode; |
| - | if ( hasDuplicate ) { |
| - | for ( ; (elem = results[i]); i++ ) { |
| - | if ( elem === results[ i - 1 ] ) { |
| - | j = duplicates.push( i ); |
| + | if ( parent ) { |
| + | parent.selectedIndex; |
| + | |
| + | // Make sure that it also works with optgroups, see #5701 |
| + | if ( parent.parentNode ) { |
| + | parent.parentNode.selectedIndex; |
| + | } |
| } | |
| + | return null; |
| } | |
| - | while ( j-- ) { |
| - | results.splice( duplicates[ j ], 1 ); |
| - | } |
| - | } |
| - | |
| - | return results; |
| - | }; |
| + | }; |
| + | } |
| - | function siblingCheck( a, b ) { |
| - | var cur = b && a, |
| - | diff = cur && ( ~b.sourceIndex || MAX_NEGATIVE ) - ( ~a.sourceIndex || MAX_NEGATIVE ); |
| + | jQuery.each([ |
| + | "tabIndex", |
| + | "readOnly", |
| + | "maxLength", |
| + | "cellSpacing", |
| + | "cellPadding", |
| + | "rowSpan", |
| + | "colSpan", |
| + | "useMap", |
| + | "frameBorder", |
| + | "contentEditable" |
| + | ], function() { |
| + | jQuery.propFix[ this.toLowerCase() ] = this; |
| + | }); |
| - | // Use IE sourceIndex if available on both nodes |
| - | if ( diff ) { |
| - | return diff; |
| - | } |
| + | // IE6/7 call enctype encoding |
| + | if ( !jQuery.support.enctype ) { |
| + | jQuery.propFix.enctype = "encoding"; |
| + | } |
| - | // Check if b follows a |
| - | if ( cur ) { |
| - | while ( (cur = cur.nextSibling) ) { |
| - | if ( cur === b ) { |
| - | return -1; |
| + | // Radios and checkboxes getter/setter |
| + | jQuery.each([ "radio", "checkbox" ], function() { |
| + | jQuery.valHooks[ this ] = { |
| + | set: function( elem, value ) { |
| + | if ( jQuery.isArray( value ) ) { |
| + | return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) >= 0 ); |
| } | |
| } | |
| + | }; |
| + | if ( !jQuery.support.checkOn ) { |
| + | jQuery.valHooks[ this ].get = function( elem ) { |
| + | // Support: Webkit |
| + | // "" is returned instead of "on" if a value isn't specified |
| + | return elem.getAttribute("value") === null ? "on" : elem.value; |
| + | }; |
| } | |
| + | }); |
| + | var rformElems = /^(?:input|select|textarea)$/i, |
| + | rkeyEvent = /^key/, |
| + | rmouseEvent = /^(?:mouse|contextmenu)|click/, |
| + | rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, |
| + | rtypenamespace = /^([^.]*)(?:\.(.+)|)$/; |
| - | return a ? 1 : -1; |
| + | function returnTrue() { |
| + | return true; |
| } | |
| - | // Returns a function to use in pseudos for input types |
| - | function createInputPseudo( type ) { |
| - | return function( elem ) { |
| - | var name = elem.nodeName.toLowerCase(); |
| - | return name === "input" && elem.type === type; |
| - | }; |
| + | function returnFalse() { |
| + | return false; |
| } | |
| - | // Returns a function to use in pseudos for buttons |
| - | function createButtonPseudo( type ) { |
| - | return function( elem ) { |
| - | var name = elem.nodeName.toLowerCase(); |
| - | return (name === "input" || name === "button") && elem.type === type; |
| - | }; |
| + | function safeActiveElement() { |
| + | try { |
| + | return document.activeElement; |
| + | } catch ( err ) { } |
| } | |
| - | // Returns a function to use in pseudos for positionals |
| - | function createPositionalPseudo( fn ) { |
| - | return markFunction(function( argument ) { |
| - | argument = +argument; |
| - | return markFunction(function( seed, matches ) { |
| - | var j, |
| - | matchIndexes = fn( [], seed.length, argument ), |
| - | i = matchIndexes.length; |
| + | /* |
| + | * Helper functions for managing events -- not part of the public interface. |
| + | * Props to Dean Edwards' addEvent library for many of the ideas. |
| + | */ |
| + | jQuery.event = { |
| - | // Match elements found at the specified indexes |
| - | while ( i-- ) { |
| - | if ( seed[ (j = matchIndexes[i]) ] ) { |
| - | seed[j] = !(matches[j] = seed[j]); |
| - | } |
| - | } |
| - | }); |
| - | }); |
| - | } |
| + | global: {}, |
| - | /** |
| - | * Utility function for retrieving the text value of an array of DOM nodes |
| - | * @param {Array|Element} elem |
| - | */ |
| - | getText = Sizzle.getText = function( elem ) { |
| - | var node, |
| - | ret = "", |
| - | i = 0, |
| - | nodeType = elem.nodeType; |
| + | add: function( elem, types, handler, data, selector ) { |
| + | var tmp, events, t, handleObjIn, |
| + | special, eventHandle, handleObj, |
| + | handlers, type, namespaces, origType, |
| + | elemData = jQuery._data( elem ); |
| - | if ( !nodeType ) { |
| - | // If no nodeType, this is expected to be an array |
| - | for ( ; (node = elem[i]); i++ ) { |
| - | // Do not traverse comment nodes |
| - | ret += getText( node ); |
| - | } |
| - | } else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) { |
| - | // Use textContent for elements |
| - | // innerText usage removed for consistency of new lines (see #11153) |
| - | if ( typeof elem.textContent === "string" ) { |
| - | return elem.textContent; |
| - | } else { |
| - | // Traverse its children |
| - | for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { |
| - | ret += getText( elem ); |
| - | } |
| + | // Don't attach events to noData or text/comment nodes (but allow plain objects) |
| + | if ( !elemData ) { |
| + | return; |
| } | |
| - | } else if ( nodeType === 3 || nodeType === 4 ) { |
| - | return elem.nodeValue; |
| - | } |
| - | // Do not include comment or processing instruction nodes |
| - | |
| - | return ret; |
| - | }; |
| - | Expr = Sizzle.selectors = { |
| + | // Caller can pass in an object of custom data in lieu of the handler |
| + | if ( handler.handler ) { |
| + | handleObjIn = handler; |
| + | handler = handleObjIn.handler; |
| + | selector = handleObjIn.selector; |
| + | } |
| - | // Can be adjusted by the user |
| - | cacheLength: 50, |
| + | // Make sure that the handler has a unique ID, used to find/remove it later |
| + | if ( !handler.guid ) { |
| + | handler.guid = jQuery.guid++; |
| + | } |
| - | createPseudo: markFunction, |
| + | // Init the element's event structure and main handler, if this is the first |
| + | if ( !(events = elemData.events) ) { |
| + | events = elemData.events = {}; |
| + | } |
| + | if ( !(eventHandle = elemData.handle) ) { |
| + | eventHandle = elemData.handle = function( e ) { |
| + | // Discard the second event of a jQuery.event.trigger() and |
| + | // when an event is called after a page has unloaded |
| + | return typeof jQuery !== core_strundefined && (!e || jQuery.event.triggered !== e.type) ? |
| + | jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : |
| + | undefined; |
| + | }; |
| + | // Add elem as a property of the handle fn to prevent a memory leak with IE non-native events |
| + | eventHandle.elem = elem; |
| + | } |
| - | match: matchExpr, |
| + | // Handle multiple events separated by a space |
| + | types = ( types || "" ).match( core_rnotwhite ) || [""]; |
| + | t = types.length; |
| + | while ( t-- ) { |
| + | tmp = rtypenamespace.exec( types[t] ) || []; |
| + | type = origType = tmp[1]; |
| + | namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
| - | find: {}, |
| + | // There *must* be a type, no attaching namespace-only handlers |
| + | if ( !type ) { |
| + | continue; |
| + | } |
| - | relative: { |
| - | ">": { dir: "parentNode", first: true }, |
| - | " ": { dir: "parentNode" }, |
| - | "+": { dir: "previousSibling", first: true }, |
| - | "~": { dir: "previousSibling" } |
| - | }, |
| + | // If event changes its type, use the special event handlers for the changed type |
| + | special = jQuery.event.special[ type ] || {}; |
| - | preFilter: { |
| - | "ATTR": function( match ) { |
| - | match[1] = match[1].replace( runescape, funescape ); |
| + | // If selector defined, determine special event api type, otherwise given type |
| + | type = ( selector ? special.delegateType : special.bindType ) || type; |
| - | // Move the given value to match[3] whether quoted or unquoted |
| - | match[3] = ( match[4] || match[5] || "" ).replace( runescape, funescape ); |
| + | // Update special based on newly reset type |
| + | special = jQuery.event.special[ type ] || {}; |
| - | if ( match[2] === "~=" ) { |
| - | match[3] = " " + match[3] + " "; |
| - | } |
| + | // handleObj is passed to all event handlers |
| + | handleObj = jQuery.extend({ |
| + | type: type, |
| + | origType: origType, |
| + | data: data, |
| + | handler: handler, |
| + | guid: handler.guid, |
| + | selector: selector, |
| + | needsContext: selector && jQuery.expr.match.needsContext.test( selector ), |
| + | namespace: namespaces.join(".") |
| + | }, handleObjIn ); |
| - | return match.slice( 0, 4 ); |
| - | }, |
| + | // Init the event handler queue if we're the first |
| + | if ( !(handlers = events[ type ]) ) { |
| + | handlers = events[ type ] = []; |
| + | handlers.delegateCount = 0; |
| - | "CHILD": function( match ) { |
| - | /* matches from matchExpr["CHILD"] |
| - | 1 type (only|nth|...) |
| - | 2 what (child|of-type) |
| - | 3 argument (even|odd|\d*|\d*n([+-]\d+)?|...) |
| - | 4 xn-component of xn+y argument ([+-]?\d*n|) |
| - | 5 sign of xn-component |
| - | 6 x of xn-component |
| - | 7 sign of y-component |
| - | 8 y of y-component |
| - | */ |
| - | match[1] = match[1].toLowerCase(); |
| + | // Only use addEventListener/attachEvent if the special events handler returns false |
| + | if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { |
| + | // Bind the global event handler to the element |
| + | if ( elem.addEventListener ) { |
| + | elem.addEventListener( type, eventHandle, false ); |
| - | if ( match[1].slice( 0, 3 ) === "nth" ) { |
| - | // nth-* requires argument |
| - | if ( !match[3] ) { |
| - | Sizzle.error( match[0] ); |
| + | } else if ( elem.attachEvent ) { |
| + | elem.attachEvent( "on" + type, eventHandle ); |
| + | } |
| } | |
| - | |
| - | // numeric x and y parameters for Expr.filter.CHILD |
| - | // remember that false/true cast respectively to 0/1 |
| - | match[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === "even" || match[3] === "odd" ) ); |
| - | match[5] = +( ( match[7] + match[8] ) || match[3] === "odd" ); |
| - | |
| - | // other types prohibit arguments |
| - | } else if ( match[3] ) { |
| - | Sizzle.error( match[0] ); |
| } | |
| - | return match; |
| - | }, |
| - | |
| - | "PSEUDO": function( match ) { |
| - | var excess, |
| - | unquoted = !match[5] && match[2]; |
| + | if ( special.add ) { |
| + | special.add.call( elem, handleObj ); |
| - | if ( matchExpr["CHILD"].test( match[0] ) ) { |
| - | return null; |
| + | if ( !handleObj.handler.guid ) { |
| + | handleObj.handler.guid = handler.guid; |
| + | } |
| } | |
| - | // Accept quoted arguments as-is |
| - | if ( match[4] ) { |
| - | match[2] = match[4]; |
| - | |
| - | // Strip excess characters from unquoted arguments |
| - | } else if ( unquoted && rpseudo.test( unquoted ) && |
| - | // Get excess from tokenize (recursively) |
| - | (excess = tokenize( unquoted, true )) && |
| - | // advance to the next closing parenthesis |
| - | (excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length) ) { |
| - | |
| - | // excess is a negative index |
| - | match[0] = match[0].slice( 0, excess ); |
| - | match[2] = unquoted.slice( 0, excess ); |
| + | // Add to the element's handler list, delegates in front |
| + | if ( selector ) { |
| + | handlers.splice( handlers.delegateCount++, 0, handleObj ); |
| + | } else { |
| + | handlers.push( handleObj ); |
| } | |
| - | // Return only captures needed by the pseudo filter method (type and argument) |
| - | return match.slice( 0, 3 ); |
| + | // Keep track of which events have ever been used, for event optimization |
| + | jQuery.event.global[ type ] = true; |
| } | |
| + | |
| + | // Nullify elem to prevent memory leaks in IE |
| + | elem = null; |
| }, | |
| - | filter: { |
| + | // Detach an event or set of events from an element |
| + | remove: function( elem, types, handler, selector, mappedTypes ) { |
| + | var j, handleObj, tmp, |
| + | origCount, t, events, |
| + | special, handlers, type, |
| + | namespaces, origType, |
| + | elemData = jQuery.hasData( elem ) && jQuery._data( elem ); |
| - | "TAG": function( nodeName ) { |
| - | if ( nodeName === "*" ) { |
| - | return function() { return true; }; |
| - | } |
| + | if ( !elemData || !(events = elemData.events) ) { |
| + | return; |
| + | } |
| - | nodeName = nodeName.replace( runescape, funescape ).toLowerCase(); |
| - | return function( elem ) { |
| - | return elem.nodeName && elem.nodeName.toLowerCase() === nodeName; |
| - | }; |
| - | }, |
| + | // Once for each type.namespace in types; type may be omitted |
| + | types = ( types || "" ).match( core_rnotwhite ) || [""]; |
| + | t = types.length; |
| + | while ( t-- ) { |
| + | tmp = rtypenamespace.exec( types[t] ) || []; |
| + | type = origType = tmp[1]; |
| + | namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
| - | "CLASS": function( className ) { |
| - | var pattern = classCache[ className + " " ]; |
| + | // Unbind all events (on this namespace, if provided) for the element |
| + | if ( !type ) { |
| + | for ( type in events ) { |
| + | jQuery.event.remove( elem, type + types[ t ], handler, selector, true ); |
| + | } |
| + | continue; |
| + | } |
| - | return pattern || |
| - | (pattern = new RegExp( "(^|" + whitespace + ")" + className + "(" + whitespace + "|$)" )) && |
| - | classCache( className, function( elem ) { |
| - | return pattern.test( elem.className || (typeof elem.getAttribute !== strundefined && elem.getAttribute("class")) || "" ); |
| - | }); |
| - | }, |
| + | special = jQuery.event.special[ type ] || {}; |
| + | type = ( selector ? special.delegateType : special.bindType ) || type; |
| + | handlers = events[ type ] || []; |
| + | tmp = tmp[2] && new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ); |
| - | "ATTR": function( name, operator, check ) { |
| - | return function( elem ) { |
| - | var result = Sizzle.attr( elem, name ); |
| + | // Remove matching events |
| + | origCount = j = handlers.length; |
| + | while ( j-- ) { |
| + | handleObj = handlers[ j ]; |
| - | if ( result == null ) { |
| - | return operator === "!="; |
| - | } |
| - | if ( !operator ) { |
| - | return true; |
| - | } |
| + | if ( ( mappedTypes || origType === handleObj.origType ) && |
| + | ( !handler || handler.guid === handleObj.guid ) && |
| + | ( !tmp || tmp.test( handleObj.namespace ) ) && |
| + | ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) { |
| + | handlers.splice( j, 1 ); |
| - | result += ""; |
| + | if ( handleObj.selector ) { |
| + | handlers.delegateCount--; |
| + | } |
| + | if ( special.remove ) { |
| + | special.remove.call( elem, handleObj ); |
| + | } |
| + | } |
| + | } |
| - | return operator === "=" ? result === check : |
| - | operator === "!=" ? result !== check : |
| - | operator === "^=" ? check && result.indexOf( check ) === 0 : |
| - | operator === "*=" ? check && result.indexOf( check ) > -1 : |
| - | operator === "$=" ? check && result.slice( -check.length ) === check : |
| - | operator === "~=" ? ( " " + result + " " ).indexOf( check ) > -1 : |
| - | operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" : |
| - | false; |
| - | }; |
| - | }, |
| + | // Remove generic event handler if we removed something and no more handlers exist |
| + | // (avoids potential for endless recursion during removal of special event handlers) |
| + | if ( origCount && !handlers.length ) { |
| + | if ( !special.teardown || special.teardown.call( elem, namespaces, elemData.handle ) === false ) { |
| + | jQuery.removeEvent( elem, type, elemData.handle ); |
| + | } |
| - | "CHILD": function( type, what, argument, first, last ) { |
| - | var simple = type.slice( 0, 3 ) !== "nth", |
| - | forward = type.slice( -4 ) !== "last", |
| - | ofType = what === "of-type"; |
| + | delete events[ type ]; |
| + | } |
| + | } |
| - | return first === 1 && last === 0 ? |
| + | // Remove the expando if it's no longer used |
| + | if ( jQuery.isEmptyObject( events ) ) { |
| + | delete elemData.handle; |
| - | // Shortcut for :nth-*(n) |
| - | function( elem ) { |
| - | return !!elem.parentNode; |
| - | } : |
| + | // removeData also checks for emptiness and clears the expando if empty |
| + | // so use it instead of delete |
| + | jQuery._removeData( elem, "events" ); |
| + | } |
| + | }, |
| - | function( elem, context, xml ) { |
| - | var cache, outerCache, node, diff, nodeIndex, start, |
| - | dir = simple !== forward ? "nextSibling" : "previousSibling", |
| - | parent = elem.parentNode, |
| - | name = ofType && elem.nodeName.toLowerCase(), |
| - | useCache = !xml && !ofType; |
| + | trigger: function( event, data, elem, onlyHandlers ) { |
| + | var handle, ontype, cur, |
| + | bubbleType, special, tmp, i, |
| + | eventPath = [ elem || document ], |
| + | type = core_hasOwn.call( event, "type" ) ? event.type : event, |
| + | namespaces = core_hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : []; |
| - | if ( parent ) { |
| + | cur = tmp = elem = elem || document; |
| - | // :(first|last|only)-(child|of-type) |
| - | if ( simple ) { |
| - | while ( dir ) { |
| - | node = elem; |
| - | while ( (node = node[ dir ]) ) { |
| - | if ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) { |
| - | return false; |
| - | } |
| - | } |
| - | // Reverse direction for :only-* (if we haven't yet done so) |
| - | start = dir = type === "only" && !start && "nextSibling"; |
| - | } |
| - | return true; |
| - | } |
| + | // Don't do events on text and comment nodes |
| + | if ( elem.nodeType === 3 || elem.nodeType === 8 ) { |
| + | return; |
| + | } |
| - | start = [ forward ? parent.firstChild : parent.lastChild ]; |
| + | // focus/blur morphs to focusin/out; ensure we're not firing them right now |
| + | if ( rfocusMorph.test( type + jQuery.event.triggered ) ) { |
| + | return; |
| + | } |
| - | // non-xml :nth-child(...) stores cache data on `parent` |
| - | if ( forward && useCache ) { |
| - | // Seek `elem` from a previously-cached index |
| - | outerCache = parent[ expando ] || (parent[ expando ] = {}); |
| - | cache = outerCache[ type ] || []; |
| - | nodeIndex = cache[0] === dirruns && cache[1]; |
| - | diff = cache[0] === dirruns && cache[2]; |
| - | node = nodeIndex && parent.childNodes[ nodeIndex ]; |
| + | if ( type.indexOf(".") >= 0 ) { |
| + | // Namespaced trigger; create a regexp to match event type in handle() |
| + | namespaces = type.split("."); |
| + | type = namespaces.shift(); |
| + | namespaces.sort(); |
| + | } |
| + | ontype = type.indexOf(":") < 0 && "on" + type; |
| - | while ( (node = ++nodeIndex && node && node[ dir ] || |
| + | // Caller can pass in a jQuery.Event object, Object, or just an event type string |
| + | event = event[ jQuery.expando ] ? |
| + | event : |
| + | new jQuery.Event( type, typeof event === "object" && event ); |
| - | // Fallback to seeking `elem` from the start |
| - | (diff = nodeIndex = 0) || start.pop()) ) { |
| + | // Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true) |
| + | event.isTrigger = onlyHandlers ? 2 : 3; |
| + | event.namespace = namespaces.join("."); |
| + | event.namespace_re = event.namespace ? |
| + | new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) : |
| + | null; |
| - | // When found, cache indexes on `parent` and break |
| - | if ( node.nodeType === 1 && ++diff && node === elem ) { |
| - | outerCache[ type ] = [ dirruns, nodeIndex, diff ]; |
| - | break; |
| - | } |
| - | } |
| + | // Clean up the event in case it is being reused |
| + | event.result = undefined; |
| + | if ( !event.target ) { |
| + | event.target = elem; |
| + | } |
| - | // Use previously-cached element index if available |
| - | } else if ( useCache && (cache = (elem[ expando ] || (elem[ expando ] = {}))[ type ]) && cache[0] === dirruns ) { |
| - | diff = cache[1]; |
| + | // Clone any incoming data and prepend the event, creating the handler arg list |
| + | data = data == null ? |
| + | [ event ] : |
| + | jQuery.makeArray( data, [ event ] ); |
| - | // xml :nth-child(...) or :nth-last-child(...) or :nth(-last)?-of-type(...) |
| - | } else { |
| - | // Use the same loop as above to seek `elem` from the start |
| - | while ( (node = ++nodeIndex && node && node[ dir ] || |
| - | (diff = nodeIndex = 0) || start.pop()) ) { |
| + | // Allow special events to draw outside the lines |
| + | special = jQuery.event.special[ type ] || {}; |
| + | if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) { |
| + | return; |
| + | } |
| - | if ( ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) && ++diff ) { |
| - | // Cache the index of each encountered element |
| - | if ( useCache ) { |
| - | (node[ expando ] || (node[ expando ] = {}))[ type ] = [ dirruns, diff ]; |
| - | } |
| + | // Determine event propagation path in advance, per W3C events spec (#9951) |
| + | // Bubble up to document, then to window; watch for a global ownerDocument var (#9724) |
| + | if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) { |
| - | if ( node === elem ) { |
| - | break; |
| - | } |
| - | } |
| - | } |
| - | } |
| + | bubbleType = special.delegateType || type; |
| + | if ( !rfocusMorph.test( bubbleType + type ) ) { |
| + | cur = cur.parentNode; |
| + | } |
| + | for ( ; cur; cur = cur.parentNode ) { |
| + | eventPath.push( cur ); |
| + | tmp = cur; |
| + | } |
| - | // Incorporate the offset, then check against cycle size |
| - | diff -= last; |
| - | return diff === first || ( diff % first === 0 && diff / first >= 0 ); |
| - | } |
| - | }; |
| - | }, |
| + | // Only add window if we got to document (e.g., not plain obj or detached DOM) |
| + | if ( tmp === (elem.ownerDocument || document) ) { |
| + | eventPath.push( tmp.defaultView || tmp.parentWindow || window ); |
| + | } |
| + | } |
| - | "PSEUDO": function( pseudo, argument ) { |
| - | // pseudo-class names are case-insensitive |
| - | // http://www.w3.org/TR/selectors/#pseudo-classes |
| - | // Prioritize by case sensitivity in case custom pseudos are added with uppercase letters |
| - | // Remember that setFilters inherits from pseudos |
| - | var args, |
| - | fn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] || |
| - | Sizzle.error( "unsupported pseudo: " + pseudo ); |
| + | // Fire handlers on the event path |
| + | i = 0; |
| + | while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) { |
| - | // The user may use createPseudo to indicate that |
| - | // arguments are needed to create the filter function |
| - | // just as Sizzle does |
| - | if ( fn[ expando ] ) { |
| - | return fn( argument ); |
| - | } |
| + | event.type = i > 1 ? |
| + | bubbleType : |
| + | special.bindType || type; |
| - | // But maintain support for old signatures |
| - | if ( fn.length > 1 ) { |
| - | args = [ pseudo, pseudo, "", argument ]; |
| - | return Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ? |
| - | markFunction(function( seed, matches ) { |
| - | var idx, |
| - | matched = fn( seed, argument ), |
| - | i = matched.length; |
| - | while ( i-- ) { |
| - | idx = indexOf.call( seed, matched[i] ); |
| - | seed[ idx ] = !( matches[ idx ] = matched[i] ); |
| - | } |
| - | }) : |
| - | function( elem ) { |
| - | return fn( elem, 0, args ); |
| - | }; |
| + | // jQuery handler |
| + | handle = ( jQuery._data( cur, "events" ) || {} )[ event.type ] && jQuery._data( cur, "handle" ); |
| + | if ( handle ) { |
| + | handle.apply( cur, data ); |
| } | |
| - | return fn; |
| + | // Native handler |
| + | handle = ontype && cur[ ontype ]; |
| + | if ( handle && jQuery.acceptData( cur ) && handle.apply && handle.apply( cur, data ) === false ) { |
| + | event.preventDefault(); |
| + | } |
| } | |
| - | }, |
| + | event.type = type; |
| - | pseudos: { |
| - | // Potentially complex pseudos |
| - | "not": markFunction(function( selector ) { |
| - | // Trim the selector passed to compile |
| - | // to avoid treating leading and trailing |
| - | // spaces as combinators |
| - | var input = [], |
| - | results = [], |
| - | matcher = compile( selector.replace( rtrim, "$1" ) ); |
| + | // If nobody prevented the default action, do it now |
| + | if ( !onlyHandlers && !event.isDefaultPrevented() ) { |
| - | return matcher[ expando ] ? |
| - | markFunction(function( seed, matches, context, xml ) { |
| - | var elem, |
| - | unmatched = matcher( seed, null, xml, [] ), |
| - | i = seed.length; |
| + | if ( (!special._default || special._default.apply( eventPath.pop(), data ) === false) && |
| + | jQuery.acceptData( elem ) ) { |
| - | // Match elements unmatched by `matcher` |
| - | while ( i-- ) { |
| - | if ( (elem = unmatched[i]) ) { |
| - | seed[i] = !(matches[i] = elem); |
| - | } |
| - | } |
| - | }) : |
| - | function( elem, context, xml ) { |
| - | input[0] = elem; |
| - | matcher( input, null, xml, results ); |
| - | return !results.pop(); |
| - | }; |
| - | }), |
| + | // Call a native DOM method on the target with the same name name as the event. |
| + | // Can't use an .isFunction() check here because IE6/7 fails that test. |
| + | // Don't do default actions on window, that's where global variables be (#6170) |
| + | if ( ontype && elem[ type ] && !jQuery.isWindow( elem ) ) { |
| - | "has": markFunction(function( selector ) { |
| - | return function( elem ) { |
| - | return Sizzle( selector, elem ).length > 0; |
| - | }; |
| - | }), |
| + | // Don't re-trigger an onFOO event when we call its FOO() method |
| + | tmp = elem[ ontype ]; |
| - | "contains": markFunction(function( text ) { |
| - | return function( elem ) { |
| - | return ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1; |
| - | }; |
| - | }), |
| + | if ( tmp ) { |
| + | elem[ ontype ] = null; |
| + | } |
| - | // "Whether an element is represented by a :lang() selector |
| - | // is based solely on the element's language value |
| - | // being equal to the identifier C, |
| - | // or beginning with the identifier C immediately followed by "-". |
| - | // The matching of C against the element's language value is performed case-insensitively. |
| - | // The identifier C does not have to be a valid language name." |
| - | // http://www.w3.org/TR/selectors/#lang-pseudo |
| - | "lang": markFunction( function( lang ) { |
| - | // lang value must be a valid identifider |
| - | if ( !ridentifier.test(lang || "") ) { |
| - | Sizzle.error( "unsupported lang: " + lang ); |
| - | } |
| - | lang = lang.replace( runescape, funescape ).toLowerCase(); |
| - | return function( elem ) { |
| - | var elemLang; |
| - | do { |
| - | if ( (elemLang = documentIsXML ? |
| - | elem.getAttribute("xml:lang") || elem.getAttribute("lang") : |
| - | elem.lang) ) { |
| + | // Prevent re-triggering of the same event, since we already bubbled it above |
| + | jQuery.event.triggered = type; |
| + | try { |
| + | elem[ type ](); |
| + | } catch ( e ) { |
| + | // IE<9 dies on focus/blur to hidden element (#1486,#12518) |
| + | // only reproducible on winXP IE8 native, not IE9 in IE8 mode |
| + | } |
| + | jQuery.event.triggered = undefined; |
| - | elemLang = elemLang.toLowerCase(); |
| - | return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0; |
| + | if ( tmp ) { |
| + | elem[ ontype ] = tmp; |
| } | |
| - | } while ( (elem = elem.parentNode) && elem.nodeType === 1 ); |
| - | return false; |
| - | }; |
| - | }), |
| + | } |
| + | } |
| + | } |
| - | // Miscellaneous |
| - | "target": function( elem ) { |
| - | var hash = window.location && window.location.hash; |
| - | return hash && hash.slice( 1 ) === elem.id; |
| - | }, |
| + | return event.result; |
| + | }, |
| - | "root": function( elem ) { |
| - | return elem === docElem; |
| - | }, |
| + | dispatch: function( event ) { |
| - | "focus": function( elem ) { |
| - | return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex); |
| - | }, |
| + | // Make a writable jQuery.Event from the native event object |
| + | event = jQuery.event.fix( event ); |
| - | // Boolean properties |
| - | "enabled": function( elem ) { |
| - | return elem.disabled === false; |
| - | }, |
| + | var i, ret, handleObj, matched, j, |
| + | handlerQueue = [], |
| + | args = core_slice.call( arguments ), |
| + | handlers = ( jQuery._data( this, "events" ) || {} )[ event.type ] || [], |
| + | special = jQuery.event.special[ event.type ] || {}; |
| - | "disabled": function( elem ) { |
| - | return elem.disabled === true; |
| - | }, |
| + | // Use the fix-ed jQuery.Event rather than the (read-only) native event |
| + | args[0] = event; |
| + | event.delegateTarget = this; |
| - | "checked": function( elem ) { |
| - | // In CSS3, :checked should return both checked and selected elements |
| - | // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked |
| - | var nodeName = elem.nodeName.toLowerCase(); |
| - | return (nodeName === "input" && !!elem.checked) || (nodeName === "option" && !!elem.selected); |
| - | }, |
| + | // Call the preDispatch hook for the mapped type, and let it bail if desired |
| + | if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) { |
| + | return; |
| + | } |
| - | "selected": function( elem ) { |
| - | // Accessing this property makes selected-by-default |
| - | // options in Safari work properly |
| - | if ( elem.parentNode ) { |
| - | elem.parentNode.selectedIndex; |
| - | } |
| + | // Determine handlers |
| + | handlerQueue = jQuery.event.handlers.call( this, event, handlers ); |
| - | return elem.selected === true; |
| - | }, |
| + | // Run delegates first; they may want to stop propagation beneath us |
| + | i = 0; |
| + | while ( (matched = handlerQueue[ i++ ]) && !event.isPropagationStopped() ) { |
| + | event.currentTarget = matched.elem; |
| - | // Contents |
| - | "empty": function( elem ) { |
| - | // http://www.w3.org/TR/selectors/#empty-pseudo |
| - | // :empty is only affected by element nodes and content nodes(including text(3), cdata(4)), |
| - | // not comment, processing instructions, or others |
| - | // Thanks to Diego Perini for the nodeName shortcut |
| - | // Greater than "@" means alpha characters (specifically not starting with "#" or "?") |
| - | for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { |
| - | if ( elem.nodeName > "@" || elem.nodeType === 3 || elem.nodeType === 4 ) { |
| - | return false; |
| - | } |
| - | } |
| - | return true; |
| - | }, |
| + | j = 0; |
| + | while ( (handleObj = matched.handlers[ j++ ]) && !event.isImmediatePropagationStopped() ) { |
| - | "parent": function( elem ) { |
| - | return !Expr.pseudos["empty"]( elem ); |
| - | }, |
| + | // Triggered event must either 1) have no namespace, or |
| + | // 2) have namespace(s) a subset or equal to those in the bound event (both can have no namespace). |
| + | if ( !event.namespace_re || event.namespace_re.test( handleObj.namespace ) ) { |
| - | // Element/input types |
| - | "header": function( elem ) { |
| - | return rheader.test( elem.nodeName ); |
| - | }, |
| + | event.handleObj = handleObj; |
| + | event.data = handleObj.data; |
| - | "input": function( elem ) { |
| - | return rinputs.test( elem.nodeName ); |
| - | }, |
| + | ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || handleObj.handler ) |
| + | .apply( matched.elem, args ); |
| - | "button": function( elem ) { |
| - | var name = elem.nodeName.toLowerCase(); |
| - | return name === "input" && elem.type === "button" || name === "button"; |
| - | }, |
| + | if ( ret !== undefined ) { |
| + | if ( (event.result = ret) === false ) { |
| + | event.preventDefault(); |
| + | event.stopPropagation(); |
| + | } |
| + | } |
| + | } |
| + | } |
| + | } |
| - | "text": function( elem ) { |
| - | var attr; |
| - | // IE6 and 7 will map elem.type to 'text' for new HTML5 types (search, etc) |
| - | // use getAttribute instead to test this case |
| - | return elem.nodeName.toLowerCase() === "input" && |
| - | elem.type === "text" && |
| - | ( (attr = elem.getAttribute("type")) == null || attr.toLowerCase() === elem.type ); |
| - | }, |
| + | // Call the postDispatch hook for the mapped type |
| + | if ( special.postDispatch ) { |
| + | special.postDispatch.call( this, event ); |
| + | } |
| - | // Position-in-collection |
| - | "first": createPositionalPseudo(function() { |
| - | return [ 0 ]; |
| - | }), |
| + | return event.result; |
| + | }, |
| - | "last": createPositionalPseudo(function( matchIndexes, length ) { |
| - | return [ length - 1 ]; |
| - | }), |
| + | handlers: function( event, handlers ) { |
| + | var sel, handleObj, matches, i, |
| + | handlerQueue = [], |
| + | delegateCount = handlers.delegateCount, |
| + | cur = event.target; |
| - | "eq": createPositionalPseudo(function( matchIndexes, length, argument ) { |
| - | return [ argument < 0 ? argument + length : argument ]; |
| - | }), |
| + | // Find delegate handlers |
| + | // Black-hole SVG <use> instance trees (#13180) |
| + | // Avoid non-left-click bubbling in Firefox (#3861) |
| + | if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) { |
| - | "even": createPositionalPseudo(function( matchIndexes, length ) { |
| - | var i = 0; |
| - | for ( ; i < length; i += 2 ) { |
| - | matchIndexes.push( i ); |
| - | } |
| - | return matchIndexes; |
| - | }), |
| + | /* jshint eqeqeq: false */ |
| + | for ( ; cur != this; cur = cur.parentNode || this ) { |
| + | /* jshint eqeqeq: true */ |
| + | |
| + | // Don't check non-elements (#13208) |
| + | // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) |
| + | if ( cur.nodeType === 1 && (cur.disabled !== true || event.type !== "click") ) { |
| + | matches = []; |
| + | for ( i = 0; i < delegateCount; i++ ) { |
| + | handleObj = handlers[ i ]; |
| - | "odd": createPositionalPseudo(function( matchIndexes, length ) { |
| - | var i = 1; |
| - | for ( ; i < length; i += 2 ) { |
| - | matchIndexes.push( i ); |
| - | } |
| - | return matchIndexes; |
| - | }), |
| + | // Don't conflict with Object.prototype properties (#13203) |
| + | sel = handleObj.selector + " "; |
| - | "lt": createPositionalPseudo(function( matchIndexes, length, argument ) { |
| - | var i = argument < 0 ? argument + length : argument; |
| - | for ( ; --i >= 0; ) { |
| - | matchIndexes.push( i ); |
| + | if ( matches[ sel ] === undefined ) { |
| + | matches[ sel ] = handleObj.needsContext ? |
| + | jQuery( sel, this ).index( cur ) >= 0 : |
| + | jQuery.find( sel, this, null, [ cur ] ).length; |
| + | } |
| + | if ( matches[ sel ] ) { |
| + | matches.push( handleObj ); |
| + | } |
| + | } |
| + | if ( matches.length ) { |
| + | handlerQueue.push({ elem: cur, handlers: matches }); |
| + | } |
| + | } |
| } | |
| - | return matchIndexes; |
| - | }), |
| + | } |
| - | "gt": createPositionalPseudo(function( matchIndexes, length, argument ) { |
| - | var i = argument < 0 ? argument + length : argument; |
| - | for ( ; ++i < length; ) { |
| - | matchIndexes.push( i ); |
| - | } |
| - | return matchIndexes; |
| - | }) |
| - | } |
| - | }; |
| + | // Add the remaining (directly-bound) handlers |
| + | if ( delegateCount < handlers.length ) { |
| + | handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) }); |
| + | } |
| - | // Add button/input type pseudos |
| - | for ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) { |
| - | Expr.pseudos[ i ] = createInputPseudo( i ); |
| - | } |
| - | for ( i in { submit: true, reset: true } ) { |
| - | Expr.pseudos[ i ] = createButtonPseudo( i ); |
| - | } |
| + | return handlerQueue; |
| + | }, |
| - | function tokenize( selector, parseOnly ) { |
| - | var matched, match, tokens, type, |
| - | soFar, groups, preFilters, |
| - | cached = tokenCache[ selector + " " ]; |
| + | fix: function( event ) { |
| + | if ( event[ jQuery.expando ] ) { |
| + | return event; |
| + | } |
| - | if ( cached ) { |
| - | return parseOnly ? 0 : cached.slice( 0 ); |
| - | } |
| + | // Create a writable copy of the event object and normalize some properties |
| + | var i, prop, copy, |
| + | type = event.type, |
| + | originalEvent = event, |
| + | fixHook = this.fixHooks[ type ]; |
| - | soFar = selector; |
| - | groups = []; |
| - | preFilters = Expr.preFilter; |
| + | if ( !fixHook ) { |
| + | this.fixHooks[ type ] = fixHook = |
| + | rmouseEvent.test( type ) ? this.mouseHooks : |
| + | rkeyEvent.test( type ) ? this.keyHooks : |
| + | {}; |
| + | } |
| + | copy = fixHook.props ? this.props.concat( fixHook.props ) : this.props; |
| - | while ( soFar ) { |
| + | event = new jQuery.Event( originalEvent ); |
| - | // Comma and first run |
| - | if ( !matched || (match = rcomma.exec( soFar )) ) { |
| - | if ( match ) { |
| - | // Don't consume trailing commas as valid |
| - | soFar = soFar.slice( match[0].length ) || soFar; |
| - | } |
| - | groups.push( tokens = [] ); |
| + | i = copy.length; |
| + | while ( i-- ) { |
| + | prop = copy[ i ]; |
| + | event[ prop ] = originalEvent[ prop ]; |
| } | |
| - | matched = false; |
| + | // Support: IE<9 |
| + | // Fix target property (#1925) |
| + | if ( !event.target ) { |
| + | event.target = originalEvent.srcElement || document; |
| + | } |
| - | // Combinators |
| - | if ( (match = rcombinators.exec( soFar )) ) { |
| - | matched = match.shift(); |
| - | tokens.push( { |
| - | value: matched, |
| - | // Cast descendant combinators to space |
| - | type: match[0].replace( rtrim, " " ) |
| - | } ); |
| - | soFar = soFar.slice( matched.length ); |
| + | // Support: Chrome 23+, Safari? |
| + | // Target should not be a text node (#504, #13143) |
| + | if ( event.target.nodeType === 3 ) { |
| + | event.target = event.target.parentNode; |
| } | |
| - | // Filters |
| - | for ( type in Expr.filter ) { |
| - | if ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] || |
| - | (match = preFilters[ type ]( match ))) ) { |
| - | matched = match.shift(); |
| - | tokens.push( { |
| - | value: matched, |
| - | type: type, |
| - | matches: match |
| - | } ); |
| - | soFar = soFar.slice( matched.length ); |
| + | // Support: IE<9 |
| + | // For mouse/key events, metaKey==false if it's undefined (#3368, #11328) |
| + | event.metaKey = !!event.metaKey; |
| + | |
| + | return fixHook.filter ? fixHook.filter( event, originalEvent ) : event; |
| + | }, |
| + | |
| + | // Includes some event props shared by KeyEvent and MouseEvent |
| + | props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), |
| + | |
| + | fixHooks: {}, |
| + | |
| + | keyHooks: { |
| + | props: "char charCode key keyCode".split(" "), |
| + | filter: function( event, original ) { |
| + | |
| + | // Add which for key events |
| + | if ( event.which == null ) { |
| + | event.which = original.charCode != null ? original.charCode : original.keyCode; |
| } | |
| - | } |
| - | if ( !matched ) { |
| - | break; |
| + | return event; |
| } | |
| - | } |
| + | }, |
| - | // Return the length of the invalid excess |
| - | // if we're just parsing |
| - | // Otherwise, throw an error or return tokens |
| - | return parseOnly ? |
| - | soFar.length : |
| - | soFar ? |
| - | Sizzle.error( selector ) : |
| - | // Cache the tokens |
| - | tokenCache( selector, groups ).slice( 0 ); |
| - | } |
| + | mouseHooks: { |
| + | props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "), |
| + | filter: function( event, original ) { |
| + | var body, eventDoc, doc, |
| + | button = original.button, |
| + | fromElement = original.fromElement; |
| - | function toSelector( tokens ) { |
| - | var i = 0, |
| - | len = tokens.length, |
| - | selector = ""; |
| - | for ( ; i < len; i++ ) { |
| - | selector += tokens[i].value; |
| - | } |
| - | return selector; |
| - | } |
| + | // Calculate pageX/Y if missing and clientX/Y available |
| + | if ( event.pageX == null && original.clientX != null ) { |
| + | eventDoc = event.target.ownerDocument || document; |
| + | doc = eventDoc.documentElement; |
| + | body = eventDoc.body; |
| - | function addCombinator( matcher, combinator, base ) { |
| - | var dir = combinator.dir, |
| - | checkNonElements = base && dir === "parentNode", |
| - | doneName = done++; |
| + | event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft || body && body.clientLeft || 0 ); |
| + | event.pageY = original.clientY + ( doc && doc.scrollTop || body && body.scrollTop || 0 ) - ( doc && doc.clientTop || body && body.clientTop || 0 ); |
| + | } |
| - | return combinator.first ? |
| - | // Check against closest ancestor/preceding element |
| - | function( elem, context, xml ) { |
| - | while ( (elem = elem[ dir ]) ) { |
| - | if ( elem.nodeType === 1 || checkNonElements ) { |
| - | return matcher( elem, context, xml ); |
| - | } |
| + | // Add relatedTarget, if necessary |
| + | if ( !event.relatedTarget && fromElement ) { |
| + | event.relatedTarget = fromElement === event.target ? original.toElement : fromElement; |
| } | |
| - | } : |
| - | // Check against all ancestor/preceding elements |
| - | function( elem, context, xml ) { |
| - | var data, cache, outerCache, |
| - | dirkey = dirruns + " " + doneName; |
| + | // Add which for click: 1 === left; 2 === middle; 3 === right |
| + | // Note: button is not normalized, so don't use it |
| + | if ( !event.which && button !== undefined ) { |
| + | event.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) ); |
| + | } |
| - | // We can't set arbitrary data on XML nodes, so they don't benefit from dir caching |
| - | if ( xml ) { |
| - | while ( (elem = elem[ dir ]) ) { |
| - | if ( elem.nodeType === 1 || checkNonElements ) { |
| - | if ( matcher( elem, context, xml ) ) { |
| - | return true; |
| - | } |
| - | } |
| - | } |
| - | } else { |
| - | while ( (elem = elem[ dir ]) ) { |
| - | if ( elem.nodeType === 1 || checkNonElements ) { |
| - | outerCache = elem[ expando ] || (elem[ expando ] = {}); |
| - | if ( (cache = outerCache[ dir ]) && cache[0] === dirkey ) { |
| - | if ( (data = cache[1]) === true || data === cachedruns ) { |
| - | return data === true; |
| - | } |
| - | } else { |
| - | cache = outerCache[ dir ] = [ dirkey ]; |
| - | cache[1] = matcher( elem, context, xml ) || cachedruns; |
| - | if ( cache[1] === true ) { |
| - | return true; |
| - | } |
| - | } |
| + | return event; |
| + | } |
| + | }, |
| + | |
| + | special: { |
| + | load: { |
| + | // Prevent triggered image.load events from bubbling to window.load |
| + | noBubble: true |
| + | }, |
| + | focus: { |
| + | // Fire native event if possible so blur/focus sequence is correct |
| + | trigger: function() { |
| + | if ( this !== safeActiveElement() && this.focus ) { |
| + | try { |
| + | this.focus(); |
| + | return false; |
| + | } catch ( e ) { |
| + | // Support: IE<9 |
| + | // If we error on focus to hidden element (#1486, #12518), |
| + | // let .trigger() run the handlers |
| } | |
| } | |
| - | } |
| - | }; |
| - | } |
| - | |
| - | function elementMatcher( matchers ) { |
| - | return matchers.length > 1 ? |
| - | function( elem, context, xml ) { |
| - | var i = matchers.length; |
| - | while ( i-- ) { |
| - | if ( !matchers[i]( elem, context, xml ) ) { |
| + | }, |
| + | delegateType: "focusin" |
| + | }, |
| + | blur: { |
| + | trigger: function() { |
| + | if ( this === safeActiveElement() && this.blur ) { |
| + | this.blur(); |
| + | return false; |
| + | } |
| + | }, |
| + | delegateType: "focusout" |
| + | }, |
| + | click: { |
| + | // For checkbox, fire native event so checked state will be right |
| + | trigger: function() { |
| + | if ( jQuery.nodeName( this, "input" ) && this.type === "checkbox" && this.click ) { |
| + | this.click(); |
| return false; | |
| } | |
| + | }, |
| + | |
| + | // For cross-browser consistency, don't fire native .click() on links |
| + | _default: function( event ) { |
| + | return jQuery.nodeName( event.target, "a" ); |
| } | |
| - | return true; |
| - | } : |
| - | matchers[0]; |
| - | } |
| + | }, |
| - | function condense( unmatched, map, filter, context, xml ) { |
| - | var elem, |
| - | newUnmatched = [], |
| - | i = 0, |
| - | len = unmatched.length, |
| - | mapped = map != null; |
| + | beforeunload: { |
| + | postDispatch: function( event ) { |
| - | for ( ; i < len; i++ ) { |
| - | if ( (elem = unmatched[i]) ) { |
| - | if ( !filter || filter( elem, context, xml ) ) { |
| - | newUnmatched.push( elem ); |
| - | if ( mapped ) { |
| - | map.push( i ); |
| + | // Even when returnValue equals to undefined Firefox will still show alert |
| + | if ( event.result !== undefined ) { |
| + | event.originalEvent.returnValue = event.result; |
| } | |
| } | |
| } | |
| + | }, |
| + | |
| + | simulate: function( type, elem, event, bubble ) { |
| + | // Piggyback on a donor event to simulate a different one. |
| + | // Fake originalEvent to avoid donor's stopPropagation, but if the |
| + | // simulated event prevents default then we do the same on the donor. |
| + | var e = jQuery.extend( |
| + | new jQuery.Event(), |
| + | event, |
| + | { |
| + | type: type, |
| + | isSimulated: true, |
| + | originalEvent: {} |
| + | } |
| + | ); |
| + | if ( bubble ) { |
| + | jQuery.event.trigger( e, null, elem ); |
| + | } else { |
| + | jQuery.event.dispatch.call( elem, e ); |
| + | } |
| + | if ( e.isDefaultPrevented() ) { |
| + | event.preventDefault(); |
| + | } |
| } | |
| + | }; |
| - | return newUnmatched; |
| - | } |
| + | jQuery.removeEvent = document.removeEventListener ? |
| + | function( elem, type, handle ) { |
| + | if ( elem.removeEventListener ) { |
| + | elem.removeEventListener( type, handle, false ); |
| + | } |
| + | } : |
| + | function( elem, type, handle ) { |
| + | var name = "on" + type; |
| - | function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) { |
| - | if ( postFilter && !postFilter[ expando ] ) { |
| - | postFilter = setMatcher( postFilter ); |
| - | } |
| - | if ( postFinder && !postFinder[ expando ] ) { |
| - | postFinder = setMatcher( postFinder, postSelector ); |
| - | } |
| - | return markFunction(function( seed, results, context, xml ) { |
| - | var temp, i, elem, |
| - | preMap = [], |
| - | postMap = [], |
| - | preexisting = results.length, |
| + | if ( elem.detachEvent ) { |
| - | // Get initial elements from seed or context |
| - | elems = seed || multipleContexts( selector || "*", context.nodeType ? [ context ] : context, [] ), |
| + | // #8545, #7054, preventing memory leaks for custom events in IE6-8 |
| + | // detachEvent needed property on element, by name of that event, to properly expose it to GC |
| + | if ( typeof elem[ name ] === core_strundefined ) { |
| + | elem[ name ] = null; |
| + | } |
| - | // Prefilter to get matcher input, preserving a map for seed-results synchronization |
| - | matcherIn = preFilter && ( seed || !selector ) ? |
| - | condense( elems, preMap, preFilter, context, xml ) : |
| - | elems, |
| + | elem.detachEvent( name, handle ); |
| + | } |
| + | }; |
| - | matcherOut = matcher ? |
| - | // If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results, |
| - | postFinder || ( seed ? preFilter : preexisting || postFilter ) ? |
| + | jQuery.Event = function( src, props ) { |
| + | // Allow instantiation without the 'new' keyword |
| + | if ( !(this instanceof jQuery.Event) ) { |
| + | return new jQuery.Event( src, props ); |
| + | } |
| - | // ...intermediate processing is necessary |
| - | [] : |
| + | // Event object |
| + | if ( src && src.type ) { |
| + | this.originalEvent = src; |
| + | this.type = src.type; |
| - | // ...otherwise use results directly |
| - | results : |
| - | matcherIn; |
| + | // Events bubbling up the document may have been marked as prevented |
| + | // by a handler lower down the tree; reflect the correct value. |
| + | this.isDefaultPrevented = ( src.defaultPrevented || src.returnValue === false || |
| + | src.getPreventDefault && src.getPreventDefault() ) ? returnTrue : returnFalse; |
| - | // Find primary matches |
| - | if ( matcher ) { |
| - | matcher( matcherIn, matcherOut, context, xml ); |
| - | } |
| + | // Event type |
| + | } else { |
| + | this.type = src; |
| + | } |
| - | // Apply postFilter |
| - | if ( postFilter ) { |
| - | temp = condense( matcherOut, postMap ); |
| - | postFilter( temp, [], context, xml ); |
| + | // Put explicitly provided properties onto the event object |
| + | if ( props ) { |
| + | jQuery.extend( this, props ); |
| + | } |
| - | // Un-match failing elements by moving them back to matcherIn |
| - | i = temp.length; |
| - | while ( i-- ) { |
| - | if ( (elem = temp[i]) ) { |
| - | matcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem); |
| - | } |
| - | } |
| - | } |
| + | // Create a timestamp if incoming event doesn't have one |
| + | this.timeStamp = src && src.timeStamp || jQuery.now(); |
| - | if ( seed ) { |
| - | if ( postFinder || preFilter ) { |
| - | if ( postFinder ) { |
| - | // Get the final matcherOut by condensing this intermediate into postFinder contexts |
| - | temp = []; |
| - | i = matcherOut.length; |
| - | while ( i-- ) { |
| - | if ( (elem = matcherOut[i]) ) { |
| - | // Restore matcherIn since elem is not yet a final match |
| - | temp.push( (matcherIn[i] = elem) ); |
| - | } |
| - | } |
| - | postFinder( null, (matcherOut = []), temp, xml ); |
| - | } |
| + | // Mark it as fixed |
| + | this[ jQuery.expando ] = true; |
| + | }; |
| - | // Move matched elements from seed to results to keep them synchronized |
| - | i = matcherOut.length; |
| - | while ( i-- ) { |
| - | if ( (elem = matcherOut[i]) && |
| - | (temp = postFinder ? indexOf.call( seed, elem ) : preMap[i]) > -1 ) { |
| + | // jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding |
| + | // http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html |
| + | jQuery.Event.prototype = { |
| + | isDefaultPrevented: returnFalse, |
| + | isPropagationStopped: returnFalse, |
| + | isImmediatePropagationStopped: returnFalse, |
| - | seed[temp] = !(results[temp] = elem); |
| - | } |
| - | } |
| - | } |
| + | preventDefault: function() { |
| + | var e = this.originalEvent; |
| - | // Add elements to results, through postFinder if defined |
| - | } else { |
| - | matcherOut = condense( |
| - | matcherOut === results ? |
| - | matcherOut.splice( preexisting, matcherOut.length ) : |
| - | matcherOut |
| - | ); |
| - | if ( postFinder ) { |
| - | postFinder( null, results, matcherOut, xml ); |
| - | } else { |
| - | push.apply( results, matcherOut ); |
| - | } |
| + | this.isDefaultPrevented = returnTrue; |
| + | if ( !e ) { |
| + | return; |
| } | |
| - | }); |
| - | } |
| - | |
| - | function matcherFromTokens( tokens ) { |
| - | var checkContext, matcher, j, |
| - | len = tokens.length, |
| - | leadingRelative = Expr.relative[ tokens[0].type ], |
| - | implicitRelative = leadingRelative || Expr.relative[" "], |
| - | i = leadingRelative ? 1 : 0, |
| - | // The foundational matcher ensures that elements are reachable from top-level context(s) |
| - | matchContext = addCombinator( function( elem ) { |
| - | return elem === checkContext; |
| - | }, implicitRelative, true ), |
| - | matchAnyContext = addCombinator( function( elem ) { |
| - | return indexOf.call( checkContext, elem ) > -1; |
| - | }, implicitRelative, true ), |
| - | matchers = [ function( elem, context, xml ) { |
| - | return ( !leadingRelative && ( xml || context !== outermostContext ) ) || ( |
| - | (checkContext = context).nodeType ? |
| - | matchContext( elem, context, xml ) : |
| - | matchAnyContext( elem, context, xml ) ); |
| - | } ]; |
| + | // If preventDefault exists, run it on the original event |
| + | if ( e.preventDefault ) { |
| + | e.preventDefault(); |
| - | for ( ; i < len; i++ ) { |
| - | if ( (matcher = Expr.relative[ tokens[i].type ]) ) { |
| - | matchers = [ addCombinator(elementMatcher( matchers ), matcher) ]; |
| + | // Support: IE |
| + | // Otherwise set the returnValue property of the original event to false |
| } else { | |
| - | matcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches ); |
| + | e.returnValue = false; |
| + | } |
| + | }, |
| + | stopPropagation: function() { |
| + | var e = this.originalEvent; |
| - | // Return special upon seeing a positional matcher |
| - | if ( matcher[ expando ] ) { |
| - | // Find the next relative operator (if any) for proper handling |
| - | j = ++i; |
| - | for ( ; j < len; j++ ) { |
| - | if ( Expr.relative[ tokens[j].type ] ) { |
| - | break; |
| - | } |
| - | } |
| - | return setMatcher( |
| - | i > 1 && elementMatcher( matchers ), |
| - | i > 1 && toSelector( tokens.slice( 0, i - 1 ) ).replace( rtrim, "$1" ), |
| - | matcher, |
| - | i < j && matcherFromTokens( tokens.slice( i, j ) ), |
| - | j < len && matcherFromTokens( (tokens = tokens.slice( j )) ), |
| - | j < len && toSelector( tokens ) |
| - | ); |
| - | } |
| - | matchers.push( matcher ); |
| + | this.isPropagationStopped = returnTrue; |
| + | if ( !e ) { |
| + | return; |
| + | } |
| + | // If stopPropagation exists, run it on the original event |
| + | if ( e.stopPropagation ) { |
| + | e.stopPropagation(); |
| } | |
| + | |
| + | // Support: IE |
| + | // Set the cancelBubble property of the original event to true |
| + | e.cancelBubble = true; |
| + | }, |
| + | stopImmediatePropagation: function() { |
| + | this.isImmediatePropagationStopped = returnTrue; |
| + | this.stopPropagation(); |
| } | |
| + | }; |
| - | return elementMatcher( matchers ); |
| - | } |
| + | // Create mouseenter/leave events using mouseover/out and event-time checks |
| + | jQuery.each({ |
| + | mouseenter: "mouseover", |
| + | mouseleave: "mouseout" |
| + | }, function( orig, fix ) { |
| + | jQuery.event.special[ orig ] = { |
| + | delegateType: fix, |
| + | bindType: fix, |
| - | function matcherFromGroupMatchers( elementMatchers, setMatchers ) { |
| - | // A counter to specify which element is currently being matched |
| - | var matcherCachedRuns = 0, |
| - | bySet = setMatchers.length > 0, |
| - | byElement = elementMatchers.length > 0, |
| - | superMatcher = function( seed, context, xml, results, expandContext ) { |
| - | var elem, j, matcher, |
| - | setMatched = [], |
| - | matchedCount = 0, |
| - | i = "0", |
| - | unmatched = seed && [], |
| - | outermost = expandContext != null, |
| - | contextBackup = outermostContext, |
| - | // We must always have either seed elements or context |
| - | elems = seed || byElement && Expr.find["TAG"]( "*", expandContext && context.parentNode || context ), |
| - | // Use integer dirruns iff this is the outermost matcher |
| - | dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1); |
| + | handle: function( event ) { |
| + | var ret, |
| + | target = this, |
| + | related = event.relatedTarget, |
| + | handleObj = event.handleObj; |
| - | if ( outermost ) { |
| - | outermostContext = context !== document && context; |
| - | cachedruns = matcherCachedRuns; |
| + | // For mousenter/leave call the handler if related is outside the target. |
| + | // NB: No relatedTarget if the mouse left/entered the browser window |
| + | if ( !related || (related !== target && !jQuery.contains( target, related )) ) { |
| + | event.type = handleObj.origType; |
| + | ret = handleObj.handler.apply( this, arguments ); |
| + | event.type = fix; |
| } | |
| + | return ret; |
| + | } |
| + | }; |
| + | }); |
| - | // Add elements passing elementMatchers directly to results |
| - | // Keep `i` a string if there are no elements so `matchedCount` will be "00" below |
| - | for ( ; (elem = elems[i]) != null; i++ ) { |
| - | if ( byElement && elem ) { |
| - | j = 0; |
| - | while ( (matcher = elementMatchers[j++]) ) { |
| - | if ( matcher( elem, context, xml ) ) { |
| - | results.push( elem ); |
| - | break; |
| - | } |
| - | } |
| - | if ( outermost ) { |
| - | dirruns = dirrunsUnique; |
| - | cachedruns = ++matcherCachedRuns; |
| - | } |
| - | } |
| - | |
| - | // Track unmatched elements for set filters |
| - | if ( bySet ) { |
| - | // They will have gone through all possible matchers |
| - | if ( (elem = !matcher && elem) ) { |
| - | matchedCount--; |
| - | } |
| + | // IE submit delegation |
| + | if ( !jQuery.support.submitBubbles ) { |
| - | // Lengthen the array for every element, matched or not |
| - | if ( seed ) { |
| - | unmatched.push( elem ); |
| - | } |
| - | } |
| + | jQuery.event.special.submit = { |
| + | setup: function() { |
| + | // Only need this for delegated form submit events |
| + | if ( jQuery.nodeName( this, "form" ) ) { |
| + | return false; |
| } | |
| - | // Apply set filters to unmatched elements |
| - | matchedCount += i; |
| - | if ( bySet && i !== matchedCount ) { |
| - | j = 0; |
| - | while ( (matcher = setMatchers[j++]) ) { |
| - | matcher( unmatched, setMatched, context, xml ); |
| - | } |
| - | |
| - | if ( seed ) { |
| - | // Reintegrate element matches to eliminate the need for sorting |
| - | if ( matchedCount > 0 ) { |
| - | while ( i-- ) { |
| - | if ( !(unmatched[i] || setMatched[i]) ) { |
| - | setMatched[i] = pop.call( results ); |
| - | } |
| - | } |
| - | } |
| - | |
| - | // Discard index placeholder values to get only actual matches |
| - | setMatched = condense( setMatched ); |
| + | // Lazy-add a submit handler when a descendant form may potentially be submitted |
| + | jQuery.event.add( this, "click._submit keypress._submit", function( e ) { |
| + | // Node name check avoids a VML-related crash in IE (#9807) |
| + | var elem = e.target, |
| + | form = jQuery.nodeName( elem, "input" ) || jQuery.nodeName( elem, "button" ) ? elem.form : undefined; |
| + | if ( form && !jQuery._data( form, "submitBubbles" ) ) { |
| + | jQuery.event.add( form, "submit._submit", function( event ) { |
| + | event._submit_bubble = true; |
| + | }); |
| + | jQuery._data( form, "submitBubbles", true ); |
| } | |
| + | }); |
| + | // return undefined since we don't need an event listener |
| + | }, |
| - | // Add matches to results |
| - | push.apply( results, setMatched ); |
| - | |
| - | // Seedless set matches succeeding multiple successful matchers stipulate sorting |
| - | if ( outermost && !seed && setMatched.length > 0 && |
| - | ( matchedCount + setMatchers.length ) > 1 ) { |
| - | |
| - | Sizzle.uniqueSort( results ); |
| + | postDispatch: function( event ) { |
| + | // If form was submitted by the user, bubble the event up the tree |
| + | if ( event._submit_bubble ) { |
| + | delete event._submit_bubble; |
| + | if ( this.parentNode && !event.isTrigger ) { |
| + | jQuery.event.simulate( "submit", this.parentNode, event, true ); |
| } | |
| } | |
| + | }, |
| - | // Override manipulation of globals by nested matchers |
| - | if ( outermost ) { |
| - | dirruns = dirrunsUnique; |
| - | outermostContext = contextBackup; |
| + | teardown: function() { |
| + | // Only need this for delegated form submit events |
| + | if ( jQuery.nodeName( this, "form" ) ) { |
| + | return false; |
| } | |
| - | return unmatched; |
| - | }; |
| - | |
| - | return bySet ? |
| - | markFunction( superMatcher ) : |
| - | superMatcher; |
| - | } |
| - | |
| - | compile = Sizzle.compile = function( selector, group /* Internal Use Only */ ) { |
| - | var i, |
| - | setMatchers = [], |
| - | elementMatchers = [], |
| - | cached = compilerCache[ selector + " " ]; |
| - | |
| - | if ( !cached ) { |
| - | // Generate a function of recursive functions that can be used to check each element |
| - | if ( !group ) { |
| - | group = tokenize( selector ); |
| - | } |
| - | i = group.length; |
| - | while ( i-- ) { |
| - | cached = matcherFromTokens( group[i] ); |
| - | if ( cached[ expando ] ) { |
| - | setMatchers.push( cached ); |
| - | } else { |
| - | elementMatchers.push( cached ); |
| - | } |
| + | // Remove delegated handlers; cleanData eventually reaps submit handlers attached above |
| + | jQuery.event.remove( this, "._submit" ); |
| } | |
| - | |
| - | // Cache the compiled function |
| - | cached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) ); |
| - | } |
| - | return cached; |
| - | }; |
| - | |
| - | function multipleContexts( selector, contexts, results ) { |
| - | var i = 0, |
| - | len = contexts.length; |
| - | for ( ; i < len; i++ ) { |
| - | Sizzle( selector, contexts[i], results ); |
| - | } |
| - | return results; |
| + | }; |
| } | |
| - | function select( selector, context, results, seed ) { |
| - | var i, tokens, token, type, find, |
| - | match = tokenize( selector ); |
| + | // IE change delegation and checkbox/radio fix |
| + | if ( !jQuery.support.changeBubbles ) { |
| - | if ( !seed ) { |
| - | // Try to minimize operations if there is only one group |
| - | if ( match.length === 1 ) { |
| + | jQuery.event.special.change = { |
| - | // Take a shortcut and set the context if the root selector is an ID |
| - | tokens = match[0] = match[0].slice( 0 ); |
| - | if ( tokens.length > 2 && (token = tokens[0]).type === "ID" && |
| - | context.nodeType === 9 && !documentIsXML && |
| - | Expr.relative[ tokens[1].type ] ) { |
| + | setup: function() { |
| - | context = Expr.find["ID"]( token.matches[0].replace( runescape, funescape ), context )[0]; |
| - | if ( !context ) { |
| - | return results; |
| + | if ( rformElems.test( this.nodeName ) ) { |
| + | // IE doesn't fire change on a check/radio until blur; trigger it on click |
| + | // after a propertychange. Eat the blur-change in special.change.handle. |
| + | // This still fires onchange a second time for check/radio after blur. |
| + | if ( this.type === "checkbox" || this.type === "radio" ) { |
| + | jQuery.event.add( this, "propertychange._change", function( event ) { |
| + | if ( event.originalEvent.propertyName === "checked" ) { |
| + | this._just_changed = true; |
| + | } |
| + | }); |
| + | jQuery.event.add( this, "click._change", function( event ) { |
| + | if ( this._just_changed && !event.isTrigger ) { |
| + | this._just_changed = false; |
| + | } |
| + | // Allow triggered, simulated change events (#11500) |
| + | jQuery.event.simulate( "change", this, event, true ); |
| + | }); |
| + | } |
| + | return false; |
| + | } |
| + | // Delegated event; lazy-add a change handler on descendant inputs |
| + | jQuery.event.add( this, "beforeactivate._change", function( e ) { |
| + | var elem = e.target; |
| + | |
| + | if ( rformElems.test( elem.nodeName ) && !jQuery._data( elem, "changeBubbles" ) ) { |
| + | jQuery.event.add( elem, "change._change", function( event ) { |
| + | if ( this.parentNode && !event.isSimulated && !event.isTrigger ) { |
| + | jQuery.event.simulate( "change", this.parentNode, event, true ); |
| + | } |
| + | }); |
| + | jQuery._data( elem, "changeBubbles", true ); |
| } | |
| + | }); |
| + | }, |
| - | selector = selector.slice( tokens.shift().value.length ); |
| + | handle: function( event ) { |
| + | var elem = event.target; |
| + | |
| + | // Swallow native change events from checkbox/radio, we already triggered them above |
| + | if ( this !== elem || event.isSimulated || event.isTrigger || (elem.type !== "radio" && elem.type !== "checkbox") ) { |
| + | return event.handleObj.handler.apply( this, arguments ); |
| } | |
| + | }, |
| - | // Fetch a seed set for right-to-left matching |
| - | i = matchExpr["needsContext"].test( selector ) ? 0 : tokens.length; |
| - | while ( i-- ) { |
| - | token = tokens[i]; |
| + | teardown: function() { |
| + | jQuery.event.remove( this, "._change" ); |
| + | |
| + | return !rformElems.test( this.nodeName ); |
| + | } |
| + | }; |
| + | } |
| - | // Abort if we hit a combinator |
| - | if ( Expr.relative[ (type = token.type) ] ) { |
| - | break; |
| - | } |
| - | if ( (find = Expr.find[ type ]) ) { |
| - | // Search, expanding context for leading sibling combinators |
| - | if ( (seed = find( |
| - | token.matches[0].replace( runescape, funescape ), |
| - | rsibling.test( tokens[0].type ) && context.parentNode || context |
| - | )) ) { |
| + | // Create "bubbling" focus and blur events |
| + | if ( !jQuery.support.focusinBubbles ) { |
| + | jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { |
| - | // If seed is empty or no tokens remain, we can return early |
| - | tokens.splice( i, 1 ); |
| - | selector = seed.length && toSelector( tokens ); |
| - | if ( !selector ) { |
| - | push.apply( results, slice.call( seed, 0 ) ); |
| - | return results; |
| - | } |
| + | // Attach a single capturing handler while someone wants focusin/focusout |
| + | var attaches = 0, |
| + | handler = function( event ) { |
| + | jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ), true ); |
| + | }; |
| - | break; |
| - | } |
| + | jQuery.event.special[ fix ] = { |
| + | setup: function() { |
| + | if ( attaches++ === 0 ) { |
| + | document.addEventListener( orig, handler, true ); |
| + | } |
| + | }, |
| + | teardown: function() { |
| + | if ( --attaches === 0 ) { |
| + | document.removeEventListener( orig, handler, true ); |
| } | |
| } | |
| - | } |
| - | } |
| - | |
| - | // Compile and execute a filtering function |
| - | // Provide `match` to avoid retokenization if we modified the selector above |
| - | compile( selector, match )( |
| - | seed, |
| - | context, |
| - | documentIsXML, |
| - | results, |
| - | rsibling.test( selector ) |
| - | ); |
| - | return results; |
| + | }; |
| + | }); |
| } | |
| - | // Deprecated |
| - | Expr.pseudos["nth"] = Expr.pseudos["eq"]; |
| + | jQuery.fn.extend({ |
| - | // Easy API for creating new setFilters |
| - | function setFilters() {} |
| - | Expr.filters = setFilters.prototype = Expr.pseudos; |
| - | Expr.setFilters = new setFilters(); |
| + | on: function( types, selector, data, fn, /*INTERNAL*/ one ) { |
| + | var type, origFn; |
| - | // Initialize with the default document |
| - | setDocument(); |
| + | // Types can be a map of types/handlers |
| + | if ( typeof types === "object" ) { |
| + | // ( types-Object, selector, data ) |
| + | if ( typeof selector !== "string" ) { |
| + | // ( types-Object, data ) |
| + | data = data || selector; |
| + | selector = undefined; |
| + | } |
| + | for ( type in types ) { |
| + | this.on( type, selector, data, types[ type ], one ); |
| + | } |
| + | return this; |
| + | } |
| - | // Override sizzle attribute retrieval |
| - | Sizzle.attr = jQuery.attr; |
| - | jQuery.find = Sizzle; |
| - | jQuery.expr = Sizzle.selectors; |
| - | jQuery.expr[":"] = jQuery.expr.pseudos; |
| - | jQuery.unique = Sizzle.uniqueSort; |
| - | jQuery.text = Sizzle.getText; |
| - | jQuery.isXMLDoc = Sizzle.isXML; |
| - | jQuery.contains = Sizzle.contains; |
| + | if ( data == null && fn == null ) { |
| + | // ( types, fn ) |
| + | fn = selector; |
| + | data = selector = undefined; |
| + | } else if ( fn == null ) { |
| + | if ( typeof selector === "string" ) { |
| + | // ( types, selector, fn ) |
| + | fn = data; |
| + | data = undefined; |
| + | } else { |
| + | // ( types, data, fn ) |
| + | fn = data; |
| + | data = selector; |
| + | selector = undefined; |
| + | } |
| + | } |
| + | if ( fn === false ) { |
| + | fn = returnFalse; |
| + | } else if ( !fn ) { |
| + | return this; |
| + | } |
| + | if ( one === 1 ) { |
| + | origFn = fn; |
| + | fn = function( event ) { |
| + | // Can use an empty set, since event contains the info |
| + | jQuery().off( event ); |
| + | return origFn.apply( this, arguments ); |
| + | }; |
| + | // Use same guid so caller can remove using origFn |
| + | fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); |
| + | } |
| + | return this.each( function() { |
| + | jQuery.event.add( this, types, fn, data, selector ); |
| + | }); |
| + | }, |
| + | one: function( types, selector, data, fn ) { |
| + | return this.on( types, selector, data, fn, 1 ); |
| + | }, |
| + | off: function( types, selector, fn ) { |
| + | var handleObj, type; |
| + | if ( types && types.preventDefault && types.handleObj ) { |
| + | // ( event ) dispatched jQuery.Event |
| + | handleObj = types.handleObj; |
| + | jQuery( types.delegateTarget ).off( |
| + | handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, |
| + | handleObj.selector, |
| + | handleObj.handler |
| + | ); |
| + | return this; |
| + | } |
| + | if ( typeof types === "object" ) { |
| + | // ( types-object [, selector] ) |
| + | for ( type in types ) { |
| + | this.off( type, selector, types[ type ] ); |
| + | } |
| + | return this; |
| + | } |
| + | if ( selector === false || typeof selector === "function" ) { |
| + | // ( types [, fn] ) |
| + | fn = selector; |
| + | selector = undefined; |
| + | } |
| + | if ( fn === false ) { |
| + | fn = returnFalse; |
| + | } |
| + | return this.each(function() { |
| + | jQuery.event.remove( this, types, fn, selector ); |
| + | }); |
| + | }, |
| - | })( window ); |
| - | var runtil = /Until$/, |
| + | trigger: function( type, data ) { |
| + | return this.each(function() { |
| + | jQuery.event.trigger( type, data, this ); |
| + | }); |
| + | }, |
| + | triggerHandler: function( type, data ) { |
| + | var elem = this[0]; |
| + | if ( elem ) { |
| + | return jQuery.event.trigger( type, data, elem, true ); |
| + | } |
| + | } |
| + | }); |
| + | var isSimple = /^.[^:#\[\.,]*$/, |
| rparentsprev = /^(?:parents|prev(?:Until|All))/, | |
| - | isSimple = /^.[^:#\[\.,]*$/, |
| rneedsContext = jQuery.expr.match.needsContext, | |
| // methods guaranteed to produce a unique set when starting from a unique set | |
| guaranteedUnique = { | |
| @@ | @@ -5557,11 +5711,12 @@ var runtil = /Until$/, |
| jQuery.fn.extend({ | |
| find: function( selector ) { | |
| - | var i, ret, self, |
| - | len = this.length; |
| + | var i, |
| + | ret = [], |
| + | self = this, |
| + | len = self.length; |
| if ( typeof selector !== "string" ) { | |
| - | self = this; |
| return this.pushStack( jQuery( selector ).filter(function() { | |
| for ( i = 0; i < len; i++ ) { | |
| if ( jQuery.contains( self[ i ], this ) ) { | |
| @@ | @@ -5571,14 +5726,13 @@ jQuery.fn.extend({ |
| }) ); | |
| } | |
| - | ret = []; |
| for ( i = 0; i < len; i++ ) { | |
| - | jQuery.find( selector, this[ i ], ret ); |
| + | jQuery.find( selector, self[ i ], ret ); |
| } | |
| // Needed because $( selector, context ) becomes $( context ).find( selector ) | |
| ret = this.pushStack( len > 1 ? jQuery.unique( ret ) : ret ); | |
| - | ret.selector = ( this.selector ? this.selector + " " : "" ) + selector; |
| + | ret.selector = this.selector ? this.selector + " " + selector : selector; |
| return ret; | |
| }, | |
| @@ | @@ -5597,22 +5751,24 @@ jQuery.fn.extend({ |
| }, | |
| not: function( selector ) { | |
| - | return this.pushStack( winnow(this, selector, false) ); |
| + | return this.pushStack( winnow(this, selector || [], true) ); |
| }, | |
| filter: function( selector ) { | |
| - | return this.pushStack( winnow(this, selector, true) ); |
| + | return this.pushStack( winnow(this, selector || [], false) ); |
| }, | |
| is: function( selector ) { | |
| - | return !!selector && ( |
| - | typeof selector === "string" ? |
| - | // If this is a positional/relative selector, check membership in the returned set |
| - | // so $("p:first").is("p:last") won't return true for a doc with two "p". |
| - | rneedsContext.test( selector ) ? |
| - | jQuery( selector, this.context ).index( this[0] ) >= 0 : |
| - | jQuery.filter( selector, this ).length > 0 : |
| - | this.filter( selector ).length > 0 ); |
| + | return !!winnow( |
| + | this, |
| + | |
| + | // If this is a positional/relative selector, check membership in the returned set |
| + | // so $("p:first").is("p:last") won't return true for a doc with two "p". |
| + | typeof selector === "string" && rneedsContext.test( selector ) ? |
| + | jQuery( selector ) : |
| + | selector || [], |
| + | false |
| + | ).length; |
| }, | |
| closest: function( selectors, context ) { | |
| @@ | @@ -5625,14 +5781,18 @@ jQuery.fn.extend({ |
| 0; | |
| for ( ; i < l; i++ ) { | |
| - | cur = this[i]; |
| + | for ( cur = this[i]; cur && cur !== context; cur = cur.parentNode ) { |
| + | // Always skip document fragments |
| + | if ( cur.nodeType < 11 && (pos ? |
| + | pos.index(cur) > -1 : |
| + | |
| + | // Don't pass non-elements to Sizzle |
| + | cur.nodeType === 1 && |
| + | jQuery.find.matchesSelector(cur, selectors)) ) { |
| - | while ( cur && cur.ownerDocument && cur !== context && cur.nodeType !== 11 ) { |
| - | if ( pos ? pos.index(cur) > -1 : jQuery.find.matchesSelector(cur, selectors) ) { |
| - | ret.push( cur ); |
| + | cur = ret.push( cur ); |
| break; | |
| } | |
| - | cur = cur.parentNode; |
| } | |
| } | |
| @@ | @@ -5675,8 +5835,6 @@ jQuery.fn.extend({ |
| } | |
| }); | |
| - | jQuery.fn.andSelf = jQuery.fn.addBack; |
| - | |
| function sibling( cur, dir ) { | |
| do { | |
| cur = cur[ dir ]; | |
| @@ | @@ -5729,7 +5887,7 @@ jQuery.each({ |
| jQuery.fn[ name ] = function( until, selector ) { | |
| var ret = jQuery.map( this, fn, until ); | |
| - | if ( !runtil.test( name ) ) { |
| + | if ( name.slice( -5 ) !== "Until" ) { |
| selector = until; | |
| } | |
| @@ | @@ -5737,10 +5895,16 @@ jQuery.each({ |
| ret = jQuery.filter( selector, ret ); | |
| } | |
| - | ret = this.length > 1 && !guaranteedUnique[ name ] ? jQuery.unique( ret ) : ret; |
| + | if ( this.length > 1 ) { |
| + | // Remove duplicates |
| + | if ( !guaranteedUnique[ name ] ) { |
| + | ret = jQuery.unique( ret ); |
| + | } |
| - | if ( this.length > 1 && rparentsprev.test( name ) ) { |
| - | ret = ret.reverse(); |
| + | // Reverse order for parents* and prev-derivatives |
| + | if ( rparentsprev.test( name ) ) { |
| + | ret = ret.reverse(); |
| + | } |
| } | |
| return this.pushStack( ret ); | |
| @@ | @@ -5749,13 +5913,17 @@ jQuery.each({ |
| jQuery.extend({ | |
| filter: function( expr, elems, not ) { | |
| + | var elem = elems[ 0 ]; |
| + | |
| if ( not ) { | |
| expr = ":not(" + expr + ")"; | |
| } | |
| - | return elems.length === 1 ? |
| - | jQuery.find.matchesSelector(elems[0], expr) ? [ elems[0] ] : [] : |
| - | jQuery.find.matches(expr, elems); |
| + | return elems.length === 1 && elem.nodeType === 1 ? |
| + | jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [] : |
| + | jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) { |
| + | return elem.nodeType === 1; |
| + | })); |
| }, | |
| dir: function( elem, dir, until ) { | |
| @@ | @@ -5785,37 +5953,32 @@ jQuery.extend({ |
| }); | |
| // Implement the identical functionality for filter and not | |
| - | function winnow( elements, qualifier, keep ) { |
| - | |
| - | // Can't pass null or undefined to indexOf in Firefox 4 |
| - | // Set to 0 to skip string check |
| - | qualifier = qualifier || 0; |
| - | |
| + | function winnow( elements, qualifier, not ) { |
| if ( jQuery.isFunction( qualifier ) ) { | |
| - | return jQuery.grep(elements, function( elem, i ) { |
| - | var retVal = !!qualifier.call( elem, i, elem ); |
| - | return retVal === keep; |
| + | return jQuery.grep( elements, function( elem, i ) { |
| + | /* jshint -W018 */ |
| + | return !!qualifier.call( elem, i, elem ) !== not; |
| }); | |
| - | } else if ( qualifier.nodeType ) { |
| - | return jQuery.grep(elements, function( elem ) { |
| - | return ( elem === qualifier ) === keep; |
| - | }); |
| + | } |
| - | } else if ( typeof qualifier === "string" ) { |
| - | var filtered = jQuery.grep(elements, function( elem ) { |
| - | return elem.nodeType === 1; |
| + | if ( qualifier.nodeType ) { |
| + | return jQuery.grep( elements, function( elem ) { |
| + | return ( elem === qualifier ) !== not; |
| }); | |
| + | } |
| + | |
| + | if ( typeof qualifier === "string" ) { |
| if ( isSimple.test( qualifier ) ) { | |
| - | return jQuery.filter(qualifier, filtered, !keep); |
| - | } else { |
| - | qualifier = jQuery.filter( qualifier, filtered ); |
| + | return jQuery.filter( qualifier, elements, not ); |
| } | |
| + | |
| + | qualifier = jQuery.filter( qualifier, elements ); |
| } | |
| - | return jQuery.grep(elements, function( elem ) { |
| - | return ( jQuery.inArray( elem, qualifier ) >= 0 ) === keep; |
| + | return jQuery.grep( elements, function( elem ) { |
| + | return ( jQuery.inArray( elem, qualifier ) >= 0 ) !== not; |
| }); | |
| } | |
| function createSafeFragment( document ) { | |
| @@ | @@ -5855,114 +6018,51 @@ var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figca |
| legend: [ 1, "<fieldset>", "</fieldset>" ], | |
| area: [ 1, "<map>", "</map>" ], | |
| param: [ 1, "<object>", "</object>" ], | |
| - | thead: [ 1, "<table>", "</table>" ], |
| - | tr: [ 2, "<table><tbody>", "</tbody></table>" ], |
| - | col: [ 2, "<table><tbody></tbody><colgroup>", "</colgroup></table>" ], |
| - | td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ], |
| - | |
| - | // IE6-8 can't serialize link, script, style, or any html5 (NoScope) tags, |
| - | // unless wrapped in a div with non-breaking characters in front of it. |
| - | _default: jQuery.support.htmlSerialize ? [ 0, "", "" ] : [ 1, "X<div>", "</div>" ] |
| - | }, |
| - | safeFragment = createSafeFragment( document ), |
| - | fragmentDiv = safeFragment.appendChild( document.createElement("div") ); |
| - | |
| - | wrapMap.optgroup = wrapMap.option; |
| - | wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; |
| - | wrapMap.th = wrapMap.td; |
| - | |
| - | jQuery.fn.extend({ |
| - | text: function( value ) { |
| - | return jQuery.access( this, function( value ) { |
| - | return value === undefined ? |
| - | jQuery.text( this ) : |
| - | this.empty().append( ( this[0] && this[0].ownerDocument || document ).createTextNode( value ) ); |
| - | }, null, value, arguments.length ); |
| - | }, |
| - | |
| - | wrapAll: function( html ) { |
| - | if ( jQuery.isFunction( html ) ) { |
| - | return this.each(function(i) { |
| - | jQuery(this).wrapAll( html.call(this, i) ); |
| - | }); |
| - | } |
| - | |
| - | if ( this[0] ) { |
| - | // The elements to wrap the target around |
| - | var wrap = jQuery( html, this[0].ownerDocument ).eq(0).clone(true); |
| - | |
| - | if ( this[0].parentNode ) { |
| - | wrap.insertBefore( this[0] ); |
| - | } |
| - | |
| - | wrap.map(function() { |
| - | var elem = this; |
| - | |
| - | while ( elem.firstChild && elem.firstChild.nodeType === 1 ) { |
| - | elem = elem.firstChild; |
| - | } |
| - | |
| - | return elem; |
| - | }).append( this ); |
| - | } |
| - | |
| - | return this; |
| - | }, |
| - | |
| - | wrapInner: function( html ) { |
| - | if ( jQuery.isFunction( html ) ) { |
| - | return this.each(function(i) { |
| - | jQuery(this).wrapInner( html.call(this, i) ); |
| - | }); |
| - | } |
| - | |
| - | return this.each(function() { |
| - | var self = jQuery( this ), |
| - | contents = self.contents(); |
| - | |
| - | if ( contents.length ) { |
| - | contents.wrapAll( html ); |
| - | |
| - | } else { |
| - | self.append( html ); |
| - | } |
| - | }); |
| - | }, |
| - | |
| - | wrap: function( html ) { |
| - | var isFunction = jQuery.isFunction( html ); |
| + | thead: [ 1, "<table>", "</table>" ], |
| + | tr: [ 2, "<table><tbody>", "</tbody></table>" ], |
| + | col: [ 2, "<table><tbody></tbody><colgroup>", "</colgroup></table>" ], |
| + | td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ], |
| - | return this.each(function(i) { |
| - | jQuery( this ).wrapAll( isFunction ? html.call(this, i) : html ); |
| - | }); |
| + | // IE6-8 can't serialize link, script, style, or any html5 (NoScope) tags, |
| + | // unless wrapped in a div with non-breaking characters in front of it. |
| + | _default: jQuery.support.htmlSerialize ? [ 0, "", "" ] : [ 1, "X<div>", "</div>" ] |
| }, | |
| + | safeFragment = createSafeFragment( document ), |
| + | fragmentDiv = safeFragment.appendChild( document.createElement("div") ); |
| - | unwrap: function() { |
| - | return this.parent().each(function() { |
| - | if ( !jQuery.nodeName( this, "body" ) ) { |
| - | jQuery( this ).replaceWith( this.childNodes ); |
| - | } |
| - | }).end(); |
| + | wrapMap.optgroup = wrapMap.option; |
| + | wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; |
| + | wrapMap.th = wrapMap.td; |
| + | |
| + | jQuery.fn.extend({ |
| + | text: function( value ) { |
| + | return jQuery.access( this, function( value ) { |
| + | return value === undefined ? |
| + | jQuery.text( this ) : |
| + | this.empty().append( ( this[0] && this[0].ownerDocument || document ).createTextNode( value ) ); |
| + | }, null, value, arguments.length ); |
| }, | |
| append: function() { | |
| - | return this.domManip(arguments, true, function( elem ) { |
| + | return this.domManip( arguments, function( elem ) { |
| if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { | |
| - | this.appendChild( elem ); |
| + | var target = manipulationTarget( this, elem ); |
| + | target.appendChild( elem ); |
| } | |
| }); | |
| }, | |
| prepend: function() { | |
| - | return this.domManip(arguments, true, function( elem ) { |
| + | return this.domManip( arguments, function( elem ) { |
| if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { | |
| - | this.insertBefore( elem, this.firstChild ); |
| + | var target = manipulationTarget( this, elem ); |
| + | target.insertBefore( elem, target.firstChild ); |
| } | |
| }); | |
| }, | |
| before: function() { | |
| - | return this.domManip( arguments, false, function( elem ) { |
| + | return this.domManip( arguments, function( elem ) { |
| if ( this.parentNode ) { | |
| this.parentNode.insertBefore( elem, this ); | |
| } | |
| @@ | @@ -5970,7 +6070,7 @@ jQuery.fn.extend({ |
| }, | |
| after: function() { | |
| - | return this.domManip( arguments, false, function( elem ) { |
| + | return this.domManip( arguments, function( elem ) { |
| if ( this.parentNode ) { | |
| this.parentNode.insertBefore( elem, this.nextSibling ); | |
| } | |
| @@ | @@ -5980,20 +6080,20 @@ jQuery.fn.extend({ |
| // keepData is for internal use only--do not document | |
| remove: function( selector, keepData ) { | |
| var elem, | |
| + | elems = selector ? jQuery.filter( selector, this ) : this, |
| i = 0; | |
| - | for ( ; (elem = this[i]) != null; i++ ) { |
| - | if ( !selector || jQuery.filter( selector, [ elem ] ).length > 0 ) { |
| - | if ( !keepData && elem.nodeType === 1 ) { |
| - | jQuery.cleanData( getAll( elem ) ); |
| - | } |
| + | for ( ; (elem = elems[i]) != null; i++ ) { |
| - | if ( elem.parentNode ) { |
| - | if ( keepData && jQuery.contains( elem.ownerDocument, elem ) ) { |
| - | setGlobalEval( getAll( elem, "script" ) ); |
| - | } |
| - | elem.parentNode.removeChild( elem ); |
| + | if ( !keepData && elem.nodeType === 1 ) { |
| + | jQuery.cleanData( getAll( elem ) ); |
| + | } |
| + | |
| + | if ( elem.parentNode ) { |
| + | if ( keepData && jQuery.contains( elem.ownerDocument, elem ) ) { |
| + | setGlobalEval( getAll( elem, "script" ) ); |
| } | |
| + | elem.parentNode.removeChild( elem ); |
| } | |
| } | |
| @@ | @@ -6076,31 +6176,39 @@ jQuery.fn.extend({ |
| }, null, value, arguments.length ); | |
| }, | |
| - | replaceWith: function( value ) { |
| - | var isFunc = jQuery.isFunction( value ); |
| - | |
| - | // Make sure that the elements are removed from the DOM before they are inserted |
| - | // this can help fix replacing a parent with child elements |
| - | if ( !isFunc && typeof value !== "string" ) { |
| - | value = jQuery( value ).not( this ).detach(); |
| - | } |
| + | replaceWith: function() { |
| + | var |
| + | // Snapshot the DOM in case .domManip sweeps something relevant into its fragment |
| + | args = jQuery.map( this, function( elem ) { |
| + | return [ elem.nextSibling, elem.parentNode ]; |
| + | }), |
| + | i = 0; |
| - | return this.domManip( [ value ], true, function( elem ) { |
| - | var next = this.nextSibling, |
| - | parent = this.parentNode; |
| + | // Make the changes, replacing each context element with the new content |
| + | this.domManip( arguments, function( elem ) { |
| + | var next = args[ i++ ], |
| + | parent = args[ i++ ]; |
| if ( parent ) { | |
| + | // Don't use the snapshot next if it has moved (#13810) |
| + | if ( next && next.parentNode !== parent ) { |
| + | next = this.nextSibling; |
| + | } |
| jQuery( this ).remove(); | |
| parent.insertBefore( elem, next ); | |
| } | |
| - | }); |
| + | // Allow new content to include elements from the context set |
| + | }, true ); |
| + | |
| + | // Force removal if there was no new content (e.g., from empty arguments) |
| + | return i ? this : this.remove(); |
| }, | |
| detach: function( selector ) { | |
| return this.remove( selector, true ); | |
| }, | |
| - | domManip: function( args, table, callback ) { |
| + | domManip: function( args, callback, allowIntersection ) { |
| // Flatten any nested arrays | |
| args = core_concat.apply( [], args ); | |
| @@ | @@ -6119,14 +6227,14 @@ jQuery.fn.extend({ |
| return this.each(function( index ) { | |
| var self = set.eq( index ); | |
| if ( isFunction ) { | |
| - | args[0] = value.call( this, index, table ? self.html() : undefined ); |
| + | args[0] = value.call( this, index, self.html() ); |
| } | |
| - | self.domManip( args, table, callback ); |
| + | self.domManip( args, callback, allowIntersection ); |
| }); | |
| } | |
| if ( l ) { | |
| - | fragment = jQuery.buildFragment( args, this[ 0 ].ownerDocument, false, this ); |
| + | fragment = jQuery.buildFragment( args, this[ 0 ].ownerDocument, false, !allowIntersection && this ); |
| first = fragment.firstChild; | |
| if ( fragment.childNodes.length === 1 ) { | |
| @@ | @@ -6134,7 +6242,6 @@ jQuery.fn.extend({ |
| } | |
| if ( first ) { | |
| - | table = table && jQuery.nodeName( first, "tr" ); |
| scripts = jQuery.map( getAll( fragment, "script" ), disableScript ); | |
| hasScripts = scripts.length; | |
| @@ | @@ -6152,13 +6259,7 @@ jQuery.fn.extend({ |
| } | |
| } | |
| - | callback.call( |
| - | table && jQuery.nodeName( this[i], "table" ) ? |
| - | findOrAppend( this[i], "tbody" ) : |
| - | this[i], |
| - | node, |
| - | i |
| - | ); |
| + | callback.call( this[i], node, i ); |
| } | |
| if ( hasScripts ) { | |
| @@ | @@ -6175,14 +6276,7 @@ jQuery.fn.extend({ |
| if ( node.src ) { | |
| // Hope ajax is available... | |
| - | jQuery.ajax({ |
| - | url: node.src, |
| - | type: "GET", |
| - | dataType: "script", |
| - | async: false, |
| - | global: false, |
| - | "throws": true |
| - | }); |
| + | jQuery._evalUrl( node.src ); |
| } else { | |
| jQuery.globalEval( ( node.text || node.textContent || node.innerHTML || "" ).replace( rcleanScript, "" ) ); | |
| } | |
| @@ | @@ -6199,14 +6293,20 @@ jQuery.fn.extend({ |
| } | |
| }); | |
| - | function findOrAppend( elem, tag ) { |
| - | return elem.getElementsByTagName( tag )[0] || elem.appendChild( elem.ownerDocument.createElement( tag ) ); |
| + | // Support: IE<8 |
| + | // Manipulating tables requires a tbody |
| + | function manipulationTarget( elem, content ) { |
| + | return jQuery.nodeName( elem, "table" ) && |
| + | jQuery.nodeName( content.nodeType === 1 ? content : content.firstChild, "tr" ) ? |
| + | |
| + | elem.getElementsByTagName("tbody")[0] || |
| + | elem.appendChild( elem.ownerDocument.createElement("tbody") ) : |
| + | elem; |
| } | |
| // Replace/restore the type attribute of script elements for safe DOM manipulation | |
| function disableScript( elem ) { | |
| - | var attr = elem.getAttributeNode("type"); |
| - | elem.type = ( attr && attr.specified ) + "/" + elem.type; |
| + | elem.type = (jQuery.find.attr( elem, "type" ) !== null) + "/" + elem.type; |
| return elem; | |
| } | |
| function restoreScript( elem ) { | |
| @@ | @@ -6612,6 +6712,83 @@ jQuery.extend({ |
| } | |
| } | |
| } | |
| + | }, |
| + | |
| + | _evalUrl: function( url ) { |
| + | return jQuery.ajax({ |
| + | url: url, |
| + | type: "GET", |
| + | dataType: "script", |
| + | async: false, |
| + | global: false, |
| + | "throws": true |
| + | }); |
| + | } |
| + | }); |
| + | jQuery.fn.extend({ |
| + | wrapAll: function( html ) { |
| + | if ( jQuery.isFunction( html ) ) { |
| + | return this.each(function(i) { |
| + | jQuery(this).wrapAll( html.call(this, i) ); |
| + | }); |
| + | } |
| + | |
| + | if ( this[0] ) { |
| + | // The elements to wrap the target around |
| + | var wrap = jQuery( html, this[0].ownerDocument ).eq(0).clone(true); |
| + | |
| + | if ( this[0].parentNode ) { |
| + | wrap.insertBefore( this[0] ); |
| + | } |
| + | |
| + | wrap.map(function() { |
| + | var elem = this; |
| + | |
| + | while ( elem.firstChild && elem.firstChild.nodeType === 1 ) { |
| + | elem = elem.firstChild; |
| + | } |
| + | |
| + | return elem; |
| + | }).append( this ); |
| + | } |
| + | |
| + | return this; |
| + | }, |
| + | |
| + | wrapInner: function( html ) { |
| + | if ( jQuery.isFunction( html ) ) { |
| + | return this.each(function(i) { |
| + | jQuery(this).wrapInner( html.call(this, i) ); |
| + | }); |
| + | } |
| + | |
| + | return this.each(function() { |
| + | var self = jQuery( this ), |
| + | contents = self.contents(); |
| + | |
| + | if ( contents.length ) { |
| + | contents.wrapAll( html ); |
| + | |
| + | } else { |
| + | self.append( html ); |
| + | } |
| + | }); |
| + | }, |
| + | |
| + | wrap: function( html ) { |
| + | var isFunction = jQuery.isFunction( html ); |
| + | |
| + | return this.each(function(i) { |
| + | jQuery( this ).wrapAll( isFunction ? html.call(this, i) : html ); |
| + | }); |
| + | }, |
| + | |
| + | unwrap: function() { |
| + | return this.parent().each(function() { |
| + | if ( !jQuery.nodeName( this, "body" ) ) { |
| + | jQuery( this ).replaceWith( this.childNodes ); |
| + | } |
| + | }).end(); |
| } | |
| }); | |
| var iframe, getStyles, curCSS, | |
| @@ | @@ -6750,10 +6927,12 @@ jQuery.fn.extend({ |
| return showHide( this ); | |
| }, | |
| toggle: function( state ) { | |
| - | var bool = typeof state === "boolean"; |
| + | if ( typeof state === "boolean" ) { |
| + | return state ? this.show() : this.hide(); |
| + | } |
| return this.each(function() { | |
| - | if ( bool ? state : isHidden( this ) ) { |
| + | if ( isHidden( this ) ) { |
| jQuery( this ).show(); | |
| } else { | |
| jQuery( this ).hide(); | |
| @@ | @@ -6777,13 +6956,14 @@ jQuery.extend({ |
| } | |
| }, | |
| - | // Exclude the following css properties to add px |
| + | // Don't automatically add "px" to these possibly-unitless properties |
| cssNumber: { | |
| "columnCount": true, | |
| "fillOpacity": true, | |
| "fontWeight": true, | |
| "lineHeight": true, | |
| "opacity": true, | |
| + | "order": true, |
| "orphans": true, | |
| "widows": true, | |
| "zIndex": true, | |
| @@ | @@ -6895,27 +7075,6 @@ jQuery.extend({ |
| return extra === true || jQuery.isNumeric( num ) ? num || 0 : val; | |
| } | |
| return val; | |
| - | }, |
| - | |
| - | // A method for quickly swapping in/out CSS properties to get correct calculations |
| - | swap: function( elem, options, callback, args ) { |
| - | var ret, name, |
| - | old = {}; |
| - | |
| - | // Remember the old values, and insert the new ones |
| - | for ( name in options ) { |
| - | old[ name ] = elem.style[ name ]; |
| - | elem.style[ name ] = options[ name ]; |
| - | } |
| - | |
| - | ret = callback.apply( elem, args || [] ); |
| - | |
| - | // Revert the old values |
| - | for ( name in options ) { |
| - | elem.style[ name ] = old[ name ]; |
| - | } |
| - | |
| - | return ret; |
| } | |
| }); | |
| @@ | @@ -7404,9 +7563,26 @@ jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblcl |
| }; | |
| }); | |
| - | jQuery.fn.hover = function( fnOver, fnOut ) { |
| - | return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); |
| - | }; |
| + | jQuery.fn.extend({ |
| + | hover: function( fnOver, fnOut ) { |
| + | return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); |
| + | }, |
| + | |
| + | bind: function( types, data, fn ) { |
| + | return this.on( types, null, data, fn ); |
| + | }, |
| + | unbind: function( types, fn ) { |
| + | return this.off( types, null, fn ); |
| + | }, |
| + | |
| + | delegate: function( selector, types, data, fn ) { |
| + | return this.on( types, selector, data, fn ); |
| + | }, |
| + | undelegate: function( selector, types, fn ) { |
| + | // ( namespace ) or ( selector, types [, fn] ) |
| + | return arguments.length === 1 ? this.off( selector, "**" ) : this.off( types, selector || "**", fn ); |
| + | } |
| + | }); |
| var | |
| // Document location | |
| ajaxLocParts, | |
| @@ | @@ -7602,25 +7778,6 @@ jQuery.each( [ "ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSucces |
| }; | |
| }); | |
| - | jQuery.each( [ "get", "post" ], function( i, method ) { |
| - | jQuery[ method ] = function( url, data, callback, type ) { |
| - | // shift arguments if data argument was omitted |
| - | if ( jQuery.isFunction( data ) ) { |
| - | type = type || callback; |
| - | callback = data; |
| - | data = undefined; |
| - | } |
| - | |
| - | return jQuery.ajax({ |
| - | url: url, |
| - | type: method, |
| - | dataType: type, |
| - | data: data, |
| - | success: callback |
| - | }); |
| - | }; |
| - | }); |
| - | |
| jQuery.extend({ | |
| // Counter for holding the number of active queries | |
| @@ | @@ -7666,7 +7823,8 @@ jQuery.extend({ |
| responseFields: { | |
| xml: "responseXML", | |
| - | text: "responseText" |
| + | text: "responseText", |
| + | json: "responseJSON" |
| }, | |
| // Data converters | |
| @@ | @@ -7674,7 +7832,7 @@ jQuery.extend({ |
| converters: { | |
| // Convert anything to text | |
| - | "* text": window.String, |
| + | "* text": String, |
| // Text to html (true = no transformation) | |
| "text html": true, | |
| @@ | @@ -7853,8 +8011,8 @@ jQuery.extend({ |
| parts = rurl.exec( s.url.toLowerCase() ); | |
| s.crossDomain = !!( parts && | |
| ( parts[ 1 ] !== ajaxLocParts[ 1 ] || parts[ 2 ] !== ajaxLocParts[ 2 ] || | |
| - | ( parts[ 3 ] || ( parts[ 1 ] === "http:" ? 80 : 443 ) ) != |
| - | ( ajaxLocParts[ 3 ] || ( ajaxLocParts[ 1 ] === "http:" ? 80 : 443 ) ) ) |
| + | ( parts[ 3 ] || ( parts[ 1 ] === "http:" ? "80" : "443" ) ) !== |
| + | ( ajaxLocParts[ 3 ] || ( ajaxLocParts[ 1 ] === "http:" ? "80" : "443" ) ) ) |
| ); | |
| } | |
| @@ | @@ -8015,13 +8173,19 @@ jQuery.extend({ |
| // Set readyState | |
| jqXHR.readyState = status > 0 ? 4 : 0; | |
| + | // Determine if successful |
| + | isSuccess = status >= 200 && status < 300 || status === 304; |
| + | |
| // Get response data | |
| if ( responses ) { | |
| response = ajaxHandleResponses( s, jqXHR, responses ); | |
| } | |
| + | // Convert no matter what (that way responseXXX fields are always set) |
| + | response = ajaxConvert( s, response, jqXHR, isSuccess ); |
| + | |
| // If successful, handle type chaining | |
| - | if ( status >= 200 && status < 300 || status === 304 ) { |
| + | if ( isSuccess ) { |
| // Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. | |
| if ( s.ifModified ) { | |
| @@ | @@ -8036,21 +8200,18 @@ jQuery.extend({ |
| } | |
| // if no content | |
| - | if ( status === 204 ) { |
| - | isSuccess = true; |
| + | if ( status === 204 || s.type === "HEAD" ) { |
| statusText = "nocontent"; | |
| // if not modified | |
| } else if ( status === 304 ) { | |
| - | isSuccess = true; |
| statusText = "notmodified"; | |
| // If we have data, let's convert it | |
| } else { | |
| - | isSuccess = ajaxConvert( s, response ); |
| - | statusText = isSuccess.state; |
| - | success = isSuccess.data; |
| - | error = isSuccess.error; |
| + | statusText = response.state; |
| + | success = response.data; |
| + | error = response.error; |
| isSuccess = !error; | |
| } | |
| } else { | |
| @@ | @@ -8100,32 +8261,42 @@ jQuery.extend({ |
| return jqXHR; | |
| }, | |
| - | getScript: function( url, callback ) { |
| - | return jQuery.get( url, undefined, callback, "script" ); |
| - | }, |
| - | |
| getJSON: function( url, data, callback ) { | |
| return jQuery.get( url, data, callback, "json" ); | |
| + | }, |
| + | |
| + | getScript: function( url, callback ) { |
| + | return jQuery.get( url, undefined, callback, "script" ); |
| } | |
| }); | |
| + | jQuery.each( [ "get", "post" ], function( i, method ) { |
| + | jQuery[ method ] = function( url, data, callback, type ) { |
| + | // shift arguments if data argument was omitted |
| + | if ( jQuery.isFunction( data ) ) { |
| + | type = type || callback; |
| + | callback = data; |
| + | data = undefined; |
| + | } |
| + | |
| + | return jQuery.ajax({ |
| + | url: url, |
| + | type: method, |
| + | dataType: type, |
| + | data: data, |
| + | success: callback |
| + | }); |
| + | }; |
| + | }); |
| + | |
| /* Handles responses to an ajax request: | |
| - | * - sets all responseXXX fields accordingly |
| * - finds the right dataType (mediates between content-type and expected dataType) | |
| * - returns the corresponding response | |
| */ | |
| function ajaxHandleResponses( s, jqXHR, responses ) { | |
| var firstDataType, ct, finalDataType, type, | |
| contents = s.contents, | |
| - | dataTypes = s.dataTypes, |
| - | responseFields = s.responseFields; |
| - | |
| - | // Fill responseXXX fields |
| - | for ( type in responseFields ) { |
| - | if ( type in responses ) { |
| - | jqXHR[ responseFields[type] ] = responses[ type ]; |
| - | } |
| - | } |
| + | dataTypes = s.dataTypes; |
| // Remove auto dataType and get content-type in the process | |
| while( dataTypes[ 0 ] === "*" ) { | |
| @@ | @@ -8174,19 +8345,14 @@ function ajaxHandleResponses( s, jqXHR, responses ) { |
| } | |
| } | |
| - | // Chain conversions given the request and the original response |
| - | function ajaxConvert( s, response ) { |
| - | var conv2, current, conv, tmp, |
| + | /* Chain conversions given the request and the original response |
| + | * Also sets the responseXXX fields on the jqXHR instance |
| + | */ |
| + | function ajaxConvert( s, response, jqXHR, isSuccess ) { |
| + | var conv2, current, conv, tmp, prev, |
| converters = {}, | |
| - | i = 0, |
| // Work with a copy of dataTypes in case we need to modify it for conversion | |
| - | dataTypes = s.dataTypes.slice(), |
| - | prev = dataTypes[ 0 ]; |
| - | |
| - | // Apply the dataFilter if provided |
| - | if ( s.dataFilter ) { |
| - | response = s.dataFilter( response, s.dataType ); |
| - | } |
| + | dataTypes = s.dataTypes.slice(); |
| // Create converters map with lowercased keys | |
| if ( dataTypes[ 1 ] ) { | |
| @@ | @@ -8195,14 +8361,32 @@ function ajaxConvert( s, response ) { |
| } | |
| } | |
| - | // Convert to each sequential dataType, tolerating list modification |
| - | for ( ; (current = dataTypes[++i]); ) { |
| + | current = dataTypes.shift(); |
| + | |
| + | // Convert to each sequential dataType |
| + | while ( current ) { |
| + | |
| + | if ( s.responseFields[ current ] ) { |
| + | jqXHR[ s.responseFields[ current ] ] = response; |
| + | } |
| + | |
| + | // Apply the dataFilter if provided |
| + | if ( !prev && isSuccess && s.dataFilter ) { |
| + | response = s.dataFilter( response, s.dataType ); |
| + | } |
| + | |
| + | prev = current; |
| + | current = dataTypes.shift(); |
| + | |
| + | if ( current ) { |
| + | |
| + | // There's only work to do if current dataType is non-auto |
| + | if ( current === "*" ) { |
| - | // There's only work to do if current dataType is non-auto |
| - | if ( current !== "*" ) { |
| + | current = prev; |
| // Convert response if prev dataType is non-auto and differs from current | |
| - | if ( prev !== "*" && prev !== current ) { |
| + | } else if ( prev !== "*" && prev !== current ) { |
| // Seek a direct converter | |
| conv = converters[ prev + " " + current ] || converters[ "* " + current ]; | |
| @@ | @@ -8212,7 +8396,7 @@ function ajaxConvert( s, response ) { |
| for ( conv2 in converters ) { | |
| // If conv2 outputs current | |
| - | tmp = conv2.split(" "); |
| + | tmp = conv2.split( " " ); |
| if ( tmp[ 1 ] === current ) { | |
| // If prev can be converted to accepted input | |
| @@ | @@ -8226,9 +8410,8 @@ function ajaxConvert( s, response ) { |
| // Otherwise, insert the intermediate dataType | |
| } else if ( converters[ conv2 ] !== true ) { | |
| current = tmp[ 0 ]; | |
| - | dataTypes.splice( i--, 0, current ); |
| + | dataTypes.unshift( tmp[ 1 ] ); |
| } | |
| - | |
| break; | |
| } | |
| } | |
| @@ | @@ -8239,7 +8422,7 @@ function ajaxConvert( s, response ) { |
| if ( conv !== true ) { | |
| // Unless errors are allowed to bubble, catch and return them | |
| - | if ( conv && s["throws"] ) { |
| + | if ( conv && s[ "throws" ] ) { |
| response = conv( response ); | |
| } else { | |
| try { | |
| @@ | @@ -8250,9 +8433,6 @@ function ajaxConvert( s, response ) { |
| } | |
| } | |
| } | |
| - | |
| - | // Update prev for next iteration |
| - | prev = current; |
| } | |
| } | |
| @@ | @@ -8638,44 +8818,51 @@ var fxNow, timerId, |
| animationPrefilters = [ defaultPrefilter ], | |
| tweeners = { | |
| "*": [function( prop, value ) { | |
| - | var end, unit, |
| - | tween = this.createTween( prop, value ), |
| - | parts = rfxnum.exec( value ), |
| + | var tween = this.createTween( prop, value ), |
| target = tween.cur(), | |
| - | start = +target || 0, |
| + | parts = rfxnum.exec( value ), |
| + | unit = parts && parts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ), |
| + | |
| + | // Starting value computation is required for potential unit mismatches |
| + | start = ( jQuery.cssNumber[ prop ] || unit !== "px" && +target ) && |
| + | rfxnum.exec( jQuery.css( tween.elem, prop ) ), |
| scale = 1, | |
| maxIterations = 20; | |
| - | if ( parts ) { |
| - | end = +parts[2]; |
| - | unit = parts[3] || ( jQuery.cssNumber[ prop ] ? "" : "px" ); |
| + | if ( start && start[ 3 ] !== unit ) { |
| + | // Trust units reported by jQuery.css |
| + | unit = unit || start[ 3 ]; |
| - | // We need to compute starting value |
| - | if ( unit !== "px" && start ) { |
| - | // Iteratively approximate from a nonzero starting point |
| - | // Prefer the current property, because this process will be trivial if it uses the same units |
| - | // Fallback to end or a simple constant |
| - | start = jQuery.css( tween.elem, prop, true ) || end || 1; |
| + | // Make sure we update the tween properties later on |
| + | parts = parts || []; |
| - | do { |
| - | // If previous iteration zeroed out, double until we get *something* |
| - | // Use a string for doubling factor so we don't accidentally see scale as unchanged below |
| - | scale = scale || ".5"; |
| + | // Iteratively approximate from a nonzero starting point |
| + | start = +target || 1; |
| - | // Adjust and apply |
| - | start = start / scale; |
| - | jQuery.style( tween.elem, prop, start + unit ); |
| + | do { |
| + | // If previous iteration zeroed out, double until we get *something* |
| + | // Use a string for doubling factor so we don't accidentally see scale as unchanged below |
| + | scale = scale || ".5"; |
| - | // Update scale, tolerating zero or NaN from tween.cur() |
| - | // And breaking the loop if scale is unchanged or perfect, or if we've just had enough |
| - | } while ( scale !== (scale = tween.cur() / target) && scale !== 1 && --maxIterations ); |
| - | } |
| + | // Adjust and apply |
| + | start = start / scale; |
| + | jQuery.style( tween.elem, prop, start + unit ); |
| + | // Update scale, tolerating zero or NaN from tween.cur() |
| + | // And breaking the loop if scale is unchanged or perfect, or if we've just had enough |
| + | } while ( scale !== (scale = tween.cur() / target) && scale !== 1 && --maxIterations ); |
| + | } |
| + | |
| + | // Update tween properties |
| + | if ( parts ) { |
| + | start = tween.start = +start || +target || 0; |
| tween.unit = unit; | |
| - | tween.start = start; |
| // If a +=/-= token was provided, we're doing a relative animation | |
| - | tween.end = parts[1] ? start + ( parts[1] + 1 ) * end : end; |
| + | tween.end = parts[ 1 ] ? |
| + | start + ( parts[ 1 ] + 1 ) * parts[ 2 ] : |
| + | +parts[ 2 ]; |
| } | |
| + | |
| return tween; | |
| }] | |
| }; | |
| @@ | @@ -8688,19 +8875,18 @@ function createFxNow() { |
| return ( fxNow = jQuery.now() ); | |
| } | |
| - | function createTweens( animation, props ) { |
| - | jQuery.each( props, function( prop, value ) { |
| - | var collection = ( tweeners[ prop ] || [] ).concat( tweeners[ "*" ] ), |
| - | index = 0, |
| - | length = collection.length; |
| - | for ( ; index < length; index++ ) { |
| - | if ( collection[ index ].call( animation, prop, value ) ) { |
| + | function createTween( value, prop, animation ) { |
| + | var tween, |
| + | collection = ( tweeners[ prop ] || [] ).concat( tweeners[ "*" ] ), |
| + | index = 0, |
| + | length = collection.length; |
| + | for ( ; index < length; index++ ) { |
| + | if ( (tween = collection[ index ].call( animation, prop, value )) ) { |
| - | // we're done with this property |
| - | return; |
| - | } |
| + | // we're done with this property |
| + | return tween; |
| } | |
| - | }); |
| + | } |
| } | |
| function Animation( elem, properties, options ) { | |
| @@ | @@ -8786,7 +8972,7 @@ function Animation( elem, properties, options ) { |
| } | |
| } | |
| - | createTweens( animation, props ); |
| + | jQuery.map( props, createTween, animation ); |
| if ( jQuery.isFunction( animation.opts.start ) ) { | |
| animation.opts.start.call( elem, animation ); | |
| @@ | @@ -8808,7 +8994,7 @@ function Animation( elem, properties, options ) { |
| } | |
| function propFilter( props, specialEasing ) { | |
| - | var value, name, index, easing, hooks; |
| + | var index, name, easing, value, hooks; |
| // camelCase, specialEasing and expand cssHook pass | |
| for ( index in props ) { | |
| @@ | @@ -8875,15 +9061,13 @@ jQuery.Animation = jQuery.extend( Animation, { |
| }); | |
| function defaultPrefilter( elem, props, opts ) { | |
| - | /*jshint validthis:true */ |
| - | var prop, index, length, |
| - | value, dataShow, toggle, |
| - | tween, hooks, oldfire, |
| + | /* jshint validthis: true */ |
| + | var prop, value, toggle, tween, hooks, oldfire, |
| anim = this, | |
| - | style = elem.style, |
| orig = {}, | |
| - | handled = [], |
| - | hidden = elem.nodeType && isHidden( elem ); |
| + | style = elem.style, |
| + | hidden = elem.nodeType && isHidden( elem ), |
| + | dataShow = jQuery._data( elem, "fxshow" ); |
| // handle queue: false promises | |
| if ( !opts.queue ) { | |
| @@ | @@ -8948,23 +9132,25 @@ function defaultPrefilter( elem, props, opts ) { |
| // show/hide pass | |
| - | for ( index in props ) { |
| - | value = props[ index ]; |
| + | for ( prop in props ) { |
| + | value = props[ prop ]; |
| if ( rfxtypes.exec( value ) ) { | |
| - | delete props[ index ]; |
| + | delete props[ prop ]; |
| toggle = toggle || value === "toggle"; | |
| if ( value === ( hidden ? "hide" : "show" ) ) { | |
| continue; | |
| } | |
| - | handled.push( index ); |
| + | orig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop ); |
| } | |
| } | |
| - | length = handled.length; |
| - | if ( length ) { |
| - | dataShow = jQuery._data( elem, "fxshow" ) || jQuery._data( elem, "fxshow", {} ); |
| - | if ( "hidden" in dataShow ) { |
| - | hidden = dataShow.hidden; |
| + | if ( !jQuery.isEmptyObject( orig ) ) { |
| + | if ( dataShow ) { |
| + | if ( "hidden" in dataShow ) { |
| + | hidden = dataShow.hidden; |
| + | } |
| + | } else { |
| + | dataShow = jQuery._data( elem, "fxshow", {} ); |
| } | |
| // store state if its toggle - enables .stop().toggle() to "reverse" | |
| @@ | @@ -8985,10 +9171,8 @@ function defaultPrefilter( elem, props, opts ) { |
| jQuery.style( elem, prop, orig[ prop ] ); | |
| } | |
| }); | |
| - | for ( index = 0 ; index < length ; index++ ) { |
| - | prop = handled[ index ]; |
| - | tween = anim.createTween( prop, hidden ? dataShow[ prop ] : 0 ); |
| - | orig[ prop ] = dataShow[ prop ] || jQuery.style( elem, prop ); |
| + | for ( prop in orig ) { |
| + | tween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim ); |
| if ( !( prop in dataShow ) ) { | |
| dataShow[ prop ] = tween.start; | |
| @@ | @@ -9084,8 +9268,8 @@ Tween.propHooks = { |
| } | |
| }; | |
| - | // Remove in 2.0 - this supports IE8's panic based approach |
| - | // to setting things on disconnected nodes |
| + | // Support: IE <=9 |
| + | // Panic based approach to setting things on disconnected nodes |
| Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = { | |
| set: function( tween ) { | |
| @@ | @@ -9119,9 +9303,7 @@ jQuery.fn.extend({ |
| doAnimation = function() { | |
| // Operate on a copy of prop so per-property easing won't be lost | |
| var anim = Animation( this, jQuery.extend( {}, prop ), optall ); | |
| - | doAnimation.finish = function() { |
| - | anim.stop( true ); |
| - | }; |
| + | |
| // Empty animations, or finishing resolves immediately | |
| if ( empty || jQuery._data( this, "finish" ) ) { | |
| anim.stop( true ); | |
| @@ | @@ -9201,8 +9383,8 @@ jQuery.fn.extend({ |
| // empty the queue first | |
| jQuery.queue( this, type, [] ); | |
| - | if ( hooks && hooks.cur && hooks.cur.finish ) { |
| - | hooks.cur.finish.call( this ); |
| + | if ( hooks && hooks.stop ) { |
| + | hooks.stop.call( this, true ); |
| } | |
| // look for any active animations, and finish them | |
| @@ | @@ -9486,11 +9668,11 @@ jQuery.fn.extend({ |
| offsetParent: function() { | |
| return this.map(function() { | |
| - | var offsetParent = this.offsetParent || document.documentElement; |
| + | var offsetParent = this.offsetParent || docElem; |
| while ( offsetParent && ( !jQuery.nodeName( offsetParent, "html" ) && jQuery.css( offsetParent, "position") === "static" ) ) { | |
| offsetParent = offsetParent.offsetParent; | |
| } | |
| - | return offsetParent || document.documentElement; |
| + | return offsetParent || docElem; |
| }); | |
| } | |
| }); | |
| @@ | @@ -9574,24 +9756,34 @@ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { |
| // Limit scope pollution from any deprecated API | |
| // (function() { | |
| + | // The number of elements contained in the matched element set |
| + | jQuery.fn.size = function() { |
| + | return this.length; |
| + | }; |
| + | |
| + | jQuery.fn.andSelf = jQuery.fn.addBack; |
| + | |
| // })(); | |
| - | // Expose jQuery to the global object |
| - | window.jQuery = window.$ = jQuery; |
| - | |
| - | // Expose jQuery as an AMD module, but only for AMD loaders that |
| - | // understand the issues with loading multiple versions of jQuery |
| - | // in a page that all might call define(). The loader will indicate |
| - | // they have special allowances for multiple jQuery versions by |
| - | // specifying define.amd.jQuery = true. Register as a named module, |
| - | // since jQuery can be concatenated with other files that may use define, |
| - | // but not use a proper concatenation script that understands anonymous |
| - | // AMD modules. A named AMD is safest and most robust way to register. |
| - | // Lowercase jquery is used because AMD module names are derived from |
| - | // file names, and jQuery is normally delivered in a lowercase file name. |
| - | // Do this after creating the global so that if an AMD module wants to call |
| - | // noConflict to hide this version of jQuery, it will work. |
| - | if ( typeof define === "function" && define.amd && define.amd.jQuery ) { |
| - | define( "jquery", [], function () { return jQuery; } ); |
| + | if ( typeof module === "object" && module && typeof module.exports === "object" ) { |
| + | // Expose jQuery as module.exports in loaders that implement the Node |
| + | // module pattern (including browserify). Do not create the global, since |
| + | // the user will be storing it themselves locally, and globals are frowned |
| + | // upon in the Node module world. |
| + | module.exports = jQuery; |
| + | } else { |
| + | // Otherwise expose jQuery to the global object as usual |
| + | window.jQuery = window.$ = jQuery; |
| + | |
| + | // Register as a named AMD module, since jQuery can be concatenated with other |
| + | // files that may use define, but not via a proper concatenation script that |
| + | // understands anonymous AMD modules. A named AMD is safest and most robust |
| + | // way to register. Lowercase jquery is used because AMD module names are |
| + | // derived from file names, and jQuery is normally delivered in a lowercase |
| + | // file name. Do this after creating the global so that if an AMD module wants |
| + | // to call noConflict to hide this version of jQuery, it will work. |
| + | if ( typeof define === "function" && define.amd ) { |
| + | define( "jquery", [], function () { return jQuery; } ); |
| + | } |
| } | |
| - | })( window ); |
| \ No newline at end of file | |
| + | })( window ); |
generators/foundation/public/javascripts/vendor/zepto.js
+117
-1
| @@ | @@ -1831,6 +1831,122 @@ window.Zepto = Zepto |
| }) | |
| })(Zepto) | |
| + | // Zepto.js |
| + | // (c) 2010-2012 Thomas Fuchs |
| + | // Zepto.js may be freely distributed under the MIT license. |
| + | |
| + | ;(function($){ |
| + | var touch = {}, |
| + | touchTimeout, tapTimeout, swipeTimeout, |
| + | longTapDelay = 750, longTapTimeout |
| + | |
| + | function parentIfText(node) { |
| + | return 'tagName' in node ? node : node.parentNode |
| + | } |
| + | |
| + | function swipeDirection(x1, x2, y1, y2) { |
| + | var xDelta = Math.abs(x1 - x2), yDelta = Math.abs(y1 - y2) |
| + | return xDelta >= yDelta ? (x1 - x2 > 0 ? 'Left' : 'Right') : (y1 - y2 > 0 ? 'Up' : 'Down') |
| + | } |
| + | |
| + | function longTap() { |
| + | longTapTimeout = null |
| + | if (touch.last) { |
| + | touch.el.trigger('longTap') |
| + | touch = {} |
| + | } |
| + | } |
| + | |
| + | function cancelLongTap() { |
| + | if (longTapTimeout) clearTimeout(longTapTimeout) |
| + | longTapTimeout = null |
| + | } |
| + | |
| + | function cancelAll() { |
| + | if (touchTimeout) clearTimeout(touchTimeout) |
| + | if (tapTimeout) clearTimeout(tapTimeout) |
| + | if (swipeTimeout) clearTimeout(swipeTimeout) |
| + | if (longTapTimeout) clearTimeout(longTapTimeout) |
| + | touchTimeout = tapTimeout = swipeTimeout = longTapTimeout = null |
| + | touch = {} |
| + | } |
| + | |
| + | $(document).ready(function(){ |
| + | var now, delta |
| + | |
| + | $(document.body) |
| + | .bind('touchstart', function(e){ |
| + | now = Date.now() |
| + | delta = now - (touch.last || now) |
| + | touch.el = $(parentIfText(e.touches[0].target)) |
| + | touchTimeout && clearTimeout(touchTimeout) |
| + | touch.x1 = e.touches[0].pageX |
| + | touch.y1 = e.touches[0].pageY |
| + | if (delta > 0 && delta <= 250) touch.isDoubleTap = true |
| + | touch.last = now |
| + | longTapTimeout = setTimeout(longTap, longTapDelay) |
| + | }) |
| + | .bind('touchmove', function(e){ |
| + | cancelLongTap() |
| + | touch.x2 = e.touches[0].pageX |
| + | touch.y2 = e.touches[0].pageY |
| + | if (Math.abs(touch.x1 - touch.x2) > 10) |
| + | e.preventDefault() |
| + | }) |
| + | .bind('touchend', function(e){ |
| + | cancelLongTap() |
| + | |
| + | // swipe |
| + | if ((touch.x2 && Math.abs(touch.x1 - touch.x2) > 30) || |
| + | (touch.y2 && Math.abs(touch.y1 - touch.y2) > 30)) |
| + | |
| + | swipeTimeout = setTimeout(function() { |
| + | touch.el.trigger('swipe') |
| + | touch.el.trigger('swipe' + (swipeDirection(touch.x1, touch.x2, touch.y1, touch.y2))) |
| + | touch = {} |
| + | }, 0) |
| + | |
| + | // normal tap |
| + | else if ('last' in touch) |
| + | |
| + | // delay by one tick so we can cancel the 'tap' event if 'scroll' fires |
| + | // ('tap' fires before 'scroll') |
| + | tapTimeout = setTimeout(function() { |
| + | |
| + | // trigger universal 'tap' with the option to cancelTouch() |
| + | // (cancelTouch cancels processing of single vs double taps for faster 'tap' response) |
| + | var event = $.Event('tap') |
| + | event.cancelTouch = cancelAll |
| + | touch.el.trigger(event) |
| + | |
| + | // trigger double tap immediately |
| + | if (touch.isDoubleTap) { |
| + | touch.el.trigger('doubleTap') |
| + | touch = {} |
| + | } |
| + | |
| + | // trigger single tap after 250ms of inactivity |
| + | else { |
| + | touchTimeout = setTimeout(function(){ |
| + | touchTimeout = null |
| + | touch.el.trigger('singleTap') |
| + | touch = {} |
| + | }, 250) |
| + | } |
| + | |
| + | }, 0) |
| + | |
| + | }) |
| + | .bind('touchcancel', cancelAll) |
| + | |
| + | $(window).bind('scroll', cancelAll) |
| + | }) |
| + | |
| + | ;['swipe', 'swipeLeft', 'swipeRight', 'swipeUp', 'swipeDown', 'doubleTap', 'tap', 'singleTap', 'longTap'].forEach(function(m){ |
| + | $.fn[m] = function(callback){ return this.bind(m, callback) } |
| + | }) |
| + | })(Zepto) |
| + | |
| // outer and inner height/width support | |
| if (this.Zepto) { | |
| @@ | @@ -1881,4 +1997,4 @@ if (this.Zepto) { |
| return cloned; | |
| }); | |
| })(Zepto); | |
| - | } |
| \ No newline at end of file | |
| + | } |
generators/foundation/public/stylesheets/foundation.css
+1145
-668
| @@ | @@ -1,3 +1,15 @@ |
| + | meta.foundation-mq-small { |
| + | font-family: "only screen and (min-width: 768px)"; |
| + | width: 768px; } |
| + | |
| + | meta.foundation-mq-medium { |
| + | font-family: "only screen and (min-width:1280px)"; |
| + | width: 1280px; } |
| + | |
| + | meta.foundation-mq-large { |
| + | font-family: "only screen and (min-width:1440px)"; |
| + | width: 1440px; } |
| + | |
| *, | |
| *:before, | |
| *:after { | |
| @@ | @@ -24,9 +36,6 @@ body { |
| a:hover { | |
| cursor: pointer; } | |
| - | a:focus { |
| - | outline: none; } |
| - | |
| img, | |
| object, | |
| embed { | |
| @@ | @@ -97,12 +106,15 @@ select { |
| display: table; } | |
| .row:after { | |
| clear: both; } | |
| - | .row.collapse .column, |
| - | .row.collapse .columns { |
| + | .row.collapse > .column, |
| + | .row.collapse > .columns { |
| position: relative; | |
| padding-left: 0; | |
| padding-right: 0; | |
| float: left; } | |
| + | .row.collapse .row { |
| + | margin-left: 0; |
| + | margin-right: 0; } |
| .row .row { | |
| width: auto; | |
| margin-left: -0.9375em; | |
| @@ | @@ -759,7 +771,7 @@ th.hide-for-touch { |
| [class*="block-grid-"] { | |
| display: block; | |
| padding: 0; | |
| - | margin: -0.625em; |
| + | margin: 0 -0.625em; |
| *zoom: 1; } | |
| [class*="block-grid-"]:before, [class*="block-grid-"]:after { | |
| content: " "; | |
| @@ | @@ -1130,7 +1142,9 @@ dl { |
| font-family: inherit; } | |
| ul, ol { | |
| - | margin-left: 1.25em; } |
| + | margin-left: 0; } |
| + | ul.no-bullet, ol.no-bullet { |
| + | margin-left: 0; } |
| /* Unordered Lists */ | |
| ul li ul, | |
| @@ | @@ -1244,7 +1258,7 @@ blockquote p { |
| @media print { | |
| * { | |
| background: transparent !important; | |
| - | color: #000 !important; |
| + | color: black !important; |
| /* Black prints faster: h5bp.com/s */ | |
| box-shadow: none !important; | |
| text-shadow: none !important; } | |
| @@ | @@ -1266,7 +1280,7 @@ blockquote p { |
| pre, | |
| blockquote { | |
| - | border: 1px solid #999; |
| + | border: 1px solid #999999; |
| page-break-inside: avoid; } | |
| thead { | |
| @@ | @@ -1310,7 +1324,7 @@ button, .button { |
| cursor: pointer; | |
| font-family: inherit; | |
| font-weight: bold; | |
| - | line-height: 1; |
| + | line-height: normal; |
| margin: 0 0 1.25em; | |
| position: relative; | |
| text-decoration: none; | |
| @@ | @@ -1371,8 +1385,8 @@ button, .button { |
| padding-left: 0.875em; | |
| font-size: 0.6875em; } | |
| button.expand, .button.expand { | |
| - | padding-right: 0px; |
| - | padding-left: 0px; |
| + | padding-right: 0; |
| + | padding-left: 0; |
| width: 100%; } | |
| button.left-align, .button.left-align { | |
| text-align: left; | |
| @@ | @@ -1439,16 +1453,20 @@ button, .button { |
| button, .button { | |
| padding-top: 0.8125em; | |
| - | padding-bottom: 0.75em; } |
| + | padding-bottom: 0.75em; |
| + | -webkit-appearance: none; } |
| button.tiny, .button.tiny { | |
| padding-top: 0.5em; | |
| - | padding-bottom: 0.4375em; } |
| + | padding-bottom: 0.4375em; |
| + | -webkit-appearance: none; } |
| button.small, .button.small { | |
| padding-top: 0.625em; | |
| - | padding-bottom: 0.5625em; } |
| + | padding-bottom: 0.5625em; |
| + | -webkit-appearance: none; } |
| button.large, .button.large { | |
| padding-top: 1.03125em; | |
| - | padding-bottom: 1.03125em; } |
| + | padding-bottom: 1.03125em; |
| + | -webkit-appearance: none; } |
| @media only screen { | |
| button, .button { | |
| @@ | @@ -1484,6 +1502,11 @@ form .row .row { |
| form .row .row.collapse .column, | |
| form .row .row.collapse .columns { | |
| padding: 0; } | |
| + | form .row .row.collapse input { |
| + | -moz-border-radius-bottomright: 0; |
| + | -moz-border-radius-topright: 0; |
| + | -webkit-border-bottom-right-radius: 0; |
| + | -webkit-border-top-right-radius: 0; } |
| form .row input.column, | |
| form .row input.columns, | |
| form .row textarea.column, | |
| @@ | @@ -1497,13 +1520,17 @@ label { |
| cursor: pointer; | |
| display: block; | |
| font-weight: 500; | |
| - | margin-bottom: 0.1875em; } |
| + | margin-bottom: 0.1875em; |
| + | /* Styles for required inputs */ } |
| label.right { | |
| float: none; | |
| text-align: right; } | |
| label.inline { | |
| margin: 0 0 1em 0; | |
| padding: 0.625em 0; } | |
| + | label small { |
| + | text-transform: capitalize; |
| + | color: #666666; } |
| /* Attach elements to the beginning or end of an input */ | |
| .prefix, | |
| @@ | @@ -1579,13 +1606,13 @@ label { |
| border-top-right-radius: 1000px; | |
| border-bottom-right-radius: 1000px; } | |
| - | /* Separate prefix and postfix styles when on span so buttons keep their own */ |
| - | span.prefix { |
| + | /* Separate prefix and postfix styles when on span or label so buttons keep their own */ |
| + | span.prefix, label.prefix { |
| background: #f2f2f2; | |
| border-color: #d9d9d9; | |
| border-right: none; | |
| color: #333333; } | |
| - | span.prefix.radius { |
| + | span.prefix.radius, label.prefix.radius { |
| -webkit-border-radius: 0; | |
| border-radius: 0; | |
| -moz-border-radius-bottomleft: 3px; | |
| @@ | @@ -1595,12 +1622,12 @@ span.prefix { |
| border-bottom-left-radius: 3px; | |
| border-top-left-radius: 3px; } | |
| - | span.postfix { |
| + | span.postfix, label.postfix { |
| background: #f2f2f2; | |
| border-color: #cccccc; | |
| border-left: none; | |
| color: #333333; } | |
| - | span.postfix.radius { |
| + | span.postfix.radius, label.postfix.radius { |
| -webkit-border-radius: 0; | |
| border-radius: 0; | |
| -moz-border-radius-topright: 3px; | |
| @@ | @@ -1655,6 +1682,9 @@ input[type="tel"], |
| input[type="time"], | |
| input[type="url"], | |
| textarea { | |
| + | -webkit-appearance: none; |
| + | -webkit-border-radius: 0; |
| + | border-radius: 0; |
| background-color: white; | |
| font-family: inherit; | |
| border: 1px solid #cccccc; | |
| @@ | @@ -1748,219 +1778,74 @@ fieldset { |
| margin-left: -0.1875em; } | |
| /* Error Handling */ | |
| + | [data-abide] .error small.error, [data-abide] span.error, [data-abide] small.error { |
| + | display: block; |
| + | padding: 0.375em 0.25em; |
| + | margin-top: 0; |
| + | margin-bottom: 1em; |
| + | font-size: 0.75em; |
| + | font-weight: bold; |
| + | background: #c60f13; |
| + | color: white; } |
| + | [data-abide] span.error, [data-abide] small.error { |
| + | display: none; } |
| + | |
| + | span.error, small.error { |
| + | display: block; |
| + | padding: 0.375em 0.25em; |
| + | margin-top: 0; |
| + | margin-bottom: 1em; |
| + | font-size: 0.75em; |
| + | font-weight: bold; |
| + | background: #c60f13; |
| + | color: white; } |
| + | |
| .error input, | |
| - | input.error, |
| .error textarea, | |
| - | textarea.error { |
| + | .error select { |
| border-color: #c60f13; | |
| - | background-color: rgba(198, 15, 19, 0.1); } |
| + | background-color: rgba(198, 15, 19, 0.1); |
| + | margin-bottom: 0; } |
| .error input:focus, | |
| - | input.error:focus, |
| .error textarea:focus, | |
| - | textarea.error:focus { |
| + | .error select:focus { |
| background: #fafafa; | |
| border-color: #999999; } | |
| - | |
| .error label, | |
| - | label.error { |
| + | .error label.error { |
| color: #c60f13; } | |
| - | |
| - | .error small, |
| - | small.error { |
| + | .error > small, |
| + | .error small.error { |
| display: block; | |
| padding: 0.375em 0.25em; | |
| - | margin-top: -1.3125em; |
| + | margin-top: 0; |
| margin-bottom: 1em; | |
| font-size: 0.75em; | |
| font-weight: bold; | |
| background: #c60f13; | |
| color: white; } | |
| + | .error span.error-message { |
| + | display: block; } |
| - | /* Custom Checkbox and Radio Inputs */ |
| - | form.custom .hidden-field { |
| - | margin-left: -99999px; |
| - | position: absolute; |
| - | visibility: hidden; } |
| - | form.custom .custom { |
| - | display: inline-block; |
| - | width: 16px; |
| - | height: 16px; |
| - | position: relative; |
| - | vertical-align: middle; |
| - | border: solid 1px #cccccc; |
| - | background: white; } |
| - | form.custom .custom.checkbox { |
| - | -webkit-border-radius: 0px; |
| - | border-radius: 0px; |
| - | padding: -1px; } |
| - | form.custom .custom.radio { |
| - | -webkit-border-radius: 1000px; |
| - | border-radius: 1000px; |
| - | padding: 3px; } |
| - | form.custom .custom.checkbox:before { |
| - | content: ""; |
| - | display: block; |
| - | font-size: 16px; |
| - | color: white; } |
| - | form.custom .custom.radio.checked:before { |
| - | content: ""; |
| - | display: block; |
| - | width: 8px; |
| - | height: 8px; |
| - | -webkit-border-radius: 1000px; |
| - | border-radius: 1000px; |
| - | background: #222222; |
| - | position: relative; } |
| - | form.custom .custom.checkbox.checked:before { |
| - | content: "\00d7"; |
| - | color: #222222; |
| - | position: absolute; |
| - | top: -50%; |
| - | left: 50%; |
| - | margin-top: 4px; |
| - | margin-left: -5px; } |
| + | input.error, |
| + | textarea.error { |
| + | border-color: #c60f13; |
| + | background-color: rgba(198, 15, 19, 0.1); |
| + | margin-bottom: 0; } |
| + | input.error:focus, |
| + | textarea.error:focus { |
| + | background: #fafafa; |
| + | border-color: #999999; } |
| - | /* Custom Select Options and Dropdowns */ |
| - | form.custom { |
| - | /* Custom input, disabled */ } |
| - | form.custom .custom.dropdown { |
| - | display: block; |
| - | position: relative; |
| - | top: 0; |
| - | height: 2.3125em; |
| - | margin-bottom: 1.25em; |
| - | margin-top: 0px; |
| - | padding: 0px; |
| - | width: 100%; |
| - | background: white; |
| - | background: -moz-linear-gradient(top, white 0%, #f3f3f3 100%); |
| - | background: -webkit-linear-gradient(top, white 0%, #f3f3f3 100%); |
| - | -webkit-box-shadow: none; |
| - | background: linear-gradient(to bottom, white 0%, #f3f3f3 100%); |
| - | box-shadow: none; |
| - | font-size: 0.875em; |
| - | vertical-align: top; } |
| - | form.custom .custom.dropdown ul { |
| - | overflow-y: auto; |
| - | max-height: 200px; } |
| - | form.custom .custom.dropdown .current { |
| - | cursor: default; |
| - | white-space: nowrap; |
| - | line-height: 2.25em; |
| - | color: rgba(0, 0, 0, 0.75); |
| - | text-decoration: none; |
| - | overflow: hidden; |
| - | display: block; |
| - | margin-left: 0.5em; |
| - | margin-right: 2.3125em; } |
| - | form.custom .custom.dropdown .selector { |
| - | cursor: default; |
| - | position: absolute; |
| - | width: 2.5em; |
| - | height: 2.3125em; |
| - | display: block; |
| - | right: 0; |
| - | top: 0; } |
| - | form.custom .custom.dropdown .selector:after { |
| - | content: ""; |
| - | display: block; |
| - | content: ""; |
| - | display: block; |
| - | width: 0; |
| - | height: 0; |
| - | border: inset 5px; |
| - | border-color: #aaaaaa transparent transparent transparent; |
| - | border-top-style: solid; |
| - | position: absolute; |
| - | left: 0.9375em; |
| - | top: 50%; |
| - | margin-top: -3px; } |
| - | form.custom .custom.dropdown:hover a.selector:after, form.custom .custom.dropdown.open a.selector:after { |
| - | content: ""; |
| - | display: block; |
| - | width: 0; |
| - | height: 0; |
| - | border: inset 5px; |
| - | border-color: #222222 transparent transparent transparent; |
| - | border-top-style: solid; } |
| - | form.custom .custom.dropdown .disabled { |
| - | color: #888888; } |
| - | form.custom .custom.dropdown .disabled:hover { |
| - | background: transparent; |
| - | color: #888888; } |
| - | form.custom .custom.dropdown .disabled:hover:after { |
| - | display: none; } |
| - | form.custom .custom.dropdown.open ul { |
| - | display: block; |
| - | z-index: 10; |
| - | min-width: 100%; |
| - | -moz-box-sizing: content-box; |
| - | -webkit-box-sizing: content-box; |
| - | box-sizing: content-box; } |
| - | form.custom .custom.dropdown.small { |
| - | max-width: 134px; } |
| - | form.custom .custom.dropdown.medium { |
| - | max-width: 254px; } |
| - | form.custom .custom.dropdown.large { |
| - | max-width: 434px; } |
| - | form.custom .custom.dropdown.expand { |
| - | width: 100% !important; } |
| - | form.custom .custom.dropdown.open.small ul { |
| - | min-width: 134px; |
| - | -moz-box-sizing: border-box; |
| - | -webkit-box-sizing: border-box; |
| - | box-sizing: border-box; } |
| - | form.custom .custom.dropdown.open.medium ul { |
| - | min-width: 254px; |
| - | -moz-box-sizing: border-box; |
| - | -webkit-box-sizing: border-box; |
| - | box-sizing: border-box; } |
| - | form.custom .custom.dropdown.open.large ul { |
| - | min-width: 434px; |
| - | -moz-box-sizing: border-box; |
| - | -webkit-box-sizing: border-box; |
| - | box-sizing: border-box; } |
| - | form.custom .custom.dropdown ul { |
| - | position: absolute; |
| - | width: auto; |
| - | display: none; |
| - | margin: 0; |
| - | left: -1px; |
| - | top: auto; |
| - | -webkit-box-shadow: 0 2px 2px 0px rgba(0, 0, 0, 0.1); |
| - | box-shadow: 0 2px 2px 0px rgba(0, 0, 0, 0.1); |
| - | margin: 0; |
| - | padding: 0; |
| - | background: white; |
| - | border: solid 1px #cccccc; |
| - | font-size: 16px; } |
| - | form.custom .custom.dropdown ul li { |
| - | color: #555555; |
| - | font-size: 0.875em; |
| - | cursor: default; |
| - | padding-top: 0.25em; |
| - | padding-bottom: 0.25em; |
| - | padding-left: 0.375em; |
| - | padding-right: 2.375em; |
| - | min-height: 1.5em; |
| - | line-height: 1.5em; |
| - | margin: 0; |
| - | white-space: nowrap; |
| - | list-style: none; } |
| - | form.custom .custom.dropdown ul li.selected { |
| - | background: #eeeeee; |
| - | color: black; } |
| - | form.custom .custom.dropdown ul li:hover { |
| - | background-color: #e4e4e4; |
| - | color: black; } |
| - | form.custom .custom.dropdown ul li.selected:hover { |
| - | background: #eeeeee; |
| - | cursor: default; |
| - | color: black; } |
| - | form.custom .custom.dropdown ul.show { |
| - | display: block; } |
| - | form.custom .custom.disabled { |
| - | background: #dddddd; } |
| + | .error select { |
| + | border-color: #c60f13; |
| + | background-color: rgba(198, 15, 19, 0.1); } |
| + | .error select:focus { |
| + | background: #fafafa; |
| + | border-color: #999999; } |
| + | |
| + | label.error { |
| + | color: #c60f13; } |
| /* Button Groups */ | |
| .button-group { | |
| @@ | @@ -2202,406 +2087,734 @@ form.custom { |
| height: 100%; } | |
| /* Sections */ | |
| - | .section-container, .section-container.auto { |
| + | [data-section=''], [data-section='auto'], .section-container.auto, |
| + | [data-section='vertical-tabs'], .section-container.vertical-tabs, |
| + | [data-section='vertical-nav'], .section-container.vertical-nav, |
| + | [data-section='horizontal-nav'], .section-container.horizontal-nav, |
| + | [data-section='accordion'], .section-container.accordion { |
| width: 100%; | |
| + | position: relative; |
| display: block; | |
| - | margin-bottom: 1.25em; |
| - | border: 1px solid #cccccc; |
| - | border-top: none; } |
| - | .section-container > section, .section-container > .section, .section-container.auto > section, .section-container.auto > .section { |
| - | position: relative; } |
| - | .section-container > section > .title, .section-container > .section > .title, .section-container.auto > section > .title, .section-container.auto > .section > .title { |
| - | background-color: #efefef; |
| - | cursor: pointer; |
| + | margin-bottom: 1.25em; } |
| + | [data-section=''][data-section-small-style], [data-section='auto'][data-section-small-style], .section-container.auto[data-section-small-style], |
| + | [data-section='vertical-tabs'][data-section-small-style], .section-container.vertical-tabs[data-section-small-style], |
| + | [data-section='vertical-nav'][data-section-small-style], .section-container.vertical-nav[data-section-small-style], |
| + | [data-section='horizontal-nav'][data-section-small-style], .section-container.horizontal-nav[data-section-small-style], |
| + | [data-section='accordion'][data-section-small-style], .section-container.accordion[data-section-small-style] { |
| + | width: 100% !important; } |
| + | [data-section=''][data-section-small-style] > [data-section-region], [data-section=''][data-section-small-style] > section, [data-section=''][data-section-small-style] > .section, [data-section='auto'][data-section-small-style] > [data-section-region], [data-section='auto'][data-section-small-style] > section, [data-section='auto'][data-section-small-style] > .section, .section-container.auto[data-section-small-style] > [data-section-region], .section-container.auto[data-section-small-style] > section, .section-container.auto[data-section-small-style] > .section, |
| + | [data-section='vertical-tabs'][data-section-small-style] > [data-section-region], |
| + | [data-section='vertical-tabs'][data-section-small-style] > section, |
| + | [data-section='vertical-tabs'][data-section-small-style] > .section, .section-container.vertical-tabs[data-section-small-style] > [data-section-region], .section-container.vertical-tabs[data-section-small-style] > section, .section-container.vertical-tabs[data-section-small-style] > .section, |
| + | [data-section='vertical-nav'][data-section-small-style] > [data-section-region], |
| + | [data-section='vertical-nav'][data-section-small-style] > section, |
| + | [data-section='vertical-nav'][data-section-small-style] > .section, .section-container.vertical-nav[data-section-small-style] > [data-section-region], .section-container.vertical-nav[data-section-small-style] > section, .section-container.vertical-nav[data-section-small-style] > .section, |
| + | [data-section='horizontal-nav'][data-section-small-style] > [data-section-region], |
| + | [data-section='horizontal-nav'][data-section-small-style] > section, |
| + | [data-section='horizontal-nav'][data-section-small-style] > .section, .section-container.horizontal-nav[data-section-small-style] > [data-section-region], .section-container.horizontal-nav[data-section-small-style] > section, .section-container.horizontal-nav[data-section-small-style] > .section, |
| + | [data-section='accordion'][data-section-small-style] > [data-section-region], |
| + | [data-section='accordion'][data-section-small-style] > section, |
| + | [data-section='accordion'][data-section-small-style] > .section, .section-container.accordion[data-section-small-style] > [data-section-region], .section-container.accordion[data-section-small-style] > section, .section-container.accordion[data-section-small-style] > .section { |
| + | padding: 0 !important; |
| + | margin: 0 !important; } |
| + | [data-section=''][data-section-small-style] > [data-section-region] > [data-section-title], [data-section=''][data-section-small-style] > [data-section-region] > .title, [data-section=''][data-section-small-style] > section > [data-section-title], [data-section=''][data-section-small-style] > section > .title, [data-section=''][data-section-small-style] > .section > [data-section-title], [data-section=''][data-section-small-style] > .section > .title, [data-section='auto'][data-section-small-style] > [data-section-region] > [data-section-title], [data-section='auto'][data-section-small-style] > [data-section-region] > .title, [data-section='auto'][data-section-small-style] > section > [data-section-title], [data-section='auto'][data-section-small-style] > section > .title, [data-section='auto'][data-section-small-style] > .section > [data-section-title], [data-section='auto'][data-section-small-style] > .section > .title, .section-container.auto[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.auto[data-section-small-style] > [data-section-region] > .title, .section-container.auto[data-section-small-style] > section > [data-section-title], .section-container.auto[data-section-small-style] > section > .title, .section-container.auto[data-section-small-style] > .section > [data-section-title], .section-container.auto[data-section-small-style] > .section > .title, |
| + | [data-section='vertical-tabs'][data-section-small-style] > [data-section-region] > [data-section-title], |
| + | [data-section='vertical-tabs'][data-section-small-style] > [data-section-region] > .title, |
| + | [data-section='vertical-tabs'][data-section-small-style] > section > [data-section-title], |
| + | [data-section='vertical-tabs'][data-section-small-style] > section > .title, |
| + | [data-section='vertical-tabs'][data-section-small-style] > .section > [data-section-title], |
| + | [data-section='vertical-tabs'][data-section-small-style] > .section > .title, .section-container.vertical-tabs[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.vertical-tabs[data-section-small-style] > [data-section-region] > .title, .section-container.vertical-tabs[data-section-small-style] > section > [data-section-title], .section-container.vertical-tabs[data-section-small-style] > section > .title, .section-container.vertical-tabs[data-section-small-style] > .section > [data-section-title], .section-container.vertical-tabs[data-section-small-style] > .section > .title, |
| + | [data-section='vertical-nav'][data-section-small-style] > [data-section-region] > [data-section-title], |
| + | [data-section='vertical-nav'][data-section-small-style] > [data-section-region] > .title, |
| + | [data-section='vertical-nav'][data-section-small-style] > section > [data-section-title], |
| + | [data-section='vertical-nav'][data-section-small-style] > section > .title, |
| + | [data-section='vertical-nav'][data-section-small-style] > .section > [data-section-title], |
| + | [data-section='vertical-nav'][data-section-small-style] > .section > .title, .section-container.vertical-nav[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.vertical-nav[data-section-small-style] > [data-section-region] > .title, .section-container.vertical-nav[data-section-small-style] > section > [data-section-title], .section-container.vertical-nav[data-section-small-style] > section > .title, .section-container.vertical-nav[data-section-small-style] > .section > [data-section-title], .section-container.vertical-nav[data-section-small-style] > .section > .title, |
| + | [data-section='horizontal-nav'][data-section-small-style] > [data-section-region] > [data-section-title], |
| + | [data-section='horizontal-nav'][data-section-small-style] > [data-section-region] > .title, |
| + | [data-section='horizontal-nav'][data-section-small-style] > section > [data-section-title], |
| + | [data-section='horizontal-nav'][data-section-small-style] > section > .title, |
| + | [data-section='horizontal-nav'][data-section-small-style] > .section > [data-section-title], |
| + | [data-section='horizontal-nav'][data-section-small-style] > .section > .title, .section-container.horizontal-nav[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.horizontal-nav[data-section-small-style] > [data-section-region] > .title, .section-container.horizontal-nav[data-section-small-style] > section > [data-section-title], .section-container.horizontal-nav[data-section-small-style] > section > .title, .section-container.horizontal-nav[data-section-small-style] > .section > [data-section-title], .section-container.horizontal-nav[data-section-small-style] > .section > .title, |
| + | [data-section='accordion'][data-section-small-style] > [data-section-region] > [data-section-title], |
| + | [data-section='accordion'][data-section-small-style] > [data-section-region] > .title, |
| + | [data-section='accordion'][data-section-small-style] > section > [data-section-title], |
| + | [data-section='accordion'][data-section-small-style] > section > .title, |
| + | [data-section='accordion'][data-section-small-style] > .section > [data-section-title], |
| + | [data-section='accordion'][data-section-small-style] > .section > .title, .section-container.accordion[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.accordion[data-section-small-style] > [data-section-region] > .title, .section-container.accordion[data-section-small-style] > section > [data-section-title], .section-container.accordion[data-section-small-style] > section > .title, .section-container.accordion[data-section-small-style] > .section > [data-section-title], .section-container.accordion[data-section-small-style] > .section > .title { |
| + | width: 100% !important; } |
| + | [data-section=''] > section, [data-section=''] > .section, [data-section=''] > [data-section-region], [data-section='auto'] > section, [data-section='auto'] > .section, [data-section='auto'] > [data-section-region], .section-container.auto > section, .section-container.auto > .section, .section-container.auto > [data-section-region], |
| + | [data-section='vertical-tabs'] > section, |
| + | [data-section='vertical-tabs'] > .section, |
| + | [data-section='vertical-tabs'] > [data-section-region], .section-container.vertical-tabs > section, .section-container.vertical-tabs > .section, .section-container.vertical-tabs > [data-section-region], |
| + | [data-section='vertical-nav'] > section, |
| + | [data-section='vertical-nav'] > .section, |
| + | [data-section='vertical-nav'] > [data-section-region], .section-container.vertical-nav > section, .section-container.vertical-nav > .section, .section-container.vertical-nav > [data-section-region], |
| + | [data-section='horizontal-nav'] > section, |
| + | [data-section='horizontal-nav'] > .section, |
| + | [data-section='horizontal-nav'] > [data-section-region], .section-container.horizontal-nav > section, .section-container.horizontal-nav > .section, .section-container.horizontal-nav > [data-section-region], |
| + | [data-section='accordion'] > section, |
| + | [data-section='accordion'] > .section, |
| + | [data-section='accordion'] > [data-section-region], .section-container.accordion > section, .section-container.accordion > .section, .section-container.accordion > [data-section-region] { |
| + | margin: 0; } |
| + | [data-section=''] > section > [data-section-title], [data-section=''] > section > .title, [data-section=''] > .section > [data-section-title], [data-section=''] > .section > .title, [data-section=''] > [data-section-region] > [data-section-title], [data-section=''] > [data-section-region] > .title, [data-section='auto'] > section > [data-section-title], [data-section='auto'] > section > .title, [data-section='auto'] > .section > [data-section-title], [data-section='auto'] > .section > .title, [data-section='auto'] > [data-section-region] > [data-section-title], [data-section='auto'] > [data-section-region] > .title, .section-container.auto > section > [data-section-title], .section-container.auto > section > .title, .section-container.auto > .section > [data-section-title], .section-container.auto > .section > .title, .section-container.auto > [data-section-region] > [data-section-title], .section-container.auto > [data-section-region] > .title, |
| + | [data-section='vertical-tabs'] > section > [data-section-title], |
| + | [data-section='vertical-tabs'] > section > .title, |
| + | [data-section='vertical-tabs'] > .section > [data-section-title], |
| + | [data-section='vertical-tabs'] > .section > .title, |
| + | [data-section='vertical-tabs'] > [data-section-region] > [data-section-title], |
| + | [data-section='vertical-tabs'] > [data-section-region] > .title, .section-container.vertical-tabs > section > [data-section-title], .section-container.vertical-tabs > section > .title, .section-container.vertical-tabs > .section > [data-section-title], .section-container.vertical-tabs > .section > .title, .section-container.vertical-tabs > [data-section-region] > [data-section-title], .section-container.vertical-tabs > [data-section-region] > .title, |
| + | [data-section='vertical-nav'] > section > [data-section-title], |
| + | [data-section='vertical-nav'] > section > .title, |
| + | [data-section='vertical-nav'] > .section > [data-section-title], |
| + | [data-section='vertical-nav'] > .section > .title, |
| + | [data-section='vertical-nav'] > [data-section-region] > [data-section-title], |
| + | [data-section='vertical-nav'] > [data-section-region] > .title, .section-container.vertical-nav > section > [data-section-title], .section-container.vertical-nav > section > .title, .section-container.vertical-nav > .section > [data-section-title], .section-container.vertical-nav > .section > .title, .section-container.vertical-nav > [data-section-region] > [data-section-title], .section-container.vertical-nav > [data-section-region] > .title, |
| + | [data-section='horizontal-nav'] > section > [data-section-title], |
| + | [data-section='horizontal-nav'] > section > .title, |
| + | [data-section='horizontal-nav'] > .section > [data-section-title], |
| + | [data-section='horizontal-nav'] > .section > .title, |
| + | [data-section='horizontal-nav'] > [data-section-region] > [data-section-title], |
| + | [data-section='horizontal-nav'] > [data-section-region] > .title, .section-container.horizontal-nav > section > [data-section-title], .section-container.horizontal-nav > section > .title, .section-container.horizontal-nav > .section > [data-section-title], .section-container.horizontal-nav > .section > .title, .section-container.horizontal-nav > [data-section-region] > [data-section-title], .section-container.horizontal-nav > [data-section-region] > .title, |
| + | [data-section='accordion'] > section > [data-section-title], |
| + | [data-section='accordion'] > section > .title, |
| + | [data-section='accordion'] > .section > [data-section-title], |
| + | [data-section='accordion'] > .section > .title, |
| + | [data-section='accordion'] > [data-section-region] > [data-section-title], |
| + | [data-section='accordion'] > [data-section-region] > .title, .section-container.accordion > section > [data-section-title], .section-container.accordion > section > .title, .section-container.accordion > .section > [data-section-title], .section-container.accordion > .section > .title, .section-container.accordion > [data-section-region] > [data-section-title], .section-container.accordion > [data-section-region] > .title { |
| margin-bottom: 0; } | |
| - | .section-container > section > .title a, .section-container > .section > .title a, .section-container.auto > section > .title a, .section-container.auto > .section > .title a { |
| - | padding: 0.9375em; |
| + | [data-section=''] > section > [data-section-title] a, [data-section=''] > section > .title a, [data-section=''] > .section > [data-section-title] a, [data-section=''] > .section > .title a, [data-section=''] > [data-section-region] > [data-section-title] a, [data-section=''] > [data-section-region] > .title a, [data-section='auto'] > section > [data-section-title] a, [data-section='auto'] > section > .title a, [data-section='auto'] > .section > [data-section-title] a, [data-section='auto'] > .section > .title a, [data-section='auto'] > [data-section-region] > [data-section-title] a, [data-section='auto'] > [data-section-region] > .title a, .section-container.auto > section > [data-section-title] a, .section-container.auto > section > .title a, .section-container.auto > .section > [data-section-title] a, .section-container.auto > .section > .title a, .section-container.auto > [data-section-region] > [data-section-title] a, .section-container.auto > [data-section-region] > .title a, |
| + | [data-section='vertical-tabs'] > section > [data-section-title] a, |
| + | [data-section='vertical-tabs'] > section > .title a, |
| + | [data-section='vertical-tabs'] > .section > [data-section-title] a, |
| + | [data-section='vertical-tabs'] > .section > .title a, |
| + | [data-section='vertical-tabs'] > [data-section-region] > [data-section-title] a, |
| + | [data-section='vertical-tabs'] > [data-section-region] > .title a, .section-container.vertical-tabs > section > [data-section-title] a, .section-container.vertical-tabs > section > .title a, .section-container.vertical-tabs > .section > [data-section-title] a, .section-container.vertical-tabs > .section > .title a, .section-container.vertical-tabs > [data-section-region] > [data-section-title] a, .section-container.vertical-tabs > [data-section-region] > .title a, |
| + | [data-section='vertical-nav'] > section > [data-section-title] a, |
| + | [data-section='vertical-nav'] > section > .title a, |
| + | [data-section='vertical-nav'] > .section > [data-section-title] a, |
| + | [data-section='vertical-nav'] > .section > .title a, |
| + | [data-section='vertical-nav'] > [data-section-region] > [data-section-title] a, |
| + | [data-section='vertical-nav'] > [data-section-region] > .title a, .section-container.vertical-nav > section > [data-section-title] a, .section-container.vertical-nav > section > .title a, .section-container.vertical-nav > .section > [data-section-title] a, .section-container.vertical-nav > .section > .title a, .section-container.vertical-nav > [data-section-region] > [data-section-title] a, .section-container.vertical-nav > [data-section-region] > .title a, |
| + | [data-section='horizontal-nav'] > section > [data-section-title] a, |
| + | [data-section='horizontal-nav'] > section > .title a, |
| + | [data-section='horizontal-nav'] > .section > [data-section-title] a, |
| + | [data-section='horizontal-nav'] > .section > .title a, |
| + | [data-section='horizontal-nav'] > [data-section-region] > [data-section-title] a, |
| + | [data-section='horizontal-nav'] > [data-section-region] > .title a, .section-container.horizontal-nav > section > [data-section-title] a, .section-container.horizontal-nav > section > .title a, .section-container.horizontal-nav > .section > [data-section-title] a, .section-container.horizontal-nav > .section > .title a, .section-container.horizontal-nav > [data-section-region] > [data-section-title] a, .section-container.horizontal-nav > [data-section-region] > .title a, |
| + | [data-section='accordion'] > section > [data-section-title] a, |
| + | [data-section='accordion'] > section > .title a, |
| + | [data-section='accordion'] > .section > [data-section-title] a, |
| + | [data-section='accordion'] > .section > .title a, |
| + | [data-section='accordion'] > [data-section-region] > [data-section-title] a, |
| + | [data-section='accordion'] > [data-section-region] > .title a, .section-container.accordion > section > [data-section-title] a, .section-container.accordion > section > .title a, .section-container.accordion > .section > [data-section-title] a, .section-container.accordion > .section > .title a, .section-container.accordion > [data-section-region] > [data-section-title] a, .section-container.accordion > [data-section-region] > .title a { |
| + | width: 100%; |
| display: inline-block; | |
| - | color: #333333; |
| - | font-size: 0.875em; |
| white-space: nowrap; } | |
| - | .section-container > section > .title:hover, .section-container > .section > .title:hover, .section-container.auto > section > .title:hover, .section-container.auto > .section > .title:hover { |
| - | background-color: #e2e2e2; } |
| - | .section-container > section .content, .section-container > .section .content, .section-container.auto > section .content, .section-container.auto > .section .content { |
| - | display: none; |
| - | padding: 0.9375em; |
| - | background-color: white; } |
| - | .section-container > section .content > *:last-child, .section-container > .section .content > *:last-child, .section-container.auto > section .content > *:last-child, .section-container.auto > .section .content > *:last-child { |
| - | margin-bottom: 0; } |
| - | .section-container > section .content > *:first-child, .section-container > .section .content > *:first-child, .section-container.auto > section .content > *:first-child, .section-container.auto > .section .content > *:first-child { |
| - | padding-top: 0; } |
| - | .section-container > section .content > *:last-child, .section-container > .section .content > *:last-child, .section-container.auto > section .content > *:last-child, .section-container.auto > .section .content > *:last-child { |
| - | padding-bottom: 0; } |
| - | .section-container > section.active > .content, .section-container > .section.active > .content, .section-container.auto > section.active > .content, .section-container.auto > .section.active > .content { |
| + | [data-section=''] > section > [data-section-content], [data-section=''] > section > .content, [data-section=''] > .section > [data-section-content], [data-section=''] > .section > .content, [data-section=''] > [data-section-region] > [data-section-content], [data-section=''] > [data-section-region] > .content, [data-section='auto'] > section > [data-section-content], [data-section='auto'] > section > .content, [data-section='auto'] > .section > [data-section-content], [data-section='auto'] > .section > .content, [data-section='auto'] > [data-section-region] > [data-section-content], [data-section='auto'] > [data-section-region] > .content, .section-container.auto > section > [data-section-content], .section-container.auto > section > .content, .section-container.auto > .section > [data-section-content], .section-container.auto > .section > .content, .section-container.auto > [data-section-region] > [data-section-content], .section-container.auto > [data-section-region] > .content, |
| + | [data-section='vertical-tabs'] > section > [data-section-content], |
| + | [data-section='vertical-tabs'] > section > .content, |
| + | [data-section='vertical-tabs'] > .section > [data-section-content], |
| + | [data-section='vertical-tabs'] > .section > .content, |
| + | [data-section='vertical-tabs'] > [data-section-region] > [data-section-content], |
| + | [data-section='vertical-tabs'] > [data-section-region] > .content, .section-container.vertical-tabs > section > [data-section-content], .section-container.vertical-tabs > section > .content, .section-container.vertical-tabs > .section > [data-section-content], .section-container.vertical-tabs > .section > .content, .section-container.vertical-tabs > [data-section-region] > [data-section-content], .section-container.vertical-tabs > [data-section-region] > .content, |
| + | [data-section='vertical-nav'] > section > [data-section-content], |
| + | [data-section='vertical-nav'] > section > .content, |
| + | [data-section='vertical-nav'] > .section > [data-section-content], |
| + | [data-section='vertical-nav'] > .section > .content, |
| + | [data-section='vertical-nav'] > [data-section-region] > [data-section-content], |
| + | [data-section='vertical-nav'] > [data-section-region] > .content, .section-container.vertical-nav > section > [data-section-content], .section-container.vertical-nav > section > .content, .section-container.vertical-nav > .section > [data-section-content], .section-container.vertical-nav > .section > .content, .section-container.vertical-nav > [data-section-region] > [data-section-content], .section-container.vertical-nav > [data-section-region] > .content, |
| + | [data-section='horizontal-nav'] > section > [data-section-content], |
| + | [data-section='horizontal-nav'] > section > .content, |
| + | [data-section='horizontal-nav'] > .section > [data-section-content], |
| + | [data-section='horizontal-nav'] > .section > .content, |
| + | [data-section='horizontal-nav'] > [data-section-region] > [data-section-content], |
| + | [data-section='horizontal-nav'] > [data-section-region] > .content, .section-container.horizontal-nav > section > [data-section-content], .section-container.horizontal-nav > section > .content, .section-container.horizontal-nav > .section > [data-section-content], .section-container.horizontal-nav > .section > .content, .section-container.horizontal-nav > [data-section-region] > [data-section-content], .section-container.horizontal-nav > [data-section-region] > .content, |
| + | [data-section='accordion'] > section > [data-section-content], |
| + | [data-section='accordion'] > section > .content, |
| + | [data-section='accordion'] > .section > [data-section-content], |
| + | [data-section='accordion'] > .section > .content, |
| + | [data-section='accordion'] > [data-section-region] > [data-section-content], |
| + | [data-section='accordion'] > [data-section-region] > .content, .section-container.accordion > section > [data-section-content], .section-container.accordion > section > .content, .section-container.accordion > .section > [data-section-content], .section-container.accordion > .section > .content, .section-container.accordion > [data-section-region] > [data-section-content], .section-container.accordion > [data-section-region] > .content { |
| + | display: none; } |
| + | [data-section=''] > section.active > [data-section-content], [data-section=''] > section.active > .content, [data-section=''] > .section.active > [data-section-content], [data-section=''] > .section.active > .content, [data-section=''] > [data-section-region].active > [data-section-content], [data-section=''] > [data-section-region].active > .content, [data-section='auto'] > section.active > [data-section-content], [data-section='auto'] > section.active > .content, [data-section='auto'] > .section.active > [data-section-content], [data-section='auto'] > .section.active > .content, [data-section='auto'] > [data-section-region].active > [data-section-content], [data-section='auto'] > [data-section-region].active > .content, .section-container.auto > section.active > [data-section-content], .section-container.auto > section.active > .content, .section-container.auto > .section.active > [data-section-content], .section-container.auto > .section.active > .content, .section-container.auto > [data-section-region].active > [data-section-content], .section-container.auto > [data-section-region].active > .content, |
| + | [data-section='vertical-tabs'] > section.active > [data-section-content], |
| + | [data-section='vertical-tabs'] > section.active > .content, |
| + | [data-section='vertical-tabs'] > .section.active > [data-section-content], |
| + | [data-section='vertical-tabs'] > .section.active > .content, |
| + | [data-section='vertical-tabs'] > [data-section-region].active > [data-section-content], |
| + | [data-section='vertical-tabs'] > [data-section-region].active > .content, .section-container.vertical-tabs > section.active > [data-section-content], .section-container.vertical-tabs > section.active > .content, .section-container.vertical-tabs > .section.active > [data-section-content], .section-container.vertical-tabs > .section.active > .content, .section-container.vertical-tabs > [data-section-region].active > [data-section-content], .section-container.vertical-tabs > [data-section-region].active > .content, |
| + | [data-section='vertical-nav'] > section.active > [data-section-content], |
| + | [data-section='vertical-nav'] > section.active > .content, |
| + | [data-section='vertical-nav'] > .section.active > [data-section-content], |
| + | [data-section='vertical-nav'] > .section.active > .content, |
| + | [data-section='vertical-nav'] > [data-section-region].active > [data-section-content], |
| + | [data-section='vertical-nav'] > [data-section-region].active > .content, .section-container.vertical-nav > section.active > [data-section-content], .section-container.vertical-nav > section.active > .content, .section-container.vertical-nav > .section.active > [data-section-content], .section-container.vertical-nav > .section.active > .content, .section-container.vertical-nav > [data-section-region].active > [data-section-content], .section-container.vertical-nav > [data-section-region].active > .content, |
| + | [data-section='horizontal-nav'] > section.active > [data-section-content], |
| + | [data-section='horizontal-nav'] > section.active > .content, |
| + | [data-section='horizontal-nav'] > .section.active > [data-section-content], |
| + | [data-section='horizontal-nav'] > .section.active > .content, |
| + | [data-section='horizontal-nav'] > [data-section-region].active > [data-section-content], |
| + | [data-section='horizontal-nav'] > [data-section-region].active > .content, .section-container.horizontal-nav > section.active > [data-section-content], .section-container.horizontal-nav > section.active > .content, .section-container.horizontal-nav > .section.active > [data-section-content], .section-container.horizontal-nav > .section.active > .content, .section-container.horizontal-nav > [data-section-region].active > [data-section-content], .section-container.horizontal-nav > [data-section-region].active > .content, |
| + | [data-section='accordion'] > section.active > [data-section-content], |
| + | [data-section='accordion'] > section.active > .content, |
| + | [data-section='accordion'] > .section.active > [data-section-content], |
| + | [data-section='accordion'] > .section.active > .content, |
| + | [data-section='accordion'] > [data-section-region].active > [data-section-content], |
| + | [data-section='accordion'] > [data-section-region].active > .content, .section-container.accordion > section.active > [data-section-content], .section-container.accordion > section.active > .content, .section-container.accordion > .section.active > [data-section-content], .section-container.accordion > .section.active > .content, .section-container.accordion > [data-section-region].active > [data-section-content], .section-container.accordion > [data-section-region].active > .content { |
| display: block; } | |
| - | .section-container > section.active > .title, .section-container > .section.active > .title, .section-container.auto > section.active > .title, .section-container.auto > .section.active > .title { |
| - | background: #d5d5d5; } |
| - | .section-container > section.active > .title a, .section-container > .section.active > .title a, .section-container.auto > section.active > .title a, .section-container.auto > .section.active > .title a { |
| - | color: #333333; } |
| - | .section-container > section > .title, .section-container > .section > .title, .section-container.auto > section > .title, .section-container.auto > .section > .title { |
| - | top: 0; |
| - | width: 100%; |
| - | margin: 0; |
| - | border-top: solid 1px #cccccc; } |
| - | .section-container > section > .title a, .section-container > .section > .title a, .section-container.auto > section > .title a, .section-container.auto > .section > .title a { |
| - | width: 100%; } |
| + | [data-section=''] > section:not(.active), [data-section=''] > .section:not(.active), [data-section=''] > [data-section-region]:not(.active), [data-section='auto'] > section:not(.active), [data-section='auto'] > .section:not(.active), [data-section='auto'] > [data-section-region]:not(.active), .section-container.auto > section:not(.active), .section-container.auto > .section:not(.active), .section-container.auto > [data-section-region]:not(.active), |
| + | [data-section='vertical-tabs'] > section:not(.active), |
| + | [data-section='vertical-tabs'] > .section:not(.active), |
| + | [data-section='vertical-tabs'] > [data-section-region]:not(.active), .section-container.vertical-tabs > section:not(.active), .section-container.vertical-tabs > .section:not(.active), .section-container.vertical-tabs > [data-section-region]:not(.active), |
| + | [data-section='vertical-nav'] > section:not(.active), |
| + | [data-section='vertical-nav'] > .section:not(.active), |
| + | [data-section='vertical-nav'] > [data-section-region]:not(.active), .section-container.vertical-nav > section:not(.active), .section-container.vertical-nav > .section:not(.active), .section-container.vertical-nav > [data-section-region]:not(.active), |
| + | [data-section='horizontal-nav'] > section:not(.active), |
| + | [data-section='horizontal-nav'] > .section:not(.active), |
| + | [data-section='horizontal-nav'] > [data-section-region]:not(.active), .section-container.horizontal-nav > section:not(.active), .section-container.horizontal-nav > .section:not(.active), .section-container.horizontal-nav > [data-section-region]:not(.active), |
| + | [data-section='accordion'] > section:not(.active), |
| + | [data-section='accordion'] > .section:not(.active), |
| + | [data-section='accordion'] > [data-section-region]:not(.active), .section-container.accordion > section:not(.active), .section-container.accordion > .section:not(.active), .section-container.accordion > [data-section-region]:not(.active) { |
| + | padding: 0 !important; } |
| + | [data-section=''] > section > [data-section-title], [data-section=''] > section > .title, [data-section=''] > .section > [data-section-title], [data-section=''] > .section > .title, [data-section=''] > [data-section-region] > [data-section-title], [data-section=''] > [data-section-region] > .title, [data-section='auto'] > section > [data-section-title], [data-section='auto'] > section > .title, [data-section='auto'] > .section > [data-section-title], [data-section='auto'] > .section > .title, [data-section='auto'] > [data-section-region] > [data-section-title], [data-section='auto'] > [data-section-region] > .title, .section-container.auto > section > [data-section-title], .section-container.auto > section > .title, .section-container.auto > .section > [data-section-title], .section-container.auto > .section > .title, .section-container.auto > [data-section-region] > [data-section-title], .section-container.auto > [data-section-region] > .title, |
| + | [data-section='vertical-tabs'] > section > [data-section-title], |
| + | [data-section='vertical-tabs'] > section > .title, |
| + | [data-section='vertical-tabs'] > .section > [data-section-title], |
| + | [data-section='vertical-tabs'] > .section > .title, |
| + | [data-section='vertical-tabs'] > [data-section-region] > [data-section-title], |
| + | [data-section='vertical-tabs'] > [data-section-region] > .title, .section-container.vertical-tabs > section > [data-section-title], .section-container.vertical-tabs > section > .title, .section-container.vertical-tabs > .section > [data-section-title], .section-container.vertical-tabs > .section > .title, .section-container.vertical-tabs > [data-section-region] > [data-section-title], .section-container.vertical-tabs > [data-section-region] > .title, |
| + | [data-section='vertical-nav'] > section > [data-section-title], |
| + | [data-section='vertical-nav'] > section > .title, |
| + | [data-section='vertical-nav'] > .section > [data-section-title], |
| + | [data-section='vertical-nav'] > .section > .title, |
| + | [data-section='vertical-nav'] > [data-section-region] > [data-section-title], |
| + | [data-section='vertical-nav'] > [data-section-region] > .title, .section-container.vertical-nav > section > [data-section-title], .section-container.vertical-nav > section > .title, .section-container.vertical-nav > .section > [data-section-title], .section-container.vertical-nav > .section > .title, .section-container.vertical-nav > [data-section-region] > [data-section-title], .section-container.vertical-nav > [data-section-region] > .title, |
| + | [data-section='horizontal-nav'] > section > [data-section-title], |
| + | [data-section='horizontal-nav'] > section > .title, |
| + | [data-section='horizontal-nav'] > .section > [data-section-title], |
| + | [data-section='horizontal-nav'] > .section > .title, |
| + | [data-section='horizontal-nav'] > [data-section-region] > [data-section-title], |
| + | [data-section='horizontal-nav'] > [data-section-region] > .title, .section-container.horizontal-nav > section > [data-section-title], .section-container.horizontal-nav > section > .title, .section-container.horizontal-nav > .section > [data-section-title], .section-container.horizontal-nav > .section > .title, .section-container.horizontal-nav > [data-section-region] > [data-section-title], .section-container.horizontal-nav > [data-section-region] > .title, |
| + | [data-section='accordion'] > section > [data-section-title], |
| + | [data-section='accordion'] > section > .title, |
| + | [data-section='accordion'] > .section > [data-section-title], |
| + | [data-section='accordion'] > .section > .title, |
| + | [data-section='accordion'] > [data-section-region] > [data-section-title], |
| + | [data-section='accordion'] > [data-section-region] > .title, .section-container.accordion > section > [data-section-title], .section-container.accordion > section > .title, .section-container.accordion > .section > [data-section-title], .section-container.accordion > .section > .title, .section-container.accordion > [data-section-region] > [data-section-title], .section-container.accordion > [data-section-region] > .title { |
| + | width: 100%; } |
| + | |
| + | .section-container.auto, |
| + | .section-container.vertical-tabs, |
| + | .section-container.vertical-nav, |
| + | .section-container.horizontal-nav, |
| + | .section-container.accordion { |
| + | border-top: 1px solid #cccccc; } |
| + | .section-container.auto > section > .title, .section-container.auto > .section > .title, |
| + | .section-container.vertical-tabs > section > .title, |
| + | .section-container.vertical-tabs > .section > .title, |
| + | .section-container.vertical-nav > section > .title, |
| + | .section-container.vertical-nav > .section > .title, |
| + | .section-container.horizontal-nav > section > .title, |
| + | .section-container.horizontal-nav > .section > .title, |
| + | .section-container.accordion > section > .title, |
| + | .section-container.accordion > .section > .title { |
| + | background-color: #efefef; |
| + | cursor: pointer; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.auto > section > .title a, .section-container.auto > .section > .title a, |
| + | .section-container.vertical-tabs > section > .title a, |
| + | .section-container.vertical-tabs > .section > .title a, |
| + | .section-container.vertical-nav > section > .title a, |
| + | .section-container.vertical-nav > .section > .title a, |
| + | .section-container.horizontal-nav > section > .title a, |
| + | .section-container.horizontal-nav > .section > .title a, |
| + | .section-container.accordion > section > .title a, |
| + | .section-container.accordion > .section > .title a { |
| + | padding: 0.9375em; |
| + | color: #333333; |
| + | font-size: 0.875em; |
| + | background: none; } |
| + | .section-container.auto > section > .title:hover, .section-container.auto > .section > .title:hover, |
| + | .section-container.vertical-tabs > section > .title:hover, |
| + | .section-container.vertical-tabs > .section > .title:hover, |
| + | .section-container.vertical-nav > section > .title:hover, |
| + | .section-container.vertical-nav > .section > .title:hover, |
| + | .section-container.horizontal-nav > section > .title:hover, |
| + | .section-container.horizontal-nav > .section > .title:hover, |
| + | .section-container.accordion > section > .title:hover, |
| + | .section-container.accordion > .section > .title:hover { |
| + | background-color: #e2e2e2; } |
| + | .section-container.auto > section > .content, .section-container.auto > .section > .content, |
| + | .section-container.vertical-tabs > section > .content, |
| + | .section-container.vertical-tabs > .section > .content, |
| + | .section-container.vertical-nav > section > .content, |
| + | .section-container.vertical-nav > .section > .content, |
| + | .section-container.horizontal-nav > section > .content, |
| + | .section-container.horizontal-nav > .section > .content, |
| + | .section-container.accordion > section > .content, |
| + | .section-container.accordion > .section > .content { |
| + | padding: 0.9375em; |
| + | background-color: white; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.auto > section > .content > *:last-child, .section-container.auto > .section > .content > *:last-child, |
| + | .section-container.vertical-tabs > section > .content > *:last-child, |
| + | .section-container.vertical-tabs > .section > .content > *:last-child, |
| + | .section-container.vertical-nav > section > .content > *:last-child, |
| + | .section-container.vertical-nav > .section > .content > *:last-child, |
| + | .section-container.horizontal-nav > section > .content > *:last-child, |
| + | .section-container.horizontal-nav > .section > .content > *:last-child, |
| + | .section-container.accordion > section > .content > *:last-child, |
| + | .section-container.accordion > .section > .content > *:last-child { |
| + | margin-bottom: 0; } |
| + | .section-container.auto > section > .content > *:first-child, .section-container.auto > .section > .content > *:first-child, |
| + | .section-container.vertical-tabs > section > .content > *:first-child, |
| + | .section-container.vertical-tabs > .section > .content > *:first-child, |
| + | .section-container.vertical-nav > section > .content > *:first-child, |
| + | .section-container.vertical-nav > .section > .content > *:first-child, |
| + | .section-container.horizontal-nav > section > .content > *:first-child, |
| + | .section-container.horizontal-nav > .section > .content > *:first-child, |
| + | .section-container.accordion > section > .content > *:first-child, |
| + | .section-container.accordion > .section > .content > *:first-child { |
| + | padding-top: 0; } |
| + | .section-container.auto > section > .content > *:last-child:not(.flex-video), .section-container.auto > .section > .content > *:last-child:not(.flex-video), |
| + | .section-container.vertical-tabs > section > .content > *:last-child:not(.flex-video), |
| + | .section-container.vertical-tabs > .section > .content > *:last-child:not(.flex-video), |
| + | .section-container.vertical-nav > section > .content > *:last-child:not(.flex-video), |
| + | .section-container.vertical-nav > .section > .content > *:last-child:not(.flex-video), |
| + | .section-container.horizontal-nav > section > .content > *:last-child:not(.flex-video), |
| + | .section-container.horizontal-nav > .section > .content > *:last-child:not(.flex-video), |
| + | .section-container.accordion > section > .content > *:last-child:not(.flex-video), |
| + | .section-container.accordion > .section > .content > *:last-child:not(.flex-video) { |
| + | padding-bottom: 0; } |
| + | .section-container.auto > section.active > .title, .section-container.auto > .section.active > .title, |
| + | .section-container.vertical-tabs > section.active > .title, |
| + | .section-container.vertical-tabs > .section.active > .title, |
| + | .section-container.vertical-nav > section.active > .title, |
| + | .section-container.vertical-nav > .section.active > .title, |
| + | .section-container.horizontal-nav > section.active > .title, |
| + | .section-container.horizontal-nav > .section.active > .title, |
| + | .section-container.accordion > section.active > .title, |
| + | .section-container.accordion > .section.active > .title { |
| + | background: #d5d5d5; } |
| + | .section-container.auto > section.active > .title a, .section-container.auto > .section.active > .title a, |
| + | .section-container.vertical-tabs > section.active > .title a, |
| + | .section-container.vertical-tabs > .section.active > .title a, |
| + | .section-container.vertical-nav > section.active > .title a, |
| + | .section-container.vertical-nav > .section.active > .title a, |
| + | .section-container.horizontal-nav > section.active > .title a, |
| + | .section-container.horizontal-nav > .section.active > .title a, |
| + | .section-container.accordion > section.active > .title a, |
| + | .section-container.accordion > .section.active > .title a { |
| + | color: #333333; } |
| + | .section-container.auto > section:not(.active), .section-container.auto > .section:not(.active), |
| + | .section-container.vertical-tabs > section:not(.active), |
| + | .section-container.vertical-tabs > .section:not(.active), |
| + | .section-container.vertical-nav > section:not(.active), |
| + | .section-container.vertical-nav > .section:not(.active), |
| + | .section-container.horizontal-nav > section:not(.active), |
| + | .section-container.horizontal-nav > .section:not(.active), |
| + | .section-container.accordion > section:not(.active), |
| + | .section-container.accordion > .section:not(.active) { |
| + | padding: 0 !important; } |
| + | .section-container.auto > section > .title, .section-container.auto > .section > .title, |
| + | .section-container.vertical-tabs > section > .title, |
| + | .section-container.vertical-tabs > .section > .title, |
| + | .section-container.vertical-nav > section > .title, |
| + | .section-container.vertical-nav > .section > .title, |
| + | .section-container.horizontal-nav > section > .title, |
| + | .section-container.horizontal-nav > .section > .title, |
| + | .section-container.accordion > section > .title, |
| + | .section-container.accordion > .section > .title { |
| + | border-top: none; } |
| + | |
| + | [data-section='tabs'], .section-container.tabs { |
| + | width: 100%; |
| + | position: relative; |
| + | display: block; |
| + | margin-bottom: 1.25em; } |
| + | [data-section='tabs']:not([data-section-resized]):not([data-section-small-style]), .section-container.tabs:not([data-section-resized]):not([data-section-small-style]) { |
| + | visibility: hidden; } |
| + | [data-section='tabs'] > section > [data-section-title], [data-section='tabs'] > section > .title, [data-section='tabs'] > .section > [data-section-title], [data-section='tabs'] > .section > .title, [data-section='tabs'] > [data-section-region] > [data-section-title], [data-section='tabs'] > [data-section-region] > .title, .section-container.tabs > section > [data-section-title], .section-container.tabs > section > .title, .section-container.tabs > .section > [data-section-title], .section-container.tabs > .section > .title, .section-container.tabs > [data-section-region] > [data-section-title], .section-container.tabs > [data-section-region] > .title { |
| + | margin-bottom: 0; } |
| + | [data-section='tabs'] > section > [data-section-title] a, [data-section='tabs'] > section > .title a, [data-section='tabs'] > .section > [data-section-title] a, [data-section='tabs'] > .section > .title a, [data-section='tabs'] > [data-section-region] > [data-section-title] a, [data-section='tabs'] > [data-section-region] > .title a, .section-container.tabs > section > [data-section-title] a, .section-container.tabs > section > .title a, .section-container.tabs > .section > [data-section-title] a, .section-container.tabs > .section > .title a, .section-container.tabs > [data-section-region] > [data-section-title] a, .section-container.tabs > [data-section-region] > .title a { |
| + | width: 100%; |
| + | display: inline-block; |
| + | white-space: nowrap; } |
| + | [data-section='tabs'] > section > [data-section-content], [data-section='tabs'] > section > .content, [data-section='tabs'] > .section > [data-section-content], [data-section='tabs'] > .section > .content, [data-section='tabs'] > [data-section-region] > [data-section-content], [data-section='tabs'] > [data-section-region] > .content, .section-container.tabs > section > [data-section-content], .section-container.tabs > section > .content, .section-container.tabs > .section > [data-section-content], .section-container.tabs > .section > .content, .section-container.tabs > [data-section-region] > [data-section-content], .section-container.tabs > [data-section-region] > .content { |
| + | display: none; } |
| + | [data-section='tabs'] > section.active > [data-section-content], [data-section='tabs'] > section.active > .content, [data-section='tabs'] > .section.active > [data-section-content], [data-section='tabs'] > .section.active > .content, [data-section='tabs'] > [data-section-region].active > [data-section-content], [data-section='tabs'] > [data-section-region].active > .content, .section-container.tabs > section.active > [data-section-content], .section-container.tabs > section.active > .content, .section-container.tabs > .section.active > [data-section-content], .section-container.tabs > .section.active > .content, .section-container.tabs > [data-section-region].active > [data-section-content], .section-container.tabs > [data-section-region].active > .content { |
| + | display: block; } |
| + | [data-section='tabs'] > section:not(.active), [data-section='tabs'] > .section:not(.active), [data-section='tabs'] > [data-section-region]:not(.active), .section-container.tabs > section:not(.active), .section-container.tabs > .section:not(.active), .section-container.tabs > [data-section-region]:not(.active) { |
| + | padding: 0 !important; } |
| + | [data-section='tabs'] > section > [data-section-title], [data-section='tabs'] > section > .title, [data-section='tabs'] > .section > [data-section-title], [data-section='tabs'] > .section > .title, [data-section='tabs'] > [data-section-region] > [data-section-title], [data-section='tabs'] > [data-section-region] > .title, .section-container.tabs > section > [data-section-title], .section-container.tabs > section > .title, .section-container.tabs > .section > [data-section-title], .section-container.tabs > .section > .title, .section-container.tabs > [data-section-region] > [data-section-title], .section-container.tabs > [data-section-region] > .title { |
| + | width: auto; |
| + | position: absolute; |
| + | top: 0; |
| + | left: 0; } |
| .section-container.tabs { | |
| - | border: 0; |
| - | position: relative; } |
| - | .section-container.tabs > section, .section-container.tabs > .section { |
| - | border: 0; |
| - | position: static; } |
| - | .section-container.tabs > section > .title, .section-container.tabs > .section > .title { |
| + | border: none; } |
| + | .section-container.tabs > section > .title, .section-container.tabs > .section > .title { |
| + | background-color: #efefef; |
| + | cursor: pointer; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.tabs > section > .title a, .section-container.tabs > .section > .title a { |
| + | padding: 0.9375em; |
| + | color: #333333; |
| + | font-size: 0.875em; |
| + | background: none; } |
| + | .section-container.tabs > section > .title:hover, .section-container.tabs > .section > .title:hover { |
| + | background-color: #e2e2e2; } |
| + | .section-container.tabs > section > .content, .section-container.tabs > .section > .content { |
| + | padding: 0.9375em; |
| + | background-color: white; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.tabs > section > .content > *:last-child, .section-container.tabs > .section > .content > *:last-child { |
| + | margin-bottom: 0; } |
| + | .section-container.tabs > section > .content > *:first-child, .section-container.tabs > .section > .content > *:first-child { |
| + | padding-top: 0; } |
| + | .section-container.tabs > section > .content > *:last-child:not(.flex-video), .section-container.tabs > .section > .content > *:last-child:not(.flex-video) { |
| + | padding-bottom: 0; } |
| + | .section-container.tabs > section.active > .title, .section-container.tabs > .section.active > .title { |
| + | background: white; } |
| + | .section-container.tabs > section.active > .title a, .section-container.tabs > .section.active > .title a { |
| + | color: #333333; } |
| + | .section-container.tabs > section:not(.active), .section-container.tabs > .section:not(.active) { |
| + | padding: 0 !important; } |
| + | .section-container.tabs > section.active > .title, .section-container.tabs > .section.active > .title { |
| + | border-bottom: 0; } |
| + | |
| + | @media only screen and (min-width: 768px) { |
| + | [data-section=''], [data-section='auto'], .section-container.auto { |
| + | width: 100%; |
| + | position: relative; |
| + | display: block; |
| + | margin-bottom: 1.25em; } |
| + | [data-section='']:not([data-section-resized]):not([data-section-small-style]), [data-section='auto']:not([data-section-resized]):not([data-section-small-style]), .section-container.auto:not([data-section-resized]):not([data-section-small-style]) { |
| + | visibility: hidden; } |
| + | [data-section=''] > section > [data-section-title], [data-section=''] > section > .title, [data-section=''] > .section > [data-section-title], [data-section=''] > .section > .title, [data-section=''] > [data-section-region] > [data-section-title], [data-section=''] > [data-section-region] > .title, [data-section='auto'] > section > [data-section-title], [data-section='auto'] > section > .title, [data-section='auto'] > .section > [data-section-title], [data-section='auto'] > .section > .title, [data-section='auto'] > [data-section-region] > [data-section-title], [data-section='auto'] > [data-section-region] > .title, .section-container.auto > section > [data-section-title], .section-container.auto > section > .title, .section-container.auto > .section > [data-section-title], .section-container.auto > .section > .title, .section-container.auto > [data-section-region] > [data-section-title], .section-container.auto > [data-section-region] > .title { |
| + | margin-bottom: 0; } |
| + | [data-section=''] > section > [data-section-title] a, [data-section=''] > section > .title a, [data-section=''] > .section > [data-section-title] a, [data-section=''] > .section > .title a, [data-section=''] > [data-section-region] > [data-section-title] a, [data-section=''] > [data-section-region] > .title a, [data-section='auto'] > section > [data-section-title] a, [data-section='auto'] > section > .title a, [data-section='auto'] > .section > [data-section-title] a, [data-section='auto'] > .section > .title a, [data-section='auto'] > [data-section-region] > [data-section-title] a, [data-section='auto'] > [data-section-region] > .title a, .section-container.auto > section > [data-section-title] a, .section-container.auto > section > .title a, .section-container.auto > .section > [data-section-title] a, .section-container.auto > .section > .title a, .section-container.auto > [data-section-region] > [data-section-title] a, .section-container.auto > [data-section-region] > .title a { |
| + | width: 100%; |
| + | display: inline-block; |
| + | white-space: nowrap; } |
| + | [data-section=''] > section > [data-section-content], [data-section=''] > section > .content, [data-section=''] > .section > [data-section-content], [data-section=''] > .section > .content, [data-section=''] > [data-section-region] > [data-section-content], [data-section=''] > [data-section-region] > .content, [data-section='auto'] > section > [data-section-content], [data-section='auto'] > section > .content, [data-section='auto'] > .section > [data-section-content], [data-section='auto'] > .section > .content, [data-section='auto'] > [data-section-region] > [data-section-content], [data-section='auto'] > [data-section-region] > .content, .section-container.auto > section > [data-section-content], .section-container.auto > section > .content, .section-container.auto > .section > [data-section-content], .section-container.auto > .section > .content, .section-container.auto > [data-section-region] > [data-section-content], .section-container.auto > [data-section-region] > .content { |
| + | display: none; } |
| + | [data-section=''] > section.active > [data-section-content], [data-section=''] > section.active > .content, [data-section=''] > .section.active > [data-section-content], [data-section=''] > .section.active > .content, [data-section=''] > [data-section-region].active > [data-section-content], [data-section=''] > [data-section-region].active > .content, [data-section='auto'] > section.active > [data-section-content], [data-section='auto'] > section.active > .content, [data-section='auto'] > .section.active > [data-section-content], [data-section='auto'] > .section.active > .content, [data-section='auto'] > [data-section-region].active > [data-section-content], [data-section='auto'] > [data-section-region].active > .content, .section-container.auto > section.active > [data-section-content], .section-container.auto > section.active > .content, .section-container.auto > .section.active > [data-section-content], .section-container.auto > .section.active > .content, .section-container.auto > [data-section-region].active > [data-section-content], .section-container.auto > [data-section-region].active > .content { |
| + | display: block; } |
| + | [data-section=''] > section:not(.active), [data-section=''] > .section:not(.active), [data-section=''] > [data-section-region]:not(.active), [data-section='auto'] > section:not(.active), [data-section='auto'] > .section:not(.active), [data-section='auto'] > [data-section-region]:not(.active), .section-container.auto > section:not(.active), .section-container.auto > .section:not(.active), .section-container.auto > [data-section-region]:not(.active) { |
| + | padding: 0 !important; } |
| + | [data-section=''] > section > [data-section-title], [data-section=''] > section > .title, [data-section=''] > .section > [data-section-title], [data-section=''] > .section > .title, [data-section=''] > [data-section-region] > [data-section-title], [data-section=''] > [data-section-region] > .title, [data-section='auto'] > section > [data-section-title], [data-section='auto'] > section > .title, [data-section='auto'] > .section > [data-section-title], [data-section='auto'] > .section > .title, [data-section='auto'] > [data-section-region] > [data-section-title], [data-section='auto'] > [data-section-region] > .title, .section-container.auto > section > [data-section-title], .section-container.auto > section > .title, .section-container.auto > .section > [data-section-title], .section-container.auto > .section > .title, .section-container.auto > [data-section-region] > [data-section-title], .section-container.auto > [data-section-region] > .title { |
| + | width: auto; |
| + | position: absolute; |
| + | top: 0; |
| + | left: 0; } |
| + | |
| + | .section-container.auto { |
| + | border: none; } |
| + | .section-container.auto > section > .title, .section-container.auto > .section > .title { |
| background-color: #efefef; | |
| cursor: pointer; | |
| - | margin-bottom: 0; } |
| - | .section-container.tabs > section > .title a, .section-container.tabs > .section > .title a { |
| + | border: solid 1px #cccccc; } |
| + | .section-container.auto > section > .title a, .section-container.auto > .section > .title a { |
| padding: 0.9375em; | |
| - | display: inline-block; |
| color: #333333; | |
| font-size: 0.875em; | |
| - | white-space: nowrap; } |
| - | .section-container.tabs > section > .title:hover, .section-container.tabs > .section > .title:hover { |
| + | background: none; } |
| + | .section-container.auto > section > .title:hover, .section-container.auto > .section > .title:hover { |
| background-color: #e2e2e2; } | |
| - | .section-container.tabs > section .content, .section-container.tabs > .section .content { |
| - | display: none; |
| + | .section-container.auto > section > .content, .section-container.auto > .section > .content { |
| padding: 0.9375em; | |
| - | background-color: white; } |
| - | .section-container.tabs > section .content > *:last-child, .section-container.tabs > .section .content > *:last-child { |
| + | background-color: white; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.auto > section > .content > *:last-child, .section-container.auto > .section > .content > *:last-child { |
| margin-bottom: 0; } | |
| - | .section-container.tabs > section .content > *:first-child, .section-container.tabs > .section .content > *:first-child { |
| + | .section-container.auto > section > .content > *:first-child, .section-container.auto > .section > .content > *:first-child { |
| padding-top: 0; } | |
| - | .section-container.tabs > section .content > *:last-child, .section-container.tabs > .section .content > *:last-child { |
| + | .section-container.auto > section > .content > *:last-child:not(.flex-video), .section-container.auto > .section > .content > *:last-child:not(.flex-video) { |
| padding-bottom: 0; } | |
| - | .section-container.tabs > section.active > .content, .section-container.tabs > .section.active > .content { |
| - | display: block; } |
| - | .section-container.tabs > section.active > .title, .section-container.tabs > .section.active > .title { |
| + | .section-container.auto > section.active > .title, .section-container.auto > .section.active > .title { |
| background: white; } | |
| - | .section-container.tabs > section.active > .title a, .section-container.tabs > .section.active > .title a { |
| + | .section-container.auto > section.active > .title a, .section-container.auto > .section.active > .title a { |
| color: #333333; } | |
| - | .section-container.tabs > section > .title, .section-container.tabs > .section > .title { |
| - | width: auto; |
| - | border: solid 1px #cccccc; |
| - | border-right: 0; |
| - | border-bottom: 0; |
| + | .section-container.auto > section:not(.active), .section-container.auto > .section:not(.active) { |
| + | padding: 0 !important; } |
| + | .section-container.auto > section.active > .title, .section-container.auto > .section.active > .title { |
| + | border-bottom: 0; } |
| + | |
| + | [data-section='vertical-tabs'], .section-container.vertical-tabs { |
| + | width: 100%; |
| + | position: relative; |
| + | display: block; |
| + | margin-bottom: 1.25em; } |
| + | [data-section='vertical-tabs']:not([data-section-resized]):not([data-section-small-style]), .section-container.vertical-tabs:not([data-section-resized]):not([data-section-small-style]) { |
| + | visibility: hidden; } |
| + | [data-section='vertical-tabs'][data-section-small-style], .section-container.vertical-tabs[data-section-small-style] { |
| + | width: 100% !important; } |
| + | [data-section='vertical-tabs'][data-section-small-style] > [data-section-region], [data-section='vertical-tabs'][data-section-small-style] > section, [data-section='vertical-tabs'][data-section-small-style] > .section, .section-container.vertical-tabs[data-section-small-style] > [data-section-region], .section-container.vertical-tabs[data-section-small-style] > section, .section-container.vertical-tabs[data-section-small-style] > .section { |
| + | padding: 0 !important; |
| + | margin: 0 !important; } |
| + | [data-section='vertical-tabs'][data-section-small-style] > [data-section-region] > [data-section-title], [data-section='vertical-tabs'][data-section-small-style] > [data-section-region] > .title, [data-section='vertical-tabs'][data-section-small-style] > section > [data-section-title], [data-section='vertical-tabs'][data-section-small-style] > section > .title, [data-section='vertical-tabs'][data-section-small-style] > .section > [data-section-title], [data-section='vertical-tabs'][data-section-small-style] > .section > .title, .section-container.vertical-tabs[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.vertical-tabs[data-section-small-style] > [data-section-region] > .title, .section-container.vertical-tabs[data-section-small-style] > section > [data-section-title], .section-container.vertical-tabs[data-section-small-style] > section > .title, .section-container.vertical-tabs[data-section-small-style] > .section > [data-section-title], .section-container.vertical-tabs[data-section-small-style] > .section > .title { |
| + | width: 100% !important; } |
| + | [data-section='vertical-tabs'] > section > [data-section-title], [data-section='vertical-tabs'] > section > .title, [data-section='vertical-tabs'] > .section > [data-section-title], [data-section='vertical-tabs'] > .section > .title, [data-section='vertical-tabs'] > [data-section-region] > [data-section-title], [data-section='vertical-tabs'] > [data-section-region] > .title, .section-container.vertical-tabs > section > [data-section-title], .section-container.vertical-tabs > section > .title, .section-container.vertical-tabs > .section > [data-section-title], .section-container.vertical-tabs > .section > .title, .section-container.vertical-tabs > [data-section-region] > [data-section-title], .section-container.vertical-tabs > [data-section-region] > .title { |
| + | margin-bottom: 0; } |
| + | [data-section='vertical-tabs'] > section > [data-section-title] a, [data-section='vertical-tabs'] > section > .title a, [data-section='vertical-tabs'] > .section > [data-section-title] a, [data-section='vertical-tabs'] > .section > .title a, [data-section='vertical-tabs'] > [data-section-region] > [data-section-title] a, [data-section='vertical-tabs'] > [data-section-region] > .title a, .section-container.vertical-tabs > section > [data-section-title] a, .section-container.vertical-tabs > section > .title a, .section-container.vertical-tabs > .section > [data-section-title] a, .section-container.vertical-tabs > .section > .title a, .section-container.vertical-tabs > [data-section-region] > [data-section-title] a, .section-container.vertical-tabs > [data-section-region] > .title a { |
| + | width: 100%; |
| + | display: inline-block; |
| + | white-space: nowrap; } |
| + | [data-section='vertical-tabs'] > section > [data-section-content], [data-section='vertical-tabs'] > section > .content, [data-section='vertical-tabs'] > .section > [data-section-content], [data-section='vertical-tabs'] > .section > .content, [data-section='vertical-tabs'] > [data-section-region] > [data-section-content], [data-section='vertical-tabs'] > [data-section-region] > .content, .section-container.vertical-tabs > section > [data-section-content], .section-container.vertical-tabs > section > .content, .section-container.vertical-tabs > .section > [data-section-content], .section-container.vertical-tabs > .section > .content, .section-container.vertical-tabs > [data-section-region] > [data-section-content], .section-container.vertical-tabs > [data-section-region] > .content { |
| + | display: none; } |
| + | [data-section='vertical-tabs'] > section.active > [data-section-content], [data-section='vertical-tabs'] > section.active > .content, [data-section='vertical-tabs'] > .section.active > [data-section-content], [data-section='vertical-tabs'] > .section.active > .content, [data-section='vertical-tabs'] > [data-section-region].active > [data-section-content], [data-section='vertical-tabs'] > [data-section-region].active > .content, .section-container.vertical-tabs > section.active > [data-section-content], .section-container.vertical-tabs > section.active > .content, .section-container.vertical-tabs > .section.active > [data-section-content], .section-container.vertical-tabs > .section.active > .content, .section-container.vertical-tabs > [data-section-region].active > [data-section-content], .section-container.vertical-tabs > [data-section-region].active > .content { |
| + | display: block; } |
| + | [data-section='vertical-tabs'] > section:not(.active), [data-section='vertical-tabs'] > .section:not(.active), [data-section='vertical-tabs'] > [data-section-region]:not(.active), .section-container.vertical-tabs > section:not(.active), .section-container.vertical-tabs > .section:not(.active), .section-container.vertical-tabs > [data-section-region]:not(.active) { |
| + | padding: 0 !important; } |
| + | [data-section='vertical-tabs'] > section > [data-section-title], [data-section='vertical-tabs'] > section > .title, [data-section='vertical-tabs'] > .section > [data-section-title], [data-section='vertical-tabs'] > .section > .title, [data-section='vertical-tabs'] > [data-section-region] > [data-section-title], [data-section='vertical-tabs'] > [data-section-region] > .title, .section-container.vertical-tabs > section > [data-section-title], .section-container.vertical-tabs > section > .title, .section-container.vertical-tabs > .section > [data-section-title], .section-container.vertical-tabs > .section > .title, .section-container.vertical-tabs > [data-section-region] > [data-section-title], .section-container.vertical-tabs > [data-section-region] > .title { |
| position: absolute; | |
| top: 0; | |
| - | z-index: 1; } |
| - | .section-container.tabs > section > .title a, .section-container.tabs > .section > .title a { |
| - | width: 100%; } |
| - | .section-container.tabs > section:last-child .title, .section-container.tabs > .section:last-child .title { |
| - | border-right: solid 1px #cccccc; } |
| - | .section-container.tabs > section .content, .section-container.tabs > .section .content { |
| - | border: solid 1px #cccccc; |
| - | position: absolute; |
| - | z-index: 10; |
| - | display: none; |
| - | top: -1px; } |
| - | .section-container.tabs > section.active > .title, .section-container.tabs > .section.active > .title { |
| - | z-index: 11; |
| - | border-bottom: 0; |
| - | background-color: white; } |
| - | .section-container.tabs > section.active > .content, .section-container.tabs > .section.active > .content { |
| - | position: relative; } |
| + | left: 0; |
| + | width: 12.5em; } |
| + | [data-section='vertical-tabs'] > section.active, [data-section='vertical-tabs'] > .section.active, [data-section='vertical-tabs'] > [data-section-region].active, .section-container.vertical-tabs > section.active, .section-container.vertical-tabs > .section.active, .section-container.vertical-tabs > [data-section-region].active { |
| + | padding-left: 12.5em; } |
| + | [data-section='vertical-tabs'] > section.active > [data-section-title], [data-section='vertical-tabs'] > section.active > .title, [data-section='vertical-tabs'] > .section.active > [data-section-title], [data-section='vertical-tabs'] > .section.active > .title, [data-section='vertical-tabs'] > [data-section-region].active > [data-section-title], [data-section='vertical-tabs'] > [data-section-region].active > .title, .section-container.vertical-tabs > section.active > [data-section-title], .section-container.vertical-tabs > section.active > .title, .section-container.vertical-tabs > .section.active > [data-section-title], .section-container.vertical-tabs > .section.active > .title, .section-container.vertical-tabs > [data-section-region].active > [data-section-title], .section-container.vertical-tabs > [data-section-region].active > .title { |
| + | width: 12.5em; } |
| - | @media only screen and (min-width: 768px) { |
| - | .section-container.auto { |
| - | border: 0; |
| - | position: relative; } |
| - | .section-container.auto > section, .section-container.auto > .section { |
| - | border: 0; |
| - | position: static; } |
| - | .section-container.auto > section > .title, .section-container.auto > .section > .title { |
| - | background-color: #efefef; |
| - | cursor: pointer; |
| + | .section-container.vertical-tabs { |
| + | border: none; } |
| + | .section-container.vertical-tabs > section > .title, .section-container.vertical-tabs > .section > .title { |
| + | background-color: #efefef; |
| + | cursor: pointer; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.vertical-tabs > section > .title a, .section-container.vertical-tabs > .section > .title a { |
| + | padding: 0.9375em; |
| + | color: #333333; |
| + | font-size: 0.875em; |
| + | background: none; } |
| + | .section-container.vertical-tabs > section > .title:hover, .section-container.vertical-tabs > .section > .title:hover { |
| + | background-color: #e2e2e2; } |
| + | .section-container.vertical-tabs > section > .content, .section-container.vertical-tabs > .section > .content { |
| + | padding: 0.9375em; |
| + | background-color: white; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.vertical-tabs > section > .content > *:last-child, .section-container.vertical-tabs > .section > .content > *:last-child { |
| + | margin-bottom: 0; } |
| + | .section-container.vertical-tabs > section > .content > *:first-child, .section-container.vertical-tabs > .section > .content > *:first-child { |
| + | padding-top: 0; } |
| + | .section-container.vertical-tabs > section > .content > *:last-child:not(.flex-video), .section-container.vertical-tabs > .section > .content > *:last-child:not(.flex-video) { |
| + | padding-bottom: 0; } |
| + | .section-container.vertical-tabs > section.active > .title, .section-container.vertical-tabs > .section.active > .title { |
| + | background: #d5d5d5; } |
| + | .section-container.vertical-tabs > section.active > .title a, .section-container.vertical-tabs > .section.active > .title a { |
| + | color: #333333; } |
| + | .section-container.vertical-tabs > section:not(.active), .section-container.vertical-tabs > .section:not(.active) { |
| + | padding: 0 !important; } |
| + | .section-container.vertical-tabs > section.active, .section-container.vertical-tabs > .section.active { |
| + | padding-left: 12.4375em; } |
| + | .section-container.vertical-tabs > section.active > .title, .section-container.vertical-tabs > .section.active > .title { |
| + | background-color: #d5d5d5; } |
| + | |
| + | [data-section='vertical-nav'], .section-container.vertical-nav { |
| + | width: 100%; |
| + | position: relative; |
| + | display: block; |
| + | margin-bottom: 1.25em; } |
| + | [data-section='vertical-nav']:not([data-section-resized]):not([data-section-small-style]), .section-container.vertical-nav:not([data-section-resized]):not([data-section-small-style]) { |
| + | visibility: hidden; } |
| + | [data-section='vertical-nav'][data-section-small-style], .section-container.vertical-nav[data-section-small-style] { |
| + | width: 100% !important; } |
| + | [data-section='vertical-nav'][data-section-small-style] > [data-section-region], [data-section='vertical-nav'][data-section-small-style] > section, [data-section='vertical-nav'][data-section-small-style] > .section, .section-container.vertical-nav[data-section-small-style] > [data-section-region], .section-container.vertical-nav[data-section-small-style] > section, .section-container.vertical-nav[data-section-small-style] > .section { |
| + | padding: 0 !important; |
| + | margin: 0 !important; } |
| + | [data-section='vertical-nav'][data-section-small-style] > [data-section-region] > [data-section-title], [data-section='vertical-nav'][data-section-small-style] > [data-section-region] > .title, [data-section='vertical-nav'][data-section-small-style] > section > [data-section-title], [data-section='vertical-nav'][data-section-small-style] > section > .title, [data-section='vertical-nav'][data-section-small-style] > .section > [data-section-title], [data-section='vertical-nav'][data-section-small-style] > .section > .title, .section-container.vertical-nav[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.vertical-nav[data-section-small-style] > [data-section-region] > .title, .section-container.vertical-nav[data-section-small-style] > section > [data-section-title], .section-container.vertical-nav[data-section-small-style] > section > .title, .section-container.vertical-nav[data-section-small-style] > .section > [data-section-title], .section-container.vertical-nav[data-section-small-style] > .section > .title { |
| + | width: 100% !important; } |
| + | [data-section='vertical-nav'] > section, [data-section='vertical-nav'] > .section, [data-section='vertical-nav'] > [data-section-region], .section-container.vertical-nav > section, .section-container.vertical-nav > .section, .section-container.vertical-nav > [data-section-region] { |
| + | position: relative; |
| + | display: inline-block; } |
| + | [data-section='vertical-nav'] > section > [data-section-title], [data-section='vertical-nav'] > section > .title, [data-section='vertical-nav'] > .section > [data-section-title], [data-section='vertical-nav'] > .section > .title, [data-section='vertical-nav'] > [data-section-region] > [data-section-title], [data-section='vertical-nav'] > [data-section-region] > .title, .section-container.vertical-nav > section > [data-section-title], .section-container.vertical-nav > section > .title, .section-container.vertical-nav > .section > [data-section-title], .section-container.vertical-nav > .section > .title, .section-container.vertical-nav > [data-section-region] > [data-section-title], .section-container.vertical-nav > [data-section-region] > .title { |
| margin-bottom: 0; } | |
| - | .section-container.auto > section > .title a, .section-container.auto > .section > .title a { |
| - | padding: 0.9375em; |
| + | [data-section='vertical-nav'] > section > [data-section-title] a, [data-section='vertical-nav'] > section > .title a, [data-section='vertical-nav'] > .section > [data-section-title] a, [data-section='vertical-nav'] > .section > .title a, [data-section='vertical-nav'] > [data-section-region] > [data-section-title] a, [data-section='vertical-nav'] > [data-section-region] > .title a, .section-container.vertical-nav > section > [data-section-title] a, .section-container.vertical-nav > section > .title a, .section-container.vertical-nav > .section > [data-section-title] a, .section-container.vertical-nav > .section > .title a, .section-container.vertical-nav > [data-section-region] > [data-section-title] a, .section-container.vertical-nav > [data-section-region] > .title a { |
| + | width: 100%; |
| display: inline-block; | |
| - | color: #333333; |
| - | font-size: 0.875em; |
| white-space: nowrap; } | |
| - | .section-container.auto > section > .title:hover, .section-container.auto > .section > .title:hover { |
| - | background-color: #e2e2e2; } |
| - | .section-container.auto > section .content, .section-container.auto > .section .content { |
| - | display: none; |
| - | padding: 0.9375em; |
| - | background-color: white; } |
| - | .section-container.auto > section .content > *:last-child, .section-container.auto > .section .content > *:last-child { |
| - | margin-bottom: 0; } |
| - | .section-container.auto > section .content > *:first-child, .section-container.auto > .section .content > *:first-child { |
| - | padding-top: 0; } |
| - | .section-container.auto > section .content > *:last-child, .section-container.auto > .section .content > *:last-child { |
| - | padding-bottom: 0; } |
| - | .section-container.auto > section.active > .content, .section-container.auto > .section.active > .content { |
| + | [data-section='vertical-nav'] > section > [data-section-content], [data-section='vertical-nav'] > section > .content, [data-section='vertical-nav'] > .section > [data-section-content], [data-section='vertical-nav'] > .section > .content, [data-section='vertical-nav'] > [data-section-region] > [data-section-content], [data-section='vertical-nav'] > [data-section-region] > .content, .section-container.vertical-nav > section > [data-section-content], .section-container.vertical-nav > section > .content, .section-container.vertical-nav > .section > [data-section-content], .section-container.vertical-nav > .section > .content, .section-container.vertical-nav > [data-section-region] > [data-section-content], .section-container.vertical-nav > [data-section-region] > .content { |
| + | display: none; } |
| + | [data-section='vertical-nav'] > section.active > [data-section-content], [data-section='vertical-nav'] > section.active > .content, [data-section='vertical-nav'] > .section.active > [data-section-content], [data-section='vertical-nav'] > .section.active > .content, [data-section='vertical-nav'] > [data-section-region].active > [data-section-content], [data-section='vertical-nav'] > [data-section-region].active > .content, .section-container.vertical-nav > section.active > [data-section-content], .section-container.vertical-nav > section.active > .content, .section-container.vertical-nav > .section.active > [data-section-content], .section-container.vertical-nav > .section.active > .content, .section-container.vertical-nav > [data-section-region].active > [data-section-content], .section-container.vertical-nav > [data-section-region].active > .content { |
| display: block; } | |
| - | .section-container.auto > section.active > .title, .section-container.auto > .section.active > .title { |
| - | background: white; } |
| - | .section-container.auto > section.active > .title a, .section-container.auto > .section.active > .title a { |
| - | color: #333333; } |
| - | .section-container.auto > section > .title, .section-container.auto > .section > .title { |
| - | width: auto; |
| - | border: solid 1px #cccccc; |
| - | border-right: 0; |
| - | border-bottom: 0; |
| + | [data-section='vertical-nav'] > section:not(.active), [data-section='vertical-nav'] > .section:not(.active), [data-section='vertical-nav'] > [data-section-region]:not(.active), .section-container.vertical-nav > section:not(.active), .section-container.vertical-nav > .section:not(.active), .section-container.vertical-nav > [data-section-region]:not(.active) { |
| + | padding: 0 !important; } |
| + | [data-section='vertical-nav'] > section > [data-section-title], [data-section='vertical-nav'] > section > .title, [data-section='vertical-nav'] > .section > [data-section-title], [data-section='vertical-nav'] > .section > .title, [data-section='vertical-nav'] > [data-section-region] > [data-section-title], [data-section='vertical-nav'] > [data-section-region] > .title, .section-container.vertical-nav > section > [data-section-title], .section-container.vertical-nav > section > .title, .section-container.vertical-nav > .section > [data-section-title], .section-container.vertical-nav > .section > .title, .section-container.vertical-nav > [data-section-region] > [data-section-title], .section-container.vertical-nav > [data-section-region] > .title { |
| + | position: static; |
| + | width: auto; } |
| + | [data-section='vertical-nav'] > section > [data-section-title] a, [data-section='vertical-nav'] > section > .title a, [data-section='vertical-nav'] > .section > [data-section-title] a, [data-section='vertical-nav'] > .section > .title a, [data-section='vertical-nav'] > [data-section-region] > [data-section-title] a, [data-section='vertical-nav'] > [data-section-region] > .title a, .section-container.vertical-nav > section > [data-section-title] a, .section-container.vertical-nav > section > .title a, .section-container.vertical-nav > .section > [data-section-title] a, .section-container.vertical-nav > .section > .title a, .section-container.vertical-nav > [data-section-region] > [data-section-title] a, .section-container.vertical-nav > [data-section-region] > .title a { |
| + | display: block; } |
| + | [data-section='vertical-nav'] > section > [data-section-content], [data-section='vertical-nav'] > section > .content, [data-section='vertical-nav'] > .section > [data-section-content], [data-section='vertical-nav'] > .section > .content, [data-section='vertical-nav'] > [data-section-region] > [data-section-content], [data-section='vertical-nav'] > [data-section-region] > .content, .section-container.vertical-nav > section > [data-section-content], .section-container.vertical-nav > section > .content, .section-container.vertical-nav > .section > [data-section-content], .section-container.vertical-nav > .section > .content, .section-container.vertical-nav > [data-section-region] > [data-section-content], .section-container.vertical-nav > [data-section-region] > .content { |
| position: absolute; | |
| top: 0; | |
| - | z-index: 1; } |
| - | .section-container.auto > section > .title a, .section-container.auto > .section > .title a { |
| - | width: 100%; } |
| - | .section-container.auto > section:last-child .title, .section-container.auto > .section:last-child .title { |
| - | border-right: solid 1px #cccccc; } |
| - | .section-container.auto > section .content, .section-container.auto > .section .content { |
| - | border: solid 1px #cccccc; |
| - | position: absolute; |
| - | z-index: 10; |
| - | display: none; |
| - | top: -1px; } |
| - | .section-container.auto > section.active > .title, .section-container.auto > .section.active > .title { |
| - | z-index: 11; |
| - | border-bottom: 0; |
| - | background-color: white; } |
| - | .section-container.auto > section.active > .content, .section-container.auto > .section.active > .content { |
| - | position: relative; } |
| - | |
| - | .section-container.accordion .section { |
| - | padding-top: 0 !important; } |
| + | left: 0; |
| + | z-index: 999; |
| + | min-width: 12.5em; } |
| - | .section-container.vertical-tabs { |
| - | border: 1px solid #cccccc; |
| - | position: relative; } |
| - | .section-container.vertical-tabs section, |
| - | .section-container.vertical-tabs .section { |
| - | padding-top: 0 !important; |
| - | border: 0; |
| - | position: static; } |
| - | .section-container.vertical-tabs section > .title, |
| - | .section-container.vertical-tabs .section > .title { |
| - | background-color: #efefef; |
| - | cursor: pointer; |
| - | margin-bottom: 0; } |
| - | .section-container.vertical-tabs section > .title a, |
| - | .section-container.vertical-tabs .section > .title a { |
| - | padding: 0.9375em; |
| - | display: inline-block; |
| - | color: #333333; |
| - | font-size: 0.875em; |
| - | white-space: nowrap; } |
| - | .section-container.vertical-tabs section > .title:hover, |
| - | .section-container.vertical-tabs .section > .title:hover { |
| - | background-color: #e2e2e2; } |
| - | .section-container.vertical-tabs section .content, |
| - | .section-container.vertical-tabs .section .content { |
| - | display: none; |
| + | .section-container.vertical-nav { |
| + | border: none; } |
| + | .section-container.vertical-nav > section > .title, .section-container.vertical-nav > .section > .title { |
| + | background-color: #efefef; |
| + | cursor: pointer; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.vertical-nav > section > .title a, .section-container.vertical-nav > .section > .title a { |
| padding: 0.9375em; | |
| - | background-color: white; } |
| - | .section-container.vertical-tabs section .content > *:last-child, |
| - | .section-container.vertical-tabs .section .content > *:last-child { |
| - | margin-bottom: 0; } |
| - | .section-container.vertical-tabs section .content > *:first-child, |
| - | .section-container.vertical-tabs .section .content > *:first-child { |
| - | padding-top: 0; } |
| - | .section-container.vertical-tabs section .content > *:last-child, |
| - | .section-container.vertical-tabs .section .content > *:last-child { |
| - | padding-bottom: 0; } |
| - | .section-container.vertical-tabs section.active > .content, |
| - | .section-container.vertical-tabs .section.active > .content { |
| - | display: block; } |
| - | .section-container.vertical-tabs section.active > .title, |
| - | .section-container.vertical-tabs .section.active > .title { |
| - | background: #d5d5d5; } |
| - | .section-container.vertical-tabs section.active > .title a, |
| - | .section-container.vertical-tabs .section.active > .title a { |
| - | color: #333333; } |
| - | .section-container.vertical-tabs section > .title, |
| - | .section-container.vertical-tabs .section > .title { |
| - | position: absolute; |
| - | border-top: solid 1px #cccccc; |
| - | width: 12.5em; } |
| - | .section-container.vertical-tabs section:first-child .title, |
| - | .section-container.vertical-tabs .section:first-child .title { |
| - | border-top: 0; } |
| - | .section-container.vertical-tabs section .content, |
| - | .section-container.vertical-tabs .section .content { |
| - | display: block; |
| - | position: relative; |
| - | left: 12.5em; |
| - | border-left: solid 1px #cccccc; |
| - | z-index: 10; } |
| - | .section-container.vertical-tabs section.active > .title, |
| - | .section-container.vertical-tabs .section.active > .title { |
| - | background-color: #d5d5d5; |
| - | width: 12.5625em; |
| - | border-right: solid 0 transparent; |
| - | z-index: 11; } |
| - | .section-container.vertical-tabs section.active:last-child .title, |
| - | .section-container.vertical-tabs .section.active:last-child .title { |
| - | border-bottom: 0; } |
| + | color: #333333; |
| + | font-size: 0.875em; |
| + | background: none; } |
| + | .section-container.vertical-nav > section > .title:hover, .section-container.vertical-nav > .section > .title:hover { |
| + | background-color: #e2e2e2; } |
| + | .section-container.vertical-nav > section > .content, .section-container.vertical-nav > .section > .content { |
| + | padding: 0.9375em; |
| + | background-color: white; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.vertical-nav > section > .content > *:last-child, .section-container.vertical-nav > .section > .content > *:last-child { |
| + | margin-bottom: 0; } |
| + | .section-container.vertical-nav > section > .content > *:first-child, .section-container.vertical-nav > .section > .content > *:first-child { |
| + | padding-top: 0; } |
| + | .section-container.vertical-nav > section > .content > *:last-child:not(.flex-video), .section-container.vertical-nav > .section > .content > *:last-child:not(.flex-video) { |
| + | padding-bottom: 0; } |
| + | .section-container.vertical-nav > section.active > .title, .section-container.vertical-nav > .section.active > .title { |
| + | background: #d5d5d5; } |
| + | .section-container.vertical-nav > section.active > .title a, .section-container.vertical-nav > .section.active > .title a { |
| + | color: #333333; } |
| + | .section-container.vertical-nav > section:not(.active), .section-container.vertical-nav > .section:not(.active) { |
| + | padding: 0 !important; } |
| - | .section-container.vertical-nav { |
| - | border: 0; |
| - | position: relative; } |
| - | .section-container.vertical-nav > section, .section-container.vertical-nav > .section { |
| - | padding-top: 0 !important; |
| - | position: relative; } |
| - | .section-container.vertical-nav > section > .title, .section-container.vertical-nav > .section > .title { |
| - | background-color: #efefef; |
| - | cursor: pointer; |
| + | [data-section='horizontal-nav'], .section-container.horizontal-nav { |
| + | width: 100%; |
| + | position: relative; |
| + | display: block; |
| + | margin-bottom: 1.25em; } |
| + | [data-section='horizontal-nav']:not([data-section-resized]):not([data-section-small-style]), .section-container.horizontal-nav:not([data-section-resized]):not([data-section-small-style]) { |
| + | visibility: hidden; } |
| + | [data-section='horizontal-nav'][data-section-small-style], .section-container.horizontal-nav[data-section-small-style] { |
| + | width: 100% !important; } |
| + | [data-section='horizontal-nav'][data-section-small-style] > [data-section-region], [data-section='horizontal-nav'][data-section-small-style] > section, [data-section='horizontal-nav'][data-section-small-style] > .section, .section-container.horizontal-nav[data-section-small-style] > [data-section-region], .section-container.horizontal-nav[data-section-small-style] > section, .section-container.horizontal-nav[data-section-small-style] > .section { |
| + | padding: 0 !important; |
| + | margin: 0 !important; } |
| + | [data-section='horizontal-nav'][data-section-small-style] > [data-section-region] > [data-section-title], [data-section='horizontal-nav'][data-section-small-style] > [data-section-region] > .title, [data-section='horizontal-nav'][data-section-small-style] > section > [data-section-title], [data-section='horizontal-nav'][data-section-small-style] > section > .title, [data-section='horizontal-nav'][data-section-small-style] > .section > [data-section-title], [data-section='horizontal-nav'][data-section-small-style] > .section > .title, .section-container.horizontal-nav[data-section-small-style] > [data-section-region] > [data-section-title], .section-container.horizontal-nav[data-section-small-style] > [data-section-region] > .title, .section-container.horizontal-nav[data-section-small-style] > section > [data-section-title], .section-container.horizontal-nav[data-section-small-style] > section > .title, .section-container.horizontal-nav[data-section-small-style] > .section > [data-section-title], .section-container.horizontal-nav[data-section-small-style] > .section > .title { |
| + | width: 100% !important; } |
| + | [data-section='horizontal-nav'] > section, [data-section='horizontal-nav'] > .section, [data-section='horizontal-nav'] > [data-section-region], .section-container.horizontal-nav > section, .section-container.horizontal-nav > .section, .section-container.horizontal-nav > [data-section-region] { |
| + | position: relative; |
| + | float: left; } |
| + | [data-section='horizontal-nav'] > section > [data-section-title], [data-section='horizontal-nav'] > section > .title, [data-section='horizontal-nav'] > .section > [data-section-title], [data-section='horizontal-nav'] > .section > .title, [data-section='horizontal-nav'] > [data-section-region] > [data-section-title], [data-section='horizontal-nav'] > [data-section-region] > .title, .section-container.horizontal-nav > section > [data-section-title], .section-container.horizontal-nav > section > .title, .section-container.horizontal-nav > .section > [data-section-title], .section-container.horizontal-nav > .section > .title, .section-container.horizontal-nav > [data-section-region] > [data-section-title], .section-container.horizontal-nav > [data-section-region] > .title { |
| margin-bottom: 0; } | |
| - | .section-container.vertical-nav > section > .title a, .section-container.vertical-nav > .section > .title a { |
| - | padding: 0.9375em; |
| + | [data-section='horizontal-nav'] > section > [data-section-title] a, [data-section='horizontal-nav'] > section > .title a, [data-section='horizontal-nav'] > .section > [data-section-title] a, [data-section='horizontal-nav'] > .section > .title a, [data-section='horizontal-nav'] > [data-section-region] > [data-section-title] a, [data-section='horizontal-nav'] > [data-section-region] > .title a, .section-container.horizontal-nav > section > [data-section-title] a, .section-container.horizontal-nav > section > .title a, .section-container.horizontal-nav > .section > [data-section-title] a, .section-container.horizontal-nav > .section > .title a, .section-container.horizontal-nav > [data-section-region] > [data-section-title] a, .section-container.horizontal-nav > [data-section-region] > .title a { |
| + | width: 100%; |
| display: inline-block; | |
| - | color: #333333; |
| - | font-size: 0.875em; |
| white-space: nowrap; } | |
| - | .section-container.vertical-nav > section > .title:hover, .section-container.vertical-nav > .section > .title:hover { |
| - | background-color: #e2e2e2; } |
| - | .section-container.vertical-nav > section .content, .section-container.vertical-nav > .section .content { |
| - | display: none; |
| - | padding: 0.9375em; |
| - | background-color: white; } |
| - | .section-container.vertical-nav > section .content > *:last-child, .section-container.vertical-nav > .section .content > *:last-child { |
| - | margin-bottom: 0; } |
| - | .section-container.vertical-nav > section .content > *:first-child, .section-container.vertical-nav > .section .content > *:first-child { |
| - | padding-top: 0; } |
| - | .section-container.vertical-nav > section .content > *:last-child, .section-container.vertical-nav > .section .content > *:last-child { |
| - | padding-bottom: 0; } |
| - | .section-container.vertical-nav > section.active > .content, .section-container.vertical-nav > .section.active > .content { |
| - | display: block; } |
| - | .section-container.vertical-nav > section.active > .title, .section-container.vertical-nav > .section.active > .title { |
| - | background: #d5d5d5; } |
| - | .section-container.vertical-nav > section.active > .title a, .section-container.vertical-nav > .section.active > .title a { |
| - | color: #333333; } |
| - | .section-container.vertical-nav > section > .title, .section-container.vertical-nav > .section > .title { |
| - | border-top: none; |
| - | border: solid 1px #cccccc; } |
| - | .section-container.vertical-nav > section > .title a, .section-container.vertical-nav > .section > .title a { |
| - | display: block; |
| - | width: 100%; } |
| - | .section-container.vertical-nav > section .content, .section-container.vertical-nav > .section .content { |
| + | [data-section='horizontal-nav'] > section > [data-section-content], [data-section='horizontal-nav'] > section > .content, [data-section='horizontal-nav'] > .section > [data-section-content], [data-section='horizontal-nav'] > .section > .content, [data-section='horizontal-nav'] > [data-section-region] > [data-section-content], [data-section='horizontal-nav'] > [data-section-region] > .content, .section-container.horizontal-nav > section > [data-section-content], .section-container.horizontal-nav > section > .content, .section-container.horizontal-nav > .section > [data-section-content], .section-container.horizontal-nav > .section > .content, .section-container.horizontal-nav > [data-section-region] > [data-section-content], .section-container.horizontal-nav > [data-section-region] > .content { |
| display: none; } | |
| - | .section-container.vertical-nav > section:first-child .title, .section-container.vertical-nav > .section:first-child .title { |
| - | border-bottom: none; } |
| - | .section-container.vertical-nav > section.active > .content, .section-container.vertical-nav > .section.active > .content { |
| - | display: block; |
| + | [data-section='horizontal-nav'] > section.active > [data-section-content], [data-section='horizontal-nav'] > section.active > .content, [data-section='horizontal-nav'] > .section.active > [data-section-content], [data-section='horizontal-nav'] > .section.active > .content, [data-section='horizontal-nav'] > [data-section-region].active > [data-section-content], [data-section='horizontal-nav'] > [data-section-region].active > .content, .section-container.horizontal-nav > section.active > [data-section-content], .section-container.horizontal-nav > section.active > .content, .section-container.horizontal-nav > .section.active > [data-section-content], .section-container.horizontal-nav > .section.active > .content, .section-container.horizontal-nav > [data-section-region].active > [data-section-content], .section-container.horizontal-nav > [data-section-region].active > .content { |
| + | display: block; } |
| + | [data-section='horizontal-nav'] > section:not(.active), [data-section='horizontal-nav'] > .section:not(.active), [data-section='horizontal-nav'] > [data-section-region]:not(.active), .section-container.horizontal-nav > section:not(.active), .section-container.horizontal-nav > .section:not(.active), .section-container.horizontal-nav > [data-section-region]:not(.active) { |
| + | padding: 0 !important; } |
| + | [data-section='horizontal-nav'] > section > [data-section-title], [data-section='horizontal-nav'] > section > .title, [data-section='horizontal-nav'] > .section > [data-section-title], [data-section='horizontal-nav'] > .section > .title, [data-section='horizontal-nav'] > [data-section-region] > [data-section-title], [data-section='horizontal-nav'] > [data-section-region] > .title, .section-container.horizontal-nav > section > [data-section-title], .section-container.horizontal-nav > section > .title, .section-container.horizontal-nav > .section > [data-section-title], .section-container.horizontal-nav > .section > .title, .section-container.horizontal-nav > [data-section-region] > [data-section-title], .section-container.horizontal-nav > [data-section-region] > .title { |
| + | position: static; |
| + | width: auto; } |
| + | [data-section='horizontal-nav'] > section > [data-section-title] a, [data-section='horizontal-nav'] > section > .title a, [data-section='horizontal-nav'] > .section > [data-section-title] a, [data-section='horizontal-nav'] > .section > .title a, [data-section='horizontal-nav'] > [data-section-region] > [data-section-title] a, [data-section='horizontal-nav'] > [data-section-region] > .title a, .section-container.horizontal-nav > section > [data-section-title] a, .section-container.horizontal-nav > section > .title a, .section-container.horizontal-nav > .section > [data-section-title] a, .section-container.horizontal-nav > .section > .title a, .section-container.horizontal-nav > [data-section-region] > [data-section-title] a, .section-container.horizontal-nav > [data-section-region] > .title a { |
| + | display: block; } |
| + | [data-section='horizontal-nav'] > section > [data-section-content], [data-section='horizontal-nav'] > section > .content, [data-section='horizontal-nav'] > .section > [data-section-content], [data-section='horizontal-nav'] > .section > .content, [data-section='horizontal-nav'] > [data-section-region] > [data-section-content], [data-section='horizontal-nav'] > [data-section-region] > .content, .section-container.horizontal-nav > section > [data-section-content], .section-container.horizontal-nav > section > .content, .section-container.horizontal-nav > .section > [data-section-content], .section-container.horizontal-nav > .section > .content, .section-container.horizontal-nav > [data-section-region] > [data-section-content], .section-container.horizontal-nav > [data-section-region] > .content { |
| + | width: auto; |
| position: absolute; | |
| - | left: 100%; |
| - | top: 0px; |
| + | top: 0; |
| + | left: 0; |
| z-index: 999; | |
| - | min-width: 12.5em; |
| - | border: solid 1px #cccccc; } |
| + | min-width: 12.5em; } |
| .section-container.horizontal-nav { | |
| - | position: relative; |
| background: #efefef; | |
| border: 1px solid #cccccc; } | |
| - | .section-container.horizontal-nav > section, .section-container.horizontal-nav > .section { |
| - | padding-top: 0; |
| - | border: 0; |
| - | position: static; } |
| - | .section-container.horizontal-nav > section > .title, .section-container.horizontal-nav > .section > .title { |
| - | background-color: #efefef; |
| - | cursor: pointer; |
| - | margin-bottom: 0; } |
| - | .section-container.horizontal-nav > section > .title a, .section-container.horizontal-nav > .section > .title a { |
| - | padding: 0.9375em; |
| - | display: inline-block; |
| - | color: #333333; |
| - | font-size: 0.875em; |
| - | white-space: nowrap; } |
| - | .section-container.horizontal-nav > section > .title:hover, .section-container.horizontal-nav > .section > .title:hover { |
| - | background-color: #e2e2e2; } |
| - | .section-container.horizontal-nav > section .content, .section-container.horizontal-nav > .section .content { |
| - | display: none; |
| - | padding: 0.9375em; |
| - | background-color: white; } |
| - | .section-container.horizontal-nav > section .content > *:last-child, .section-container.horizontal-nav > .section .content > *:last-child { |
| - | margin-bottom: 0; } |
| - | .section-container.horizontal-nav > section .content > *:first-child, .section-container.horizontal-nav > .section .content > *:first-child { |
| - | padding-top: 0; } |
| - | .section-container.horizontal-nav > section .content > *:last-child, .section-container.horizontal-nav > .section .content > *:last-child { |
| - | padding-bottom: 0; } |
| - | .section-container.horizontal-nav > section.active > .content, .section-container.horizontal-nav > .section.active > .content { |
| - | display: block; } |
| - | .section-container.horizontal-nav > section.active > .title, .section-container.horizontal-nav > .section.active > .title { |
| - | background: #d5d5d5; } |
| - | .section-container.horizontal-nav > section.active > .title a, .section-container.horizontal-nav > .section.active > .title a { |
| - | color: #333333; } |
| - | .section-container.horizontal-nav > section > .title, .section-container.horizontal-nav > .section > .title { |
| - | width: auto; |
| - | border: solid 1px #cccccc; |
| - | border-left: 0; |
| - | top: -1px; |
| - | position: absolute; |
| - | z-index: 1; } |
| - | .section-container.horizontal-nav > section > .title a, .section-container.horizontal-nav > .section > .title a { |
| - | width: 100%; } |
| - | .section-container.horizontal-nav > section .content, .section-container.horizontal-nav > .section .content { |
| - | display: none; } |
| - | .section-container.horizontal-nav > section.active > .content, .section-container.horizontal-nav > .section.active > .content { |
| - | display: block; |
| - | position: absolute; |
| - | z-index: 999; |
| - | left: 0; |
| - | top: -2px; |
| - | min-width: 12.5em; |
| - | border: solid 1px #cccccc; } } |
| - | .no-js .section-container.auto, .no-js .section-container.accordion, .no-js .section-container.tabs, .no-js .section-container.vertical-tabs, .no-js .section-container.vertical-nav, .no-js .section-container.horizontal-nav { |
| - | width: 100%; |
| - | display: block; |
| - | margin-bottom: 1.25em; |
| - | border: 1px solid #cccccc; |
| - | border-top: none; } |
| - | .no-js .section-container.auto > section, .no-js .section-container.auto > .section, .no-js .section-container.accordion > section, .no-js .section-container.accordion > .section, .no-js .section-container.tabs > section, .no-js .section-container.tabs > .section, .no-js .section-container.vertical-tabs > section, .no-js .section-container.vertical-tabs > .section, .no-js .section-container.vertical-nav > section, .no-js .section-container.vertical-nav > .section, .no-js .section-container.horizontal-nav > section, .no-js .section-container.horizontal-nav > .section { |
| - | position: relative; } |
| - | .no-js .section-container.auto > section > .title, .no-js .section-container.auto > .section > .title, .no-js .section-container.accordion > section > .title, .no-js .section-container.accordion > .section > .title, .no-js .section-container.tabs > section > .title, .no-js .section-container.tabs > .section > .title, .no-js .section-container.vertical-tabs > section > .title, .no-js .section-container.vertical-tabs > .section > .title, .no-js .section-container.vertical-nav > section > .title, .no-js .section-container.vertical-nav > .section > .title, .no-js .section-container.horizontal-nav > section > .title, .no-js .section-container.horizontal-nav > .section > .title { |
| + | .section-container.horizontal-nav > section > .title, .section-container.horizontal-nav > .section > .title { |
| background-color: #efefef; | |
| cursor: pointer; | |
| - | margin-bottom: 0; } |
| - | .no-js .section-container.auto > section > .title a, .no-js .section-container.auto > .section > .title a, .no-js .section-container.accordion > section > .title a, .no-js .section-container.accordion > .section > .title a, .no-js .section-container.tabs > section > .title a, .no-js .section-container.tabs > .section > .title a, .no-js .section-container.vertical-tabs > section > .title a, .no-js .section-container.vertical-tabs > .section > .title a, .no-js .section-container.vertical-nav > section > .title a, .no-js .section-container.vertical-nav > .section > .title a, .no-js .section-container.horizontal-nav > section > .title a, .no-js .section-container.horizontal-nav > .section > .title a { |
| + | border: solid 1px #cccccc; } |
| + | .section-container.horizontal-nav > section > .title a, .section-container.horizontal-nav > .section > .title a { |
| padding: 0.9375em; | |
| - | display: inline-block; |
| color: #333333; | |
| font-size: 0.875em; | |
| - | white-space: nowrap; } |
| - | .no-js .section-container.auto > section > .title:hover, .no-js .section-container.auto > .section > .title:hover, .no-js .section-container.accordion > section > .title:hover, .no-js .section-container.accordion > .section > .title:hover, .no-js .section-container.tabs > section > .title:hover, .no-js .section-container.tabs > .section > .title:hover, .no-js .section-container.vertical-tabs > section > .title:hover, .no-js .section-container.vertical-tabs > .section > .title:hover, .no-js .section-container.vertical-nav > section > .title:hover, .no-js .section-container.vertical-nav > .section > .title:hover, .no-js .section-container.horizontal-nav > section > .title:hover, .no-js .section-container.horizontal-nav > .section > .title:hover { |
| + | background: none; } |
| + | .section-container.horizontal-nav > section > .title:hover, .section-container.horizontal-nav > .section > .title:hover { |
| background-color: #e2e2e2; } | |
| - | .no-js .section-container.auto > section .content, .no-js .section-container.auto > .section .content, .no-js .section-container.accordion > section .content, .no-js .section-container.accordion > .section .content, .no-js .section-container.tabs > section .content, .no-js .section-container.tabs > .section .content, .no-js .section-container.vertical-tabs > section .content, .no-js .section-container.vertical-tabs > .section .content, .no-js .section-container.vertical-nav > section .content, .no-js .section-container.vertical-nav > .section .content, .no-js .section-container.horizontal-nav > section .content, .no-js .section-container.horizontal-nav > .section .content { |
| - | display: none; |
| + | .section-container.horizontal-nav > section > .content, .section-container.horizontal-nav > .section > .content { |
| padding: 0.9375em; | |
| - | background-color: white; } |
| - | .no-js .section-container.auto > section .content > *:last-child, .no-js .section-container.auto > .section .content > *:last-child, .no-js .section-container.accordion > section .content > *:last-child, .no-js .section-container.accordion > .section .content > *:last-child, .no-js .section-container.tabs > section .content > *:last-child, .no-js .section-container.tabs > .section .content > *:last-child, .no-js .section-container.vertical-tabs > section .content > *:last-child, .no-js .section-container.vertical-tabs > .section .content > *:last-child, .no-js .section-container.vertical-nav > section .content > *:last-child, .no-js .section-container.vertical-nav > .section .content > *:last-child, .no-js .section-container.horizontal-nav > section .content > *:last-child, .no-js .section-container.horizontal-nav > .section .content > *:last-child { |
| + | background-color: white; |
| + | border: solid 1px #cccccc; } |
| + | .section-container.horizontal-nav > section > .content > *:last-child, .section-container.horizontal-nav > .section > .content > *:last-child { |
| margin-bottom: 0; } | |
| - | .no-js .section-container.auto > section .content > *:first-child, .no-js .section-container.auto > .section .content > *:first-child, .no-js .section-container.accordion > section .content > *:first-child, .no-js .section-container.accordion > .section .content > *:first-child, .no-js .section-container.tabs > section .content > *:first-child, .no-js .section-container.tabs > .section .content > *:first-child, .no-js .section-container.vertical-tabs > section .content > *:first-child, .no-js .section-container.vertical-tabs > .section .content > *:first-child, .no-js .section-container.vertical-nav > section .content > *:first-child, .no-js .section-container.vertical-nav > .section .content > *:first-child, .no-js .section-container.horizontal-nav > section .content > *:first-child, .no-js .section-container.horizontal-nav > .section .content > *:first-child { |
| + | .section-container.horizontal-nav > section > .content > *:first-child, .section-container.horizontal-nav > .section > .content > *:first-child { |
| padding-top: 0; } | |
| - | .no-js .section-container.auto > section .content > *:last-child, .no-js .section-container.auto > .section .content > *:last-child, .no-js .section-container.accordion > section .content > *:last-child, .no-js .section-container.accordion > .section .content > *:last-child, .no-js .section-container.tabs > section .content > *:last-child, .no-js .section-container.tabs > .section .content > *:last-child, .no-js .section-container.vertical-tabs > section .content > *:last-child, .no-js .section-container.vertical-tabs > .section .content > *:last-child, .no-js .section-container.vertical-nav > section .content > *:last-child, .no-js .section-container.vertical-nav > .section .content > *:last-child, .no-js .section-container.horizontal-nav > section .content > *:last-child, .no-js .section-container.horizontal-nav > .section .content > *:last-child { |
| + | .section-container.horizontal-nav > section > .content > *:last-child:not(.flex-video), .section-container.horizontal-nav > .section > .content > *:last-child:not(.flex-video) { |
| padding-bottom: 0; } | |
| - | .no-js .section-container.auto > section.active > .content, .no-js .section-container.auto > .section.active > .content, .no-js .section-container.accordion > section.active > .content, .no-js .section-container.accordion > .section.active > .content, .no-js .section-container.tabs > section.active > .content, .no-js .section-container.tabs > .section.active > .content, .no-js .section-container.vertical-tabs > section.active > .content, .no-js .section-container.vertical-tabs > .section.active > .content, .no-js .section-container.vertical-nav > section.active > .content, .no-js .section-container.vertical-nav > .section.active > .content, .no-js .section-container.horizontal-nav > section.active > .content, .no-js .section-container.horizontal-nav > .section.active > .content { |
| - | display: block; } |
| - | .no-js .section-container.auto > section.active > .title, .no-js .section-container.auto > .section.active > .title, .no-js .section-container.accordion > section.active > .title, .no-js .section-container.accordion > .section.active > .title, .no-js .section-container.tabs > section.active > .title, .no-js .section-container.tabs > .section.active > .title, .no-js .section-container.vertical-tabs > section.active > .title, .no-js .section-container.vertical-tabs > .section.active > .title, .no-js .section-container.vertical-nav > section.active > .title, .no-js .section-container.vertical-nav > .section.active > .title, .no-js .section-container.horizontal-nav > section.active > .title, .no-js .section-container.horizontal-nav > .section.active > .title { |
| + | .section-container.horizontal-nav > section.active > .title, .section-container.horizontal-nav > .section.active > .title { |
| background: #d5d5d5; } | |
| - | .no-js .section-container.auto > section.active > .title a, .no-js .section-container.auto > .section.active > .title a, .no-js .section-container.accordion > section.active > .title a, .no-js .section-container.accordion > .section.active > .title a, .no-js .section-container.tabs > section.active > .title a, .no-js .section-container.tabs > .section.active > .title a, .no-js .section-container.vertical-tabs > section.active > .title a, .no-js .section-container.vertical-tabs > .section.active > .title a, .no-js .section-container.vertical-nav > section.active > .title a, .no-js .section-container.vertical-nav > .section.active > .title a, .no-js .section-container.horizontal-nav > section.active > .title a, .no-js .section-container.horizontal-nav > .section.active > .title a { |
| + | .section-container.horizontal-nav > section.active > .title a, .section-container.horizontal-nav > .section.active > .title a { |
| color: #333333; } | |
| - | .no-js .section-container.auto > section > .title, .no-js .section-container.auto > .section > .title, .no-js .section-container.accordion > section > .title, .no-js .section-container.accordion > .section > .title, .no-js .section-container.tabs > section > .title, .no-js .section-container.tabs > .section > .title, .no-js .section-container.vertical-tabs > section > .title, .no-js .section-container.vertical-tabs > .section > .title, .no-js .section-container.vertical-nav > section > .title, .no-js .section-container.vertical-nav > .section > .title, .no-js .section-container.horizontal-nav > section > .title, .no-js .section-container.horizontal-nav > .section > .title { |
| - | top: 0; |
| - | width: 100%; |
| - | margin: 0; |
| - | border-top: solid 1px #cccccc; } |
| - | .no-js .section-container.auto > section > .title a, .no-js .section-container.auto > .section > .title a, .no-js .section-container.accordion > section > .title a, .no-js .section-container.accordion > .section > .title a, .no-js .section-container.tabs > section > .title a, .no-js .section-container.tabs > .section > .title a, .no-js .section-container.vertical-tabs > section > .title a, .no-js .section-container.vertical-tabs > .section > .title a, .no-js .section-container.vertical-nav > section > .title a, .no-js .section-container.vertical-nav > .section > .title a, .no-js .section-container.horizontal-nav > section > .title a, .no-js .section-container.horizontal-nav > .section > .title a { |
| - | width: 100%; } |
| - | .no-js .section-container.auto > section .title, .no-js .section-container.auto > .section .title, .no-js .section-container.accordion > section .title, .no-js .section-container.accordion > .section .title, .no-js .section-container.tabs > section .title, .no-js .section-container.tabs > .section .title, .no-js .section-container.vertical-tabs > section .title, .no-js .section-container.vertical-tabs > .section .title, .no-js .section-container.vertical-nav > section .title, .no-js .section-container.vertical-nav > .section .title, .no-js .section-container.horizontal-nav > section .title, .no-js .section-container.horizontal-nav > .section .title { |
| - | position: static; |
| - | width: 100%; |
| - | border-left: 0; |
| - | border-right: 0; } |
| - | .no-js .section-container.auto > section .content, .no-js .section-container.auto > .section .content, .no-js .section-container.accordion > section .content, .no-js .section-container.accordion > .section .content, .no-js .section-container.tabs > section .content, .no-js .section-container.tabs > .section .content, .no-js .section-container.vertical-tabs > section .content, .no-js .section-container.vertical-tabs > .section .content, .no-js .section-container.vertical-nav > section .content, .no-js .section-container.vertical-nav > .section .content, .no-js .section-container.horizontal-nav > section .content, .no-js .section-container.horizontal-nav > .section .content { |
| - | position: static; |
| - | display: block; |
| - | width: 100%; |
| - | border-left: 0; |
| - | border-right: 0; |
| - | border-bottom: 0; } |
| + | .section-container.horizontal-nav > section:not(.active), .section-container.horizontal-nav > .section:not(.active) { |
| + | padding: 0 !important; } } |
| + | .no-js [data-section], .no-js .section-container { |
| + | width: 100%; |
| + | position: relative; |
| + | display: block; |
| + | margin-bottom: 1.25em; } |
| + | .no-js [data-section][data-section-small-style], .no-js .section-container[data-section-small-style] { |
| + | width: 100% !important; } |
| + | .no-js [data-section][data-section-small-style] > [data-section-region], .no-js [data-section][data-section-small-style] > section, .no-js [data-section][data-section-small-style] > .section, .no-js .section-container[data-section-small-style] > [data-section-region], .no-js .section-container[data-section-small-style] > section, .no-js .section-container[data-section-small-style] > .section { |
| + | padding: 0 !important; |
| + | margin: 0 !important; } |
| + | .no-js [data-section][data-section-small-style] > [data-section-region] > [data-section-title], .no-js [data-section][data-section-small-style] > [data-section-region] > .title, .no-js [data-section][data-section-small-style] > section > [data-section-title], .no-js [data-section][data-section-small-style] > section > .title, .no-js [data-section][data-section-small-style] > .section > [data-section-title], .no-js [data-section][data-section-small-style] > .section > .title, .no-js .section-container[data-section-small-style] > [data-section-region] > [data-section-title], .no-js .section-container[data-section-small-style] > [data-section-region] > .title, .no-js .section-container[data-section-small-style] > section > [data-section-title], .no-js .section-container[data-section-small-style] > section > .title, .no-js .section-container[data-section-small-style] > .section > [data-section-title], .no-js .section-container[data-section-small-style] > .section > .title { |
| + | width: 100% !important; } |
| + | .no-js [data-section] > section, .no-js [data-section] > .section, .no-js [data-section] > [data-section-region], .no-js .section-container > section, .no-js .section-container > .section, .no-js .section-container > [data-section-region] { |
| + | margin: 0; } |
| + | .no-js [data-section] > section > [data-section-title], .no-js [data-section] > section > .title, .no-js [data-section] > .section > [data-section-title], .no-js [data-section] > .section > .title, .no-js [data-section] > [data-section-region] > [data-section-title], .no-js [data-section] > [data-section-region] > .title, .no-js .section-container > section > [data-section-title], .no-js .section-container > section > .title, .no-js .section-container > .section > [data-section-title], .no-js .section-container > .section > .title, .no-js .section-container > [data-section-region] > [data-section-title], .no-js .section-container > [data-section-region] > .title { |
| + | margin-bottom: 0; } |
| + | .no-js [data-section] > section > [data-section-title] a, .no-js [data-section] > section > .title a, .no-js [data-section] > .section > [data-section-title] a, .no-js [data-section] > .section > .title a, .no-js [data-section] > [data-section-region] > [data-section-title] a, .no-js [data-section] > [data-section-region] > .title a, .no-js .section-container > section > [data-section-title] a, .no-js .section-container > section > .title a, .no-js .section-container > .section > [data-section-title] a, .no-js .section-container > .section > .title a, .no-js .section-container > [data-section-region] > [data-section-title] a, .no-js .section-container > [data-section-region] > .title a { |
| + | width: 100%; |
| + | display: inline-block; |
| + | white-space: nowrap; } |
| + | .no-js [data-section] > section > [data-section-content], .no-js [data-section] > section > .content, .no-js [data-section] > .section > [data-section-content], .no-js [data-section] > .section > .content, .no-js [data-section] > [data-section-region] > [data-section-content], .no-js [data-section] > [data-section-region] > .content, .no-js .section-container > section > [data-section-content], .no-js .section-container > section > .content, .no-js .section-container > .section > [data-section-content], .no-js .section-container > .section > .content, .no-js .section-container > [data-section-region] > [data-section-content], .no-js .section-container > [data-section-region] > .content { |
| + | display: none; } |
| + | .no-js [data-section] > section.active > [data-section-content], .no-js [data-section] > section.active > .content, .no-js [data-section] > .section.active > [data-section-content], .no-js [data-section] > .section.active > .content, .no-js [data-section] > [data-section-region].active > [data-section-content], .no-js [data-section] > [data-section-region].active > .content, .no-js .section-container > section.active > [data-section-content], .no-js .section-container > section.active > .content, .no-js .section-container > .section.active > [data-section-content], .no-js .section-container > .section.active > .content, .no-js .section-container > [data-section-region].active > [data-section-content], .no-js .section-container > [data-section-region].active > .content { |
| + | display: block; } |
| + | .no-js [data-section] > section:not(.active), .no-js [data-section] > .section:not(.active), .no-js [data-section] > [data-section-region]:not(.active), .no-js .section-container > section:not(.active), .no-js .section-container > .section:not(.active), .no-js .section-container > [data-section-region]:not(.active) { |
| + | padding: 0 !important; } |
| + | .no-js [data-section] > section > [data-section-title], .no-js [data-section] > section > .title, .no-js [data-section] > .section > [data-section-title], .no-js [data-section] > .section > .title, .no-js [data-section] > [data-section-region] > [data-section-title], .no-js [data-section] > [data-section-region] > .title, .no-js .section-container > section > [data-section-title], .no-js .section-container > section > .title, .no-js .section-container > .section > [data-section-title], .no-js .section-container > .section > .title, .no-js .section-container > [data-section-region] > [data-section-title], .no-js .section-container > [data-section-region] > .title { |
| + | width: 100%; } |
| + | .no-js .section-container { |
| + | border-top: 1px solid #cccccc; } |
| + | .no-js .section-container > section > .title, .no-js .section-container > .section > .title { |
| + | background-color: #efefef; |
| + | cursor: pointer; |
| + | border: solid 1px #cccccc; } |
| + | .no-js .section-container > section > .title a, .no-js .section-container > .section > .title a { |
| + | padding: 0.9375em; |
| + | color: #333333; |
| + | font-size: 0.875em; |
| + | background: none; } |
| + | .no-js .section-container > section > .title:hover, .no-js .section-container > .section > .title:hover { |
| + | background-color: #e2e2e2; } |
| + | .no-js .section-container > section > .content, .no-js .section-container > .section > .content { |
| + | padding: 0.9375em; |
| + | background-color: white; |
| + | border: solid 1px #cccccc; } |
| + | .no-js .section-container > section > .content > *:last-child, .no-js .section-container > .section > .content > *:last-child { |
| + | margin-bottom: 0; } |
| + | .no-js .section-container > section > .content > *:first-child, .no-js .section-container > .section > .content > *:first-child { |
| + | padding-top: 0; } |
| + | .no-js .section-container > section > .content > *:last-child:not(.flex-video), .no-js .section-container > .section > .content > *:last-child:not(.flex-video) { |
| + | padding-bottom: 0; } |
| + | .no-js .section-container > section.active > .title, .no-js .section-container > .section.active > .title { |
| + | background: #d5d5d5; } |
| + | .no-js .section-container > section.active > .title a, .no-js .section-container > .section.active > .title a { |
| + | color: #333333; } |
| + | .no-js .section-container > section:not(.active), .no-js .section-container > .section:not(.active) { |
| + | padding: 0 !important; } |
| + | .no-js .section-container > section > .title, .no-js .section-container > .section > .title { |
| + | border-top: none; } |
| /* Wrapped around .top-bar to contain to grid width */ | |
| .contain-to-grid { | |
| @@ | @@ -2616,6 +2829,18 @@ form.custom { |
| position: fixed; | |
| top: 0; | |
| z-index: 99; } | |
| + | .fixed.expanded:not(.top-bar) { |
| + | overflow-y: auto; |
| + | height: auto; |
| + | width: 100%; |
| + | max-height: 100%; } |
| + | .fixed.expanded:not(.top-bar) .title-area { |
| + | position: fixed; |
| + | width: 100%; |
| + | z-index: 99; } |
| + | .fixed.expanded:not(.top-bar) .top-bar-section { |
| + | z-index: 98; |
| + | margin-top: 45px; } |
| .top-bar { | |
| overflow: hidden; | |
| @@ | @@ -2623,7 +2848,7 @@ form.custom { |
| line-height: 45px; | |
| position: relative; | |
| background: #111111; | |
| - | margin-bottom: 1.875em; } |
| + | margin-bottom: 0; } |
| .top-bar ul { | |
| margin-bottom: 0; | |
| list-style: none; } | |
| @@ | @@ -2730,26 +2955,28 @@ form.custom { |
| font-size: 0.8125em; | |
| font-weight: bold; | |
| background: #222222; } | |
| - | .top-bar-section ul li > a.hover { |
| - | background: #090909; |
| - | color: white; } |
| .top-bar-section ul li > a.button { | |
| background: #2ba6cb; | |
| - | font-size: 0.8125em; } |
| - | .top-bar-section ul li > a.button.hover { |
| + | font-size: 0.8125em; |
| + | padding-right: 15px; |
| + | padding-left: 15px; } |
| + | .top-bar-section ul li > a.button:hover { |
| background: #2284a1; } | |
| .top-bar-section ul li > a.button.secondary { | |
| background: #e9e9e9; } | |
| - | .top-bar-section ul li > a.button.secondary.hover { |
| + | .top-bar-section ul li > a.button.secondary:hover { |
| background: #d0d0d0; } | |
| .top-bar-section ul li > a.button.success { | |
| background: #5da423; } | |
| - | .top-bar-section ul li > a.button.success.hover { |
| + | .top-bar-section ul li > a.button.success:hover { |
| background: #457a1a; } | |
| .top-bar-section ul li > a.button.alert { | |
| background: #c60f13; } | |
| - | .top-bar-section ul li > a.button.alert.hover { |
| + | .top-bar-section ul li > a.button.alert:hover { |
| background: #970b0e; } | |
| + | .top-bar-section ul li:hover > a { |
| + | background: black; |
| + | color: white; } |
| .top-bar-section ul li.active > a { | |
| background: #090909; | |
| color: white; } | |
| @@ | @@ -2773,12 +3000,12 @@ form.custom { |
| .top-bar-section .has-dropdown.moved { | |
| position: static; } | |
| .top-bar-section .has-dropdown.moved > .dropdown { | |
| - | visibility: visible; } |
| + | display: block; } |
| .top-bar-section .dropdown { | |
| position: absolute; | |
| left: 100%; | |
| top: 0; | |
| - | visibility: hidden; |
| + | display: none; |
| z-index: 99; } | |
| .top-bar-section .dropdown li { | |
| width: 100%; | |
| @@ | @@ -2786,6 +3013,8 @@ form.custom { |
| .top-bar-section .dropdown li a { | |
| font-weight: normal; | |
| padding: 8px 15px; } | |
| + | .top-bar-section .dropdown li a.parent-link { |
| + | font-weight: bold; } |
| .top-bar-section .dropdown li.title h5 { | |
| margin-bottom: 0; } | |
| .top-bar-section .dropdown li.title h5 a { | |
| @@ | @@ -2801,13 +3030,13 @@ form.custom { |
| font-size: 0.625em; } | |
| .top-bar-js-breakpoint { | |
| - | width: 58.75em !important; |
| + | width: 940px !important; |
| visibility: hidden; } | |
| .js-generated { | |
| display: block; } | |
| - | @media only screen and (min-width: 58.75em) { |
| + | @media only screen and (min-width: 940px) { |
| .top-bar { | |
| background: #111111; | |
| *zoom: 1; | |
| @@ | @@ -2836,7 +3065,8 @@ form.custom { |
| .contain-to-grid .top-bar { | |
| max-width: 62.5em; | |
| - | margin: 0 auto; } |
| + | margin: 0 auto; |
| + | margin-bottom: 0; } |
| .top-bar-section { | |
| -webkit-transition: none 0 0; | |
| @@ | @@ -2851,11 +3081,14 @@ form.custom { |
| float: left; } | |
| .top-bar-section ul li .js-generated { | |
| display: none; } | |
| + | .top-bar-section li.hover > a:not(.button) { |
| + | background: black; |
| + | color: white; } |
| .top-bar-section li a:not(.button) { | |
| padding: 0 15px; | |
| line-height: 45px; | |
| background: #111111; } | |
| - | .top-bar-section li a:not(.button).hover { |
| + | .top-bar-section li a:not(.button):hover { |
| background: black; } | |
| .top-bar-section .has-dropdown > a { | |
| padding-right: 35px !important; } | |
| @@ | @@ -2872,13 +3105,14 @@ form.custom { |
| .top-bar-section .has-dropdown.moved { | |
| position: relative; } | |
| .top-bar-section .has-dropdown.moved > .dropdown { | |
| - | visibility: hidden; } |
| - | .top-bar-section .has-dropdown.hover > .dropdown { |
| - | visibility: visible; } |
| + | display: none; } |
| + | .top-bar-section .has-dropdown.hover > .dropdown, .top-bar-section .has-dropdown.not-click:hover > .dropdown { |
| + | display: block; } |
| .top-bar-section .has-dropdown .dropdown li.has-dropdown > a:after { | |
| border: none; | |
| content: "\00bb"; | |
| - | margin-top: -16px; |
| + | top: 1em; |
| + | margin-top: -7px; |
| right: 5px; } | |
| .top-bar-section .dropdown { | |
| left: 0; | |
| @@ | @@ -2904,7 +3138,7 @@ form.custom { |
| border-left: solid 1px black; | |
| clear: none; | |
| height: 45px; | |
| - | width: 0px; } |
| + | width: 0; } |
| .top-bar-section .has-form { | |
| background: #111111; | |
| padding: 0 15px; | |
| @@ | @@ -2913,7 +3147,16 @@ form.custom { |
| left: auto; | |
| right: 0; } | |
| .top-bar-section ul.right li .dropdown li .dropdown { | |
| - | right: 100%; } } |
| + | right: 100%; } |
| + | |
| + | .no-js .top-bar-section ul li:hover > a { |
| + | background: black; |
| + | color: white; } |
| + | .no-js .top-bar-section ul li:active > a { |
| + | background: #090909; |
| + | color: white; } |
| + | .no-js .top-bar-section .has-dropdown:hover > .dropdown { |
| + | display: block; } } |
| @-webkit-keyframes rotate { | |
| from { | |
| -webkit-transform: rotate(0deg); } | |
| @@ | @@ -2923,24 +3166,24 @@ form.custom { |
| @-moz-keyframes rotate { | |
| from { | |
| - | -webkit-transform: rotate(0deg); } |
| + | -moz-transform: rotate(0deg); } |
| to { | |
| - | -webkit-transform: rotate(360deg); } } |
| + | -moz-transform: rotate(360deg); } } |
| @-o-keyframes rotate { | |
| from { | |
| - | -webkit-transform: rotate(0deg); } |
| + | -o-transform: rotate(0deg); } |
| to { | |
| - | -webkit-transform: rotate(360deg); } } |
| + | -o-transform: rotate(360deg); } } |
| @keyframes rotate { | |
| from { | |
| - | -webkit-transform: rotate(0deg); } |
| + | transform: rotate(0deg); } |
| to { | |
| - | -webkit-transform: rotate(360deg); } } |
| + | transform: rotate(360deg); } } |
| /* Orbit Graceful Loading */ | |
| .slideshow-wrapper { | |
| @@ | @@ -2970,7 +3213,7 @@ form.custom { |
| margin-top: -20px; | |
| margin-left: -20px; | |
| border: solid 3px; | |
| - | border-color: #555 #fff; |
| + | border-color: #555555 white; |
| -webkit-border-radius: 1000px; | |
| border-radius: 1000px; | |
| -webkit-animation-name: rotate; | |
| @@ | @@ -3001,15 +3244,18 @@ form.custom { |
| padding: 0; | |
| position: relative; } | |
| .orbit-container .orbit-slides-container img { | |
| - | display: block; } |
| + | display: block; |
| + | max-width: 100%; } |
| .orbit-container .orbit-slides-container > * { | |
| - | position: relative; |
| - | float: left; |
| - | height: auto; } |
| + | position: absolute; |
| + | top: 0; |
| + | width: 100%; |
| + | margin-left: 100%; } |
| + | .orbit-container .orbit-slides-container > *:first-child { |
| + | margin-left: 0%; } |
| .orbit-container .orbit-slides-container > * .orbit-caption { | |
| position: absolute; | |
| bottom: 0; | |
| - | background-color: black; |
| background-color: rgba(0, 0, 0, 0.6); | |
| color: white; | |
| width: 100%; | |
| @@ | @@ -3021,7 +3267,8 @@ form.custom { |
| left: 10px; | |
| font-size: 12px; | |
| color: white; | |
| - | background: rgba(0, 0, 0, 0); } |
| + | background: rgba(0, 0, 0, 0); |
| + | z-index: 10; } |
| .orbit-container .orbit-slide-number span { | |
| font-weight: 700; | |
| padding: 0.3125em; } | |
| @@ | @@ -3030,10 +3277,10 @@ form.custom { |
| top: 10px; | |
| right: 10px; | |
| height: 6px; | |
| - | width: 100px; } |
| + | width: 100px; |
| + | z-index: 10; } |
| .orbit-container .orbit-timer .orbit-progress { | |
| height: 100%; | |
| - | background-color: black; |
| background-color: rgba(0, 0, 0, 0.6); | |
| display: block; | |
| width: 0%; } | |
| @@ | @@ -3041,10 +3288,10 @@ form.custom { |
| display: none; | |
| position: absolute; | |
| top: 10px; | |
| - | right: 0px; |
| + | right: 0; |
| width: 11px; | |
| height: 14px; | |
| - | border: solid 4px #000; |
| + | border: solid 4px black; |
| border-top: none; | |
| border-bottom: none; } | |
| .orbit-container .orbit-timer.paused > span { | |
| @@ | @@ -3054,7 +3301,7 @@ form.custom { |
| height: 14px; | |
| border: inset 8px; | |
| border-right-style: solid; | |
| - | border-color: transparent transparent transparent #000; } |
| + | border-color: transparent transparent transparent black; } |
| .orbit-container:hover .orbit-timer > span { | |
| display: block; } | |
| .orbit-container .orbit-prev, | |
| @@ | @@ -3062,13 +3309,16 @@ form.custom { |
| position: absolute; | |
| top: 50%; | |
| margin-top: -25px; | |
| - | background-color: black; |
| background-color: rgba(0, 0, 0, 0.6); | |
| width: 50px; | |
| height: 60px; | |
| line-height: 50px; | |
| color: white; | |
| - | text-indent: -9999px !important; } |
| + | text-indent: -9999px !important; |
| + | z-index: 10; } |
| + | .orbit-container .orbit-prev:hover, |
| + | .orbit-container .orbit-next:hover { |
| + | background-color: rgba(0, 0, 0, 0.6); } |
| .orbit-container .orbit-prev > span, | |
| .orbit-container .orbit-next > span { | |
| position: absolute; | |
| @@ | @@ -3083,19 +3333,19 @@ form.custom { |
| .orbit-container .orbit-prev > span { | |
| border-right-style: solid; | |
| border-color: transparent; | |
| - | border-right-color: #fff; } |
| + | border-right-color: white; } |
| .orbit-container .orbit-prev:hover > span { | |
| - | border-right-color: #ccc; } |
| + | border-right-color: #cccccc; } |
| .orbit-container .orbit-next { | |
| right: 0; } | |
| .orbit-container .orbit-next > span { | |
| border-color: transparent; | |
| border-left-style: solid; | |
| - | border-left-color: #fff; |
| + | border-left-color: white; |
| left: 50%; | |
| margin-left: -8px; } | |
| .orbit-container .orbit-next:hover > span { | |
| - | border-left-color: #ccc; } |
| + | border-left-color: #cccccc; } |
| .orbit-bullets { | |
| margin: 0 auto 30px auto; | |
| @@ | @@ -3104,16 +3354,16 @@ form.custom { |
| top: 10px; } | |
| .orbit-bullets li { | |
| display: block; | |
| - | width: 18px; |
| - | height: 18px; |
| + | width: 0.75em; |
| + | height: 0.75em; |
| background: #999999; | |
| float: left; | |
| margin-right: 6px; | |
| - | border: solid 2px #222222; |
| + | border: solid 1px #555555; |
| -webkit-border-radius: 1000px; | |
| border-radius: 1000px; } | |
| .orbit-bullets li.active { | |
| - | background: #222222; } |
| + | background: #555555; } |
| .orbit-bullets li:last-child { | |
| margin-right: 0; } | |
| @@ | @@ -3129,6 +3379,17 @@ form.custom { |
| display: inherit; } | |
| .touch .orbit-bullets { | |
| display: block; } } | |
| + | @media only screen and (max-width: 768px) { |
| + | .orbit-stack-on-small .orbit-slides-container { |
| + | height: auto !important; } |
| + | .orbit-stack-on-small .orbit-slides-container > * { |
| + | position: relative; |
| + | margin-left: 0% !important; } |
| + | .orbit-stack-on-small .orbit-timer, |
| + | .orbit-stack-on-small .orbit-next, |
| + | .orbit-stack-on-small .orbit-prev, |
| + | .orbit-stack-on-small .orbit-bullets { |
| + | display: none; } } |
| .reveal-modal-bg { | |
| position: fixed; | |
| height: 100%; | |
| @@ | @@ -3193,7 +3454,7 @@ form.custom { |
| width: 95%; } } | |
| @media print { | |
| .reveal-modal { | |
| - | background: #fff !important; } } |
| + | background: white !important; } } |
| /* Foundation Joyride */ | |
| .joyride-list { | |
| display: none; } | |
| @@ | @@ -3288,9 +3549,9 @@ form.custom { |
| text-decoration: none; | |
| font-size: 30px; | |
| font-weight: normal; | |
| - | line-height: .5 !important; } |
| + | line-height: 0.5 !important; } |
| .joyride-close-tip:hover, .joyride-close-tip:focus { | |
| - | color: #eee !important; } |
| + | color: #eeeeee !important; } |
| .joyride-modal-bg { | |
| position: fixed; | |
| @@ | @@ -3309,17 +3570,17 @@ form.custom { |
| position: absolute; | |
| border-radius: 3px; | |
| z-index: 102; | |
| - | -moz-box-shadow: 0px 0px 30px #ffffff; |
| - | -webkit-box-shadow: 0px 0px 15px #ffffff; |
| - | box-shadow: 0px 0px 15px #ffffff; } |
| + | -moz-box-shadow: 0 0 30px white; |
| + | -webkit-box-shadow: 0 0 15px white; |
| + | box-shadow: 0 0 15px white; } |
| .joyride-expose-cover { | |
| background: transparent; | |
| border-radius: 3px; | |
| position: absolute; | |
| z-index: 9999; | |
| - | top: 0px; |
| - | left: 0px; } |
| + | top: 0; |
| + | left: 0; } |
| /* Styles for screens that are atleast 768px; */ | |
| @media only screen and (min-width: 768px) { | |
| @@ | @@ -3352,6 +3613,7 @@ form.custom { |
| [data-clearing] { | |
| *zoom: 1; | |
| margin-bottom: 0; | |
| + | margin-left: 0; |
| list-style: none; } | |
| [data-clearing]:before, [data-clearing]:after { | |
| content: " "; | |
| @@ | @@ -3565,8 +3827,7 @@ form.custom { |
| margin: 0; | |
| float: left; | |
| font-size: 0.6875em; | |
| - | text-transform: uppercase; |
| - | color: #2ba6cb; } |
| + | text-transform: uppercase; } |
| .breadcrumbs > *:hover a, .breadcrumbs > *:focus a { | |
| text-decoration: underline; } | |
| .breadcrumbs > * a, | |
| @@ | @@ -3600,6 +3861,204 @@ form.custom { |
| content: " "; | |
| margin: 0; } | |
| + | /* Custom Checkbox and Radio Inputs */ |
| + | form.custom .hidden-field { |
| + | margin-left: -99999px; |
| + | position: absolute; |
| + | visibility: hidden; } |
| + | form.custom .custom { |
| + | display: inline-block; |
| + | width: 16px; |
| + | height: 16px; |
| + | position: relative; |
| + | top: -1px; |
| + | /* fix centering issue */ |
| + | vertical-align: middle; |
| + | border: solid 1px #cccccc; |
| + | background: white; } |
| + | form.custom .custom.checkbox { |
| + | -webkit-border-radius: 0; |
| + | border-radius: 0; |
| + | padding: 0; } |
| + | form.custom .custom.radio { |
| + | -webkit-border-radius: 1000px; |
| + | border-radius: 1000px; |
| + | padding: 3px; } |
| + | form.custom .custom.checkbox:before { |
| + | content: ""; |
| + | display: block; |
| + | font-size: 16px; |
| + | color: white; } |
| + | form.custom .custom.radio.checked:before { |
| + | content: ""; |
| + | display: block; |
| + | width: 8px; |
| + | height: 8px; |
| + | -webkit-border-radius: 1000px; |
| + | border-radius: 1000px; |
| + | background: #222222; |
| + | position: relative; } |
| + | form.custom .custom.checkbox.checked:before { |
| + | content: "\00d7"; |
| + | color: #222222; |
| + | position: absolute; |
| + | top: -50%; |
| + | left: 50%; |
| + | margin-top: 4px; |
| + | margin-left: -5px; } |
| + | |
| + | /* Custom Select Options and Dropdowns */ |
| + | form.custom { |
| + | /* Custom input, disabled */ } |
| + | form.custom .custom.dropdown { |
| + | display: block; |
| + | position: relative; |
| + | top: 0; |
| + | height: 2.3125em; |
| + | margin-bottom: 1.25em; |
| + | margin-top: 0; |
| + | padding: 0; |
| + | width: 100%; |
| + | background: white; |
| + | background: -moz-linear-gradient(top, white 0%, #f3f3f3 100%); |
| + | background: -webkit-linear-gradient(top, white 0%, #f3f3f3 100%); |
| + | -webkit-box-shadow: none; |
| + | background: linear-gradient(to bottom, white 0%, #f3f3f3 100%); |
| + | box-shadow: none; |
| + | font-size: 0.875em; |
| + | vertical-align: top; } |
| + | form.custom .custom.dropdown ul { |
| + | overflow-y: auto; |
| + | max-height: 200px; } |
| + | form.custom .custom.dropdown .current { |
| + | cursor: default; |
| + | white-space: nowrap; |
| + | line-height: 2.25em; |
| + | color: rgba(0, 0, 0, 0.75); |
| + | text-decoration: none; |
| + | overflow: hidden; |
| + | display: block; |
| + | margin-left: 0.5em; |
| + | margin-right: 2.3125em; } |
| + | form.custom .custom.dropdown .selector { |
| + | cursor: default; |
| + | position: absolute; |
| + | width: 2.5em; |
| + | height: 2.3125em; |
| + | display: block; |
| + | right: 0; |
| + | top: 0; } |
| + | form.custom .custom.dropdown .selector:after { |
| + | content: ""; |
| + | display: block; |
| + | content: ""; |
| + | display: block; |
| + | width: 0; |
| + | height: 0; |
| + | border: inset 5px; |
| + | border-color: #aaaaaa transparent transparent transparent; |
| + | border-top-style: solid; |
| + | position: absolute; |
| + | left: 0.9375em; |
| + | top: 50%; |
| + | margin-top: -3px; } |
| + | form.custom .custom.dropdown:hover a.selector:after, form.custom .custom.dropdown.open a.selector:after { |
| + | content: ""; |
| + | display: block; |
| + | width: 0; |
| + | height: 0; |
| + | border: inset 5px; |
| + | border-color: #222222 transparent transparent transparent; |
| + | border-top-style: solid; } |
| + | form.custom .custom.dropdown .disabled { |
| + | color: #888888; } |
| + | form.custom .custom.dropdown .disabled:hover { |
| + | background: transparent; |
| + | color: #888888; } |
| + | form.custom .custom.dropdown .disabled:hover:after { |
| + | display: none; } |
| + | form.custom .custom.dropdown.open ul { |
| + | display: block; |
| + | z-index: 10; |
| + | min-width: 100%; |
| + | -moz-box-sizing: content-box; |
| + | -webkit-box-sizing: content-box; |
| + | box-sizing: content-box; } |
| + | form.custom .custom.dropdown.small { |
| + | max-width: 134px; } |
| + | form.custom .custom.dropdown.medium { |
| + | max-width: 254px; } |
| + | form.custom .custom.dropdown.large { |
| + | max-width: 434px; } |
| + | form.custom .custom.dropdown.expand { |
| + | width: 100% !important; } |
| + | form.custom .custom.dropdown.open.small ul { |
| + | min-width: 134px; |
| + | -moz-box-sizing: border-box; |
| + | -webkit-box-sizing: border-box; |
| + | box-sizing: border-box; } |
| + | form.custom .custom.dropdown.open.medium ul { |
| + | min-width: 254px; |
| + | -moz-box-sizing: border-box; |
| + | -webkit-box-sizing: border-box; |
| + | box-sizing: border-box; } |
| + | form.custom .custom.dropdown.open.large ul { |
| + | min-width: 434px; |
| + | -moz-box-sizing: border-box; |
| + | -webkit-box-sizing: border-box; |
| + | box-sizing: border-box; } |
| + | form.custom .error .custom.dropdown { |
| + | border-color: #c60f13; |
| + | background-color: rgba(198, 15, 19, 0.1); |
| + | background: rgba(198, 15, 19, 0.1); |
| + | margin-bottom: 0; } |
| + | form.custom .error .custom.dropdown:focus { |
| + | background: #fafafa; |
| + | border-color: #999999; } |
| + | form.custom .error .custom.dropdown + small.error { |
| + | margin-top: 0; } |
| + | form.custom .custom.dropdown ul { |
| + | position: absolute; |
| + | width: auto; |
| + | display: none; |
| + | margin: 0; |
| + | left: -1px; |
| + | top: auto; |
| + | -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.1); |
| + | box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.1); |
| + | margin: 0; |
| + | padding: 0; |
| + | background: white; |
| + | border: solid 1px #cccccc; |
| + | font-size: 16px; } |
| + | form.custom .custom.dropdown ul li { |
| + | color: #555555; |
| + | font-size: 0.875em; |
| + | cursor: default; |
| + | padding-top: 0.25em; |
| + | padding-bottom: 0.25em; |
| + | padding-left: 0.375em; |
| + | padding-right: 2.375em; |
| + | min-height: 1.5em; |
| + | line-height: 1.5em; |
| + | margin: 0; |
| + | white-space: nowrap; |
| + | list-style: none; } |
| + | form.custom .custom.dropdown ul li.selected { |
| + | background: #eeeeee; |
| + | color: black; } |
| + | form.custom .custom.dropdown ul li:hover { |
| + | background-color: #e4e4e4; |
| + | color: black; } |
| + | form.custom .custom.dropdown ul li.selected:hover { |
| + | background: #eeeeee; |
| + | cursor: default; |
| + | color: black; } |
| + | form.custom .custom.dropdown ul.show { |
| + | display: block; } |
| + | form.custom .custom.disabled { |
| + | background: #dddddd; } |
| + | |
| /* Keystroke Characters */ | |
| .keystroke, | |
| kbd { | |
| @@ | @@ -3611,7 +4070,7 @@ kbd { |
| margin: 0; | |
| font-family: "Consolas", "Menlo", "Courier", monospace; | |
| font-size: 0.875em; | |
| - | padding: 0.125em 0.25em 0em; |
| + | padding: 0.125em 0.25em 0; |
| -webkit-border-radius: 3px; | |
| border-radius: 3px; } | |
| @@ | @@ -3660,41 +4119,43 @@ kbd { |
| .inline-list > li > * { | |
| display: block; } | |
| - | /* Pagination */ |
| - | .pagination { |
| + | /* Default Pagination */ |
| + | ul.pagination { |
| display: block; | |
| height: 1.5em; | |
| margin-left: -0.3125em; } | |
| - | .pagination li { |
| - | display: block; |
| - | float: left; |
| + | ul.pagination li { |
| height: 1.5em; | |
| color: #222222; | |
| font-size: 0.875em; | |
| margin-left: 0.3125em; } | |
| - | .pagination li a { |
| + | ul.pagination li a { |
| display: block; | |
| padding: 0.0625em 0.4375em 0.0625em; | |
| color: #999999; } | |
| - | .pagination li:hover a, |
| - | .pagination li a:focus { |
| + | ul.pagination li:hover a, |
| + | ul.pagination li a:focus { |
| background: #e6e6e6; } | |
| - | .pagination li.unavailable a { |
| + | ul.pagination li.unavailable a { |
| cursor: default; | |
| color: #999999; } | |
| - | .pagination li.unavailable:hover a, .pagination li.unavailable a:focus { |
| + | ul.pagination li.unavailable:hover a, ul.pagination li.unavailable a:focus { |
| background: transparent; } | |
| - | .pagination li.current a { |
| + | ul.pagination li.current a { |
| background: #2ba6cb; | |
| color: white; | |
| font-weight: bold; | |
| cursor: default; } | |
| - | .pagination li.current a:hover, .pagination li.current a:focus { |
| + | ul.pagination li.current a:hover, ul.pagination li.current a:focus { |
| background: #2ba6cb; } | |
| + | ul.pagination li { |
| + | float: left; |
| + | display: block; } |
| + | /* Pagination centred wrapper */ |
| .pagination-centered { | |
| text-align: center; } | |
| - | .pagination-centered ul > li { |
| + | .pagination-centered ul.pagination li { |
| float: none; | |
| display: inline-block; } | |
| @@ | @@ -3706,12 +4167,12 @@ kbd { |
| margin-bottom: 1.25em; | |
| padding: 1.25em; | |
| background: #f2f2f2; } | |
| - | .panel h1, .panel h2, .panel h3, .panel h4, .panel h5, .panel h6, .panel p { |
| - | color: #333333; } |
| .panel > :first-child { | |
| margin-top: 0; } | |
| .panel > :last-child { | |
| margin-bottom: 0; } | |
| + | .panel h1, .panel h2, .panel h3, .panel h4, .panel h5, .panel h6, .panel p { |
| + | color: #333333; } |
| .panel h1, .panel h2, .panel h3, .panel h4, .panel h5, .panel h6 { | |
| line-height: 1; | |
| margin-bottom: 0.625em; } | |
| @@ | @@ -3726,17 +4187,19 @@ kbd { |
| background: #2ba6cb; | |
| -webkit-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.5) inset; | |
| box-shadow: 0 1px 0 rgba(255, 255, 255, 0.5) inset; } | |
| - | .panel.callout h1, .panel.callout h2, .panel.callout h3, .panel.callout h4, .panel.callout h5, .panel.callout h6, .panel.callout p { |
| - | color: white; } |
| .panel.callout > :first-child { | |
| margin-top: 0; } | |
| .panel.callout > :last-child { | |
| margin-bottom: 0; } | |
| + | .panel.callout h1, .panel.callout h2, .panel.callout h3, .panel.callout h4, .panel.callout h5, .panel.callout h6, .panel.callout p { |
| + | color: white; } |
| .panel.callout h1, .panel.callout h2, .panel.callout h3, .panel.callout h4, .panel.callout h5, .panel.callout h6 { | |
| line-height: 1; | |
| margin-bottom: 0.625em; } | |
| .panel.callout h1.subheader, .panel.callout h2.subheader, .panel.callout h3.subheader, .panel.callout h4.subheader, .panel.callout h5.subheader, .panel.callout h6.subheader { | |
| line-height: 1.4; } | |
| + | .panel.callout a { |
| + | color: white; } |
| .panel.radius { | |
| -webkit-border-radius: 3px; | |
| border-radius: 3px; } | |
| @@ | @@ -3854,7 +4317,8 @@ kbd { |
| margin-right: 0; | |
| margin-left: -0.5625em; } | |
| .sub-nav dt, | |
| - | .sub-nav dd { |
| + | .sub-nav dd, |
| + | .sub-nav li { |
| float: left; | |
| display: inline; | |
| margin-left: 0.5625em; | |
| @@ | @@ -3862,11 +4326,13 @@ kbd { |
| font-weight: normal; | |
| font-size: 0.875em; } | |
| .sub-nav dt a, | |
| - | .sub-nav dd a { |
| + | .sub-nav dd a, |
| + | .sub-nav li a { |
| color: #999999; | |
| text-decoration: none; } | |
| .sub-nav dt.active a, | |
| - | .sub-nav dd.active a { |
| + | .sub-nav dd.active a, |
| + | .sub-nav li.active a { |
| -webkit-border-radius: 1000px; | |
| border-radius: 1000px; | |
| font-weight: bold; | |
| @@ | @@ -3879,15 +4345,13 @@ kbd { |
| @media only screen { | |
| div.switch { | |
| position: relative; | |
| - | width: 100%; |
| padding: 0; | |
| display: block; | |
| overflow: hidden; | |
| border-style: solid; | |
| border-width: 1px; | |
| margin-bottom: 1.25em; | |
| - | -webkit-animation: webkitSiblingBugfix infinite 1s; |
| - | height: 36px; |
| + | height: 2.25em; |
| background: white; | |
| border-color: #cccccc; } | |
| div.switch label { | |
| @@ | @@ -3912,7 +4376,7 @@ kbd { |
| -moz-appearance: none; } | |
| div.switch input:hover, div.switch input:focus { | |
| cursor: pointer; } | |
| - | div.switch > span { |
| + | div.switch span:last-child { |
| position: absolute; | |
| top: -1px; | |
| left: -1px; | |
| @@ | @@ -3948,17 +4412,21 @@ kbd { |
| left: auto; } | |
| div.switch span.custom { | |
| display: none !important; } | |
| + | form.custom div.switch .hidden-field { |
| + | margin-left: auto; |
| + | position: absolute; |
| + | visibility: visible; } |
| div.switch label { | |
| - | padding: 0 0.375em; |
| + | padding: 0; |
| line-height: 2.3em; | |
| font-size: 0.875em; } | |
| - | div.switch input:first-of-type:checked ~ span { |
| + | div.switch input:first-of-type:checked ~ span:last-child { |
| left: 100%; | |
| margin-left: -2.1875em; } | |
| - | div.switch > span { |
| + | div.switch span:last-child { |
| width: 2.25em; | |
| height: 2.25em; } | |
| - | div.switch > span { |
| + | div.switch span:last-child { |
| border-color: #b3b3b3; | |
| background: white; | |
| background: -moz-linear-gradient(top, white 0%, #f2f2f2 100%); | |
| @@ | @@ -3966,7 +4434,7 @@ kbd { |
| background: linear-gradient(to bottom, white 0%, #f2f2f2 100%); | |
| -webkit-box-shadow: 2px 0 10px 0 rgba(0, 0, 0, 0.07), 1000px 0 0 1000px #e1f5d1, -2px 0 10px 0 rgba(0, 0, 0, 0.07), -1000px 0 0 1000px whitesmoke; | |
| box-shadow: 2px 0 10px 0 rgba(0, 0, 0, 0.07), 1000px 0 0 980px #e1f5d1, -2px 0 10px 0 rgba(0, 0, 0, 0.07), -1000px 0 0 1000px whitesmoke; } | |
| - | div.switch:hover > span, div.switch:focus > span { |
| + | div.switch:hover span:last-child, div.switch:focus span:last-child { |
| background: white; | |
| background: -moz-linear-gradient(top, white 0%, #e6e6e6 100%); | |
| background: -webkit-linear-gradient(top, white 0%, #e6e6e6 100%); | |
| @@ | @@ -3974,51 +4442,51 @@ kbd { |
| div.switch:active { | |
| background: transparent; } | |
| div.switch.large { | |
| - | height: 44px; } |
| + | height: 2.75em; } |
| div.switch.large label { | |
| - | padding: 0 0.375em; |
| + | padding: 0; |
| line-height: 2.3em; | |
| font-size: 1.0625em; } | |
| - | div.switch.large input:first-of-type:checked ~ span { |
| + | div.switch.large input:first-of-type:checked ~ span:last-child { |
| left: 100%; | |
| margin-left: -2.6875em; } | |
| - | div.switch.large > span { |
| + | div.switch.large span:last-child { |
| width: 2.75em; | |
| height: 2.75em; } | |
| div.switch.small { | |
| - | height: 28px; } |
| + | height: 1.75em; } |
| div.switch.small label { | |
| - | padding: 0 0.375em; |
| + | padding: 0; |
| line-height: 2.1em; | |
| font-size: 0.75em; } | |
| - | div.switch.small input:first-of-type:checked ~ span { |
| + | div.switch.small input:first-of-type:checked ~ span:last-child { |
| left: 100%; | |
| margin-left: -1.6875em; } | |
| - | div.switch.small > span { |
| + | div.switch.small span:last-child { |
| width: 1.75em; | |
| height: 1.75em; } | |
| div.switch.tiny { | |
| - | height: 22px; } |
| + | height: 1.375em; } |
| div.switch.tiny label { | |
| - | padding: 0 0.375em; |
| + | padding: 0; |
| line-height: 1.9em; | |
| font-size: 0.6875em; } | |
| - | div.switch.tiny input:first-of-type:checked ~ span { |
| + | div.switch.tiny input:first-of-type:checked ~ span:last-child { |
| left: 100%; | |
| margin-left: -1.3125em; } | |
| - | div.switch.tiny > span { |
| + | div.switch.tiny span:last-child { |
| width: 1.375em; | |
| height: 1.375em; } | |
| div.switch.radius { | |
| -webkit-border-radius: 4px; | |
| border-radius: 4px; } | |
| - | div.switch.radius > span { |
| + | div.switch.radius span:last-child { |
| -webkit-border-radius: 3px; | |
| border-radius: 3px; } | |
| div.switch.round { | |
| -webkit-border-radius: 1000px; | |
| border-radius: 1000px; } | |
| - | div.switch.round > span { |
| + | div.switch.round span:last-child { |
| -webkit-border-radius: 999px; | |
| border-radius: 999px; } | |
| div.switch.round label { | |
| @@ | @@ -4030,6 +4498,12 @@ kbd { |
| to { | |
| position: relative; } } } | |
| + | @media only screen and (-webkit-min-device-pixel-ratio: 0) and (max-device-width: 480px) { |
| + | div.switch { |
| + | -webkit-animation: webkitSiblingBugfix infinite 1s; } } |
| + | @media only screen and (-webkit-min-device-pixel-ratio: 1.5) { |
| + | div.switch { |
| + | -webkit-animation: none 0; } } |
| [data-magellan-expedition] { | |
| background: white; | |
| z-index: 50; | |
| @@ | @@ -4090,7 +4564,8 @@ table { |
| border-radius: 3px; } | |
| a.th { | |
| - | display: inline-block; } |
| + | display: inline-block; |
| + | max-width: 100%; } |
| /* Tooltips */ | |
| .has-tip { | |
| @@ | @@ -4169,6 +4644,7 @@ a.th { |
| position: absolute; | |
| top: -9999px; | |
| list-style: none; | |
| + | margin-left: 0; |
| width: 100%; | |
| max-height: none; | |
| height: auto; | |
| @@ | @@ -4221,12 +4697,13 @@ a.th { |
| background: #eeeeee; } | |
| .f-dropdown li a { | |
| display: block; | |
| - | padding: 0.3125em 0.625em; |
| + | padding: 0.5em; |
| color: #555555; } | |
| .f-dropdown.content { | |
| position: absolute; | |
| top: -9999px; | |
| list-style: none; | |
| + | margin-left: 0; |
| padding: 1.25em; | |
| width: 100%; | |
| height: auto; | |
generators/foundation/public/stylesheets/foundation.min.css
+1
-440
| @@ | @@ -1,440 +1 @@ |
| - | *,*:before,*:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}html,body{font-size:100%}body{background:white;color:#222;padding:0;margin:0;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:normal;font-style:normal;line-height:1;position:relative;cursor:default} |
| - | a:hover{cursor:pointer}a:focus{outline:0}img,object,embed{max-width:100%;height:auto}object,embed{height:100%}img{-ms-interpolation-mode:bicubic}#map_canvas img,#map_canvas embed,#map_canvas object,.map_canvas img,.map_canvas embed,.map_canvas object{max-width:none!important} |
| - | .left{float:left!important}.right{float:right!important}.text-left{text-align:left!important}.text-right{text-align:right!important}.text-center{text-align:center!important} |
| - | .text-justify{text-align:justify!important}.hide{display:none}.antialiased{-webkit-font-smoothing:antialiased}img{display:inline-block;vertical-align:middle} |
| - | textarea{height:auto;min-height:50px}select{width:100%}.row{width:100%;margin-left:auto;margin-right:auto;margin-top:0;margin-bottom:0;max-width:62.5em;*zoom:1} |
| - | .row:before,.row:after{content:" ";display:table}.row:after{clear:both}.row.collapse .column,.row.collapse .columns{position:relative;padding-left:0;padding-right:0;float:left} |
| - | .row .row{width:auto;margin-left:-0.9375em;margin-right:-0.9375em;margin-top:0;margin-bottom:0;max-width:none;*zoom:1}.row .row:before,.row .row:after{content:" ";display:table} |
| - | .row .row:after{clear:both}.row .row.collapse{width:auto;margin:0;max-width:none;*zoom:1}.row .row.collapse:before,.row .row.collapse:after{content:" ";display:table} |
| - | .row .row.collapse:after{clear:both}.column,.columns{position:relative;padding-left:.9375em;padding-right:.9375em;width:100%;float:left}@media only screen{.column,.columns{position:relative;padding-left:.9375em;padding-right:.9375em;float:left} |
| - | .small-1{position:relative;width:8.33333%}.small-2{position:relative;width:16.66667%}.small-3{position:relative;width:25%}.small-4{position:relative;width:33.33333%} |
| - | .small-5{position:relative;width:41.66667%}.small-6{position:relative;width:50%}.small-7{position:relative;width:58.33333%}.small-8{position:relative;width:66.66667%} |
| - | .small-9{position:relative;width:75%}.small-10{position:relative;width:83.33333%}.small-11{position:relative;width:91.66667%}.small-12{position:relative;width:100%} |
| - | .small-offset-0{position:relative;margin-left:0}.small-offset-1{position:relative;margin-left:8.33333%}.small-offset-2{position:relative;margin-left:16.66667%} |
| - | .small-offset-3{position:relative;margin-left:25%}.small-offset-4{position:relative;margin-left:33.33333%}.small-offset-5{position:relative;margin-left:41.66667%} |
| - | .small-offset-6{position:relative;margin-left:50%}.small-offset-7{position:relative;margin-left:58.33333%}.small-offset-8{position:relative;margin-left:66.66667%} |
| - | .small-offset-9{position:relative;margin-left:75%}.small-offset-10{position:relative;margin-left:83.33333%}[class*="column"]+[class*="column"]:last-child{float:right} |
| - | [class*="column"]+[class*="column"].end{float:left}.column.small-centered,.columns.small-centered{position:relative;margin-left:auto;margin-right:auto;float:none!important} |
| - | }@media only screen and (min-width:768px){.large-1{position:relative;width:8.33333%}.large-2{position:relative;width:16.66667%}.large-3{position:relative;width:25%} |
| - | .large-4{position:relative;width:33.33333%}.large-5{position:relative;width:41.66667%}.large-6{position:relative;width:50%}.large-7{position:relative;width:58.33333%} |
| - | .large-8{position:relative;width:66.66667%}.large-9{position:relative;width:75%}.large-10{position:relative;width:83.33333%}.large-11{position:relative;width:91.66667%} |
| - | .large-12{position:relative;width:100%}.row .large-offset-0{position:relative;margin-left:0}.row .large-offset-1{position:relative;margin-left:8.33333%} |
| - | .row .large-offset-2{position:relative;margin-left:16.66667%}.row .large-offset-3{position:relative;margin-left:25%}.row .large-offset-4{position:relative;margin-left:33.33333%} |
| - | .row .large-offset-5{position:relative;margin-left:41.66667%}.row .large-offset-6{position:relative;margin-left:50%}.row .large-offset-7{position:relative;margin-left:58.33333%} |
| - | .row .large-offset-8{position:relative;margin-left:66.66667%}.row .large-offset-9{position:relative;margin-left:75%}.row .large-offset-10{position:relative;margin-left:83.33333%} |
| - | .row .large-offset-11{position:relative;margin-left:91.66667%}.push-1{position:relative;left:8.33333%;right:auto}.pull-1{position:relative;right:8.33333%;left:auto} |
| - | .push-2{position:relative;left:16.66667%;right:auto}.pull-2{position:relative;right:16.66667%;left:auto}.push-3{position:relative;left:25%;right:auto} |
| - | .pull-3{position:relative;right:25%;left:auto}.push-4{position:relative;left:33.33333%;right:auto}.pull-4{position:relative;right:33.33333%;left:auto} |
| - | .push-5{position:relative;left:41.66667%;right:auto}.pull-5{position:relative;right:41.66667%;left:auto}.push-6{position:relative;left:50%;right:auto} |
| - | .pull-6{position:relative;right:50%;left:auto}.push-7{position:relative;left:58.33333%;right:auto}.pull-7{position:relative;right:58.33333%;left:auto} |
| - | .push-8{position:relative;left:66.66667%;right:auto}.pull-8{position:relative;right:66.66667%;left:auto}.push-9{position:relative;left:75%;right:auto} |
| - | .pull-9{position:relative;right:75%;left:auto}.push-10{position:relative;left:83.33333%;right:auto}.pull-10{position:relative;right:83.33333%;left:auto} |
| - | .push-11{position:relative;left:91.66667%;right:auto}.pull-11{position:relative;right:91.66667%;left:auto}.column.large-centered,.columns.large-centered{position:relative;margin-left:auto;margin-right:auto;float:none!important} |
| - | .column.large-uncentered,.columns.large-uncentered{margin-left:0;margin-right:0;float:left!important}.column.large-uncentered.opposite,.columns.large-uncentered.opposite{float:right!important} |
| - | }.show-for-small,.show-for-medium-down,.show-for-large-down{display:inherit!important}.show-for-medium,.show-for-medium-up,.show-for-large,.show-for-large-up,.show-for-xlarge{display:none!important} |
| - | .hide-for-medium,.hide-for-medium-up,.hide-for-large,.hide-for-large-up,.hide-for-xlarge{display:inherit!important}.hide-for-small,.hide-for-medium-down,.hide-for-large-down{display:none!important} |
| - | table.show-for-small,table.show-for-medium-down,table.show-for-large-down,table.hide-for-medium,table.hide-for-medium-up,table.hide-for-large,table.hide-for-large-up,table.hide-for-xlarge{display:table} |
| - | thead.show-for-small,thead.show-for-medium-down,thead.show-for-large-down,thead.hide-for-medium,thead.hide-for-medium-up,thead.hide-for-large,thead.hide-for-large-up,thead.hide-for-xlarge{display:table-header-group!important} |
| - | tbody.show-for-small,tbody.show-for-medium-down,tbody.show-for-large-down,tbody.hide-for-medium,tbody.hide-for-medium-up,tbody.hide-for-large,tbody.hide-for-large-up,tbody.hide-for-xlarge{display:table-row-group!important} |
| - | tr.show-for-small,tr.show-for-medium-down,tr.show-for-large-down,tr.hide-for-medium,tr.hide-for-medium-up,tr.hide-for-large,tr.hide-for-large-up,tr.hide-for-xlarge{display:table-row!important} |
| - | td.show-for-small,td.show-for-medium-down,td.show-for-large-down,td.hide-for-medium,td.hide-for-medium-up,td.hide-for-large,td.hide-for-large-up,td.hide-for-xlarge,th.show-for-small,th.show-for-medium-down,th.show-for-large-down,th.hide-for-medium,th.hide-for-medium-up,th.hide-for-large,th.hide-for-large-up,th.hide-for-xlarge{display:table-cell!important} |
| - | @media only screen and (min-width:768px){.show-for-medium,.show-for-medium-up{display:inherit!important}.show-for-small{display:none!important}.hide-for-small{display:inherit!important} |
| - | .hide-for-medium,.hide-for-medium-up{display:none!important}table.show-for-medium,table.show-for-medium-up,table.hide-for-small{display:table}thead.show-for-medium,thead.show-for-medium-up,thead.hide-for-small{display:table-header-group!important} |
| - | tbody.show-for-medium,tbody.show-for-medium-up,tbody.hide-for-small{display:table-row-group!important}tr.show-for-medium,tr.show-for-medium-up,tr.hide-for-small{display:table-row!important} |
| - | td.show-for-medium,td.show-for-medium-up,td.hide-for-small,th.show-for-medium,th.show-for-medium-up,th.hide-for-small{display:table-cell!important}}@media only screen and (min-width:1280px){.show-for-large,.show-for-large-up{display:inherit!important} |
| - | .show-for-medium,.show-for-medium-down{display:none!important}.hide-for-medium,.hide-for-medium-down{display:inherit!important}.hide-for-large,.hide-for-large-up{display:none!important} |
| - | table.show-for-large,table.show-for-large-up,table.hide-for-medium,table.hide-for-medium-down{display:table}thead.show-for-large,thead.show-for-large-up,thead.hide-for-medium,thead.hide-for-medium-down{display:table-header-group!important} |
| - | tbody.show-for-large,tbody.show-for-large-up,tbody.hide-for-medium,tbody.hide-for-medium-down{display:table-row-group!important}tr.show-for-large,tr.show-for-large-up,tr.hide-for-medium,tr.hide-for-medium-down{display:table-row!important} |
| - | td.show-for-large,td.show-for-large-up,td.hide-for-medium,td.hide-for-medium-down,th.show-for-large,th.show-for-large-up,th.hide-for-medium,th.hide-for-medium-down{display:table-cell!important} |
| - | }@media only screen and (min-width:1440px){.show-for-xlarge{display:inherit!important}.show-for-large,.show-for-large-down{display:none!important}.hide-for-large,.hide-for-large-down{display:inherit!important} |
| - | .hide-for-xlarge{display:none!important}table.show-for-xlarge,table.hide-for-large,table.hide-for-large-down{display:table}thead.show-for-xlarge,thead.hide-for-large,thead.hide-for-large-down{display:table-header-group!important} |
| - | tbody.show-for-xlarge,tbody.hide-for-large,tbody.hide-for-large-down{display:table-row-group!important}tr.show-for-xlarge,tr.hide-for-large,tr.hide-for-large-down{display:table-row!important} |
| - | td.show-for-xlarge,td.hide-for-large,td.hide-for-large-down,th.show-for-xlarge,th.hide-for-large,th.hide-for-large-down{display:table-cell!important}} |
| - | .show-for-landscape,.hide-for-portrait{display:inherit!important}.hide-for-landscape,.show-for-portrait{display:none!important}table.hide-for-landscape,table.show-for-portrait{display:table} |
| - | thead.hide-for-landscape,thead.show-for-portrait{display:table-header-group!important}tbody.hide-for-landscape,tbody.show-for-portrait{display:table-row-group!important} |
| - | tr.hide-for-landscape,tr.show-for-portrait{display:table-row!important}td.hide-for-landscape,td.show-for-portrait,th.hide-for-landscape,th.show-for-portrait{display:table-cell!important} |
| - | @media only screen and (orientation:landscape){.show-for-landscape,.hide-for-portrait{display:inherit!important}.hide-for-landscape,.show-for-portrait{display:none!important} |
| - | table.show-for-landscape,table.hide-for-portrait{display:table}thead.show-for-landscape,thead.hide-for-portrait{display:table-header-group!important}tbody.show-for-landscape,tbody.hide-for-portrait{display:table-row-group!important} |
| - | tr.show-for-landscape,tr.hide-for-portrait{display:table-row!important}td.show-for-landscape,td.hide-for-portrait,th.show-for-landscape,th.hide-for-portrait{display:table-cell!important} |
| - | }@media only screen and (orientation:portrait){.show-for-portrait,.hide-for-landscape{display:inherit!important}.hide-for-portrait,.show-for-landscape{display:none!important} |
| - | table.show-for-portrait,table.hide-for-landscape{display:table}thead.show-for-portrait,thead.hide-for-landscape{display:table-header-group!important}tbody.show-for-portrait,tbody.hide-for-landscape{display:table-row-group!important} |
| - | tr.show-for-portrait,tr.hide-for-landscape{display:table-row!important}td.show-for-portrait,td.hide-for-landscape,th.show-for-portrait,th.hide-for-landscape{display:table-cell!important} |
| - | }.show-for-touch{display:none!important}.hide-for-touch{display:inherit!important}.touch .show-for-touch{display:inherit!important}.touch .hide-for-touch{display:none!important} |
| - | table.hide-for-touch{display:table}.touch table.show-for-touch{display:table}thead.hide-for-touch{display:table-header-group!important}.touch thead.show-for-touch{display:table-header-group!important} |
| - | tbody.hide-for-touch{display:table-row-group!important}.touch tbody.show-for-touch{display:table-row-group!important}tr.hide-for-touch{display:table-row!important} |
| - | .touch tr.show-for-touch{display:table-row!important}td.hide-for-touch{display:table-cell!important}.touch td.show-for-touch{display:table-cell!important} |
| - | th.hide-for-touch{display:table-cell!important}.touch th.show-for-touch{display:table-cell!important}@media only screen{[class*="block-grid-"]{display:block;padding:0;margin:-0.625em;*zoom:1} |
| - | [class*="block-grid-"]:before,[class*="block-grid-"]:after{content:" ";display:table} |
| - | [class*="block-grid-"]:after{clear:both}[class*="block-grid-"]>li{display:inline;height:auto;float:left;padding:0 .625em 1.25em} |
| - | .small-block-grid-1>li{width:100%;padding:0 .625em 1.25em}.small-block-grid-1>li:nth-of-type(n){clear:none}.small-block-grid-1>li:nth-of-type(1n+1){clear:both} |
| - | .small-block-grid-2>li{width:50%;padding:0 .625em 1.25em}.small-block-grid-2>li:nth-of-type(n){clear:none}.small-block-grid-2>li:nth-of-type(2n+1){clear:both} |
| - | .small-block-grid-3>li{width:33.33333%;padding:0 .625em 1.25em}.small-block-grid-3>li:nth-of-type(n){clear:none}.small-block-grid-3>li:nth-of-type(3n+1){clear:both} |
| - | .small-block-grid-4>li{width:25%;padding:0 .625em 1.25em}.small-block-grid-4>li:nth-of-type(n){clear:none}.small-block-grid-4>li:nth-of-type(4n+1){clear:both} |
| - | .small-block-grid-5>li{width:20%;padding:0 .625em 1.25em}.small-block-grid-5>li:nth-of-type(n){clear:none}.small-block-grid-5>li:nth-of-type(5n+1){clear:both} |
| - | .small-block-grid-6>li{width:16.66667%;padding:0 .625em 1.25em}.small-block-grid-6>li:nth-of-type(n){clear:none}.small-block-grid-6>li:nth-of-type(6n+1){clear:both} |
| - | .small-block-grid-7>li{width:14.28571%;padding:0 .625em 1.25em}.small-block-grid-7>li:nth-of-type(n){clear:none}.small-block-grid-7>li:nth-of-type(7n+1){clear:both} |
| - | .small-block-grid-8>li{width:12.5%;padding:0 .625em 1.25em}.small-block-grid-8>li:nth-of-type(n){clear:none}.small-block-grid-8>li:nth-of-type(8n+1){clear:both} |
| - | .small-block-grid-9>li{width:11.11111%;padding:0 .625em 1.25em}.small-block-grid-9>li:nth-of-type(n){clear:none}.small-block-grid-9>li:nth-of-type(9n+1){clear:both} |
| - | .small-block-grid-10>li{width:10%;padding:0 .625em 1.25em}.small-block-grid-10>li:nth-of-type(n){clear:none}.small-block-grid-10>li:nth-of-type(10n+1){clear:both} |
| - | .small-block-grid-11>li{width:9.09091%;padding:0 .625em 1.25em}.small-block-grid-11>li:nth-of-type(n){clear:none}.small-block-grid-11>li:nth-of-type(11n+1){clear:both} |
| - | .small-block-grid-12>li{width:8.33333%;padding:0 .625em 1.25em}.small-block-grid-12>li:nth-of-type(n){clear:none}.small-block-grid-12>li:nth-of-type(12n+1){clear:both} |
| - | }@media only screen and (min-width:768px){.small-block-grid-1>li:nth-of-type(1n+1){clear:none}.small-block-grid-2>li:nth-of-type(2n+1){clear:none}.small-block-grid-3>li:nth-of-type(3n+1){clear:none} |
| - | .small-block-grid-4>li:nth-of-type(4n+1){clear:none}.small-block-grid-5>li:nth-of-type(5n+1){clear:none}.small-block-grid-6>li:nth-of-type(6n+1){clear:none} |
| - | .small-block-grid-7>li:nth-of-type(7n+1){clear:none}.small-block-grid-8>li:nth-of-type(8n+1){clear:none}.small-block-grid-9>li:nth-of-type(9n+1){clear:none} |
| - | .small-block-grid-10>li:nth-of-type(10n+1){clear:none}.small-block-grid-11>li:nth-of-type(11n+1){clear:none}.small-block-grid-12>li:nth-of-type(12n+1){clear:none} |
| - | .large-block-grid-1>li{width:100%;padding:0 .625em 1.25em}.large-block-grid-1>li:nth-of-type(n){clear:none}.large-block-grid-1>li:nth-of-type(1n+1){clear:both} |
| - | .large-block-grid-2>li{width:50%;padding:0 .625em 1.25em}.large-block-grid-2>li:nth-of-type(n){clear:none}.large-block-grid-2>li:nth-of-type(2n+1){clear:both} |
| - | .large-block-grid-3>li{width:33.33333%;padding:0 .625em 1.25em}.large-block-grid-3>li:nth-of-type(n){clear:none}.large-block-grid-3>li:nth-of-type(3n+1){clear:both} |
| - | .large-block-grid-4>li{width:25%;padding:0 .625em 1.25em}.large-block-grid-4>li:nth-of-type(n){clear:none}.large-block-grid-4>li:nth-of-type(4n+1){clear:both} |
| - | .large-block-grid-5>li{width:20%;padding:0 .625em 1.25em}.large-block-grid-5>li:nth-of-type(n){clear:none}.large-block-grid-5>li:nth-of-type(5n+1){clear:both} |
| - | .large-block-grid-6>li{width:16.66667%;padding:0 .625em 1.25em}.large-block-grid-6>li:nth-of-type(n){clear:none}.large-block-grid-6>li:nth-of-type(6n+1){clear:both} |
| - | .large-block-grid-7>li{width:14.28571%;padding:0 .625em 1.25em}.large-block-grid-7>li:nth-of-type(n){clear:none}.large-block-grid-7>li:nth-of-type(7n+1){clear:both} |
| - | .large-block-grid-8>li{width:12.5%;padding:0 .625em 1.25em}.large-block-grid-8>li:nth-of-type(n){clear:none}.large-block-grid-8>li:nth-of-type(8n+1){clear:both} |
| - | .large-block-grid-9>li{width:11.11111%;padding:0 .625em 1.25em}.large-block-grid-9>li:nth-of-type(n){clear:none}.large-block-grid-9>li:nth-of-type(9n+1){clear:both} |
| - | .large-block-grid-10>li{width:10%;padding:0 .625em 1.25em}.large-block-grid-10>li:nth-of-type(n){clear:none}.large-block-grid-10>li:nth-of-type(10n+1){clear:both} |
| - | .large-block-grid-11>li{width:9.09091%;padding:0 .625em 1.25em}.large-block-grid-11>li:nth-of-type(n){clear:none}.large-block-grid-11>li:nth-of-type(11n+1){clear:both} |
| - | .large-block-grid-12>li{width:8.33333%;padding:0 .625em 1.25em}.large-block-grid-12>li:nth-of-type(n){clear:none}.large-block-grid-12>li:nth-of-type(12n+1){clear:both} |
| - | }p.lead{font-size:1.21875em;line-height:1.6}.subheader{line-height:1.4;color:#6f6f6f;font-weight:300;margin-top:.2em;margin-bottom:.5em}div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0;direction:ltr} |
| - | a{color:#2ba6cb;text-decoration:none;line-height:inherit}a:hover,a:focus{color:#2795b6}a img{border:0}p{font-family:inherit;font-weight:normal;font-size:1em;line-height:1.6;margin-bottom:1.25em;text-rendering:optimizeLegibility} |
| - | p aside{font-size:.875em;line-height:1.35;font-style:italic}h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:bold;font-style:normal;color:#222;text-rendering:optimizeLegibility;margin-top:.2em;margin-bottom:.5em;line-height:1.2125em} |
| - | h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{font-size:60%;color:#6f6f6f;line-height:0}h1{font-size:2.125em}h2{font-size:1.6875em}h3{font-size:1.375em} |
| - | h4{font-size:1.125em}h5{font-size:1.125em}h6{font-size:1em}hr{border:solid #ddd;border-width:1px 0 0;clear:both;margin:1.25em 0 1.1875em;height:0}em,i{font-style:italic;line-height:inherit} |
| - | strong,b{font-weight:bold;line-height:inherit}small{font-size:60%;line-height:inherit}code{font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:bold;color:#7f0a0c} |
| - | ul,ol,dl{font-size:1em;line-height:1.6;margin-bottom:1.25em;list-style-position:outside;font-family:inherit}ul,ol{margin-left:1.25em}ul li ul,ul li ol{margin-left:1.25em;margin-bottom:0;font-size:1em} |
| - | ul.square li ul,ul.circle li ul,ul.disc li ul{list-style:inherit}ul.square{list-style-type:square}ul.circle{list-style-type:circle}ul.disc{list-style-type:disc} |
| - | ul.no-bullet{list-style:none}ol li ul,ol li ol{margin-left:1.25em;margin-bottom:0}dl dt{margin-bottom:.3em;font-weight:bold}dl dd{margin-bottom:.75em} |
| - | abbr,acronym{text-transform:uppercase;font-size:90%;color:#222;border-bottom:1px dotted #ddd;cursor:help}abbr{text-transform:none}blockquote{margin:0 0 1.25em;padding:.5625em 1.25em 0 1.1875em;border-left:1px solid #ddd} |
| - | blockquote cite{display:block;font-size:.8125em;color:#555}blockquote cite:before{content:"\2014 \0020"}blockquote cite a,blockquote cite a:visited{color:#555} |
| - | blockquote,blockquote p{line-height:1.6;color:#6f6f6f}.vcard{display:inline-block;margin:0 0 1.25em 0;border:1px solid #ddd;padding:.625em .75em}.vcard li{margin:0;display:block} |
| - | .vcard .fn{font-weight:bold;font-size:.9375em}.vevent .summary{font-weight:bold}.vevent abbr{cursor:default;text-decoration:none;font-weight:bold;border:0;padding:0 .0625em} |
| - | @media only screen and (min-width:768px){h1,h2,h3,h4,h5,h6{line-height:1.4}h1{font-size:2.75em}h2{font-size:2.3125em}h3{font-size:1.6875em}h4{font-size:1.4375em} |
| - | }.print-only{display:none!important}@media print{*{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important} |
| - | a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"} |
| - | .ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""} |
| - | pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100%!important} |
| - | @page{margin:.5cm}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}.hide-on-print{display:none!important}.print-only{display:block!important}.hide-for-print{display:none!important} |
| - | .show-for-print{display:inherit!important}}button,.button{border-style:solid;border-width:1px;cursor:pointer;font-family:inherit;font-weight:bold;line-height:1;margin:0 0 1.25em;position:relative;text-decoration:none;text-align:center;display:inline-block;padding-top:.75em;padding-right:1.5em;padding-bottom:.8125em;padding-left:1.5em;font-size:1em;background-color:#2ba6cb;border-color:#2284a1;color:white} |
| - | button:hover,button:focus,.button:hover,.button:focus{background-color:#2284a1}button:hover,button:focus,.button:hover,.button:focus{color:white}button.secondary,.button.secondary{background-color:#e9e9e9;border-color:#d0d0d0;color:#333} |
| - | button.secondary:hover,button.secondary:focus,.button.secondary:hover,.button.secondary:focus{background-color:#d0d0d0}button.secondary:hover,button.secondary:focus,.button.secondary:hover,.button.secondary:focus{color:#333} |
| - | button.success,.button.success{background-color:#5da423;border-color:#457a1a;color:white}button.success:hover,button.success:focus,.button.success:hover,.button.success:focus{background-color:#457a1a} |
| - | button.success:hover,button.success:focus,.button.success:hover,.button.success:focus{color:white}button.alert,.button.alert{background-color:#c60f13;border-color:#970b0e;color:white} |
| - | button.alert:hover,button.alert:focus,.button.alert:hover,.button.alert:focus{background-color:#970b0e}button.alert:hover,button.alert:focus,.button.alert:hover,.button.alert:focus{color:white} |
| - | button.large,.button.large{padding-top:1em;padding-right:2em;padding-bottom:1.0625em;padding-left:2em;font-size:1.25em}button.small,.button.small{padding-top:.5625em;padding-right:1.125em;padding-bottom:.625em;padding-left:1.125em;font-size:.8125em} |
| - | button.tiny,.button.tiny{padding-top:.4375em;padding-right:.875em;padding-bottom:.5em;padding-left:.875em;font-size:.6875em}button.expand,.button.expand{padding-right:0;padding-left:0;width:100%} |
| - | button.left-align,.button.left-align{text-align:left;text-indent:.75em}button.right-align,.button.right-align{text-align:right;padding-right:.75em}button.disabled,button[disabled],.button.disabled,.button[disabled]{background-color:#2ba6cb;border-color:#2284a1;color:white;cursor:default;opacity:.6;-webkit-box-shadow:none;box-shadow:none} |
| - | button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{background-color:#2284a1} |
| - | button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{color:white} |
| - | button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{background-color:#2ba6cb} |
| - | button.disabled.secondary,button[disabled].secondary,.button.disabled.secondary,.button[disabled].secondary{background-color:#e9e9e9;border-color:#d0d0d0;color:#333;cursor:default;opacity:.6;-webkit-box-shadow:none;box-shadow:none} |
| - | button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{background-color:#d0d0d0} |
| - | button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{color:#333} |
| - | button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{background-color:#e9e9e9} |
| - | button.disabled.success,button[disabled].success,.button.disabled.success,.button[disabled].success{background-color:#5da423;border-color:#457a1a;color:white;cursor:default;opacity:.6;-webkit-box-shadow:none;box-shadow:none} |
| - | button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{background-color:#457a1a} |
| - | button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{color:white} |
| - | button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{background-color:#5da423} |
| - | button.disabled.alert,button[disabled].alert,.button.disabled.alert,.button[disabled].alert{background-color:#c60f13;border-color:#970b0e;color:white;cursor:default;opacity:.6;-webkit-box-shadow:none;box-shadow:none} |
| - | button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{background-color:#970b0e} |
| - | button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{color:white} |
| - | button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{background-color:#c60f13} |
| - | button,.button{padding-top:.8125em;padding-bottom:.75em}button.tiny,.button.tiny{padding-top:.5em;padding-bottom:.4375em}button.small,.button.small{padding-top:.625em;padding-bottom:.5625em} |
| - | button.large,.button.large{padding-top:1.03125em;padding-bottom:1.03125em}@media only screen{button,.button{-webkit-box-shadow:0 1px 0 rgba(255,255,255,0.5) inset;box-shadow:0 1px 0 rgba(255,255,255,0.5) inset;-webkit-transition:background-color 300ms ease-out;-moz-transition:background-color 300ms ease-out;transition:background-color 300ms ease-out} |
| - | button:active,.button:active{-webkit-box-shadow:0 1px 0 rgba(0,0,0,0.2) inset;box-shadow:0 1px 0 rgba(0,0,0,0.2) inset}button.radius,.button.radius{-webkit-border-radius:3px;border-radius:3px} |
| - | button.round,.button.round{-webkit-border-radius:1000px;border-radius:1000px}}@media only screen and (min-width:768px){button,.button{display:inline-block} |
| - | }form{margin:0 0 1em}form .row .row{margin:0 -0.5em}form .row .row .column,form .row .row .columns{padding:0 .5em}form .row .row.collapse{margin:0}form .row .row.collapse .column,form .row .row.collapse .columns{padding:0} |
| - | form .row input.column,form .row input.columns,form .row textarea.column,form .row textarea.columns{padding-left:.5em}label{font-size:.875em;color:#4d4d4d;cursor:pointer;display:block;font-weight:500;margin-bottom:.1875em} |
| - | label.right{float:none;text-align:right}label.inline{margin:0 0 1em 0;padding:.625em 0}.prefix,.postfix{display:block;position:relative;z-index:2;text-align:center;width:100%;padding-top:0;padding-bottom:0;border-style:solid;border-width:1px;overflow:hidden;font-size:.875em;height:2.3125em;line-height:2.3125em} |
| - | .postfix.button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;text-align:center;line-height:2.125em}.prefix.button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;text-align:center;line-height:2.125em} |
| - | .prefix.button.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px} |
| - | .postfix.button.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px} |
| - | .prefix.button.round{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px} |
| - | .postfix.button.round{-webkit-border-radius:0;border-radius:0;-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px} |
| - | span.prefix{background:#f2f2f2;border-color:#d9d9d9;border-right:0;color:#333}span.prefix.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px} |
| - | span.postfix{background:#f2f2f2;border-color:#ccc;border-left:none;color:#333}span.postfix.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px} |
| - | .input-group.radius>*:first-child,.input-group.radius>*:first-child *{-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px} |
| - | .input-group.radius>*:last-child,.input-group.radius>*:last-child *{-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px} |
| - | .input-group.round>*:first-child,.input-group.round>*:first-child *{-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px} |
| - | .input-group.round>*:last-child,.input-group.round>*:last-child *{-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px} |
| - | input[type="text"],input[type="password"],input[type="date"],input[type="datetime"],input[type="datetime-local"],input[type="month"],input[type="week"],input[type="email"],input[type="number"],input[type="search"],input[type="tel"],input[type="time"],input[type="url"],textarea{background-color:white;font-family:inherit;border:1px solid #ccc;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);color:rgba(0,0,0,0.75);display:block;font-size:.875em;margin:0 0 1em 0;padding:.5em;height:2.3125em;width:100%;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-transition:-webkit-box-shadow .45s,border-color .45s ease-in-out;-moz-transition:-moz-box-shadow .45s,border-color .45s ease-in-out;transition:box-shadow .45s,border-color .45s ease-in-out} |
| - | input[type="text"]:focus,input[type="password"]:focus,input[type="date"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="month"]:focus,input[type="week"]:focus,input[type="email"]:focus,input[type="number"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="time"]:focus,input[type="url"]:focus,textarea:focus{-webkit-box-shadow:0 0 5px #999;-moz-box-shadow:0 0 5px #999;box-shadow:0 0 5px #999;border-color:#999} |
| - | input[type="text"]:focus,input[type="password"]:focus,input[type="date"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="month"]:focus,input[type="week"]:focus,input[type="email"]:focus,input[type="number"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="time"]:focus,input[type="url"]:focus,textarea:focus{background:#fafafa;border-color:#999;outline:0} |
| - | input[type="text"][disabled],input[type="password"][disabled],input[type="date"][disabled],input[type="datetime"][disabled],input[type="datetime-local"][disabled],input[type="month"][disabled],input[type="week"][disabled],input[type="email"][disabled],input[type="number"][disabled],input[type="search"][disabled],input[type="tel"][disabled],input[type="time"][disabled],input[type="url"][disabled],textarea[disabled]{background-color:#ddd} |
| - | input[type="file"],input[type="checkbox"],input[type="radio"],select{margin:0 0 1em 0} |
| - | input[type="file"]{width:100%}fieldset{border:solid 1px #ddd;padding:1.25em;margin:1.125em 0}fieldset legend{font-weight:bold;background:white;padding:0 .1875em;margin:0;margin-left:-0.1875em} |
| - | .error input,input.error,.error textarea,textarea.error{border-color:#c60f13;background-color:rgba(198,15,19,0.1)}.error input:focus,input.error:focus,.error textarea:focus,textarea.error:focus{background:#fafafa;border-color:#999} |
| - | .error label,label.error{color:#c60f13}.error small,small.error{display:block;padding:.375em .25em;margin-top:-1.3125em;margin-bottom:1em;font-size:.75em;font-weight:bold;background:#c60f13;color:white} |
| - | form.custom .hidden-field{margin-left:-99999px;position:absolute;visibility:hidden}form.custom .custom{display:inline-block;width:16px;height:16px;position:relative;vertical-align:middle;border:solid 1px #ccc;background:white} |
| - | form.custom .custom.checkbox{-webkit-border-radius:0;border-radius:0;padding:-1px}form.custom .custom.radio{-webkit-border-radius:1000px;border-radius:1000px;padding:3px} |
| - | form.custom .custom.checkbox:before{content:"";display:block;font-size:16px;color:white}form.custom .custom.radio.checked:before{content:"";display:block;width:8px;height:8px;-webkit-border-radius:1000px;border-radius:1000px;background:#222;position:relative} |
| - | form.custom .custom.checkbox.checked:before{content:"\00d7";color:#222;position:absolute;top:-50%;left:50%;margin-top:4px;margin-left:-5px} |
| - | form.custom .custom.dropdown{display:block;position:relative;top:0;height:2.3125em;margin-bottom:1.25em;margin-top:0;padding:0;width:100%;background:white;background:-moz-linear-gradient(top,white 0,#f3f3f3 100%);background:-webkit-linear-gradient(top,white 0,#f3f3f3 100%);-webkit-box-shadow:none;background:linear-gradient(to bottom,white 0,#f3f3f3 100%);box-shadow:none;font-size:.875em;vertical-align:top} |
| - | form.custom .custom.dropdown ul{overflow-y:auto;max-height:200px}form.custom .custom.dropdown .current{cursor:default;white-space:nowrap;line-height:2.25em;color:rgba(0,0,0,0.75);text-decoration:none;overflow:hidden;display:block;margin-left:.5em;margin-right:2.3125em} |
| - | form.custom .custom.dropdown .selector{cursor:default;position:absolute;width:2.5em;height:2.3125em;display:block;right:0;top:0}form.custom .custom.dropdown .selector:after{content:"";display:block;content:"";display:block;width:0;height:0;border:inset 5px;border-color:#aaa transparent transparent transparent;border-top-style:solid;position:absolute;left:.9375em;top:50%;margin-top:-3px} |
| - | form.custom .custom.dropdown:hover a.selector:after,form.custom .custom.dropdown.open a.selector:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:#222 transparent transparent transparent;border-top-style:solid} |
| - | form.custom .custom.dropdown .disabled{color:#888}form.custom .custom.dropdown .disabled:hover{background:transparent;color:#888}form.custom .custom.dropdown .disabled:hover:after{display:none} |
| - | form.custom .custom.dropdown.open ul{display:block;z-index:10;min-width:100%;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box} |
| - | form.custom .custom.dropdown.small{max-width:134px}form.custom .custom.dropdown.medium{max-width:254px}form.custom .custom.dropdown.large{max-width:434px} |
| - | form.custom .custom.dropdown.expand{width:100%!important}form.custom .custom.dropdown.open.small ul{min-width:134px;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box} |
| - | form.custom .custom.dropdown.open.medium ul{min-width:254px;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}form.custom .custom.dropdown.open.large ul{min-width:434px;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box} |
| - | form.custom .custom.dropdown ul{position:absolute;width:auto;display:none;margin:0;left:-1px;top:auto;-webkit-box-shadow:0 2px 2px 0 rgba(0,0,0,0.1);box-shadow:0 2px 2px 0 rgba(0,0,0,0.1);margin:0;padding:0;background:white;border:solid 1px #ccc;font-size:16px} |
| - | form.custom .custom.dropdown ul li{color:#555;font-size:.875em;cursor:default;padding-top:.25em;padding-bottom:.25em;padding-left:.375em;padding-right:2.375em;min-height:1.5em;line-height:1.5em;margin:0;white-space:nowrap;list-style:none} |
| - | form.custom .custom.dropdown ul li.selected{background:#eee;color:black}form.custom .custom.dropdown ul li:hover{background-color:#e4e4e4;color:black} |
| - | form.custom .custom.dropdown ul li.selected:hover{background:#eee;cursor:default;color:black}form.custom .custom.dropdown ul.show{display:block}form.custom .custom.disabled{background:#ddd} |
| - | .button-group{list-style:none;margin:0;*zoom:1}.button-group:before,.button-group:after{content:" ";display:table}.button-group:after{clear:both} |
| - | .button-group>*{margin:0 0 0 -1px;float:left}.button-group>*:first-child{margin-left:0}.button-group.radius>*:first-child,.button-group.radius>*:first-child>a,.button-group.radius>*:first-child>button,.button-group.radius>*:first-child>.button{-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px} |
| - | .button-group.radius>*:last-child,.button-group.radius>*:last-child>a,.button-group.radius>*:last-child>button,.button-group.radius>*:last-child>.button{-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px} |
| - | .button-group.round>*:first-child,.button-group.round>*:first-child>a,.button-group.round>*:first-child>button,.button-group.round>*:first-child>.button{-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px} |
| - | .button-group.round>*:last-child,.button-group.round>*:last-child>a,.button-group.round>*:last-child>button,.button-group.round>*:last-child>.button{-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px} |
| - | .button-group.even-2 li{width:50%}.button-group.even-2 li button,.button-group.even-2 li .button{width:100%}.button-group.even-3 li{width:33.33333%}.button-group.even-3 li button,.button-group.even-3 li .button{width:100%} |
| - | .button-group.even-4 li{width:25%}.button-group.even-4 li button,.button-group.even-4 li .button{width:100%}.button-group.even-5 li{width:20%}.button-group.even-5 li button,.button-group.even-5 li .button{width:100%} |
| - | .button-group.even-6 li{width:16.66667%}.button-group.even-6 li button,.button-group.even-6 li .button{width:100%}.button-group.even-7 li{width:14.28571%} |
| - | .button-group.even-7 li button,.button-group.even-7 li .button{width:100%}.button-group.even-8 li{width:12.5%}.button-group.even-8 li button,.button-group.even-8 li .button{width:100%} |
| - | .button-bar{*zoom:1}.button-bar:before,.button-bar:after{content:" ";display:table}.button-bar:after{clear:both}.button-bar .button-group{float:left;margin-right:.625em} |
| - | .button-bar .button-group div{overflow:hidden}.dropdown.button{position:relative;padding-right:3.1875em}.dropdown.button:before{position:absolute;content:"";width:0;height:0;display:block;border-style:solid;border-color:white transparent transparent transparent;top:50%} |
| - | .dropdown.button:before{border-width:.5625em;right:1.5em;margin-top:-0.25em}.dropdown.button:before{border-color:white transparent transparent transparent} |
| - | .dropdown.button.tiny{padding-right:2.1875em}.dropdown.button.tiny:before{border-width:.4375em;right:.875em;margin-top:-0.15625em}.dropdown.button.tiny:before{border-color:white transparent transparent transparent} |
| - | .dropdown.button.small{padding-right:2.8125em}.dropdown.button.small:before{border-width:.5625em;right:1.125em;margin-top:-0.21875em}.dropdown.button.small:before{border-color:white transparent transparent transparent} |
| - | .dropdown.button.large{padding-right:4em}.dropdown.button.large:before{border-width:.625em;right:1.75em;margin-top:-0.3125em}.dropdown.button.large:before{border-color:white transparent transparent transparent} |
| - | .dropdown.button.secondary:before{border-color:#333 transparent transparent transparent}.split.button{position:relative;padding-right:4.8em}.split.button span{display:block;height:100%;position:absolute;right:0;top:0;border-left:solid 1px} |
| - | .split.button span:before{position:absolute;content:"";width:0;height:0;display:block;border-style:inset;left:50%}.split.button span:active{background-color:rgba(0,0,0,0.1)} |
| - | .split.button span{border-left-color:#1e728c}.split.button span{width:3em}.split.button span:before{border-top-style:solid;border-width:.5625em;top:1.125em;margin-left:-0.5625em} |
| - | .split.button span:before{border-color:white transparent transparent transparent}.split.button.secondary span{border-left-color:#c3c3c3}.split.button.secondary span:before{border-color:white transparent transparent transparent} |
| - | .split.button.alert span{border-left-color:#7f0a0c}.split.button.success span{border-left-color:#396516}.split.button.tiny{padding-right:3.9375em}.split.button.tiny span{width:2.84375em} |
| - | .split.button.tiny span:before{border-top-style:solid;border-width:.4375em;top:.875em;margin-left:-0.3125em}.split.button.small{padding-right:3.9375em} |
| - | .split.button.small span{width:2.8125em}.split.button.small span:before{border-top-style:solid;border-width:.5625em;top:.84375em;margin-left:-0.5625em} |
| - | .split.button.large{padding-right:6em}.split.button.large span{width:3.75em}.split.button.large span:before{border-top-style:solid;border-width:.625em;top:1.3125em;margin-left:-0.5625em} |
| - | .split.button.expand{padding-left:2em}.split.button.secondary span:before{border-color:#333 transparent transparent transparent}.split.button.radius span{-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px} |
| - | .split.button.round span{-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px} |
| - | .flex-video{position:relative;padding-top:1.5625em;padding-bottom:67.5%;height:0;margin-bottom:1em;overflow:hidden}.flex-video.widescreen{padding-bottom:57.25%} |
| - | .flex-video.vimeo{padding-top:0}.flex-video iframe,.flex-video object,.flex-video embed,.flex-video video{position:absolute;top:0;left:0;width:100%;height:100%} |
| - | .section-container,.section-container.auto{width:100%;display:block;margin-bottom:1.25em;border:1px solid #ccc;border-top:0}.section-container>section,.section-container>.section,.section-container.auto>section,.section-container.auto>.section{position:relative} |
| - | .section-container>section>.title,.section-container>.section>.title,.section-container.auto>section>.title,.section-container.auto>.section>.title{background-color:#efefef;cursor:pointer;margin-bottom:0} |
| - | .section-container>section>.title a,.section-container>.section>.title a,.section-container.auto>section>.title a,.section-container.auto>.section>.title a{padding:.9375em;display:inline-block;color:#333;font-size:.875em;white-space:nowrap} |
| - | .section-container>section>.title:hover,.section-container>.section>.title:hover,.section-container.auto>section>.title:hover,.section-container.auto>.section>.title:hover{background-color:#e2e2e2} |
| - | .section-container>section .content,.section-container>.section .content,.section-container.auto>section .content,.section-container.auto>.section .content{display:none;padding:.9375em;background-color:white} |
| - | .section-container>section .content>*:last-child,.section-container>.section .content>*:last-child,.section-container.auto>section .content>*:last-child,.section-container.auto>.section .content>*:last-child{margin-bottom:0} |
| - | .section-container>section .content>*:first-child,.section-container>.section .content>*:first-child,.section-container.auto>section .content>*:first-child,.section-container.auto>.section .content>*:first-child{padding-top:0} |
| - | .section-container>section .content>*:last-child,.section-container>.section .content>*:last-child,.section-container.auto>section .content>*:last-child,.section-container.auto>.section .content>*:last-child{padding-bottom:0} |
| - | .section-container>section.active>.content,.section-container>.section.active>.content,.section-container.auto>section.active>.content,.section-container.auto>.section.active>.content{display:block} |
| - | .section-container>section.active>.title,.section-container>.section.active>.title,.section-container.auto>section.active>.title,.section-container.auto>.section.active>.title{background:#d5d5d5} |
| - | .section-container>section.active>.title a,.section-container>.section.active>.title a,.section-container.auto>section.active>.title a,.section-container.auto>.section.active>.title a{color:#333} |
| - | .section-container>section>.title,.section-container>.section>.title,.section-container.auto>section>.title,.section-container.auto>.section>.title{top:0;width:100%;margin:0;border-top:solid 1px #ccc} |
| - | .section-container>section>.title a,.section-container>.section>.title a,.section-container.auto>section>.title a,.section-container.auto>.section>.title a{width:100%} |
| - | .section-container.tabs{border:0;position:relative}.section-container.tabs>section,.section-container.tabs>.section{border:0;position:static}.section-container.tabs>section>.title,.section-container.tabs>.section>.title{background-color:#efefef;cursor:pointer;margin-bottom:0} |
| - | .section-container.tabs>section>.title a,.section-container.tabs>.section>.title a{padding:.9375em;display:inline-block;color:#333;font-size:.875em;white-space:nowrap} |
| - | .section-container.tabs>section>.title:hover,.section-container.tabs>.section>.title:hover{background-color:#e2e2e2}.section-container.tabs>section .content,.section-container.tabs>.section .content{display:none;padding:.9375em;background-color:white} |
| - | .section-container.tabs>section .content>*:last-child,.section-container.tabs>.section .content>*:last-child{margin-bottom:0}.section-container.tabs>section .content>*:first-child,.section-container.tabs>.section .content>*:first-child{padding-top:0} |
| - | .section-container.tabs>section .content>*:last-child,.section-container.tabs>.section .content>*:last-child{padding-bottom:0}.section-container.tabs>section.active>.content,.section-container.tabs>.section.active>.content{display:block} |
| - | .section-container.tabs>section.active>.title,.section-container.tabs>.section.active>.title{background:white}.section-container.tabs>section.active>.title a,.section-container.tabs>.section.active>.title a{color:#333} |
| - | .section-container.tabs>section>.title,.section-container.tabs>.section>.title{width:auto;border:solid 1px #ccc;border-right:0;border-bottom:0;position:absolute;top:0;z-index:1} |
| - | .section-container.tabs>section>.title a,.section-container.tabs>.section>.title a{width:100%}.section-container.tabs>section:last-child .title,.section-container.tabs>.section:last-child .title{border-right:solid 1px #ccc} |
| - | .section-container.tabs>section .content,.section-container.tabs>.section .content{border:solid 1px #ccc;position:absolute;z-index:10;display:none;top:-1px} |
| - | .section-container.tabs>section.active>.title,.section-container.tabs>.section.active>.title{z-index:11;border-bottom:0;background-color:white}.section-container.tabs>section.active>.content,.section-container.tabs>.section.active>.content{position:relative} |
| - | @media only screen and (min-width:768px){.section-container.auto{border:0;position:relative}.section-container.auto>section,.section-container.auto>.section{border:0;position:static} |
| - | .section-container.auto>section>.title,.section-container.auto>.section>.title{background-color:#efefef;cursor:pointer;margin-bottom:0}.section-container.auto>section>.title a,.section-container.auto>.section>.title a{padding:.9375em;display:inline-block;color:#333;font-size:.875em;white-space:nowrap} |
| - | .section-container.auto>section>.title:hover,.section-container.auto>.section>.title:hover{background-color:#e2e2e2}.section-container.auto>section .content,.section-container.auto>.section .content{display:none;padding:.9375em;background-color:white} |
| - | .section-container.auto>section .content>*:last-child,.section-container.auto>.section .content>*:last-child{margin-bottom:0}.section-container.auto>section .content>*:first-child,.section-container.auto>.section .content>*:first-child{padding-top:0} |
| - | .section-container.auto>section .content>*:last-child,.section-container.auto>.section .content>*:last-child{padding-bottom:0}.section-container.auto>section.active>.content,.section-container.auto>.section.active>.content{display:block} |
| - | .section-container.auto>section.active>.title,.section-container.auto>.section.active>.title{background:white}.section-container.auto>section.active>.title a,.section-container.auto>.section.active>.title a{color:#333} |
| - | .section-container.auto>section>.title,.section-container.auto>.section>.title{width:auto;border:solid 1px #ccc;border-right:0;border-bottom:0;position:absolute;top:0;z-index:1} |
| - | .section-container.auto>section>.title a,.section-container.auto>.section>.title a{width:100%}.section-container.auto>section:last-child .title,.section-container.auto>.section:last-child .title{border-right:solid 1px #ccc} |
| - | .section-container.auto>section .content,.section-container.auto>.section .content{border:solid 1px #ccc;position:absolute;z-index:10;display:none;top:-1px} |
| - | .section-container.auto>section.active>.title,.section-container.auto>.section.active>.title{z-index:11;border-bottom:0;background-color:white}.section-container.auto>section.active>.content,.section-container.auto>.section.active>.content{position:relative} |
| - | .section-container.accordion .section{padding-top:0!important}.section-container.vertical-tabs{border:1px solid #ccc;position:relative}.section-container.vertical-tabs section,.section-container.vertical-tabs .section{padding-top:0!important;border:0;position:static} |
| - | .section-container.vertical-tabs section>.title,.section-container.vertical-tabs .section>.title{background-color:#efefef;cursor:pointer;margin-bottom:0} |
| - | .section-container.vertical-tabs section>.title a,.section-container.vertical-tabs .section>.title a{padding:.9375em;display:inline-block;color:#333;font-size:.875em;white-space:nowrap} |
| - | .section-container.vertical-tabs section>.title:hover,.section-container.vertical-tabs .section>.title:hover{background-color:#e2e2e2}.section-container.vertical-tabs section .content,.section-container.vertical-tabs .section .content{display:none;padding:.9375em;background-color:white} |
| - | .section-container.vertical-tabs section .content>*:last-child,.section-container.vertical-tabs .section .content>*:last-child{margin-bottom:0}.section-container.vertical-tabs section .content>*:first-child,.section-container.vertical-tabs .section .content>*:first-child{padding-top:0} |
| - | .section-container.vertical-tabs section .content>*:last-child,.section-container.vertical-tabs .section .content>*:last-child{padding-bottom:0}.section-container.vertical-tabs section.active>.content,.section-container.vertical-tabs .section.active>.content{display:block} |
| - | .section-container.vertical-tabs section.active>.title,.section-container.vertical-tabs .section.active>.title{background:#d5d5d5}.section-container.vertical-tabs section.active>.title a,.section-container.vertical-tabs .section.active>.title a{color:#333} |
| - | .section-container.vertical-tabs section>.title,.section-container.vertical-tabs .section>.title{position:absolute;border-top:solid 1px #ccc;width:12.5em} |
| - | .section-container.vertical-tabs section:first-child .title,.section-container.vertical-tabs .section:first-child .title{border-top:0}.section-container.vertical-tabs section .content,.section-container.vertical-tabs .section .content{display:block;position:relative;left:12.5em;border-left:solid 1px #ccc;z-index:10} |
| - | .section-container.vertical-tabs section.active>.title,.section-container.vertical-tabs .section.active>.title{background-color:#d5d5d5;width:12.5625em;border-right:solid 0 transparent;z-index:11} |
| - | .section-container.vertical-tabs section.active:last-child .title,.section-container.vertical-tabs .section.active:last-child .title{border-bottom:0}.section-container.vertical-nav{border:0;position:relative} |
| - | .section-container.vertical-nav>section,.section-container.vertical-nav>.section{padding-top:0!important;position:relative}.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>.title{background-color:#efefef;cursor:pointer;margin-bottom:0} |
| - | .section-container.vertical-nav>section>.title a,.section-container.vertical-nav>.section>.title a{padding:.9375em;display:inline-block;color:#333;font-size:.875em;white-space:nowrap} |
| - | .section-container.vertical-nav>section>.title:hover,.section-container.vertical-nav>.section>.title:hover{background-color:#e2e2e2}.section-container.vertical-nav>section .content,.section-container.vertical-nav>.section .content{display:none;padding:.9375em;background-color:white} |
| - | .section-container.vertical-nav>section .content>*:last-child,.section-container.vertical-nav>.section .content>*:last-child{margin-bottom:0}.section-container.vertical-nav>section .content>*:first-child,.section-container.vertical-nav>.section .content>*:first-child{padding-top:0} |
| - | .section-container.vertical-nav>section .content>*:last-child,.section-container.vertical-nav>.section .content>*:last-child{padding-bottom:0}.section-container.vertical-nav>section.active>.content,.section-container.vertical-nav>.section.active>.content{display:block} |
| - | .section-container.vertical-nav>section.active>.title,.section-container.vertical-nav>.section.active>.title{background:#d5d5d5}.section-container.vertical-nav>section.active>.title a,.section-container.vertical-nav>.section.active>.title a{color:#333} |
| - | .section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>.title{border-top:0;border:solid 1px #ccc}.section-container.vertical-nav>section>.title a,.section-container.vertical-nav>.section>.title a{display:block;width:100%} |
| - | .section-container.vertical-nav>section .content,.section-container.vertical-nav>.section .content{display:none}.section-container.vertical-nav>section:first-child .title,.section-container.vertical-nav>.section:first-child .title{border-bottom:0} |
| - | .section-container.vertical-nav>section.active>.content,.section-container.vertical-nav>.section.active>.content{display:block;position:absolute;left:100%;top:0;z-index:999;min-width:12.5em;border:solid 1px #ccc} |
| - | .section-container.horizontal-nav{position:relative;background:#efefef;border:1px solid #ccc}.section-container.horizontal-nav>section,.section-container.horizontal-nav>.section{padding-top:0;border:0;position:static} |
| - | .section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>.title{background-color:#efefef;cursor:pointer;margin-bottom:0} |
| - | .section-container.horizontal-nav>section>.title a,.section-container.horizontal-nav>.section>.title a{padding:.9375em;display:inline-block;color:#333;font-size:.875em;white-space:nowrap} |
| - | .section-container.horizontal-nav>section>.title:hover,.section-container.horizontal-nav>.section>.title:hover{background-color:#e2e2e2}.section-container.horizontal-nav>section .content,.section-container.horizontal-nav>.section .content{display:none;padding:.9375em;background-color:white} |
| - | .section-container.horizontal-nav>section .content>*:last-child,.section-container.horizontal-nav>.section .content>*:last-child{margin-bottom:0}.section-container.horizontal-nav>section .content>*:first-child,.section-container.horizontal-nav>.section .content>*:first-child{padding-top:0} |
| - | .section-container.horizontal-nav>section .content>*:last-child,.section-container.horizontal-nav>.section .content>*:last-child{padding-bottom:0}.section-container.horizontal-nav>section.active>.content,.section-container.horizontal-nav>.section.active>.content{display:block} |
| - | .section-container.horizontal-nav>section.active>.title,.section-container.horizontal-nav>.section.active>.title{background:#d5d5d5}.section-container.horizontal-nav>section.active>.title a,.section-container.horizontal-nav>.section.active>.title a{color:#333} |
| - | .section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>.title{width:auto;border:solid 1px #ccc;border-left:0;top:-1px;position:absolute;z-index:1} |
| - | .section-container.horizontal-nav>section>.title a,.section-container.horizontal-nav>.section>.title a{width:100%}.section-container.horizontal-nav>section .content,.section-container.horizontal-nav>.section .content{display:none} |
| - | .section-container.horizontal-nav>section.active>.content,.section-container.horizontal-nav>.section.active>.content{display:block;position:absolute;z-index:999;left:0;top:-2px;min-width:12.5em;border:solid 1px #ccc} |
| - | }.no-js .section-container.auto,.no-js .section-container.accordion,.no-js .section-container.tabs,.no-js .section-container.vertical-tabs,.no-js .section-container.vertical-nav,.no-js .section-container.horizontal-nav{width:100%;display:block;margin-bottom:1.25em;border:1px solid #ccc;border-top:0} |
| - | .no-js .section-container.auto>section,.no-js .section-container.auto>.section,.no-js .section-container.accordion>section,.no-js .section-container.accordion>.section,.no-js .section-container.tabs>section,.no-js .section-container.tabs>.section,.no-js .section-container.vertical-tabs>section,.no-js .section-container.vertical-tabs>.section,.no-js .section-container.vertical-nav>section,.no-js .section-container.vertical-nav>.section,.no-js .section-container.horizontal-nav>section,.no-js .section-container.horizontal-nav>.section{position:relative} |
| - | .no-js .section-container.auto>section>.title,.no-js .section-container.auto>.section>.title,.no-js .section-container.accordion>section>.title,.no-js .section-container.accordion>.section>.title,.no-js .section-container.tabs>section>.title,.no-js .section-container.tabs>.section>.title,.no-js .section-container.vertical-tabs>section>.title,.no-js .section-container.vertical-tabs>.section>.title,.no-js .section-container.vertical-nav>section>.title,.no-js .section-container.vertical-nav>.section>.title,.no-js .section-container.horizontal-nav>section>.title,.no-js .section-container.horizontal-nav>.section>.title{background-color:#efefef;cursor:pointer;margin-bottom:0} |
| - | .no-js .section-container.auto>section>.title a,.no-js .section-container.auto>.section>.title a,.no-js .section-container.accordion>section>.title a,.no-js .section-container.accordion>.section>.title a,.no-js .section-container.tabs>section>.title a,.no-js .section-container.tabs>.section>.title a,.no-js .section-container.vertical-tabs>section>.title a,.no-js .section-container.vertical-tabs>.section>.title a,.no-js .section-container.vertical-nav>section>.title a,.no-js .section-container.vertical-nav>.section>.title a,.no-js .section-container.horizontal-nav>section>.title a,.no-js .section-container.horizontal-nav>.section>.title a{padding:.9375em;display:inline-block;color:#333;font-size:.875em;white-space:nowrap} |
| - | .no-js .section-container.auto>section>.title:hover,.no-js .section-container.auto>.section>.title:hover,.no-js .section-container.accordion>section>.title:hover,.no-js .section-container.accordion>.section>.title:hover,.no-js .section-container.tabs>section>.title:hover,.no-js .section-container.tabs>.section>.title:hover,.no-js .section-container.vertical-tabs>section>.title:hover,.no-js .section-container.vertical-tabs>.section>.title:hover,.no-js .section-container.vertical-nav>section>.title:hover,.no-js .section-container.vertical-nav>.section>.title:hover,.no-js .section-container.horizontal-nav>section>.title:hover,.no-js .section-container.horizontal-nav>.section>.title:hover{background-color:#e2e2e2} |
| - | .no-js .section-container.auto>section .content,.no-js .section-container.auto>.section .content,.no-js .section-container.accordion>section .content,.no-js .section-container.accordion>.section .content,.no-js .section-container.tabs>section .content,.no-js .section-container.tabs>.section .content,.no-js .section-container.vertical-tabs>section .content,.no-js .section-container.vertical-tabs>.section .content,.no-js .section-container.vertical-nav>section .content,.no-js .section-container.vertical-nav>.section .content,.no-js .section-container.horizontal-nav>section .content,.no-js .section-container.horizontal-nav>.section .content{display:none;padding:.9375em;background-color:white} |
| - | .no-js .section-container.auto>section .content>*:last-child,.no-js .section-container.auto>.section .content>*:last-child,.no-js .section-container.accordion>section .content>*:last-child,.no-js .section-container.accordion>.section .content>*:last-child,.no-js .section-container.tabs>section .content>*:last-child,.no-js .section-container.tabs>.section .content>*:last-child,.no-js .section-container.vertical-tabs>section .content>*:last-child,.no-js .section-container.vertical-tabs>.section .content>*:last-child,.no-js .section-container.vertical-nav>section .content>*:last-child,.no-js .section-container.vertical-nav>.section .content>*:last-child,.no-js .section-container.horizontal-nav>section .content>*:last-child,.no-js .section-container.horizontal-nav>.section .content>*:last-child{margin-bottom:0} |
| - | .no-js .section-container.auto>section .content>*:first-child,.no-js .section-container.auto>.section .content>*:first-child,.no-js .section-container.accordion>section .content>*:first-child,.no-js .section-container.accordion>.section .content>*:first-child,.no-js .section-container.tabs>section .content>*:first-child,.no-js .section-container.tabs>.section .content>*:first-child,.no-js .section-container.vertical-tabs>section .content>*:first-child,.no-js .section-container.vertical-tabs>.section .content>*:first-child,.no-js .section-container.vertical-nav>section .content>*:first-child,.no-js .section-container.vertical-nav>.section .content>*:first-child,.no-js .section-container.horizontal-nav>section .content>*:first-child,.no-js .section-container.horizontal-nav>.section .content>*:first-child{padding-top:0} |
| - | .no-js .section-container.auto>section .content>*:last-child,.no-js .section-container.auto>.section .content>*:last-child,.no-js .section-container.accordion>section .content>*:last-child,.no-js .section-container.accordion>.section .content>*:last-child,.no-js .section-container.tabs>section .content>*:last-child,.no-js .section-container.tabs>.section .content>*:last-child,.no-js .section-container.vertical-tabs>section .content>*:last-child,.no-js .section-container.vertical-tabs>.section .content>*:last-child,.no-js .section-container.vertical-nav>section .content>*:last-child,.no-js .section-container.vertical-nav>.section .content>*:last-child,.no-js .section-container.horizontal-nav>section .content>*:last-child,.no-js .section-container.horizontal-nav>.section .content>*:last-child{padding-bottom:0} |
| - | .no-js .section-container.auto>section.active>.content,.no-js .section-container.auto>.section.active>.content,.no-js .section-container.accordion>section.active>.content,.no-js .section-container.accordion>.section.active>.content,.no-js .section-container.tabs>section.active>.content,.no-js .section-container.tabs>.section.active>.content,.no-js .section-container.vertical-tabs>section.active>.content,.no-js .section-container.vertical-tabs>.section.active>.content,.no-js .section-container.vertical-nav>section.active>.content,.no-js .section-container.vertical-nav>.section.active>.content,.no-js .section-container.horizontal-nav>section.active>.content,.no-js .section-container.horizontal-nav>.section.active>.content{display:block} |
| - | .no-js .section-container.auto>section.active>.title,.no-js .section-container.auto>.section.active>.title,.no-js .section-container.accordion>section.active>.title,.no-js .section-container.accordion>.section.active>.title,.no-js .section-container.tabs>section.active>.title,.no-js .section-container.tabs>.section.active>.title,.no-js .section-container.vertical-tabs>section.active>.title,.no-js .section-container.vertical-tabs>.section.active>.title,.no-js .section-container.vertical-nav>section.active>.title,.no-js .section-container.vertical-nav>.section.active>.title,.no-js .section-container.horizontal-nav>section.active>.title,.no-js .section-container.horizontal-nav>.section.active>.title{background:#d5d5d5} |
| - | .no-js .section-container.auto>section.active>.title a,.no-js .section-container.auto>.section.active>.title a,.no-js .section-container.accordion>section.active>.title a,.no-js .section-container.accordion>.section.active>.title a,.no-js .section-container.tabs>section.active>.title a,.no-js .section-container.tabs>.section.active>.title a,.no-js .section-container.vertical-tabs>section.active>.title a,.no-js .section-container.vertical-tabs>.section.active>.title a,.no-js .section-container.vertical-nav>section.active>.title a,.no-js .section-container.vertical-nav>.section.active>.title a,.no-js .section-container.horizontal-nav>section.active>.title a,.no-js .section-container.horizontal-nav>.section.active>.title a{color:#333} |
| - | .no-js .section-container.auto>section>.title,.no-js .section-container.auto>.section>.title,.no-js .section-container.accordion>section>.title,.no-js .section-container.accordion>.section>.title,.no-js .section-container.tabs>section>.title,.no-js .section-container.tabs>.section>.title,.no-js .section-container.vertical-tabs>section>.title,.no-js .section-container.vertical-tabs>.section>.title,.no-js .section-container.vertical-nav>section>.title,.no-js .section-container.vertical-nav>.section>.title,.no-js .section-container.horizontal-nav>section>.title,.no-js .section-container.horizontal-nav>.section>.title{top:0;width:100%;margin:0;border-top:solid 1px #ccc} |
| - | .no-js .section-container.auto>section>.title a,.no-js .section-container.auto>.section>.title a,.no-js .section-container.accordion>section>.title a,.no-js .section-container.accordion>.section>.title a,.no-js .section-container.tabs>section>.title a,.no-js .section-container.tabs>.section>.title a,.no-js .section-container.vertical-tabs>section>.title a,.no-js .section-container.vertical-tabs>.section>.title a,.no-js .section-container.vertical-nav>section>.title a,.no-js .section-container.vertical-nav>.section>.title a,.no-js .section-container.horizontal-nav>section>.title a,.no-js .section-container.horizontal-nav>.section>.title a{width:100%} |
| - | .no-js .section-container.auto>section .title,.no-js .section-container.auto>.section .title,.no-js .section-container.accordion>section .title,.no-js .section-container.accordion>.section .title,.no-js .section-container.tabs>section .title,.no-js .section-container.tabs>.section .title,.no-js .section-container.vertical-tabs>section .title,.no-js .section-container.vertical-tabs>.section .title,.no-js .section-container.vertical-nav>section .title,.no-js .section-container.vertical-nav>.section .title,.no-js .section-container.horizontal-nav>section .title,.no-js .section-container.horizontal-nav>.section .title{position:static;width:100%;border-left:0;border-right:0} |
| - | .no-js .section-container.auto>section .content,.no-js .section-container.auto>.section .content,.no-js .section-container.accordion>section .content,.no-js .section-container.accordion>.section .content,.no-js .section-container.tabs>section .content,.no-js .section-container.tabs>.section .content,.no-js .section-container.vertical-tabs>section .content,.no-js .section-container.vertical-tabs>.section .content,.no-js .section-container.vertical-nav>section .content,.no-js .section-container.vertical-nav>.section .content,.no-js .section-container.horizontal-nav>section .content,.no-js .section-container.horizontal-nav>.section .content{position:static;display:block;width:100%;border-left:0;border-right:0;border-bottom:0} |
| - | .contain-to-grid{width:100%;background:#111}.contain-to-grid .top-bar{margin-bottom:0}.fixed{width:100%;left:0;position:fixed;top:0;z-index:99}.top-bar{overflow:hidden;height:45px;line-height:45px;position:relative;background:#111;margin-bottom:1.875em} |
| - | .top-bar ul{margin-bottom:0;list-style:none}.top-bar .row{max-width:none}.top-bar form,.top-bar input{margin-bottom:0}.top-bar input{height:2.45em}.top-bar .button{padding-top:.5em;padding-bottom:.5em;margin-bottom:0} |
| - | .top-bar .title-area{position:relative;margin:0}.top-bar .name{height:45px;margin:0;font-size:16px}.top-bar .name h1{line-height:45px;font-size:1.0625em;margin:0} |
| - | .top-bar .name h1 a{font-weight:bold;color:white;width:50%;display:block;padding:0 15px}.top-bar .toggle-topbar{position:absolute;right:0;top:0}.top-bar .toggle-topbar a{color:white;text-transform:uppercase;font-size:.8125em;font-weight:bold;position:relative;display:block;padding:0 15px;height:45px;line-height:45px} |
| - | .top-bar .toggle-topbar.menu-icon{right:15px;top:50%;margin-top:-16px;padding-left:40px}.top-bar .toggle-topbar.menu-icon a{text-indent:-48px;width:34px;height:34px;line-height:33px;padding:0;color:white} |
| - | .top-bar .toggle-topbar.menu-icon a span{position:absolute;right:0;display:block;width:16px;height:0;-webkit-box-shadow:0 10px 0 1px white,0 16px 0 1px white,0 22px 0 1px white;box-shadow:0 10px 0 1px white,0 16px 0 1px white,0 22px 0 1px white} |
| - | .top-bar.expanded{height:auto;background:transparent}.top-bar.expanded .title-area{background:#111}.top-bar.expanded .toggle-topbar a{color:#888}.top-bar.expanded .toggle-topbar a span{-webkit-box-shadow:0 10px 0 1px #888,0 16px 0 1px #888,0 22px 0 1px #888;box-shadow:0 10px 0 1px #888,0 16px 0 1px #888,0 22px 0 1px #888} |
| - | .top-bar-section{left:0;position:relative;width:auto;-webkit-transition:left 300ms ease-out;-moz-transition:left 300ms ease-out;transition:left 300ms ease-out} |
| - | .top-bar-section ul{width:100%;height:auto;display:block;background:#222;font-size:16px;margin:0}.top-bar-section .divider,.top-bar-section [role="separator"]{border-bottom:solid 1px #2b2b2b;border-top:solid 1px black;clear:both;height:1px;width:100%} |
| - | .top-bar-section ul li>a{display:block;width:100%;color:white;padding:12px 0 12px 0;padding-left:15px;font-size:.8125em;font-weight:bold;background:#222} |
| - | .top-bar-section ul li>a.hover{background:#090909;color:white}.top-bar-section ul li>a.button{background:#2ba6cb;font-size:.8125em}.top-bar-section ul li>a.button.hover{background:#2284a1} |
| - | .top-bar-section ul li>a.button.secondary{background:#e9e9e9}.top-bar-section ul li>a.button.secondary.hover{background:#d0d0d0}.top-bar-section ul li>a.button.success{background:#5da423} |
| - | .top-bar-section ul li>a.button.success.hover{background:#457a1a}.top-bar-section ul li>a.button.alert{background:#c60f13}.top-bar-section ul li>a.button.alert.hover{background:#970b0e} |
| - | .top-bar-section ul li.active>a{background:#090909;color:white}.top-bar-section .has-form{padding:15px}.top-bar-section .has-dropdown{position:relative} |
| - | .top-bar-section .has-dropdown>a:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:transparent transparent transparent rgba(255,255,255,0.5);border-left-style:solid;margin-right:15px;margin-top:-4.5px;position:absolute;top:50%;right:0} |
| - | .top-bar-section .has-dropdown.moved{position:static}.top-bar-section .has-dropdown.moved>.dropdown{visibility:visible}.top-bar-section .dropdown{position:absolute;left:100%;top:0;visibility:hidden;z-index:99} |
| - | .top-bar-section .dropdown li{width:100%;height:auto}.top-bar-section .dropdown li a{font-weight:normal;padding:8px 15px}.top-bar-section .dropdown li.title h5{margin-bottom:0} |
| - | .top-bar-section .dropdown li.title h5 a{color:white;line-height:22.5px;display:block}.top-bar-section .dropdown label{padding:8px 15px 2px;margin-bottom:0;text-transform:uppercase;color:#555;font-weight:bold;font-size:.625em} |
| - | .top-bar-js-breakpoint{width:58.75em!important;visibility:hidden}.js-generated{display:block}@media only screen and (min-width:58.75em){.top-bar{background:#111;*zoom:1;overflow:visible} |
| - | .top-bar:before,.top-bar:after{content:" ";display:table}.top-bar:after{clear:both}.top-bar .toggle-topbar{display:none} |
| - | .top-bar .title-area{float:left}.top-bar .name h1 a{width:auto}.top-bar input,.top-bar .button{line-height:2em;font-size:.875em;height:2em;padding:0 10px;position:relative;top:8px} |
| - | .top-bar.expanded{background:#111}.contain-to-grid .top-bar{max-width:62.5em;margin:0 auto}.top-bar-section{-webkit-transition:none 0 0;-moz-transition:none 0 0;transition:none 0 0;left:0!important} |
| - | .top-bar-section ul{width:auto;height:auto!important;display:inline}.top-bar-section ul li{float:left}.top-bar-section ul li .js-generated{display:none} |
| - | .top-bar-section li a:not(.button){padding:0 15px;line-height:45px;background:#111}.top-bar-section li a:not(.button).hover{background:black}.top-bar-section .has-dropdown>a{padding-right:35px!important} |
| - | .top-bar-section .has-dropdown>a:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:rgba(255,255,255,0.5) transparent transparent transparent;border-top-style:solid;margin-top:-2.5px;top:22.5px} |
| - | .top-bar-section .has-dropdown.moved{position:relative}.top-bar-section .has-dropdown.moved>.dropdown{visibility:hidden}.top-bar-section .has-dropdown.hover>.dropdown{visibility:visible} |
| - | .top-bar-section .has-dropdown .dropdown li.has-dropdown>a:after{border:0;content:"\00bb";margin-top:-16px;right:5px}.top-bar-section .dropdown{left:0;top:auto;background:transparent;min-width:100%} |
| - | .top-bar-section .dropdown li a{color:white;line-height:1;white-space:nowrap;padding:7px 15px;background:#1e1e1e}.top-bar-section .dropdown li label{white-space:nowrap;background:#1e1e1e} |
| - | .top-bar-section .dropdown li .dropdown{left:100%;top:0}.top-bar-section>ul>.divider,.top-bar-section>ul>[role="separator"]{border-bottom:0;border-top:0;border-right:solid 1px #2b2b2b;border-left:solid 1px black;clear:none;height:45px;width:0} |
| - | .top-bar-section .has-form{background:#111;padding:0 15px;height:45px}.top-bar-section ul.right li .dropdown{left:auto;right:0}.top-bar-section ul.right li .dropdown li .dropdown{right:100%} |
| - | }@-webkit-keyframes rotate{from{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@-moz-keyframes rotate{from{-webkit-transform:rotate(0deg)} |
| - | to{-webkit-transform:rotate(360deg)}}@-o-keyframes rotate{from{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes rotate{from{-webkit-transform:rotate(0deg)} |
| - | to{-webkit-transform:rotate(360deg)}}.slideshow-wrapper{position:relative}.slideshow-wrapper ul{list-style-type:none;margin:0}.slideshow-wrapper ul li,.slideshow-wrapper ul li .orbit-caption{display:none} |
| - | .slideshow-wrapper ul li:first-child{display:block}.slideshow-wrapper .orbit-container{background-color:transparent}.slideshow-wrapper .orbit-container li{display:block} |
| - | .slideshow-wrapper .orbit-container li .orbit-caption{display:block}.preloader{display:block;width:40px;height:40px;position:absolute;top:50%;left:50%;margin-top:-20px;margin-left:-20px;border:solid 3px;border-color:#555 #fff;-webkit-border-radius:1000px;border-radius:1000px;-webkit-animation-name:rotate;-webkit-animation-duration:1.5s;-webkit-animation-iteration-count:infinite;-webkit-animation-timing-function:linear;-moz-animation-name:rotate;-moz-animation-duration:1.5s;-moz-animation-iteration-count:infinite;-moz-animation-timing-function:linear;-o-animation-name:rotate;-o-animation-duration:1.5s;-o-animation-iteration-count:infinite;-o-animation-timing-function:linear;animation-name:rotate;animation-duration:1.5s;animation-iteration-count:infinite;animation-timing-function:linear} |
| - | .orbit-container{overflow:hidden;width:100%;position:relative;background:whitesmoke}.orbit-container .orbit-slides-container{list-style:none;margin:0;padding:0;position:relative} |
| - | .orbit-container .orbit-slides-container img{display:block}.orbit-container .orbit-slides-container>*{position:relative;float:left;height:auto}.orbit-container .orbit-slides-container>* .orbit-caption{position:absolute;bottom:0;background-color:black;background-color:rgba(0,0,0,0.6);color:white;width:100%;padding:10px 14px;font-size:.875em} |
| - | .orbit-container .orbit-slide-number{position:absolute;top:10px;left:10px;font-size:12px;color:white;background:rgba(0,0,0,0)}.orbit-container .orbit-slide-number span{font-weight:700;padding:.3125em} |
| - | .orbit-container .orbit-timer{position:absolute;top:10px;right:10px;height:6px;width:100px}.orbit-container .orbit-timer .orbit-progress{height:100%;background-color:black;background-color:rgba(0,0,0,0.6);display:block;width:0} |
| - | .orbit-container .orbit-timer>span{display:none;position:absolute;top:10px;right:0;width:11px;height:14px;border:solid 4px #000;border-top:0;border-bottom:0} |
| - | .orbit-container .orbit-timer.paused>span{right:-6px;top:9px;width:11px;height:14px;border:inset 8px;border-right-style:solid;border-color:transparent transparent transparent #000} |
| - | .orbit-container:hover .orbit-timer>span{display:block}.orbit-container .orbit-prev,.orbit-container .orbit-next{position:absolute;top:50%;margin-top:-25px;background-color:black;background-color:rgba(0,0,0,0.6);width:50px;height:60px;line-height:50px;color:white;text-indent:-9999px!important} |
| - | .orbit-container .orbit-prev>span,.orbit-container .orbit-next>span{position:absolute;top:50%;margin-top:-16px;display:block;width:0;height:0;border:inset 16px} |
| - | .orbit-container .orbit-prev{left:0}.orbit-container .orbit-prev>span{border-right-style:solid;border-color:transparent;border-right-color:#fff}.orbit-container .orbit-prev:hover>span{border-right-color:#ccc} |
| - | .orbit-container .orbit-next{right:0}.orbit-container .orbit-next>span{border-color:transparent;border-left-style:solid;border-left-color:#fff;left:50%;margin-left:-8px} |
| - | .orbit-container .orbit-next:hover>span{border-left-color:#ccc}.orbit-bullets{margin:0 auto 30px auto;overflow:hidden;position:relative;top:10px}.orbit-bullets li{display:block;width:18px;height:18px;background:#999;float:left;margin-right:6px;border:solid 2px #222;-webkit-border-radius:1000px;border-radius:1000px} |
| - | .orbit-bullets li.active{background:#222}.orbit-bullets li:last-child{margin-right:0}.touch .orbit-container .orbit-prev,.touch .orbit-container .orbit-next{display:none} |
| - | .touch .orbit-bullets{display:none}@media only screen and (min-width:768px){.touch .orbit-container .orbit-prev,.touch .orbit-container .orbit-next{display:inherit} |
| - | .touch .orbit-bullets{display:block}}.reveal-modal-bg{position:fixed;height:100%;width:100%;background:black;background:rgba(0,0,0,0.45);z-index:98;display:none;top:0;left:0} |
| - | .reveal-modal{visibility:hidden;display:none;position:absolute;left:50%;z-index:99;height:auto;margin-left:-40%;width:80%;background-color:white;padding:1.25em;border:solid 1px #666;-webkit-box-shadow:0 0 10px rgba(0,0,0,0.4);box-shadow:0 0 10px rgba(0,0,0,0.4);top:50px} |
| - | .reveal-modal .column,.reveal-modal .columns{min-width:0}.reveal-modal>:first-child{margin-top:0}.reveal-modal>:last-child{margin-bottom:0}.reveal-modal .close-reveal-modal{font-size:1.375em;line-height:1;position:absolute;top:.5em;right:.6875em;color:#aaa;font-weight:bold;cursor:pointer} |
| - | @media only screen and (min-width:768px){.reveal-modal{padding:1.875em;top:6.25em}.reveal-modal.tiny{margin-left:-15%;width:30%}.reveal-modal.small{margin-left:-20%;width:40%} |
| - | .reveal-modal.medium{margin-left:-30%;width:60%}.reveal-modal.large{margin-left:-35%;width:70%}.reveal-modal.xlarge{margin-left:-47.5%;width:95%}}@media print{.reveal-modal{background:#fff!important} |
| - | }.joyride-list{display:none}.joyride-tip-guide{display:none;position:absolute;background:black;color:white;z-index:101;top:0;left:2.5%;font-family:inherit;font-weight:normal;width:95%} |
| - | .lt-ie9 .joyride-tip-guide{max-width:800px;left:50%;margin-left:-400px}.joyride-content-wrapper{width:100%;padding:1.125em 1.25em 1.5em}.joyride-content-wrapper .button{margin-bottom:0!important} |
| - | .joyride-tip-guide .joyride-nub{display:block;position:absolute;left:22px;width:0;height:0;border:inset 14px}.joyride-tip-guide .joyride-nub.top{border-top-style:solid;border-color:black;border-top-color:transparent!important;border-left-color:transparent!important;border-right-color:transparent!important;top:-28px} |
| - | .joyride-tip-guide .joyride-nub.bottom{border-bottom-style:solid;border-color:black!important;border-bottom-color:transparent!important;border-left-color:transparent!important;border-right-color:transparent!important;bottom:-28px} |
| - | .joyride-tip-guide .joyride-nub.right{right:-28px}.joyride-tip-guide .joyride-nub.left{left:-28px}.joyride-tip-guide h1,.joyride-tip-guide h2,.joyride-tip-guide h3,.joyride-tip-guide h4,.joyride-tip-guide h5,.joyride-tip-guide h6{line-height:1.25;margin:0;font-weight:bold;color:white} |
| - | .joyride-tip-guide p{margin:0 0 1.125em 0;font-size:.875em;line-height:1.3}.joyride-timer-indicator-wrap{width:50px;height:3px;border:solid 1px #555;position:absolute;right:1.0625em;bottom:1em} |
| - | .joyride-timer-indicator{display:block;width:0;height:inherit;background:#666}.joyride-close-tip{position:absolute;right:12px;top:10px;color:#777!important;text-decoration:none;font-size:30px;font-weight:normal;line-height:.5!important} |
| - | .joyride-close-tip:hover,.joyride-close-tip:focus{color:#eee!important}.joyride-modal-bg{position:fixed;height:100%;width:100%;background:transparent;background:rgba(0,0,0,0.5);z-index:100;display:none;top:0;left:0;cursor:pointer} |
| - | .joyride-expose-wrapper{background-color:#fff;position:absolute;border-radius:3px;z-index:102;-moz-box-shadow:0 0 30px #fff;-webkit-box-shadow:0 0 15px #fff;box-shadow:0 0 15px #fff} |
| - | .joyride-expose-cover{background:transparent;border-radius:3px;position:absolute;z-index:9999;top:0;left:0}@media only screen and (min-width:768px){.joyride-tip-guide{width:300px;left:inherit} |
| - | .joyride-tip-guide .joyride-nub.bottom{border-color:black!important;border-bottom-color:transparent!important;border-left-color:transparent!important;border-right-color:transparent!important;bottom:-28px} |
| - | .joyride-tip-guide .joyride-nub.right{border-color:black!important;border-top-color:transparent!important;border-right-color:transparent!important;border-bottom-color:transparent!important;top:22px;left:auto;right:-28px} |
| - | .joyride-tip-guide .joyride-nub.left{border-color:black!important;border-top-color:transparent!important;border-left-color:transparent!important;border-bottom-color:transparent!important;top:22px;left:-28px;right:auto} |
| - | }[data-clearing]{*zoom:1;margin-bottom:0;list-style:none}[data-clearing]:before,[data-clearing]:after{content:" ";display:table} |
| - | [data-clearing]:after{clear:both}[data-clearing] li{float:left;margin-right:10px}.clearing-blackout{background:#111;position:fixed;width:100%;height:100%;top:0;left:0;z-index:998} |
| - | .clearing-blackout .clearing-close{display:block}.clearing-container{position:relative;z-index:998;height:100%;overflow:hidden;margin:0}.visible-img{height:95%;position:relative} |
| - | .visible-img img{position:absolute;left:50%;top:50%;margin-left:-50%;max-height:100%;max-width:100%}.clearing-caption{color:white;line-height:1.3;margin-bottom:0;text-align:center;bottom:0;background:#111;width:100%;padding:10px 30px;position:absolute;left:0} |
| - | .clearing-close{z-index:999;padding-left:20px;padding-top:10px;font-size:40px;line-height:1;color:white;display:none}.clearing-close:hover,.clearing-close:focus{color:#ccc} |
| - | .clearing-assembled .clearing-container{height:100%}.clearing-assembled .clearing-container .carousel>ul{display:none}.clearing-feature li{display:none} |
| - | .clearing-feature li.clearing-featured-img{display:block}@media only screen and (min-width:768px){.clearing-main-prev,.clearing-main-next{position:absolute;height:100%;width:40px;top:0} |
| - | .clearing-main-prev>span,.clearing-main-next>span{position:absolute;top:50%;display:block;width:0;height:0;border:solid 16px}.clearing-main-prev{left:0} |
| - | .clearing-main-prev>span{left:5px;border-color:transparent;border-right-color:white}.clearing-main-next{right:0}.clearing-main-next>span{border-color:transparent;border-left-color:white} |
| - | .clearing-main-prev.disabled,.clearing-main-next.disabled{opacity:.5}.clearing-assembled .clearing-container .carousel{background:#111;height:150px;margin-top:5px} |
| - | .clearing-assembled .clearing-container .carousel>ul{display:block;z-index:999;width:200%;height:100%;margin-left:0;position:relative;left:0}.clearing-assembled .clearing-container .carousel>ul li{display:block;width:175px;height:inherit;padding:0;float:left;overflow:hidden;margin-right:1px;position:relative;cursor:pointer;opacity:.4} |
| - | .clearing-assembled .clearing-container .carousel>ul li.fix-height img{min-height:100%;height:100%;max-width:none}.clearing-assembled .clearing-container .carousel>ul li a.th{border:0;-webkit-box-shadow:none;box-shadow:none;display:block} |
| - | .clearing-assembled .clearing-container .carousel>ul li img{cursor:pointer!important;min-width:100%!important}.clearing-assembled .clearing-container .carousel>ul li.visible{opacity:1} |
| - | .clearing-assembled .clearing-container .visible-img{background:#111;overflow:hidden;height:75%}.clearing-close{position:absolute;top:10px;right:20px;padding-left:0;padding-top:0} |
| - | }.alert-box{border-style:solid;border-width:1px;display:block;font-weight:bold;margin-bottom:1.25em;position:relative;padding:.6875em 1.3125em .75em .6875em;font-size:.875em;background-color:#2ba6cb;border-color:#2284a1;color:white} |
| - | .alert-box .close{font-size:1.375em;padding:5px 4px 4px;line-height:0;position:absolute;top:.4375em;right:.3125em;color:#333;opacity:.3}.alert-box .close:hover,.alert-box .close:focus{opacity:.5} |
| - | .alert-box.radius{-webkit-border-radius:3px;border-radius:3px}.alert-box.round{-webkit-border-radius:1000px;border-radius:1000px}.alert-box.success{background-color:#5da423;border-color:#457a1a;color:white} |
| - | .alert-box.alert{background-color:#c60f13;border-color:#970b0e;color:white}.alert-box.secondary{background-color:#e9e9e9;border-color:#d0d0d0;color:#505050} |
| - | .breadcrumbs{display:block;padding:.5625em .875em .5625em;overflow:hidden;margin-left:0;list-style:none;border-style:solid;border-width:1px;background-color:#f6f6f6;border-color:gainsboro;-webkit-border-radius:3px;border-radius:3px} |
| - | .breadcrumbs>*{margin:0;float:left;font-size:.6875em;text-transform:uppercase;color:#2ba6cb}.breadcrumbs>*:hover a,.breadcrumbs>*:focus a{text-decoration:underline} |
| - | .breadcrumbs>* a,.breadcrumbs>* span{text-transform:uppercase;color:#2ba6cb}.breadcrumbs>*.current{cursor:default;color:#333}.breadcrumbs>*.current a{cursor:default;color:#333} |
| - | .breadcrumbs>*.current:hover,.breadcrumbs>*.current:hover a,.breadcrumbs>*.current:focus,.breadcrumbs>*.current:focus a{text-decoration:none}.breadcrumbs>*.unavailable{color:#999} |
| - | .breadcrumbs>*.unavailable a{color:#999}.breadcrumbs>*.unavailable:hover,.breadcrumbs>*.unavailable:hover a,.breadcrumbs>*.unavailable:focus,.breadcrumbs>*.unavailable a:focus{text-decoration:none;color:#999;cursor:default} |
| - | .breadcrumbs>*:before{content:"/";color:#aaa;margin:0 .75em;position:relative;top:1px}.breadcrumbs>*:first-child:before{content:" ";margin:0} |
| - | .keystroke,kbd{background-color:#ededed;border-color:#dbdbdb;color:#222;border-style:solid;border-width:1px;margin:0;font-family:"Consolas","Menlo","Courier",monospace;font-size:.875em;padding:.125em .25em 0;-webkit-border-radius:3px;border-radius:3px} |
| - | .label{font-weight:bold;text-align:center;text-decoration:none;line-height:1;white-space:nowrap;display:inline-block;position:relative;padding:.1875em .625em .25em;font-size:.875em;background-color:#2ba6cb;color:white} |
| - | .label.radius{-webkit-border-radius:3px;border-radius:3px}.label.round{-webkit-border-radius:1000px;border-radius:1000px}.label.alert{background-color:#c60f13;color:white} |
| - | .label.success{background-color:#5da423;color:white}.label.secondary{background-color:#e9e9e9;color:#333}.inline-list{margin:0 auto 1.0625em auto;margin-left:-1.375em;margin-right:0;padding:0;list-style:none;overflow:hidden} |
| - | .inline-list>li{list-style:none;float:left;margin-left:1.375em;display:block}.inline-list>li>*{display:block}.pagination{display:block;height:1.5em;margin-left:-0.3125em} |
| - | .pagination li{display:block;float:left;height:1.5em;color:#222;font-size:.875em;margin-left:.3125em}.pagination li a{display:block;padding:.0625em .4375em .0625em;color:#999} |
| - | .pagination li:hover a,.pagination li a:focus{background:#e6e6e6}.pagination li.unavailable a{cursor:default;color:#999}.pagination li.unavailable:hover a,.pagination li.unavailable a:focus{background:transparent} |
| - | .pagination li.current a{background:#2ba6cb;color:white;font-weight:bold;cursor:default}.pagination li.current a:hover,.pagination li.current a:focus{background:#2ba6cb} |
| - | .pagination-centered{text-align:center}.pagination-centered ul>li{float:none;display:inline-block}.panel{border-style:solid;border-width:1px;border-color:#d9d9d9;margin-bottom:1.25em;padding:1.25em;background:#f2f2f2} |
| - | .panel h1,.panel h2,.panel h3,.panel h4,.panel h5,.panel h6,.panel p{color:#333}.panel>:first-child{margin-top:0}.panel>:last-child{margin-bottom:0}.panel h1,.panel h2,.panel h3,.panel h4,.panel h5,.panel h6{line-height:1;margin-bottom:.625em} |
| - | .panel h1.subheader,.panel h2.subheader,.panel h3.subheader,.panel h4.subheader,.panel h5.subheader,.panel h6.subheader{line-height:1.4}.panel.callout{border-style:solid;border-width:1px;border-color:#2284a1;margin-bottom:1.25em;padding:1.25em;background:#2ba6cb;-webkit-box-shadow:0 1px 0 rgba(255,255,255,0.5) inset;box-shadow:0 1px 0 rgba(255,255,255,0.5) inset} |
| - | .panel.callout h1,.panel.callout h2,.panel.callout h3,.panel.callout h4,.panel.callout h5,.panel.callout h6,.panel.callout p{color:white}.panel.callout>:first-child{margin-top:0} |
| - | .panel.callout>:last-child{margin-bottom:0}.panel.callout h1,.panel.callout h2,.panel.callout h3,.panel.callout h4,.panel.callout h5,.panel.callout h6{line-height:1;margin-bottom:.625em} |
| - | .panel.callout h1.subheader,.panel.callout h2.subheader,.panel.callout h3.subheader,.panel.callout h4.subheader,.panel.callout h5.subheader,.panel.callout h6.subheader{line-height:1.4} |
| - | .panel.radius{-webkit-border-radius:3px;border-radius:3px}.pricing-table{border:solid 1px #ddd;margin-left:0;margin-bottom:1.25em}.pricing-table *{list-style:none;line-height:1} |
| - | .pricing-table .title{background-color:#ddd;padding:.9375em 1.25em;text-align:center;color:#333;font-weight:bold;font-size:1em}.pricing-table .price{background-color:#eee;padding:.9375em 1.25em;text-align:center;color:#333;font-weight:normal;font-size:1.25em} |
| - | .pricing-table .description{background-color:white;padding:.9375em;text-align:center;color:#777;font-size:.75em;font-weight:normal;line-height:1.4;border-bottom:dotted 1px #ddd} |
| - | .pricing-table .bullet-item{background-color:white;padding:.9375em;text-align:center;color:#333;font-size:.875em;font-weight:normal;border-bottom:dotted 1px #ddd} |
| - | .pricing-table .cta-button{background-color:whitesmoke;text-align:center;padding:1.25em 1.25em 0}.progress{background-color:transparent;height:1.5625em;border:1px solid #ccc;padding:.125em;margin-bottom:.625em} |
| - | .progress .meter{background:#2ba6cb;height:100%;display:block}.progress.secondary .meter{background:#e9e9e9;height:100%;display:block}.progress.success .meter{background:#5da423;height:100%;display:block} |
| - | .progress.alert .meter{background:#c60f13;height:100%;display:block}.progress.radius{-webkit-border-radius:3px;border-radius:3px}.progress.radius .meter{-webkit-border-radius:2px;border-radius:2px} |
| - | .progress.round{-webkit-border-radius:1000px;border-radius:1000px}.progress.round .meter{-webkit-border-radius:999px;border-radius:999px}.side-nav{display:block;margin:0;padding:.875em 0;list-style-type:none;list-style-position:inside} |
| - | .side-nav li{margin:0 0 .4375em 0;font-size:.875em}.side-nav li a{display:block;color:#2ba6cb}.side-nav li.active>a:first-child{color:#4d4d4d;font-weight:bold} |
| - | .side-nav li.divider{border-top:1px solid;height:0;padding:0;list-style:none;border-top-color:#e6e6e6}.sub-nav{display:block;width:auto;overflow:hidden;margin:-0.25em 0 1.125em;padding-top:.25em;margin-right:0;margin-left:-0.5625em} |
| - | .sub-nav dt,.sub-nav dd{float:left;display:inline;margin-left:.5625em;margin-bottom:.625em;font-weight:normal;font-size:.875em}.sub-nav dt a,.sub-nav dd a{color:#999;text-decoration:none} |
| - | .sub-nav dt.active a,.sub-nav dd.active a{-webkit-border-radius:1000px;border-radius:1000px;font-weight:bold;background:#2ba6cb;padding:.1875em .5625em;cursor:default;color:white} |
| - | @media only screen{div.switch{position:relative;width:100%;padding:0;display:block;overflow:hidden;border-style:solid;border-width:1px;margin-bottom:1.25em;-webkit-animation:webkitSiblingBugfix infinite 1s;height:36px;background:white;border-color:#ccc} |
| - | div.switch label{position:relative;left:0;z-index:2;float:left;width:50%;height:100%;margin:0;font-weight:bold;text-align:left;-webkit-transition:all .1s ease-out;-moz-transition:all .1s ease-out;transition:all .1s ease-out} |
| - | div.switch input{position:absolute;z-index:3;opacity:0;width:100%;height:100%;-moz-appearance:none}div.switch input:hover,div.switch input:focus{cursor:pointer} |
| - | div.switch>span{position:absolute;top:-1px;left:-1px;z-index:1;display:block;padding:0;border-width:1px;border-style:solid;-webkit-transition:all .1s ease-out;-moz-transition:all .1s ease-out;transition:all .1s ease-out} |
| - | div.switch input:not(:checked)+label{opacity:0}div.switch input:checked{display:none!important}div.switch input{left:0;display:block!important}div.switch input:first-of-type+label,div.switch input:first-of-type+span+label{left:-50%} |
| - | div.switch input:first-of-type:checked+label,div.switch input:first-of-type:checked+span+label{left:0}div.switch input:last-of-type+label,div.switch input:last-of-type+span+label{right:-50%;left:auto;text-align:right} |
| - | div.switch input:last-of-type:checked+label,div.switch input:last-of-type:checked+span+label{right:0;left:auto}div.switch span.custom{display:none!important} |
| - | div.switch label{padding:0 .375em;line-height:2.3em;font-size:.875em}div.switch input:first-of-type:checked ~ span{left:100%;margin-left:-2.1875em}div.switch>span{width:2.25em;height:2.25em} |
| - | div.switch>span{border-color:#b3b3b3;background:white;background:-moz-linear-gradient(top,white 0,#f2f2f2 100%);background:-webkit-linear-gradient(top,white 0,#f2f2f2 100%);background:linear-gradient(to bottom,white 0,#f2f2f2 100%);-webkit-box-shadow:2px 0 10px 0 rgba(0,0,0,0.07),1000px 0 0 1000px #e1f5d1,-2px 0 10px 0 rgba(0,0,0,0.07),-1000px 0 0 1000px whitesmoke;box-shadow:2px 0 10px 0 rgba(0,0,0,0.07),1000px 0 0 980px #e1f5d1,-2px 0 10px 0 rgba(0,0,0,0.07),-1000px 0 0 1000px whitesmoke} |
| - | div.switch:hover>span,div.switch:focus>span{background:white;background:-moz-linear-gradient(top,white 0,#e6e6e6 100%);background:-webkit-linear-gradient(top,white 0,#e6e6e6 100%);background:linear-gradient(to bottom,white 0,#e6e6e6 100%)} |
| - | div.switch:active{background:transparent}div.switch.large{height:44px}div.switch.large label{padding:0 .375em;line-height:2.3em;font-size:1.0625em}div.switch.large input:first-of-type:checked ~ span{left:100%;margin-left:-2.6875em} |
| - | div.switch.large>span{width:2.75em;height:2.75em}div.switch.small{height:28px}div.switch.small label{padding:0 .375em;line-height:2.1em;font-size:.75em} |
| - | div.switch.small input:first-of-type:checked ~ span{left:100%;margin-left:-1.6875em}div.switch.small>span{width:1.75em;height:1.75em}div.switch.tiny{height:22px} |
| - | div.switch.tiny label{padding:0 .375em;line-height:1.9em;font-size:.6875em}div.switch.tiny input:first-of-type:checked ~ span{left:100%;margin-left:-1.3125em} |
| - | div.switch.tiny>span{width:1.375em;height:1.375em}div.switch.radius{-webkit-border-radius:4px;border-radius:4px}div.switch.radius>span{-webkit-border-radius:3px;border-radius:3px} |
| - | div.switch.round{-webkit-border-radius:1000px;border-radius:1000px}div.switch.round>span{-webkit-border-radius:999px;border-radius:999px}div.switch.round label{padding:0 .5625em} |
| - | @-webkit-keyframes webkitSiblingBugfix{from{position:relative}to{position:relative}}}[data-magellan-expedition]{background:white;z-index:50;min-width:100%;padding:10px} |
| - | [data-magellan-expedition] .sub-nav{margin-bottom:0}[data-magellan-expedition] .sub-nav dd{margin-bottom:0}table{background:white;margin-bottom:1.25em;border:solid 1px #ddd} |
| - | table thead,table tfoot{background:whitesmoke;font-weight:bold}table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:.5em .625em .625em;font-size:.875em;color:#222;text-align:left} |
| - | table tr th,table tr td{padding:.5625em .625em;font-size:.875em;color:#222}table tr.even,table tr.alt,table tr:nth-of-type(even){background:#f9f9f9}table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{display:table-cell;line-height:1.125em} |
| - | .th{line-height:0;display:inline-block;border:solid 4px white;-webkit-box-shadow:0 0 0 1px rgba(0,0,0,0.2);box-shadow:0 0 0 1px rgba(0,0,0,0.2);-webkit-transition:all 200ms ease-out;-moz-transition:all 200ms ease-out;transition:all 200ms ease-out} |
| - | .th:hover,.th:focus{-webkit-box-shadow:0 0 6px 1px rgba(43,166,203,0.5);box-shadow:0 0 6px 1px rgba(43,166,203,0.5)}.th.radius{-webkit-border-radius:3px;border-radius:3px} |
| - | a.th{display:inline-block}.has-tip{border-bottom:dotted 1px #ccc;cursor:help;font-weight:bold;color:#333}.has-tip:hover,.has-tip:focus{border-bottom:dotted 1px #196177;color:#2ba6cb} |
| - | .has-tip.tip-left,.has-tip.tip-right{float:none!important}.tooltip{display:none;position:absolute;z-index:999;font-weight:bold;font-size:.9375em;line-height:1.3;padding:.5em;max-width:85%;left:50%;width:100%;color:white;background:black;-webkit-border-radius:3px;border-radius:3px} |
| - | .tooltip>.nub{display:block;left:5px;position:absolute;width:0;height:0;border:solid 5px;border-color:transparent transparent black transparent;top:-10px} |
| - | .tooltip.opened{color:#2ba6cb!important;border-bottom:dotted 1px #196177!important}.tap-to-close{display:block;font-size:.625em;color:#888;font-weight:normal} |
| - | @media only screen and (min-width:768px){.tooltip>.nub{border-color:transparent transparent black transparent;top:-10px}.tooltip.tip-top>.nub{border-color:black transparent transparent transparent;top:auto;bottom:-10px} |
| - | .tooltip.tip-left,.tooltip.tip-right{float:none!important}.tooltip.tip-left>.nub{border-color:transparent transparent transparent black;right:-10px;left:auto;top:50%;margin-top:-5px} |
| - | .tooltip.tip-right>.nub{border-color:transparent black transparent transparent;right:auto;left:-10px;top:50%;margin-top:-5px}}@media only screen and (max-width:767px){.f-dropdown{max-width:100%;left:0} |
| - | }.f-dropdown{position:absolute;top:-9999px;list-style:none;width:100%;max-height:none;height:auto;background:white;border:solid 1px #ccc;font-size:16px;z-index:99;margin-top:2px;max-width:200px} |
| - | .f-dropdown>*:first-child{margin-top:0}.f-dropdown>*:last-child{margin-bottom:0}.f-dropdown:before{content:"";display:block;width:0;height:0;border:inset 6px;border-color:transparent transparent white transparent;border-bottom-style:solid;position:absolute;top:-12px;left:10px;z-index:99} |
| - | .f-dropdown:after{content:"";display:block;width:0;height:0;border:inset 7px;border-color:transparent transparent #ccc transparent;border-bottom-style:solid;position:absolute;top:-14px;left:9px;z-index:98} |
| - | .f-dropdown.right:before{left:auto;right:10px}.f-dropdown.right:after{left:auto;right:9px}.f-dropdown li{font-size:.875em;cursor:pointer;line-height:1.125em;margin:0} |
| - | .f-dropdown li:hover,.f-dropdown li:focus{background:#eee}.f-dropdown li a{display:block;padding:.3125em .625em;color:#555}.f-dropdown.content{position:absolute;top:-9999px;list-style:none;padding:1.25em;width:100%;height:auto;max-height:none;background:white;border:solid 1px #ccc;font-size:16px;z-index:99;max-width:200px} |
| - | .f-dropdown.content>*:first-child{margin-top:0}.f-dropdown.content>*:last-child{margin-bottom:0}.f-dropdown.tiny{max-width:200px}.f-dropdown.small{max-width:300px} |
| - | .f-dropdown.medium{max-width:500px}.f-dropdown.large{max-width:800px} |
| \ No newline at end of file | |
| + | meta.foundation-mq-small{font-family:"only screen and (min-width: 768px)";width:768px}meta.foundation-mq-medium{font-family:"only screen and (min-width:1280px)";width:1280px}meta.foundation-mq-large{font-family:"only screen and (min-width:1440px)";width:1440px}*,*:before,*:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}html,body{font-size:100%}body{background:#fff;color:#222;padding:0;margin:0;font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:normal;font-style:normal;line-height:1;position:relative;cursor:default}a:hover{cursor:pointer}img,object,embed{max-width:100%;height:auto}object,embed{height:100%}img{-ms-interpolation-mode:bicubic}#map_canvas img,#map_canvas embed,#map_canvas object,.map_canvas img,.map_canvas embed,.map_canvas object{max-width:none !important}.left{float:left !important}.right{float:right !important}.text-left{text-align:left !important}.text-right{text-align:right !important}.text-center{text-align:center !important}.text-justify{text-align:justify !important}.hide{display:none}.antialiased{-webkit-font-smoothing:antialiased}img{display:inline-block;vertical-align:middle}textarea{height:auto;min-height:50px}select{width:100%}.row{width:100%;margin-left:auto;margin-right:auto;margin-top:0;margin-bottom:0;max-width:62.5em;*zoom:1}.row:before,.row:after{content:" ";display:table}.row:after{clear:both}.row.collapse>.column,.row.collapse>.columns{position:relative;padding-left:0;padding-right:0;float:left}.row.collapse .row{margin-left:0;margin-right:0}.row .row{width:auto;margin-left:-0.9375em;margin-right:-0.9375em;margin-top:0;margin-bottom:0;max-width:none;*zoom:1}.row .row:before,.row .row:after{content:" ";display:table}.row .row:after{clear:both}.row .row.collapse{width:auto;margin:0;max-width:none;*zoom:1}.row .row.collapse:before,.row .row.collapse:after{content:" ";display:table}.row .row.collapse:after{clear:both}.column,.columns{position:relative;padding-left:0.9375em;padding-right:0.9375em;width:100%;float:left}@media only screen{.column,.columns{position:relative;padding-left:0.9375em;padding-right:0.9375em;float:left}.small-1{position:relative;width:8.33333%}.small-2{position:relative;width:16.66667%}.small-3{position:relative;width:25%}.small-4{position:relative;width:33.33333%}.small-5{position:relative;width:41.66667%}.small-6{position:relative;width:50%}.small-7{position:relative;width:58.33333%}.small-8{position:relative;width:66.66667%}.small-9{position:relative;width:75%}.small-10{position:relative;width:83.33333%}.small-11{position:relative;width:91.66667%}.small-12{position:relative;width:100%}.small-offset-0{position:relative;margin-left:0%}.small-offset-1{position:relative;margin-left:8.33333%}.small-offset-2{position:relative;margin-left:16.66667%}.small-offset-3{position:relative;margin-left:25%}.small-offset-4{position:relative;margin-left:33.33333%}.small-offset-5{position:relative;margin-left:41.66667%}.small-offset-6{position:relative;margin-left:50%}.small-offset-7{position:relative;margin-left:58.33333%}.small-offset-8{position:relative;margin-left:66.66667%}.small-offset-9{position:relative;margin-left:75%}.small-offset-10{position:relative;margin-left:83.33333%}[class*="column"]+[class*="column"]:last-child{float:right}[class*="column"]+[class*="column"].end{float:left}.column.small-centered,.columns.small-centered{position:relative;margin-left:auto;margin-right:auto;float:none !important}}@media only screen and (min-width: 768px){.large-1{position:relative;width:8.33333%}.large-2{position:relative;width:16.66667%}.large-3{position:relative;width:25%}.large-4{position:relative;width:33.33333%}.large-5{position:relative;width:41.66667%}.large-6{position:relative;width:50%}.large-7{position:relative;width:58.33333%}.large-8{position:relative;width:66.66667%}.large-9{position:relative;width:75%}.large-10{position:relative;width:83.33333%}.large-11{position:relative;width:91.66667%}.large-12{position:relative;width:100%}.row .large-offset-0{position:relative;margin-left:0%}.row .large-offset-1{position:relative;margin-left:8.33333%}.row .large-offset-2{position:relative;margin-left:16.66667%}.row .large-offset-3{position:relative;margin-left:25%}.row .large-offset-4{position:relative;margin-left:33.33333%}.row .large-offset-5{position:relative;margin-left:41.66667%}.row .large-offset-6{position:relative;margin-left:50%}.row .large-offset-7{position:relative;margin-left:58.33333%}.row .large-offset-8{position:relative;margin-left:66.66667%}.row .large-offset-9{position:relative;margin-left:75%}.row .large-offset-10{position:relative;margin-left:83.33333%}.row .large-offset-11{position:relative;margin-left:91.66667%}.push-1{position:relative;left:8.33333%;right:auto}.pull-1{position:relative;right:8.33333%;left:auto}.push-2{position:relative;left:16.66667%;right:auto}.pull-2{position:relative;right:16.66667%;left:auto}.push-3{position:relative;left:25%;right:auto}.pull-3{position:relative;right:25%;left:auto}.push-4{position:relative;left:33.33333%;right:auto}.pull-4{position:relative;right:33.33333%;left:auto}.push-5{position:relative;left:41.66667%;right:auto}.pull-5{position:relative;right:41.66667%;left:auto}.push-6{position:relative;left:50%;right:auto}.pull-6{position:relative;right:50%;left:auto}.push-7{position:relative;left:58.33333%;right:auto}.pull-7{position:relative;right:58.33333%;left:auto}.push-8{position:relative;left:66.66667%;right:auto}.pull-8{position:relative;right:66.66667%;left:auto}.push-9{position:relative;left:75%;right:auto}.pull-9{position:relative;right:75%;left:auto}.push-10{position:relative;left:83.33333%;right:auto}.pull-10{position:relative;right:83.33333%;left:auto}.push-11{position:relative;left:91.66667%;right:auto}.pull-11{position:relative;right:91.66667%;left:auto}.column.large-centered,.columns.large-centered{position:relative;margin-left:auto;margin-right:auto;float:none !important}.column.large-uncentered,.columns.large-uncentered{margin-left:0;margin-right:0;float:left !important}.column.large-uncentered.opposite,.columns.large-uncentered.opposite{float:right !important}}.show-for-small,.show-for-medium-down,.show-for-large-down{display:inherit !important}.show-for-medium,.show-for-medium-up,.show-for-large,.show-for-large-up,.show-for-xlarge{display:none !important}.hide-for-medium,.hide-for-medium-up,.hide-for-large,.hide-for-large-up,.hide-for-xlarge{display:inherit !important}.hide-for-small,.hide-for-medium-down,.hide-for-large-down{display:none !important}table.show-for-small,table.show-for-medium-down,table.show-for-large-down,table.hide-for-medium,table.hide-for-medium-up,table.hide-for-large,table.hide-for-large-up,table.hide-for-xlarge{display:table}thead.show-for-small,thead.show-for-medium-down,thead.show-for-large-down,thead.hide-for-medium,thead.hide-for-medium-up,thead.hide-for-large,thead.hide-for-large-up,thead.hide-for-xlarge{display:table-header-group !important}tbody.show-for-small,tbody.show-for-medium-down,tbody.show-for-large-down,tbody.hide-for-medium,tbody.hide-for-medium-up,tbody.hide-for-large,tbody.hide-for-large-up,tbody.hide-for-xlarge{display:table-row-group !important}tr.show-for-small,tr.show-for-medium-down,tr.show-for-large-down,tr.hide-for-medium,tr.hide-for-medium-up,tr.hide-for-large,tr.hide-for-large-up,tr.hide-for-xlarge{display:table-row !important}td.show-for-small,td.show-for-medium-down,td.show-for-large-down,td.hide-for-medium,td.hide-for-medium-up,td.hide-for-large,td.hide-for-large-up,td.hide-for-xlarge,th.show-for-small,th.show-for-medium-down,th.show-for-large-down,th.hide-for-medium,th.hide-for-medium-up,th.hide-for-large,th.hide-for-large-up,th.hide-for-xlarge{display:table-cell !important}@media only screen and (min-width: 768px){.show-for-medium,.show-for-medium-up{display:inherit !important}.show-for-small{display:none !important}.hide-for-small{display:inherit !important}.hide-for-medium,.hide-for-medium-up{display:none !important}table.show-for-medium,table.show-for-medium-up,table.hide-for-small{display:table}thead.show-for-medium,thead.show-for-medium-up,thead.hide-for-small{display:table-header-group !important}tbody.show-for-medium,tbody.show-for-medium-up,tbody.hide-for-small{display:table-row-group !important}tr.show-for-medium,tr.show-for-medium-up,tr.hide-for-small{display:table-row !important}td.show-for-medium,td.show-for-medium-up,td.hide-for-small,th.show-for-medium,th.show-for-medium-up,th.hide-for-small{display:table-cell !important}}@media only screen and (min-width: 1280px){.show-for-large,.show-for-large-up{display:inherit !important}.show-for-medium,.show-for-medium-down{display:none !important}.hide-for-medium,.hide-for-medium-down{display:inherit !important}.hide-for-large,.hide-for-large-up{display:none !important}table.show-for-large,table.show-for-large-up,table.hide-for-medium,table.hide-for-medium-down{display:table}thead.show-for-large,thead.show-for-large-up,thead.hide-for-medium,thead.hide-for-medium-down{display:table-header-group !important}tbody.show-for-large,tbody.show-for-large-up,tbody.hide-for-medium,tbody.hide-for-medium-down{display:table-row-group !important}tr.show-for-large,tr.show-for-large-up,tr.hide-for-medium,tr.hide-for-medium-down{display:table-row !important}td.show-for-large,td.show-for-large-up,td.hide-for-medium,td.hide-for-medium-down,th.show-for-large,th.show-for-large-up,th.hide-for-medium,th.hide-for-medium-down{display:table-cell !important}}@media only screen and (min-width: 1440px){.show-for-xlarge{display:inherit !important}.show-for-large,.show-for-large-down{display:none !important}.hide-for-large,.hide-for-large-down{display:inherit !important}.hide-for-xlarge{display:none !important}table.show-for-xlarge,table.hide-for-large,table.hide-for-large-down{display:table}thead.show-for-xlarge,thead.hide-for-large,thead.hide-for-large-down{display:table-header-group !important}tbody.show-for-xlarge,tbody.hide-for-large,tbody.hide-for-large-down{display:table-row-group !important}tr.show-for-xlarge,tr.hide-for-large,tr.hide-for-large-down{display:table-row !important}td.show-for-xlarge,td.hide-for-large,td.hide-for-large-down,th.show-for-xlarge,th.hide-for-large,th.hide-for-large-down{display:table-cell !important}}.show-for-landscape,.hide-for-portrait{display:inherit !important}.hide-for-landscape,.show-for-portrait{display:none !important}table.hide-for-landscape,table.show-for-portrait{display:table}thead.hide-for-landscape,thead.show-for-portrait{display:table-header-group !important}tbody.hide-for-landscape,tbody.show-for-portrait{display:table-row-group !important}tr.hide-for-landscape,tr.show-for-portrait{display:table-row !important}td.hide-for-landscape,td.show-for-portrait,th.hide-for-landscape,th.show-for-portrait{display:table-cell !important}@media only screen and (orientation: landscape){.show-for-landscape,.hide-for-portrait{display:inherit !important}.hide-for-landscape,.show-for-portrait{display:none !important}table.show-for-landscape,table.hide-for-portrait{display:table}thead.show-for-landscape,thead.hide-for-portrait{display:table-header-group !important}tbody.show-for-landscape,tbody.hide-for-portrait{display:table-row-group !important}tr.show-for-landscape,tr.hide-for-portrait{display:table-row !important}td.show-for-landscape,td.hide-for-portrait,th.show-for-landscape,th.hide-for-portrait{display:table-cell !important}}@media only screen and (orientation: portrait){.show-for-portrait,.hide-for-landscape{display:inherit !important}.hide-for-portrait,.show-for-landscape{display:none !important}table.show-for-portrait,table.hide-for-landscape{display:table}thead.show-for-portrait,thead.hide-for-landscape{display:table-header-group !important}tbody.show-for-portrait,tbody.hide-for-landscape{display:table-row-group !important}tr.show-for-portrait,tr.hide-for-landscape{display:table-row !important}td.show-for-portrait,td.hide-for-landscape,th.show-for-portrait,th.hide-for-landscape{display:table-cell !important}}.show-for-touch{display:none !important}.hide-for-touch{display:inherit !important}.touch .show-for-touch{display:inherit !important}.touch .hide-for-touch{display:none !important}table.hide-for-touch{display:table}.touch table.show-for-touch{display:table}thead.hide-for-touch{display:table-header-group !important}.touch thead.show-for-touch{display:table-header-group !important}tbody.hide-for-touch{display:table-row-group !important}.touch tbody.show-for-touch{display:table-row-group !important}tr.hide-for-touch{display:table-row !important}.touch tr.show-for-touch{display:table-row !important}td.hide-for-touch{display:table-cell !important}.touch td.show-for-touch{display:table-cell !important}th.hide-for-touch{display:table-cell !important}.touch th.show-for-touch{display:table-cell !important}@media only screen{[class*="block-grid-"]{display:block;padding:0;margin:0 -0.625em;*zoom:1}[class*="block-grid-"]:before,[class*="block-grid-"]:after{content:" ";display:table}[class*="block-grid-"]:after{clear:both}[class*="block-grid-"]>li{display:inline;height:auto;float:left;padding:0 0.625em 1.25em}.small-block-grid-1>li{width:100%;padding:0 0.625em 1.25em}.small-block-grid-1>li:nth-of-type(n){clear:none}.small-block-grid-1>li:nth-of-type(1n+1){clear:both}.small-block-grid-2>li{width:50%;padding:0 0.625em 1.25em}.small-block-grid-2>li:nth-of-type(n){clear:none}.small-block-grid-2>li:nth-of-type(2n+1){clear:both}.small-block-grid-3>li{width:33.33333%;padding:0 0.625em 1.25em}.small-block-grid-3>li:nth-of-type(n){clear:none}.small-block-grid-3>li:nth-of-type(3n+1){clear:both}.small-block-grid-4>li{width:25%;padding:0 0.625em 1.25em}.small-block-grid-4>li:nth-of-type(n){clear:none}.small-block-grid-4>li:nth-of-type(4n+1){clear:both}.small-block-grid-5>li{width:20%;padding:0 0.625em 1.25em}.small-block-grid-5>li:nth-of-type(n){clear:none}.small-block-grid-5>li:nth-of-type(5n+1){clear:both}.small-block-grid-6>li{width:16.66667%;padding:0 0.625em 1.25em}.small-block-grid-6>li:nth-of-type(n){clear:none}.small-block-grid-6>li:nth-of-type(6n+1){clear:both}.small-block-grid-7>li{width:14.28571%;padding:0 0.625em 1.25em}.small-block-grid-7>li:nth-of-type(n){clear:none}.small-block-grid-7>li:nth-of-type(7n+1){clear:both}.small-block-grid-8>li{width:12.5%;padding:0 0.625em 1.25em}.small-block-grid-8>li:nth-of-type(n){clear:none}.small-block-grid-8>li:nth-of-type(8n+1){clear:both}.small-block-grid-9>li{width:11.11111%;padding:0 0.625em 1.25em}.small-block-grid-9>li:nth-of-type(n){clear:none}.small-block-grid-9>li:nth-of-type(9n+1){clear:both}.small-block-grid-10>li{width:10%;padding:0 0.625em 1.25em}.small-block-grid-10>li:nth-of-type(n){clear:none}.small-block-grid-10>li:nth-of-type(10n+1){clear:both}.small-block-grid-11>li{width:9.09091%;padding:0 0.625em 1.25em}.small-block-grid-11>li:nth-of-type(n){clear:none}.small-block-grid-11>li:nth-of-type(11n+1){clear:both}.small-block-grid-12>li{width:8.33333%;padding:0 0.625em 1.25em}.small-block-grid-12>li:nth-of-type(n){clear:none}.small-block-grid-12>li:nth-of-type(12n+1){clear:both}}@media only screen and (min-width: 768px){.small-block-grid-1>li:nth-of-type(1n+1){clear:none}.small-block-grid-2>li:nth-of-type(2n+1){clear:none}.small-block-grid-3>li:nth-of-type(3n+1){clear:none}.small-block-grid-4>li:nth-of-type(4n+1){clear:none}.small-block-grid-5>li:nth-of-type(5n+1){clear:none}.small-block-grid-6>li:nth-of-type(6n+1){clear:none}.small-block-grid-7>li:nth-of-type(7n+1){clear:none}.small-block-grid-8>li:nth-of-type(8n+1){clear:none}.small-block-grid-9>li:nth-of-type(9n+1){clear:none}.small-block-grid-10>li:nth-of-type(10n+1){clear:none}.small-block-grid-11>li:nth-of-type(11n+1){clear:none}.small-block-grid-12>li:nth-of-type(12n+1){clear:none}.large-block-grid-1>li{width:100%;padding:0 0.625em 1.25em}.large-block-grid-1>li:nth-of-type(n){clear:none}.large-block-grid-1>li:nth-of-type(1n+1){clear:both}.large-block-grid-2>li{width:50%;padding:0 0.625em 1.25em}.large-block-grid-2>li:nth-of-type(n){clear:none}.large-block-grid-2>li:nth-of-type(2n+1){clear:both}.large-block-grid-3>li{width:33.33333%;padding:0 0.625em 1.25em}.large-block-grid-3>li:nth-of-type(n){clear:none}.large-block-grid-3>li:nth-of-type(3n+1){clear:both}.large-block-grid-4>li{width:25%;padding:0 0.625em 1.25em}.large-block-grid-4>li:nth-of-type(n){clear:none}.large-block-grid-4>li:nth-of-type(4n+1){clear:both}.large-block-grid-5>li{width:20%;padding:0 0.625em 1.25em}.large-block-grid-5>li:nth-of-type(n){clear:none}.large-block-grid-5>li:nth-of-type(5n+1){clear:both}.large-block-grid-6>li{width:16.66667%;padding:0 0.625em 1.25em}.large-block-grid-6>li:nth-of-type(n){clear:none}.large-block-grid-6>li:nth-of-type(6n+1){clear:both}.large-block-grid-7>li{width:14.28571%;padding:0 0.625em 1.25em}.large-block-grid-7>li:nth-of-type(n){clear:none}.large-block-grid-7>li:nth-of-type(7n+1){clear:both}.large-block-grid-8>li{width:12.5%;padding:0 0.625em 1.25em}.large-block-grid-8>li:nth-of-type(n){clear:none}.large-block-grid-8>li:nth-of-type(8n+1){clear:both}.large-block-grid-9>li{width:11.11111%;padding:0 0.625em 1.25em}.large-block-grid-9>li:nth-of-type(n){clear:none}.large-block-grid-9>li:nth-of-type(9n+1){clear:both}.large-block-grid-10>li{width:10%;padding:0 0.625em 1.25em}.large-block-grid-10>li:nth-of-type(n){clear:none}.large-block-grid-10>li:nth-of-type(10n+1){clear:both}.large-block-grid-11>li{width:9.09091%;padding:0 0.625em 1.25em}.large-block-grid-11>li:nth-of-type(n){clear:none}.large-block-grid-11>li:nth-of-type(11n+1){clear:both}.large-block-grid-12>li{width:8.33333%;padding:0 0.625em 1.25em}.large-block-grid-12>li:nth-of-type(n){clear:none}.large-block-grid-12>li:nth-of-type(12n+1){clear:both}}p.lead{font-size:1.21875em;line-height:1.6}.subheader{line-height:1.4;color:#6f6f6f;font-weight:300;margin-top:0.2em;margin-bottom:0.5em}div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0;direction:ltr}a{color:#2ba6cb;text-decoration:none;line-height:inherit}a:hover,a:focus{color:#2795b6}a img{border:none}p{font-family:inherit;font-weight:normal;font-size:1em;line-height:1.6;margin-bottom:1.25em;text-rendering:optimizeLegibility}p aside{font-size:0.875em;line-height:1.35;font-style:italic}h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue","Helvetica",Helvetica,Arial,sans-serif;font-weight:bold;font-style:normal;color:#222;text-rendering:optimizeLegibility;margin-top:0.2em;margin-bottom:0.5em;line-height:1.2125em}h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{font-size:60%;color:#6f6f6f;line-height:0}h1{font-size:2.125em}h2{font-size:1.6875em}h3{font-size:1.375em}h4{font-size:1.125em}h5{font-size:1.125em}h6{font-size:1em}hr{border:solid #ddd;border-width:1px 0 0;clear:both;margin:1.25em 0 1.1875em;height:0}em,i{font-style:italic;line-height:inherit}strong,b{font-weight:bold;line-height:inherit}small{font-size:60%;line-height:inherit}code{font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:bold;color:#7f0a0c}ul,ol,dl{font-size:1em;line-height:1.6;margin-bottom:1.25em;list-style-position:outside;font-family:inherit}ul,ol{margin-left:0}ul.no-bullet,ol.no-bullet{margin-left:0}ul li ul,ul li ol{margin-left:1.25em;margin-bottom:0;font-size:1em}ul.square li ul,ul.circle li ul,ul.disc li ul{list-style:inherit}ul.square{list-style-type:square}ul.circle{list-style-type:circle}ul.disc{list-style-type:disc}ul.no-bullet{list-style:none}ol li ul,ol li ol{margin-left:1.25em;margin-bottom:0}dl dt{margin-bottom:0.3em;font-weight:bold}dl dd{margin-bottom:0.75em}abbr,acronym{text-transform:uppercase;font-size:90%;color:#222;border-bottom:1px dotted #ddd;cursor:help}abbr{text-transform:none}blockquote{margin:0 0 1.25em;padding:0.5625em 1.25em 0 1.1875em;border-left:1px solid #ddd}blockquote cite{display:block;font-size:0.8125em;color:#555}blockquote cite:before{content:"\2014 \0020"}blockquote cite a,blockquote cite a:visited{color:#555}blockquote,blockquote p{line-height:1.6;color:#6f6f6f}.vcard{display:inline-block;margin:0 0 1.25em 0;border:1px solid #ddd;padding:0.625em 0.75em}.vcard li{margin:0;display:block}.vcard .fn{font-weight:bold;font-size:0.9375em}.vevent .summary{font-weight:bold}.vevent abbr{cursor:default;text-decoration:none;font-weight:bold;border:none;padding:0 0.0625em}@media only screen and (min-width: 768px){h1,h2,h3,h4,h5,h6{line-height:1.4}h1{font-size:2.75em}h2{font-size:2.3125em}h3{font-size:1.6875em}h4{font-size:1.4375em}}.print-only{display:none !important}@media print{*{background:transparent !important;color:#000 !important;box-shadow:none !important;text-shadow:none !important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100% !important}@page{margin:0.5cm}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}.hide-on-print{display:none !important}.print-only{display:block !important}.hide-for-print{display:none !important}.show-for-print{display:inherit !important}}button,.button{border-style:solid;border-width:1px;cursor:pointer;font-family:inherit;font-weight:bold;line-height:normal;margin:0 0 1.25em;position:relative;text-decoration:none;text-align:center;display:inline-block;padding-top:0.75em;padding-right:1.5em;padding-bottom:0.8125em;padding-left:1.5em;font-size:1em;background-color:#2ba6cb;border-color:#2284a1;color:#fff}button:hover,button:focus,.button:hover,.button:focus{background-color:#2284a1}button:hover,button:focus,.button:hover,.button:focus{color:#fff}button.secondary,.button.secondary{background-color:#e9e9e9;border-color:#d0d0d0;color:#333}button.secondary:hover,button.secondary:focus,.button.secondary:hover,.button.secondary:focus{background-color:#d0d0d0}button.secondary:hover,button.secondary:focus,.button.secondary:hover,.button.secondary:focus{color:#333}button.success,.button.success{background-color:#5da423;border-color:#457a1a;color:#fff}button.success:hover,button.success:focus,.button.success:hover,.button.success:focus{background-color:#457a1a}button.success:hover,button.success:focus,.button.success:hover,.button.success:focus{color:#fff}button.alert,.button.alert{background-color:#c60f13;border-color:#970b0e;color:#fff}button.alert:hover,button.alert:focus,.button.alert:hover,.button.alert:focus{background-color:#970b0e}button.alert:hover,button.alert:focus,.button.alert:hover,.button.alert:focus{color:#fff}button.large,.button.large{padding-top:1em;padding-right:2em;padding-bottom:1.0625em;padding-left:2em;font-size:1.25em}button.small,.button.small{padding-top:0.5625em;padding-right:1.125em;padding-bottom:0.625em;padding-left:1.125em;font-size:0.8125em}button.tiny,.button.tiny{padding-top:0.4375em;padding-right:0.875em;padding-bottom:0.5em;padding-left:0.875em;font-size:0.6875em}button.expand,.button.expand{padding-right:0;padding-left:0;width:100%}button.left-align,.button.left-align{text-align:left;text-indent:0.75em}button.right-align,.button.right-align{text-align:right;padding-right:0.75em}button.disabled,button[disabled],.button.disabled,.button[disabled]{background-color:#2ba6cb;border-color:#2284a1;color:#fff;cursor:default;opacity:0.6;-webkit-box-shadow:none;box-shadow:none}button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{background-color:#2284a1}button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{color:#fff}button.disabled:hover,button.disabled:focus,button[disabled]:hover,button[disabled]:focus,.button.disabled:hover,.button.disabled:focus,.button[disabled]:hover,.button[disabled]:focus{background-color:#2ba6cb}button.disabled.secondary,button[disabled].secondary,.button.disabled.secondary,.button[disabled].secondary{background-color:#e9e9e9;border-color:#d0d0d0;color:#333;cursor:default;opacity:0.6;-webkit-box-shadow:none;box-shadow:none}button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{background-color:#d0d0d0}button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{color:#333}button.disabled.secondary:hover,button.disabled.secondary:focus,button[disabled].secondary:hover,button[disabled].secondary:focus,.button.disabled.secondary:hover,.button.disabled.secondary:focus,.button[disabled].secondary:hover,.button[disabled].secondary:focus{background-color:#e9e9e9}button.disabled.success,button[disabled].success,.button.disabled.success,.button[disabled].success{background-color:#5da423;border-color:#457a1a;color:#fff;cursor:default;opacity:0.6;-webkit-box-shadow:none;box-shadow:none}button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{background-color:#457a1a}button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{color:#fff}button.disabled.success:hover,button.disabled.success:focus,button[disabled].success:hover,button[disabled].success:focus,.button.disabled.success:hover,.button.disabled.success:focus,.button[disabled].success:hover,.button[disabled].success:focus{background-color:#5da423}button.disabled.alert,button[disabled].alert,.button.disabled.alert,.button[disabled].alert{background-color:#c60f13;border-color:#970b0e;color:#fff;cursor:default;opacity:0.6;-webkit-box-shadow:none;box-shadow:none}button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{background-color:#970b0e}button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{color:#fff}button.disabled.alert:hover,button.disabled.alert:focus,button[disabled].alert:hover,button[disabled].alert:focus,.button.disabled.alert:hover,.button.disabled.alert:focus,.button[disabled].alert:hover,.button[disabled].alert:focus{background-color:#c60f13}button,.button{padding-top:0.8125em;padding-bottom:0.75em;-webkit-appearance:none}button.tiny,.button.tiny{padding-top:0.5em;padding-bottom:0.4375em;-webkit-appearance:none}button.small,.button.small{padding-top:0.625em;padding-bottom:0.5625em;-webkit-appearance:none}button.large,.button.large{padding-top:1.03125em;padding-bottom:1.03125em;-webkit-appearance:none}@media only screen{button,.button{-webkit-box-shadow:0 1px 0 rgba(255,255,255,0.5) inset;box-shadow:0 1px 0 rgba(255,255,255,0.5) inset;-webkit-transition:background-color 300ms ease-out;-moz-transition:background-color 300ms ease-out;transition:background-color 300ms ease-out}button:active,.button:active{-webkit-box-shadow:0 1px 0 rgba(0,0,0,0.2) inset;box-shadow:0 1px 0 rgba(0,0,0,0.2) inset}button.radius,.button.radius{-webkit-border-radius:3px;border-radius:3px}button.round,.button.round{-webkit-border-radius:1000px;border-radius:1000px}}@media only screen and (min-width: 768px){button,.button{display:inline-block}}form{margin:0 0 1em}form .row .row{margin:0 -0.5em}form .row .row .column,form .row .row .columns{padding:0 0.5em}form .row .row.collapse{margin:0}form .row .row.collapse .column,form .row .row.collapse .columns{padding:0}form .row .row.collapse input{-moz-border-radius-bottomright:0;-moz-border-radius-topright:0;-webkit-border-bottom-right-radius:0;-webkit-border-top-right-radius:0}form .row input.column,form .row input.columns,form .row textarea.column,form .row textarea.columns{padding-left:0.5em}label{font-size:0.875em;color:#4d4d4d;cursor:pointer;display:block;font-weight:500;margin-bottom:0.1875em}label.right{float:none;text-align:right}label.inline{margin:0 0 1em 0;padding:0.625em 0}label small{text-transform:capitalize;color:#666}.prefix,.postfix{display:block;position:relative;z-index:2;text-align:center;width:100%;padding-top:0;padding-bottom:0;border-style:solid;border-width:1px;overflow:hidden;font-size:0.875em;height:2.3125em;line-height:2.3125em}.postfix.button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;text-align:center;line-height:2.125em}.prefix.button{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;text-align:center;line-height:2.125em}.prefix.button.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}.postfix.button.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px}.prefix.button.round{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px}.postfix.button.round{-webkit-border-radius:0;border-radius:0;-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px}span.prefix,label.prefix{background:#f2f2f2;border-color:#d9d9d9;border-right:none;color:#333}span.prefix.radius,label.prefix.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}span.postfix,label.postfix{background:#f2f2f2;border-color:#ccc;border-left:none;color:#333}span.postfix.radius,label.postfix.radius{-webkit-border-radius:0;border-radius:0;-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px}.input-group.radius>*:first-child,.input-group.radius>*:first-child *{-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}.input-group.radius>*:last-child,.input-group.radius>*:last-child *{-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px}.input-group.round>*:first-child,.input-group.round>*:first-child *{-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px}.input-group.round>*:last-child,.input-group.round>*:last-child *{-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px}input[type="text"],input[type="password"],input[type="date"],input[type="datetime"],input[type="datetime-local"],input[type="month"],input[type="week"],input[type="email"],input[type="number"],input[type="search"],input[type="tel"],input[type="time"],input[type="url"],textarea{-webkit-appearance:none;-webkit-border-radius:0;border-radius:0;background-color:#fff;font-family:inherit;border:1px solid #ccc;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);color:rgba(0,0,0,0.75);display:block;font-size:0.875em;margin:0 0 1em 0;padding:0.5em;height:2.3125em;width:100%;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-transition:-webkit-box-shadow 0.45s,border-color 0.45s ease-in-out;-moz-transition:-moz-box-shadow 0.45s,border-color 0.45s ease-in-out;transition:box-shadow 0.45s,border-color 0.45s ease-in-out}input[type="text"]:focus,input[type="password"]:focus,input[type="date"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="month"]:focus,input[type="week"]:focus,input[type="email"]:focus,input[type="number"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="time"]:focus,input[type="url"]:focus,textarea:focus{-webkit-box-shadow:0 0 5px #999;-moz-box-shadow:0 0 5px #999;box-shadow:0 0 5px #999;border-color:#999}input[type="text"]:focus,input[type="password"]:focus,input[type="date"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="month"]:focus,input[type="week"]:focus,input[type="email"]:focus,input[type="number"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="time"]:focus,input[type="url"]:focus,textarea:focus{background:#fafafa;border-color:#999;outline:none}input[type="text"][disabled],input[type="password"][disabled],input[type="date"][disabled],input[type="datetime"][disabled],input[type="datetime-local"][disabled],input[type="month"][disabled],input[type="week"][disabled],input[type="email"][disabled],input[type="number"][disabled],input[type="search"][disabled],input[type="tel"][disabled],input[type="time"][disabled],input[type="url"][disabled],textarea[disabled]{background-color:#ddd}input[type="file"],input[type="checkbox"],input[type="radio"],select{margin:0 0 1em 0}input[type="file"]{width:100%}fieldset{border:solid 1px #ddd;padding:1.25em;margin:1.125em 0}fieldset legend{font-weight:bold;background:#fff;padding:0 0.1875em;margin:0;margin-left:-0.1875em}[data-abide] .error small.error,[data-abide] span.error,[data-abide] small.error{display:block;padding:0.375em 0.25em;margin-top:0;margin-bottom:1em;font-size:0.75em;font-weight:bold;background:#c60f13;color:#fff}[data-abide] span.error,[data-abide] small.error{display:none}span.error,small.error{display:block;padding:0.375em 0.25em;margin-top:0;margin-bottom:1em;font-size:0.75em;font-weight:bold;background:#c60f13;color:#fff}.error input,.error textarea,.error select{border-color:#c60f13;background-color:rgba(198,15,19,0.1);margin-bottom:0}.error input:focus,.error textarea:focus,.error select:focus{background:#fafafa;border-color:#999}.error label,.error label.error{color:#c60f13}.error>small,.error small.error{display:block;padding:0.375em 0.25em;margin-top:0;margin-bottom:1em;font-size:0.75em;font-weight:bold;background:#c60f13;color:#fff}.error span.error-message{display:block}input.error,textarea.error{border-color:#c60f13;background-color:rgba(198,15,19,0.1);margin-bottom:0}input.error:focus,textarea.error:focus{background:#fafafa;border-color:#999}.error select{border-color:#c60f13;background-color:rgba(198,15,19,0.1)}.error select:focus{background:#fafafa;border-color:#999}label.error{color:#c60f13}.button-group{list-style:none;margin:0;*zoom:1}.button-group:before,.button-group:after{content:" ";display:table}.button-group:after{clear:both}.button-group>*{margin:0 0 0 -1px;float:left}.button-group>*:first-child{margin-left:0}.button-group.radius>*:first-child,.button-group.radius>*:first-child>a,.button-group.radius>*:first-child>button,.button-group.radius>*:first-child>.button{-moz-border-radius-bottomleft:3px;-moz-border-radius-topleft:3px;-webkit-border-bottom-left-radius:3px;-webkit-border-top-left-radius:3px;border-bottom-left-radius:3px;border-top-left-radius:3px}.button-group.radius>*:last-child,.button-group.radius>*:last-child>a,.button-group.radius>*:last-child>button,.button-group.radius>*:last-child>.button{-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px}.button-group.round>*:first-child,.button-group.round>*:first-child>a,.button-group.round>*:first-child>button,.button-group.round>*:first-child>.button{-moz-border-radius-bottomleft:1000px;-moz-border-radius-topleft:1000px;-webkit-border-bottom-left-radius:1000px;-webkit-border-top-left-radius:1000px;border-bottom-left-radius:1000px;border-top-left-radius:1000px}.button-group.round>*:last-child,.button-group.round>*:last-child>a,.button-group.round>*:last-child>button,.button-group.round>*:last-child>.button{-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px}.button-group.even-2 li{width:50%}.button-group.even-2 li button,.button-group.even-2 li .button{width:100%}.button-group.even-3 li{width:33.33333%}.button-group.even-3 li button,.button-group.even-3 li .button{width:100%}.button-group.even-4 li{width:25%}.button-group.even-4 li button,.button-group.even-4 li .button{width:100%}.button-group.even-5 li{width:20%}.button-group.even-5 li button,.button-group.even-5 li .button{width:100%}.button-group.even-6 li{width:16.66667%}.button-group.even-6 li button,.button-group.even-6 li .button{width:100%}.button-group.even-7 li{width:14.28571%}.button-group.even-7 li button,.button-group.even-7 li .button{width:100%}.button-group.even-8 li{width:12.5%}.button-group.even-8 li button,.button-group.even-8 li .button{width:100%}.button-bar{*zoom:1}.button-bar:before,.button-bar:after{content:" ";display:table}.button-bar:after{clear:both}.button-bar .button-group{float:left;margin-right:0.625em}.button-bar .button-group div{overflow:hidden}.dropdown.button{position:relative;padding-right:3.1875em}.dropdown.button:before{position:absolute;content:"";width:0;height:0;display:block;border-style:solid;border-color:#fff transparent transparent transparent;top:50%}.dropdown.button:before{border-width:0.5625em;right:1.5em;margin-top:-0.25em}.dropdown.button:before{border-color:#fff transparent transparent transparent}.dropdown.button.tiny{padding-right:2.1875em}.dropdown.button.tiny:before{border-width:0.4375em;right:0.875em;margin-top:-0.15625em}.dropdown.button.tiny:before{border-color:#fff transparent transparent transparent}.dropdown.button.small{padding-right:2.8125em}.dropdown.button.small:before{border-width:0.5625em;right:1.125em;margin-top:-0.21875em}.dropdown.button.small:before{border-color:#fff transparent transparent transparent}.dropdown.button.large{padding-right:4em}.dropdown.button.large:before{border-width:0.625em;right:1.75em;margin-top:-0.3125em}.dropdown.button.large:before{border-color:#fff transparent transparent transparent}.dropdown.button.secondary:before{border-color:#333 transparent transparent transparent}.split.button{position:relative;padding-right:4.8em}.split.button span{display:block;height:100%;position:absolute;right:0;top:0;border-left:solid 1px}.split.button span:before{position:absolute;content:"";width:0;height:0;display:block;border-style:inset;left:50%}.split.button span:active{background-color:rgba(0,0,0,0.1)}.split.button span{border-left-color:#1e728c}.split.button span{width:3em}.split.button span:before{border-top-style:solid;border-width:0.5625em;top:1.125em;margin-left:-0.5625em}.split.button span:before{border-color:#fff transparent transparent transparent}.split.button.secondary span{border-left-color:#c3c3c3}.split.button.secondary span:before{border-color:#fff transparent transparent transparent}.split.button.alert span{border-left-color:#7f0a0c}.split.button.success span{border-left-color:#396516}.split.button.tiny{padding-right:3.9375em}.split.button.tiny span{width:2.84375em}.split.button.tiny span:before{border-top-style:solid;border-width:0.4375em;top:0.875em;margin-left:-0.3125em}.split.button.small{padding-right:3.9375em}.split.button.small span{width:2.8125em}.split.button.small span:before{border-top-style:solid;border-width:0.5625em;top:0.84375em;margin-left:-0.5625em}.split.button.large{padding-right:6em}.split.button.large span{width:3.75em}.split.button.large span:before{border-top-style:solid;border-width:0.625em;top:1.3125em;margin-left:-0.5625em}.split.button.expand{padding-left:2em}.split.button.secondary span:before{border-color:#333 transparent transparent transparent}.split.button.radius span{-moz-border-radius-topright:3px;-moz-border-radius-bottomright:3px;-webkit-border-top-right-radius:3px;-webkit-border-bottom-right-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px}.split.button.round span{-moz-border-radius-topright:1000px;-moz-border-radius-bottomright:1000px;-webkit-border-top-right-radius:1000px;-webkit-border-bottom-right-radius:1000px;border-top-right-radius:1000px;border-bottom-right-radius:1000px}.flex-video{position:relative;padding-top:1.5625em;padding-bottom:67.5%;height:0;margin-bottom:1em;overflow:hidden}.flex-video.widescreen{padding-bottom:57.25%}.flex-video.vimeo{padding-top:0}.flex-video iframe,.flex-video object,.flex-video embed,.flex-video video{position:absolute;top:0;left:0;width:100%;height:100%}[data-section=''],[data-section='auto'],.section-container.auto,[data-section='vertical-tabs'],.section-container.vertical-tabs,[data-section='vertical-nav'],.section-container.vertical-nav,[data-section='horizontal-nav'],.section-container.horizontal-nav,[data-section='accordion'],.section-container.accordion{width:100%;position:relative;display:block;margin-bottom:1.25em}[data-section=''][data-section-small-style],[data-section='auto'][data-section-small-style],.section-container.auto[data-section-small-style],[data-section='vertical-tabs'][data-section-small-style],.section-container.vertical-tabs[data-section-small-style],[data-section='vertical-nav'][data-section-small-style],.section-container.vertical-nav[data-section-small-style],[data-section='horizontal-nav'][data-section-small-style],.section-container.horizontal-nav[data-section-small-style],[data-section='accordion'][data-section-small-style],.section-container.accordion[data-section-small-style]{width:100% !important}[data-section=''][data-section-small-style]>[data-section-region],[data-section=''][data-section-small-style]>section,[data-section=''][data-section-small-style]>.section,[data-section='auto'][data-section-small-style]>[data-section-region],[data-section='auto'][data-section-small-style]>section,[data-section='auto'][data-section-small-style]>.section,.section-container.auto[data-section-small-style]>[data-section-region],.section-container.auto[data-section-small-style]>section,.section-container.auto[data-section-small-style]>.section,[data-section='vertical-tabs'][data-section-small-style]>[data-section-region],[data-section='vertical-tabs'][data-section-small-style]>section,[data-section='vertical-tabs'][data-section-small-style]>.section,.section-container.vertical-tabs[data-section-small-style]>[data-section-region],.section-container.vertical-tabs[data-section-small-style]>section,.section-container.vertical-tabs[data-section-small-style]>.section,[data-section='vertical-nav'][data-section-small-style]>[data-section-region],[data-section='vertical-nav'][data-section-small-style]>section,[data-section='vertical-nav'][data-section-small-style]>.section,.section-container.vertical-nav[data-section-small-style]>[data-section-region],.section-container.vertical-nav[data-section-small-style]>section,.section-container.vertical-nav[data-section-small-style]>.section,[data-section='horizontal-nav'][data-section-small-style]>[data-section-region],[data-section='horizontal-nav'][data-section-small-style]>section,[data-section='horizontal-nav'][data-section-small-style]>.section,.section-container.horizontal-nav[data-section-small-style]>[data-section-region],.section-container.horizontal-nav[data-section-small-style]>section,.section-container.horizontal-nav[data-section-small-style]>.section,[data-section='accordion'][data-section-small-style]>[data-section-region],[data-section='accordion'][data-section-small-style]>section,[data-section='accordion'][data-section-small-style]>.section,.section-container.accordion[data-section-small-style]>[data-section-region],.section-container.accordion[data-section-small-style]>section,.section-container.accordion[data-section-small-style]>.section{padding:0 !important;margin:0 !important}[data-section=''][data-section-small-style]>[data-section-region]>[data-section-title],[data-section=''][data-section-small-style]>[data-section-region]>.title,[data-section=''][data-section-small-style]>section>[data-section-title],[data-section=''][data-section-small-style]>section>.title,[data-section=''][data-section-small-style]>.section>[data-section-title],[data-section=''][data-section-small-style]>.section>.title,[data-section='auto'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='auto'][data-section-small-style]>[data-section-region]>.title,[data-section='auto'][data-section-small-style]>section>[data-section-title],[data-section='auto'][data-section-small-style]>section>.title,[data-section='auto'][data-section-small-style]>.section>[data-section-title],[data-section='auto'][data-section-small-style]>.section>.title,.section-container.auto[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.auto[data-section-small-style]>[data-section-region]>.title,.section-container.auto[data-section-small-style]>section>[data-section-title],.section-container.auto[data-section-small-style]>section>.title,.section-container.auto[data-section-small-style]>.section>[data-section-title],.section-container.auto[data-section-small-style]>.section>.title,[data-section='vertical-tabs'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='vertical-tabs'][data-section-small-style]>[data-section-region]>.title,[data-section='vertical-tabs'][data-section-small-style]>section>[data-section-title],[data-section='vertical-tabs'][data-section-small-style]>section>.title,[data-section='vertical-tabs'][data-section-small-style]>.section>[data-section-title],[data-section='vertical-tabs'][data-section-small-style]>.section>.title,.section-container.vertical-tabs[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.vertical-tabs[data-section-small-style]>[data-section-region]>.title,.section-container.vertical-tabs[data-section-small-style]>section>[data-section-title],.section-container.vertical-tabs[data-section-small-style]>section>.title,.section-container.vertical-tabs[data-section-small-style]>.section>[data-section-title],.section-container.vertical-tabs[data-section-small-style]>.section>.title,[data-section='vertical-nav'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='vertical-nav'][data-section-small-style]>[data-section-region]>.title,[data-section='vertical-nav'][data-section-small-style]>section>[data-section-title],[data-section='vertical-nav'][data-section-small-style]>section>.title,[data-section='vertical-nav'][data-section-small-style]>.section>[data-section-title],[data-section='vertical-nav'][data-section-small-style]>.section>.title,.section-container.vertical-nav[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.vertical-nav[data-section-small-style]>[data-section-region]>.title,.section-container.vertical-nav[data-section-small-style]>section>[data-section-title],.section-container.vertical-nav[data-section-small-style]>section>.title,.section-container.vertical-nav[data-section-small-style]>.section>[data-section-title],.section-container.vertical-nav[data-section-small-style]>.section>.title,[data-section='horizontal-nav'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='horizontal-nav'][data-section-small-style]>[data-section-region]>.title,[data-section='horizontal-nav'][data-section-small-style]>section>[data-section-title],[data-section='horizontal-nav'][data-section-small-style]>section>.title,[data-section='horizontal-nav'][data-section-small-style]>.section>[data-section-title],[data-section='horizontal-nav'][data-section-small-style]>.section>.title,.section-container.horizontal-nav[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.horizontal-nav[data-section-small-style]>[data-section-region]>.title,.section-container.horizontal-nav[data-section-small-style]>section>[data-section-title],.section-container.horizontal-nav[data-section-small-style]>section>.title,.section-container.horizontal-nav[data-section-small-style]>.section>[data-section-title],.section-container.horizontal-nav[data-section-small-style]>.section>.title,[data-section='accordion'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='accordion'][data-section-small-style]>[data-section-region]>.title,[data-section='accordion'][data-section-small-style]>section>[data-section-title],[data-section='accordion'][data-section-small-style]>section>.title,[data-section='accordion'][data-section-small-style]>.section>[data-section-title],[data-section='accordion'][data-section-small-style]>.section>.title,.section-container.accordion[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.accordion[data-section-small-style]>[data-section-region]>.title,.section-container.accordion[data-section-small-style]>section>[data-section-title],.section-container.accordion[data-section-small-style]>section>.title,.section-container.accordion[data-section-small-style]>.section>[data-section-title],.section-container.accordion[data-section-small-style]>.section>.title{width:100% !important}[data-section='']>section,[data-section='']>.section,[data-section='']>[data-section-region],[data-section='auto']>section,[data-section='auto']>.section,[data-section='auto']>[data-section-region],.section-container.auto>section,.section-container.auto>.section,.section-container.auto>[data-section-region],[data-section='vertical-tabs']>section,[data-section='vertical-tabs']>.section,[data-section='vertical-tabs']>[data-section-region],.section-container.vertical-tabs>section,.section-container.vertical-tabs>.section,.section-container.vertical-tabs>[data-section-region],[data-section='vertical-nav']>section,[data-section='vertical-nav']>.section,[data-section='vertical-nav']>[data-section-region],.section-container.vertical-nav>section,.section-container.vertical-nav>.section,.section-container.vertical-nav>[data-section-region],[data-section='horizontal-nav']>section,[data-section='horizontal-nav']>.section,[data-section='horizontal-nav']>[data-section-region],.section-container.horizontal-nav>section,.section-container.horizontal-nav>.section,.section-container.horizontal-nav>[data-section-region],[data-section='accordion']>section,[data-section='accordion']>.section,[data-section='accordion']>[data-section-region],.section-container.accordion>section,.section-container.accordion>.section,.section-container.accordion>[data-section-region]{margin:0}[data-section='']>section>[data-section-title],[data-section='']>section>.title,[data-section='']>.section>[data-section-title],[data-section='']>.section>.title,[data-section='']>[data-section-region]>[data-section-title],[data-section='']>[data-section-region]>.title,[data-section='auto']>section>[data-section-title],[data-section='auto']>section>.title,[data-section='auto']>.section>[data-section-title],[data-section='auto']>.section>.title,[data-section='auto']>[data-section-region]>[data-section-title],[data-section='auto']>[data-section-region]>.title,.section-container.auto>section>[data-section-title],.section-container.auto>section>.title,.section-container.auto>.section>[data-section-title],.section-container.auto>.section>.title,.section-container.auto>[data-section-region]>[data-section-title],.section-container.auto>[data-section-region]>.title,[data-section='vertical-tabs']>section>[data-section-title],[data-section='vertical-tabs']>section>.title,[data-section='vertical-tabs']>.section>[data-section-title],[data-section='vertical-tabs']>.section>.title,[data-section='vertical-tabs']>[data-section-region]>[data-section-title],[data-section='vertical-tabs']>[data-section-region]>.title,.section-container.vertical-tabs>section>[data-section-title],.section-container.vertical-tabs>section>.title,.section-container.vertical-tabs>.section>[data-section-title],.section-container.vertical-tabs>.section>.title,.section-container.vertical-tabs>[data-section-region]>[data-section-title],.section-container.vertical-tabs>[data-section-region]>.title,[data-section='vertical-nav']>section>[data-section-title],[data-section='vertical-nav']>section>.title,[data-section='vertical-nav']>.section>[data-section-title],[data-section='vertical-nav']>.section>.title,[data-section='vertical-nav']>[data-section-region]>[data-section-title],[data-section='vertical-nav']>[data-section-region]>.title,.section-container.vertical-nav>section>[data-section-title],.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>[data-section-title],.section-container.vertical-nav>.section>.title,.section-container.vertical-nav>[data-section-region]>[data-section-title],.section-container.vertical-nav>[data-section-region]>.title,[data-section='horizontal-nav']>section>[data-section-title],[data-section='horizontal-nav']>section>.title,[data-section='horizontal-nav']>.section>[data-section-title],[data-section='horizontal-nav']>.section>.title,[data-section='horizontal-nav']>[data-section-region]>[data-section-title],[data-section='horizontal-nav']>[data-section-region]>.title,.section-container.horizontal-nav>section>[data-section-title],.section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>[data-section-title],.section-container.horizontal-nav>.section>.title,.section-container.horizontal-nav>[data-section-region]>[data-section-title],.section-container.horizontal-nav>[data-section-region]>.title,[data-section='accordion']>section>[data-section-title],[data-section='accordion']>section>.title,[data-section='accordion']>.section>[data-section-title],[data-section='accordion']>.section>.title,[data-section='accordion']>[data-section-region]>[data-section-title],[data-section='accordion']>[data-section-region]>.title,.section-container.accordion>section>[data-section-title],.section-container.accordion>section>.title,.section-container.accordion>.section>[data-section-title],.section-container.accordion>.section>.title,.section-container.accordion>[data-section-region]>[data-section-title],.section-container.accordion>[data-section-region]>.title{margin-bottom:0}[data-section='']>section>[data-section-title] a,[data-section='']>section>.title a,[data-section='']>.section>[data-section-title] a,[data-section='']>.section>.title a,[data-section='']>[data-section-region]>[data-section-title] a,[data-section='']>[data-section-region]>.title a,[data-section='auto']>section>[data-section-title] a,[data-section='auto']>section>.title a,[data-section='auto']>.section>[data-section-title] a,[data-section='auto']>.section>.title a,[data-section='auto']>[data-section-region]>[data-section-title] a,[data-section='auto']>[data-section-region]>.title a,.section-container.auto>section>[data-section-title] a,.section-container.auto>section>.title a,.section-container.auto>.section>[data-section-title] a,.section-container.auto>.section>.title a,.section-container.auto>[data-section-region]>[data-section-title] a,.section-container.auto>[data-section-region]>.title a,[data-section='vertical-tabs']>section>[data-section-title] a,[data-section='vertical-tabs']>section>.title a,[data-section='vertical-tabs']>.section>[data-section-title] a,[data-section='vertical-tabs']>.section>.title a,[data-section='vertical-tabs']>[data-section-region]>[data-section-title] a,[data-section='vertical-tabs']>[data-section-region]>.title a,.section-container.vertical-tabs>section>[data-section-title] a,.section-container.vertical-tabs>section>.title a,.section-container.vertical-tabs>.section>[data-section-title] a,.section-container.vertical-tabs>.section>.title a,.section-container.vertical-tabs>[data-section-region]>[data-section-title] a,.section-container.vertical-tabs>[data-section-region]>.title a,[data-section='vertical-nav']>section>[data-section-title] a,[data-section='vertical-nav']>section>.title a,[data-section='vertical-nav']>.section>[data-section-title] a,[data-section='vertical-nav']>.section>.title a,[data-section='vertical-nav']>[data-section-region]>[data-section-title] a,[data-section='vertical-nav']>[data-section-region]>.title a,.section-container.vertical-nav>section>[data-section-title] a,.section-container.vertical-nav>section>.title a,.section-container.vertical-nav>.section>[data-section-title] a,.section-container.vertical-nav>.section>.title a,.section-container.vertical-nav>[data-section-region]>[data-section-title] a,.section-container.vertical-nav>[data-section-region]>.title a,[data-section='horizontal-nav']>section>[data-section-title] a,[data-section='horizontal-nav']>section>.title a,[data-section='horizontal-nav']>.section>[data-section-title] a,[data-section='horizontal-nav']>.section>.title a,[data-section='horizontal-nav']>[data-section-region]>[data-section-title] a,[data-section='horizontal-nav']>[data-section-region]>.title a,.section-container.horizontal-nav>section>[data-section-title] a,.section-container.horizontal-nav>section>.title a,.section-container.horizontal-nav>.section>[data-section-title] a,.section-container.horizontal-nav>.section>.title a,.section-container.horizontal-nav>[data-section-region]>[data-section-title] a,.section-container.horizontal-nav>[data-section-region]>.title a,[data-section='accordion']>section>[data-section-title] a,[data-section='accordion']>section>.title a,[data-section='accordion']>.section>[data-section-title] a,[data-section='accordion']>.section>.title a,[data-section='accordion']>[data-section-region]>[data-section-title] a,[data-section='accordion']>[data-section-region]>.title a,.section-container.accordion>section>[data-section-title] a,.section-container.accordion>section>.title a,.section-container.accordion>.section>[data-section-title] a,.section-container.accordion>.section>.title a,.section-container.accordion>[data-section-region]>[data-section-title] a,.section-container.accordion>[data-section-region]>.title a{width:100%;display:inline-block;white-space:nowrap}[data-section='']>section>[data-section-content],[data-section='']>section>.content,[data-section='']>.section>[data-section-content],[data-section='']>.section>.content,[data-section='']>[data-section-region]>[data-section-content],[data-section='']>[data-section-region]>.content,[data-section='auto']>section>[data-section-content],[data-section='auto']>section>.content,[data-section='auto']>.section>[data-section-content],[data-section='auto']>.section>.content,[data-section='auto']>[data-section-region]>[data-section-content],[data-section='auto']>[data-section-region]>.content,.section-container.auto>section>[data-section-content],.section-container.auto>section>.content,.section-container.auto>.section>[data-section-content],.section-container.auto>.section>.content,.section-container.auto>[data-section-region]>[data-section-content],.section-container.auto>[data-section-region]>.content,[data-section='vertical-tabs']>section>[data-section-content],[data-section='vertical-tabs']>section>.content,[data-section='vertical-tabs']>.section>[data-section-content],[data-section='vertical-tabs']>.section>.content,[data-section='vertical-tabs']>[data-section-region]>[data-section-content],[data-section='vertical-tabs']>[data-section-region]>.content,.section-container.vertical-tabs>section>[data-section-content],.section-container.vertical-tabs>section>.content,.section-container.vertical-tabs>.section>[data-section-content],.section-container.vertical-tabs>.section>.content,.section-container.vertical-tabs>[data-section-region]>[data-section-content],.section-container.vertical-tabs>[data-section-region]>.content,[data-section='vertical-nav']>section>[data-section-content],[data-section='vertical-nav']>section>.content,[data-section='vertical-nav']>.section>[data-section-content],[data-section='vertical-nav']>.section>.content,[data-section='vertical-nav']>[data-section-region]>[data-section-content],[data-section='vertical-nav']>[data-section-region]>.content,.section-container.vertical-nav>section>[data-section-content],.section-container.vertical-nav>section>.content,.section-container.vertical-nav>.section>[data-section-content],.section-container.vertical-nav>.section>.content,.section-container.vertical-nav>[data-section-region]>[data-section-content],.section-container.vertical-nav>[data-section-region]>.content,[data-section='horizontal-nav']>section>[data-section-content],[data-section='horizontal-nav']>section>.content,[data-section='horizontal-nav']>.section>[data-section-content],[data-section='horizontal-nav']>.section>.content,[data-section='horizontal-nav']>[data-section-region]>[data-section-content],[data-section='horizontal-nav']>[data-section-region]>.content,.section-container.horizontal-nav>section>[data-section-content],.section-container.horizontal-nav>section>.content,.section-container.horizontal-nav>.section>[data-section-content],.section-container.horizontal-nav>.section>.content,.section-container.horizontal-nav>[data-section-region]>[data-section-content],.section-container.horizontal-nav>[data-section-region]>.content,[data-section='accordion']>section>[data-section-content],[data-section='accordion']>section>.content,[data-section='accordion']>.section>[data-section-content],[data-section='accordion']>.section>.content,[data-section='accordion']>[data-section-region]>[data-section-content],[data-section='accordion']>[data-section-region]>.content,.section-container.accordion>section>[data-section-content],.section-container.accordion>section>.content,.section-container.accordion>.section>[data-section-content],.section-container.accordion>.section>.content,.section-container.accordion>[data-section-region]>[data-section-content],.section-container.accordion>[data-section-region]>.content{display:none}[data-section='']>section.active>[data-section-content],[data-section='']>section.active>.content,[data-section='']>.section.active>[data-section-content],[data-section='']>.section.active>.content,[data-section='']>[data-section-region].active>[data-section-content],[data-section='']>[data-section-region].active>.content,[data-section='auto']>section.active>[data-section-content],[data-section='auto']>section.active>.content,[data-section='auto']>.section.active>[data-section-content],[data-section='auto']>.section.active>.content,[data-section='auto']>[data-section-region].active>[data-section-content],[data-section='auto']>[data-section-region].active>.content,.section-container.auto>section.active>[data-section-content],.section-container.auto>section.active>.content,.section-container.auto>.section.active>[data-section-content],.section-container.auto>.section.active>.content,.section-container.auto>[data-section-region].active>[data-section-content],.section-container.auto>[data-section-region].active>.content,[data-section='vertical-tabs']>section.active>[data-section-content],[data-section='vertical-tabs']>section.active>.content,[data-section='vertical-tabs']>.section.active>[data-section-content],[data-section='vertical-tabs']>.section.active>.content,[data-section='vertical-tabs']>[data-section-region].active>[data-section-content],[data-section='vertical-tabs']>[data-section-region].active>.content,.section-container.vertical-tabs>section.active>[data-section-content],.section-container.vertical-tabs>section.active>.content,.section-container.vertical-tabs>.section.active>[data-section-content],.section-container.vertical-tabs>.section.active>.content,.section-container.vertical-tabs>[data-section-region].active>[data-section-content],.section-container.vertical-tabs>[data-section-region].active>.content,[data-section='vertical-nav']>section.active>[data-section-content],[data-section='vertical-nav']>section.active>.content,[data-section='vertical-nav']>.section.active>[data-section-content],[data-section='vertical-nav']>.section.active>.content,[data-section='vertical-nav']>[data-section-region].active>[data-section-content],[data-section='vertical-nav']>[data-section-region].active>.content,.section-container.vertical-nav>section.active>[data-section-content],.section-container.vertical-nav>section.active>.content,.section-container.vertical-nav>.section.active>[data-section-content],.section-container.vertical-nav>.section.active>.content,.section-container.vertical-nav>[data-section-region].active>[data-section-content],.section-container.vertical-nav>[data-section-region].active>.content,[data-section='horizontal-nav']>section.active>[data-section-content],[data-section='horizontal-nav']>section.active>.content,[data-section='horizontal-nav']>.section.active>[data-section-content],[data-section='horizontal-nav']>.section.active>.content,[data-section='horizontal-nav']>[data-section-region].active>[data-section-content],[data-section='horizontal-nav']>[data-section-region].active>.content,.section-container.horizontal-nav>section.active>[data-section-content],.section-container.horizontal-nav>section.active>.content,.section-container.horizontal-nav>.section.active>[data-section-content],.section-container.horizontal-nav>.section.active>.content,.section-container.horizontal-nav>[data-section-region].active>[data-section-content],.section-container.horizontal-nav>[data-section-region].active>.content,[data-section='accordion']>section.active>[data-section-content],[data-section='accordion']>section.active>.content,[data-section='accordion']>.section.active>[data-section-content],[data-section='accordion']>.section.active>.content,[data-section='accordion']>[data-section-region].active>[data-section-content],[data-section='accordion']>[data-section-region].active>.content,.section-container.accordion>section.active>[data-section-content],.section-container.accordion>section.active>.content,.section-container.accordion>.section.active>[data-section-content],.section-container.accordion>.section.active>.content,.section-container.accordion>[data-section-region].active>[data-section-content],.section-container.accordion>[data-section-region].active>.content{display:block}[data-section='']>section:not(.active),[data-section='']>.section:not(.active),[data-section='']>[data-section-region]:not(.active),[data-section='auto']>section:not(.active),[data-section='auto']>.section:not(.active),[data-section='auto']>[data-section-region]:not(.active),.section-container.auto>section:not(.active),.section-container.auto>.section:not(.active),.section-container.auto>[data-section-region]:not(.active),[data-section='vertical-tabs']>section:not(.active),[data-section='vertical-tabs']>.section:not(.active),[data-section='vertical-tabs']>[data-section-region]:not(.active),.section-container.vertical-tabs>section:not(.active),.section-container.vertical-tabs>.section:not(.active),.section-container.vertical-tabs>[data-section-region]:not(.active),[data-section='vertical-nav']>section:not(.active),[data-section='vertical-nav']>.section:not(.active),[data-section='vertical-nav']>[data-section-region]:not(.active),.section-container.vertical-nav>section:not(.active),.section-container.vertical-nav>.section:not(.active),.section-container.vertical-nav>[data-section-region]:not(.active),[data-section='horizontal-nav']>section:not(.active),[data-section='horizontal-nav']>.section:not(.active),[data-section='horizontal-nav']>[data-section-region]:not(.active),.section-container.horizontal-nav>section:not(.active),.section-container.horizontal-nav>.section:not(.active),.section-container.horizontal-nav>[data-section-region]:not(.active),[data-section='accordion']>section:not(.active),[data-section='accordion']>.section:not(.active),[data-section='accordion']>[data-section-region]:not(.active),.section-container.accordion>section:not(.active),.section-container.accordion>.section:not(.active),.section-container.accordion>[data-section-region]:not(.active){padding:0 !important}[data-section='']>section>[data-section-title],[data-section='']>section>.title,[data-section='']>.section>[data-section-title],[data-section='']>.section>.title,[data-section='']>[data-section-region]>[data-section-title],[data-section='']>[data-section-region]>.title,[data-section='auto']>section>[data-section-title],[data-section='auto']>section>.title,[data-section='auto']>.section>[data-section-title],[data-section='auto']>.section>.title,[data-section='auto']>[data-section-region]>[data-section-title],[data-section='auto']>[data-section-region]>.title,.section-container.auto>section>[data-section-title],.section-container.auto>section>.title,.section-container.auto>.section>[data-section-title],.section-container.auto>.section>.title,.section-container.auto>[data-section-region]>[data-section-title],.section-container.auto>[data-section-region]>.title,[data-section='vertical-tabs']>section>[data-section-title],[data-section='vertical-tabs']>section>.title,[data-section='vertical-tabs']>.section>[data-section-title],[data-section='vertical-tabs']>.section>.title,[data-section='vertical-tabs']>[data-section-region]>[data-section-title],[data-section='vertical-tabs']>[data-section-region]>.title,.section-container.vertical-tabs>section>[data-section-title],.section-container.vertical-tabs>section>.title,.section-container.vertical-tabs>.section>[data-section-title],.section-container.vertical-tabs>.section>.title,.section-container.vertical-tabs>[data-section-region]>[data-section-title],.section-container.vertical-tabs>[data-section-region]>.title,[data-section='vertical-nav']>section>[data-section-title],[data-section='vertical-nav']>section>.title,[data-section='vertical-nav']>.section>[data-section-title],[data-section='vertical-nav']>.section>.title,[data-section='vertical-nav']>[data-section-region]>[data-section-title],[data-section='vertical-nav']>[data-section-region]>.title,.section-container.vertical-nav>section>[data-section-title],.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>[data-section-title],.section-container.vertical-nav>.section>.title,.section-container.vertical-nav>[data-section-region]>[data-section-title],.section-container.vertical-nav>[data-section-region]>.title,[data-section='horizontal-nav']>section>[data-section-title],[data-section='horizontal-nav']>section>.title,[data-section='horizontal-nav']>.section>[data-section-title],[data-section='horizontal-nav']>.section>.title,[data-section='horizontal-nav']>[data-section-region]>[data-section-title],[data-section='horizontal-nav']>[data-section-region]>.title,.section-container.horizontal-nav>section>[data-section-title],.section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>[data-section-title],.section-container.horizontal-nav>.section>.title,.section-container.horizontal-nav>[data-section-region]>[data-section-title],.section-container.horizontal-nav>[data-section-region]>.title,[data-section='accordion']>section>[data-section-title],[data-section='accordion']>section>.title,[data-section='accordion']>.section>[data-section-title],[data-section='accordion']>.section>.title,[data-section='accordion']>[data-section-region]>[data-section-title],[data-section='accordion']>[data-section-region]>.title,.section-container.accordion>section>[data-section-title],.section-container.accordion>section>.title,.section-container.accordion>.section>[data-section-title],.section-container.accordion>.section>.title,.section-container.accordion>[data-section-region]>[data-section-title],.section-container.accordion>[data-section-region]>.title{width:100%}.section-container.auto,.section-container.vertical-tabs,.section-container.vertical-nav,.section-container.horizontal-nav,.section-container.accordion{border-top:1px solid #ccc}.section-container.auto>section>.title,.section-container.auto>.section>.title,.section-container.vertical-tabs>section>.title,.section-container.vertical-tabs>.section>.title,.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>.title,.section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>.title,.section-container.accordion>section>.title,.section-container.accordion>.section>.title{background-color:#efefef;cursor:pointer;border:solid 1px #ccc}.section-container.auto>section>.title a,.section-container.auto>.section>.title a,.section-container.vertical-tabs>section>.title a,.section-container.vertical-tabs>.section>.title a,.section-container.vertical-nav>section>.title a,.section-container.vertical-nav>.section>.title a,.section-container.horizontal-nav>section>.title a,.section-container.horizontal-nav>.section>.title a,.section-container.accordion>section>.title a,.section-container.accordion>.section>.title a{padding:0.9375em;color:#333;font-size:0.875em;background:none}.section-container.auto>section>.title:hover,.section-container.auto>.section>.title:hover,.section-container.vertical-tabs>section>.title:hover,.section-container.vertical-tabs>.section>.title:hover,.section-container.vertical-nav>section>.title:hover,.section-container.vertical-nav>.section>.title:hover,.section-container.horizontal-nav>section>.title:hover,.section-container.horizontal-nav>.section>.title:hover,.section-container.accordion>section>.title:hover,.section-container.accordion>.section>.title:hover{background-color:#e2e2e2}.section-container.auto>section>.content,.section-container.auto>.section>.content,.section-container.vertical-tabs>section>.content,.section-container.vertical-tabs>.section>.content,.section-container.vertical-nav>section>.content,.section-container.vertical-nav>.section>.content,.section-container.horizontal-nav>section>.content,.section-container.horizontal-nav>.section>.content,.section-container.accordion>section>.content,.section-container.accordion>.section>.content{padding:0.9375em;background-color:#fff;border:solid 1px #ccc}.section-container.auto>section>.content>*:last-child,.section-container.auto>.section>.content>*:last-child,.section-container.vertical-tabs>section>.content>*:last-child,.section-container.vertical-tabs>.section>.content>*:last-child,.section-container.vertical-nav>section>.content>*:last-child,.section-container.vertical-nav>.section>.content>*:last-child,.section-container.horizontal-nav>section>.content>*:last-child,.section-container.horizontal-nav>.section>.content>*:last-child,.section-container.accordion>section>.content>*:last-child,.section-container.accordion>.section>.content>*:last-child{margin-bottom:0}.section-container.auto>section>.content>*:first-child,.section-container.auto>.section>.content>*:first-child,.section-container.vertical-tabs>section>.content>*:first-child,.section-container.vertical-tabs>.section>.content>*:first-child,.section-container.vertical-nav>section>.content>*:first-child,.section-container.vertical-nav>.section>.content>*:first-child,.section-container.horizontal-nav>section>.content>*:first-child,.section-container.horizontal-nav>.section>.content>*:first-child,.section-container.accordion>section>.content>*:first-child,.section-container.accordion>.section>.content>*:first-child{padding-top:0}.section-container.auto>section>.content>*:last-child:not(.flex-video),.section-container.auto>.section>.content>*:last-child:not(.flex-video),.section-container.vertical-tabs>section>.content>*:last-child:not(.flex-video),.section-container.vertical-tabs>.section>.content>*:last-child:not(.flex-video),.section-container.vertical-nav>section>.content>*:last-child:not(.flex-video),.section-container.vertical-nav>.section>.content>*:last-child:not(.flex-video),.section-container.horizontal-nav>section>.content>*:last-child:not(.flex-video),.section-container.horizontal-nav>.section>.content>*:last-child:not(.flex-video),.section-container.accordion>section>.content>*:last-child:not(.flex-video),.section-container.accordion>.section>.content>*:last-child:not(.flex-video){padding-bottom:0}.section-container.auto>section.active>.title,.section-container.auto>.section.active>.title,.section-container.vertical-tabs>section.active>.title,.section-container.vertical-tabs>.section.active>.title,.section-container.vertical-nav>section.active>.title,.section-container.vertical-nav>.section.active>.title,.section-container.horizontal-nav>section.active>.title,.section-container.horizontal-nav>.section.active>.title,.section-container.accordion>section.active>.title,.section-container.accordion>.section.active>.title{background:#d5d5d5}.section-container.auto>section.active>.title a,.section-container.auto>.section.active>.title a,.section-container.vertical-tabs>section.active>.title a,.section-container.vertical-tabs>.section.active>.title a,.section-container.vertical-nav>section.active>.title a,.section-container.vertical-nav>.section.active>.title a,.section-container.horizontal-nav>section.active>.title a,.section-container.horizontal-nav>.section.active>.title a,.section-container.accordion>section.active>.title a,.section-container.accordion>.section.active>.title a{color:#333}.section-container.auto>section:not(.active),.section-container.auto>.section:not(.active),.section-container.vertical-tabs>section:not(.active),.section-container.vertical-tabs>.section:not(.active),.section-container.vertical-nav>section:not(.active),.section-container.vertical-nav>.section:not(.active),.section-container.horizontal-nav>section:not(.active),.section-container.horizontal-nav>.section:not(.active),.section-container.accordion>section:not(.active),.section-container.accordion>.section:not(.active){padding:0 !important}.section-container.auto>section>.title,.section-container.auto>.section>.title,.section-container.vertical-tabs>section>.title,.section-container.vertical-tabs>.section>.title,.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>.title,.section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>.title,.section-container.accordion>section>.title,.section-container.accordion>.section>.title{border-top:none}[data-section='tabs'],.section-container.tabs{width:100%;position:relative;display:block;margin-bottom:1.25em}[data-section='tabs']:not([data-section-resized]):not([data-section-small-style]),.section-container.tabs:not([data-section-resized]):not([data-section-small-style]){visibility:hidden}[data-section='tabs']>section>[data-section-title],[data-section='tabs']>section>.title,[data-section='tabs']>.section>[data-section-title],[data-section='tabs']>.section>.title,[data-section='tabs']>[data-section-region]>[data-section-title],[data-section='tabs']>[data-section-region]>.title,.section-container.tabs>section>[data-section-title],.section-container.tabs>section>.title,.section-container.tabs>.section>[data-section-title],.section-container.tabs>.section>.title,.section-container.tabs>[data-section-region]>[data-section-title],.section-container.tabs>[data-section-region]>.title{margin-bottom:0}[data-section='tabs']>section>[data-section-title] a,[data-section='tabs']>section>.title a,[data-section='tabs']>.section>[data-section-title] a,[data-section='tabs']>.section>.title a,[data-section='tabs']>[data-section-region]>[data-section-title] a,[data-section='tabs']>[data-section-region]>.title a,.section-container.tabs>section>[data-section-title] a,.section-container.tabs>section>.title a,.section-container.tabs>.section>[data-section-title] a,.section-container.tabs>.section>.title a,.section-container.tabs>[data-section-region]>[data-section-title] a,.section-container.tabs>[data-section-region]>.title a{width:100%;display:inline-block;white-space:nowrap}[data-section='tabs']>section>[data-section-content],[data-section='tabs']>section>.content,[data-section='tabs']>.section>[data-section-content],[data-section='tabs']>.section>.content,[data-section='tabs']>[data-section-region]>[data-section-content],[data-section='tabs']>[data-section-region]>.content,.section-container.tabs>section>[data-section-content],.section-container.tabs>section>.content,.section-container.tabs>.section>[data-section-content],.section-container.tabs>.section>.content,.section-container.tabs>[data-section-region]>[data-section-content],.section-container.tabs>[data-section-region]>.content{display:none}[data-section='tabs']>section.active>[data-section-content],[data-section='tabs']>section.active>.content,[data-section='tabs']>.section.active>[data-section-content],[data-section='tabs']>.section.active>.content,[data-section='tabs']>[data-section-region].active>[data-section-content],[data-section='tabs']>[data-section-region].active>.content,.section-container.tabs>section.active>[data-section-content],.section-container.tabs>section.active>.content,.section-container.tabs>.section.active>[data-section-content],.section-container.tabs>.section.active>.content,.section-container.tabs>[data-section-region].active>[data-section-content],.section-container.tabs>[data-section-region].active>.content{display:block}[data-section='tabs']>section:not(.active),[data-section='tabs']>.section:not(.active),[data-section='tabs']>[data-section-region]:not(.active),.section-container.tabs>section:not(.active),.section-container.tabs>.section:not(.active),.section-container.tabs>[data-section-region]:not(.active){padding:0 !important}[data-section='tabs']>section>[data-section-title],[data-section='tabs']>section>.title,[data-section='tabs']>.section>[data-section-title],[data-section='tabs']>.section>.title,[data-section='tabs']>[data-section-region]>[data-section-title],[data-section='tabs']>[data-section-region]>.title,.section-container.tabs>section>[data-section-title],.section-container.tabs>section>.title,.section-container.tabs>.section>[data-section-title],.section-container.tabs>.section>.title,.section-container.tabs>[data-section-region]>[data-section-title],.section-container.tabs>[data-section-region]>.title{width:auto;position:absolute;top:0;left:0}.section-container.tabs{border:none}.section-container.tabs>section>.title,.section-container.tabs>.section>.title{background-color:#efefef;cursor:pointer;border:solid 1px #ccc}.section-container.tabs>section>.title a,.section-container.tabs>.section>.title a{padding:0.9375em;color:#333;font-size:0.875em;background:none}.section-container.tabs>section>.title:hover,.section-container.tabs>.section>.title:hover{background-color:#e2e2e2}.section-container.tabs>section>.content,.section-container.tabs>.section>.content{padding:0.9375em;background-color:#fff;border:solid 1px #ccc}.section-container.tabs>section>.content>*:last-child,.section-container.tabs>.section>.content>*:last-child{margin-bottom:0}.section-container.tabs>section>.content>*:first-child,.section-container.tabs>.section>.content>*:first-child{padding-top:0}.section-container.tabs>section>.content>*:last-child:not(.flex-video),.section-container.tabs>.section>.content>*:last-child:not(.flex-video){padding-bottom:0}.section-container.tabs>section.active>.title,.section-container.tabs>.section.active>.title{background:#fff}.section-container.tabs>section.active>.title a,.section-container.tabs>.section.active>.title a{color:#333}.section-container.tabs>section:not(.active),.section-container.tabs>.section:not(.active){padding:0 !important}.section-container.tabs>section.active>.title,.section-container.tabs>.section.active>.title{border-bottom:0}@media only screen and (min-width: 768px){[data-section=''],[data-section='auto'],.section-container.auto{width:100%;position:relative;display:block;margin-bottom:1.25em}[data-section='']:not([data-section-resized]):not([data-section-small-style]),[data-section='auto']:not([data-section-resized]):not([data-section-small-style]),.section-container.auto:not([data-section-resized]):not([data-section-small-style]){visibility:hidden}[data-section='']>section>[data-section-title],[data-section='']>section>.title,[data-section='']>.section>[data-section-title],[data-section='']>.section>.title,[data-section='']>[data-section-region]>[data-section-title],[data-section='']>[data-section-region]>.title,[data-section='auto']>section>[data-section-title],[data-section='auto']>section>.title,[data-section='auto']>.section>[data-section-title],[data-section='auto']>.section>.title,[data-section='auto']>[data-section-region]>[data-section-title],[data-section='auto']>[data-section-region]>.title,.section-container.auto>section>[data-section-title],.section-container.auto>section>.title,.section-container.auto>.section>[data-section-title],.section-container.auto>.section>.title,.section-container.auto>[data-section-region]>[data-section-title],.section-container.auto>[data-section-region]>.title{margin-bottom:0}[data-section='']>section>[data-section-title] a,[data-section='']>section>.title a,[data-section='']>.section>[data-section-title] a,[data-section='']>.section>.title a,[data-section='']>[data-section-region]>[data-section-title] a,[data-section='']>[data-section-region]>.title a,[data-section='auto']>section>[data-section-title] a,[data-section='auto']>section>.title a,[data-section='auto']>.section>[data-section-title] a,[data-section='auto']>.section>.title a,[data-section='auto']>[data-section-region]>[data-section-title] a,[data-section='auto']>[data-section-region]>.title a,.section-container.auto>section>[data-section-title] a,.section-container.auto>section>.title a,.section-container.auto>.section>[data-section-title] a,.section-container.auto>.section>.title a,.section-container.auto>[data-section-region]>[data-section-title] a,.section-container.auto>[data-section-region]>.title a{width:100%;display:inline-block;white-space:nowrap}[data-section='']>section>[data-section-content],[data-section='']>section>.content,[data-section='']>.section>[data-section-content],[data-section='']>.section>.content,[data-section='']>[data-section-region]>[data-section-content],[data-section='']>[data-section-region]>.content,[data-section='auto']>section>[data-section-content],[data-section='auto']>section>.content,[data-section='auto']>.section>[data-section-content],[data-section='auto']>.section>.content,[data-section='auto']>[data-section-region]>[data-section-content],[data-section='auto']>[data-section-region]>.content,.section-container.auto>section>[data-section-content],.section-container.auto>section>.content,.section-container.auto>.section>[data-section-content],.section-container.auto>.section>.content,.section-container.auto>[data-section-region]>[data-section-content],.section-container.auto>[data-section-region]>.content{display:none}[data-section='']>section.active>[data-section-content],[data-section='']>section.active>.content,[data-section='']>.section.active>[data-section-content],[data-section='']>.section.active>.content,[data-section='']>[data-section-region].active>[data-section-content],[data-section='']>[data-section-region].active>.content,[data-section='auto']>section.active>[data-section-content],[data-section='auto']>section.active>.content,[data-section='auto']>.section.active>[data-section-content],[data-section='auto']>.section.active>.content,[data-section='auto']>[data-section-region].active>[data-section-content],[data-section='auto']>[data-section-region].active>.content,.section-container.auto>section.active>[data-section-content],.section-container.auto>section.active>.content,.section-container.auto>.section.active>[data-section-content],.section-container.auto>.section.active>.content,.section-container.auto>[data-section-region].active>[data-section-content],.section-container.auto>[data-section-region].active>.content{display:block}[data-section='']>section:not(.active),[data-section='']>.section:not(.active),[data-section='']>[data-section-region]:not(.active),[data-section='auto']>section:not(.active),[data-section='auto']>.section:not(.active),[data-section='auto']>[data-section-region]:not(.active),.section-container.auto>section:not(.active),.section-container.auto>.section:not(.active),.section-container.auto>[data-section-region]:not(.active){padding:0 !important}[data-section='']>section>[data-section-title],[data-section='']>section>.title,[data-section='']>.section>[data-section-title],[data-section='']>.section>.title,[data-section='']>[data-section-region]>[data-section-title],[data-section='']>[data-section-region]>.title,[data-section='auto']>section>[data-section-title],[data-section='auto']>section>.title,[data-section='auto']>.section>[data-section-title],[data-section='auto']>.section>.title,[data-section='auto']>[data-section-region]>[data-section-title],[data-section='auto']>[data-section-region]>.title,.section-container.auto>section>[data-section-title],.section-container.auto>section>.title,.section-container.auto>.section>[data-section-title],.section-container.auto>.section>.title,.section-container.auto>[data-section-region]>[data-section-title],.section-container.auto>[data-section-region]>.title{width:auto;position:absolute;top:0;left:0}.section-container.auto{border:none}.section-container.auto>section>.title,.section-container.auto>.section>.title{background-color:#efefef;cursor:pointer;border:solid 1px #ccc}.section-container.auto>section>.title a,.section-container.auto>.section>.title a{padding:0.9375em;color:#333;font-size:0.875em;background:none}.section-container.auto>section>.title:hover,.section-container.auto>.section>.title:hover{background-color:#e2e2e2}.section-container.auto>section>.content,.section-container.auto>.section>.content{padding:0.9375em;background-color:#fff;border:solid 1px #ccc}.section-container.auto>section>.content>*:last-child,.section-container.auto>.section>.content>*:last-child{margin-bottom:0}.section-container.auto>section>.content>*:first-child,.section-container.auto>.section>.content>*:first-child{padding-top:0}.section-container.auto>section>.content>*:last-child:not(.flex-video),.section-container.auto>.section>.content>*:last-child:not(.flex-video){padding-bottom:0}.section-container.auto>section.active>.title,.section-container.auto>.section.active>.title{background:#fff}.section-container.auto>section.active>.title a,.section-container.auto>.section.active>.title a{color:#333}.section-container.auto>section:not(.active),.section-container.auto>.section:not(.active){padding:0 !important}.section-container.auto>section.active>.title,.section-container.auto>.section.active>.title{border-bottom:0}[data-section='vertical-tabs'],.section-container.vertical-tabs{width:100%;position:relative;display:block;margin-bottom:1.25em}[data-section='vertical-tabs']:not([data-section-resized]):not([data-section-small-style]),.section-container.vertical-tabs:not([data-section-resized]):not([data-section-small-style]){visibility:hidden}[data-section='vertical-tabs'][data-section-small-style],.section-container.vertical-tabs[data-section-small-style]{width:100% !important}[data-section='vertical-tabs'][data-section-small-style]>[data-section-region],[data-section='vertical-tabs'][data-section-small-style]>section,[data-section='vertical-tabs'][data-section-small-style]>.section,.section-container.vertical-tabs[data-section-small-style]>[data-section-region],.section-container.vertical-tabs[data-section-small-style]>section,.section-container.vertical-tabs[data-section-small-style]>.section{padding:0 !important;margin:0 !important}[data-section='vertical-tabs'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='vertical-tabs'][data-section-small-style]>[data-section-region]>.title,[data-section='vertical-tabs'][data-section-small-style]>section>[data-section-title],[data-section='vertical-tabs'][data-section-small-style]>section>.title,[data-section='vertical-tabs'][data-section-small-style]>.section>[data-section-title],[data-section='vertical-tabs'][data-section-small-style]>.section>.title,.section-container.vertical-tabs[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.vertical-tabs[data-section-small-style]>[data-section-region]>.title,.section-container.vertical-tabs[data-section-small-style]>section>[data-section-title],.section-container.vertical-tabs[data-section-small-style]>section>.title,.section-container.vertical-tabs[data-section-small-style]>.section>[data-section-title],.section-container.vertical-tabs[data-section-small-style]>.section>.title{width:100% !important}[data-section='vertical-tabs']>section>[data-section-title],[data-section='vertical-tabs']>section>.title,[data-section='vertical-tabs']>.section>[data-section-title],[data-section='vertical-tabs']>.section>.title,[data-section='vertical-tabs']>[data-section-region]>[data-section-title],[data-section='vertical-tabs']>[data-section-region]>.title,.section-container.vertical-tabs>section>[data-section-title],.section-container.vertical-tabs>section>.title,.section-container.vertical-tabs>.section>[data-section-title],.section-container.vertical-tabs>.section>.title,.section-container.vertical-tabs>[data-section-region]>[data-section-title],.section-container.vertical-tabs>[data-section-region]>.title{margin-bottom:0}[data-section='vertical-tabs']>section>[data-section-title] a,[data-section='vertical-tabs']>section>.title a,[data-section='vertical-tabs']>.section>[data-section-title] a,[data-section='vertical-tabs']>.section>.title a,[data-section='vertical-tabs']>[data-section-region]>[data-section-title] a,[data-section='vertical-tabs']>[data-section-region]>.title a,.section-container.vertical-tabs>section>[data-section-title] a,.section-container.vertical-tabs>section>.title a,.section-container.vertical-tabs>.section>[data-section-title] a,.section-container.vertical-tabs>.section>.title a,.section-container.vertical-tabs>[data-section-region]>[data-section-title] a,.section-container.vertical-tabs>[data-section-region]>.title a{width:100%;display:inline-block;white-space:nowrap}[data-section='vertical-tabs']>section>[data-section-content],[data-section='vertical-tabs']>section>.content,[data-section='vertical-tabs']>.section>[data-section-content],[data-section='vertical-tabs']>.section>.content,[data-section='vertical-tabs']>[data-section-region]>[data-section-content],[data-section='vertical-tabs']>[data-section-region]>.content,.section-container.vertical-tabs>section>[data-section-content],.section-container.vertical-tabs>section>.content,.section-container.vertical-tabs>.section>[data-section-content],.section-container.vertical-tabs>.section>.content,.section-container.vertical-tabs>[data-section-region]>[data-section-content],.section-container.vertical-tabs>[data-section-region]>.content{display:none}[data-section='vertical-tabs']>section.active>[data-section-content],[data-section='vertical-tabs']>section.active>.content,[data-section='vertical-tabs']>.section.active>[data-section-content],[data-section='vertical-tabs']>.section.active>.content,[data-section='vertical-tabs']>[data-section-region].active>[data-section-content],[data-section='vertical-tabs']>[data-section-region].active>.content,.section-container.vertical-tabs>section.active>[data-section-content],.section-container.vertical-tabs>section.active>.content,.section-container.vertical-tabs>.section.active>[data-section-content],.section-container.vertical-tabs>.section.active>.content,.section-container.vertical-tabs>[data-section-region].active>[data-section-content],.section-container.vertical-tabs>[data-section-region].active>.content{display:block}[data-section='vertical-tabs']>section:not(.active),[data-section='vertical-tabs']>.section:not(.active),[data-section='vertical-tabs']>[data-section-region]:not(.active),.section-container.vertical-tabs>section:not(.active),.section-container.vertical-tabs>.section:not(.active),.section-container.vertical-tabs>[data-section-region]:not(.active){padding:0 !important}[data-section='vertical-tabs']>section>[data-section-title],[data-section='vertical-tabs']>section>.title,[data-section='vertical-tabs']>.section>[data-section-title],[data-section='vertical-tabs']>.section>.title,[data-section='vertical-tabs']>[data-section-region]>[data-section-title],[data-section='vertical-tabs']>[data-section-region]>.title,.section-container.vertical-tabs>section>[data-section-title],.section-container.vertical-tabs>section>.title,.section-container.vertical-tabs>.section>[data-section-title],.section-container.vertical-tabs>.section>.title,.section-container.vertical-tabs>[data-section-region]>[data-section-title],.section-container.vertical-tabs>[data-section-region]>.title{position:absolute;top:0;left:0;width:12.5em}[data-section='vertical-tabs']>section.active,[data-section='vertical-tabs']>.section.active,[data-section='vertical-tabs']>[data-section-region].active,.section-container.vertical-tabs>section.active,.section-container.vertical-tabs>.section.active,.section-container.vertical-tabs>[data-section-region].active{padding-left:12.5em}[data-section='vertical-tabs']>section.active>[data-section-title],[data-section='vertical-tabs']>section.active>.title,[data-section='vertical-tabs']>.section.active>[data-section-title],[data-section='vertical-tabs']>.section.active>.title,[data-section='vertical-tabs']>[data-section-region].active>[data-section-title],[data-section='vertical-tabs']>[data-section-region].active>.title,.section-container.vertical-tabs>section.active>[data-section-title],.section-container.vertical-tabs>section.active>.title,.section-container.vertical-tabs>.section.active>[data-section-title],.section-container.vertical-tabs>.section.active>.title,.section-container.vertical-tabs>[data-section-region].active>[data-section-title],.section-container.vertical-tabs>[data-section-region].active>.title{width:12.5em}.section-container.vertical-tabs{border:none}.section-container.vertical-tabs>section>.title,.section-container.vertical-tabs>.section>.title{background-color:#efefef;cursor:pointer;border:solid 1px #ccc}.section-container.vertical-tabs>section>.title a,.section-container.vertical-tabs>.section>.title a{padding:0.9375em;color:#333;font-size:0.875em;background:none}.section-container.vertical-tabs>section>.title:hover,.section-container.vertical-tabs>.section>.title:hover{background-color:#e2e2e2}.section-container.vertical-tabs>section>.content,.section-container.vertical-tabs>.section>.content{padding:0.9375em;background-color:#fff;border:solid 1px #ccc}.section-container.vertical-tabs>section>.content>*:last-child,.section-container.vertical-tabs>.section>.content>*:last-child{margin-bottom:0}.section-container.vertical-tabs>section>.content>*:first-child,.section-container.vertical-tabs>.section>.content>*:first-child{padding-top:0}.section-container.vertical-tabs>section>.content>*:last-child:not(.flex-video),.section-container.vertical-tabs>.section>.content>*:last-child:not(.flex-video){padding-bottom:0}.section-container.vertical-tabs>section.active>.title,.section-container.vertical-tabs>.section.active>.title{background:#d5d5d5}.section-container.vertical-tabs>section.active>.title a,.section-container.vertical-tabs>.section.active>.title a{color:#333}.section-container.vertical-tabs>section:not(.active),.section-container.vertical-tabs>.section:not(.active){padding:0 !important}.section-container.vertical-tabs>section.active,.section-container.vertical-tabs>.section.active{padding-left:12.4375em}.section-container.vertical-tabs>section.active>.title,.section-container.vertical-tabs>.section.active>.title{background-color:#d5d5d5}[data-section='vertical-nav'],.section-container.vertical-nav{width:100%;position:relative;display:block;margin-bottom:1.25em}[data-section='vertical-nav']:not([data-section-resized]):not([data-section-small-style]),.section-container.vertical-nav:not([data-section-resized]):not([data-section-small-style]){visibility:hidden}[data-section='vertical-nav'][data-section-small-style],.section-container.vertical-nav[data-section-small-style]{width:100% !important}[data-section='vertical-nav'][data-section-small-style]>[data-section-region],[data-section='vertical-nav'][data-section-small-style]>section,[data-section='vertical-nav'][data-section-small-style]>.section,.section-container.vertical-nav[data-section-small-style]>[data-section-region],.section-container.vertical-nav[data-section-small-style]>section,.section-container.vertical-nav[data-section-small-style]>.section{padding:0 !important;margin:0 !important}[data-section='vertical-nav'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='vertical-nav'][data-section-small-style]>[data-section-region]>.title,[data-section='vertical-nav'][data-section-small-style]>section>[data-section-title],[data-section='vertical-nav'][data-section-small-style]>section>.title,[data-section='vertical-nav'][data-section-small-style]>.section>[data-section-title],[data-section='vertical-nav'][data-section-small-style]>.section>.title,.section-container.vertical-nav[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.vertical-nav[data-section-small-style]>[data-section-region]>.title,.section-container.vertical-nav[data-section-small-style]>section>[data-section-title],.section-container.vertical-nav[data-section-small-style]>section>.title,.section-container.vertical-nav[data-section-small-style]>.section>[data-section-title],.section-container.vertical-nav[data-section-small-style]>.section>.title{width:100% !important}[data-section='vertical-nav']>section,[data-section='vertical-nav']>.section,[data-section='vertical-nav']>[data-section-region],.section-container.vertical-nav>section,.section-container.vertical-nav>.section,.section-container.vertical-nav>[data-section-region]{position:relative;display:inline-block}[data-section='vertical-nav']>section>[data-section-title],[data-section='vertical-nav']>section>.title,[data-section='vertical-nav']>.section>[data-section-title],[data-section='vertical-nav']>.section>.title,[data-section='vertical-nav']>[data-section-region]>[data-section-title],[data-section='vertical-nav']>[data-section-region]>.title,.section-container.vertical-nav>section>[data-section-title],.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>[data-section-title],.section-container.vertical-nav>.section>.title,.section-container.vertical-nav>[data-section-region]>[data-section-title],.section-container.vertical-nav>[data-section-region]>.title{margin-bottom:0}[data-section='vertical-nav']>section>[data-section-title] a,[data-section='vertical-nav']>section>.title a,[data-section='vertical-nav']>.section>[data-section-title] a,[data-section='vertical-nav']>.section>.title a,[data-section='vertical-nav']>[data-section-region]>[data-section-title] a,[data-section='vertical-nav']>[data-section-region]>.title a,.section-container.vertical-nav>section>[data-section-title] a,.section-container.vertical-nav>section>.title a,.section-container.vertical-nav>.section>[data-section-title] a,.section-container.vertical-nav>.section>.title a,.section-container.vertical-nav>[data-section-region]>[data-section-title] a,.section-container.vertical-nav>[data-section-region]>.title a{width:100%;display:inline-block;white-space:nowrap}[data-section='vertical-nav']>section>[data-section-content],[data-section='vertical-nav']>section>.content,[data-section='vertical-nav']>.section>[data-section-content],[data-section='vertical-nav']>.section>.content,[data-section='vertical-nav']>[data-section-region]>[data-section-content],[data-section='vertical-nav']>[data-section-region]>.content,.section-container.vertical-nav>section>[data-section-content],.section-container.vertical-nav>section>.content,.section-container.vertical-nav>.section>[data-section-content],.section-container.vertical-nav>.section>.content,.section-container.vertical-nav>[data-section-region]>[data-section-content],.section-container.vertical-nav>[data-section-region]>.content{display:none}[data-section='vertical-nav']>section.active>[data-section-content],[data-section='vertical-nav']>section.active>.content,[data-section='vertical-nav']>.section.active>[data-section-content],[data-section='vertical-nav']>.section.active>.content,[data-section='vertical-nav']>[data-section-region].active>[data-section-content],[data-section='vertical-nav']>[data-section-region].active>.content,.section-container.vertical-nav>section.active>[data-section-content],.section-container.vertical-nav>section.active>.content,.section-container.vertical-nav>.section.active>[data-section-content],.section-container.vertical-nav>.section.active>.content,.section-container.vertical-nav>[data-section-region].active>[data-section-content],.section-container.vertical-nav>[data-section-region].active>.content{display:block}[data-section='vertical-nav']>section:not(.active),[data-section='vertical-nav']>.section:not(.active),[data-section='vertical-nav']>[data-section-region]:not(.active),.section-container.vertical-nav>section:not(.active),.section-container.vertical-nav>.section:not(.active),.section-container.vertical-nav>[data-section-region]:not(.active){padding:0 !important}[data-section='vertical-nav']>section>[data-section-title],[data-section='vertical-nav']>section>.title,[data-section='vertical-nav']>.section>[data-section-title],[data-section='vertical-nav']>.section>.title,[data-section='vertical-nav']>[data-section-region]>[data-section-title],[data-section='vertical-nav']>[data-section-region]>.title,.section-container.vertical-nav>section>[data-section-title],.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>[data-section-title],.section-container.vertical-nav>.section>.title,.section-container.vertical-nav>[data-section-region]>[data-section-title],.section-container.vertical-nav>[data-section-region]>.title{position:static;width:auto}[data-section='vertical-nav']>section>[data-section-title] a,[data-section='vertical-nav']>section>.title a,[data-section='vertical-nav']>.section>[data-section-title] a,[data-section='vertical-nav']>.section>.title a,[data-section='vertical-nav']>[data-section-region]>[data-section-title] a,[data-section='vertical-nav']>[data-section-region]>.title a,.section-container.vertical-nav>section>[data-section-title] a,.section-container.vertical-nav>section>.title a,.section-container.vertical-nav>.section>[data-section-title] a,.section-container.vertical-nav>.section>.title a,.section-container.vertical-nav>[data-section-region]>[data-section-title] a,.section-container.vertical-nav>[data-section-region]>.title a{display:block}[data-section='vertical-nav']>section>[data-section-content],[data-section='vertical-nav']>section>.content,[data-section='vertical-nav']>.section>[data-section-content],[data-section='vertical-nav']>.section>.content,[data-section='vertical-nav']>[data-section-region]>[data-section-content],[data-section='vertical-nav']>[data-section-region]>.content,.section-container.vertical-nav>section>[data-section-content],.section-container.vertical-nav>section>.content,.section-container.vertical-nav>.section>[data-section-content],.section-container.vertical-nav>.section>.content,.section-container.vertical-nav>[data-section-region]>[data-section-content],.section-container.vertical-nav>[data-section-region]>.content{position:absolute;top:0;left:0;z-index:999;min-width:12.5em}.section-container.vertical-nav{border:none}.section-container.vertical-nav>section>.title,.section-container.vertical-nav>.section>.title{background-color:#efefef;cursor:pointer;border:solid 1px #ccc}.section-container.vertical-nav>section>.title a,.section-container.vertical-nav>.section>.title a{padding:0.9375em;color:#333;font-size:0.875em;background:none}.section-container.vertical-nav>section>.title:hover,.section-container.vertical-nav>.section>.title:hover{background-color:#e2e2e2}.section-container.vertical-nav>section>.content,.section-container.vertical-nav>.section>.content{padding:0.9375em;background-color:#fff;border:solid 1px #ccc}.section-container.vertical-nav>section>.content>*:last-child,.section-container.vertical-nav>.section>.content>*:last-child{margin-bottom:0}.section-container.vertical-nav>section>.content>*:first-child,.section-container.vertical-nav>.section>.content>*:first-child{padding-top:0}.section-container.vertical-nav>section>.content>*:last-child:not(.flex-video),.section-container.vertical-nav>.section>.content>*:last-child:not(.flex-video){padding-bottom:0}.section-container.vertical-nav>section.active>.title,.section-container.vertical-nav>.section.active>.title{background:#d5d5d5}.section-container.vertical-nav>section.active>.title a,.section-container.vertical-nav>.section.active>.title a{color:#333}.section-container.vertical-nav>section:not(.active),.section-container.vertical-nav>.section:not(.active){padding:0 !important}[data-section='horizontal-nav'],.section-container.horizontal-nav{width:100%;position:relative;display:block;margin-bottom:1.25em}[data-section='horizontal-nav']:not([data-section-resized]):not([data-section-small-style]),.section-container.horizontal-nav:not([data-section-resized]):not([data-section-small-style]){visibility:hidden}[data-section='horizontal-nav'][data-section-small-style],.section-container.horizontal-nav[data-section-small-style]{width:100% !important}[data-section='horizontal-nav'][data-section-small-style]>[data-section-region],[data-section='horizontal-nav'][data-section-small-style]>section,[data-section='horizontal-nav'][data-section-small-style]>.section,.section-container.horizontal-nav[data-section-small-style]>[data-section-region],.section-container.horizontal-nav[data-section-small-style]>section,.section-container.horizontal-nav[data-section-small-style]>.section{padding:0 !important;margin:0 !important}[data-section='horizontal-nav'][data-section-small-style]>[data-section-region]>[data-section-title],[data-section='horizontal-nav'][data-section-small-style]>[data-section-region]>.title,[data-section='horizontal-nav'][data-section-small-style]>section>[data-section-title],[data-section='horizontal-nav'][data-section-small-style]>section>.title,[data-section='horizontal-nav'][data-section-small-style]>.section>[data-section-title],[data-section='horizontal-nav'][data-section-small-style]>.section>.title,.section-container.horizontal-nav[data-section-small-style]>[data-section-region]>[data-section-title],.section-container.horizontal-nav[data-section-small-style]>[data-section-region]>.title,.section-container.horizontal-nav[data-section-small-style]>section>[data-section-title],.section-container.horizontal-nav[data-section-small-style]>section>.title,.section-container.horizontal-nav[data-section-small-style]>.section>[data-section-title],.section-container.horizontal-nav[data-section-small-style]>.section>.title{width:100% !important}[data-section='horizontal-nav']>section,[data-section='horizontal-nav']>.section,[data-section='horizontal-nav']>[data-section-region],.section-container.horizontal-nav>section,.section-container.horizontal-nav>.section,.section-container.horizontal-nav>[data-section-region]{position:relative;float:left}[data-section='horizontal-nav']>section>[data-section-title],[data-section='horizontal-nav']>section>.title,[data-section='horizontal-nav']>.section>[data-section-title],[data-section='horizontal-nav']>.section>.title,[data-section='horizontal-nav']>[data-section-region]>[data-section-title],[data-section='horizontal-nav']>[data-section-region]>.title,.section-container.horizontal-nav>section>[data-section-title],.section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>[data-section-title],.section-container.horizontal-nav>.section>.title,.section-container.horizontal-nav>[data-section-region]>[data-section-title],.section-container.horizontal-nav>[data-section-region]>.title{margin-bottom:0}[data-section='horizontal-nav']>section>[data-section-title] a,[data-section='horizontal-nav']>section>.title a,[data-section='horizontal-nav']>.section>[data-section-title] a,[data-section='horizontal-nav']>.section>.title a,[data-section='horizontal-nav']>[data-section-region]>[data-section-title] a,[data-section='horizontal-nav']>[data-section-region]>.title a,.section-container.horizontal-nav>section>[data-section-title] a,.section-container.horizontal-nav>section>.title a,.section-container.horizontal-nav>.section>[data-section-title] a,.section-container.horizontal-nav>.section>.title a,.section-container.horizontal-nav>[data-section-region]>[data-section-title] a,.section-container.horizontal-nav>[data-section-region]>.title a{width:100%;display:inline-block;white-space:nowrap}[data-section='horizontal-nav']>section>[data-section-content],[data-section='horizontal-nav']>section>.content,[data-section='horizontal-nav']>.section>[data-section-content],[data-section='horizontal-nav']>.section>.content,[data-section='horizontal-nav']>[data-section-region]>[data-section-content],[data-section='horizontal-nav']>[data-section-region]>.content,.section-container.horizontal-nav>section>[data-section-content],.section-container.horizontal-nav>section>.content,.section-container.horizontal-nav>.section>[data-section-content],.section-container.horizontal-nav>.section>.content,.section-container.horizontal-nav>[data-section-region]>[data-section-content],.section-container.horizontal-nav>[data-section-region]>.content{display:none}[data-section='horizontal-nav']>section.active>[data-section-content],[data-section='horizontal-nav']>section.active>.content,[data-section='horizontal-nav']>.section.active>[data-section-content],[data-section='horizontal-nav']>.section.active>.content,[data-section='horizontal-nav']>[data-section-region].active>[data-section-content],[data-section='horizontal-nav']>[data-section-region].active>.content,.section-container.horizontal-nav>section.active>[data-section-content],.section-container.horizontal-nav>section.active>.content,.section-container.horizontal-nav>.section.active>[data-section-content],.section-container.horizontal-nav>.section.active>.content,.section-container.horizontal-nav>[data-section-region].active>[data-section-content],.section-container.horizontal-nav>[data-section-region].active>.content{display:block}[data-section='horizontal-nav']>section:not(.active),[data-section='horizontal-nav']>.section:not(.active),[data-section='horizontal-nav']>[data-section-region]:not(.active),.section-container.horizontal-nav>section:not(.active),.section-container.horizontal-nav>.section:not(.active),.section-container.horizontal-nav>[data-section-region]:not(.active){padding:0 !important}[data-section='horizontal-nav']>section>[data-section-title],[data-section='horizontal-nav']>section>.title,[data-section='horizontal-nav']>.section>[data-section-title],[data-section='horizontal-nav']>.section>.title,[data-section='horizontal-nav']>[data-section-region]>[data-section-title],[data-section='horizontal-nav']>[data-section-region]>.title,.section-container.horizontal-nav>section>[data-section-title],.section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>[data-section-title],.section-container.horizontal-nav>.section>.title,.section-container.horizontal-nav>[data-section-region]>[data-section-title],.section-container.horizontal-nav>[data-section-region]>.title{position:static;width:auto}[data-section='horizontal-nav']>section>[data-section-title] a,[data-section='horizontal-nav']>section>.title a,[data-section='horizontal-nav']>.section>[data-section-title] a,[data-section='horizontal-nav']>.section>.title a,[data-section='horizontal-nav']>[data-section-region]>[data-section-title] a,[data-section='horizontal-nav']>[data-section-region]>.title a,.section-container.horizontal-nav>section>[data-section-title] a,.section-container.horizontal-nav>section>.title a,.section-container.horizontal-nav>.section>[data-section-title] a,.section-container.horizontal-nav>.section>.title a,.section-container.horizontal-nav>[data-section-region]>[data-section-title] a,.section-container.horizontal-nav>[data-section-region]>.title a{display:block}[data-section='horizontal-nav']>section>[data-section-content],[data-section='horizontal-nav']>section>.content,[data-section='horizontal-nav']>.section>[data-section-content],[data-section='horizontal-nav']>.section>.content,[data-section='horizontal-nav']>[data-section-region]>[data-section-content],[data-section='horizontal-nav']>[data-section-region]>.content,.section-container.horizontal-nav>section>[data-section-content],.section-container.horizontal-nav>section>.content,.section-container.horizontal-nav>.section>[data-section-content],.section-container.horizontal-nav>.section>.content,.section-container.horizontal-nav>[data-section-region]>[data-section-content],.section-container.horizontal-nav>[data-section-region]>.content{width:auto;position:absolute;top:0;left:0;z-index:999;min-width:12.5em}.section-container.horizontal-nav{background:#efefef;border:1px solid #ccc}.section-container.horizontal-nav>section>.title,.section-container.horizontal-nav>.section>.title{background-color:#efefef;cursor:pointer;border:solid 1px #ccc}.section-container.horizontal-nav>section>.title a,.section-container.horizontal-nav>.section>.title a{padding:0.9375em;color:#333;font-size:0.875em;background:none}.section-container.horizontal-nav>section>.title:hover,.section-container.horizontal-nav>.section>.title:hover{background-color:#e2e2e2}.section-container.horizontal-nav>section>.content,.section-container.horizontal-nav>.section>.content{padding:0.9375em;background-color:#fff;border:solid 1px #ccc}.section-container.horizontal-nav>section>.content>*:last-child,.section-container.horizontal-nav>.section>.content>*:last-child{margin-bottom:0}.section-container.horizontal-nav>section>.content>*:first-child,.section-container.horizontal-nav>.section>.content>*:first-child{padding-top:0}.section-container.horizontal-nav>section>.content>*:last-child:not(.flex-video),.section-container.horizontal-nav>.section>.content>*:last-child:not(.flex-video){padding-bottom:0}.section-container.horizontal-nav>section.active>.title,.section-container.horizontal-nav>.section.active>.title{background:#d5d5d5}.section-container.horizontal-nav>section.active>.title a,.section-container.horizontal-nav>.section.active>.title a{color:#333}.section-container.horizontal-nav>section:not(.active),.section-container.horizontal-nav>.section:not(.active){padding:0 !important}}.no-js [data-section],.no-js .section-container{width:100%;position:relative;display:block;margin-bottom:1.25em}.no-js [data-section][data-section-small-style],.no-js .section-container[data-section-small-style]{width:100% !important}.no-js [data-section][data-section-small-style]>[data-section-region],.no-js [data-section][data-section-small-style]>section,.no-js [data-section][data-section-small-style]>.section,.no-js .section-container[data-section-small-style]>[data-section-region],.no-js .section-container[data-section-small-style]>section,.no-js .section-container[data-section-small-style]>.section{padding:0 !important;margin:0 !important}.no-js [data-section][data-section-small-style]>[data-section-region]>[data-section-title],.no-js [data-section][data-section-small-style]>[data-section-region]>.title,.no-js [data-section][data-section-small-style]>section>[data-section-title],.no-js [data-section][data-section-small-style]>section>.title,.no-js [data-section][data-section-small-style]>.section>[data-section-title],.no-js [data-section][data-section-small-style]>.section>.title,.no-js .section-container[data-section-small-style]>[data-section-region]>[data-section-title],.no-js .section-container[data-section-small-style]>[data-section-region]>.title,.no-js .section-container[data-section-small-style]>section>[data-section-title],.no-js .section-container[data-section-small-style]>section>.title,.no-js .section-container[data-section-small-style]>.section>[data-section-title],.no-js .section-container[data-section-small-style]>.section>.title{width:100% !important}.no-js [data-section]>section,.no-js [data-section]>.section,.no-js [data-section]>[data-section-region],.no-js .section-container>section,.no-js .section-container>.section,.no-js .section-container>[data-section-region]{margin:0}.no-js [data-section]>section>[data-section-title],.no-js [data-section]>section>.title,.no-js [data-section]>.section>[data-section-title],.no-js [data-section]>.section>.title,.no-js [data-section]>[data-section-region]>[data-section-title],.no-js [data-section]>[data-section-region]>.title,.no-js .section-container>section>[data-section-title],.no-js .section-container>section>.title,.no-js .section-container>.section>[data-section-title],.no-js .section-container>.section>.title,.no-js .section-container>[data-section-region]>[data-section-title],.no-js .section-container>[data-section-region]>.title{margin-bottom:0}.no-js [data-section]>section>[data-section-title] a,.no-js [data-section]>section>.title a,.no-js [data-section]>.section>[data-section-title] a,.no-js [data-section]>.section>.title a,.no-js [data-section]>[data-section-region]>[data-section-title] a,.no-js [data-section]>[data-section-region]>.title a,.no-js .section-container>section>[data-section-title] a,.no-js .section-container>section>.title a,.no-js .section-container>.section>[data-section-title] a,.no-js .section-container>.section>.title a,.no-js .section-container>[data-section-region]>[data-section-title] a,.no-js .section-container>[data-section-region]>.title a{width:100%;display:inline-block;white-space:nowrap}.no-js [data-section]>section>[data-section-content],.no-js [data-section]>section>.content,.no-js [data-section]>.section>[data-section-content],.no-js [data-section]>.section>.content,.no-js [data-section]>[data-section-region]>[data-section-content],.no-js [data-section]>[data-section-region]>.content,.no-js .section-container>section>[data-section-content],.no-js .section-container>section>.content,.no-js .section-container>.section>[data-section-content],.no-js .section-container>.section>.content,.no-js .section-container>[data-section-region]>[data-section-content],.no-js .section-container>[data-section-region]>.content{display:none}.no-js [data-section]>section.active>[data-section-content],.no-js [data-section]>section.active>.content,.no-js [data-section]>.section.active>[data-section-content],.no-js [data-section]>.section.active>.content,.no-js [data-section]>[data-section-region].active>[data-section-content],.no-js [data-section]>[data-section-region].active>.content,.no-js .section-container>section.active>[data-section-content],.no-js .section-container>section.active>.content,.no-js .section-container>.section.active>[data-section-content],.no-js .section-container>.section.active>.content,.no-js .section-container>[data-section-region].active>[data-section-content],.no-js .section-container>[data-section-region].active>.content{display:block}.no-js [data-section]>section:not(.active),.no-js [data-section]>.section:not(.active),.no-js [data-section]>[data-section-region]:not(.active),.no-js .section-container>section:not(.active),.no-js .section-container>.section:not(.active),.no-js .section-container>[data-section-region]:not(.active){padding:0 !important}.no-js [data-section]>section>[data-section-title],.no-js [data-section]>section>.title,.no-js [data-section]>.section>[data-section-title],.no-js [data-section]>.section>.title,.no-js [data-section]>[data-section-region]>[data-section-title],.no-js [data-section]>[data-section-region]>.title,.no-js .section-container>section>[data-section-title],.no-js .section-container>section>.title,.no-js .section-container>.section>[data-section-title],.no-js .section-container>.section>.title,.no-js .section-container>[data-section-region]>[data-section-title],.no-js .section-container>[data-section-region]>.title{width:100%}.no-js .section-container{border-top:1px solid #ccc}.no-js .section-container>section>.title,.no-js .section-container>.section>.title{background-color:#efefef;cursor:pointer;border:solid 1px #ccc}.no-js .section-container>section>.title a,.no-js .section-container>.section>.title a{padding:0.9375em;color:#333;font-size:0.875em;background:none}.no-js .section-container>section>.title:hover,.no-js .section-container>.section>.title:hover{background-color:#e2e2e2}.no-js .section-container>section>.content,.no-js .section-container>.section>.content{padding:0.9375em;background-color:#fff;border:solid 1px #ccc}.no-js .section-container>section>.content>*:last-child,.no-js .section-container>.section>.content>*:last-child{margin-bottom:0}.no-js .section-container>section>.content>*:first-child,.no-js .section-container>.section>.content>*:first-child{padding-top:0}.no-js .section-container>section>.content>*:last-child:not(.flex-video),.no-js .section-container>.section>.content>*:last-child:not(.flex-video){padding-bottom:0}.no-js .section-container>section.active>.title,.no-js .section-container>.section.active>.title{background:#d5d5d5}.no-js .section-container>section.active>.title a,.no-js .section-container>.section.active>.title a{color:#333}.no-js .section-container>section:not(.active),.no-js .section-container>.section:not(.active){padding:0 !important}.no-js .section-container>section>.title,.no-js .section-container>.section>.title{border-top:none}.contain-to-grid{width:100%;background:#111}.contain-to-grid .top-bar{margin-bottom:0}.fixed{width:100%;left:0;position:fixed;top:0;z-index:99}.fixed.expanded:not(.top-bar){overflow-y:auto;height:auto;width:100%;max-height:100%}.fixed.expanded:not(.top-bar) .title-area{position:fixed;width:100%;z-index:99}.fixed.expanded:not(.top-bar) .top-bar-section{z-index:98;margin-top:45px}.top-bar{overflow:hidden;height:45px;line-height:45px;position:relative;background:#111;margin-bottom:0}.top-bar ul{margin-bottom:0;list-style:none}.top-bar .row{max-width:none}.top-bar form,.top-bar input{margin-bottom:0}.top-bar input{height:2.45em}.top-bar .button{padding-top:.5em;padding-bottom:.5em;margin-bottom:0}.top-bar .title-area{position:relative;margin:0}.top-bar .name{height:45px;margin:0;font-size:16px}.top-bar .name h1{line-height:45px;font-size:1.0625em;margin:0}.top-bar .name h1 a{font-weight:bold;color:#fff;width:50%;display:block;padding:0 15px}.top-bar .toggle-topbar{position:absolute;right:0;top:0}.top-bar .toggle-topbar a{color:#fff;text-transform:uppercase;font-size:0.8125em;font-weight:bold;position:relative;display:block;padding:0 15px;height:45px;line-height:45px}.top-bar .toggle-topbar.menu-icon{right:15px;top:50%;margin-top:-16px;padding-left:40px}.top-bar .toggle-topbar.menu-icon a{text-indent:-48px;width:34px;height:34px;line-height:33px;padding:0;color:#fff}.top-bar .toggle-topbar.menu-icon a span{position:absolute;right:0;display:block;width:16px;height:0;-webkit-box-shadow:0 10px 0 1px #fff,0 16px 0 1px #fff,0 22px 0 1px #fff;box-shadow:0 10px 0 1px #fff,0 16px 0 1px #fff,0 22px 0 1px #fff}.top-bar.expanded{height:auto;background:transparent}.top-bar.expanded .title-area{background:#111}.top-bar.expanded .toggle-topbar a{color:#888}.top-bar.expanded .toggle-topbar a span{-webkit-box-shadow:0 10px 0 1px #888,0 16px 0 1px #888,0 22px 0 1px #888;box-shadow:0 10px 0 1px #888,0 16px 0 1px #888,0 22px 0 1px #888}.top-bar-section{left:0;position:relative;width:auto;-webkit-transition:left 300ms ease-out;-moz-transition:left 300ms ease-out;transition:left 300ms ease-out}.top-bar-section ul{width:100%;height:auto;display:block;background:#222;font-size:16px;margin:0}.top-bar-section .divider,.top-bar-section [role="separator"]{border-bottom:solid 1px #2b2b2b;border-top:solid 1px #000;clear:both;height:1px;width:100%}.top-bar-section ul li>a{display:block;width:100%;color:#fff;padding:12px 0 12px 0;padding-left:15px;font-size:0.8125em;font-weight:bold;background:#222}.top-bar-section ul li>a.button{background:#2ba6cb;font-size:0.8125em;padding-right:15px;padding-left:15px}.top-bar-section ul li>a.button:hover{background:#2284a1}.top-bar-section ul li>a.button.secondary{background:#e9e9e9}.top-bar-section ul li>a.button.secondary:hover{background:#d0d0d0}.top-bar-section ul li>a.button.success{background:#5da423}.top-bar-section ul li>a.button.success:hover{background:#457a1a}.top-bar-section ul li>a.button.alert{background:#c60f13}.top-bar-section ul li>a.button.alert:hover{background:#970b0e}.top-bar-section ul li:hover>a{background:#000;color:#fff}.top-bar-section ul li.active>a{background:#090909;color:#fff}.top-bar-section .has-form{padding:15px}.top-bar-section .has-dropdown{position:relative}.top-bar-section .has-dropdown>a:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:transparent transparent transparent rgba(255,255,255,0.5);border-left-style:solid;margin-right:15px;margin-top:-4.5px;position:absolute;top:50%;right:0}.top-bar-section .has-dropdown.moved{position:static}.top-bar-section .has-dropdown.moved>.dropdown{display:block}.top-bar-section .dropdown{position:absolute;left:100%;top:0;display:none;z-index:99}.top-bar-section .dropdown li{width:100%;height:auto}.top-bar-section .dropdown li a{font-weight:normal;padding:8px 15px}.top-bar-section .dropdown li a.parent-link{font-weight:bold}.top-bar-section .dropdown li.title h5{margin-bottom:0}.top-bar-section .dropdown li.title h5 a{color:#fff;line-height:22.5px;display:block}.top-bar-section .dropdown label{padding:8px 15px 2px;margin-bottom:0;text-transform:uppercase;color:#555;font-weight:bold;font-size:0.625em}.top-bar-js-breakpoint{width:940px !important;visibility:hidden}.js-generated{display:block}@media only screen and (min-width: 940px){.top-bar{background:#111;*zoom:1;overflow:visible}.top-bar:before,.top-bar:after{content:" ";display:table}.top-bar:after{clear:both}.top-bar .toggle-topbar{display:none}.top-bar .title-area{float:left}.top-bar .name h1 a{width:auto}.top-bar input,.top-bar .button{line-height:2em;font-size:0.875em;height:2em;padding:0 10px;position:relative;top:8px}.top-bar.expanded{background:#111}.contain-to-grid .top-bar{max-width:62.5em;margin:0 auto;margin-bottom:0}.top-bar-section{-webkit-transition:none 0 0;-moz-transition:none 0 0;transition:none 0 0;left:0 !important}.top-bar-section ul{width:auto;height:auto !important;display:inline}.top-bar-section ul li{float:left}.top-bar-section ul li .js-generated{display:none}.top-bar-section li.hover>a:not(.button){background:#000;color:#fff}.top-bar-section li a:not(.button){padding:0 15px;line-height:45px;background:#111}.top-bar-section li a:not(.button):hover{background:#000}.top-bar-section .has-dropdown>a{padding-right:35px !important}.top-bar-section .has-dropdown>a:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:rgba(255,255,255,0.5) transparent transparent transparent;border-top-style:solid;margin-top:-2.5px;top:22.5px}.top-bar-section .has-dropdown.moved{position:relative}.top-bar-section .has-dropdown.moved>.dropdown{display:none}.top-bar-section .has-dropdown.hover>.dropdown,.top-bar-section .has-dropdown.not-click:hover>.dropdown{display:block}.top-bar-section .has-dropdown .dropdown li.has-dropdown>a:after{border:none;content:"\00bb";top:1em;margin-top:-7px;right:5px}.top-bar-section .dropdown{left:0;top:auto;background:transparent;min-width:100%}.top-bar-section .dropdown li a{color:#fff;line-height:1;white-space:nowrap;padding:7px 15px;background:#1e1e1e}.top-bar-section .dropdown li label{white-space:nowrap;background:#1e1e1e}.top-bar-section .dropdown li .dropdown{left:100%;top:0}.top-bar-section>ul>.divider,.top-bar-section>ul>[role="separator"]{border-bottom:none;border-top:none;border-right:solid 1px #2b2b2b;border-left:solid 1px #000;clear:none;height:45px;width:0}.top-bar-section .has-form{background:#111;padding:0 15px;height:45px}.top-bar-section ul.right li .dropdown{left:auto;right:0}.top-bar-section ul.right li .dropdown li .dropdown{right:100%}.no-js .top-bar-section ul li:hover>a{background:#000;color:#fff}.no-js .top-bar-section ul li:active>a{background:#090909;color:#fff}.no-js .top-bar-section .has-dropdown:hover>.dropdown{display:block}}@-webkit-keyframes rotate{from{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@-moz-keyframes rotate{from{-moz-transform:rotate(0deg)}to{-moz-transform:rotate(360deg)}}@-o-keyframes rotate{from{-o-transform:rotate(0deg)}to{-o-transform:rotate(360deg)}}@keyframes rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}.slideshow-wrapper{position:relative}.slideshow-wrapper ul{list-style-type:none;margin:0}.slideshow-wrapper ul li,.slideshow-wrapper ul li .orbit-caption{display:none}.slideshow-wrapper ul li:first-child{display:block}.slideshow-wrapper .orbit-container{background-color:transparent}.slideshow-wrapper .orbit-container li{display:block}.slideshow-wrapper .orbit-container li .orbit-caption{display:block}.preloader{display:block;width:40px;height:40px;position:absolute;top:50%;left:50%;margin-top:-20px;margin-left:-20px;border:solid 3px;border-color:#555 #fff;-webkit-border-radius:1000px;border-radius:1000px;-webkit-animation-name:rotate;-webkit-animation-duration:1.5s;-webkit-animation-iteration-count:infinite;-webkit-animation-timing-function:linear;-moz-animation-name:rotate;-moz-animation-duration:1.5s;-moz-animation-iteration-count:infinite;-moz-animation-timing-function:linear;-o-animation-name:rotate;-o-animation-duration:1.5s;-o-animation-iteration-count:infinite;-o-animation-timing-function:linear;animation-name:rotate;animation-duration:1.5s;animation-iteration-count:infinite;animation-timing-function:linear}.orbit-container{overflow:hidden;width:100%;position:relative;background:#f5f5f5}.orbit-container .orbit-slides-container{list-style:none;margin:0;padding:0;position:relative}.orbit-container .orbit-slides-container img{display:block;max-width:100%}.orbit-container .orbit-slides-container>*{position:absolute;top:0;width:100%;margin-left:100%}.orbit-container .orbit-slides-container>*:first-child{margin-left:0%}.orbit-container .orbit-slides-container>* .orbit-caption{position:absolute;bottom:0;background-color:rgba(0,0,0,0.6);color:#fff;width:100%;padding:10px 14px;font-size:0.875em}.orbit-container .orbit-slide-number{position:absolute;top:10px;left:10px;font-size:12px;color:#fff;background:rgba(0,0,0,0);z-index:10}.orbit-container .orbit-slide-number span{font-weight:700;padding:0.3125em}.orbit-container .orbit-timer{position:absolute;top:10px;right:10px;height:6px;width:100px;z-index:10}.orbit-container .orbit-timer .orbit-progress{height:100%;background-color:rgba(0,0,0,0.6);display:block;width:0%}.orbit-container .orbit-timer>span{display:none;position:absolute;top:10px;right:0;width:11px;height:14px;border:solid 4px #000;border-top:none;border-bottom:none}.orbit-container .orbit-timer.paused>span{right:-6px;top:9px;width:11px;height:14px;border:inset 8px;border-right-style:solid;border-color:transparent transparent transparent #000}.orbit-container:hover .orbit-timer>span{display:block}.orbit-container .orbit-prev,.orbit-container .orbit-next{position:absolute;top:50%;margin-top:-25px;background-color:rgba(0,0,0,0.6);width:50px;height:60px;line-height:50px;color:white;text-indent:-9999px !important;z-index:10}.orbit-container .orbit-prev:hover,.orbit-container .orbit-next:hover{background-color:rgba(0,0,0,0.6)}.orbit-container .orbit-prev>span,.orbit-container .orbit-next>span{position:absolute;top:50%;margin-top:-16px;display:block;width:0;height:0;border:inset 16px}.orbit-container .orbit-prev{left:0}.orbit-container .orbit-prev>span{border-right-style:solid;border-color:transparent;border-right-color:#fff}.orbit-container .orbit-prev:hover>span{border-right-color:#ccc}.orbit-container .orbit-next{right:0}.orbit-container .orbit-next>span{border-color:transparent;border-left-style:solid;border-left-color:#fff;left:50%;margin-left:-8px}.orbit-container .orbit-next:hover>span{border-left-color:#ccc}.orbit-bullets{margin:0 auto 30px auto;overflow:hidden;position:relative;top:10px}.orbit-bullets li{display:block;width:0.75em;height:0.75em;background:#999;float:left;margin-right:6px;border:solid 1px #555;-webkit-border-radius:1000px;border-radius:1000px}.orbit-bullets li.active{background:#555}.orbit-bullets li:last-child{margin-right:0}.touch .orbit-container .orbit-prev,.touch .orbit-container .orbit-next{display:none}.touch .orbit-bullets{display:none}@media only screen and (min-width: 768px){.touch .orbit-container .orbit-prev,.touch .orbit-container .orbit-next{display:inherit}.touch .orbit-bullets{display:block}}@media only screen and (max-width: 768px){.orbit-stack-on-small .orbit-slides-container{height:auto !important}.orbit-stack-on-small .orbit-slides-container>*{position:relative;margin-left:0% !important}.orbit-stack-on-small .orbit-timer,.orbit-stack-on-small .orbit-next,.orbit-stack-on-small .orbit-prev,.orbit-stack-on-small .orbit-bullets{display:none}}.reveal-modal-bg{position:fixed;height:100%;width:100%;background:#000;background:rgba(0,0,0,0.45);z-index:98;display:none;top:0;left:0}.reveal-modal{visibility:hidden;display:none;position:absolute;left:50%;z-index:99;height:auto;margin-left:-40%;width:80%;background-color:#fff;padding:1.25em;border:solid 1px #666;-webkit-box-shadow:0 0 10px rgba(0,0,0,0.4);box-shadow:0 0 10px rgba(0,0,0,0.4);top:50px}.reveal-modal .column,.reveal-modal .columns{min-width:0}.reveal-modal>:first-child{margin-top:0}.reveal-modal>:last-child{margin-bottom:0}.reveal-modal .close-reveal-modal{font-size:1.375em;line-height:1;position:absolute;top:0.5em;right:0.6875em;color:#aaa;font-weight:bold;cursor:pointer}@media only screen and (min-width: 768px){.reveal-modal{padding:1.875em;top:6.25em}.reveal-modal.tiny{margin-left:-15%;width:30%}.reveal-modal.small{margin-left:-20%;width:40%}.reveal-modal.medium{margin-left:-30%;width:60%}.reveal-modal.large{margin-left:-35%;width:70%}.reveal-modal.xlarge{margin-left:-47.5%;width:95%}}@media print{.reveal-modal{background:#fff !important}}.joyride-list{display:none}.joyride-tip-guide{display:none;position:absolute;background:#000;color:#fff;z-index:101;top:0;left:2.5%;font-family:inherit;font-weight:normal;width:95%}.lt-ie9 .joyride-tip-guide{max-width:800px;left:50%;margin-left:-400px}.joyride-content-wrapper{width:100%;padding:1.125em 1.25em 1.5em}.joyride-content-wrapper .button{margin-bottom:0 !important}.joyride-tip-guide .joyride-nub{display:block;position:absolute;left:22px;width:0;height:0;border:inset 14px}.joyride-tip-guide .joyride-nub.top{border-top-style:solid;border-color:#000;border-top-color:transparent !important;border-left-color:transparent !important;border-right-color:transparent !important;top:-28px}.joyride-tip-guide .joyride-nub.bottom{border-bottom-style:solid;border-color:#000 !important;border-bottom-color:transparent !important;border-left-color:transparent !important;border-right-color:transparent !important;bottom:-28px}.joyride-tip-guide .joyride-nub.right{right:-28px}.joyride-tip-guide .joyride-nub.left{left:-28px}.joyride-tip-guide h1,.joyride-tip-guide h2,.joyride-tip-guide h3,.joyride-tip-guide h4,.joyride-tip-guide h5,.joyride-tip-guide h6{line-height:1.25;margin:0;font-weight:bold;color:#fff}.joyride-tip-guide p{margin:0 0 1.125em 0;font-size:0.875em;line-height:1.3}.joyride-timer-indicator-wrap{width:50px;height:3px;border:solid 1px #555;position:absolute;right:1.0625em;bottom:1em}.joyride-timer-indicator{display:block;width:0;height:inherit;background:#666}.joyride-close-tip{position:absolute;right:12px;top:10px;color:#777 !important;text-decoration:none;font-size:30px;font-weight:normal;line-height:0.5 !important}.joyride-close-tip:hover,.joyride-close-tip:focus{color:#eee !important}.joyride-modal-bg{position:fixed;height:100%;width:100%;background:transparent;background:rgba(0,0,0,0.5);z-index:100;display:none;top:0;left:0;cursor:pointer}.joyride-expose-wrapper{background-color:#ffffff;position:absolute;border-radius:3px;z-index:102;-moz-box-shadow:0 0 30px #fff;-webkit-box-shadow:0 0 15px #fff;box-shadow:0 0 15px #fff}.joyride-expose-cover{background:transparent;border-radius:3px;position:absolute;z-index:9999;top:0;left:0}@media only screen and (min-width: 768px){.joyride-tip-guide{width:300px;left:inherit}.joyride-tip-guide .joyride-nub.bottom{border-color:#000 !important;border-bottom-color:transparent !important;border-left-color:transparent !important;border-right-color:transparent !important;bottom:-28px}.joyride-tip-guide .joyride-nub.right{border-color:#000 !important;border-top-color:transparent !important;border-right-color:transparent !important;border-bottom-color:transparent !important;top:22px;left:auto;right:-28px}.joyride-tip-guide .joyride-nub.left{border-color:#000 !important;border-top-color:transparent !important;border-left-color:transparent !important;border-bottom-color:transparent !important;top:22px;left:-28px;right:auto}}[data-clearing]{*zoom:1;margin-bottom:0;margin-left:0;list-style:none}[data-clearing]:before,[data-clearing]:after{content:" ";display:table}[data-clearing]:after{clear:both}[data-clearing] li{float:left;margin-right:10px}.clearing-blackout{background:#111;position:fixed;width:100%;height:100%;top:0;left:0;z-index:998}.clearing-blackout .clearing-close{display:block}.clearing-container{position:relative;z-index:998;height:100%;overflow:hidden;margin:0}.visible-img{height:95%;position:relative}.visible-img img{position:absolute;left:50%;top:50%;margin-left:-50%;max-height:100%;max-width:100%}.clearing-caption{color:#fff;line-height:1.3;margin-bottom:0;text-align:center;bottom:0;background:#111;width:100%;padding:10px 30px;position:absolute;left:0}.clearing-close{z-index:999;padding-left:20px;padding-top:10px;font-size:40px;line-height:1;color:#fff;display:none}.clearing-close:hover,.clearing-close:focus{color:#ccc}.clearing-assembled .clearing-container{height:100%}.clearing-assembled .clearing-container .carousel>ul{display:none}.clearing-feature li{display:none}.clearing-feature li.clearing-featured-img{display:block}@media only screen and (min-width: 768px){.clearing-main-prev,.clearing-main-next{position:absolute;height:100%;width:40px;top:0}.clearing-main-prev>span,.clearing-main-next>span{position:absolute;top:50%;display:block;width:0;height:0;border:solid 16px}.clearing-main-prev{left:0}.clearing-main-prev>span{left:5px;border-color:transparent;border-right-color:#fff}.clearing-main-next{right:0}.clearing-main-next>span{border-color:transparent;border-left-color:#fff}.clearing-main-prev.disabled,.clearing-main-next.disabled{opacity:0.5}.clearing-assembled .clearing-container .carousel{background:#111;height:150px;margin-top:5px}.clearing-assembled .clearing-container .carousel>ul{display:block;z-index:999;width:200%;height:100%;margin-left:0;position:relative;left:0}.clearing-assembled .clearing-container .carousel>ul li{display:block;width:175px;height:inherit;padding:0;float:left;overflow:hidden;margin-right:1px;position:relative;cursor:pointer;opacity:0.4}.clearing-assembled .clearing-container .carousel>ul li.fix-height img{min-height:100%;height:100%;max-width:none}.clearing-assembled .clearing-container .carousel>ul li a.th{border:none;-webkit-box-shadow:none;box-shadow:none;display:block}.clearing-assembled .clearing-container .carousel>ul li img{cursor:pointer !important;min-width:100% !important}.clearing-assembled .clearing-container .carousel>ul li.visible{opacity:1}.clearing-assembled .clearing-container .visible-img{background:#111;overflow:hidden;height:75%}.clearing-close{position:absolute;top:10px;right:20px;padding-left:0;padding-top:0}}.alert-box{border-style:solid;border-width:1px;display:block;font-weight:bold;margin-bottom:1.25em;position:relative;padding:0.6875em 1.3125em 0.75em 0.6875em;font-size:0.875em;background-color:#2ba6cb;border-color:#2284a1;color:#fff}.alert-box .close{font-size:1.375em;padding:5px 4px 4px;line-height:0;position:absolute;top:0.4375em;right:0.3125em;color:#333;opacity:0.3}.alert-box .close:hover,.alert-box .close:focus{opacity:0.5}.alert-box.radius{-webkit-border-radius:3px;border-radius:3px}.alert-box.round{-webkit-border-radius:1000px;border-radius:1000px}.alert-box.success{background-color:#5da423;border-color:#457a1a;color:#fff}.alert-box.alert{background-color:#c60f13;border-color:#970b0e;color:#fff}.alert-box.secondary{background-color:#e9e9e9;border-color:#d0d0d0;color:#505050}.breadcrumbs{display:block;padding:0.5625em 0.875em 0.5625em;overflow:hidden;margin-left:0;list-style:none;border-style:solid;border-width:1px;background-color:#f6f6f6;border-color:#dcdcdc;-webkit-border-radius:3px;border-radius:3px}.breadcrumbs>*{margin:0;float:left;font-size:0.6875em;text-transform:uppercase}.breadcrumbs>*:hover a,.breadcrumbs>*:focus a{text-decoration:underline}.breadcrumbs>* a,.breadcrumbs>* span{text-transform:uppercase;color:#2ba6cb}.breadcrumbs>*.current{cursor:default;color:#333}.breadcrumbs>*.current a{cursor:default;color:#333}.breadcrumbs>*.current:hover,.breadcrumbs>*.current:hover a,.breadcrumbs>*.current:focus,.breadcrumbs>*.current:focus a{text-decoration:none}.breadcrumbs>*.unavailable{color:#999}.breadcrumbs>*.unavailable a{color:#999}.breadcrumbs>*.unavailable:hover,.breadcrumbs>*.unavailable:hover a,.breadcrumbs>*.unavailable:focus,.breadcrumbs>*.unavailable a:focus{text-decoration:none;color:#999;cursor:default}.breadcrumbs>*:before{content:"/";color:#aaa;margin:0 0.75em;position:relative;top:1px}.breadcrumbs>*:first-child:before{content:" ";margin:0}form.custom .hidden-field{margin-left:-99999px;position:absolute;visibility:hidden}form.custom .custom{display:inline-block;width:16px;height:16px;position:relative;top:-1px;vertical-align:middle;border:solid 1px #ccc;background:#fff}form.custom .custom.checkbox{-webkit-border-radius:0;border-radius:0;padding:0}form.custom .custom.radio{-webkit-border-radius:1000px;border-radius:1000px;padding:3px}form.custom .custom.checkbox:before{content:"";display:block;font-size:16px;color:#fff}form.custom .custom.radio.checked:before{content:"";display:block;width:8px;height:8px;-webkit-border-radius:1000px;border-radius:1000px;background:#222;position:relative}form.custom .custom.checkbox.checked:before{content:"\00d7";color:#222;position:absolute;top:-50%;left:50%;margin-top:4px;margin-left:-5px}form.custom .custom.dropdown{display:block;position:relative;top:0;height:2.3125em;margin-bottom:1.25em;margin-top:0;padding:0;width:100%;background:#fff;background:-moz-linear-gradient(top, #fff 0%, #f3f3f3 100%);background:-webkit-linear-gradient(top, #fff 0%, #f3f3f3 100%);-webkit-box-shadow:none;background:linear-gradient(to bottom, #fff 0%, #f3f3f3 100%);box-shadow:none;font-size:0.875em;vertical-align:top}form.custom .custom.dropdown ul{overflow-y:auto;max-height:200px}form.custom .custom.dropdown .current{cursor:default;white-space:nowrap;line-height:2.25em;color:rgba(0,0,0,0.75);text-decoration:none;overflow:hidden;display:block;margin-left:0.5em;margin-right:2.3125em}form.custom .custom.dropdown .selector{cursor:default;position:absolute;width:2.5em;height:2.3125em;display:block;right:0;top:0}form.custom .custom.dropdown .selector:after{content:"";display:block;content:"";display:block;width:0;height:0;border:inset 5px;border-color:#aaa transparent transparent transparent;border-top-style:solid;position:absolute;left:0.9375em;top:50%;margin-top:-3px}form.custom .custom.dropdown:hover a.selector:after,form.custom .custom.dropdown.open a.selector:after{content:"";display:block;width:0;height:0;border:inset 5px;border-color:#222 transparent transparent transparent;border-top-style:solid}form.custom .custom.dropdown .disabled{color:#888}form.custom .custom.dropdown .disabled:hover{background:transparent;color:#888}form.custom .custom.dropdown .disabled:hover:after{display:none}form.custom .custom.dropdown.open ul{display:block;z-index:10;min-width:100%;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box}form.custom .custom.dropdown.small{max-width:134px}form.custom .custom.dropdown.medium{max-width:254px}form.custom .custom.dropdown.large{max-width:434px}form.custom .custom.dropdown.expand{width:100% !important}form.custom .custom.dropdown.open.small ul{min-width:134px;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}form.custom .custom.dropdown.open.medium ul{min-width:254px;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}form.custom .custom.dropdown.open.large ul{min-width:434px;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}form.custom .error .custom.dropdown{border-color:#c60f13;background-color:rgba(198,15,19,0.1);background:rgba(198,15,19,0.1);margin-bottom:0}form.custom .error .custom.dropdown:focus{background:#fafafa;border-color:#999}form.custom .error .custom.dropdown+small.error{margin-top:0}form.custom .custom.dropdown ul{position:absolute;width:auto;display:none;margin:0;left:-1px;top:auto;-webkit-box-shadow:0 2px 2px 0 rgba(0,0,0,0.1);box-shadow:0 2px 2px 0 rgba(0,0,0,0.1);margin:0;padding:0;background:#fff;border:solid 1px #ccc;font-size:16px}form.custom .custom.dropdown ul li{color:#555;font-size:0.875em;cursor:default;padding-top:0.25em;padding-bottom:0.25em;padding-left:0.375em;padding-right:2.375em;min-height:1.5em;line-height:1.5em;margin:0;white-space:nowrap;list-style:none}form.custom .custom.dropdown ul li.selected{background:#eee;color:#000}form.custom .custom.dropdown ul li:hover{background-color:#e4e4e4;color:#000}form.custom .custom.dropdown ul li.selected:hover{background:#eee;cursor:default;color:#000}form.custom .custom.dropdown ul.show{display:block}form.custom .custom.disabled{background:#ddd}.keystroke,kbd{background-color:#ededed;border-color:#dbdbdb;color:#222;border-style:solid;border-width:1px;margin:0;font-family:"Consolas","Menlo","Courier",monospace;font-size:0.875em;padding:0.125em 0.25em 0;-webkit-border-radius:3px;border-radius:3px}.label{font-weight:bold;text-align:center;text-decoration:none;line-height:1;white-space:nowrap;display:inline-block;position:relative;padding:0.1875em 0.625em 0.25em;font-size:0.875em;background-color:#2ba6cb;color:#fff}.label.radius{-webkit-border-radius:3px;border-radius:3px}.label.round{-webkit-border-radius:1000px;border-radius:1000px}.label.alert{background-color:#c60f13;color:#fff}.label.success{background-color:#5da423;color:#fff}.label.secondary{background-color:#e9e9e9;color:#333}.inline-list{margin:0 auto 1.0625em auto;margin-left:-1.375em;margin-right:0;padding:0;list-style:none;overflow:hidden}.inline-list>li{list-style:none;float:left;margin-left:1.375em;display:block}.inline-list>li>*{display:block}ul.pagination{display:block;height:1.5em;margin-left:-0.3125em}ul.pagination li{height:1.5em;color:#222;font-size:0.875em;margin-left:0.3125em}ul.pagination li a{display:block;padding:0.0625em 0.4375em 0.0625em;color:#999}ul.pagination li:hover a,ul.pagination li a:focus{background:#e6e6e6}ul.pagination li.unavailable a{cursor:default;color:#999}ul.pagination li.unavailable:hover a,ul.pagination li.unavailable a:focus{background:transparent}ul.pagination li.current a{background:#2ba6cb;color:#fff;font-weight:bold;cursor:default}ul.pagination li.current a:hover,ul.pagination li.current a:focus{background:#2ba6cb}ul.pagination li{float:left;display:block}.pagination-centered{text-align:center}.pagination-centered ul.pagination li{float:none;display:inline-block}.panel{border-style:solid;border-width:1px;border-color:#d9d9d9;margin-bottom:1.25em;padding:1.25em;background:#f2f2f2}.panel>:first-child{margin-top:0}.panel>:last-child{margin-bottom:0}.panel h1,.panel h2,.panel h3,.panel h4,.panel h5,.panel h6,.panel p{color:#333}.panel h1,.panel h2,.panel h3,.panel h4,.panel h5,.panel h6{line-height:1;margin-bottom:0.625em}.panel h1.subheader,.panel h2.subheader,.panel h3.subheader,.panel h4.subheader,.panel h5.subheader,.panel h6.subheader{line-height:1.4}.panel.callout{border-style:solid;border-width:1px;border-color:#2284a1;margin-bottom:1.25em;padding:1.25em;background:#2ba6cb;-webkit-box-shadow:0 1px 0 rgba(255,255,255,0.5) inset;box-shadow:0 1px 0 rgba(255,255,255,0.5) inset}.panel.callout>:first-child{margin-top:0}.panel.callout>:last-child{margin-bottom:0}.panel.callout h1,.panel.callout h2,.panel.callout h3,.panel.callout h4,.panel.callout h5,.panel.callout h6,.panel.callout p{color:#fff}.panel.callout h1,.panel.callout h2,.panel.callout h3,.panel.callout h4,.panel.callout h5,.panel.callout h6{line-height:1;margin-bottom:0.625em}.panel.callout h1.subheader,.panel.callout h2.subheader,.panel.callout h3.subheader,.panel.callout h4.subheader,.panel.callout h5.subheader,.panel.callout h6.subheader{line-height:1.4}.panel.callout a{color:#fff}.panel.radius{-webkit-border-radius:3px;border-radius:3px}.pricing-table{border:solid 1px #ddd;margin-left:0;margin-bottom:1.25em}.pricing-table *{list-style:none;line-height:1}.pricing-table .title{background-color:#ddd;padding:0.9375em 1.25em;text-align:center;color:#333;font-weight:bold;font-size:1em}.pricing-table .price{background-color:#eee;padding:0.9375em 1.25em;text-align:center;color:#333;font-weight:normal;font-size:1.25em}.pricing-table .description{background-color:#fff;padding:0.9375em;text-align:center;color:#777;font-size:0.75em;font-weight:normal;line-height:1.4;border-bottom:dotted 1px #ddd}.pricing-table .bullet-item{background-color:#fff;padding:0.9375em;text-align:center;color:#333;font-size:0.875em;font-weight:normal;border-bottom:dotted 1px #ddd}.pricing-table .cta-button{background-color:#f5f5f5;text-align:center;padding:1.25em 1.25em 0}.progress{background-color:transparent;height:1.5625em;border:1px solid #ccc;padding:0.125em;margin-bottom:0.625em}.progress .meter{background:#2ba6cb;height:100%;display:block}.progress.secondary .meter{background:#e9e9e9;height:100%;display:block}.progress.success .meter{background:#5da423;height:100%;display:block}.progress.alert .meter{background:#c60f13;height:100%;display:block}.progress.radius{-webkit-border-radius:3px;border-radius:3px}.progress.radius .meter{-webkit-border-radius:2px;border-radius:2px}.progress.round{-webkit-border-radius:1000px;border-radius:1000px}.progress.round .meter{-webkit-border-radius:999px;border-radius:999px}.side-nav{display:block;margin:0;padding:0.875em 0;list-style-type:none;list-style-position:inside}.side-nav li{margin:0 0 0.4375em 0;font-size:0.875em}.side-nav li a{display:block;color:#2ba6cb}.side-nav li.active>a:first-child{color:#4d4d4d;font-weight:bold}.side-nav li.divider{border-top:1px solid;height:0;padding:0;list-style:none;border-top-color:#e6e6e6}.sub-nav{display:block;width:auto;overflow:hidden;margin:-0.25em 0 1.125em;padding-top:0.25em;margin-right:0;margin-left:-0.5625em}.sub-nav dt,.sub-nav dd,.sub-nav li{float:left;display:inline;margin-left:0.5625em;margin-bottom:0.625em;font-weight:normal;font-size:0.875em}.sub-nav dt a,.sub-nav dd a,.sub-nav li a{color:#999;text-decoration:none}.sub-nav dt.active a,.sub-nav dd.active a,.sub-nav li.active a{-webkit-border-radius:1000px;border-radius:1000px;font-weight:bold;background:#2ba6cb;padding:0.1875em 0.5625em;cursor:default;color:#fff}@media only screen{div.switch{position:relative;padding:0;display:block;overflow:hidden;border-style:solid;border-width:1px;margin-bottom:1.25em;height:2.25em;background:#fff;border-color:#ccc}div.switch label{position:relative;left:0;z-index:2;float:left;width:50%;height:100%;margin:0;font-weight:bold;text-align:left;-webkit-transition:all 0.1s ease-out;-moz-transition:all 0.1s ease-out;transition:all 0.1s ease-out}div.switch input{position:absolute;z-index:3;opacity:0;width:100%;height:100%;-moz-appearance:none}div.switch input:hover,div.switch input:focus{cursor:pointer}div.switch span:last-child{position:absolute;top:-1px;left:-1px;z-index:1;display:block;padding:0;border-width:1px;border-style:solid;-webkit-transition:all 0.1s ease-out;-moz-transition:all 0.1s ease-out;transition:all 0.1s ease-out}div.switch input:not(:checked)+label{opacity:0}div.switch input:checked{display:none !important}div.switch input{left:0;display:block !important}div.switch input:first-of-type+label,div.switch input:first-of-type+span+label{left:-50%}div.switch input:first-of-type:checked+label,div.switch input:first-of-type:checked+span+label{left:0%}div.switch input:last-of-type+label,div.switch input:last-of-type+span+label{right:-50%;left:auto;text-align:right}div.switch input:last-of-type:checked+label,div.switch input:last-of-type:checked+span+label{right:0%;left:auto}div.switch span.custom{display:none !important}form.custom div.switch .hidden-field{margin-left:auto;position:absolute;visibility:visible}div.switch label{padding:0;line-height:2.3em;font-size:0.875em}div.switch input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-2.1875em}div.switch span:last-child{width:2.25em;height:2.25em}div.switch span:last-child{border-color:#b3b3b3;background:#fff;background:-moz-linear-gradient(top, #fff 0%, #f2f2f2 100%);background:-webkit-linear-gradient(top, #fff 0%, #f2f2f2 100%);background:linear-gradient(to bottom, #fff 0%, #f2f2f2 100%);-webkit-box-shadow:2px 0 10px 0 rgba(0,0,0,0.07),1000px 0 0 1000px #e1f5d1,-2px 0 10px 0 rgba(0,0,0,0.07),-1000px 0 0 1000px #f5f5f5;box-shadow:2px 0 10px 0 rgba(0,0,0,0.07),1000px 0 0 980px #e1f5d1,-2px 0 10px 0 rgba(0,0,0,0.07),-1000px 0 0 1000px #f5f5f5}div.switch:hover span:last-child,div.switch:focus span:last-child{background:#fff;background:-moz-linear-gradient(top, #fff 0%, #e6e6e6 100%);background:-webkit-linear-gradient(top, #fff 0%, #e6e6e6 100%);background:linear-gradient(to bottom, #fff 0%, #e6e6e6 100%)}div.switch:active{background:transparent}div.switch.large{height:2.75em}div.switch.large label{padding:0;line-height:2.3em;font-size:1.0625em}div.switch.large input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-2.6875em}div.switch.large span:last-child{width:2.75em;height:2.75em}div.switch.small{height:1.75em}div.switch.small label{padding:0;line-height:2.1em;font-size:0.75em}div.switch.small input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-1.6875em}div.switch.small span:last-child{width:1.75em;height:1.75em}div.switch.tiny{height:1.375em}div.switch.tiny label{padding:0;line-height:1.9em;font-size:0.6875em}div.switch.tiny input:first-of-type:checked ~ span:last-child{left:100%;margin-left:-1.3125em}div.switch.tiny span:last-child{width:1.375em;height:1.375em}div.switch.radius{-webkit-border-radius:4px;border-radius:4px}div.switch.radius span:last-child{-webkit-border-radius:3px;border-radius:3px}div.switch.round{-webkit-border-radius:1000px;border-radius:1000px}div.switch.round span:last-child{-webkit-border-radius:999px;border-radius:999px}div.switch.round label{padding:0 0.5625em}@-webkit-keyframes webkitSiblingBugfix{from{position:relative}to{position:relative}}}@media only screen and (-webkit-min-device-pixel-ratio: 0) and (max-device-width: 480px){div.switch{-webkit-animation:webkitSiblingBugfix infinite 1s}}@media only screen and (-webkit-min-device-pixel-ratio: 1.5){div.switch{-webkit-animation:none 0}}[data-magellan-expedition]{background:#fff;z-index:50;min-width:100%;padding:10px}[data-magellan-expedition] .sub-nav{margin-bottom:0}[data-magellan-expedition] .sub-nav dd{margin-bottom:0}table{background:#fff;margin-bottom:1.25em;border:solid 1px #ddd}table thead,table tfoot{background:#f5f5f5;font-weight:bold}table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:0.5em 0.625em 0.625em;font-size:0.875em;color:#222;text-align:left}table tr th,table tr td{padding:0.5625em 0.625em;font-size:0.875em;color:#222}table tr.even,table tr.alt,table tr:nth-of-type(even){background:#f9f9f9}table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{display:table-cell;line-height:1.125em}.th{line-height:0;display:inline-block;border:solid 4px #fff;-webkit-box-shadow:0 0 0 1px rgba(0,0,0,0.2);box-shadow:0 0 0 1px rgba(0,0,0,0.2);-webkit-transition:all 200ms ease-out;-moz-transition:all 200ms ease-out;transition:all 200ms ease-out}.th:hover,.th:focus{-webkit-box-shadow:0 0 6px 1px rgba(43,166,203,0.5);box-shadow:0 0 6px 1px rgba(43,166,203,0.5)}.th.radius{-webkit-border-radius:3px;border-radius:3px}a.th{display:inline-block;max-width:100%}.has-tip{border-bottom:dotted 1px #ccc;cursor:help;font-weight:bold;color:#333}.has-tip:hover,.has-tip:focus{border-bottom:dotted 1px #196177;color:#2ba6cb}.has-tip.tip-left,.has-tip.tip-right{float:none !important}.tooltip{display:none;position:absolute;z-index:999;font-weight:bold;font-size:0.9375em;line-height:1.3;padding:0.5em;max-width:85%;left:50%;width:100%;color:#fff;background:#000;-webkit-border-radius:3px;border-radius:3px}.tooltip>.nub{display:block;left:5px;position:absolute;width:0;height:0;border:solid 5px;border-color:transparent transparent #000 transparent;top:-10px}.tooltip.opened{color:#2ba6cb !important;border-bottom:dotted 1px #196177 !important}.tap-to-close{display:block;font-size:0.625em;color:#888;font-weight:normal}@media only screen and (min-width: 768px){.tooltip>.nub{border-color:transparent transparent #000 transparent;top:-10px}.tooltip.tip-top>.nub{border-color:#000 transparent transparent transparent;top:auto;bottom:-10px}.tooltip.tip-left,.tooltip.tip-right{float:none !important}.tooltip.tip-left>.nub{border-color:transparent transparent transparent #000;right:-10px;left:auto;top:50%;margin-top:-5px}.tooltip.tip-right>.nub{border-color:transparent #000 transparent transparent;right:auto;left:-10px;top:50%;margin-top:-5px}}@media only screen and (max-width: 767px){.f-dropdown{max-width:100%;left:0}}.f-dropdown{position:absolute;top:-9999px;list-style:none;margin-left:0;width:100%;max-height:none;height:auto;background:#fff;border:solid 1px #ccc;font-size:16px;z-index:99;margin-top:2px;max-width:200px}.f-dropdown>*:first-child{margin-top:0}.f-dropdown>*:last-child{margin-bottom:0}.f-dropdown:before{content:"";display:block;width:0;height:0;border:inset 6px;border-color:transparent transparent #fff transparent;border-bottom-style:solid;position:absolute;top:-12px;left:10px;z-index:99}.f-dropdown:after{content:"";display:block;width:0;height:0;border:inset 7px;border-color:transparent transparent #ccc transparent;border-bottom-style:solid;position:absolute;top:-14px;left:9px;z-index:98}.f-dropdown.right:before{left:auto;right:10px}.f-dropdown.right:after{left:auto;right:9px}.f-dropdown li{font-size:0.875em;cursor:pointer;line-height:1.125em;margin:0}.f-dropdown li:hover,.f-dropdown li:focus{background:#eee}.f-dropdown li a{display:block;padding:0.5em;color:#555}.f-dropdown.content{position:absolute;top:-9999px;list-style:none;margin-left:0;padding:1.25em;width:100%;height:auto;max-height:none;background:#fff;border:solid 1px #ccc;font-size:16px;z-index:99;max-width:200px}.f-dropdown.content>*:first-child{margin-top:0}.f-dropdown.content>*:last-child{margin-bottom:0}.f-dropdown.tiny{max-width:200px}.f-dropdown.small{max-width:300px}.f-dropdown.medium{max-width:500px}.f-dropdown.large{max-width:800px} |
generators/foundation/public/stylesheets/normalize.css
+162
-91
| @@ | @@ -1,10 +1,13 @@ |
| - | /* normalize.css v2.1.1 | MIT License | git.io/normalize */ |
| + | /*! normalize.css v2.1.2 | MIT License | git.io/normalize */ |
| + | |
| /* ========================================================================== | |
| HTML5 display definitions | |
| ========================================================================== */ | |
| + | |
| /** | |
| * Correct `block` display not defined in IE 8/9. | |
| */ | |
| + | |
| article, | |
| aside, | |
| details, | |
| @@ | @@ -17,233 +20,290 @@ main, |
| nav, | |
| section, | |
| summary { | |
| - | display: block; } |
| + | display: block; |
| + | } |
| /** | |
| * Correct `inline-block` display not defined in IE 8/9. | |
| */ | |
| + | |
| audio, | |
| canvas, | |
| video { | |
| - | display: inline-block; } |
| + | display: inline-block; |
| + | } |
| /** | |
| * Prevent modern browsers from displaying `audio` without controls. | |
| * Remove excess height in iOS 5 devices. | |
| */ | |
| + | |
| audio:not([controls]) { | |
| - | display: none; |
| - | height: 0; } |
| + | display: none; |
| + | height: 0; |
| + | } |
| /** | |
| - | * Address styling not present in IE 8/9. |
| + | * Address `[hidden]` styling not present in IE 8/9. |
| + | * Hide the `template` element in IE, Safari, and Firefox < 22. |
| */ | |
| - | [hidden] { |
| - | display: none; } |
| + | |
| + | [hidden], |
| + | template { |
| + | display: none; |
| + | } |
| + | |
| + | script { |
| + | display: none !important; |
| + | } |
| /* ========================================================================== | |
| Base | |
| ========================================================================== */ | |
| + | |
| /** | |
| - | * 1. Prevent system color scheme's background color being used in Firefox, IE, |
| - | * and Opera. |
| - | * 2. Prevent system color scheme's text color being used in Firefox, IE, and |
| - | * Opera. |
| - | * 3. Set default font family to sans-serif. |
| - | * 4. Prevent iOS text size adjust after orientation change, without disabling |
| + | * 1. Set default font family to sans-serif. |
| + | * 2. Prevent iOS text size adjust after orientation change, without disabling |
| * user zoom. | |
| */ | |
| + | |
| html { | |
| - | background: #fff; |
| - | /* 1 */ |
| - | color: #000; |
| - | /* 2 */ |
| - | font-family: sans-serif; |
| - | /* 3 */ |
| - | -ms-text-size-adjust: 100%; |
| - | /* 4 */ |
| - | -webkit-text-size-adjust: 100%; |
| - | /* 4 */ } |
| + | font-family: sans-serif; /* 1 */ |
| + | -ms-text-size-adjust: 100%; /* 2 */ |
| + | -webkit-text-size-adjust: 100%; /* 2 */ |
| + | } |
| /** | |
| * Remove default margin. | |
| */ | |
| + | |
| body { | |
| - | margin: 0; } |
| + | margin: 0; |
| + | } |
| /* ========================================================================== | |
| Links | |
| ========================================================================== */ | |
| + | |
| + | /** |
| + | * Remove the gray background color from active links in IE 10. |
| + | */ |
| + | |
| + | a { |
| + | background: transparent; |
| + | } |
| + | |
| /** | |
| * Address `outline` inconsistency between Chrome and other browsers. | |
| */ | |
| + | |
| a:focus { | |
| - | outline: thin dotted; } |
| + | outline: thin dotted; |
| + | } |
| /** | |
| * Improve readability when focused and also mouse hovered in all browsers. | |
| */ | |
| + | |
| a:active, | |
| a:hover { | |
| - | outline: 0; } |
| + | outline: 0; |
| + | } |
| /* ========================================================================== | |
| Typography | |
| ========================================================================== */ | |
| + | |
| /** | |
| * Address variable `h1` font-size and margin within `section` and `article` | |
| * contexts in Firefox 4+, Safari 5, and Chrome. | |
| */ | |
| + | |
| h1 { | |
| - | font-size: 2em; |
| - | margin: 0.67em 0; } |
| + | font-size: 2em; |
| + | margin: 0.67em 0; |
| + | } |
| /** | |
| * Address styling not present in IE 8/9, Safari 5, and Chrome. | |
| */ | |
| + | |
| abbr[title] { | |
| - | border-bottom: 1px dotted; } |
| + | border-bottom: 1px dotted; |
| + | } |
| /** | |
| * Address style set to `bolder` in Firefox 4+, Safari 5, and Chrome. | |
| */ | |
| + | |
| b, | |
| strong { | |
| - | font-weight: bold; } |
| + | font-weight: bold; |
| + | } |
| /** | |
| * Address styling not present in Safari 5 and Chrome. | |
| */ | |
| + | |
| dfn { | |
| - | font-style: italic; } |
| + | font-style: italic; |
| + | } |
| /** | |
| * Address differences between Firefox and other browsers. | |
| */ | |
| + | |
| hr { | |
| - | -moz-box-sizing: content-box; |
| - | box-sizing: content-box; |
| - | height: 0; } |
| + | -moz-box-sizing: content-box; |
| + | box-sizing: content-box; |
| + | height: 0; |
| + | } |
| /** | |
| * Address styling not present in IE 8/9. | |
| */ | |
| + | |
| mark { | |
| - | background: #ff0; |
| - | color: #000; } |
| + | background: #ff0; |
| + | color: #000; |
| + | } |
| /** | |
| * Correct font family set oddly in Safari 5 and Chrome. | |
| */ | |
| + | |
| code, | |
| kbd, | |
| pre, | |
| samp { | |
| - | font-family: monospace, serif; |
| - | font-size: 1em; } |
| + | font-family: monospace, serif; |
| + | font-size: 1em; |
| + | } |
| /** | |
| * Improve readability of pre-formatted text in all browsers. | |
| */ | |
| + | |
| pre { | |
| - | white-space: pre-wrap; } |
| + | white-space: pre-wrap; |
| + | } |
| /** | |
| * Set consistent quote types. | |
| */ | |
| + | |
| q { | |
| - | quotes: "\201C" "\201D" "\2018" "\2019"; } |
| + | quotes: "\201C" "\201D" "\2018" "\2019"; |
| + | } |
| /** | |
| * Address inconsistent and variable font size in all browsers. | |
| */ | |
| + | |
| small { | |
| - | font-size: 80%; } |
| + | font-size: 80%; |
| + | } |
| /** | |
| * Prevent `sub` and `sup` affecting `line-height` in all browsers. | |
| */ | |
| + | |
| sub, | |
| sup { | |
| - | font-size: 75%; |
| - | line-height: 0; |
| - | position: relative; |
| - | vertical-align: baseline; } |
| + | font-size: 75%; |
| + | line-height: 0; |
| + | position: relative; |
| + | vertical-align: baseline; |
| + | } |
| sup { | |
| - | top: -0.5em; } |
| + | top: -0.5em; |
| + | } |
| sub { | |
| - | bottom: -0.25em; } |
| + | bottom: -0.25em; |
| + | } |
| /* ========================================================================== | |
| Embedded content | |
| ========================================================================== */ | |
| + | |
| /** | |
| * Remove border when inside `a` element in IE 8/9. | |
| */ | |
| + | |
| img { | |
| - | border: 0; } |
| + | border: 0; |
| + | } |
| /** | |
| * Correct overflow displayed oddly in IE 9. | |
| */ | |
| + | |
| svg:not(:root) { | |
| - | overflow: hidden; } |
| + | overflow: hidden; |
| + | } |
| /* ========================================================================== | |
| Figures | |
| ========================================================================== */ | |
| + | |
| /** | |
| * Address margin not present in IE 8/9 and Safari 5. | |
| */ | |
| + | |
| figure { | |
| - | margin: 0; } |
| + | margin: 0; |
| + | } |
| /* ========================================================================== | |
| Forms | |
| ========================================================================== */ | |
| + | |
| /** | |
| * Define consistent border, margin, and padding. | |
| */ | |
| + | |
| fieldset { | |
| - | border: 1px solid #c0c0c0; |
| - | margin: 0 2px; |
| - | padding: 0.35em 0.625em 0.75em; } |
| + | border: 1px solid #c0c0c0; |
| + | margin: 0 2px; |
| + | padding: 0.35em 0.625em 0.75em; |
| + | } |
| /** | |
| * 1. Correct `color` not being inherited in IE 8/9. | |
| * 2. Remove padding so people aren't caught out if they zero out fieldsets. | |
| */ | |
| + | |
| legend { | |
| - | border: 0; |
| - | /* 1 */ |
| - | padding: 0; |
| - | /* 2 */ } |
| + | border: 0; /* 1 */ |
| + | padding: 0; /* 2 */ |
| + | } |
| /** | |
| * 1. Correct font family not being inherited in all browsers. | |
| * 2. Correct font size not being inherited in all browsers. | |
| * 3. Address margins set differently in Firefox 4+, Safari 5, and Chrome. | |
| */ | |
| + | |
| button, | |
| input, | |
| select, | |
| textarea { | |
| - | font-family: inherit; |
| - | /* 1 */ |
| - | font-size: 100%; |
| - | /* 2 */ |
| - | margin: 0; |
| - | /* 3 */ } |
| + | font-family: inherit; /* 1 */ |
| + | font-size: 100%; /* 2 */ |
| + | margin: 0; /* 3 */ |
| + | } |
| /** | |
| * Address Firefox 4+ setting `line-height` on `input` using `!important` in | |
| * the UA stylesheet. | |
| */ | |
| + | |
| button, | |
| input { | |
| - | line-height: normal; } |
| + | line-height: normal; |
| + | } |
| /** | |
| * Address inconsistent `text-transform` inheritance for `button` and `select`. | |
| @@ | @@ -251,9 +311,11 @@ input { |
| * Correct `button` style inheritance in Chrome, Safari 5+, and IE 8+. | |
| * Correct `select` style inheritance in Firefox 4+ and Opera. | |
| */ | |
| + | |
| button, | |
| select { | |
| - | text-transform: none; } |
| + | text-transform: none; |
| + | } |
| /** | |
| * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` | |
| @@ | @@ -262,78 +324,87 @@ select { |
| * 3. Improve usability and consistency of cursor style between image-type | |
| * `input` and others. | |
| */ | |
| + | |
| button, | |
| - | html input[type="button"], |
| + | html input[type="button"], /* 1 */ |
| input[type="reset"], | |
| input[type="submit"] { | |
| - | -webkit-appearance: button; |
| - | /* 2 */ |
| - | cursor: pointer; |
| - | /* 3 */ } |
| + | -webkit-appearance: button; /* 2 */ |
| + | cursor: pointer; /* 3 */ |
| + | } |
| /** | |
| * Re-set default cursor for disabled elements. | |
| */ | |
| + | |
| button[disabled], | |
| html input[disabled] { | |
| - | cursor: default; } |
| + | cursor: default; |
| + | } |
| /** | |
| * 1. Address box sizing set to `content-box` in IE 8/9. | |
| * 2. Remove excess padding in IE 8/9. | |
| */ | |
| + | |
| input[type="checkbox"], | |
| input[type="radio"] { | |
| - | box-sizing: border-box; |
| - | /* 1 */ |
| - | padding: 0; |
| - | /* 2 */ } |
| + | box-sizing: border-box; /* 1 */ |
| + | padding: 0; /* 2 */ |
| + | } |
| /** | |
| * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome. | |
| * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome | |
| * (include `-moz` to future-proof). | |
| */ | |
| + | |
| input[type="search"] { | |
| - | -webkit-appearance: textfield; |
| - | /* 1 */ |
| - | -moz-box-sizing: content-box; |
| - | -webkit-box-sizing: content-box; |
| - | /* 2 */ |
| - | box-sizing: content-box; } |
| + | -webkit-appearance: textfield; /* 1 */ |
| + | -moz-box-sizing: content-box; |
| + | -webkit-box-sizing: content-box; /* 2 */ |
| + | box-sizing: content-box; |
| + | } |
| /** | |
| * Remove inner padding and search cancel button in Safari 5 and Chrome | |
| * on OS X. | |
| */ | |
| + | |
| input[type="search"]::-webkit-search-cancel-button, | |
| input[type="search"]::-webkit-search-decoration { | |
| - | -webkit-appearance: none; } |
| + | -webkit-appearance: none; |
| + | } |
| /** | |
| * Remove inner padding and border in Firefox 4+. | |
| */ | |
| + | |
| button::-moz-focus-inner, | |
| input::-moz-focus-inner { | |
| - | border: 0; |
| - | padding: 0; } |
| + | border: 0; |
| + | padding: 0; |
| + | } |
| /** | |
| * 1. Remove default vertical scrollbar in IE 8/9. | |
| * 2. Improve readability and alignment in all browsers. | |
| */ | |
| + | |
| textarea { | |
| - | overflow: auto; |
| - | /* 1 */ |
| - | vertical-align: top; |
| - | /* 2 */ } |
| + | overflow: auto; /* 1 */ |
| + | vertical-align: top; /* 2 */ |
| + | } |
| /* ========================================================================== | |
| Tables | |
| ========================================================================== */ | |
| + | |
| /** | |
| * Remove most spacing between table cells. | |
| */ | |
| + | |
| table { | |
| - | border-collapse: collapse; |
| - | border-spacing: 0; } |
| + | border-collapse: collapse; |
| + | border-spacing: 0; |
| + | } |
locomotive/wagon/generators/site/foundation.rb b/lib/locomotive/wagon/generators/site/foundation.rb
+1
-1
| @@ | @@ -27,7 +27,7 @@ module Locomotive |
| end | |
| Locomotive::Wagon::Generators::Site.register(:foundation, Foundation, %{ | |
| - | A LocomotiveCMS site powered by Foundation (v4.2.1). |
| + | A LocomotiveCMS site powered by Foundation (v4.3.2). |
| }) | |
| end | |
| end | |