|
|
Line 3: |
Line 3: |
| | | |
| <html> | | <html> |
− |
| |
− | <meta charset="utf-8">
| |
− |
| |
− | <!-- CSS -->
| |
− |
| |
− | <style type="text/css">
| |
− | /*!
| |
− | * Bootstrap v4.0.0 (https://getbootstrap.com)
| |
− | * Copyright 2011-2018 The Bootstrap Authors
| |
− | * Copyright 2011-2018 Twitter, Inc.
| |
− | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
| |
− | */:root{--blue:#007bff;--indigo:#6610f2;--purple:#6f42c1;--pink:#e83e8c;--red:#dc3545;--orange:#fd7e14;--yellow:#ffc107;--green:#28a745;--teal:#20c997;--cyan:#17a2b8;--white:#fff;--gray:#6c757d;--gray-dark:#343a40;--primary:#007bff;--secondary:#6c757d;--success:#28a745;--info:#17a2b8;--warning:#ffc107;--danger:#dc3545;--light:#f8f9fa;--dark:#343a40;--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--font-family-sans-serif:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";--font-family-monospace:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}*,::after,::before{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:transparent}@-ms-viewport{width:device-width}article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";font-size:1rem;font-weight:400;line-height:1.5;color:#212529;text-align:left;background-color:#fff}[tabindex="-1"]:focus{outline:0!important}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem}p{margin-top:0;margin-bottom:1rem}abbr[data-original-title],abbr[title]{text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;border-bottom:0}address{margin-bottom:1rem;font-style:normal;line-height:inherit}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#007bff;text-decoration:none;background-color:transparent;-webkit-text-decoration-skip:objects}a:hover{color:#0056b3;text-decoration:underline}a:not([href]):not([tabindex]){color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus,a:not([href]):not([tabindex]):hover{color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus{outline:0}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}pre{margin-top:0;margin-bottom:1rem;overflow:auto;-ms-overflow-style:scrollbar}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg:not(:root){overflow:hidden}table{border-collapse:collapse}caption{padding-top:.75rem;padding-bottom:.75rem;color:#6c757d;text-align:left;caption-side:bottom}th{text-align:inherit}label{display:inline-block;margin-bottom:.5rem}button{border-radius:0}button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=date],input[type=datetime-local],input[type=month],input[type=time]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none!important}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{margin-bottom:.5rem;font-family:inherit;font-weight:500;line-height:1.2;color:inherit}.h1,h1{font-size:2.5rem}.h2,h2{font-size:2rem}.h3,h3{font-size:1.75rem}.h4,h4{font-size:1.5rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:6rem;font-weight:300;line-height:1.2}.display-2{font-size:5.5rem;font-weight:300;line-height:1.2}.display-3{font-size:4.5rem;font-weight:300;line-height:1.2}.display-4{font-size:3.5rem;font-weight:300;line-height:1.2}hr{margin-top:1rem;margin-bottom:1rem;border:0;border-top:1px solid rgba(0,0,0,.1)}.small,small{font-size:80%;font-weight:400}.mark,mark{padding:.2em;background-color:#fcf8e3}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:.5rem}.initialism{font-size:90%;text-transform:uppercase}.blockquote{margin-bottom:1rem;font-size:1.25rem}.blockquote-footer{display:block;font-size:80%;color:#6c757d}.blockquote-footer::before{content:"\2014 \00A0"}.img-fluid{max-width:100%;height:auto}.img-thumbnail{padding:.25rem;background-color:#fff;border:1px solid #dee2e6;border-radius:.25rem;max-width:100%;height:auto}.figure{display:inline-block}.figure-img{margin-bottom:.5rem;line-height:1}.figure-caption{font-size:90%;color:#6c757d}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}code{font-size:87.5%;color:#e83e8c;word-break:break-word}a>code{color:inherit}kbd{padding:.2rem .4rem;font-size:87.5%;color:#fff;background-color:#212529;border-radius:.2rem}kbd kbd{padding:0;font-size:100%;font-weight:700}pre{display:block;font-size:87.5%;color:#212529}pre code{font-size:inherit;color:inherit;word-break:normal}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:576px){.container{max-width:540px}}@media (min-width:768px){.container{max-width:720px}}@media (min-width:992px){.container{max-width:960px}}@media (min-width:1200px){.container{max-width:1140px}}.container-fluid{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-15px;margin-left:-15px}.no-gutters{margin-right:0;margin-left:0}.no-gutters>.col,.no-gutters>[class*=col-]{padding-right:0;padding-left:0}.col,.col-1,.col-10,.col-11,.col-12,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-auto,.col-lg,.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-auto,.col-md,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-auto,.col-sm,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-auto,.col-xl,.col-xl-1,.col-xl-10,.col-xl-11,.col-xl-12,.col-xl-2,.col-xl-3,.col-xl-4,.col-xl-5,.col-xl-6,.col-xl-7,.col-xl-8,.col-xl-9,.col-xl-auto{position:relative;width:100%;min-height:1px;padding-right:15px;padding-left:15px}.col{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-1{margin-left:8.333333%}.offset-2{margin-left:16.666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.333333%}.offset-5{margin-left:41.666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.333333%}.offset-8{margin-left:66.666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.333333%}.offset-11{margin-left:91.666667%}@media (min-width:576px){.col-sm{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-sm-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-sm-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-sm-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-sm-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-sm-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-sm-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-sm-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-sm-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-sm-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-sm-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-sm-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-sm-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-sm-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-sm-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-sm-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-sm-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-sm-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-sm-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-sm-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-sm-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-sm-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-sm-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-sm-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-sm-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-sm-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-sm-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-sm-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-sm-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.333333%}.offset-sm-2{margin-left:16.666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.333333%}.offset-sm-5{margin-left:41.666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.333333%}.offset-sm-8{margin-left:66.666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.333333%}.offset-sm-11{margin-left:91.666667%}}@media (min-width:768px){.col-md{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-md-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-md-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-md-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-md-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-md-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-md-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-md-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-md-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-md-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-md-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-md-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-md-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-md-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-md-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-md-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-md-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-md-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-md-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-md-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-md-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-md-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-md-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-md-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-md-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-md-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-md-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-md-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-md-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.333333%}.offset-md-2{margin-left:16.666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.333333%}.offset-md-5{margin-left:41.666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.333333%}.offset-md-8{margin-left:66.666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.333333%}.offset-md-11{margin-left:91.666667%}}@media (min-width:992px){.col-lg{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-lg-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-lg-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-lg-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-lg-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-lg-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-lg-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-lg-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-lg-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-lg-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-lg-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-lg-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-lg-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-lg-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-lg-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-lg-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-lg-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-lg-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-lg-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-lg-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-lg-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-lg-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-lg-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-lg-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-lg-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-lg-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-lg-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-lg-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-lg-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.333333%}.offset-lg-2{margin-left:16.666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.333333%}.offset-lg-5{margin-left:41.666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.333333%}.offset-lg-8{margin-left:66.666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.333333%}.offset-lg-11{margin-left:91.666667%}}@media (min-width:1200px){.col-xl{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-xl-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-xl-1{-webkit-box-flex:0;-ms-flex:0 0 8.333333%;flex:0 0 8.333333%;max-width:8.333333%}.col-xl-2{-webkit-box-flex:0;-ms-flex:0 0 16.666667%;flex:0 0 16.666667%;max-width:16.666667%}.col-xl-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-xl-4{-webkit-box-flex:0;-ms-flex:0 0 33.333333%;flex:0 0 33.333333%;max-width:33.333333%}.col-xl-5{-webkit-box-flex:0;-ms-flex:0 0 41.666667%;flex:0 0 41.666667%;max-width:41.666667%}.col-xl-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-xl-7{-webkit-box-flex:0;-ms-flex:0 0 58.333333%;flex:0 0 58.333333%;max-width:58.333333%}.col-xl-8{-webkit-box-flex:0;-ms-flex:0 0 66.666667%;flex:0 0 66.666667%;max-width:66.666667%}.col-xl-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-xl-10{-webkit-box-flex:0;-ms-flex:0 0 83.333333%;flex:0 0 83.333333%;max-width:83.333333%}.col-xl-11{-webkit-box-flex:0;-ms-flex:0 0 91.666667%;flex:0 0 91.666667%;max-width:91.666667%}.col-xl-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-xl-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-xl-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-xl-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-xl-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-xl-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-xl-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-xl-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-xl-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-xl-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-xl-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-xl-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-xl-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-xl-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-xl-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-xl-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.333333%}.offset-xl-2{margin-left:16.666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.333333%}.offset-xl-5{margin-left:41.666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.333333%}.offset-xl-8{margin-left:66.666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.333333%}.offset-xl-11{margin-left:91.666667%}}.table{width:100%;max-width:100%;margin-bottom:1rem;background-color:transparent}.table td,.table th{padding:.75rem;vertical-align:top;border-top:1px solid #dee2e6}.table thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6}.table tbody+tbody{border-top:2px solid #dee2e6}.table .table{background-color:#fff}.table-sm td,.table-sm th{padding:.3rem}.table-bordered{border:1px solid #dee2e6}.table-bordered td,.table-bordered th{border:1px solid #dee2e6}.table-bordered thead td,.table-bordered thead th{border-bottom-width:2px}.table-striped tbody tr:nth-of-type(odd){background-color:rgba(0,0,0,.05)}.table-hover tbody tr:hover{background-color:rgba(0,0,0,.075)}.table-primary,.table-primary>td,.table-primary>th{background-color:#b8daff}.table-hover .table-primary:hover{background-color:#9fcdff}.table-hover .table-primary:hover>td,.table-hover .table-primary:hover>th{background-color:#9fcdff}.table-secondary,.table-secondary>td,.table-secondary>th{background-color:#d6d8db}.table-hover .table-secondary:hover{background-color:#c8cbcf}.table-hover .table-secondary:hover>td,.table-hover .table-secondary:hover>th{background-color:#c8cbcf}.table-success,.table-success>td,.table-success>th{background-color:#c3e6cb}.table-hover .table-success:hover{background-color:#b1dfbb}.table-hover .table-success:hover>td,.table-hover .table-success:hover>th{background-color:#b1dfbb}.table-info,.table-info>td,.table-info>th{background-color:#bee5eb}.table-hover .table-info:hover{background-color:#abdde5}.table-hover .table-info:hover>td,.table-hover .table-info:hover>th{background-color:#abdde5}.table-warning,.table-warning>td,.table-warning>th{background-color:#ffeeba}.table-hover .table-warning:hover{background-color:#ffe8a1}.table-hover .table-warning:hover>td,.table-hover .table-warning:hover>th{background-color:#ffe8a1}.table-danger,.table-danger>td,.table-danger>th{background-color:#f5c6cb}.table-hover .table-danger:hover{background-color:#f1b0b7}.table-hover .table-danger:hover>td,.table-hover .table-danger:hover>th{background-color:#f1b0b7}.table-light,.table-light>td,.table-light>th{background-color:#fdfdfe}.table-hover .table-light:hover{background-color:#ececf6}.table-hover .table-light:hover>td,.table-hover .table-light:hover>th{background-color:#ececf6}.table-dark,.table-dark>td,.table-dark>th{background-color:#c6c8ca}.table-hover .table-dark:hover{background-color:#b9bbbe}.table-hover .table-dark:hover>td,.table-hover .table-dark:hover>th{background-color:#b9bbbe}.table-active,.table-active>td,.table-active>th{background-color:rgba(0,0,0,.075)}.table-hover .table-active:hover{background-color:rgba(0,0,0,.075)}.table-hover .table-active:hover>td,.table-hover .table-active:hover>th{background-color:rgba(0,0,0,.075)}.table .thead-dark th{color:#fff;background-color:#212529;border-color:#32383e}.table .thead-light th{color:#495057;background-color:#e9ecef;border-color:#dee2e6}.table-dark{color:#fff;background-color:#212529}.table-dark td,.table-dark th,.table-dark thead th{border-color:#32383e}.table-dark.table-bordered{border:0}.table-dark.table-striped tbody tr:nth-of-type(odd){background-color:rgba(255,255,255,.05)}.table-dark.table-hover tbody tr:hover{background-color:rgba(255,255,255,.075)}@media (max-width:575.98px){.table-responsive-sm{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-sm>.table-bordered{border:0}}@media (max-width:767.98px){.table-responsive-md{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-md>.table-bordered{border:0}}@media (max-width:991.98px){.table-responsive-lg{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-lg>.table-bordered{border:0}}@media (max-width:1199.98px){.table-responsive-xl{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-xl>.table-bordered{border:0}}.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive>.table-bordered{border:0}.form-control{display:block;width:100%;padding:.375rem .75rem;font-size:1rem;line-height:1.5;color:#495057;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.25rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-control::-ms-expand{background-color:transparent;border:0}.form-control:focus{color:#495057;background-color:#fff;border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.form-control::-webkit-input-placeholder{color:#6c757d;opacity:1}.form-control::-moz-placeholder{color:#6c757d;opacity:1}.form-control:-ms-input-placeholder{color:#6c757d;opacity:1}.form-control::-ms-input-placeholder{color:#6c757d;opacity:1}.form-control::placeholder{color:#6c757d;opacity:1}.form-control:disabled,.form-control[readonly]{background-color:#e9ecef;opacity:1}select.form-control:not([size]):not([multiple]){height:calc(2.25rem + 2px)}select.form-control:focus::-ms-value{color:#495057;background-color:#fff}.form-control-file,.form-control-range{display:block;width:100%}.col-form-label{padding-top:calc(.375rem + 1px);padding-bottom:calc(.375rem + 1px);margin-bottom:0;font-size:inherit;line-height:1.5}.col-form-label-lg{padding-top:calc(.5rem + 1px);padding-bottom:calc(.5rem + 1px);font-size:1.25rem;line-height:1.5}.col-form-label-sm{padding-top:calc(.25rem + 1px);padding-bottom:calc(.25rem + 1px);font-size:.875rem;line-height:1.5}.form-control-plaintext{display:block;width:100%;padding-top:.375rem;padding-bottom:.375rem;margin-bottom:0;line-height:1.5;background-color:transparent;border:solid transparent;border-width:1px 0}.form-control-plaintext.form-control-lg,.form-control-plaintext.form-control-sm,.input-group-lg>.form-control-plaintext.form-control,.input-group-lg>.input-group-append>.form-control-plaintext.btn,.input-group-lg>.input-group-append>.form-control-plaintext.input-group-text,.input-group-lg>.input-group-prepend>.form-control-plaintext.btn,.input-group-lg>.input-group-prepend>.form-control-plaintext.input-group-text,.input-group-sm>.form-control-plaintext.form-control,.input-group-sm>.input-group-append>.form-control-plaintext.btn,.input-group-sm>.input-group-append>.form-control-plaintext.input-group-text,.input-group-sm>.input-group-prepend>.form-control-plaintext.btn,.input-group-sm>.input-group-prepend>.form-control-plaintext.input-group-text{padding-right:0;padding-left:0}.form-control-sm,.input-group-sm>.form-control,.input-group-sm>.input-group-append>.btn,.input-group-sm>.input-group-append>.input-group-text,.input-group-sm>.input-group-prepend>.btn,.input-group-sm>.input-group-prepend>.input-group-text{padding:.25rem .5rem;font-size:.875rem;line-height:1.5;border-radius:.2rem}.input-group-sm>.input-group-append>select.btn:not([size]):not([multiple]),.input-group-sm>.input-group-append>select.input-group-text:not([size]):not([multiple]),.input-group-sm>.input-group-prepend>select.btn:not([size]):not([multiple]),.input-group-sm>.input-group-prepend>select.input-group-text:not([size]):not([multiple]),.input-group-sm>select.form-control:not([size]):not([multiple]),select.form-control-sm:not([size]):not([multiple]){height:calc(1.8125rem + 2px)}.form-control-lg,.input-group-lg>.form-control,.input-group-lg>.input-group-append>.btn,.input-group-lg>.input-group-append>.input-group-text,.input-group-lg>.input-group-prepend>.btn,.input-group-lg>.input-group-prepend>.input-group-text{padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.input-group-lg>.input-group-append>select.btn:not([size]):not([multiple]),.input-group-lg>.input-group-append>select.input-group-text:not([size]):not([multiple]),.input-group-lg>.input-group-prepend>select.btn:not([size]):not([multiple]),.input-group-lg>.input-group-prepend>select.input-group-text:not([size]):not([multiple]),.input-group-lg>select.form-control:not([size]):not([multiple]),select.form-control-lg:not([size]):not([multiple]){height:calc(2.875rem + 2px)}.form-group{margin-bottom:1rem}.form-text{display:block;margin-top:.25rem}.form-row{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.form-row>.col,.form-row>[class*=col-]{padding-right:5px;padding-left:5px}.form-check{position:relative;display:block;padding-left:1.25rem}.form-check-input{position:absolute;margin-top:.3rem;margin-left:-1.25rem}.form-check-input:disabled~.form-check-label{color:#6c757d}.form-check-label{margin-bottom:0}.form-check-inline{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding-left:0;margin-right:.75rem}.form-check-inline .form-check-input{position:static;margin-top:0;margin-right:.3125rem;margin-left:0}.valid-feedback{display:none;width:100%;margin-top:.25rem;font-size:80%;color:#28a745}.valid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.5rem;margin-top:.1rem;font-size:.875rem;line-height:1;color:#fff;background-color:rgba(40,167,69,.8);border-radius:.2rem}.custom-select.is-valid,.form-control.is-valid,.was-validated .custom-select:valid,.was-validated .form-control:valid{border-color:#28a745}.custom-select.is-valid:focus,.form-control.is-valid:focus,.was-validated .custom-select:valid:focus,.was-validated .form-control:valid:focus{border-color:#28a745;box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}.custom-select.is-valid~.valid-feedback,.custom-select.is-valid~.valid-tooltip,.form-control.is-valid~.valid-feedback,.form-control.is-valid~.valid-tooltip,.was-validated .custom-select:valid~.valid-feedback,.was-validated .custom-select:valid~.valid-tooltip,.was-validated .form-control:valid~.valid-feedback,.was-validated .form-control:valid~.valid-tooltip{display:block}.form-check-input.is-valid~.form-check-label,.was-validated .form-check-input:valid~.form-check-label{color:#28a745}.form-check-input.is-valid~.valid-feedback,.form-check-input.is-valid~.valid-tooltip,.was-validated .form-check-input:valid~.valid-feedback,.was-validated .form-check-input:valid~.valid-tooltip{display:block}.custom-control-input.is-valid~.custom-control-label,.was-validated .custom-control-input:valid~.custom-control-label{color:#28a745}.custom-control-input.is-valid~.custom-control-label::before,.was-validated .custom-control-input:valid~.custom-control-label::before{background-color:#71dd8a}.custom-control-input.is-valid~.valid-feedback,.custom-control-input.is-valid~.valid-tooltip,.was-validated .custom-control-input:valid~.valid-feedback,.was-validated .custom-control-input:valid~.valid-tooltip{display:block}.custom-control-input.is-valid:checked~.custom-control-label::before,.was-validated .custom-control-input:valid:checked~.custom-control-label::before{background-color:#34ce57}.custom-control-input.is-valid:focus~.custom-control-label::before,.was-validated .custom-control-input:valid:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(40,167,69,.25)}.custom-file-input.is-valid~.custom-file-label,.was-validated .custom-file-input:valid~.custom-file-label{border-color:#28a745}.custom-file-input.is-valid~.custom-file-label::before,.was-validated .custom-file-input:valid~.custom-file-label::before{border-color:inherit}.custom-file-input.is-valid~.valid-feedback,.custom-file-input.is-valid~.valid-tooltip,.was-validated .custom-file-input:valid~.valid-feedback,.was-validated .custom-file-input:valid~.valid-tooltip{display:block}.custom-file-input.is-valid:focus~.custom-file-label,.was-validated .custom-file-input:valid:focus~.custom-file-label{box-shadow:0 0 0 .2rem rgba(40,167,69,.25)}.invalid-feedback{display:none;width:100%;margin-top:.25rem;font-size:80%;color:#dc3545}.invalid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.5rem;margin-top:.1rem;font-size:.875rem;line-height:1;color:#fff;background-color:rgba(220,53,69,.8);border-radius:.2rem}.custom-select.is-invalid,.form-control.is-invalid,.was-validated .custom-select:invalid,.was-validated .form-control:invalid{border-color:#dc3545}.custom-select.is-invalid:focus,.form-control.is-invalid:focus,.was-validated .custom-select:invalid:focus,.was-validated .form-control:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}.custom-select.is-invalid~.invalid-feedback,.custom-select.is-invalid~.invalid-tooltip,.form-control.is-invalid~.invalid-feedback,.form-control.is-invalid~.invalid-tooltip,.was-validated .custom-select:invalid~.invalid-feedback,.was-validated .custom-select:invalid~.invalid-tooltip,.was-validated .form-control:invalid~.invalid-feedback,.was-validated .form-control:invalid~.invalid-tooltip{display:block}.form-check-input.is-invalid~.form-check-label,.was-validated .form-check-input:invalid~.form-check-label{color:#dc3545}.form-check-input.is-invalid~.invalid-feedback,.form-check-input.is-invalid~.invalid-tooltip,.was-validated .form-check-input:invalid~.invalid-feedback,.was-validated .form-check-input:invalid~.invalid-tooltip{display:block}.custom-control-input.is-invalid~.custom-control-label,.was-validated .custom-control-input:invalid~.custom-control-label{color:#dc3545}.custom-control-input.is-invalid~.custom-control-label::before,.was-validated .custom-control-input:invalid~.custom-control-label::before{background-color:#efa2a9}.custom-control-input.is-invalid~.invalid-feedback,.custom-control-input.is-invalid~.invalid-tooltip,.was-validated .custom-control-input:invalid~.invalid-feedback,.was-validated .custom-control-input:invalid~.invalid-tooltip{display:block}.custom-control-input.is-invalid:checked~.custom-control-label::before,.was-validated .custom-control-input:invalid:checked~.custom-control-label::before{background-color:#e4606d}.custom-control-input.is-invalid:focus~.custom-control-label::before,.was-validated .custom-control-input:invalid:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(220,53,69,.25)}.custom-file-input.is-invalid~.custom-file-label,.was-validated .custom-file-input:invalid~.custom-file-label{border-color:#dc3545}.custom-file-input.is-invalid~.custom-file-label::before,.was-validated .custom-file-input:invalid~.custom-file-label::before{border-color:inherit}.custom-file-input.is-invalid~.invalid-feedback,.custom-file-input.is-invalid~.invalid-tooltip,.was-validated .custom-file-input:invalid~.invalid-feedback,.was-validated .custom-file-input:invalid~.invalid-tooltip{display:block}.custom-file-input.is-invalid:focus~.custom-file-label,.was-validated .custom-file-input:invalid:focus~.custom-file-label{box-shadow:0 0 0 .2rem rgba(220,53,69,.25)}.form-inline{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.form-inline .form-check{width:100%}@media (min-width:576px){.form-inline label{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;margin-bottom:0}.form-inline .form-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:0}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-plaintext{display:inline-block}.form-inline .input-group{width:auto}.form-inline .form-check{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:auto;padding-left:0}.form-inline .form-check-input{position:relative;margin-top:0;margin-right:.25rem;margin-left:0}.form-inline .custom-control{-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.form-inline .custom-control-label{margin-bottom:0}}.btn{display:inline-block;font-weight:400;text-align:center;white-space:nowrap;vertical-align:middle;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border:1px solid transparent;padding:.375rem .75rem;font-size:1rem;line-height:1.5;border-radius:.25rem;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.btn:focus,.btn:hover{text-decoration:none}.btn.focus,.btn:focus{outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.btn.disabled,.btn:disabled{opacity:.65}.btn:not(:disabled):not(.disabled){cursor:pointer}.btn:not(:disabled):not(.disabled).active,.btn:not(:disabled):not(.disabled):active{background-image:none}a.btn.disabled,fieldset:disabled a.btn{pointer-events:none}.btn-primary{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:hover{color:#fff;background-color:#0069d9;border-color:#0062cc}.btn-primary.focus,.btn-primary:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-primary.disabled,.btn-primary:disabled{color:#fff;background-color:#007bff;border-color:#007bff}.btn-primary:not(:disabled):not(.disabled).active,.btn-primary:not(:disabled):not(.disabled):active,.show>.btn-primary.dropdown-toggle{color:#fff;background-color:#0062cc;border-color:#005cbf}.btn-primary:not(:disabled):not(.disabled).active:focus,.btn-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-secondary{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:hover{color:#fff;background-color:#5a6268;border-color:#545b62}.btn-secondary.focus,.btn-secondary:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-secondary.disabled,.btn-secondary:disabled{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-secondary:not(:disabled):not(.disabled).active,.btn-secondary:not(:disabled):not(.disabled):active,.show>.btn-secondary.dropdown-toggle{color:#fff;background-color:#545b62;border-color:#4e555b}.btn-secondary:not(:disabled):not(.disabled).active:focus,.btn-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-success{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:hover{color:#fff;background-color:#218838;border-color:#1e7e34}.btn-success.focus,.btn-success:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-success.disabled,.btn-success:disabled{color:#fff;background-color:#28a745;border-color:#28a745}.btn-success:not(:disabled):not(.disabled).active,.btn-success:not(:disabled):not(.disabled):active,.show>.btn-success.dropdown-toggle{color:#fff;background-color:#1e7e34;border-color:#1c7430}.btn-success:not(:disabled):not(.disabled).active:focus,.btn-success:not(:disabled):not(.disabled):active:focus,.show>.btn-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-info{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:hover{color:#fff;background-color:#138496;border-color:#117a8b}.btn-info.focus,.btn-info:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-info.disabled,.btn-info:disabled{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-info:not(:disabled):not(.disabled).active,.btn-info:not(:disabled):not(.disabled):active,.show>.btn-info.dropdown-toggle{color:#fff;background-color:#117a8b;border-color:#10707f}.btn-info:not(:disabled):not(.disabled).active:focus,.btn-info:not(:disabled):not(.disabled):active:focus,.show>.btn-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-warning{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:hover{color:#212529;background-color:#e0a800;border-color:#d39e00}.btn-warning.focus,.btn-warning:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-warning.disabled,.btn-warning:disabled{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-warning:not(:disabled):not(.disabled).active,.btn-warning:not(:disabled):not(.disabled):active,.show>.btn-warning.dropdown-toggle{color:#212529;background-color:#d39e00;border-color:#c69500}.btn-warning:not(:disabled):not(.disabled).active:focus,.btn-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-danger{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:hover{color:#fff;background-color:#c82333;border-color:#bd2130}.btn-danger.focus,.btn-danger:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-danger.disabled,.btn-danger:disabled{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-danger:not(:disabled):not(.disabled).active,.btn-danger:not(:disabled):not(.disabled):active,.show>.btn-danger.dropdown-toggle{color:#fff;background-color:#bd2130;border-color:#b21f2d}.btn-danger:not(:disabled):not(.disabled).active:focus,.btn-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-light{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:hover{color:#212529;background-color:#e2e6ea;border-color:#dae0e5}.btn-light.focus,.btn-light:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-light.disabled,.btn-light:disabled{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-light:not(:disabled):not(.disabled).active,.btn-light:not(:disabled):not(.disabled):active,.show>.btn-light.dropdown-toggle{color:#212529;background-color:#dae0e5;border-color:#d3d9df}.btn-light:not(:disabled):not(.disabled).active:focus,.btn-light:not(:disabled):not(.disabled):active:focus,.show>.btn-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-dark{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:hover{color:#fff;background-color:#23272b;border-color:#1d2124}.btn-dark.focus,.btn-dark:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-dark.disabled,.btn-dark:disabled{color:#fff;background-color:#343a40;border-color:#343a40}.btn-dark:not(:disabled):not(.disabled).active,.btn-dark:not(:disabled):not(.disabled):active,.show>.btn-dark.dropdown-toggle{color:#fff;background-color:#1d2124;border-color:#171a1d}.btn-dark:not(:disabled):not(.disabled).active:focus,.btn-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-outline-primary{color:#007bff;background-color:transparent;background-image:none;border-color:#007bff}.btn-outline-primary:hover{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary.focus,.btn-outline-primary:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-outline-primary.disabled,.btn-outline-primary:disabled{color:#007bff;background-color:transparent}.btn-outline-primary:not(:disabled):not(.disabled).active,.btn-outline-primary:not(:disabled):not(.disabled):active,.show>.btn-outline-primary.dropdown-toggle{color:#fff;background-color:#007bff;border-color:#007bff}.btn-outline-primary:not(:disabled):not(.disabled).active:focus,.btn-outline-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,123,255,.5)}.btn-outline-secondary{color:#6c757d;background-color:transparent;background-image:none;border-color:#6c757d}.btn-outline-secondary:hover{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary.focus,.btn-outline-secondary:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-outline-secondary.disabled,.btn-outline-secondary:disabled{color:#6c757d;background-color:transparent}.btn-outline-secondary:not(:disabled):not(.disabled).active,.btn-outline-secondary:not(:disabled):not(.disabled):active,.show>.btn-outline-secondary.dropdown-toggle{color:#fff;background-color:#6c757d;border-color:#6c757d}.btn-outline-secondary:not(:disabled):not(.disabled).active:focus,.btn-outline-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(108,117,125,.5)}.btn-outline-success{color:#28a745;background-color:transparent;background-image:none;border-color:#28a745}.btn-outline-success:hover{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success.focus,.btn-outline-success:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-outline-success.disabled,.btn-outline-success:disabled{color:#28a745;background-color:transparent}.btn-outline-success:not(:disabled):not(.disabled).active,.btn-outline-success:not(:disabled):not(.disabled):active,.show>.btn-outline-success.dropdown-toggle{color:#fff;background-color:#28a745;border-color:#28a745}.btn-outline-success:not(:disabled):not(.disabled).active:focus,.btn-outline-success:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-success.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(40,167,69,.5)}.btn-outline-info{color:#17a2b8;background-color:transparent;background-image:none;border-color:#17a2b8}.btn-outline-info:hover{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info.focus,.btn-outline-info:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-outline-info.disabled,.btn-outline-info:disabled{color:#17a2b8;background-color:transparent}.btn-outline-info:not(:disabled):not(.disabled).active,.btn-outline-info:not(:disabled):not(.disabled):active,.show>.btn-outline-info.dropdown-toggle{color:#fff;background-color:#17a2b8;border-color:#17a2b8}.btn-outline-info:not(:disabled):not(.disabled).active:focus,.btn-outline-info:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-info.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(23,162,184,.5)}.btn-outline-warning{color:#ffc107;background-color:transparent;background-image:none;border-color:#ffc107}.btn-outline-warning:hover{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning.focus,.btn-outline-warning:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-outline-warning.disabled,.btn-outline-warning:disabled{color:#ffc107;background-color:transparent}.btn-outline-warning:not(:disabled):not(.disabled).active,.btn-outline-warning:not(:disabled):not(.disabled):active,.show>.btn-outline-warning.dropdown-toggle{color:#212529;background-color:#ffc107;border-color:#ffc107}.btn-outline-warning:not(:disabled):not(.disabled).active:focus,.btn-outline-warning:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-warning.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(255,193,7,.5)}.btn-outline-danger{color:#dc3545;background-color:transparent;background-image:none;border-color:#dc3545}.btn-outline-danger:hover{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger.focus,.btn-outline-danger:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-outline-danger.disabled,.btn-outline-danger:disabled{color:#dc3545;background-color:transparent}.btn-outline-danger:not(:disabled):not(.disabled).active,.btn-outline-danger:not(:disabled):not(.disabled):active,.show>.btn-outline-danger.dropdown-toggle{color:#fff;background-color:#dc3545;border-color:#dc3545}.btn-outline-danger:not(:disabled):not(.disabled).active:focus,.btn-outline-danger:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-danger.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(220,53,69,.5)}.btn-outline-light{color:#f8f9fa;background-color:transparent;background-image:none;border-color:#f8f9fa}.btn-outline-light:hover{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light.focus,.btn-outline-light:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-outline-light.disabled,.btn-outline-light:disabled{color:#f8f9fa;background-color:transparent}.btn-outline-light:not(:disabled):not(.disabled).active,.btn-outline-light:not(:disabled):not(.disabled):active,.show>.btn-outline-light.dropdown-toggle{color:#212529;background-color:#f8f9fa;border-color:#f8f9fa}.btn-outline-light:not(:disabled):not(.disabled).active:focus,.btn-outline-light:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-light.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(248,249,250,.5)}.btn-outline-dark{color:#343a40;background-color:transparent;background-image:none;border-color:#343a40}.btn-outline-dark:hover{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark.focus,.btn-outline-dark:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-outline-dark.disabled,.btn-outline-dark:disabled{color:#343a40;background-color:transparent}.btn-outline-dark:not(:disabled):not(.disabled).active,.btn-outline-dark:not(:disabled):not(.disabled):active,.show>.btn-outline-dark.dropdown-toggle{color:#fff;background-color:#343a40;border-color:#343a40}.btn-outline-dark:not(:disabled):not(.disabled).active:focus,.btn-outline-dark:not(:disabled):not(.disabled):active:focus,.show>.btn-outline-dark.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(52,58,64,.5)}.btn-link{font-weight:400;color:#007bff;background-color:transparent}.btn-link:hover{color:#0056b3;text-decoration:underline;background-color:transparent;border-color:transparent}.btn-link.focus,.btn-link:focus{text-decoration:underline;border-color:transparent;box-shadow:none}.btn-link.disabled,.btn-link:disabled{color:#6c757d}.btn-group-lg>.btn,.btn-lg{padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.btn-group-sm>.btn,.btn-sm{padding:.25rem .5rem;font-size:.875rem;line-height:1.5;border-radius:.2rem}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:.5rem}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{opacity:0;transition:opacity .15s linear}.fade.show{opacity:1}.collapse{display:none}.collapse.show{display:block}tr.collapse.show{display:table-row}tbody.collapse.show{display:table-row-group}.collapsing{position:relative;height:0;overflow:hidden;transition:height .35s ease}.dropdown,.dropup{position:relative}.dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid;border-right:.3em solid transparent;border-bottom:0;border-left:.3em solid transparent}.dropdown-toggle:empty::after{margin-left:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:10rem;padding:.5rem 0;margin:.125rem 0 0;font-size:1rem;color:#212529;text-align:left;list-style:none;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.15);border-radius:.25rem}.dropup .dropdown-menu{margin-top:0;margin-bottom:.125rem}.dropup .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:0;border-right:.3em solid transparent;border-bottom:.3em solid;border-left:.3em solid transparent}.dropup .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-menu{margin-top:0;margin-left:.125rem}.dropright .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-bottom:.3em solid transparent;border-left:.3em solid}.dropright .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-toggle::after{vertical-align:0}.dropleft .dropdown-menu{margin-top:0;margin-right:.125rem}.dropleft .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:.255em;vertical-align:.255em;content:""}.dropleft .dropdown-toggle::after{display:none}.dropleft .dropdown-toggle::before{display:inline-block;width:0;height:0;margin-right:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:.3em solid;border-bottom:.3em solid transparent}.dropleft .dropdown-toggle:empty::after{margin-left:0}.dropleft .dropdown-toggle::before{vertical-align:0}.dropdown-divider{height:0;margin:.5rem 0;overflow:hidden;border-top:1px solid #e9ecef}.dropdown-item{display:block;width:100%;padding:.25rem 1.5rem;clear:both;font-weight:400;color:#212529;text-align:inherit;white-space:nowrap;background-color:transparent;border:0}.dropdown-item:focus,.dropdown-item:hover{color:#16181b;text-decoration:none;background-color:#f8f9fa}.dropdown-item.active,.dropdown-item:active{color:#fff;text-decoration:none;background-color:#007bff}.dropdown-item.disabled,.dropdown-item:disabled{color:#6c757d;background-color:transparent}.dropdown-menu.show{display:block}.dropdown-header{display:block;padding:.5rem 1.5rem;margin-bottom:0;font-size:.875rem;color:#6c757d;white-space:nowrap}.btn-group,.btn-group-vertical{position:relative;display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;-webkit-box-flex:0;-ms-flex:0 1 auto;flex:0 1 auto}.btn-group-vertical>.btn:hover,.btn-group>.btn:hover{z-index:1}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus{z-index:1}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group,.btn-group-vertical .btn+.btn,.btn-group-vertical .btn+.btn-group,.btn-group-vertical .btn-group+.btn,.btn-group-vertical .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn-group:not(:last-child)>.btn,.btn-group>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:not(:first-child)>.btn,.btn-group>.btn:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-right:.5625rem;padding-left:.5625rem}.dropdown-toggle-split::after{margin-left:0}.btn-group-sm>.btn+.dropdown-toggle-split,.btn-sm+.dropdown-toggle-split{padding-right:.375rem;padding-left:.375rem}.btn-group-lg>.btn+.dropdown-toggle-split,.btn-lg+.dropdown-toggle-split{padding-right:.75rem;padding-left:.75rem}.btn-group-vertical{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.btn-group-vertical .btn,.btn-group-vertical .btn-group{width:100%}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn-group:not(:last-child)>.btn,.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:not(:first-child)>.btn,.btn-group-vertical>.btn:not(:first-child){border-top-left-radius:0;border-top-right-radius:0}.btn-group-toggle>.btn,.btn-group-toggle>.btn-group>.btn{margin-bottom:0}.btn-group-toggle>.btn input[type=checkbox],.btn-group-toggle>.btn input[type=radio],.btn-group-toggle>.btn-group>.btn input[type=checkbox],.btn-group-toggle>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch;width:100%}.input-group>.custom-file,.input-group>.custom-select,.input-group>.form-control{position:relative;-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;width:1%;margin-bottom:0}.input-group>.custom-file:focus,.input-group>.custom-select:focus,.input-group>.form-control:focus{z-index:3}.input-group>.custom-file+.custom-file,.input-group>.custom-file+.custom-select,.input-group>.custom-file+.form-control,.input-group>.custom-select+.custom-file,.input-group>.custom-select+.custom-select,.input-group>.custom-select+.form-control,.input-group>.form-control+.custom-file,.input-group>.form-control+.custom-select,.input-group>.form-control+.form-control{margin-left:-1px}.input-group>.custom-select:not(:last-child),.input-group>.form-control:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-select:not(:first-child),.input-group>.form-control:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.custom-file{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.input-group>.custom-file:not(:last-child) .custom-file-label,.input-group>.custom-file:not(:last-child) .custom-file-label::before{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-file:not(:first-child) .custom-file-label,.input-group>.custom-file:not(:first-child) .custom-file-label::before{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-append,.input-group-prepend{display:-webkit-box;display:-ms-flexbox;display:flex}.input-group-append .btn,.input-group-prepend .btn{position:relative;z-index:2}.input-group-append .btn+.btn,.input-group-append .btn+.input-group-text,.input-group-append .input-group-text+.btn,.input-group-append .input-group-text+.input-group-text,.input-group-prepend .btn+.btn,.input-group-prepend .btn+.input-group-text,.input-group-prepend .input-group-text+.btn,.input-group-prepend .input-group-text+.input-group-text{margin-left:-1px}.input-group-prepend{margin-right:-1px}.input-group-append{margin-left:-1px}.input-group-text{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:.375rem .75rem;margin-bottom:0;font-size:1rem;font-weight:400;line-height:1.5;color:#495057;text-align:center;white-space:nowrap;background-color:#e9ecef;border:1px solid #ced4da;border-radius:.25rem}.input-group-text input[type=checkbox],.input-group-text input[type=radio]{margin-top:0}.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle),.input-group>.input-group-append:last-child>.input-group-text:not(:last-child),.input-group>.input-group-append:not(:last-child)>.btn,.input-group>.input-group-append:not(:last-child)>.input-group-text,.input-group>.input-group-prepend>.btn,.input-group>.input-group-prepend>.input-group-text{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.input-group-append>.btn,.input-group>.input-group-append>.input-group-text,.input-group>.input-group-prepend:first-child>.btn:not(:first-child),.input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child),.input-group>.input-group-prepend:not(:first-child)>.btn,.input-group>.input-group-prepend:not(:first-child)>.input-group-text{border-top-left-radius:0;border-bottom-left-radius:0}.custom-control{position:relative;display:block;min-height:1.5rem;padding-left:1.5rem}.custom-control-inline{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;margin-right:1rem}.custom-control-input{position:absolute;z-index:-1;opacity:0}.custom-control-input:checked~.custom-control-label::before{color:#fff;background-color:#007bff}.custom-control-input:focus~.custom-control-label::before{box-shadow:0 0 0 1px #fff,0 0 0 .2rem rgba(0,123,255,.25)}.custom-control-input:active~.custom-control-label::before{color:#fff;background-color:#b3d7ff}.custom-control-input:disabled~.custom-control-label{color:#6c757d}.custom-control-input:disabled~.custom-control-label::before{background-color:#e9ecef}.custom-control-label{margin-bottom:0}.custom-control-label::before{position:absolute;top:.25rem;left:0;display:block;width:1rem;height:1rem;pointer-events:none;content:"";-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#dee2e6}.custom-control-label::after{position:absolute;top:.25rem;left:0;display:block;width:1rem;height:1rem;content:"";background-repeat:no-repeat;background-position:center center;background-size:50% 50%}.custom-checkbox .custom-control-label::before{border-radius:.25rem}.custom-checkbox .custom-control-input:checked~.custom-control-label::before{background-color:#007bff}.custom-checkbox .custom-control-input:checked~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before{background-color:#007bff}.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3E%3Cpath stroke='%23fff' d='M0 2h4'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:disabled:checked~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-checkbox .custom-control-input:disabled:indeterminate~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-radio .custom-control-label::before{border-radius:50%}.custom-radio .custom-control-input:checked~.custom-control-label::before{background-color:#007bff}.custom-radio .custom-control-input:checked~.custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E")}.custom-radio .custom-control-input:disabled:checked~.custom-control-label::before{background-color:rgba(0,123,255,.5)}.custom-select{display:inline-block;width:100%;height:calc(2.25rem + 2px);padding:.375rem 1.75rem .375rem .75rem;line-height:1.5;color:#495057;vertical-align:middle;background:#fff url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E") no-repeat right .75rem center;background-size:8px 10px;border:1px solid #ced4da;border-radius:.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:inset 0 1px 2px rgba(0,0,0,.075),0 0 5px rgba(128,189,255,.5)}.custom-select:focus::-ms-value{color:#495057;background-color:#fff}.custom-select[multiple],.custom-select[size]:not([size="1"]){height:auto;padding-right:.75rem;background-image:none}.custom-select:disabled{color:#6c757d;background-color:#e9ecef}.custom-select::-ms-expand{opacity:0}.custom-select-sm{height:calc(1.8125rem + 2px);padding-top:.375rem;padding-bottom:.375rem;font-size:75%}.custom-select-lg{height:calc(2.875rem + 2px);padding-top:.375rem;padding-bottom:.375rem;font-size:125%}.custom-file{position:relative;display:inline-block;width:100%;height:calc(2.25rem + 2px);margin-bottom:0}.custom-file-input{position:relative;z-index:2;width:100%;height:calc(2.25rem + 2px);margin:0;opacity:0}.custom-file-input:focus~.custom-file-control{border-color:#80bdff;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.custom-file-input:focus~.custom-file-control::before{border-color:#80bdff}.custom-file-input:lang(en)~.custom-file-label::after{content:"Browse"}.custom-file-label{position:absolute;top:0;right:0;left:0;z-index:1;height:calc(2.25rem + 2px);padding:.375rem .75rem;line-height:1.5;color:#495057;background-color:#fff;border:1px solid #ced4da;border-radius:.25rem}.custom-file-label::after{position:absolute;top:0;right:0;bottom:0;z-index:3;display:block;height:calc(calc(2.25rem + 2px) - 1px * 2);padding:.375rem .75rem;line-height:1.5;color:#495057;content:"Browse";background-color:#e9ecef;border-left:1px solid #ced4da;border-radius:0 .25rem .25rem 0}.nav{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding-left:0;margin-bottom:0;list-style:none}.nav-link{display:block;padding:.5rem 1rem}.nav-link:focus,.nav-link:hover{text-decoration:none}.nav-link.disabled{color:#6c757d}.nav-tabs{border-bottom:1px solid #dee2e6}.nav-tabs .nav-item{margin-bottom:-1px}.nav-tabs .nav-link{border:1px solid transparent;border-top-left-radius:.25rem;border-top-right-radius:.25rem}.nav-tabs .nav-link:focus,.nav-tabs .nav-link:hover{border-color:#e9ecef #e9ecef #dee2e6}.nav-tabs .nav-link.disabled{color:#6c757d;background-color:transparent;border-color:transparent}.nav-tabs .nav-item.show .nav-link,.nav-tabs .nav-link.active{color:#495057;background-color:#fff;border-color:#dee2e6 #dee2e6 #fff}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.nav-pills .nav-link{border-radius:.25rem}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{color:#fff;background-color:#007bff}.nav-fill .nav-item{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;text-align:center}.nav-justified .nav-item{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;text-align:center}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;padding:.5rem 1rem}.navbar>.container,.navbar>.container-fluid{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between}.navbar-brand{display:inline-block;padding-top:.3125rem;padding-bottom:.3125rem;margin-right:1rem;font-size:1.25rem;line-height:inherit;white-space:nowrap}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-nav{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}.navbar-nav .nav-link{padding-right:0;padding-left:0}.navbar-nav .dropdown-menu{position:static;float:none}.navbar-text{display:inline-block;padding-top:.5rem;padding-bottom:.5rem}.navbar-collapse{-ms-flex-preferred-size:100%;flex-basis:100%;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.navbar-toggler{padding:.25rem .75rem;font-size:1.25rem;line-height:1;background-color:transparent;border:1px solid transparent;border-radius:.25rem}.navbar-toggler:focus,.navbar-toggler:hover{text-decoration:none}.navbar-toggler:not(:disabled):not(.disabled){cursor:pointer}.navbar-toggler-icon{display:inline-block;width:1.5em;height:1.5em;vertical-align:middle;content:"";background:no-repeat center center;background-size:100% 100%}@media (max-width:575.98px){.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:576px){.navbar-expand-sm{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-sm .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-sm .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-sm .navbar-collapse{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-sm .navbar-toggler{display:none}.navbar-expand-sm .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width:767.98px){.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:768px){.navbar-expand-md{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-md .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-md .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-md .navbar-collapse{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-md .navbar-toggler{display:none}.navbar-expand-md .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width:991.98px){.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:992px){.navbar-expand-lg{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-lg .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-lg .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-lg .navbar-collapse{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-lg .navbar-toggler{display:none}.navbar-expand-lg .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width:1199.98px){.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{padding-right:0;padding-left:0}}@media (min-width:1200px){.navbar-expand-xl{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-xl .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-xl .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-xl .navbar-collapse{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-xl .navbar-toggler{display:none}.navbar-expand-xl .dropup .dropdown-menu{top:auto;bottom:100%}}.navbar-expand{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand>.container,.navbar-expand>.container-fluid{padding-right:0;padding-left:0}.navbar-expand .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand .navbar-nav .nav-link{padding-right:.5rem;padding-left:.5rem}.navbar-expand>.container,.navbar-expand>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand .navbar-collapse{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand .navbar-toggler{display:none}.navbar-expand .dropup .dropdown-menu{top:auto;bottom:100%}.navbar-light .navbar-brand{color:rgba(0,0,0,.9)}.navbar-light .navbar-brand:focus,.navbar-light .navbar-brand:hover{color:rgba(0,0,0,.9)}.navbar-light .navbar-nav .nav-link{color:rgba(0,0,0,.5)}.navbar-light .navbar-nav .nav-link:focus,.navbar-light .navbar-nav .nav-link:hover{color:rgba(0,0,0,.7)}.navbar-light .navbar-nav .nav-link.disabled{color:rgba(0,0,0,.3)}.navbar-light .navbar-nav .active>.nav-link,.navbar-light .navbar-nav .nav-link.active,.navbar-light .navbar-nav .nav-link.show,.navbar-light .navbar-nav .show>.nav-link{color:rgba(0,0,0,.9)}.navbar-light .navbar-toggler{color:rgba(0,0,0,.5);border-color:rgba(0,0,0,.1)}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-light .navbar-text{color:rgba(0,0,0,.5)}.navbar-light .navbar-text a{color:rgba(0,0,0,.9)}.navbar-light .navbar-text a:focus,.navbar-light .navbar-text a:hover{color:rgba(0,0,0,.9)}.navbar-dark .navbar-brand{color:#fff}.navbar-dark .navbar-brand:focus,.navbar-dark .navbar-brand:hover{color:#fff}.navbar-dark .navbar-nav .nav-link{color:rgba(255,255,255,.5)}.navbar-dark .navbar-nav .nav-link:focus,.navbar-dark .navbar-nav .nav-link:hover{color:rgba(255,255,255,.75)}.navbar-dark .navbar-nav .nav-link.disabled{color:rgba(255,255,255,.25)}.navbar-dark .navbar-nav .active>.nav-link,.navbar-dark .navbar-nav .nav-link.active,.navbar-dark .navbar-nav .nav-link.show,.navbar-dark .navbar-nav .show>.nav-link{color:#fff}.navbar-dark .navbar-toggler{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.1)}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-dark .navbar-text{color:rgba(255,255,255,.5)}.navbar-dark .navbar-text a{color:#fff}.navbar-dark .navbar-text a:focus,.navbar-dark .navbar-text a:hover{color:#fff}.card{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-width:0;word-wrap:break-word;background-color:#fff;background-clip:border-box;border:1px solid rgba(0,0,0,.125);border-radius:.25rem}.card>hr{margin-right:0;margin-left:0}.card>.list-group:first-child .list-group-item:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card>.list-group:last-child .list-group-item:last-child{border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.card-body{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;padding:1.25rem}.card-title{margin-bottom:.75rem}.card-subtitle{margin-top:-.375rem;margin-bottom:0}.card-text:last-child{margin-bottom:0}.card-link:hover{text-decoration:none}.card-link+.card-link{margin-left:1.25rem}.card-header{padding:.75rem 1.25rem;margin-bottom:0;background-color:rgba(0,0,0,.03);border-bottom:1px solid rgba(0,0,0,.125)}.card-header:first-child{border-radius:calc(.25rem - 1px) calc(.25rem - 1px) 0 0}.card-header+.list-group .list-group-item:first-child{border-top:0}.card-footer{padding:.75rem 1.25rem;background-color:rgba(0,0,0,.03);border-top:1px solid rgba(0,0,0,.125)}.card-footer:last-child{border-radius:0 0 calc(.25rem - 1px) calc(.25rem - 1px)}.card-header-tabs{margin-right:-.625rem;margin-bottom:-.75rem;margin-left:-.625rem;border-bottom:0}.card-header-pills{margin-right:-.625rem;margin-left:-.625rem}.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:1.25rem}.card-img{width:100%;border-radius:calc(.25rem - 1px)}.card-img-top{width:100%;border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px)}.card-img-bottom{width:100%;border-bottom-right-radius:calc(.25rem - 1px);border-bottom-left-radius:calc(.25rem - 1px)}.card-deck{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.card-deck .card{margin-bottom:15px}@media (min-width:576px){.card-deck{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;margin-right:-15px;margin-left:-15px}.card-deck .card{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;margin-right:15px;margin-bottom:0;margin-left:15px}}.card-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.card-group>.card{margin-bottom:15px}@media (min-width:576px){.card-group{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap}.card-group>.card{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;margin-bottom:0}.card-group>.card+.card{margin-left:0;border-left:0}.card-group>.card:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:first-child .card-header,.card-group>.card:first-child .card-img-top{border-top-right-radius:0}.card-group>.card:first-child .card-footer,.card-group>.card:first-child .card-img-bottom{border-bottom-right-radius:0}.card-group>.card:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:last-child .card-header,.card-group>.card:last-child .card-img-top{border-top-left-radius:0}.card-group>.card:last-child .card-footer,.card-group>.card:last-child .card-img-bottom{border-bottom-left-radius:0}.card-group>.card:only-child{border-radius:.25rem}.card-group>.card:only-child .card-header,.card-group>.card:only-child .card-img-top{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card-group>.card:only-child .card-footer,.card-group>.card:only-child .card-img-bottom{border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.card-group>.card:not(:first-child):not(:last-child):not(:only-child){border-radius:0}.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-footer,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-header,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-bottom,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-top{border-radius:0}}.card-columns .card{margin-bottom:.75rem}@media (min-width:576px){.card-columns{-webkit-column-count:3;-moz-column-count:3;column-count:3;-webkit-column-gap:1.25rem;-moz-column-gap:1.25rem;column-gap:1.25rem}.card-columns .card{display:inline-block;width:100%}}.breadcrumb{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding:.75rem 1rem;margin-bottom:1rem;list-style:none;background-color:#e9ecef;border-radius:.25rem}.breadcrumb-item+.breadcrumb-item::before{display:inline-block;padding-right:.5rem;padding-left:.5rem;color:#6c757d;content:"/"}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:underline}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:none}.breadcrumb-item.active{color:#6c757d}.pagination{display:-webkit-box;display:-ms-flexbox;display:flex;padding-left:0;list-style:none;border-radius:.25rem}.page-link{position:relative;display:block;padding:.5rem .75rem;margin-left:-1px;line-height:1.25;color:#007bff;background-color:#fff;border:1px solid #dee2e6}.page-link:hover{color:#0056b3;text-decoration:none;background-color:#e9ecef;border-color:#dee2e6}.page-link:focus{z-index:2;outline:0;box-shadow:0 0 0 .2rem rgba(0,123,255,.25)}.page-link:not(:disabled):not(.disabled){cursor:pointer}.page-item:first-child .page-link{margin-left:0;border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}.page-item:last-child .page-link{border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.page-item.active .page-link{z-index:1;color:#fff;background-color:#007bff;border-color:#007bff}.page-item.disabled .page-link{color:#6c757d;pointer-events:none;cursor:auto;background-color:#fff;border-color:#dee2e6}.pagination-lg .page-link{padding:.75rem 1.5rem;font-size:1.25rem;line-height:1.5}.pagination-lg .page-item:first-child .page-link{border-top-left-radius:.3rem;border-bottom-left-radius:.3rem}.pagination-lg .page-item:last-child .page-link{border-top-right-radius:.3rem;border-bottom-right-radius:.3rem}.pagination-sm .page-link{padding:.25rem .5rem;font-size:.875rem;line-height:1.5}.pagination-sm .page-item:first-child .page-link{border-top-left-radius:.2rem;border-bottom-left-radius:.2rem}.pagination-sm .page-item:last-child .page-link{border-top-right-radius:.2rem;border-bottom-right-radius:.2rem}.badge{display:inline-block;padding:.25em .4em;font-size:75%;font-weight:700;line-height:1;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25rem}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.badge-pill{padding-right:.6em;padding-left:.6em;border-radius:10rem}.badge-primary{color:#fff;background-color:#007bff}.badge-primary[href]:focus,.badge-primary[href]:hover{color:#fff;text-decoration:none;background-color:#0062cc}.badge-secondary{color:#fff;background-color:#6c757d}.badge-secondary[href]:focus,.badge-secondary[href]:hover{color:#fff;text-decoration:none;background-color:#545b62}.badge-success{color:#fff;background-color:#28a745}.badge-success[href]:focus,.badge-success[href]:hover{color:#fff;text-decoration:none;background-color:#1e7e34}.badge-info{color:#fff;background-color:#17a2b8}.badge-info[href]:focus,.badge-info[href]:hover{color:#fff;text-decoration:none;background-color:#117a8b}.badge-warning{color:#212529;background-color:#ffc107}.badge-warning[href]:focus,.badge-warning[href]:hover{color:#212529;text-decoration:none;background-color:#d39e00}.badge-danger{color:#fff;background-color:#dc3545}.badge-danger[href]:focus,.badge-danger[href]:hover{color:#fff;text-decoration:none;background-color:#bd2130}.badge-light{color:#212529;background-color:#f8f9fa}.badge-light[href]:focus,.badge-light[href]:hover{color:#212529;text-decoration:none;background-color:#dae0e5}.badge-dark{color:#fff;background-color:#343a40}.badge-dark[href]:focus,.badge-dark[href]:hover{color:#fff;text-decoration:none;background-color:#1d2124}.jumbotron{padding:2rem 1rem;margin-bottom:2rem;background-color:#e9ecef;border-radius:.3rem}@media (min-width:576px){.jumbotron{padding:4rem 2rem}}.jumbotron-fluid{padding-right:0;padding-left:0;border-radius:0}.alert{position:relative;padding:.75rem 1.25rem;margin-bottom:1rem;border:1px solid transparent;border-radius:.25rem}.alert-heading{color:inherit}.alert-link{font-weight:700}.alert-dismissible{padding-right:4rem}.alert-dismissible .close{position:absolute;top:0;right:0;padding:.75rem 1.25rem;color:inherit}.alert-primary{color:#004085;background-color:#cce5ff;border-color:#b8daff}.alert-primary hr{border-top-color:#9fcdff}.alert-primary .alert-link{color:#002752}.alert-secondary{color:#383d41;background-color:#e2e3e5;border-color:#d6d8db}.alert-secondary hr{border-top-color:#c8cbcf}.alert-secondary .alert-link{color:#202326}.alert-success{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.alert-success hr{border-top-color:#b1dfbb}.alert-success .alert-link{color:#0b2e13}.alert-info{color:#0c5460;background-color:#d1ecf1;border-color:#bee5eb}.alert-info hr{border-top-color:#abdde5}.alert-info .alert-link{color:#062c33}.alert-warning{color:#856404;background-color:#fff3cd;border-color:#ffeeba}.alert-warning hr{border-top-color:#ffe8a1}.alert-warning .alert-link{color:#533f03}.alert-danger{color:#721c24;background-color:#f8d7da;border-color:#f5c6cb}.alert-danger hr{border-top-color:#f1b0b7}.alert-danger .alert-link{color:#491217}.alert-light{color:#818182;background-color:#fefefe;border-color:#fdfdfe}.alert-light hr{border-top-color:#ececf6}.alert-light .alert-link{color:#686868}.alert-dark{color:#1b1e21;background-color:#d6d8d9;border-color:#c6c8ca}.alert-dark hr{border-top-color:#b9bbbe}.alert-dark .alert-link{color:#040505}@-webkit-keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}.progress{display:-webkit-box;display:-ms-flexbox;display:flex;height:1rem;overflow:hidden;font-size:.75rem;background-color:#e9ecef;border-radius:.25rem}.progress-bar{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;color:#fff;text-align:center;background-color:#007bff;transition:width .6s ease}.progress-bar-striped{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem}.progress-bar-animated{-webkit-animation:progress-bar-stripes 1s linear infinite;animation:progress-bar-stripes 1s linear infinite}.media{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.media-body{-webkit-box-flex:1;-ms-flex:1;flex:1}.list-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0}.list-group-item-action{width:100%;color:#495057;text-align:inherit}.list-group-item-action:focus,.list-group-item-action:hover{color:#495057;text-decoration:none;background-color:#f8f9fa}.list-group-item-action:active{color:#212529;background-color:#e9ecef}.list-group-item{position:relative;display:block;padding:.75rem 1.25rem;margin-bottom:-1px;background-color:#fff;border:1px solid rgba(0,0,0,.125)}.list-group-item:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:.25rem;border-bottom-left-radius:.25rem}.list-group-item:focus,.list-group-item:hover{z-index:1;text-decoration:none}.list-group-item.disabled,.list-group-item:disabled{color:#6c757d;background-color:#fff}.list-group-item.active{z-index:2;color:#fff;background-color:#007bff;border-color:#007bff}.list-group-flush .list-group-item{border-right:0;border-left:0;border-radius:0}.list-group-flush:first-child .list-group-item:first-child{border-top:0}.list-group-flush:last-child .list-group-item:last-child{border-bottom:0}.list-group-item-primary{color:#004085;background-color:#b8daff}.list-group-item-primary.list-group-item-action:focus,.list-group-item-primary.list-group-item-action:hover{color:#004085;background-color:#9fcdff}.list-group-item-primary.list-group-item-action.active{color:#fff;background-color:#004085;border-color:#004085}.list-group-item-secondary{color:#383d41;background-color:#d6d8db}.list-group-item-secondary.list-group-item-action:focus,.list-group-item-secondary.list-group-item-action:hover{color:#383d41;background-color:#c8cbcf}.list-group-item-secondary.list-group-item-action.active{color:#fff;background-color:#383d41;border-color:#383d41}.list-group-item-success{color:#155724;background-color:#c3e6cb}.list-group-item-success.list-group-item-action:focus,.list-group-item-success.list-group-item-action:hover{color:#155724;background-color:#b1dfbb}.list-group-item-success.list-group-item-action.active{color:#fff;background-color:#155724;border-color:#155724}.list-group-item-info{color:#0c5460;background-color:#bee5eb}.list-group-item-info.list-group-item-action:focus,.list-group-item-info.list-group-item-action:hover{color:#0c5460;background-color:#abdde5}.list-group-item-info.list-group-item-action.active{color:#fff;background-color:#0c5460;border-color:#0c5460}.list-group-item-warning{color:#856404;background-color:#ffeeba}.list-group-item-warning.list-group-item-action:focus,.list-group-item-warning.list-group-item-action:hover{color:#856404;background-color:#ffe8a1}.list-group-item-warning.list-group-item-action.active{color:#fff;background-color:#856404;border-color:#856404}.list-group-item-danger{color:#721c24;background-color:#f5c6cb}.list-group-item-danger.list-group-item-action:focus,.list-group-item-danger.list-group-item-action:hover{color:#721c24;background-color:#f1b0b7}.list-group-item-danger.list-group-item-action.active{color:#fff;background-color:#721c24;border-color:#721c24}.list-group-item-light{color:#818182;background-color:#fdfdfe}.list-group-item-light.list-group-item-action:focus,.list-group-item-light.list-group-item-action:hover{color:#818182;background-color:#ececf6}.list-group-item-light.list-group-item-action.active{color:#fff;background-color:#818182;border-color:#818182}.list-group-item-dark{color:#1b1e21;background-color:#c6c8ca}.list-group-item-dark.list-group-item-action:focus,.list-group-item-dark.list-group-item-action:hover{color:#1b1e21;background-color:#b9bbbe}.list-group-item-dark.list-group-item-action.active{color:#fff;background-color:#1b1e21;border-color:#1b1e21}.close{float:right;font-size:1.5rem;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.5}.close:focus,.close:hover{color:#000;text-decoration:none;opacity:.75}.close:not(:disabled):not(.disabled){cursor:pointer}button.close{padding:0;background-color:transparent;border:0;-webkit-appearance:none}.modal-open{overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;outline:0}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:.5rem;pointer-events:none}.modal.fade .modal-dialog{transition:-webkit-transform .3s ease-out;transition:transform .3s ease-out;transition:transform .3s ease-out,-webkit-transform .3s ease-out;-webkit-transform:translate(0,-25%);transform:translate(0,-25%)}.modal.show .modal-dialog{-webkit-transform:translate(0,0);transform:translate(0,0)}.modal-dialog-centered{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-height:calc(100% - (.5rem * 2))}.modal-content{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;width:100%;pointer-events:auto;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.2);border-radius:.3rem;outline:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:.5}.modal-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;padding:1rem;border-bottom:1px solid #e9ecef;border-top-left-radius:.3rem;border-top-right-radius:.3rem}.modal-header .close{padding:1rem;margin:-1rem -1rem -1rem auto}.modal-title{margin-bottom:0;line-height:1.5}.modal-body{position:relative;-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;padding:1rem}.modal-footer{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end;padding:1rem;border-top:1px solid #e9ecef}.modal-footer>:not(:first-child){margin-left:.25rem}.modal-footer>:not(:last-child){margin-right:.25rem}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:576px){.modal-dialog{max-width:500px;margin:1.75rem auto}.modal-dialog-centered{min-height:calc(100% - (1.75rem * 2))}.modal-sm{max-width:300px}}@media (min-width:992px){.modal-lg{max-width:800px}}.tooltip{position:absolute;z-index:1070;display:block;margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;opacity:0}.tooltip.show{opacity:.9}.tooltip .arrow{position:absolute;display:block;width:.8rem;height:.4rem}.tooltip .arrow::before{position:absolute;content:"";border-color:transparent;border-style:solid}.bs-tooltip-auto[x-placement^=top],.bs-tooltip-top{padding:.4rem 0}.bs-tooltip-auto[x-placement^=top] .arrow,.bs-tooltip-top .arrow{bottom:0}.bs-tooltip-auto[x-placement^=top] .arrow::before,.bs-tooltip-top .arrow::before{top:0;border-width:.4rem .4rem 0;border-top-color:#000}.bs-tooltip-auto[x-placement^=right],.bs-tooltip-right{padding:0 .4rem}.bs-tooltip-auto[x-placement^=right] .arrow,.bs-tooltip-right .arrow{left:0;width:.4rem;height:.8rem}.bs-tooltip-auto[x-placement^=right] .arrow::before,.bs-tooltip-right .arrow::before{right:0;border-width:.4rem .4rem .4rem 0;border-right-color:#000}.bs-tooltip-auto[x-placement^=bottom],.bs-tooltip-bottom{padding:.4rem 0}.bs-tooltip-auto[x-placement^=bottom] .arrow,.bs-tooltip-bottom .arrow{top:0}.bs-tooltip-auto[x-placement^=bottom] .arrow::before,.bs-tooltip-bottom .arrow::before{bottom:0;border-width:0 .4rem .4rem;border-bottom-color:#000}.bs-tooltip-auto[x-placement^=left],.bs-tooltip-left{padding:0 .4rem}.bs-tooltip-auto[x-placement^=left] .arrow,.bs-tooltip-left .arrow{right:0;width:.4rem;height:.8rem}.bs-tooltip-auto[x-placement^=left] .arrow::before,.bs-tooltip-left .arrow::before{left:0;border-width:.4rem 0 .4rem .4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:.25rem .5rem;color:#fff;text-align:center;background-color:#000;border-radius:.25rem}.popover{position:absolute;top:0;left:0;z-index:1060;display:block;max-width:276px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,.2);border-radius:.3rem}.popover .arrow{position:absolute;display:block;width:1rem;height:.5rem;margin:0 .3rem}.popover .arrow::after,.popover .arrow::before{position:absolute;display:block;content:"";border-color:transparent;border-style:solid}.bs-popover-auto[x-placement^=top],.bs-popover-top{margin-bottom:.5rem}.bs-popover-auto[x-placement^=top] .arrow,.bs-popover-top .arrow{bottom:calc((.5rem + 1px) * -1)}.bs-popover-auto[x-placement^=top] .arrow::after,.bs-popover-auto[x-placement^=top] .arrow::before,.bs-popover-top .arrow::after,.bs-popover-top .arrow::before{border-width:.5rem .5rem 0}.bs-popover-auto[x-placement^=top] .arrow::before,.bs-popover-top .arrow::before{bottom:0;border-top-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=top] .arrow::after,.bs-popover-top .arrow::after{bottom:1px;border-top-color:#fff}.bs-popover-auto[x-placement^=right],.bs-popover-right{margin-left:.5rem}.bs-popover-auto[x-placement^=right] .arrow,.bs-popover-right .arrow{left:calc((.5rem + 1px) * -1);width:.5rem;height:1rem;margin:.3rem 0}.bs-popover-auto[x-placement^=right] .arrow::after,.bs-popover-auto[x-placement^=right] .arrow::before,.bs-popover-right .arrow::after,.bs-popover-right .arrow::before{border-width:.5rem .5rem .5rem 0}.bs-popover-auto[x-placement^=right] .arrow::before,.bs-popover-right .arrow::before{left:0;border-right-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=right] .arrow::after,.bs-popover-right .arrow::after{left:1px;border-right-color:#fff}.bs-popover-auto[x-placement^=bottom],.bs-popover-bottom{margin-top:.5rem}.bs-popover-auto[x-placement^=bottom] .arrow,.bs-popover-bottom .arrow{top:calc((.5rem + 1px) * -1)}.bs-popover-auto[x-placement^=bottom] .arrow::after,.bs-popover-auto[x-placement^=bottom] .arrow::before,.bs-popover-bottom .arrow::after,.bs-popover-bottom .arrow::before{border-width:0 .5rem .5rem .5rem}.bs-popover-auto[x-placement^=bottom] .arrow::before,.bs-popover-bottom .arrow::before{top:0;border-bottom-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=bottom] .arrow::after,.bs-popover-bottom .arrow::after{top:1px;border-bottom-color:#fff}.bs-popover-auto[x-placement^=bottom] .popover-header::before,.bs-popover-bottom .popover-header::before{position:absolute;top:0;left:50%;display:block;width:1rem;margin-left:-.5rem;content:"";border-bottom:1px solid #f7f7f7}.bs-popover-auto[x-placement^=left],.bs-popover-left{margin-right:.5rem}.bs-popover-auto[x-placement^=left] .arrow,.bs-popover-left .arrow{right:calc((.5rem + 1px) * -1);width:.5rem;height:1rem;margin:.3rem 0}.bs-popover-auto[x-placement^=left] .arrow::after,.bs-popover-auto[x-placement^=left] .arrow::before,.bs-popover-left .arrow::after,.bs-popover-left .arrow::before{border-width:.5rem 0 .5rem .5rem}.bs-popover-auto[x-placement^=left] .arrow::before,.bs-popover-left .arrow::before{right:0;border-left-color:rgba(0,0,0,.25)}.bs-popover-auto[x-placement^=left] .arrow::after,.bs-popover-left .arrow::after{right:1px;border-left-color:#fff}.popover-header{padding:.5rem .75rem;margin-bottom:0;font-size:1rem;color:inherit;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-top-left-radius:calc(.3rem - 1px);border-top-right-radius:calc(.3rem - 1px)}.popover-header:empty{display:none}.popover-body{padding:.5rem .75rem;color:#212529}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-item{position:relative;display:none;-webkit-box-align:center;-ms-flex-align:center;align-items:center;width:100%;transition:-webkit-transform .6s ease;transition:transform .6s ease;transition:transform .6s ease,-webkit-transform .6s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-item-next,.carousel-item-prev,.carousel-item.active{display:block}.carousel-item-next,.carousel-item-prev{position:absolute;top:0}.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translateX(0);transform:translateX(0)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.active.carousel-item-right,.carousel-item-next{-webkit-transform:translateX(100%);transform:translateX(100%)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.active.carousel-item-right,.carousel-item-next{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}}.active.carousel-item-left,.carousel-item-prev{-webkit-transform:translateX(-100%);transform:translateX(-100%)}@supports ((-webkit-transform-style:preserve-3d) or (transform-style:preserve-3d)){.active.carousel-item-left,.carousel-item-prev{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}}.carousel-control-next,.carousel-control-prev{position:absolute;top:0;bottom:0;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:15%;color:#fff;text-align:center;opacity:.5}.carousel-control-next:focus,.carousel-control-next:hover,.carousel-control-prev:focus,.carousel-control-prev:hover{color:#fff;text-decoration:none;outline:0;opacity:.9}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-next-icon,.carousel-control-prev-icon{display:inline-block;width:20px;height:20px;background:transparent no-repeat center center;background-size:100% 100%}.carousel-control-prev-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E")}.carousel-control-next-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E")}.carousel-indicators{position:absolute;right:0;bottom:10px;left:0;z-index:15;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;padding-left:0;margin-right:15%;margin-left:15%;list-style:none}.carousel-indicators li{position:relative;-webkit-box-flex:0;-ms-flex:0 1 auto;flex:0 1 auto;width:30px;height:3px;margin-right:3px;margin-left:3px;text-indent:-999px;background-color:rgba(255,255,255,.5)}.carousel-indicators li::before{position:absolute;top:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators li::after{position:absolute;bottom:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators .active{background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center}.align-baseline{vertical-align:baseline!important}.align-top{vertical-align:top!important}.align-middle{vertical-align:middle!important}.align-bottom{vertical-align:bottom!important}.align-text-bottom{vertical-align:text-bottom!important}.align-text-top{vertical-align:text-top!important}.bg-primary{background-color:#007bff!important}a.bg-primary:focus,a.bg-primary:hover,button.bg-primary:focus,button.bg-primary:hover{background-color:#0062cc!important}.bg-secondary{background-color:#6c757d!important}a.bg-secondary:focus,a.bg-secondary:hover,button.bg-secondary:focus,button.bg-secondary:hover{background-color:#545b62!important}.bg-success{background-color:#28a745!important}a.bg-success:focus,a.bg-success:hover,button.bg-success:focus,button.bg-success:hover{background-color:#1e7e34!important}.bg-info{background-color:#17a2b8!important}a.bg-info:focus,a.bg-info:hover,button.bg-info:focus,button.bg-info:hover{background-color:#117a8b!important}.bg-warning{background-color:#ffc107!important}a.bg-warning:focus,a.bg-warning:hover,button.bg-warning:focus,button.bg-warning:hover{background-color:#d39e00!important}.bg-danger{background-color:#dc3545!important}a.bg-danger:focus,a.bg-danger:hover,button.bg-danger:focus,button.bg-danger:hover{background-color:#bd2130!important}.bg-light{background-color:#f8f9fa!important}a.bg-light:focus,a.bg-light:hover,button.bg-light:focus,button.bg-light:hover{background-color:#dae0e5!important}.bg-dark{background-color:#343a40!important}a.bg-dark:focus,a.bg-dark:hover,button.bg-dark:focus,button.bg-dark:hover{background-color:#1d2124!important}.bg-white{background-color:#fff!important}.bg-transparent{background-color:transparent!important}.border{border:1px solid #dee2e6!important}.border-top{border-top:1px solid #dee2e6!important}.border-right{border-right:1px solid #dee2e6!important}.border-bottom{border-bottom:1px solid #dee2e6!important}.border-left{border-left:1px solid #dee2e6!important}.border-0{border:0!important}.border-top-0{border-top:0!important}.border-right-0{border-right:0!important}.border-bottom-0{border-bottom:0!important}.border-left-0{border-left:0!important}.border-primary{border-color:#007bff!important}.border-secondary{border-color:#6c757d!important}.border-success{border-color:#28a745!important}.border-info{border-color:#17a2b8!important}.border-warning{border-color:#ffc107!important}.border-danger{border-color:#dc3545!important}.border-light{border-color:#f8f9fa!important}.border-dark{border-color:#343a40!important}.border-white{border-color:#fff!important}.rounded{border-radius:.25rem!important}.rounded-top{border-top-left-radius:.25rem!important;border-top-right-radius:.25rem!important}.rounded-right{border-top-right-radius:.25rem!important;border-bottom-right-radius:.25rem!important}.rounded-bottom{border-bottom-right-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.rounded-left{border-top-left-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.rounded-circle{border-radius:50%!important}.rounded-0{border-radius:0!important}.clearfix::after{display:block;clear:both;content:""}.d-none{display:none!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-table{display:table!important}.d-table-row{display:table-row!important}.d-table-cell{display:table-cell!important}.d-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}@media (min-width:576px){.d-sm-none{display:none!important}.d-sm-inline{display:inline!important}.d-sm-inline-block{display:inline-block!important}.d-sm-block{display:block!important}.d-sm-table{display:table!important}.d-sm-table-row{display:table-row!important}.d-sm-table-cell{display:table-cell!important}.d-sm-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-sm-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:768px){.d-md-none{display:none!important}.d-md-inline{display:inline!important}.d-md-inline-block{display:inline-block!important}.d-md-block{display:block!important}.d-md-table{display:table!important}.d-md-table-row{display:table-row!important}.d-md-table-cell{display:table-cell!important}.d-md-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-md-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:992px){.d-lg-none{display:none!important}.d-lg-inline{display:inline!important}.d-lg-inline-block{display:inline-block!important}.d-lg-block{display:block!important}.d-lg-table{display:table!important}.d-lg-table-row{display:table-row!important}.d-lg-table-cell{display:table-cell!important}.d-lg-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-lg-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media (min-width:1200px){.d-xl-none{display:none!important}.d-xl-inline{display:inline!important}.d-xl-inline-block{display:inline-block!important}.d-xl-block{display:block!important}.d-xl-table{display:table!important}.d-xl-table-row{display:table-row!important}.d-xl-table-cell{display:table-cell!important}.d-xl-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-xl-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}@media print{.d-print-none{display:none!important}.d-print-inline{display:inline!important}.d-print-inline-block{display:inline-block!important}.d-print-block{display:block!important}.d-print-table{display:table!important}.d-print-table-row{display:table-row!important}.d-print-table-cell{display:table-cell!important}.d-print-flex{display:-webkit-box!important;display:-ms-flexbox!important;display:flex!important}.d-print-inline-flex{display:-webkit-inline-box!important;display:-ms-inline-flexbox!important;display:inline-flex!important}}.embed-responsive{position:relative;display:block;width:100%;padding:0;overflow:hidden}.embed-responsive::before{display:block;content:""}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-21by9::before{padding-top:42.857143%}.embed-responsive-16by9::before{padding-top:56.25%}.embed-responsive-4by3::before{padding-top:75%}.embed-responsive-1by1::before{padding-top:100%}.flex-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}@media (min-width:576px){.flex-sm-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-sm-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-sm-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-sm-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-sm-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-sm-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-sm-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-sm-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-sm-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-sm-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-sm-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-sm-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-sm-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-sm-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-sm-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-sm-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-sm-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-sm-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-sm-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-sm-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-sm-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-sm-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-sm-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-sm-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-sm-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-sm-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-sm-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-sm-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-sm-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:768px){.flex-md-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-md-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-md-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-md-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-md-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-md-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-md-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-md-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-md-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-md-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-md-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-md-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-md-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-md-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-md-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-md-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-md-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-md-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-md-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-md-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-md-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-md-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-md-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-md-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-md-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-md-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-md-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-md-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-md-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:992px){.flex-lg-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-lg-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-lg-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-lg-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-lg-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-lg-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-lg-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-lg-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-lg-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-lg-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-lg-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-lg-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-lg-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-lg-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-lg-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-lg-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-lg-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-lg-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-lg-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-lg-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-lg-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-lg-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-lg-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-lg-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-lg-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-lg-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-lg-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-lg-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-lg-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}@media (min-width:1200px){.flex-xl-row{-webkit-box-orient:horizontal!important;-webkit-box-direction:normal!important;-ms-flex-direction:row!important;flex-direction:row!important}.flex-xl-column{-webkit-box-orient:vertical!important;-webkit-box-direction:normal!important;-ms-flex-direction:column!important;flex-direction:column!important}.flex-xl-row-reverse{-webkit-box-orient:horizontal!important;-webkit-box-direction:reverse!important;-ms-flex-direction:row-reverse!important;flex-direction:row-reverse!important}.flex-xl-column-reverse{-webkit-box-orient:vertical!important;-webkit-box-direction:reverse!important;-ms-flex-direction:column-reverse!important;flex-direction:column-reverse!important}.flex-xl-wrap{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.flex-xl-nowrap{-ms-flex-wrap:nowrap!important;flex-wrap:nowrap!important}.flex-xl-wrap-reverse{-ms-flex-wrap:wrap-reverse!important;flex-wrap:wrap-reverse!important}.justify-content-xl-start{-webkit-box-pack:start!important;-ms-flex-pack:start!important;justify-content:flex-start!important}.justify-content-xl-end{-webkit-box-pack:end!important;-ms-flex-pack:end!important;justify-content:flex-end!important}.justify-content-xl-center{-webkit-box-pack:center!important;-ms-flex-pack:center!important;justify-content:center!important}.justify-content-xl-between{-webkit-box-pack:justify!important;-ms-flex-pack:justify!important;justify-content:space-between!important}.justify-content-xl-around{-ms-flex-pack:distribute!important;justify-content:space-around!important}.align-items-xl-start{-webkit-box-align:start!important;-ms-flex-align:start!important;align-items:flex-start!important}.align-items-xl-end{-webkit-box-align:end!important;-ms-flex-align:end!important;align-items:flex-end!important}.align-items-xl-center{-webkit-box-align:center!important;-ms-flex-align:center!important;align-items:center!important}.align-items-xl-baseline{-webkit-box-align:baseline!important;-ms-flex-align:baseline!important;align-items:baseline!important}.align-items-xl-stretch{-webkit-box-align:stretch!important;-ms-flex-align:stretch!important;align-items:stretch!important}.align-content-xl-start{-ms-flex-line-pack:start!important;align-content:flex-start!important}.align-content-xl-end{-ms-flex-line-pack:end!important;align-content:flex-end!important}.align-content-xl-center{-ms-flex-line-pack:center!important;align-content:center!important}.align-content-xl-between{-ms-flex-line-pack:justify!important;align-content:space-between!important}.align-content-xl-around{-ms-flex-line-pack:distribute!important;align-content:space-around!important}.align-content-xl-stretch{-ms-flex-line-pack:stretch!important;align-content:stretch!important}.align-self-xl-auto{-ms-flex-item-align:auto!important;align-self:auto!important}.align-self-xl-start{-ms-flex-item-align:start!important;align-self:flex-start!important}.align-self-xl-end{-ms-flex-item-align:end!important;align-self:flex-end!important}.align-self-xl-center{-ms-flex-item-align:center!important;align-self:center!important}.align-self-xl-baseline{-ms-flex-item-align:baseline!important;align-self:baseline!important}.align-self-xl-stretch{-ms-flex-item-align:stretch!important;align-self:stretch!important}}.float-left{float:left!important}.float-right{float:right!important}.float-none{float:none!important}@media (min-width:576px){.float-sm-left{float:left!important}.float-sm-right{float:right!important}.float-sm-none{float:none!important}}@media (min-width:768px){.float-md-left{float:left!important}.float-md-right{float:right!important}.float-md-none{float:none!important}}@media (min-width:992px){.float-lg-left{float:left!important}.float-lg-right{float:right!important}.float-lg-none{float:none!important}}@media (min-width:1200px){.float-xl-left{float:left!important}.float-xl-right{float:right!important}.float-xl-none{float:none!important}}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-sticky{position:-webkit-sticky!important;position:sticky!important}.fixed-top{position:fixed;top:0;right:0;left:0;z-index:1030}.fixed-bottom{position:fixed;right:0;bottom:0;left:0;z-index:1030}@supports ((position:-webkit-sticky) or (position:sticky)){.sticky-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal;-webkit-clip-path:none;clip-path:none}.w-25{width:25%!important}.w-50{width:50%!important}.w-75{width:75%!important}.w-100{width:100%!important}.h-25{height:25%!important}.h-50{height:50%!important}.h-75{height:75%!important}.h-100{height:100%!important}.mw-100{max-width:100%!important}.mh-100{max-height:100%!important}.m-0{margin:0!important}.mt-0,.my-0{margin-top:0!important}.mr-0,.mx-0{margin-right:0!important}.mb-0,.my-0{margin-bottom:0!important}.ml-0,.mx-0{margin-left:0!important}.m-1{margin:.25rem!important}.mt-1,.my-1{margin-top:.25rem!important}.mr-1,.mx-1{margin-right:.25rem!important}.mb-1,.my-1{margin-bottom:.25rem!important}.ml-1,.mx-1{margin-left:.25rem!important}.m-2{margin:.5rem!important}.mt-2,.my-2{margin-top:.5rem!important}.mr-2,.mx-2{margin-right:.5rem!important}.mb-2,.my-2{margin-bottom:.5rem!important}.ml-2,.mx-2{margin-left:.5rem!important}.m-3{margin:1rem!important}.mt-3,.my-3{margin-top:1rem!important}.mr-3,.mx-3{margin-right:1rem!important}.mb-3,.my-3{margin-bottom:1rem!important}.ml-3,.mx-3{margin-left:1rem!important}.m-4{margin:1.5rem!important}.mt-4,.my-4{margin-top:1.5rem!important}.mr-4,.mx-4{margin-right:1.5rem!important}.mb-4,.my-4{margin-bottom:1.5rem!important}.ml-4,.mx-4{margin-left:1.5rem!important}.m-5{margin:3rem!important}.mt-5,.my-5{margin-top:3rem!important}.mr-5,.mx-5{margin-right:3rem!important}.mb-5,.my-5{margin-bottom:3rem!important}.ml-5,.mx-5{margin-left:3rem!important}.p-0{padding:0!important}.pt-0,.py-0{padding-top:0!important}.pr-0,.px-0{padding-right:0!important}.pb-0,.py-0{padding-bottom:0!important}.pl-0,.px-0{padding-left:0!important}.p-1{padding:.25rem!important}.pt-1,.py-1{padding-top:.25rem!important}.pr-1,.px-1{padding-right:.25rem!important}.pb-1,.py-1{padding-bottom:.25rem!important}.pl-1,.px-1{padding-left:.25rem!important}.p-2{padding:.5rem!important}.pt-2,.py-2{padding-top:.5rem!important}.pr-2,.px-2{padding-right:.5rem!important}.pb-2,.py-2{padding-bottom:.5rem!important}.pl-2,.px-2{padding-left:.5rem!important}.p-3{padding:1rem!important}.pt-3,.py-3{padding-top:1rem!important}.pr-3,.px-3{padding-right:1rem!important}.pb-3,.py-3{padding-bottom:1rem!important}.pl-3,.px-3{padding-left:1rem!important}.p-4{padding:1.5rem!important}.pt-4,.py-4{padding-top:1.5rem!important}.pr-4,.px-4{padding-right:1.5rem!important}.pb-4,.py-4{padding-bottom:1.5rem!important}.pl-4,.px-4{padding-left:1.5rem!important}.p-5{padding:3rem!important}.pt-5,.py-5{padding-top:3rem!important}.pr-5,.px-5{padding-right:3rem!important}.pb-5,.py-5{padding-bottom:3rem!important}.pl-5,.px-5{padding-left:3rem!important}.m-auto{margin:auto!important}.mt-auto,.my-auto{margin-top:auto!important}.mr-auto,.mx-auto{margin-right:auto!important}.mb-auto,.my-auto{margin-bottom:auto!important}.ml-auto,.mx-auto{margin-left:auto!important}@media (min-width:576px){.m-sm-0{margin:0!important}.mt-sm-0,.my-sm-0{margin-top:0!important}.mr-sm-0,.mx-sm-0{margin-right:0!important}.mb-sm-0,.my-sm-0{margin-bottom:0!important}.ml-sm-0,.mx-sm-0{margin-left:0!important}.m-sm-1{margin:.25rem!important}.mt-sm-1,.my-sm-1{margin-top:.25rem!important}.mr-sm-1,.mx-sm-1{margin-right:.25rem!important}.mb-sm-1,.my-sm-1{margin-bottom:.25rem!important}.ml-sm-1,.mx-sm-1{margin-left:.25rem!important}.m-sm-2{margin:.5rem!important}.mt-sm-2,.my-sm-2{margin-top:.5rem!important}.mr-sm-2,.mx-sm-2{margin-right:.5rem!important}.mb-sm-2,.my-sm-2{margin-bottom:.5rem!important}.ml-sm-2,.mx-sm-2{margin-left:.5rem!important}.m-sm-3{margin:1rem!important}.mt-sm-3,.my-sm-3{margin-top:1rem!important}.mr-sm-3,.mx-sm-3{margin-right:1rem!important}.mb-sm-3,.my-sm-3{margin-bottom:1rem!important}.ml-sm-3,.mx-sm-3{margin-left:1rem!important}.m-sm-4{margin:1.5rem!important}.mt-sm-4,.my-sm-4{margin-top:1.5rem!important}.mr-sm-4,.mx-sm-4{margin-right:1.5rem!important}.mb-sm-4,.my-sm-4{margin-bottom:1.5rem!important}.ml-sm-4,.mx-sm-4{margin-left:1.5rem!important}.m-sm-5{margin:3rem!important}.mt-sm-5,.my-sm-5{margin-top:3rem!important}.mr-sm-5,.mx-sm-5{margin-right:3rem!important}.mb-sm-5,.my-sm-5{margin-bottom:3rem!important}.ml-sm-5,.mx-sm-5{margin-left:3rem!important}.p-sm-0{padding:0!important}.pt-sm-0,.py-sm-0{padding-top:0!important}.pr-sm-0,.px-sm-0{padding-right:0!important}.pb-sm-0,.py-sm-0{padding-bottom:0!important}.pl-sm-0,.px-sm-0{padding-left:0!important}.p-sm-1{padding:.25rem!important}.pt-sm-1,.py-sm-1{padding-top:.25rem!important}.pr-sm-1,.px-sm-1{padding-right:.25rem!important}.pb-sm-1,.py-sm-1{padding-bottom:.25rem!important}.pl-sm-1,.px-sm-1{padding-left:.25rem!important}.p-sm-2{padding:.5rem!important}.pt-sm-2,.py-sm-2{padding-top:.5rem!important}.pr-sm-2,.px-sm-2{padding-right:.5rem!important}.pb-sm-2,.py-sm-2{padding-bottom:.5rem!important}.pl-sm-2,.px-sm-2{padding-left:.5rem!important}.p-sm-3{padding:1rem!important}.pt-sm-3,.py-sm-3{padding-top:1rem!important}.pr-sm-3,.px-sm-3{padding-right:1rem!important}.pb-sm-3,.py-sm-3{padding-bottom:1rem!important}.pl-sm-3,.px-sm-3{padding-left:1rem!important}.p-sm-4{padding:1.5rem!important}.pt-sm-4,.py-sm-4{padding-top:1.5rem!important}.pr-sm-4,.px-sm-4{padding-right:1.5rem!important}.pb-sm-4,.py-sm-4{padding-bottom:1.5rem!important}.pl-sm-4,.px-sm-4{padding-left:1.5rem!important}.p-sm-5{padding:3rem!important}.pt-sm-5,.py-sm-5{padding-top:3rem!important}.pr-sm-5,.px-sm-5{padding-right:3rem!important}.pb-sm-5,.py-sm-5{padding-bottom:3rem!important}.pl-sm-5,.px-sm-5{padding-left:3rem!important}.m-sm-auto{margin:auto!important}.mt-sm-auto,.my-sm-auto{margin-top:auto!important}.mr-sm-auto,.mx-sm-auto{margin-right:auto!important}.mb-sm-auto,.my-sm-auto{margin-bottom:auto!important}.ml-sm-auto,.mx-sm-auto{margin-left:auto!important}}@media (min-width:768px){.m-md-0{margin:0!important}.mt-md-0,.my-md-0{margin-top:0!important}.mr-md-0,.mx-md-0{margin-right:0!important}.mb-md-0,.my-md-0{margin-bottom:0!important}.ml-md-0,.mx-md-0{margin-left:0!important}.m-md-1{margin:.25rem!important}.mt-md-1,.my-md-1{margin-top:.25rem!important}.mr-md-1,.mx-md-1{margin-right:.25rem!important}.mb-md-1,.my-md-1{margin-bottom:.25rem!important}.ml-md-1,.mx-md-1{margin-left:.25rem!important}.m-md-2{margin:.5rem!important}.mt-md-2,.my-md-2{margin-top:.5rem!important}.mr-md-2,.mx-md-2{margin-right:.5rem!important}.mb-md-2,.my-md-2{margin-bottom:.5rem!important}.ml-md-2,.mx-md-2{margin-left:.5rem!important}.m-md-3{margin:1rem!important}.mt-md-3,.my-md-3{margin-top:1rem!important}.mr-md-3,.mx-md-3{margin-right:1rem!important}.mb-md-3,.my-md-3{margin-bottom:1rem!important}.ml-md-3,.mx-md-3{margin-left:1rem!important}.m-md-4{margin:1.5rem!important}.mt-md-4,.my-md-4{margin-top:1.5rem!important}.mr-md-4,.mx-md-4{margin-right:1.5rem!important}.mb-md-4,.my-md-4{margin-bottom:1.5rem!important}.ml-md-4,.mx-md-4{margin-left:1.5rem!important}.m-md-5{margin:3rem!important}.mt-md-5,.my-md-5{margin-top:3rem!important}.mr-md-5,.mx-md-5{margin-right:3rem!important}.mb-md-5,.my-md-5{margin-bottom:3rem!important}.ml-md-5,.mx-md-5{margin-left:3rem!important}.p-md-0{padding:0!important}.pt-md-0,.py-md-0{padding-top:0!important}.pr-md-0,.px-md-0{padding-right:0!important}.pb-md-0,.py-md-0{padding-bottom:0!important}.pl-md-0,.px-md-0{padding-left:0!important}.p-md-1{padding:.25rem!important}.pt-md-1,.py-md-1{padding-top:.25rem!important}.pr-md-1,.px-md-1{padding-right:.25rem!important}.pb-md-1,.py-md-1{padding-bottom:.25rem!important}.pl-md-1,.px-md-1{padding-left:.25rem!important}.p-md-2{padding:.5rem!important}.pt-md-2,.py-md-2{padding-top:.5rem!important}.pr-md-2,.px-md-2{padding-right:.5rem!important}.pb-md-2,.py-md-2{padding-bottom:.5rem!important}.pl-md-2,.px-md-2{padding-left:.5rem!important}.p-md-3{padding:1rem!important}.pt-md-3,.py-md-3{padding-top:1rem!important}.pr-md-3,.px-md-3{padding-right:1rem!important}.pb-md-3,.py-md-3{padding-bottom:1rem!important}.pl-md-3,.px-md-3{padding-left:1rem!important}.p-md-4{padding:1.5rem!important}.pt-md-4,.py-md-4{padding-top:1.5rem!important}.pr-md-4,.px-md-4{padding-right:1.5rem!important}.pb-md-4,.py-md-4{padding-bottom:1.5rem!important}.pl-md-4,.px-md-4{padding-left:1.5rem!important}.p-md-5{padding:3rem!important}.pt-md-5,.py-md-5{padding-top:3rem!important}.pr-md-5,.px-md-5{padding-right:3rem!important}.pb-md-5,.py-md-5{padding-bottom:3rem!important}.pl-md-5,.px-md-5{padding-left:3rem!important}.m-md-auto{margin:auto!important}.mt-md-auto,.my-md-auto{margin-top:auto!important}.mr-md-auto,.mx-md-auto{margin-right:auto!important}.mb-md-auto,.my-md-auto{margin-bottom:auto!important}.ml-md-auto,.mx-md-auto{margin-left:auto!important}}@media (min-width:992px){.m-lg-0{margin:0!important}.mt-lg-0,.my-lg-0{margin-top:0!important}.mr-lg-0,.mx-lg-0{margin-right:0!important}.mb-lg-0,.my-lg-0{margin-bottom:0!important}.ml-lg-0,.mx-lg-0{margin-left:0!important}.m-lg-1{margin:.25rem!important}.mt-lg-1,.my-lg-1{margin-top:.25rem!important}.mr-lg-1,.mx-lg-1{margin-right:.25rem!important}.mb-lg-1,.my-lg-1{margin-bottom:.25rem!important}.ml-lg-1,.mx-lg-1{margin-left:.25rem!important}.m-lg-2{margin:.5rem!important}.mt-lg-2,.my-lg-2{margin-top:.5rem!important}.mr-lg-2,.mx-lg-2{margin-right:.5rem!important}.mb-lg-2,.my-lg-2{margin-bottom:.5rem!important}.ml-lg-2,.mx-lg-2{margin-left:.5rem!important}.m-lg-3{margin:1rem!important}.mt-lg-3,.my-lg-3{margin-top:1rem!important}.mr-lg-3,.mx-lg-3{margin-right:1rem!important}.mb-lg-3,.my-lg-3{margin-bottom:1rem!important}.ml-lg-3,.mx-lg-3{margin-left:1rem!important}.m-lg-4{margin:1.5rem!important}.mt-lg-4,.my-lg-4{margin-top:1.5rem!important}.mr-lg-4,.mx-lg-4{margin-right:1.5rem!important}.mb-lg-4,.my-lg-4{margin-bottom:1.5rem!important}.ml-lg-4,.mx-lg-4{margin-left:1.5rem!important}.m-lg-5{margin:3rem!important}.mt-lg-5,.my-lg-5{margin-top:3rem!important}.mr-lg-5,.mx-lg-5{margin-right:3rem!important}.mb-lg-5,.my-lg-5{margin-bottom:3rem!important}.ml-lg-5,.mx-lg-5{margin-left:3rem!important}.p-lg-0{padding:0!important}.pt-lg-0,.py-lg-0{padding-top:0!important}.pr-lg-0,.px-lg-0{padding-right:0!important}.pb-lg-0,.py-lg-0{padding-bottom:0!important}.pl-lg-0,.px-lg-0{padding-left:0!important}.p-lg-1{padding:.25rem!important}.pt-lg-1,.py-lg-1{padding-top:.25rem!important}.pr-lg-1,.px-lg-1{padding-right:.25rem!important}.pb-lg-1,.py-lg-1{padding-bottom:.25rem!important}.pl-lg-1,.px-lg-1{padding-left:.25rem!important}.p-lg-2{padding:.5rem!important}.pt-lg-2,.py-lg-2{padding-top:.5rem!important}.pr-lg-2,.px-lg-2{padding-right:.5rem!important}.pb-lg-2,.py-lg-2{padding-bottom:.5rem!important}.pl-lg-2,.px-lg-2{padding-left:.5rem!important}.p-lg-3{padding:1rem!important}.pt-lg-3,.py-lg-3{padding-top:1rem!important}.pr-lg-3,.px-lg-3{padding-right:1rem!important}.pb-lg-3,.py-lg-3{padding-bottom:1rem!important}.pl-lg-3,.px-lg-3{padding-left:1rem!important}.p-lg-4{padding:1.5rem!important}.pt-lg-4,.py-lg-4{padding-top:1.5rem!important}.pr-lg-4,.px-lg-4{padding-right:1.5rem!important}.pb-lg-4,.py-lg-4{padding-bottom:1.5rem!important}.pl-lg-4,.px-lg-4{padding-left:1.5rem!important}.p-lg-5{padding:3rem!important}.pt-lg-5,.py-lg-5{padding-top:3rem!important}.pr-lg-5,.px-lg-5{padding-right:3rem!important}.pb-lg-5,.py-lg-5{padding-bottom:3rem!important}.pl-lg-5,.px-lg-5{padding-left:3rem!important}.m-lg-auto{margin:auto!important}.mt-lg-auto,.my-lg-auto{margin-top:auto!important}.mr-lg-auto,.mx-lg-auto{margin-right:auto!important}.mb-lg-auto,.my-lg-auto{margin-bottom:auto!important}.ml-lg-auto,.mx-lg-auto{margin-left:auto!important}}@media (min-width:1200px){.m-xl-0{margin:0!important}.mt-xl-0,.my-xl-0{margin-top:0!important}.mr-xl-0,.mx-xl-0{margin-right:0!important}.mb-xl-0,.my-xl-0{margin-bottom:0!important}.ml-xl-0,.mx-xl-0{margin-left:0!important}.m-xl-1{margin:.25rem!important}.mt-xl-1,.my-xl-1{margin-top:.25rem!important}.mr-xl-1,.mx-xl-1{margin-right:.25rem!important}.mb-xl-1,.my-xl-1{margin-bottom:.25rem!important}.ml-xl-1,.mx-xl-1{margin-left:.25rem!important}.m-xl-2{margin:.5rem!important}.mt-xl-2,.my-xl-2{margin-top:.5rem!important}.mr-xl-2,.mx-xl-2{margin-right:.5rem!important}.mb-xl-2,.my-xl-2{margin-bottom:.5rem!important}.ml-xl-2,.mx-xl-2{margin-left:.5rem!important}.m-xl-3{margin:1rem!important}.mt-xl-3,.my-xl-3{margin-top:1rem!important}.mr-xl-3,.mx-xl-3{margin-right:1rem!important}.mb-xl-3,.my-xl-3{margin-bottom:1rem!important}.ml-xl-3,.mx-xl-3{margin-left:1rem!important}.m-xl-4{margin:1.5rem!important}.mt-xl-4,.my-xl-4{margin-top:1.5rem!important}.mr-xl-4,.mx-xl-4{margin-right:1.5rem!important}.mb-xl-4,.my-xl-4{margin-bottom:1.5rem!important}.ml-xl-4,.mx-xl-4{margin-left:1.5rem!important}.m-xl-5{margin:3rem!important}.mt-xl-5,.my-xl-5{margin-top:3rem!important}.mr-xl-5,.mx-xl-5{margin-right:3rem!important}.mb-xl-5,.my-xl-5{margin-bottom:3rem!important}.ml-xl-5,.mx-xl-5{margin-left:3rem!important}.p-xl-0{padding:0!important}.pt-xl-0,.py-xl-0{padding-top:0!important}.pr-xl-0,.px-xl-0{padding-right:0!important}.pb-xl-0,.py-xl-0{padding-bottom:0!important}.pl-xl-0,.px-xl-0{padding-left:0!important}.p-xl-1{padding:.25rem!important}.pt-xl-1,.py-xl-1{padding-top:.25rem!important}.pr-xl-1,.px-xl-1{padding-right:.25rem!important}.pb-xl-1,.py-xl-1{padding-bottom:.25rem!important}.pl-xl-1,.px-xl-1{padding-left:.25rem!important}.p-xl-2{padding:.5rem!important}.pt-xl-2,.py-xl-2{padding-top:.5rem!important}.pr-xl-2,.px-xl-2{padding-right:.5rem!important}.pb-xl-2,.py-xl-2{padding-bottom:.5rem!important}.pl-xl-2,.px-xl-2{padding-left:.5rem!important}.p-xl-3{padding:1rem!important}.pt-xl-3,.py-xl-3{padding-top:1rem!important}.pr-xl-3,.px-xl-3{padding-right:1rem!important}.pb-xl-3,.py-xl-3{padding-bottom:1rem!important}.pl-xl-3,.px-xl-3{padding-left:1rem!important}.p-xl-4{padding:1.5rem!important}.pt-xl-4,.py-xl-4{padding-top:1.5rem!important}.pr-xl-4,.px-xl-4{padding-right:1.5rem!important}.pb-xl-4,.py-xl-4{padding-bottom:1.5rem!important}.pl-xl-4,.px-xl-4{padding-left:1.5rem!important}.p-xl-5{padding:3rem!important}.pt-xl-5,.py-xl-5{padding-top:3rem!important}.pr-xl-5,.px-xl-5{padding-right:3rem!important}.pb-xl-5,.py-xl-5{padding-bottom:3rem!important}.pl-xl-5,.px-xl-5{padding-left:3rem!important}.m-xl-auto{margin:auto!important}.mt-xl-auto,.my-xl-auto{margin-top:auto!important}.mr-xl-auto,.mx-xl-auto{margin-right:auto!important}.mb-xl-auto,.my-xl-auto{margin-bottom:auto!important}.ml-xl-auto,.mx-xl-auto{margin-left:auto!important}}.text-justify{text-align:justify!important}.text-nowrap{white-space:nowrap!important}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-left{text-align:left!important}.text-right{text-align:right!important}.text-center{text-align:center!important}@media (min-width:576px){.text-sm-left{text-align:left!important}.text-sm-right{text-align:right!important}.text-sm-center{text-align:center!important}}@media (min-width:768px){.text-md-left{text-align:left!important}.text-md-right{text-align:right!important}.text-md-center{text-align:center!important}}@media (min-width:992px){.text-lg-left{text-align:left!important}.text-lg-right{text-align:right!important}.text-lg-center{text-align:center!important}}@media (min-width:1200px){.text-xl-left{text-align:left!important}.text-xl-right{text-align:right!important}.text-xl-center{text-align:center!important}}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.font-weight-light{font-weight:300!important}.font-weight-normal{font-weight:400!important}.font-weight-bold{font-weight:700!important}.font-italic{font-style:italic!important}.text-white{color:#fff!important}.text-primary{color:#007bff!important}a.text-primary:focus,a.text-primary:hover{color:#0062cc!important}.text-secondary{color:#6c757d!important}a.text-secondary:focus,a.text-secondary:hover{color:#545b62!important}.text-success{color:#28a745!important}a.text-success:focus,a.text-success:hover{color:#1e7e34!important}.text-info{color:#17a2b8!important}a.text-info:focus,a.text-info:hover{color:#117a8b!important}.text-warning{color:#ffc107!important}a.text-warning:focus,a.text-warning:hover{color:#d39e00!important}.text-danger{color:#dc3545!important}a.text-danger:focus,a.text-danger:hover{color:#bd2130!important}.text-light{color:#f8f9fa!important}a.text-light:focus,a.text-light:hover{color:#dae0e5!important}.text-dark{color:#343a40!important}a.text-dark:focus,a.text-dark:hover{color:#1d2124!important}.text-muted{color:#6c757d!important}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.visible{visibility:visible!important}.invisible{visibility:hidden!important}@media print{*,::after,::before{text-shadow:none!important;box-shadow:none!important}a:not(.btn){text-decoration:underline}abbr[title]::after{content:" (" attr(title) ")"}pre{white-space:pre-wrap!important}blockquote,pre{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}@page{size:a3}body{min-width:992px!important}.container{min-width:992px!important}.navbar{display:none}.badge{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #ddd!important}}
| |
− | /*# sourceMappingURL=bootstrap.min.css.map */
| |
− | </style>
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | <style type="text/css">
| |
− | @import url(font_awesome.min.css);
| |
− | @font-face {
| |
− | font-family: 'florante_at_lauraitalic';
| |
− | src: url('FLORLI__-webfont.eot');
| |
− | src: url('FLORLI__-webfont.eot?#iefix') format('embedded-opentype'),
| |
− | url('FLORLI__-webfont.woff2') format('woff2'),
| |
− | url('FLORLI__-webfont.woff') format('woff'),
| |
− | url('FLORLI__-webfont.ttf') format('truetype'),
| |
− | url('FLORLI__-webfont.svg#florante_at_lauraitalic') format('svg');
| |
− | font-weight: normal;
| |
− | font-style: normal;
| |
− |
| |
− | }
| |
− | /* @font-face kit by Fonts2u (http://www.fonts2u.com) */
| |
− | @font-face {font-family:"Merriweather Black";src:url("Merriweather-Black.eot?") format("eot"),url("Merriweather-Black.woff") format("woff"),url("Merriweather-Black.ttf") format("truetype"),url("Merriweather-Black.svg#Merriweather-Black") format("svg");font-weight:normal;font-style:normal;}
| |
− |
| |
− | .navbar .navbar-brand {
| |
− | font-family: 'Merriweather Black',arial,sans-serif;
| |
− | color:white;
| |
− | }
| |
− |
| |
− | .vert{
| |
− | height: 100px;
| |
− | background-color:#4e4e4e;
| |
− | }
| |
− | #logo{
| |
− | width: 88px;
| |
− | height: 90px;
| |
− | }
| |
− |
| |
− | body{
| |
− | background-color: white;
| |
− | }
| |
− | #FSDIE{
| |
− | height: 80px;
| |
− | width: 80px;
| |
− | margin-top:10px;
| |
− | }
| |
− |
| |
− | #SU{
| |
− | height: 80px;
| |
− | width:200px;
| |
− | margin-top:10px;
| |
− | margin-left: 20px;
| |
− | }
| |
− |
| |
− | #crous{
| |
− | height: 80px;
| |
− | width: 80px;
| |
− | margin-top:10px;
| |
− | margin-left: 20px;
| |
− | }
| |
− |
| |
− | #bmc{
| |
− | height: 80px;
| |
− | width:250px;
| |
− | margin-top:10px;
| |
− | margin-left: 20px;
| |
− |
| |
− | }
| |
− |
| |
− | /* Page Team Members */
| |
− |
| |
− |
| |
− | #team {
| |
− | background: white !important;
| |
− | }
| |
− |
| |
− | .btn-primary:hover,
| |
− | .btn-primary:focus {
| |
− | background-color: #108d6f;
| |
− | border-color: #108d6f;
| |
− | box-shadow: none;
| |
− | outline: none;
| |
− | }
| |
− |
| |
− | .btn-primary {
| |
− | color: #fff;
| |
− | background-color: #007b5e;
| |
− | border-color: #007b5e;
| |
− | }
| |
− |
| |
− | section {
| |
− | padding: 60px 0;
| |
− | }
| |
− |
| |
− | section .section-title {
| |
− | text-align: center;
| |
− | color: #4e4e4e;
| |
− | margin-bottom: 50px;
| |
− | text-transform: uppercase;
| |
− | }
| |
− |
| |
− | #team .card {
| |
− | border: none;
| |
− | background: #ffffff;
| |
− | }
| |
− |
| |
− | .image-flip:hover .backside,
| |
− | .image-flip.hover .backside {
| |
− | -webkit-transform: rotateY(0deg);
| |
− | -moz-transform: rotateY(0deg);
| |
− | -o-transform: rotateY(0deg);
| |
− | -ms-transform: rotateY(0deg);
| |
− | transform: rotateY(0deg);
| |
− | border-radius: .25rem;
| |
− | }
| |
− |
| |
− | .image-flip:hover .frontside,
| |
− | .image-flip.hover .frontside {
| |
− | -webkit-transform: rotateY(180deg);
| |
− | -moz-transform: rotateY(180deg);
| |
− | -o-transform: rotateY(180deg);
| |
− | transform: rotateY(180deg);
| |
− | }
| |
− |
| |
− | .mainflip {
| |
− | -webkit-transition: 1s;
| |
− | -webkit-transform-style: preserve-3d;
| |
− | -ms-transition: 1s;
| |
− | -moz-transition: 1s;
| |
− | -moz-transform: perspective(1000px);
| |
− | -moz-transform-style: preserve-3d;
| |
− | -ms-transform-style: preserve-3d;
| |
− | transition: 1s;
| |
− | transform-style: preserve-3d;
| |
− | position: relative;
| |
− | }
| |
− |
| |
− | .frontside {
| |
− | position: relative;
| |
− | -webkit-transform: rotateY(0deg);
| |
− | -ms-transform: rotateY(0deg);
| |
− | z-index: 2;
| |
− | margin-bottom: 30px;
| |
− | }
| |
− |
| |
− | .backside {
| |
− | position: absolute;
| |
− | top: 0;
| |
− | left: 0;
| |
− | background: white;
| |
− | -webkit-transform: rotateY(-180deg);
| |
− | -moz-transform: rotateY(-180deg);
| |
− | -o-transform: rotateY(-180deg);
| |
− | -ms-transform: rotateY(-180deg);
| |
− | transform: rotateY(-180deg);
| |
− | -webkit-box-shadow: 5px 7px 9px -4px rgb(158, 158, 158);
| |
− | -moz-box-shadow: 5px 7px 9px -4px rgb(158, 158, 158);
| |
− | box-shadow: 5px 7px 9px -4px rgb(158, 158, 158);
| |
− | }
| |
− |
| |
− | .frontside,
| |
− | .backside {
| |
− | -webkit-backface-visibility: hidden;
| |
− | -moz-backface-visibility: hidden;
| |
− | -ms-backface-visibility: hidden;
| |
− | backface-visibility: hidden;
| |
− | -webkit-transition: 1s;
| |
− | -webkit-transform-style: preserve-3d;
| |
− | -moz-transition: 1s;
| |
− | -moz-transform-style: preserve-3d;
| |
− | -o-transition: 1s;
| |
− | -o-transform-style: preserve-3d;
| |
− | -ms-transition: 1s;
| |
− | -ms-transform-style: preserve-3d;
| |
− | transition: 1s;
| |
− | transform-style: preserve-3d;
| |
− | }
| |
− |
| |
− | .frontside .card,
| |
− | .backside .card {
| |
− | min-height: 312px;
| |
− | }
| |
− |
| |
− | .backside .card a {
| |
− | font-size: 18px;
| |
− | color: #007b5e !important;
| |
− | }
| |
− |
| |
− | .frontside .card .card-title,
| |
− | .backside .card .card-title {
| |
− | color: #007b5e !important;
| |
− | }
| |
− |
| |
− | .frontside .card .card-body img {
| |
− | width: 120px;
| |
− | height: 120px;
| |
− | border-radius: 50%;
| |
− | }
| |
− | </style>
| |
− |
| |
− |
| |
− | <body>
| |
− | <!-- JS -->
| |
− | <script type="text/javascript" >
| |
− | /*!
| |
− | * jQuery JavaScript Library v3.3.1
| |
− | * https://jquery.com/
| |
− | *
| |
− | * Includes Sizzle.js
| |
− | * https://sizzlejs.com/
| |
− | *
| |
− | * Copyright JS Foundation and other contributors
| |
− | * Released under the MIT license
| |
− | * https://jquery.org/license
| |
− | *
| |
− | * Date: 2018-01-20T17:24Z
| |
− | */
| |
− | ( function( global, factory ) {
| |
− |
| |
− | "use strict";
| |
− |
| |
− | if ( typeof module === "object" && typeof module.exports === "object" ) {
| |
− |
| |
− | // For CommonJS and CommonJS-like environments where a proper `window`
| |
− | // is present, execute the factory and get jQuery.
| |
− | // For environments that do not have a `window` with a `document`
| |
− | // (such as Node.js), expose a factory as module.exports.
| |
− | // This accentuates the need for the creation of a real `window`.
| |
− | // e.g. var jQuery = require("jquery")(window);
| |
− | // See ticket #14549 for more info.
| |
− | module.exports = global.document ?
| |
− | factory( global, true ) :
| |
− | function( w ) {
| |
− | if ( !w.document ) {
| |
− | throw new Error( "jQuery requires a window with a document" );
| |
− | }
| |
− | return factory( w );
| |
− | };
| |
− | } else {
| |
− | factory( global );
| |
− | }
| |
− |
| |
− | // Pass this if window is not defined yet
| |
− | } )( typeof window !== "undefined" ? window : this, function( window, noGlobal ) {
| |
− |
| |
− | // Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1
| |
− | // throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode
| |
− | // arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common
| |
− | // enough that all such attempts are guarded in a try block.
| |
− | "use strict";
| |
− |
| |
− | var arr = [];
| |
− |
| |
− | var document = window.document;
| |
− |
| |
− | var getProto = Object.getPrototypeOf;
| |
− |
| |
− | var slice = arr.slice;
| |
− |
| |
− | var concat = arr.concat;
| |
− |
| |
− | var push = arr.push;
| |
− |
| |
− | var indexOf = arr.indexOf;
| |
− |
| |
− | var class2type = {};
| |
− |
| |
− | var toString = class2type.toString;
| |
− |
| |
− | var hasOwn = class2type.hasOwnProperty;
| |
− |
| |
− | var fnToString = hasOwn.toString;
| |
− |
| |
− | var ObjectFunctionString = fnToString.call( Object );
| |
− |
| |
− | var support = {};
| |
− |
| |
− | var isFunction = function isFunction( obj ) {
| |
− |
| |
− | // Support: Chrome <=57, Firefox <=52
| |
− | // In some browsers, typeof returns "function" for HTML <object> elements
| |
− | // (i.e., `typeof document.createElement( "object" ) === "function"`).
| |
− | // We don't want to classify *any* DOM node as a function.
| |
− | return typeof obj === "function" && typeof obj.nodeType !== "number";
| |
− | };
| |
− |
| |
− |
| |
− | var isWindow = function isWindow( obj ) {
| |
− | return obj != null && obj === obj.window;
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | var preservedScriptAttributes = {
| |
− | type: true,
| |
− | src: true,
| |
− | noModule: true
| |
− | };
| |
− |
| |
− | function DOMEval( code, doc, node ) {
| |
− | doc = doc || document;
| |
− |
| |
− | var i,
| |
− | script = doc.createElement( "script" );
| |
− |
| |
− | script.text = code;
| |
− | if ( node ) {
| |
− | for ( i in preservedScriptAttributes ) {
| |
− | if ( node[ i ] ) {
| |
− | script[ i ] = node[ i ];
| |
− | }
| |
− | }
| |
− | }
| |
− | doc.head.appendChild( script ).parentNode.removeChild( script );
| |
− | }
| |
− |
| |
− |
| |
− | function toType( obj ) {
| |
− | if ( obj == null ) {
| |
− | return obj + "";
| |
− | }
| |
− |
| |
− | // Support: Android <=2.3 only (functionish RegExp)
| |
− | return typeof obj === "object" || typeof obj === "function" ?
| |
− | class2type[ toString.call( obj ) ] || "object" :
| |
− | typeof obj;
| |
− | }
| |
− | /* global Symbol */
| |
− | // Defining this global in .eslintrc.json would create a danger of using the global
| |
− | // unguarded in another place, it seems safer to define global only for this module
| |
− |
| |
− |
| |
− |
| |
− | var
| |
− | version = "3.3.1",
| |
− |
| |
− | // Define a local copy of jQuery
| |
− | jQuery = function( selector, context ) {
| |
− |
| |
− | // The jQuery object is actually just the init constructor 'enhanced'
| |
− | // Need init if jQuery is called (just allow error to be thrown if not included)
| |
− | return new jQuery.fn.init( selector, context );
| |
− | },
| |
− |
| |
− | // Support: Android <=4.0 only
| |
− | // Make sure we trim BOM and NBSP
| |
− | rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;
| |
− |
| |
− | jQuery.fn = jQuery.prototype = {
| |
− |
| |
− | // The current version of jQuery being used
| |
− | jquery: version,
| |
− |
| |
− | constructor: jQuery,
| |
− |
| |
− | // The default length of a jQuery object is 0
| |
− | length: 0,
| |
− |
| |
− | toArray: function() {
| |
− | return slice.call( this );
| |
− | },
| |
− |
| |
− | // Get the Nth element in the matched element set OR
| |
− | // Get the whole matched element set as a clean array
| |
− | get: function( num ) {
| |
− |
| |
− | // Return all the elements in a clean array
| |
− | if ( num == null ) {
| |
− | return slice.call( this );
| |
− | }
| |
− |
| |
− | // Return just the one element from the set
| |
− | return num < 0 ? this[ num + this.length ] : this[ num ];
| |
− | },
| |
− |
| |
− | // Take an array of elements and push it onto the stack
| |
− | // (returning the new matched element set)
| |
− | pushStack: function( elems ) {
| |
− |
| |
− | // Build a new jQuery matched element set
| |
− | var ret = jQuery.merge( this.constructor(), elems );
| |
− |
| |
− | // Add the old object onto the stack (as a reference)
| |
− | ret.prevObject = this;
| |
− |
| |
− | // Return the newly-formed element set
| |
− | return ret;
| |
− | },
| |
− |
| |
− | // Execute a callback for every element in the matched set.
| |
− | each: function( callback ) {
| |
− | return jQuery.each( this, callback );
| |
− | },
| |
− |
| |
− | map: function( callback ) {
| |
− | return this.pushStack( jQuery.map( this, function( elem, i ) {
| |
− | return callback.call( elem, i, elem );
| |
− | } ) );
| |
− | },
| |
− |
| |
− | slice: function() {
| |
− | return this.pushStack( slice.apply( this, arguments ) );
| |
− | },
| |
− |
| |
− | first: function() {
| |
− | return this.eq( 0 );
| |
− | },
| |
− |
| |
− | last: function() {
| |
− | return this.eq( -1 );
| |
− | },
| |
− |
| |
− | eq: function( i ) {
| |
− | var len = this.length,
| |
− | j = +i + ( i < 0 ? len : 0 );
| |
− | return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] );
| |
− | },
| |
− |
| |
− | end: function() {
| |
− | return this.prevObject || this.constructor();
| |
− | },
| |
− |
| |
− | // For internal use only.
| |
− | // Behaves like an Array's method, not like a jQuery method.
| |
− | push: push,
| |
− | sort: arr.sort,
| |
− | splice: arr.splice
| |
− | };
| |
− |
| |
− | jQuery.extend = jQuery.fn.extend = function() {
| |
− | var options, name, src, copy, copyIsArray, clone,
| |
− | target = arguments[ 0 ] || {},
| |
− | i = 1,
| |
− | length = arguments.length,
| |
− | deep = false;
| |
− |
| |
− | // Handle a deep copy situation
| |
− | if ( typeof target === "boolean" ) {
| |
− | deep = target;
| |
− |
| |
− | // Skip the boolean and the target
| |
− | target = arguments[ i ] || {};
| |
− | i++;
| |
− | }
| |
− |
| |
− | // Handle case when target is a string or something (possible in deep copy)
| |
− | if ( typeof target !== "object" && !isFunction( target ) ) {
| |
− | target = {};
| |
− | }
| |
− |
| |
− | // Extend jQuery itself if only one argument is passed
| |
− | if ( i === length ) {
| |
− | target = this;
| |
− | i--;
| |
− | }
| |
− |
| |
− | for ( ; i < length; i++ ) {
| |
− |
| |
− | // Only deal with non-null/undefined values
| |
− | if ( ( options = arguments[ i ] ) != null ) {
| |
− |
| |
− | // Extend the base object
| |
− | for ( name in options ) {
| |
− | src = target[ name ];
| |
− | copy = options[ name ];
| |
− |
| |
− | // Prevent never-ending loop
| |
− | if ( target === copy ) {
| |
− | continue;
| |
− | }
| |
− |
| |
− | // Recurse if we're merging plain objects or arrays
| |
− | if ( deep && copy && ( jQuery.isPlainObject( copy ) ||
| |
− | ( copyIsArray = Array.isArray( copy ) ) ) ) {
| |
− |
| |
− | if ( copyIsArray ) {
| |
− | copyIsArray = false;
| |
− | clone = src && Array.isArray( src ) ? src : [];
| |
− |
| |
− | } else {
| |
− | clone = src && jQuery.isPlainObject( src ) ? src : {};
| |
− | }
| |
− |
| |
− | // Never move original objects, clone them
| |
− | target[ name ] = jQuery.extend( deep, clone, copy );
| |
− |
| |
− | // Don't bring in undefined values
| |
− | } else if ( copy !== undefined ) {
| |
− | target[ name ] = copy;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Return the modified object
| |
− | return target;
| |
− | };
| |
− |
| |
− | jQuery.extend( {
| |
− |
| |
− | // Unique for each copy of jQuery on the page
| |
− | expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ),
| |
− |
| |
− | // Assume jQuery is ready without the ready module
| |
− | isReady: true,
| |
− |
| |
− | error: function( msg ) {
| |
− | throw new Error( msg );
| |
− | },
| |
− |
| |
− | noop: function() {},
| |
− |
| |
− | isPlainObject: function( obj ) {
| |
− | var proto, Ctor;
| |
− |
| |
− | // Detect obvious negatives
| |
− | // Use toString instead of jQuery.type to catch host objects
| |
− | if ( !obj || toString.call( obj ) !== "[object Object]" ) {
| |
− | return false;
| |
− | }
| |
− |
| |
− | proto = getProto( obj );
| |
− |
| |
− | // Objects with no prototype (e.g., `Object.create( null )`) are plain
| |
− | if ( !proto ) {
| |
− | return true;
| |
− | }
| |
− |
| |
− | // Objects with prototype are plain iff they were constructed by a global Object function
| |
− | Ctor = hasOwn.call( proto, "constructor" ) && proto.constructor;
| |
− | return typeof Ctor === "function" && fnToString.call( Ctor ) === ObjectFunctionString;
| |
− | },
| |
− |
| |
− | isEmptyObject: function( obj ) {
| |
− |
| |
− | /* eslint-disable no-unused-vars */
| |
− | // See https://github.com/eslint/eslint/issues/6125
| |
− | var name;
| |
− |
| |
− | for ( name in obj ) {
| |
− | return false;
| |
− | }
| |
− | return true;
| |
− | },
| |
− |
| |
− | // Evaluates a script in a global context
| |
− | globalEval: function( code ) {
| |
− | DOMEval( code );
| |
− | },
| |
− |
| |
− | each: function( obj, callback ) {
| |
− | var length, i = 0;
| |
− |
| |
− | if ( isArrayLike( obj ) ) {
| |
− | length = obj.length;
| |
− | for ( ; i < length; i++ ) {
| |
− | if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {
| |
− | break;
| |
− | }
| |
− | }
| |
− | } else {
| |
− | for ( i in obj ) {
| |
− | if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {
| |
− | break;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return obj;
| |
− | },
| |
− |
| |
− | // Support: Android <=4.0 only
| |
− | trim: function( text ) {
| |
− | return text == null ?
| |
− | "" :
| |
− | ( text + "" ).replace( rtrim, "" );
| |
− | },
| |
− |
| |
− | // results is for internal usage only
| |
− | makeArray: function( arr, results ) {
| |
− | var ret = results || [];
| |
− |
| |
− | if ( arr != null ) {
| |
− | if ( isArrayLike( Object( arr ) ) ) {
| |
− | jQuery.merge( ret,
| |
− | typeof arr === "string" ?
| |
− | [ arr ] : arr
| |
− | );
| |
− | } else {
| |
− | push.call( ret, arr );
| |
− | }
| |
− | }
| |
− |
| |
− | return ret;
| |
− | },
| |
− |
| |
− | inArray: function( elem, arr, i ) {
| |
− | return arr == null ? -1 : indexOf.call( arr, elem, i );
| |
− | },
| |
− |
| |
− | // Support: Android <=4.0 only, PhantomJS 1 only
| |
− | // push.apply(_, arraylike) throws on ancient WebKit
| |
− | merge: function( first, second ) {
| |
− | var len = +second.length,
| |
− | j = 0,
| |
− | i = first.length;
| |
− |
| |
− | for ( ; j < len; j++ ) {
| |
− | first[ i++ ] = second[ j ];
| |
− | }
| |
− |
| |
− | first.length = i;
| |
− |
| |
− | return first;
| |
− | },
| |
− |
| |
− | grep: function( elems, callback, invert ) {
| |
− | var callbackInverse,
| |
− | matches = [],
| |
− | i = 0,
| |
− | length = elems.length,
| |
− | callbackExpect = !invert;
| |
− |
| |
− | // Go through the array, only saving the items
| |
− | // that pass the validator function
| |
− | for ( ; i < length; i++ ) {
| |
− | callbackInverse = !callback( elems[ i ], i );
| |
− | if ( callbackInverse !== callbackExpect ) {
| |
− | matches.push( elems[ i ] );
| |
− | }
| |
− | }
| |
− |
| |
− | return matches;
| |
− | },
| |
− |
| |
− | // arg is for internal usage only
| |
− | map: function( elems, callback, arg ) {
| |
− | var length, value,
| |
− | i = 0,
| |
− | ret = [];
| |
− |
| |
− | // Go through the array, translating each of the items to their new values
| |
− | if ( isArrayLike( elems ) ) {
| |
− | length = elems.length;
| |
− | for ( ; i < length; i++ ) {
| |
− | value = callback( elems[ i ], i, arg );
| |
− |
| |
− | if ( value != null ) {
| |
− | ret.push( value );
| |
− | }
| |
− | }
| |
− |
| |
− | // Go through every key on the object,
| |
− | } else {
| |
− | for ( i in elems ) {
| |
− | value = callback( elems[ i ], i, arg );
| |
− |
| |
− | if ( value != null ) {
| |
− | ret.push( value );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Flatten any nested arrays
| |
− | return concat.apply( [], ret );
| |
− | },
| |
− |
| |
− | // A global GUID counter for objects
| |
− | guid: 1,
| |
− |
| |
− | // jQuery.support is not used in Core but other projects attach their
| |
− | // properties to it so it needs to exist.
| |
− | support: support
| |
− | } );
| |
− |
| |
− | if ( typeof Symbol === "function" ) {
| |
− | jQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ];
| |
− | }
| |
− |
| |
− | // Populate the class2type map
| |
− | jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ),
| |
− | function( i, name ) {
| |
− | class2type[ "[object " + name + "]" ] = name.toLowerCase();
| |
− | } );
| |
− |
| |
− | function isArrayLike( obj ) {
| |
− |
| |
− | // Support: real iOS 8.2 only (not reproducible in simulator)
| |
− | // `in` check used to prevent JIT error (gh-2145)
| |
− | // hasOwn isn't used here due to false negatives
| |
− | // regarding Nodelist length in IE
| |
− | var length = !!obj && "length" in obj && obj.length,
| |
− | type = toType( obj );
| |
− |
| |
− | if ( isFunction( obj ) || isWindow( obj ) ) {
| |
− | return false;
| |
− | }
| |
− |
| |
− | return type === "array" || length === 0 ||
| |
− | typeof length === "number" && length > 0 && ( length - 1 ) in obj;
| |
− | }
| |
− | var Sizzle =
| |
− | /*!
| |
− | * Sizzle CSS Selector Engine v2.3.3
| |
− | * https://sizzlejs.com/
| |
− | *
| |
− | * Copyright jQuery Foundation and other contributors
| |
− | * Released under the MIT license
| |
− | * http://jquery.org/license
| |
− | *
| |
− | * Date: 2016-08-08
| |
− | */
| |
− | (function( window ) {
| |
− |
| |
− | var i,
| |
− | support,
| |
− | Expr,
| |
− | getText,
| |
− | isXML,
| |
− | tokenize,
| |
− | compile,
| |
− | select,
| |
− | outermostContext,
| |
− | sortInput,
| |
− | hasDuplicate,
| |
− |
| |
− | // Local document vars
| |
− | setDocument,
| |
− | document,
| |
− | docElem,
| |
− | documentIsHTML,
| |
− | rbuggyQSA,
| |
− | rbuggyMatches,
| |
− | matches,
| |
− | contains,
| |
− |
| |
− | // Instance-specific data
| |
− | expando = "sizzle" + 1 * new Date(),
| |
− | preferredDoc = window.document,
| |
− | dirruns = 0,
| |
− | done = 0,
| |
− | classCache = createCache(),
| |
− | tokenCache = createCache(),
| |
− | compilerCache = createCache(),
| |
− | sortOrder = function( a, b ) {
| |
− | if ( a === b ) {
| |
− | hasDuplicate = true;
| |
− | }
| |
− | return 0;
| |
− | },
| |
− |
| |
− | // Instance methods
| |
− | hasOwn = ({}).hasOwnProperty,
| |
− | arr = [],
| |
− | pop = arr.pop,
| |
− | push_native = arr.push,
| |
− | push = arr.push,
| |
− | slice = arr.slice,
| |
− | // Use a stripped-down indexOf as it's faster than native
| |
− | // https://jsperf.com/thor-indexof-vs-for/5
| |
− | indexOf = function( list, elem ) {
| |
− | var i = 0,
| |
− | len = list.length;
| |
− | for ( ; i < len; i++ ) {
| |
− | if ( list[i] === elem ) {
| |
− | return i;
| |
− | }
| |
− | }
| |
− | return -1;
| |
− | },
| |
− |
| |
− | booleans = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
| |
− |
| |
− | // Regular expressions
| |
− |
| |
− | // http://www.w3.org/TR/css3-selectors/#whitespace
| |
− | whitespace = "[\\x20\\t\\r\\n\\f]",
| |
− |
| |
− | // http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier
| |
− | identifier = "(?:\\\\.|[\\w-]|[^\0-\\xa0])+",
| |
− |
| |
− | // Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors
| |
− | attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace +
| |
− | // Operator (capture 2)
| |
− | "*([*^$|!~]?=)" + whitespace +
| |
− | // "Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]"
| |
− | "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" + whitespace +
| |
− | "*\\]",
| |
− |
| |
− | pseudos = ":(" + identifier + ")(?:\\((" +
| |
− | // To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:
| |
− | // 1. quoted (capture 3; capture 4 or capture 5)
| |
− | "('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|" +
| |
− | // 2. simple (capture 6)
| |
− | "((?:\\\\.|[^\\\\()[\\]]|" + attributes + ")*)|" +
| |
− | // 3. anything else (capture 2)
| |
− | ".*" +
| |
− | ")\\)|)",
| |
− |
| |
− | // Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter
| |
− | rwhitespace = new RegExp( whitespace + "+", "g" ),
| |
− | rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + whitespace + "+$", "g" ),
| |
− |
| |
− | rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ),
| |
− | rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + "*" ),
| |
− |
| |
− | rattributeQuotes = new RegExp( "=" + whitespace + "*([^\\]'\"]*?)" + whitespace + "*\\]", "g" ),
| |
− |
| |
− | rpseudo = new RegExp( pseudos ),
| |
− | ridentifier = new RegExp( "^" + identifier + "$" ),
| |
− |
| |
− | matchExpr = {
| |
− | "ID": new RegExp( "^#(" + identifier + ")" ),
| |
− | "CLASS": new RegExp( "^\\.(" + identifier + ")" ),
| |
− | "TAG": new RegExp( "^(" + identifier + "|[*])" ),
| |
− | "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" )
| |
− | },
| |
− |
| |
− | rinputs = /^(?:input|select|textarea|button)$/i,
| |
− | rheader = /^h\d$/i,
| |
− |
| |
− | rnative = /^[^{]+\{\s*\[native \w/,
| |
− |
| |
− | // Easily-parseable/retrievable ID or TAG or CLASS selectors
| |
− | rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
| |
− |
| |
− | rsibling = /[+~]/,
| |
− |
| |
− | // 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<24
| |
− | // Workaround erroneous numeric interpretation of +"0x"
| |
− | return high !== high || escapedWhitespace ?
| |
− | escaped :
| |
− | high < 0 ?
| |
− | // BMP codepoint
| |
− | String.fromCharCode( high + 0x10000 ) :
| |
− | // Supplemental Plane codepoint (surrogate pair)
| |
− | String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );
| |
− | },
| |
− |
| |
− | // CSS string/identifier serialization
| |
− | // https://drafts.csswg.org/cssom/#common-serializing-idioms
| |
− | rcssescape = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,
| |
− | fcssescape = function( ch, asCodePoint ) {
| |
− | if ( asCodePoint ) {
| |
− |
| |
− | // U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER
| |
− | if ( ch === "\0" ) {
| |
− | return "\uFFFD";
| |
− | }
| |
− |
| |
− | // Control characters and (dependent upon position) numbers get escaped as code points
| |
− | return ch.slice( 0, -1 ) + "\\" + ch.charCodeAt( ch.length - 1 ).toString( 16 ) + " ";
| |
− | }
| |
− |
| |
− | // Other potentially-special ASCII characters get backslash-escaped
| |
− | return "\\" + ch;
| |
− | },
| |
− |
| |
− | // Used for iframes
| |
− | // See setDocument()
| |
− | // Removing the function wrapper causes a "Permission Denied"
| |
− | // error in IE
| |
− | unloadHandler = function() {
| |
− | setDocument();
| |
− | },
| |
− |
| |
− | disabledAncestor = addCombinator(
| |
− | function( elem ) {
| |
− | return elem.disabled === true && ("form" in elem || "label" in elem);
| |
− | },
| |
− | { dir: "parentNode", next: "legend" }
| |
− | );
| |
− |
| |
− | // 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 ?
| |
− |
| |
− | // Leverage slice if possible
| |
− | function( target, els ) {
| |
− | push_native.apply( target, slice.call(els) );
| |
− | } :
| |
− |
| |
− | // 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;
| |
− | }
| |
− | };
| |
− | }
| |
− |
| |
− | function Sizzle( selector, context, results, seed ) {
| |
− | var m, i, elem, nid, match, groups, newSelector,
| |
− | newContext = context && context.ownerDocument,
| |
− |
| |
− | // nodeType defaults to 9, since context defaults to document
| |
− | nodeType = context ? context.nodeType : 9;
| |
− |
| |
− | results = results || [];
| |
− |
| |
− | // Return early from calls with invalid selector or context
| |
− | if ( typeof selector !== "string" || !selector ||
| |
− | nodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) {
| |
− |
| |
− | return results;
| |
− | }
| |
− |
| |
− | // Try to shortcut find operations (as opposed to filters) in HTML documents
| |
− | if ( !seed ) {
| |
− |
| |
− | if ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) {
| |
− | setDocument( context );
| |
− | }
| |
− | context = context || document;
| |
− |
| |
− | if ( documentIsHTML ) {
| |
− |
| |
− | // If the selector is sufficiently simple, try using a "get*By*" DOM method
| |
− | // (excepting DocumentFragment context, where the methods don't exist)
| |
− | if ( nodeType !== 11 && (match = rquickExpr.exec( selector )) ) {
| |
− |
| |
− | // ID selector
| |
− | if ( (m = match[1]) ) {
| |
− |
| |
− | // Document context
| |
− | if ( nodeType === 9 ) {
| |
− | if ( (elem = context.getElementById( m )) ) {
| |
− |
| |
− | // Support: IE, Opera, Webkit
| |
− | // TODO: identify versions
| |
− | // getElementById can match elements by name instead of ID
| |
− | if ( elem.id === m ) {
| |
− | results.push( elem );
| |
− | return results;
| |
− | }
| |
− | } else {
| |
− | return results;
| |
− | }
| |
− |
| |
− | // Element context
| |
− | } else {
| |
− |
| |
− | // Support: IE, Opera, Webkit
| |
− | // TODO: identify versions
| |
− | // getElementById can match elements by name instead of ID
| |
− | if ( newContext && (elem = newContext.getElementById( m )) &&
| |
− | contains( context, elem ) &&
| |
− | elem.id === m ) {
| |
− |
| |
− | results.push( elem );
| |
− | return results;
| |
− | }
| |
− | }
| |
− |
| |
− | // Type selector
| |
− | } else if ( match[2] ) {
| |
− | push.apply( results, context.getElementsByTagName( selector ) );
| |
− | return results;
| |
− |
| |
− | // Class selector
| |
− | } else if ( (m = match[3]) && support.getElementsByClassName &&
| |
− | context.getElementsByClassName ) {
| |
− |
| |
− | push.apply( results, context.getElementsByClassName( m ) );
| |
− | return results;
| |
− | }
| |
− | }
| |
− |
| |
− | // Take advantage of querySelectorAll
| |
− | if ( support.qsa &&
| |
− | !compilerCache[ selector + " " ] &&
| |
− | (!rbuggyQSA || !rbuggyQSA.test( selector )) ) {
| |
− |
| |
− | if ( nodeType !== 1 ) {
| |
− | newContext = context;
| |
− | newSelector = selector;
| |
− |
| |
− | // qSA looks outside Element context, which is not what we want
| |
− | // Thanks to Andrew Dupont for this workaround technique
| |
− | // Support: IE <=8
| |
− | // Exclude object elements
| |
− | } else if ( context.nodeName.toLowerCase() !== "object" ) {
| |
− |
| |
− | // Capture the context ID, setting it first if necessary
| |
− | if ( (nid = context.getAttribute( "id" )) ) {
| |
− | nid = nid.replace( rcssescape, fcssescape );
| |
− | } else {
| |
− | context.setAttribute( "id", (nid = expando) );
| |
− | }
| |
− |
| |
− | // Prefix every selector in the list
| |
− | groups = tokenize( selector );
| |
− | i = groups.length;
| |
− | while ( i-- ) {
| |
− | groups[i] = "#" + nid + " " + toSelector( groups[i] );
| |
− | }
| |
− | newSelector = groups.join( "," );
| |
− |
| |
− | // Expand context for sibling selectors
| |
− | newContext = rsibling.test( selector ) && testContext( context.parentNode ) ||
| |
− | context;
| |
− | }
| |
− |
| |
− | if ( newSelector ) {
| |
− | try {
| |
− | push.apply( results,
| |
− | newContext.querySelectorAll( newSelector )
| |
− | );
| |
− | return results;
| |
− | } catch ( qsaError ) {
| |
− | } finally {
| |
− | if ( nid === expando ) {
| |
− | context.removeAttribute( "id" );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // All others
| |
− | return select( selector.replace( rtrim, "$1" ), context, results, seed );
| |
− | }
| |
− |
| |
− | /**
| |
− | * 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 = [];
| |
− |
| |
− | 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;
| |
− | }
| |
− |
| |
− | /**
| |
− | * Mark a function for special use by Sizzle
| |
− | * @param {Function} fn The function to mark
| |
− | */
| |
− | function markFunction( fn ) {
| |
− | fn[ expando ] = true;
| |
− | return fn;
| |
− | }
| |
− |
| |
− | /**
| |
− | * Support testing using an element
| |
− | * @param {Function} fn Passed the created element and returns a boolean result
| |
− | */
| |
− | function assert( fn ) {
| |
− | var el = document.createElement("fieldset");
| |
− |
| |
− | try {
| |
− | return !!fn( el );
| |
− | } catch (e) {
| |
− | return false;
| |
− | } finally {
| |
− | // Remove from its parent by default
| |
− | if ( el.parentNode ) {
| |
− | el.parentNode.removeChild( el );
| |
− | }
| |
− | // release memory in IE
| |
− | el = null;
| |
− | }
| |
− | }
| |
− |
| |
− | /**
| |
− | * 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 = arr.length;
| |
− |
| |
− | while ( i-- ) {
| |
− | Expr.attrHandle[ arr[i] ] = handler;
| |
− | }
| |
− | }
| |
− |
| |
− | /**
| |
− | * 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 &&
| |
− | a.sourceIndex - b.sourceIndex;
| |
− |
| |
− | // Use IE sourceIndex if available on both nodes
| |
− | if ( diff ) {
| |
− | return diff;
| |
− | }
| |
− |
| |
− | // Check if b follows a
| |
− | if ( cur ) {
| |
− | while ( (cur = cur.nextSibling) ) {
| |
− | if ( cur === b ) {
| |
− | return -1;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return a ? 1 : -1;
| |
− | }
| |
− |
| |
− | /**
| |
− | * 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;
| |
− | };
| |
− | }
| |
− |
| |
− | /**
| |
− | * 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;
| |
− | };
| |
− | }
| |
− |
| |
− | /**
| |
− | * Returns a function to use in pseudos for :enabled/:disabled
| |
− | * @param {Boolean} disabled true for :disabled; false for :enabled
| |
− | */
| |
− | function createDisabledPseudo( disabled ) {
| |
− |
| |
− | // Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable
| |
− | return function( elem ) {
| |
− |
| |
− | // Only certain elements can match :enabled or :disabled
| |
− | // https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled
| |
− | // https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled
| |
− | if ( "form" in elem ) {
| |
− |
| |
− | // Check for inherited disabledness on relevant non-disabled elements:
| |
− | // * listed form-associated elements in a disabled fieldset
| |
− | // https://html.spec.whatwg.org/multipage/forms.html#category-listed
| |
− | // https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled
| |
− | // * option elements in a disabled optgroup
| |
− | // https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled
| |
− | // All such elements have a "form" property.
| |
− | if ( elem.parentNode && elem.disabled === false ) {
| |
− |
| |
− | // Option elements defer to a parent optgroup if present
| |
− | if ( "label" in elem ) {
| |
− | if ( "label" in elem.parentNode ) {
| |
− | return elem.parentNode.disabled === disabled;
| |
− | } else {
| |
− | return elem.disabled === disabled;
| |
− | }
| |
− | }
| |
− |
| |
− | // Support: IE 6 - 11
| |
− | // Use the isDisabled shortcut property to check for disabled fieldset ancestors
| |
− | return elem.isDisabled === disabled ||
| |
− |
| |
− | // Where there is no isDisabled, check manually
| |
− | /* jshint -W018 */
| |
− | elem.isDisabled !== !disabled &&
| |
− | disabledAncestor( elem ) === disabled;
| |
− | }
| |
− |
| |
− | return elem.disabled === disabled;
| |
− |
| |
− | // Try to winnow out elements that can't be disabled before trusting the disabled property.
| |
− | // Some victims get caught in our net (label, legend, menu, track), but it shouldn't
| |
− | // even exist on them, let alone have a boolean value.
| |
− | } else if ( "label" in elem ) {
| |
− | return elem.disabled === disabled;
| |
− | }
| |
− |
| |
− | // Remaining elements are neither :enabled nor :disabled
| |
− | return false;
| |
− | };
| |
− | }
| |
− |
| |
− | /**
| |
− | * 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;
| |
− |
| |
− | // Match elements found at the specified indexes
| |
− | while ( i-- ) {
| |
− | if ( seed[ (j = matchIndexes[i]) ] ) {
| |
− | seed[j] = !(matches[j] = seed[j]);
| |
− | }
| |
− | }
| |
− | });
| |
− | });
| |
− | }
| |
− |
| |
− | /**
| |
− | * Checks a node for validity as a Sizzle context
| |
− | * @param {Element|Object=} context
| |
− | * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value
| |
− | */
| |
− | function testContext( context ) {
| |
− | return context && typeof context.getElementsByTagName !== "undefined" && context;
| |
− | }
| |
− |
| |
− | // Expose support vars for convenience
| |
− | support = Sizzle.support = {};
| |
− |
| |
− | /**
| |
− | * Detects XML nodes
| |
− | * @param {Element|Object} elem An element or a document
| |
− | * @returns {Boolean} True iff elem is a non-HTML XML node
| |
− | */
| |
− | 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 hasCompare, subWindow,
| |
− | doc = node ? node.ownerDocument || node : preferredDoc;
| |
− |
| |
− | // Return early if doc is invalid or already selected
| |
− | if ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) {
| |
− | return document;
| |
− | }
| |
− |
| |
− | // Update global variables
| |
− | document = doc;
| |
− | docElem = document.documentElement;
| |
− | documentIsHTML = !isXML( document );
| |
− |
| |
− | // Support: IE 9-11, Edge
| |
− | // Accessing iframe documents after unload throws "permission denied" errors (jQuery #13936)
| |
− | if ( preferredDoc !== document &&
| |
− | (subWindow = document.defaultView) && subWindow.top !== subWindow ) {
| |
− |
| |
− | // Support: IE 11, Edge
| |
− | if ( subWindow.addEventListener ) {
| |
− | subWindow.addEventListener( "unload", unloadHandler, false );
| |
− |
| |
− | // Support: IE 9 - 10 only
| |
− | } else if ( subWindow.attachEvent ) {
| |
− | subWindow.attachEvent( "onunload", unloadHandler );
| |
− | }
| |
− | }
| |
− |
| |
− | /* Attributes
| |
− | ---------------------------------------------------------------------- */
| |
− |
| |
− | // Support: IE<8
| |
− | // Verify that getAttribute really returns attributes and not properties
| |
− | // (excepting IE8 booleans)
| |
− | support.attributes = assert(function( el ) {
| |
− | el.className = "i";
| |
− | return !el.getAttribute("className");
| |
− | });
| |
− |
| |
− | /* getElement(s)By*
| |
− | ---------------------------------------------------------------------- */
| |
− |
| |
− | // Check if getElementsByTagName("*") returns only elements
| |
− | support.getElementsByTagName = assert(function( el ) {
| |
− | el.appendChild( document.createComment("") );
| |
− | return !el.getElementsByTagName("*").length;
| |
− | });
| |
− |
| |
− | // Support: IE<9
| |
− | support.getElementsByClassName = rnative.test( document.getElementsByClassName );
| |
− |
| |
− | // Support: IE<10
| |
− | // Check if getElementById returns elements by name
| |
− | // The broken getElementById methods don't pick up programmatically-set names,
| |
− | // so use a roundabout getElementsByName test
| |
− | support.getById = assert(function( el ) {
| |
− | docElem.appendChild( el ).id = expando;
| |
− | return !document.getElementsByName || !document.getElementsByName( expando ).length;
| |
− | });
| |
− |
| |
− | // ID filter and find
| |
− | if ( support.getById ) {
| |
− | Expr.filter["ID"] = function( id ) {
| |
− | var attrId = id.replace( runescape, funescape );
| |
− | return function( elem ) {
| |
− | return elem.getAttribute("id") === attrId;
| |
− | };
| |
− | };
| |
− | Expr.find["ID"] = function( id, context ) {
| |
− | if ( typeof context.getElementById !== "undefined" && documentIsHTML ) {
| |
− | var elem = context.getElementById( id );
| |
− | return elem ? [ elem ] : [];
| |
− | }
| |
− | };
| |
− | } else {
| |
− | Expr.filter["ID"] = function( id ) {
| |
− | var attrId = id.replace( runescape, funescape );
| |
− | return function( elem ) {
| |
− | var node = typeof elem.getAttributeNode !== "undefined" &&
| |
− | elem.getAttributeNode("id");
| |
− | return node && node.value === attrId;
| |
− | };
| |
− | };
| |
− |
| |
− | // Support: IE 6 - 7 only
| |
− | // getElementById is not reliable as a find shortcut
| |
− | Expr.find["ID"] = function( id, context ) {
| |
− | if ( typeof context.getElementById !== "undefined" && documentIsHTML ) {
| |
− | var node, i, elems,
| |
− | elem = context.getElementById( id );
| |
− |
| |
− | if ( elem ) {
| |
− |
| |
− | // Verify the id attribute
| |
− | node = elem.getAttributeNode("id");
| |
− | if ( node && node.value === id ) {
| |
− | return [ elem ];
| |
− | }
| |
− |
| |
− | // Fall back on getElementsByName
| |
− | elems = context.getElementsByName( id );
| |
− | i = 0;
| |
− | while ( (elem = elems[i++]) ) {
| |
− | node = elem.getAttributeNode("id");
| |
− | if ( node && node.value === id ) {
| |
− | return [ elem ];
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return [];
| |
− | }
| |
− | };
| |
− | }
| |
− |
| |
− | // Tag
| |
− | Expr.find["TAG"] = support.getElementsByTagName ?
| |
− | function( tag, context ) {
| |
− | if ( typeof context.getElementsByTagName !== "undefined" ) {
| |
− | return context.getElementsByTagName( tag );
| |
− |
| |
− | // DocumentFragment nodes don't have gEBTN
| |
− | } else if ( support.qsa ) {
| |
− | return context.querySelectorAll( tag );
| |
− | }
| |
− | } :
| |
− |
| |
− | function( tag, context ) {
| |
− | var elem,
| |
− | tmp = [],
| |
− | i = 0,
| |
− | // By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too
| |
− | results = context.getElementsByTagName( tag );
| |
− |
| |
− | // Filter out possible comments
| |
− | if ( tag === "*" ) {
| |
− | while ( (elem = results[i++]) ) {
| |
− | if ( elem.nodeType === 1 ) {
| |
− | tmp.push( elem );
| |
− | }
| |
− | }
| |
− |
| |
− | return tmp;
| |
− | }
| |
− | return results;
| |
− | };
| |
− |
| |
− | // Class
| |
− | Expr.find["CLASS"] = support.getElementsByClassName && function( className, context ) {
| |
− | if ( typeof context.getElementsByClassName !== "undefined" && documentIsHTML ) {
| |
− | return context.getElementsByClassName( className );
| |
− | }
| |
− | };
| |
− |
| |
− | /* QSA/matchesSelector
| |
− | ---------------------------------------------------------------------- */
| |
− |
| |
− | // QSA and matchesSelector support
| |
− |
| |
− | // matchesSelector(:active) reports false when true (IE9/Opera 11.5)
| |
− | rbuggyMatches = [];
| |
− |
| |
− | // 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 https://bugs.jquery.com/ticket/13378
| |
− | rbuggyQSA = [];
| |
− |
| |
− | if ( (support.qsa = rnative.test( document.querySelectorAll )) ) {
| |
− | // Build QSA regex
| |
− | // Regex strategy adopted from Diego Perini
| |
− | assert(function( el ) {
| |
− | // 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
| |
− | // https://bugs.jquery.com/ticket/12359
| |
− | docElem.appendChild( el ).innerHTML = "<a id='" + expando + "'></a>" +
| |
− | "<select id='" + expando + "-\r\\' msallowcapture=''>" +
| |
− | "<option selected=''></option></select>";
| |
− |
| |
− | // Support: IE8, Opera 11-12.16
| |
− | // Nothing should be selected when empty strings follow ^= or $= or *=
| |
− | // The test attribute must be unknown in Opera but "safe" for WinRT
| |
− | // https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section
| |
− | if ( el.querySelectorAll("[msallowcapture^='']").length ) {
| |
− | rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" );
| |
− | }
| |
− |
| |
− | // Support: IE8
| |
− | // Boolean attributes and "value" are not treated correctly
| |
− | if ( !el.querySelectorAll("[selected]").length ) {
| |
− | rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" );
| |
− | }
| |
− |
| |
− | // Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+
| |
− | if ( !el.querySelectorAll( "[id~=" + expando + "-]" ).length ) {
| |
− | rbuggyQSA.push("~=");
| |
− | }
| |
− |
| |
− | // 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 ( !el.querySelectorAll(":checked").length ) {
| |
− | rbuggyQSA.push(":checked");
| |
− | }
| |
− |
| |
− | // Support: Safari 8+, iOS 8+
| |
− | // https://bugs.webkit.org/show_bug.cgi?id=136851
| |
− | // In-page `selector#id sibling-combinator selector` fails
| |
− | if ( !el.querySelectorAll( "a#" + expando + "+*" ).length ) {
| |
− | rbuggyQSA.push(".#.+[+~]");
| |
− | }
| |
− | });
| |
− |
| |
− | assert(function( el ) {
| |
− | el.innerHTML = "<a href='' disabled='disabled'></a>" +
| |
− | "<select disabled='disabled'><option/></select>";
| |
− |
| |
− | // Support: Windows 8 Native Apps
| |
− | // The type and name attributes are restricted during .innerHTML assignment
| |
− | var input = document.createElement("input");
| |
− | input.setAttribute( "type", "hidden" );
| |
− | el.appendChild( input ).setAttribute( "name", "D" );
| |
− |
| |
− | // Support: IE8
| |
− | // Enforce case-sensitivity of name attribute
| |
− | if ( el.querySelectorAll("[name=d]").length ) {
| |
− | rbuggyQSA.push( "name" + whitespace + "*[*^$|!~]?=" );
| |
− | }
| |
− |
| |
− | // FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)
| |
− | // IE8 throws error here and will not see later tests
| |
− | if ( el.querySelectorAll(":enabled").length !== 2 ) {
| |
− | rbuggyQSA.push( ":enabled", ":disabled" );
| |
− | }
| |
− |
| |
− | // Support: IE9-11+
| |
− | // IE's :disabled selector does not pick up the children of disabled fieldsets
| |
− | docElem.appendChild( el ).disabled = true;
| |
− | if ( el.querySelectorAll(":disabled").length !== 2 ) {
| |
− | rbuggyQSA.push( ":enabled", ":disabled" );
| |
− | }
| |
− |
| |
− | // Opera 10-11 does not throw on post-comma invalid pseudos
| |
− | el.querySelectorAll("*,:x");
| |
− | rbuggyQSA.push(",.*:");
| |
− | });
| |
− | }
| |
− |
| |
− | if ( (support.matchesSelector = rnative.test( (matches = docElem.matches ||
| |
− | docElem.webkitMatchesSelector ||
| |
− | docElem.mozMatchesSelector ||
| |
− | docElem.oMatchesSelector ||
| |
− | docElem.msMatchesSelector) )) ) {
| |
− |
| |
− | assert(function( el ) {
| |
− | // Check to see if it's possible to do matchesSelector
| |
− | // on a disconnected node (IE 9)
| |
− | support.disconnectedMatch = matches.call( el, "*" );
| |
− |
| |
− | // This should fail with an exception
| |
− | // Gecko does not error, returns false instead
| |
− | matches.call( el, "[s!='']:x" );
| |
− | rbuggyMatches.push( "!=", pseudos );
| |
− | });
| |
− | }
| |
− |
| |
− | rbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join("|") );
| |
− | rbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join("|") );
| |
− |
| |
− | /* Contains
| |
− | ---------------------------------------------------------------------- */
| |
− | hasCompare = rnative.test( docElem.compareDocumentPosition );
| |
− |
| |
− | // Element contains another
| |
− | // Purposefully self-exclusive
| |
− | // As in, an element does not contain itself
| |
− | contains = hasCompare || rnative.test( docElem.contains ) ?
| |
− | 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;
| |
− | }
| |
− | }
| |
− | }
| |
− | return false;
| |
− | };
| |
− |
| |
− | /* Sorting
| |
− | ---------------------------------------------------------------------- */
| |
− |
| |
− | // Document order sorting
| |
− | sortOrder = hasCompare ?
| |
− | function( a, b ) {
| |
− |
| |
− | // Flag for duplicate removal
| |
− | if ( a === b ) {
| |
− | hasDuplicate = true;
| |
− | return 0;
| |
− | }
| |
− |
| |
− | // Sort on method existence if only one input has compareDocumentPosition
| |
− | var compare = !a.compareDocumentPosition - !b.compareDocumentPosition;
| |
− | if ( compare ) {
| |
− | return compare;
| |
− | }
| |
− |
| |
− | // Calculate position if both inputs belong to the same document
| |
− | compare = ( a.ownerDocument || a ) === ( b.ownerDocument || b ) ?
| |
− | a.compareDocumentPosition( b ) :
| |
− |
| |
− | // Otherwise we know they are disconnected
| |
− | 1;
| |
− |
| |
− | // Disconnected nodes
| |
− | if ( compare & 1 ||
| |
− | (!support.sortDetached && b.compareDocumentPosition( a ) === compare) ) {
| |
− |
| |
− | // Choose the first element that is related to our preferred document
| |
− | if ( a === document || a.ownerDocument === preferredDoc && contains(preferredDoc, a) ) {
| |
− | return -1;
| |
− | }
| |
− | if ( b === document || b.ownerDocument === preferredDoc && contains(preferredDoc, b) ) {
| |
− | return 1;
| |
− | }
| |
− |
| |
− | // Maintain original order
| |
− | return sortInput ?
| |
− | ( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :
| |
− | 0;
| |
− | }
| |
− |
| |
− | return compare & 4 ? -1 : 1;
| |
− | } :
| |
− | function( a, b ) {
| |
− | // Exit early if the nodes are identical
| |
− | if ( a === b ) {
| |
− | hasDuplicate = true;
| |
− | return 0;
| |
− | }
| |
− |
| |
− | var cur,
| |
− | i = 0,
| |
− | aup = a.parentNode,
| |
− | bup = b.parentNode,
| |
− | ap = [ a ],
| |
− | bp = [ b ];
| |
− |
| |
− | // Parentless nodes are either documents or disconnected
| |
− | if ( !aup || !bup ) {
| |
− | return a === document ? -1 :
| |
− | b === document ? 1 :
| |
− | aup ? -1 :
| |
− | bup ? 1 :
| |
− | sortInput ?
| |
− | ( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :
| |
− | 0;
| |
− |
| |
− | // If the nodes are siblings, we can do a quick check
| |
− | } else if ( aup === bup ) {
| |
− | return siblingCheck( a, b );
| |
− | }
| |
− |
| |
− | // 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 );
| |
− | }
| |
− |
| |
− | // Walk down the tree looking for a discrepancy
| |
− | while ( ap[i] === bp[i] ) {
| |
− | i++;
| |
− | }
| |
− |
| |
− | return i ?
| |
− | // Do a sibling check if the nodes have a common ancestor
| |
− | siblingCheck( ap[i], bp[i] ) :
| |
− |
| |
− | // Otherwise nodes in our document sort first
| |
− | ap[i] === preferredDoc ? -1 :
| |
− | bp[i] === preferredDoc ? 1 :
| |
− | 0;
| |
− | };
| |
− |
| |
− | return document;
| |
− | };
| |
− |
| |
− | Sizzle.matches = function( expr, elements ) {
| |
− | return Sizzle( expr, null, null, elements );
| |
− | };
| |
− |
| |
− | Sizzle.matchesSelector = function( elem, expr ) {
| |
− | // Set document vars if needed
| |
− | if ( ( elem.ownerDocument || elem ) !== document ) {
| |
− | setDocument( elem );
| |
− | }
| |
− |
| |
− | // Make sure that attribute selectors are quoted
| |
− | expr = expr.replace( rattributeQuotes, "='$1']" );
| |
− |
| |
− | if ( support.matchesSelector && documentIsHTML &&
| |
− | !compilerCache[ expr + " " ] &&
| |
− | ( !rbuggyMatches || !rbuggyMatches.test( expr ) ) &&
| |
− | ( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) {
| |
− |
| |
− | 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) {}
| |
− | }
| |
− |
| |
− | return Sizzle( expr, document, null, [ elem ] ).length > 0;
| |
− | };
| |
− |
| |
− | Sizzle.contains = function( context, elem ) {
| |
− | // Set document vars if needed
| |
− | if ( ( context.ownerDocument || context ) !== document ) {
| |
− | setDocument( context );
| |
− | }
| |
− | return contains( context, elem );
| |
− | };
| |
− |
| |
− | Sizzle.attr = function( elem, name ) {
| |
− | // Set document vars if needed
| |
− | if ( ( elem.ownerDocument || elem ) !== document ) {
| |
− | setDocument( elem );
| |
− | }
| |
− |
| |
− | 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;
| |
− |
| |
− | return val !== undefined ?
| |
− | val :
| |
− | support.attributes || !documentIsHTML ?
| |
− | elem.getAttribute( name ) :
| |
− | (val = elem.getAttributeNode(name)) && val.specified ?
| |
− | val.value :
| |
− | null;
| |
− | };
| |
− |
| |
− | Sizzle.escape = function( sel ) {
| |
− | return (sel + "").replace( rcssescape, fcssescape );
| |
− | };
| |
− |
| |
− | Sizzle.error = function( msg ) {
| |
− | throw new Error( "Syntax error, unrecognized expression: " + msg );
| |
− | };
| |
− |
| |
− | /**
| |
− | * Document sorting and removing duplicates
| |
− | * @param {ArrayLike} results
| |
− | */
| |
− | Sizzle.uniqueSort = function( results ) {
| |
− | var elem,
| |
− | duplicates = [],
| |
− | j = 0,
| |
− | i = 0;
| |
− |
| |
− | // Unless we *know* we can detect duplicates, assume their presence
| |
− | hasDuplicate = !support.detectDuplicates;
| |
− | sortInput = !support.sortStable && results.slice( 0 );
| |
− | results.sort( sortOrder );
| |
− |
| |
− | if ( hasDuplicate ) {
| |
− | while ( (elem = results[i++]) ) {
| |
− | if ( elem === results[ i ] ) {
| |
− | j = duplicates.push( i );
| |
− | }
| |
− | }
| |
− | while ( j-- ) {
| |
− | results.splice( duplicates[ j ], 1 );
| |
− | }
| |
− | }
| |
− |
| |
− | // Clear input after sorting to release objects
| |
− | // See https://github.com/jquery/sizzle/pull/225
| |
− | sortInput = null;
| |
− |
| |
− | return results;
| |
− | };
| |
− |
| |
− | /**
| |
− | * 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;
| |
− |
| |
− | if ( !nodeType ) {
| |
− | // If no nodeType, this is expected to be an array
| |
− | while ( (node = elem[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 (jQuery #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
| |
− |
| |
− | return ret;
| |
− | };
| |
− |
| |
− | Expr = Sizzle.selectors = {
| |
− |
| |
− | // Can be adjusted by the user
| |
− | cacheLength: 50,
| |
− |
| |
− | createPseudo: markFunction,
| |
− |
| |
− | match: matchExpr,
| |
− |
| |
− | attrHandle: {},
| |
− |
| |
− | find: {},
| |
− |
| |
− | relative: {
| |
− | ">": { dir: "parentNode", first: true },
| |
− | " ": { dir: "parentNode" },
| |
− | "+": { dir: "previousSibling", first: true },
| |
− | "~": { dir: "previousSibling" }
| |
− | },
| |
− |
| |
− | preFilter: {
| |
− | "ATTR": function( match ) {
| |
− | match[1] = match[1].replace( runescape, funescape );
| |
− |
| |
− | // Move the given value to match[3] whether quoted or unquoted
| |
− | match[3] = ( match[3] || match[4] || match[5] || "" ).replace( runescape, funescape );
| |
− |
| |
− | if ( match[2] === "~=" ) {
| |
− | match[3] = " " + match[3] + " ";
| |
− | }
| |
− |
| |
− | return match.slice( 0, 4 );
| |
− | },
| |
− |
| |
− | "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();
| |
− |
| |
− | if ( match[1].slice( 0, 3 ) === "nth" ) {
| |
− | // nth-* requires argument
| |
− | if ( !match[3] ) {
| |
− | Sizzle.error( match[0] );
| |
− | }
| |
− |
| |
− | // 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[6] && match[2];
| |
− |
| |
− | if ( matchExpr["CHILD"].test( match[0] ) ) {
| |
− | return null;
| |
− | }
| |
− |
| |
− | // Accept quoted arguments as-is
| |
− | if ( match[3] ) {
| |
− | match[2] = match[4] || match[5] || "";
| |
− |
| |
− | // 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 );
| |
− | }
| |
− |
| |
− | // Return only captures needed by the pseudo filter method (type and argument)
| |
− | return match.slice( 0, 3 );
| |
− | }
| |
− | },
| |
− |
| |
− | filter: {
| |
− |
| |
− | "TAG": function( nodeNameSelector ) {
| |
− | var nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase();
| |
− | return nodeNameSelector === "*" ?
| |
− | function() { return true; } :
| |
− | function( elem ) {
| |
− | return elem.nodeName && elem.nodeName.toLowerCase() === nodeName;
| |
− | };
| |
− | },
| |
− |
| |
− | "CLASS": function( className ) {
| |
− | var pattern = classCache[ className + " " ];
| |
− |
| |
− | return pattern ||
| |
− | (pattern = new RegExp( "(^|" + whitespace + ")" + className + "(" + whitespace + "|$)" )) &&
| |
− | classCache( className, function( elem ) {
| |
− | return pattern.test( typeof elem.className === "string" && elem.className || typeof elem.getAttribute !== "undefined" && elem.getAttribute("class") || "" );
| |
− | });
| |
− | },
| |
− |
| |
− | "ATTR": function( name, operator, check ) {
| |
− | return function( elem ) {
| |
− | var result = Sizzle.attr( elem, name );
| |
− |
| |
− | if ( result == null ) {
| |
− | return operator === "!=";
| |
− | }
| |
− | if ( !operator ) {
| |
− | return true;
| |
− | }
| |
− |
| |
− | 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.replace( rwhitespace, " " ) + " " ).indexOf( check ) > -1 :
| |
− | operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" :
| |
− | false;
| |
− | };
| |
− | },
| |
− |
| |
− | "CHILD": function( type, what, argument, first, last ) {
| |
− | var simple = type.slice( 0, 3 ) !== "nth",
| |
− | forward = type.slice( -4 ) !== "last",
| |
− | ofType = what === "of-type";
| |
− |
| |
− | return first === 1 && last === 0 ?
| |
− |
| |
− | // Shortcut for :nth-*(n)
| |
− | function( elem ) {
| |
− | return !!elem.parentNode;
| |
− | } :
| |
− |
| |
− | function( elem, context, xml ) {
| |
− | var cache, uniqueCache, outerCache, node, nodeIndex, start,
| |
− | dir = simple !== forward ? "nextSibling" : "previousSibling",
| |
− | parent = elem.parentNode,
| |
− | name = ofType && elem.nodeName.toLowerCase(),
| |
− | useCache = !xml && !ofType,
| |
− | diff = false;
| |
− |
| |
− | if ( parent ) {
| |
− |
| |
− | // :(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;
| |
− | }
| |
− |
| |
− | start = [ forward ? parent.firstChild : parent.lastChild ];
| |
− |
| |
− | // non-xml :nth-child(...) stores cache data on `parent`
| |
− | if ( forward && useCache ) {
| |
− |
| |
− | // Seek `elem` from a previously-cached index
| |
− |
| |
− | // ...in a gzip-friendly way
| |
− | node = parent;
| |
− | outerCache = node[ expando ] || (node[ expando ] = {});
| |
− |
| |
− | // Support: IE <9 only
| |
− | // Defend against cloned attroperties (jQuery gh-1709)
| |
− | uniqueCache = outerCache[ node.uniqueID ] ||
| |
− | (outerCache[ node.uniqueID ] = {});
| |
− |
| |
− | cache = uniqueCache[ type ] || [];
| |
− | nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];
| |
− | diff = nodeIndex && cache[ 2 ];
| |
− | node = nodeIndex && parent.childNodes[ nodeIndex ];
| |
− |
| |
− | while ( (node = ++nodeIndex && node && node[ dir ] ||
| |
− |
| |
− | // Fallback to seeking `elem` from the start
| |
− | (diff = nodeIndex = 0) || start.pop()) ) {
| |
− |
| |
− | // When found, cache indexes on `parent` and break
| |
− | if ( node.nodeType === 1 && ++diff && node === elem ) {
| |
− | uniqueCache[ type ] = [ dirruns, nodeIndex, diff ];
| |
− | break;
| |
− | }
| |
− | }
| |
− |
| |
− | } else {
| |
− | // Use previously-cached element index if available
| |
− | if ( useCache ) {
| |
− | // ...in a gzip-friendly way
| |
− | node = elem;
| |
− | outerCache = node[ expando ] || (node[ expando ] = {});
| |
− |
| |
− | // Support: IE <9 only
| |
− | // Defend against cloned attroperties (jQuery gh-1709)
| |
− | uniqueCache = outerCache[ node.uniqueID ] ||
| |
− | (outerCache[ node.uniqueID ] = {});
| |
− |
| |
− | cache = uniqueCache[ type ] || [];
| |
− | nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];
| |
− | diff = nodeIndex;
| |
− | }
| |
− |
| |
− | // xml :nth-child(...)
| |
− | // or :nth-last-child(...) or :nth(-last)?-of-type(...)
| |
− | if ( diff === false ) {
| |
− | // Use the same loop as above to seek `elem` from the start
| |
− | while ( (node = ++nodeIndex && node && node[ dir ] ||
| |
− | (diff = nodeIndex = 0) || start.pop()) ) {
| |
− |
| |
− | if ( ( ofType ?
| |
− | node.nodeName.toLowerCase() === name :
| |
− | node.nodeType === 1 ) &&
| |
− | ++diff ) {
| |
− |
| |
− | // Cache the index of each encountered element
| |
− | if ( useCache ) {
| |
− | outerCache = node[ expando ] || (node[ expando ] = {});
| |
− |
| |
− | // Support: IE <9 only
| |
− | // Defend against cloned attroperties (jQuery gh-1709)
| |
− | uniqueCache = outerCache[ node.uniqueID ] ||
| |
− | (outerCache[ node.uniqueID ] = {});
| |
− |
| |
− | uniqueCache[ type ] = [ dirruns, diff ];
| |
− | }
| |
− |
| |
− | if ( node === elem ) {
| |
− | break;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Incorporate the offset, then check against cycle size
| |
− | diff -= last;
| |
− | return diff === first || ( diff % first === 0 && diff / first >= 0 );
| |
− | }
| |
− | };
| |
− | },
| |
− |
| |
− | "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 );
| |
− |
| |
− | // 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 );
| |
− | }
| |
− |
| |
− | // 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( seed, matched[i] );
| |
− | seed[ idx ] = !( matches[ idx ] = matched[i] );
| |
− | }
| |
− | }) :
| |
− | function( elem ) {
| |
− | return fn( elem, 0, args );
| |
− | };
| |
− | }
| |
− |
| |
− | return fn;
| |
− | }
| |
− | },
| |
− |
| |
− | 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" ) );
| |
− |
| |
− | return matcher[ expando ] ?
| |
− | markFunction(function( seed, matches, context, xml ) {
| |
− | var elem,
| |
− | unmatched = matcher( seed, null, xml, [] ),
| |
− | i = seed.length;
| |
− |
| |
− | // 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 );
| |
− | // Don't keep the element (issue #299)
| |
− | input[0] = null;
| |
− | return !results.pop();
| |
− | };
| |
− | }),
| |
− |
| |
− | "has": markFunction(function( selector ) {
| |
− | return function( elem ) {
| |
− | return Sizzle( selector, elem ).length > 0;
| |
− | };
| |
− | }),
| |
− |
| |
− | "contains": markFunction(function( text ) {
| |
− | text = text.replace( runescape, funescape );
| |
− | 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")) ) {
| |
− |
| |
− | elemLang = elemLang.toLowerCase();
| |
− | return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0;
| |
− | }
| |
− | } 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;
| |
− | },
| |
− |
| |
− | "root": function( elem ) {
| |
− | return elem === docElem;
| |
− | },
| |
− |
| |
− | "focus": function( elem ) {
| |
− | return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex);
| |
− | },
| |
− |
| |
− | // Boolean properties
| |
− | "enabled": createDisabledPseudo( false ),
| |
− | "disabled": createDisabledPseudo( true ),
| |
− |
| |
− | "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);
| |
− | },
| |
− |
| |
− | "selected": function( elem ) {
| |
− | // Accessing this property makes selected-by-default
| |
− | // options in Safari work properly
| |
− | if ( elem.parentNode ) {
| |
− | elem.parentNode.selectedIndex;
| |
− | }
| |
− |
| |
− | return elem.selected === true;
| |
− | },
| |
− |
| |
− | // Contents
| |
− | "empty": function( elem ) {
| |
− | // http://www.w3.org/TR/selectors/#empty-pseudo
| |
− | // :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),
| |
− | // but not by others (comment: 8; processing instruction: 7; etc.)
| |
− | // nodeType < 6 works because attributes (2) do not appear as children
| |
− | for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {
| |
− | if ( elem.nodeType < 6 ) {
| |
− | return false;
| |
− | }
| |
− | }
| |
− | return true;
| |
− | },
| |
− |
| |
− | "parent": function( elem ) {
| |
− | return !Expr.pseudos["empty"]( elem );
| |
− | },
| |
− |
| |
− | // Element/input types
| |
− | "header": function( elem ) {
| |
− | return rheader.test( elem.nodeName );
| |
− | },
| |
− |
| |
− | "input": function( elem ) {
| |
− | return rinputs.test( elem.nodeName );
| |
− | },
| |
− |
| |
− | "button": function( elem ) {
| |
− | var name = elem.nodeName.toLowerCase();
| |
− | return name === "input" && elem.type === "button" || name === "button";
| |
− | },
| |
− |
| |
− | "text": function( elem ) {
| |
− | var attr;
| |
− | return elem.nodeName.toLowerCase() === "input" &&
| |
− | elem.type === "text" &&
| |
− |
| |
− | // Support: IE<8
| |
− | // New HTML5 attribute values (e.g., "search") appear with elem.type === "text"
| |
− | ( (attr = elem.getAttribute("type")) == null || attr.toLowerCase() === "text" );
| |
− | },
| |
− |
| |
− | // Position-in-collection
| |
− | "first": createPositionalPseudo(function() {
| |
− | return [ 0 ];
| |
− | }),
| |
− |
| |
− | "last": createPositionalPseudo(function( matchIndexes, length ) {
| |
− | return [ length - 1 ];
| |
− | }),
| |
− |
| |
− | "eq": createPositionalPseudo(function( matchIndexes, length, argument ) {
| |
− | return [ argument < 0 ? argument + length : argument ];
| |
− | }),
| |
− |
| |
− | "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;
| |
− | }),
| |
− |
| |
− | "lt": createPositionalPseudo(function( matchIndexes, length, argument ) {
| |
− | var i = argument < 0 ? argument + length : argument;
| |
− | for ( ; --i >= 0; ) {
| |
− | matchIndexes.push( i );
| |
− | }
| |
− | return matchIndexes;
| |
− | }),
| |
− |
| |
− | "gt": createPositionalPseudo(function( matchIndexes, length, argument ) {
| |
− | var i = argument < 0 ? argument + length : argument;
| |
− | for ( ; ++i < length; ) {
| |
− | matchIndexes.push( i );
| |
− | }
| |
− | return matchIndexes;
| |
− | })
| |
− | }
| |
− | };
| |
− |
| |
− | 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 );
| |
− | }
| |
− |
| |
− | // Easy API for creating new setFilters
| |
− | function setFilters() {}
| |
− | setFilters.prototype = Expr.filters = Expr.pseudos;
| |
− | Expr.setFilters = new setFilters();
| |
− |
| |
− | tokenize = Sizzle.tokenize = function( selector, parseOnly ) {
| |
− | var matched, match, tokens, type,
| |
− | soFar, groups, preFilters,
| |
− | cached = tokenCache[ selector + " " ];
| |
− |
| |
− | if ( cached ) {
| |
− | return parseOnly ? 0 : cached.slice( 0 );
| |
− | }
| |
− |
| |
− | soFar = selector;
| |
− | groups = [];
| |
− | preFilters = Expr.preFilter;
| |
− |
| |
− | 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 = []) );
| |
− | }
| |
− |
| |
− | matched = 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 );
| |
− | }
| |
− |
| |
− | // 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 );
| |
− | }
| |
− | }
| |
− |
| |
− | if ( !matched ) {
| |
− | break;
| |
− | }
| |
− | }
| |
− |
| |
− | // 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 );
| |
− | };
| |
− |
| |
− | function toSelector( tokens ) {
| |
− | var i = 0,
| |
− | len = tokens.length,
| |
− | selector = "";
| |
− | for ( ; i < len; i++ ) {
| |
− | selector += tokens[i].value;
| |
− | }
| |
− | return selector;
| |
− | }
| |
− |
| |
− | function addCombinator( matcher, combinator, base ) {
| |
− | var dir = combinator.dir,
| |
− | skip = combinator.next,
| |
− | key = skip || dir,
| |
− | checkNonElements = base && key === "parentNode",
| |
− | doneName = done++;
| |
− |
| |
− | 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 );
| |
− | }
| |
− | }
| |
− | return false;
| |
− | } :
| |
− |
| |
− | // Check against all ancestor/preceding elements
| |
− | function( elem, context, xml ) {
| |
− | var oldCache, uniqueCache, outerCache,
| |
− | newCache = [ dirruns, doneName ];
| |
− |
| |
− | // We can't set arbitrary data on XML nodes, so they don't benefit from combinator 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 ] = {});
| |
− |
| |
− | // Support: IE <9 only
| |
− | // Defend against cloned attroperties (jQuery gh-1709)
| |
− | uniqueCache = outerCache[ elem.uniqueID ] || (outerCache[ elem.uniqueID ] = {});
| |
− |
| |
− | if ( skip && skip === elem.nodeName.toLowerCase() ) {
| |
− | elem = elem[ dir ] || elem;
| |
− | } else if ( (oldCache = uniqueCache[ key ]) &&
| |
− | oldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) {
| |
− |
| |
− | // Assign to newCache so results back-propagate to previous elements
| |
− | return (newCache[ 2 ] = oldCache[ 2 ]);
| |
− | } else {
| |
− | // Reuse newcache so results back-propagate to previous elements
| |
− | uniqueCache[ key ] = newCache;
| |
− |
| |
− | // A match means we're done; a fail means we have to keep checking
| |
− | if ( (newCache[ 2 ] = matcher( elem, context, xml )) ) {
| |
− | return true;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | return false;
| |
− | };
| |
− | }
| |
− |
| |
− | 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];
| |
− | }
| |
− |
| |
− | function multipleContexts( selector, contexts, results ) {
| |
− | var i = 0,
| |
− | len = contexts.length;
| |
− | for ( ; i < len; i++ ) {
| |
− | Sizzle( selector, contexts[i], results );
| |
− | }
| |
− | return results;
| |
− | }
| |
− |
| |
− | function condense( unmatched, map, filter, context, xml ) {
| |
− | var elem,
| |
− | newUnmatched = [],
| |
− | i = 0,
| |
− | len = unmatched.length,
| |
− | mapped = map != null;
| |
− |
| |
− | for ( ; i < len; i++ ) {
| |
− | if ( (elem = unmatched[i]) ) {
| |
− | if ( !filter || filter( elem, context, xml ) ) {
| |
− | newUnmatched.push( elem );
| |
− | if ( mapped ) {
| |
− | map.push( i );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return newUnmatched;
| |
− | }
| |
− |
| |
− | 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,
| |
− |
| |
− | // Get initial elements from seed or context
| |
− | elems = seed || multipleContexts( selector || "*", context.nodeType ? [ context ] : context, [] ),
| |
− |
| |
− | // Prefilter to get matcher input, preserving a map for seed-results synchronization
| |
− | matcherIn = preFilter && ( seed || !selector ) ?
| |
− | condense( elems, preMap, preFilter, context, xml ) :
| |
− | elems,
| |
− |
| |
− | matcherOut = matcher ?
| |
− | // If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,
| |
− | postFinder || ( seed ? preFilter : preexisting || postFilter ) ?
| |
− |
| |
− | // ...intermediate processing is necessary
| |
− | [] :
| |
− |
| |
− | // ...otherwise use results directly
| |
− | results :
| |
− | matcherIn;
| |
− |
| |
− | // Find primary matches
| |
− | if ( matcher ) {
| |
− | matcher( matcherIn, matcherOut, context, xml );
| |
− | }
| |
− |
| |
− | // 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);
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | 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 );
| |
− | }
| |
− |
| |
− | // Move matched elements from seed to results to keep them synchronized
| |
− | i = matcherOut.length;
| |
− | while ( i-- ) {
| |
− | if ( (elem = matcherOut[i]) &&
| |
− | (temp = postFinder ? indexOf( 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 );
| |
− | }
| |
− | }
| |
− | });
| |
− | }
| |
− |
| |
− | 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( checkContext, elem ) > -1;
| |
− | }, implicitRelative, true ),
| |
− | matchers = [ function( elem, context, xml ) {
| |
− | var ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (
| |
− | (checkContext = context).nodeType ?
| |
− | matchContext( elem, context, xml ) :
| |
− | matchAnyContext( elem, context, xml ) );
| |
− | // Avoid hanging onto element (issue #299)
| |
− | checkContext = null;
| |
− | return ret;
| |
− | } ];
| |
− |
| |
− | 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 );
| |
− | }
| |
− | }
| |
− |
| |
− | return elementMatcher( matchers );
| |
− | }
| |
− |
| |
− | function matcherFromGroupMatchers( elementMatchers, setMatchers ) {
| |
− | var bySet = setMatchers.length > 0,
| |
− | byElement = elementMatchers.length > 0,
| |
− | superMatcher = function( seed, context, xml, results, outermost ) {
| |
− | var elem, j, matcher,
| |
− | matchedCount = 0,
| |
− | i = "0",
| |
− | unmatched = seed && [],
| |
− | setMatched = [],
| |
− | contextBackup = outermostContext,
| |
− | // We must always have either seed elements or outermost context
| |
− | elems = seed || byElement && Expr.find["TAG"]( "*", outermost ),
| |
− | // Use integer dirruns iff this is the outermost matcher
| |
− | dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1),
| |
− | len = elems.length;
| |
− |
| |
− | if ( outermost ) {
| |
− | outermostContext = context === document || context || outermost;
| |
− | }
| |
− |
| |
− | // Add elements passing elementMatchers directly to results
| |
− | // Support: IE<9, Safari
| |
− | // Tolerate NodeList properties (IE: "length"; Safari: <number>) matching elements by id
| |
− | for ( ; i !== len && (elem = elems[i]) != null; i++ ) {
| |
− | if ( byElement && elem ) {
| |
− | j = 0;
| |
− | if ( !context && elem.ownerDocument !== document ) {
| |
− | setDocument( elem );
| |
− | xml = !documentIsHTML;
| |
− | }
| |
− | while ( (matcher = elementMatchers[j++]) ) {
| |
− | if ( matcher( elem, context || document, xml) ) {
| |
− | results.push( elem );
| |
− | break;
| |
− | }
| |
− | }
| |
− | if ( outermost ) {
| |
− | dirruns = dirrunsUnique;
| |
− | }
| |
− | }
| |
− |
| |
− | // Track unmatched elements for set filters
| |
− | if ( bySet ) {
| |
− | // They will have gone through all possible matchers
| |
− | if ( (elem = !matcher && elem) ) {
| |
− | matchedCount--;
| |
− | }
| |
− |
| |
− | // Lengthen the array for every element, matched or not
| |
− | if ( seed ) {
| |
− | unmatched.push( elem );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // `i` is now the count of elements visited above, and adding it to `matchedCount`
| |
− | // makes the latter nonnegative.
| |
− | matchedCount += i;
| |
− |
| |
− | // Apply set filters to unmatched elements
| |
− | // NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount`
| |
− | // equals `i`), unless we didn't visit _any_ elements in the above loop because we have
| |
− | // no element matchers and no seed.
| |
− | // Incrementing an initially-string "0" `i` allows `i` to remain a string only in that
| |
− | // case, which will result in a "00" `matchedCount` that differs from `i` but is also
| |
− | // numerically zero.
| |
− | 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 );
| |
− | }
| |
− |
| |
− | // 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 );
| |
− | }
| |
− | }
| |
− |
| |
− | // Override manipulation of globals by nested matchers
| |
− | if ( outermost ) {
| |
− | dirruns = dirrunsUnique;
| |
− | outermostContext = contextBackup;
| |
− | }
| |
− |
| |
− | return unmatched;
| |
− | };
| |
− |
| |
− | return bySet ?
| |
− | markFunction( superMatcher ) :
| |
− | superMatcher;
| |
− | }
| |
− |
| |
− | compile = Sizzle.compile = function( selector, match /* 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 ( !match ) {
| |
− | match = tokenize( selector );
| |
− | }
| |
− | i = match.length;
| |
− | while ( i-- ) {
| |
− | cached = matcherFromTokens( match[i] );
| |
− | if ( cached[ expando ] ) {
| |
− | setMatchers.push( cached );
| |
− | } else {
| |
− | elementMatchers.push( cached );
| |
− | }
| |
− | }
| |
− |
| |
− | // Cache the compiled function
| |
− | cached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) );
| |
− |
| |
− | // Save selector and tokenization
| |
− | cached.selector = selector;
| |
− | }
| |
− | return cached;
| |
− | };
| |
− |
| |
− | /**
| |
− | * A low-level selection function that works with Sizzle's compiled
| |
− | * selector functions
| |
− | * @param {String|Function} selector A selector or a pre-compiled
| |
− | * selector function built with Sizzle.compile
| |
− | * @param {Element} context
| |
− | * @param {Array} [results]
| |
− | * @param {Array} [seed] A set of elements to match against
| |
− | */
| |
− | select = Sizzle.select = function( selector, context, results, seed ) {
| |
− | var i, tokens, token, type, find,
| |
− | compiled = typeof selector === "function" && selector,
| |
− | match = !seed && tokenize( (selector = compiled.selector || selector) );
| |
− |
| |
− | results = results || [];
| |
− |
| |
− | // Try to minimize operations if there is only one selector in the list and no seed
| |
− | // (the latter of which guarantees us context)
| |
− | if ( match.length === 1 ) {
| |
− |
| |
− | // Reduce context if the leading compound selector is an ID
| |
− | tokens = match[0] = match[0].slice( 0 );
| |
− | if ( tokens.length > 2 && (token = tokens[0]).type === "ID" &&
| |
− | context.nodeType === 9 && documentIsHTML && Expr.relative[ tokens[1].type ] ) {
| |
− |
| |
− | context = ( Expr.find["ID"]( token.matches[0].replace(runescape, funescape), context ) || [] )[0];
| |
− | if ( !context ) {
| |
− | return results;
| |
− |
| |
− | // Precompiled matchers will still verify ancestry, so step up a level
| |
− | } else if ( compiled ) {
| |
− | context = context.parentNode;
| |
− | }
| |
− |
| |
− | selector = selector.slice( tokens.shift().value.length );
| |
− | }
| |
− |
| |
− | // Fetch a seed set for right-to-left matching
| |
− | i = matchExpr["needsContext"].test( selector ) ? 0 : tokens.length;
| |
− | while ( i-- ) {
| |
− | token = tokens[i];
| |
− |
| |
− | // 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 ) && testContext( context.parentNode ) || context
| |
− | )) ) {
| |
− |
| |
− | // 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;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Compile and execute a filtering function if one is not provided
| |
− | // Provide `match` to avoid retokenization if we modified the selector above
| |
− | ( compiled || compile( selector, match ) )(
| |
− | seed,
| |
− | context,
| |
− | !documentIsHTML,
| |
− | results,
| |
− | !context || rsibling.test( selector ) && testContext( context.parentNode ) || context
| |
− | );
| |
− | return results;
| |
− | };
| |
− |
| |
− | // One-time assignments
| |
− |
| |
− | // Sort stability
| |
− | support.sortStable = expando.split("").sort( sortOrder ).join("") === expando;
| |
− |
| |
− | // Support: Chrome 14-35+
| |
− | // Always assume duplicates if they aren't passed to the comparison function
| |
− | support.detectDuplicates = !!hasDuplicate;
| |
− |
| |
− | // Initialize against the default document
| |
− | setDocument();
| |
− |
| |
− | // Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)
| |
− | // Detached nodes confoundingly follow *each other*
| |
− | support.sortDetached = assert(function( el ) {
| |
− | // Should return 1, but returns 4 (following)
| |
− | return el.compareDocumentPosition( document.createElement("fieldset") ) & 1;
| |
− | });
| |
− |
| |
− | // Support: IE<8
| |
− | // Prevent attribute/property "interpolation"
| |
− | // https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx
| |
− | if ( !assert(function( el ) {
| |
− | el.innerHTML = "<a href='#'></a>";
| |
− | return el.firstChild.getAttribute("href") === "#" ;
| |
− | }) ) {
| |
− | addHandle( "type|href|height|width", function( elem, name, isXML ) {
| |
− | if ( !isXML ) {
| |
− | return elem.getAttribute( name, name.toLowerCase() === "type" ? 1 : 2 );
| |
− | }
| |
− | });
| |
− | }
| |
− |
| |
− | // Support: IE<9
| |
− | // Use defaultValue in place of getAttribute("value")
| |
− | if ( !support.attributes || !assert(function( el ) {
| |
− | el.innerHTML = "<input/>";
| |
− | el.firstChild.setAttribute( "value", "" );
| |
− | return el.firstChild.getAttribute( "value" ) === "";
| |
− | }) ) {
| |
− | addHandle( "value", function( elem, name, isXML ) {
| |
− | if ( !isXML && elem.nodeName.toLowerCase() === "input" ) {
| |
− | return elem.defaultValue;
| |
− | }
| |
− | });
| |
− | }
| |
− |
| |
− | // Support: IE<9
| |
− | // Use getAttributeNode to fetch booleans when getAttribute lies
| |
− | if ( !assert(function( el ) {
| |
− | return el.getAttribute("disabled") == null;
| |
− | }) ) {
| |
− | addHandle( booleans, function( elem, name, isXML ) {
| |
− | var val;
| |
− | if ( !isXML ) {
| |
− | return elem[ name ] === true ? name.toLowerCase() :
| |
− | (val = elem.getAttributeNode( name )) && val.specified ?
| |
− | val.value :
| |
− | null;
| |
− | }
| |
− | });
| |
− | }
| |
− |
| |
− | return Sizzle;
| |
− |
| |
− | })( window );
| |
− |
| |
− |
| |
− |
| |
− | jQuery.find = Sizzle;
| |
− | jQuery.expr = Sizzle.selectors;
| |
− |
| |
− | // Deprecated
| |
− | jQuery.expr[ ":" ] = jQuery.expr.pseudos;
| |
− | jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort;
| |
− | jQuery.text = Sizzle.getText;
| |
− | jQuery.isXMLDoc = Sizzle.isXML;
| |
− | jQuery.contains = Sizzle.contains;
| |
− | jQuery.escapeSelector = Sizzle.escape;
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | var dir = function( elem, dir, until ) {
| |
− | var matched = [],
| |
− | truncate = until !== undefined;
| |
− |
| |
− | while ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) {
| |
− | if ( elem.nodeType === 1 ) {
| |
− | if ( truncate && jQuery( elem ).is( until ) ) {
| |
− | break;
| |
− | }
| |
− | matched.push( elem );
| |
− | }
| |
− | }
| |
− | return matched;
| |
− | };
| |
− |
| |
− |
| |
− | var siblings = function( n, elem ) {
| |
− | var matched = [];
| |
− |
| |
− | for ( ; n; n = n.nextSibling ) {
| |
− | if ( n.nodeType === 1 && n !== elem ) {
| |
− | matched.push( n );
| |
− | }
| |
− | }
| |
− |
| |
− | return matched;
| |
− | };
| |
− |
| |
− |
| |
− | var rneedsContext = jQuery.expr.match.needsContext;
| |
− |
| |
− |
| |
− |
| |
− | function nodeName( elem, name ) {
| |
− |
| |
− | return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();
| |
− |
| |
− | };
| |
− | var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i );
| |
− |
| |
− |
| |
− |
| |
− | // Implement the identical functionality for filter and not
| |
− | function winnow( elements, qualifier, not ) {
| |
− | if ( isFunction( qualifier ) ) {
| |
− | return jQuery.grep( elements, function( elem, i ) {
| |
− | return !!qualifier.call( elem, i, elem ) !== not;
| |
− | } );
| |
− | }
| |
− |
| |
− | // Single element
| |
− | if ( qualifier.nodeType ) {
| |
− | return jQuery.grep( elements, function( elem ) {
| |
− | return ( elem === qualifier ) !== not;
| |
− | } );
| |
− | }
| |
− |
| |
− | // Arraylike of elements (jQuery, arguments, Array)
| |
− | if ( typeof qualifier !== "string" ) {
| |
− | return jQuery.grep( elements, function( elem ) {
| |
− | return ( indexOf.call( qualifier, elem ) > -1 ) !== not;
| |
− | } );
| |
− | }
| |
− |
| |
− | // Filtered directly for both simple and complex selectors
| |
− | return jQuery.filter( qualifier, elements, not );
| |
− | }
| |
− |
| |
− | jQuery.filter = function( expr, elems, not ) {
| |
− | var elem = elems[ 0 ];
| |
− |
| |
− | if ( not ) {
| |
− | expr = ":not(" + expr + ")";
| |
− | }
| |
− |
| |
− | if ( elems.length === 1 && elem.nodeType === 1 ) {
| |
− | return jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [];
| |
− | }
| |
− |
| |
− | return jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) {
| |
− | return elem.nodeType === 1;
| |
− | } ) );
| |
− | };
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | find: function( selector ) {
| |
− | var i, ret,
| |
− | len = this.length,
| |
− | self = this;
| |
− |
| |
− | if ( typeof selector !== "string" ) {
| |
− | return this.pushStack( jQuery( selector ).filter( function() {
| |
− | for ( i = 0; i < len; i++ ) {
| |
− | if ( jQuery.contains( self[ i ], this ) ) {
| |
− | return true;
| |
− | }
| |
− | }
| |
− | } ) );
| |
− | }
| |
− |
| |
− | ret = this.pushStack( [] );
| |
− |
| |
− | for ( i = 0; i < len; i++ ) {
| |
− | jQuery.find( selector, self[ i ], ret );
| |
− | }
| |
− |
| |
− | return len > 1 ? jQuery.uniqueSort( ret ) : ret;
| |
− | },
| |
− | filter: function( selector ) {
| |
− | return this.pushStack( winnow( this, selector || [], false ) );
| |
− | },
| |
− | not: function( selector ) {
| |
− | return this.pushStack( winnow( this, selector || [], true ) );
| |
− | },
| |
− | is: function( selector ) {
| |
− | 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;
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | // Initialize a jQuery object
| |
− |
| |
− |
| |
− | // A central reference to the root jQuery(document)
| |
− | var rootjQuery,
| |
− |
| |
− | // 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 <)
| |
− | // Shortcut simple #id case for speed
| |
− | rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,
| |
− |
| |
− | init = jQuery.fn.init = function( selector, context, root ) {
| |
− | var match, elem;
| |
− |
| |
− | // HANDLE: $(""), $(null), $(undefined), $(false)
| |
− | if ( !selector ) {
| |
− | return this;
| |
− | }
| |
− |
| |
− | // Method init() accepts an alternate rootjQuery
| |
− | // so migrate can support jQuery.sub (gh-2101)
| |
− | root = root || rootjQuery;
| |
− |
| |
− | // Handle HTML strings
| |
− | if ( typeof selector === "string" ) {
| |
− | if ( selector[ 0 ] === "<" &&
| |
− | selector[ selector.length - 1 ] === ">" &&
| |
− | selector.length >= 3 ) {
| |
− |
| |
− | // Assume that strings that start and end with <> are HTML and skip the regex check
| |
− | match = [ null, selector, null ];
| |
− |
| |
− | } else {
| |
− | match = rquickExpr.exec( selector );
| |
− | }
| |
− |
| |
− | // Match html or make sure no context is specified for #id
| |
− | if ( match && ( match[ 1 ] || !context ) ) {
| |
− |
| |
− | // HANDLE: $(html) -> $(array)
| |
− | if ( match[ 1 ] ) {
| |
− | context = context instanceof jQuery ? context[ 0 ] : context;
| |
− |
| |
− | // Option to run scripts is true for back-compat
| |
− | // Intentionally let the error be thrown if parseHTML is not present
| |
− | jQuery.merge( this, jQuery.parseHTML(
| |
− | match[ 1 ],
| |
− | context && context.nodeType ? context.ownerDocument || context : document,
| |
− | true
| |
− | ) );
| |
− |
| |
− | // HANDLE: $(html, props)
| |
− | if ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) {
| |
− | for ( match in context ) {
| |
− |
| |
− | // Properties of context are called as methods if possible
| |
− | if ( isFunction( this[ match ] ) ) {
| |
− | this[ match ]( context[ match ] );
| |
− |
| |
− | // ...and otherwise set as attributes
| |
− | } else {
| |
− | this.attr( match, context[ match ] );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return this;
| |
− |
| |
− | // HANDLE: $(#id)
| |
− | } else {
| |
− | elem = document.getElementById( match[ 2 ] );
| |
− |
| |
− | if ( elem ) {
| |
− |
| |
− | // Inject the element directly into the jQuery object
| |
− | this[ 0 ] = elem;
| |
− | this.length = 1;
| |
− | }
| |
− | return this;
| |
− | }
| |
− |
| |
− | // HANDLE: $(expr, $(...))
| |
− | } else if ( !context || context.jquery ) {
| |
− | return ( context || root ).find( selector );
| |
− |
| |
− | // HANDLE: $(expr, context)
| |
− | // (which is just equivalent to: $(context).find(expr)
| |
− | } else {
| |
− | return this.constructor( context ).find( selector );
| |
− | }
| |
− |
| |
− | // HANDLE: $(DOMElement)
| |
− | } else if ( selector.nodeType ) {
| |
− | this[ 0 ] = selector;
| |
− | this.length = 1;
| |
− | return this;
| |
− |
| |
− | // HANDLE: $(function)
| |
− | // Shortcut for document ready
| |
− | } else if ( isFunction( selector ) ) {
| |
− | return root.ready !== undefined ?
| |
− | root.ready( selector ) :
| |
− |
| |
− | // Execute immediately if ready is not present
| |
− | selector( jQuery );
| |
− | }
| |
− |
| |
− | return jQuery.makeArray( selector, this );
| |
− | };
| |
− |
| |
− | // Give the init function the jQuery prototype for later instantiation
| |
− | init.prototype = jQuery.fn;
| |
− |
| |
− | // Initialize central reference
| |
− | rootjQuery = jQuery( document );
| |
− |
| |
− |
| |
− | var rparentsprev = /^(?:parents|prev(?:Until|All))/,
| |
− |
| |
− | // Methods guaranteed to produce a unique set when starting from a unique set
| |
− | guaranteedUnique = {
| |
− | children: true,
| |
− | contents: true,
| |
− | next: true,
| |
− | prev: true
| |
− | };
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | has: function( target ) {
| |
− | var targets = jQuery( target, this ),
| |
− | l = targets.length;
| |
− |
| |
− | return this.filter( function() {
| |
− | var i = 0;
| |
− | for ( ; i < l; i++ ) {
| |
− | if ( jQuery.contains( this, targets[ i ] ) ) {
| |
− | return true;
| |
− | }
| |
− | }
| |
− | } );
| |
− | },
| |
− |
| |
− | closest: function( selectors, context ) {
| |
− | var cur,
| |
− | i = 0,
| |
− | l = this.length,
| |
− | matched = [],
| |
− | targets = typeof selectors !== "string" && jQuery( selectors );
| |
− |
| |
− | // Positional selectors never match, since there's no _selection_ context
| |
− | if ( !rneedsContext.test( selectors ) ) {
| |
− | for ( ; i < l; i++ ) {
| |
− | for ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) {
| |
− |
| |
− | // Always skip document fragments
| |
− | if ( cur.nodeType < 11 && ( targets ?
| |
− | targets.index( cur ) > -1 :
| |
− |
| |
− | // Don't pass non-elements to Sizzle
| |
− | cur.nodeType === 1 &&
| |
− | jQuery.find.matchesSelector( cur, selectors ) ) ) {
| |
− |
| |
− | matched.push( cur );
| |
− | break;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return this.pushStack( matched.length > 1 ? jQuery.uniqueSort( matched ) : matched );
| |
− | },
| |
− |
| |
− | // Determine the position of an element within the set
| |
− | index: function( elem ) {
| |
− |
| |
− | // No argument, return index in parent
| |
− | if ( !elem ) {
| |
− | return ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1;
| |
− | }
| |
− |
| |
− | // Index in selector
| |
− | if ( typeof elem === "string" ) {
| |
− | return indexOf.call( jQuery( elem ), this[ 0 ] );
| |
− | }
| |
− |
| |
− | // Locate the position of the desired element
| |
− | return indexOf.call( this,
| |
− |
| |
− | // If it receives a jQuery object, the first element is used
| |
− | elem.jquery ? elem[ 0 ] : elem
| |
− | );
| |
− | },
| |
− |
| |
− | add: function( selector, context ) {
| |
− | return this.pushStack(
| |
− | jQuery.uniqueSort(
| |
− | jQuery.merge( this.get(), jQuery( selector, context ) )
| |
− | )
| |
− | );
| |
− | },
| |
− |
| |
− | addBack: function( selector ) {
| |
− | return this.add( selector == null ?
| |
− | this.prevObject : this.prevObject.filter( selector )
| |
− | );
| |
− | }
| |
− | } );
| |
− |
| |
− | function sibling( cur, dir ) {
| |
− | while ( ( cur = cur[ dir ] ) && cur.nodeType !== 1 ) {}
| |
− | return cur;
| |
− | }
| |
− |
| |
− | jQuery.each( {
| |
− | parent: function( elem ) {
| |
− | var parent = elem.parentNode;
| |
− | return parent && parent.nodeType !== 11 ? parent : null;
| |
− | },
| |
− | parents: function( elem ) {
| |
− | return dir( elem, "parentNode" );
| |
− | },
| |
− | parentsUntil: function( elem, i, until ) {
| |
− | return dir( elem, "parentNode", until );
| |
− | },
| |
− | next: function( elem ) {
| |
− | return sibling( elem, "nextSibling" );
| |
− | },
| |
− | prev: function( elem ) {
| |
− | return sibling( elem, "previousSibling" );
| |
− | },
| |
− | nextAll: function( elem ) {
| |
− | return dir( elem, "nextSibling" );
| |
− | },
| |
− | prevAll: function( elem ) {
| |
− | return dir( elem, "previousSibling" );
| |
− | },
| |
− | nextUntil: function( elem, i, until ) {
| |
− | return dir( elem, "nextSibling", until );
| |
− | },
| |
− | prevUntil: function( elem, i, until ) {
| |
− | return dir( elem, "previousSibling", until );
| |
− | },
| |
− | siblings: function( elem ) {
| |
− | return siblings( ( elem.parentNode || {} ).firstChild, elem );
| |
− | },
| |
− | children: function( elem ) {
| |
− | return siblings( elem.firstChild );
| |
− | },
| |
− | contents: function( elem ) {
| |
− | if ( nodeName( elem, "iframe" ) ) {
| |
− | return elem.contentDocument;
| |
− | }
| |
− |
| |
− | // Support: IE 9 - 11 only, iOS 7 only, Android Browser <=4.3 only
| |
− | // Treat the template element as a regular one in browsers that
| |
− | // don't support it.
| |
− | if ( nodeName( elem, "template" ) ) {
| |
− | elem = elem.content || elem;
| |
− | }
| |
− |
| |
− | return jQuery.merge( [], elem.childNodes );
| |
− | }
| |
− | }, function( name, fn ) {
| |
− | jQuery.fn[ name ] = function( until, selector ) {
| |
− | var matched = jQuery.map( this, fn, until );
| |
− |
| |
− | if ( name.slice( -5 ) !== "Until" ) {
| |
− | selector = until;
| |
− | }
| |
− |
| |
− | if ( selector && typeof selector === "string" ) {
| |
− | matched = jQuery.filter( selector, matched );
| |
− | }
| |
− |
| |
− | if ( this.length > 1 ) {
| |
− |
| |
− | // Remove duplicates
| |
− | if ( !guaranteedUnique[ name ] ) {
| |
− | jQuery.uniqueSort( matched );
| |
− | }
| |
− |
| |
− | // Reverse order for parents* and prev-derivatives
| |
− | if ( rparentsprev.test( name ) ) {
| |
− | matched.reverse();
| |
− | }
| |
− | }
| |
− |
| |
− | return this.pushStack( matched );
| |
− | };
| |
− | } );
| |
− | var rnothtmlwhite = ( /[^\x20\t\r\n\f]+/g );
| |
− |
| |
− |
| |
− |
| |
− | // Convert String-formatted options into Object-formatted ones
| |
− | function createOptions( options ) {
| |
− | var object = {};
| |
− | jQuery.each( options.match( rnothtmlwhite ) || [], 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" ?
| |
− | 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,
| |
− |
| |
− | // Flag to prevent firing
| |
− | locked,
| |
− |
| |
− | // Actual callback list
| |
− | list = [],
| |
− |
| |
− | // Queue of execution data for repeatable lists
| |
− | queue = [],
| |
− |
| |
− | // Index of currently firing callback (modified by add/remove as needed)
| |
− | firingIndex = -1,
| |
− |
| |
− | // Fire callbacks
| |
− | fire = function() {
| |
− |
| |
− | // Enforce single-firing
| |
− | locked = locked || options.once;
| |
− |
| |
− | // Execute callbacks for all pending executions,
| |
− | // respecting firingIndex overrides and runtime changes
| |
− | fired = firing = true;
| |
− | for ( ; queue.length; firingIndex = -1 ) {
| |
− | memory = queue.shift();
| |
− | while ( ++firingIndex < list.length ) {
| |
− |
| |
− | // Run callback and check for early termination
| |
− | if ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false &&
| |
− | options.stopOnFalse ) {
| |
− |
| |
− | // Jump to end and forget the data so .add doesn't re-fire
| |
− | firingIndex = list.length;
| |
− | memory = false;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Forget the data if we're done with it
| |
− | if ( !options.memory ) {
| |
− | memory = false;
| |
− | }
| |
− |
| |
− | firing = false;
| |
− |
| |
− | // Clean up if we're done firing for good
| |
− | if ( locked ) {
| |
− |
| |
− | // Keep an empty list if we have data for future add calls
| |
− | if ( memory ) {
| |
− | list = [];
| |
− |
| |
− | // Otherwise, this object is spent
| |
− | } else {
| |
− | list = "";
| |
− | }
| |
− | }
| |
− | },
| |
− |
| |
− | // Actual Callbacks object
| |
− | self = {
| |
− |
| |
− | // Add a callback or a collection of callbacks to the list
| |
− | add: function() {
| |
− | if ( list ) {
| |
− |
| |
− | // If we have memory from a past run, we should fire after adding
| |
− | if ( memory && !firing ) {
| |
− | firingIndex = list.length - 1;
| |
− | queue.push( memory );
| |
− | }
| |
− |
| |
− | ( function add( args ) {
| |
− | jQuery.each( args, function( _, arg ) {
| |
− | if ( isFunction( arg ) ) {
| |
− | if ( !options.unique || !self.has( arg ) ) {
| |
− | list.push( arg );
| |
− | }
| |
− | } else if ( arg && arg.length && toType( arg ) !== "string" ) {
| |
− |
| |
− | // Inspect recursively
| |
− | add( arg );
| |
− | }
| |
− | } );
| |
− | } )( arguments );
| |
− |
| |
− | if ( memory && !firing ) {
| |
− | fire();
| |
− | }
| |
− | }
| |
− | return this;
| |
− | },
| |
− |
| |
− | // Remove a callback from the list
| |
− | remove: function() {
| |
− | jQuery.each( arguments, function( _, arg ) {
| |
− | var index;
| |
− | while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) {
| |
− | list.splice( index, 1 );
| |
− |
| |
− | // Handle firing indexes
| |
− | 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.length > 0;
| |
− | },
| |
− |
| |
− | // Remove all callbacks from the list
| |
− | empty: function() {
| |
− | if ( list ) {
| |
− | list = [];
| |
− | }
| |
− | return this;
| |
− | },
| |
− |
| |
− | // Disable .fire and .add
| |
− | // Abort any current/pending executions
| |
− | // Clear all callbacks and values
| |
− | disable: function() {
| |
− | locked = queue = [];
| |
− | list = memory = "";
| |
− | return this;
| |
− | },
| |
− | disabled: function() {
| |
− | return !list;
| |
− | },
| |
− |
| |
− | // Disable .fire
| |
− | // Also disable .add unless we have memory (since it would have no effect)
| |
− | // Abort any pending executions
| |
− | lock: function() {
| |
− | locked = queue = [];
| |
− | if ( !memory && !firing ) {
| |
− | list = memory = "";
| |
− | }
| |
− | return this;
| |
− | },
| |
− | locked: function() {
| |
− | return !!locked;
| |
− | },
| |
− |
| |
− | // Call all callbacks with the given context and arguments
| |
− | fireWith: function( context, args ) {
| |
− | if ( !locked ) {
| |
− | args = args || [];
| |
− | args = [ context, args.slice ? args.slice() : args ];
| |
− | queue.push( args );
| |
− | if ( !firing ) {
| |
− | fire();
| |
− | }
| |
− | }
| |
− | 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;
| |
− | };
| |
− |
| |
− |
| |
− | function Identity( v ) {
| |
− | return v;
| |
− | }
| |
− | function Thrower( ex ) {
| |
− | throw ex;
| |
− | }
| |
− |
| |
− | function adoptValue( value, resolve, reject, noValue ) {
| |
− | var method;
| |
− |
| |
− | try {
| |
− |
| |
− | // Check for promise aspect first to privilege synchronous behavior
| |
− | if ( value && isFunction( ( method = value.promise ) ) ) {
| |
− | method.call( value ).done( resolve ).fail( reject );
| |
− |
| |
− | // Other thenables
| |
− | } else if ( value && isFunction( ( method = value.then ) ) ) {
| |
− | method.call( value, resolve, reject );
| |
− |
| |
− | // Other non-thenables
| |
− | } else {
| |
− |
| |
− | // Control `resolve` arguments by letting Array#slice cast boolean `noValue` to integer:
| |
− | // * false: [ value ].slice( 0 ) => resolve( value )
| |
− | // * true: [ value ].slice( 1 ) => resolve()
| |
− | resolve.apply( undefined, [ value ].slice( noValue ) );
| |
− | }
| |
− |
| |
− | // For Promises/A+, convert exceptions into rejections
| |
− | // Since jQuery.when doesn't unwrap thenables, we can skip the extra checks appearing in
| |
− | // Deferred#then to conditionally suppress rejection.
| |
− | } catch ( value ) {
| |
− |
| |
− | // Support: Android 4.0 only
| |
− | // Strict mode functions invoked without .call/.apply get global-object context
| |
− | reject.apply( undefined, [ value ] );
| |
− | }
| |
− | }
| |
− |
| |
− | jQuery.extend( {
| |
− |
| |
− | Deferred: function( func ) {
| |
− | var tuples = [
| |
− |
| |
− | // action, add listener, callbacks,
| |
− | // ... .then handlers, argument index, [final state]
| |
− | [ "notify", "progress", jQuery.Callbacks( "memory" ),
| |
− | jQuery.Callbacks( "memory" ), 2 ],
| |
− | [ "resolve", "done", jQuery.Callbacks( "once memory" ),
| |
− | jQuery.Callbacks( "once memory" ), 0, "resolved" ],
| |
− | [ "reject", "fail", jQuery.Callbacks( "once memory" ),
| |
− | jQuery.Callbacks( "once memory" ), 1, "rejected" ]
| |
− | ],
| |
− | state = "pending",
| |
− | promise = {
| |
− | state: function() {
| |
− | return state;
| |
− | },
| |
− | always: function() {
| |
− | deferred.done( arguments ).fail( arguments );
| |
− | return this;
| |
− | },
| |
− | "catch": function( fn ) {
| |
− | return promise.then( null, fn );
| |
− | },
| |
− |
| |
− | // Keep pipe for back-compat
| |
− | pipe: function( /* fnDone, fnFail, fnProgress */ ) {
| |
− | var fns = arguments;
| |
− |
| |
− | return jQuery.Deferred( function( newDefer ) {
| |
− | jQuery.each( tuples, function( i, tuple ) {
| |
− |
| |
− | // Map tuples (progress, done, fail) to arguments (done, fail, progress)
| |
− | var fn = isFunction( fns[ tuple[ 4 ] ] ) && fns[ tuple[ 4 ] ];
| |
− |
| |
− | // deferred.progress(function() { bind to newDefer or newDefer.notify })
| |
− | // deferred.done(function() { bind to newDefer or newDefer.resolve })
| |
− | // deferred.fail(function() { bind to newDefer or newDefer.reject })
| |
− | deferred[ tuple[ 1 ] ]( function() {
| |
− | var returned = fn && fn.apply( this, arguments );
| |
− | if ( returned && isFunction( returned.promise ) ) {
| |
− | returned.promise()
| |
− | .progress( newDefer.notify )
| |
− | .done( newDefer.resolve )
| |
− | .fail( newDefer.reject );
| |
− | } else {
| |
− | newDefer[ tuple[ 0 ] + "With" ](
| |
− | this,
| |
− | fn ? [ returned ] : arguments
| |
− | );
| |
− | }
| |
− | } );
| |
− | } );
| |
− | fns = null;
| |
− | } ).promise();
| |
− | },
| |
− | then: function( onFulfilled, onRejected, onProgress ) {
| |
− | var maxDepth = 0;
| |
− | function resolve( depth, deferred, handler, special ) {
| |
− | return function() {
| |
− | var that = this,
| |
− | args = arguments,
| |
− | mightThrow = function() {
| |
− | var returned, then;
| |
− |
| |
− | // Support: Promises/A+ section 2.3.3.3.3
| |
− | // https://promisesaplus.com/#point-59
| |
− | // Ignore double-resolution attempts
| |
− | if ( depth < maxDepth ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | returned = handler.apply( that, args );
| |
− |
| |
− | // Support: Promises/A+ section 2.3.1
| |
− | // https://promisesaplus.com/#point-48
| |
− | if ( returned === deferred.promise() ) {
| |
− | throw new TypeError( "Thenable self-resolution" );
| |
− | }
| |
− |
| |
− | // Support: Promises/A+ sections 2.3.3.1, 3.5
| |
− | // https://promisesaplus.com/#point-54
| |
− | // https://promisesaplus.com/#point-75
| |
− | // Retrieve `then` only once
| |
− | then = returned &&
| |
− |
| |
− | // Support: Promises/A+ section 2.3.4
| |
− | // https://promisesaplus.com/#point-64
| |
− | // Only check objects and functions for thenability
| |
− | ( typeof returned === "object" ||
| |
− | typeof returned === "function" ) &&
| |
− | returned.then;
| |
− |
| |
− | // Handle a returned thenable
| |
− | if ( isFunction( then ) ) {
| |
− |
| |
− | // Special processors (notify) just wait for resolution
| |
− | if ( special ) {
| |
− | then.call(
| |
− | returned,
| |
− | resolve( maxDepth, deferred, Identity, special ),
| |
− | resolve( maxDepth, deferred, Thrower, special )
| |
− | );
| |
− |
| |
− | // Normal processors (resolve) also hook into progress
| |
− | } else {
| |
− |
| |
− | // ...and disregard older resolution values
| |
− | maxDepth++;
| |
− |
| |
− | then.call(
| |
− | returned,
| |
− | resolve( maxDepth, deferred, Identity, special ),
| |
− | resolve( maxDepth, deferred, Thrower, special ),
| |
− | resolve( maxDepth, deferred, Identity,
| |
− | deferred.notifyWith )
| |
− | );
| |
− | }
| |
− |
| |
− | // Handle all other returned values
| |
− | } else {
| |
− |
| |
− | // Only substitute handlers pass on context
| |
− | // and multiple values (non-spec behavior)
| |
− | if ( handler !== Identity ) {
| |
− | that = undefined;
| |
− | args = [ returned ];
| |
− | }
| |
− |
| |
− | // Process the value(s)
| |
− | // Default process is resolve
| |
− | ( special || deferred.resolveWith )( that, args );
| |
− | }
| |
− | },
| |
− |
| |
− | // Only normal processors (resolve) catch and reject exceptions
| |
− | process = special ?
| |
− | mightThrow :
| |
− | function() {
| |
− | try {
| |
− | mightThrow();
| |
− | } catch ( e ) {
| |
− |
| |
− | if ( jQuery.Deferred.exceptionHook ) {
| |
− | jQuery.Deferred.exceptionHook( e,
| |
− | process.stackTrace );
| |
− | }
| |
− |
| |
− | // Support: Promises/A+ section 2.3.3.3.4.1
| |
− | // https://promisesaplus.com/#point-61
| |
− | // Ignore post-resolution exceptions
| |
− | if ( depth + 1 >= maxDepth ) {
| |
− |
| |
− | // Only substitute handlers pass on context
| |
− | // and multiple values (non-spec behavior)
| |
− | if ( handler !== Thrower ) {
| |
− | that = undefined;
| |
− | args = [ e ];
| |
− | }
| |
− |
| |
− | deferred.rejectWith( that, args );
| |
− | }
| |
− | }
| |
− | };
| |
− |
| |
− | // Support: Promises/A+ section 2.3.3.3.1
| |
− | // https://promisesaplus.com/#point-57
| |
− | // Re-resolve promises immediately to dodge false rejection from
| |
− | // subsequent errors
| |
− | if ( depth ) {
| |
− | process();
| |
− | } else {
| |
− |
| |
− | // Call an optional hook to record the stack, in case of exception
| |
− | // since it's otherwise lost when execution goes async
| |
− | if ( jQuery.Deferred.getStackHook ) {
| |
− | process.stackTrace = jQuery.Deferred.getStackHook();
| |
− | }
| |
− | window.setTimeout( process );
| |
− | }
| |
− | };
| |
− | }
| |
− |
| |
− | return jQuery.Deferred( function( newDefer ) {
| |
− |
| |
− | // progress_handlers.add( ... )
| |
− | tuples[ 0 ][ 3 ].add(
| |
− | resolve(
| |
− | 0,
| |
− | newDefer,
| |
− | isFunction( onProgress ) ?
| |
− | onProgress :
| |
− | Identity,
| |
− | newDefer.notifyWith
| |
− | )
| |
− | );
| |
− |
| |
− | // fulfilled_handlers.add( ... )
| |
− | tuples[ 1 ][ 3 ].add(
| |
− | resolve(
| |
− | 0,
| |
− | newDefer,
| |
− | isFunction( onFulfilled ) ?
| |
− | onFulfilled :
| |
− | Identity
| |
− | )
| |
− | );
| |
− |
| |
− | // rejected_handlers.add( ... )
| |
− | tuples[ 2 ][ 3 ].add(
| |
− | resolve(
| |
− | 0,
| |
− | newDefer,
| |
− | isFunction( onRejected ) ?
| |
− | onRejected :
| |
− | Thrower
| |
− | )
| |
− | );
| |
− | } ).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 = {};
| |
− |
| |
− | // Add list-specific methods
| |
− | jQuery.each( tuples, function( i, tuple ) {
| |
− | var list = tuple[ 2 ],
| |
− | stateString = tuple[ 5 ];
| |
− |
| |
− | // promise.progress = list.add
| |
− | // promise.done = list.add
| |
− | // promise.fail = list.add
| |
− | promise[ tuple[ 1 ] ] = list.add;
| |
− |
| |
− | // Handle state
| |
− | if ( stateString ) {
| |
− | list.add(
| |
− | function() {
| |
− |
| |
− | // state = "resolved" (i.e., fulfilled)
| |
− | // state = "rejected"
| |
− | state = stateString;
| |
− | },
| |
− |
| |
− | // rejected_callbacks.disable
| |
− | // fulfilled_callbacks.disable
| |
− | tuples[ 3 - i ][ 2 ].disable,
| |
− |
| |
− | // rejected_handlers.disable
| |
− | // fulfilled_handlers.disable
| |
− | tuples[ 3 - i ][ 3 ].disable,
| |
− |
| |
− | // progress_callbacks.lock
| |
− | tuples[ 0 ][ 2 ].lock,
| |
− |
| |
− | // progress_handlers.lock
| |
− | tuples[ 0 ][ 3 ].lock
| |
− | );
| |
− | }
| |
− |
| |
− | // progress_handlers.fire
| |
− | // fulfilled_handlers.fire
| |
− | // rejected_handlers.fire
| |
− | list.add( tuple[ 3 ].fire );
| |
− |
| |
− | // deferred.notify = function() { deferred.notifyWith(...) }
| |
− | // deferred.resolve = function() { deferred.resolveWith(...) }
| |
− | // deferred.reject = function() { deferred.rejectWith(...) }
| |
− | deferred[ tuple[ 0 ] ] = function() {
| |
− | deferred[ tuple[ 0 ] + "With" ]( this === deferred ? undefined : this, arguments );
| |
− | return this;
| |
− | };
| |
− |
| |
− | // deferred.notifyWith = list.fireWith
| |
− | // deferred.resolveWith = list.fireWith
| |
− | // deferred.rejectWith = list.fireWith
| |
− | 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 );
| |
− | }
| |
− |
| |
− | // All done!
| |
− | return deferred;
| |
− | },
| |
− |
| |
− | // Deferred helper
| |
− | when: function( singleValue ) {
| |
− | var
| |
− |
| |
− | // count of uncompleted subordinates
| |
− | remaining = arguments.length,
| |
− |
| |
− | // count of unprocessed arguments
| |
− | i = remaining,
| |
− |
| |
− | // subordinate fulfillment data
| |
− | resolveContexts = Array( i ),
| |
− | resolveValues = slice.call( arguments ),
| |
− |
| |
− | // the master Deferred
| |
− | master = jQuery.Deferred(),
| |
− |
| |
− | // subordinate callback factory
| |
− | updateFunc = function( i ) {
| |
− | return function( value ) {
| |
− | resolveContexts[ i ] = this;
| |
− | resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;
| |
− | if ( !( --remaining ) ) {
| |
− | master.resolveWith( resolveContexts, resolveValues );
| |
− | }
| |
− | };
| |
− | };
| |
− |
| |
− | // Single- and empty arguments are adopted like Promise.resolve
| |
− | if ( remaining <= 1 ) {
| |
− | adoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject,
| |
− | !remaining );
| |
− |
| |
− | // Use .then() to unwrap secondary thenables (cf. gh-3000)
| |
− | if ( master.state() === "pending" ||
| |
− | isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) {
| |
− |
| |
− | return master.then();
| |
− | }
| |
− | }
| |
− |
| |
− | // Multiple arguments are aggregated like Promise.all array elements
| |
− | while ( i-- ) {
| |
− | adoptValue( resolveValues[ i ], updateFunc( i ), master.reject );
| |
− | }
| |
− |
| |
− | return master.promise();
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | // These usually indicate a programmer mistake during development,
| |
− | // warn about them ASAP rather than swallowing them by default.
| |
− | var rerrorNames = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;
| |
− |
| |
− | jQuery.Deferred.exceptionHook = function( error, stack ) {
| |
− |
| |
− | // Support: IE 8 - 9 only
| |
− | // Console exists when dev tools are open, which can happen at any time
| |
− | if ( window.console && window.console.warn && error && rerrorNames.test( error.name ) ) {
| |
− | window.console.warn( "jQuery.Deferred exception: " + error.message, error.stack, stack );
| |
− | }
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | jQuery.readyException = function( error ) {
| |
− | window.setTimeout( function() {
| |
− | throw error;
| |
− | } );
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // The deferred used on DOM ready
| |
− | var readyList = jQuery.Deferred();
| |
− |
| |
− | jQuery.fn.ready = function( fn ) {
| |
− |
| |
− | readyList
| |
− | .then( fn )
| |
− |
| |
− | // Wrap jQuery.readyException in a function so that the lookup
| |
− | // happens at the time of error handling instead of callback
| |
− | // registration.
| |
− | .catch( function( error ) {
| |
− | jQuery.readyException( error );
| |
− | } );
| |
− |
| |
− | return this;
| |
− | };
| |
− |
| |
− | jQuery.extend( {
| |
− |
| |
− | // Is the DOM ready to be used? Set to true once it occurs.
| |
− | isReady: false,
| |
− |
| |
− | // A counter to track how many items to wait for before
| |
− | // the ready event fires. See #6781
| |
− | readyWait: 1,
| |
− |
| |
− | // Handle when the DOM is ready
| |
− | ready: function( wait ) {
| |
− |
| |
− | // Abort if there are pending holds or we're already ready
| |
− | if ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // Remember that the DOM is ready
| |
− | jQuery.isReady = true;
| |
− |
| |
− | // If a normal DOM Ready event fired, decrement, and wait if need be
| |
− | if ( wait !== true && --jQuery.readyWait > 0 ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // If there are functions bound, to execute
| |
− | readyList.resolveWith( document, [ jQuery ] );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.ready.then = readyList.then;
| |
− |
| |
− | // The ready event handler and self cleanup method
| |
− | function completed() {
| |
− | document.removeEventListener( "DOMContentLoaded", completed );
| |
− | window.removeEventListener( "load", completed );
| |
− | jQuery.ready();
| |
− | }
| |
− |
| |
− | // Catch cases where $(document).ready() is called
| |
− | // after the browser event has already occurred.
| |
− | // Support: IE <=9 - 10 only
| |
− | // Older IE sometimes signals "interactive" too soon
| |
− | if ( document.readyState === "complete" ||
| |
− | ( document.readyState !== "loading" && !document.documentElement.doScroll ) ) {
| |
− |
| |
− | // Handle it asynchronously to allow scripts the opportunity to delay ready
| |
− | window.setTimeout( jQuery.ready );
| |
− |
| |
− | } else {
| |
− |
| |
− | // Use the handy event callback
| |
− | document.addEventListener( "DOMContentLoaded", completed );
| |
− |
| |
− | // A fallback to window.onload, that will always work
| |
− | window.addEventListener( "load", completed );
| |
− | }
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // Multifunctional method to get and set values of a collection
| |
− | // The value/s can optionally be executed if it's a function
| |
− | var access = function( elems, fn, key, value, chainable, emptyGet, raw ) {
| |
− | var i = 0,
| |
− | len = elems.length,
| |
− | bulk = key == null;
| |
− |
| |
− | // Sets many values
| |
− | if ( toType( key ) === "object" ) {
| |
− | chainable = true;
| |
− | for ( i in key ) {
| |
− | access( elems, fn, i, key[ i ], true, emptyGet, raw );
| |
− | }
| |
− |
| |
− | // Sets one value
| |
− | } else if ( value !== undefined ) {
| |
− | chainable = true;
| |
− |
| |
− | if ( !isFunction( value ) ) {
| |
− | raw = true;
| |
− | }
| |
− |
| |
− | if ( bulk ) {
| |
− |
| |
− | // Bulk operations run against the entire set
| |
− | if ( raw ) {
| |
− | fn.call( elems, value );
| |
− | fn = null;
| |
− |
| |
− | // ...except when executing function values
| |
− | } else {
| |
− | bulk = fn;
| |
− | fn = function( elem, key, value ) {
| |
− | return bulk.call( jQuery( elem ), value );
| |
− | };
| |
− | }
| |
− | }
| |
− |
| |
− | if ( fn ) {
| |
− | for ( ; i < len; i++ ) {
| |
− | fn(
| |
− | elems[ i ], key, raw ?
| |
− | value :
| |
− | value.call( elems[ i ], i, fn( elems[ i ], key ) )
| |
− | );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | if ( chainable ) {
| |
− | return elems;
| |
− | }
| |
− |
| |
− | // Gets
| |
− | if ( bulk ) {
| |
− | return fn.call( elems );
| |
− | }
| |
− |
| |
− | return len ? fn( elems[ 0 ], key ) : emptyGet;
| |
− | };
| |
− |
| |
− |
| |
− | // Matches dashed string for camelizing
| |
− | var rmsPrefix = /^-ms-/,
| |
− | rdashAlpha = /-([a-z])/g;
| |
− |
| |
− | // Used by camelCase as callback to replace()
| |
− | function fcamelCase( all, letter ) {
| |
− | return letter.toUpperCase();
| |
− | }
| |
− |
| |
− | // Convert dashed to camelCase; used by the css and data modules
| |
− | // Support: IE <=9 - 11, Edge 12 - 15
| |
− | // Microsoft forgot to hump their vendor prefix (#9572)
| |
− | function camelCase( string ) {
| |
− | return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase );
| |
− | }
| |
− | var acceptData = function( owner ) {
| |
− |
| |
− | // Accepts only:
| |
− | // - Node
| |
− | // - Node.ELEMENT_NODE
| |
− | // - Node.DOCUMENT_NODE
| |
− | // - Object
| |
− | // - Any
| |
− | return owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType );
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | function Data() {
| |
− | this.expando = jQuery.expando + Data.uid++;
| |
− | }
| |
− |
| |
− | Data.uid = 1;
| |
− |
| |
− | Data.prototype = {
| |
− |
| |
− | cache: function( owner ) {
| |
− |
| |
− | // Check if the owner object already has a cache
| |
− | var value = owner[ this.expando ];
| |
− |
| |
− | // If not, create one
| |
− | if ( !value ) {
| |
− | value = {};
| |
− |
| |
− | // We can accept data for non-element nodes in modern browsers,
| |
− | // but we should not, see #8335.
| |
− | // Always return an empty object.
| |
− | if ( acceptData( owner ) ) {
| |
− |
| |
− | // If it is a node unlikely to be stringify-ed or looped over
| |
− | // use plain assignment
| |
− | if ( owner.nodeType ) {
| |
− | owner[ this.expando ] = value;
| |
− |
| |
− | // Otherwise secure it in a non-enumerable property
| |
− | // configurable must be true to allow the property to be
| |
− | // deleted when data is removed
| |
− | } else {
| |
− | Object.defineProperty( owner, this.expando, {
| |
− | value: value,
| |
− | configurable: true
| |
− | } );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return value;
| |
− | },
| |
− | set: function( owner, data, value ) {
| |
− | var prop,
| |
− | cache = this.cache( owner );
| |
− |
| |
− | // Handle: [ owner, key, value ] args
| |
− | // Always use camelCase key (gh-2257)
| |
− | if ( typeof data === "string" ) {
| |
− | cache[ camelCase( data ) ] = value;
| |
− |
| |
− | // Handle: [ owner, { properties } ] args
| |
− | } else {
| |
− |
| |
− | // Copy the properties one-by-one to the cache object
| |
− | for ( prop in data ) {
| |
− | cache[ camelCase( prop ) ] = data[ prop ];
| |
− | }
| |
− | }
| |
− | return cache;
| |
− | },
| |
− | get: function( owner, key ) {
| |
− | return key === undefined ?
| |
− | this.cache( owner ) :
| |
− |
| |
− | // Always use camelCase key (gh-2257)
| |
− | owner[ this.expando ] && owner[ this.expando ][ camelCase( key ) ];
| |
− | },
| |
− | access: function( owner, key, value ) {
| |
− |
| |
− | // In cases where either:
| |
− | //
| |
− | // 1. No key was specified
| |
− | // 2. A string key was specified, but no value provided
| |
− | //
| |
− | // Take the "read" path and allow the get method to determine
| |
− | // which value to return, respectively either:
| |
− | //
| |
− | // 1. The entire cache object
| |
− | // 2. The data stored at the key
| |
− | //
| |
− | if ( key === undefined ||
| |
− | ( ( key && typeof key === "string" ) && value === undefined ) ) {
| |
− |
| |
− | return this.get( owner, key );
| |
− | }
| |
− |
| |
− | // When the key is not a string, or both a key and value
| |
− | // are specified, set or extend (existing objects) with either:
| |
− | //
| |
− | // 1. An object of properties
| |
− | // 2. A key and value
| |
− | //
| |
− | this.set( owner, key, value );
| |
− |
| |
− | // Since the "set" path can have two possible entry points
| |
− | // return the expected data based on which path was taken[*]
| |
− | return value !== undefined ? value : key;
| |
− | },
| |
− | remove: function( owner, key ) {
| |
− | var i,
| |
− | cache = owner[ this.expando ];
| |
− |
| |
− | if ( cache === undefined ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | if ( key !== undefined ) {
| |
− |
| |
− | // Support array or space separated string of keys
| |
− | if ( Array.isArray( key ) ) {
| |
− |
| |
− | // If key is an array of keys...
| |
− | // We always set camelCase keys, so remove that.
| |
− | key = key.map( camelCase );
| |
− | } else {
| |
− | key = camelCase( key );
| |
− |
| |
− | // If a key with the spaces exists, use it.
| |
− | // Otherwise, create an array by matching non-whitespace
| |
− | key = key in cache ?
| |
− | [ key ] :
| |
− | ( key.match( rnothtmlwhite ) || [] );
| |
− | }
| |
− |
| |
− | i = key.length;
| |
− |
| |
− | while ( i-- ) {
| |
− | delete cache[ key[ i ] ];
| |
− | }
| |
− | }
| |
− |
| |
− | // Remove the expando if there's no more data
| |
− | if ( key === undefined || jQuery.isEmptyObject( cache ) ) {
| |
− |
| |
− | // Support: Chrome <=35 - 45
| |
− | // Webkit & Blink performance suffers when deleting properties
| |
− | // from DOM nodes, so set to undefined instead
| |
− | // https://bugs.chromium.org/p/chromium/issues/detail?id=378607 (bug restricted)
| |
− | if ( owner.nodeType ) {
| |
− | owner[ this.expando ] = undefined;
| |
− | } else {
| |
− | delete owner[ this.expando ];
| |
− | }
| |
− | }
| |
− | },
| |
− | hasData: function( owner ) {
| |
− | var cache = owner[ this.expando ];
| |
− | return cache !== undefined && !jQuery.isEmptyObject( cache );
| |
− | }
| |
− | };
| |
− | var dataPriv = new Data();
| |
− |
| |
− | var dataUser = new Data();
| |
− |
| |
− |
| |
− |
| |
− | // Implementation Summary
| |
− | //
| |
− | // 1. Enforce API surface and semantic compatibility with 1.9.x branch
| |
− | // 2. Improve the module's maintainability by reducing the storage
| |
− | // paths to a single mechanism.
| |
− | // 3. Use the same single mechanism to support "private" and "user" data.
| |
− | // 4. _Never_ expose "private" data to user code (TODO: Drop _data, _removeData)
| |
− | // 5. Avoid exposing implementation details on user objects (eg. expando properties)
| |
− | // 6. Provide a clear path for implementation upgrade to WeakMap in 2014
| |
− |
| |
− | var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
| |
− | rmultiDash = /[A-Z]/g;
| |
− |
| |
− | function getData( data ) {
| |
− | if ( data === "true" ) {
| |
− | return true;
| |
− | }
| |
− |
| |
− | if ( data === "false" ) {
| |
− | return false;
| |
− | }
| |
− |
| |
− | if ( data === "null" ) {
| |
− | return null;
| |
− | }
| |
− |
| |
− | // Only convert to a number if it doesn't change the string
| |
− | if ( data === +data + "" ) {
| |
− | return +data;
| |
− | }
| |
− |
| |
− | if ( rbrace.test( data ) ) {
| |
− | return JSON.parse( data );
| |
− | }
| |
− |
| |
− | return data;
| |
− | }
| |
− |
| |
− | function dataAttr( elem, key, data ) {
| |
− | var name;
| |
− |
| |
− | // If nothing was found internally, try to fetch any
| |
− | // data from the HTML5 data-* attribute
| |
− | if ( data === undefined && elem.nodeType === 1 ) {
| |
− | name = "data-" + key.replace( rmultiDash, "-$&" ).toLowerCase();
| |
− | data = elem.getAttribute( name );
| |
− |
| |
− | if ( typeof data === "string" ) {
| |
− | try {
| |
− | data = getData( data );
| |
− | } catch ( e ) {}
| |
− |
| |
− | // Make sure we set the data so it isn't changed later
| |
− | dataUser.set( elem, key, data );
| |
− | } else {
| |
− | data = undefined;
| |
− | }
| |
− | }
| |
− | return data;
| |
− | }
| |
− |
| |
− | jQuery.extend( {
| |
− | hasData: function( elem ) {
| |
− | return dataUser.hasData( elem ) || dataPriv.hasData( elem );
| |
− | },
| |
− |
| |
− | data: function( elem, name, data ) {
| |
− | return dataUser.access( elem, name, data );
| |
− | },
| |
− |
| |
− | removeData: function( elem, name ) {
| |
− | dataUser.remove( elem, name );
| |
− | },
| |
− |
| |
− | // TODO: Now that all calls to _data and _removeData have been replaced
| |
− | // with direct calls to dataPriv methods, these can be deprecated.
| |
− | _data: function( elem, name, data ) {
| |
− | return dataPriv.access( elem, name, data );
| |
− | },
| |
− |
| |
− | _removeData: function( elem, name ) {
| |
− | dataPriv.remove( elem, name );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | data: function( key, value ) {
| |
− | var i, name, data,
| |
− | elem = this[ 0 ],
| |
− | attrs = elem && elem.attributes;
| |
− |
| |
− | // Gets all values
| |
− | if ( key === undefined ) {
| |
− | if ( this.length ) {
| |
− | data = dataUser.get( elem );
| |
− |
| |
− | if ( elem.nodeType === 1 && !dataPriv.get( elem, "hasDataAttrs" ) ) {
| |
− | i = attrs.length;
| |
− | while ( i-- ) {
| |
− |
| |
− | // Support: IE 11 only
| |
− | // The attrs elements can be null (#14894)
| |
− | if ( attrs[ i ] ) {
| |
− | name = attrs[ i ].name;
| |
− | if ( name.indexOf( "data-" ) === 0 ) {
| |
− | name = camelCase( name.slice( 5 ) );
| |
− | dataAttr( elem, name, data[ name ] );
| |
− | }
| |
− | }
| |
− | }
| |
− | dataPriv.set( elem, "hasDataAttrs", true );
| |
− | }
| |
− | }
| |
− |
| |
− | return data;
| |
− | }
| |
− |
| |
− | // Sets multiple values
| |
− | if ( typeof key === "object" ) {
| |
− | return this.each( function() {
| |
− | dataUser.set( this, key );
| |
− | } );
| |
− | }
| |
− |
| |
− | return access( this, function( value ) {
| |
− | var data;
| |
− |
| |
− | // The calling jQuery object (element matches) is not empty
| |
− | // (and therefore has an element appears at this[ 0 ]) and the
| |
− | // `value` parameter was not undefined. An empty jQuery object
| |
− | // will result in `undefined` for elem = this[ 0 ] which will
| |
− | // throw an exception if an attempt to read a data cache is made.
| |
− | if ( elem && value === undefined ) {
| |
− |
| |
− | // Attempt to get data from the cache
| |
− | // The key will always be camelCased in Data
| |
− | data = dataUser.get( elem, key );
| |
− | if ( data !== undefined ) {
| |
− | return data;
| |
− | }
| |
− |
| |
− | // Attempt to "discover" the data in
| |
− | // HTML5 custom data-* attrs
| |
− | data = dataAttr( elem, key );
| |
− | if ( data !== undefined ) {
| |
− | return data;
| |
− | }
| |
− |
| |
− | // We tried really hard, but the data doesn't exist.
| |
− | return;
| |
− | }
| |
− |
| |
− | // Set the data...
| |
− | this.each( function() {
| |
− |
| |
− | // We always store the camelCased key
| |
− | dataUser.set( this, key, value );
| |
− | } );
| |
− | }, null, value, arguments.length > 1, null, true );
| |
− | },
| |
− |
| |
− | removeData: function( key ) {
| |
− | return this.each( function() {
| |
− | dataUser.remove( this, key );
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | jQuery.extend( {
| |
− | queue: function( elem, type, data ) {
| |
− | var queue;
| |
− |
| |
− | if ( elem ) {
| |
− | type = ( type || "fx" ) + "queue";
| |
− | queue = dataPriv.get( elem, type );
| |
− |
| |
− | // Speed up dequeue by getting out quickly if this is just a lookup
| |
− | if ( data ) {
| |
− | if ( !queue || Array.isArray( data ) ) {
| |
− | queue = dataPriv.access( elem, type, jQuery.makeArray( data ) );
| |
− | } else {
| |
− | queue.push( data );
| |
− | }
| |
− | }
| |
− | return queue || [];
| |
− | }
| |
− | },
| |
− |
| |
− | dequeue: function( elem, type ) {
| |
− | type = type || "fx";
| |
− |
| |
− | var queue = jQuery.queue( elem, type ),
| |
− | startLength = queue.length,
| |
− | fn = queue.shift(),
| |
− | hooks = jQuery._queueHooks( elem, type ),
| |
− | next = function() {
| |
− | jQuery.dequeue( elem, type );
| |
− | };
| |
− |
| |
− | // If the fx queue is dequeued, always remove the progress sentinel
| |
− | if ( fn === "inprogress" ) {
| |
− | fn = queue.shift();
| |
− | startLength--;
| |
− | }
| |
− |
| |
− | if ( fn ) {
| |
− |
| |
− | // Add a progress sentinel to prevent the fx queue from being
| |
− | // automatically dequeued
| |
− | if ( type === "fx" ) {
| |
− | queue.unshift( "inprogress" );
| |
− | }
| |
− |
| |
− | // Clear up the last queue stop function
| |
− | delete hooks.stop;
| |
− | fn.call( elem, next, hooks );
| |
− | }
| |
− |
| |
− | if ( !startLength && hooks ) {
| |
− | hooks.empty.fire();
| |
− | }
| |
− | },
| |
− |
| |
− | // Not public - generate a queueHooks object, or return the current one
| |
− | _queueHooks: function( elem, type ) {
| |
− | var key = type + "queueHooks";
| |
− | return dataPriv.get( elem, key ) || dataPriv.access( elem, key, {
| |
− | empty: jQuery.Callbacks( "once memory" ).add( function() {
| |
− | dataPriv.remove( elem, [ type + "queue", key ] );
| |
− | } )
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | queue: function( type, data ) {
| |
− | var setter = 2;
| |
− |
| |
− | if ( typeof type !== "string" ) {
| |
− | data = type;
| |
− | type = "fx";
| |
− | setter--;
| |
− | }
| |
− |
| |
− | if ( arguments.length < setter ) {
| |
− | return jQuery.queue( this[ 0 ], type );
| |
− | }
| |
− |
| |
− | return data === undefined ?
| |
− | this :
| |
− | this.each( function() {
| |
− | var queue = jQuery.queue( this, type, data );
| |
− |
| |
− | // Ensure a hooks for this queue
| |
− | jQuery._queueHooks( this, type );
| |
− |
| |
− | if ( type === "fx" && queue[ 0 ] !== "inprogress" ) {
| |
− | jQuery.dequeue( this, type );
| |
− | }
| |
− | } );
| |
− | },
| |
− | dequeue: function( type ) {
| |
− | return this.each( function() {
| |
− | jQuery.dequeue( this, type );
| |
− | } );
| |
− | },
| |
− | 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 ] );
| |
− | }
| |
− | };
| |
− |
| |
− | if ( typeof type !== "string" ) {
| |
− | obj = type;
| |
− | type = undefined;
| |
− | }
| |
− | type = type || "fx";
| |
− |
| |
− | while ( i-- ) {
| |
− | tmp = dataPriv.get( elements[ i ], type + "queueHooks" );
| |
− | if ( tmp && tmp.empty ) {
| |
− | count++;
| |
− | tmp.empty.add( resolve );
| |
− | }
| |
− | }
| |
− | resolve();
| |
− | return defer.promise( obj );
| |
− | }
| |
− | } );
| |
− | var pnum = ( /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/ ).source;
| |
− |
| |
− | var rcssNum = new RegExp( "^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i" );
| |
− |
| |
− |
| |
− | var cssExpand = [ "Top", "Right", "Bottom", "Left" ];
| |
− |
| |
− | var isHiddenWithinTree = function( elem, el ) {
| |
− |
| |
− | // isHiddenWithinTree might be called from jQuery#filter function;
| |
− | // in that case, element will be second argument
| |
− | elem = el || elem;
| |
− |
| |
− | // Inline style trumps all
| |
− | return elem.style.display === "none" ||
| |
− | elem.style.display === "" &&
| |
− |
| |
− | // Otherwise, check computed style
| |
− | // Support: Firefox <=43 - 45
| |
− | // Disconnected elements can have computed display: none, so first confirm that elem is
| |
− | // in the document.
| |
− | jQuery.contains( elem.ownerDocument, elem ) &&
| |
− |
| |
− | jQuery.css( elem, "display" ) === "none";
| |
− | };
| |
− |
| |
− | var 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;
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | function adjustCSS( elem, prop, valueParts, tween ) {
| |
− | var adjusted, scale,
| |
− | maxIterations = 20,
| |
− | currentValue = tween ?
| |
− | function() {
| |
− | return tween.cur();
| |
− | } :
| |
− | function() {
| |
− | return jQuery.css( elem, prop, "" );
| |
− | },
| |
− | initial = currentValue(),
| |
− | unit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ),
| |
− |
| |
− | // Starting value computation is required for potential unit mismatches
| |
− | initialInUnit = ( jQuery.cssNumber[ prop ] || unit !== "px" && +initial ) &&
| |
− | rcssNum.exec( jQuery.css( elem, prop ) );
| |
− |
| |
− | if ( initialInUnit && initialInUnit[ 3 ] !== unit ) {
| |
− |
| |
− | // Support: Firefox <=54
| |
− | // Halve the iteration target value to prevent interference from CSS upper bounds (gh-2144)
| |
− | initial = initial / 2;
| |
− |
| |
− | // Trust units reported by jQuery.css
| |
− | unit = unit || initialInUnit[ 3 ];
| |
− |
| |
− | // Iteratively approximate from a nonzero starting point
| |
− | initialInUnit = +initial || 1;
| |
− |
| |
− | while ( maxIterations-- ) {
| |
− |
| |
− | // Evaluate and update our best guess (doubling guesses that zero out).
| |
− | // Finish if the scale equals or crosses 1 (making the old*new product non-positive).
| |
− | jQuery.style( elem, prop, initialInUnit + unit );
| |
− | if ( ( 1 - scale ) * ( 1 - ( scale = currentValue() / initial || 0.5 ) ) <= 0 ) {
| |
− | maxIterations = 0;
| |
− | }
| |
− | initialInUnit = initialInUnit / scale;
| |
− |
| |
− | }
| |
− |
| |
− | initialInUnit = initialInUnit * 2;
| |
− | jQuery.style( elem, prop, initialInUnit + unit );
| |
− |
| |
− | // Make sure we update the tween properties later on
| |
− | valueParts = valueParts || [];
| |
− | }
| |
− |
| |
− | if ( valueParts ) {
| |
− | initialInUnit = +initialInUnit || +initial || 0;
| |
− |
| |
− | // Apply relative offset (+=/-=) if specified
| |
− | adjusted = valueParts[ 1 ] ?
| |
− | initialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] :
| |
− | +valueParts[ 2 ];
| |
− | if ( tween ) {
| |
− | tween.unit = unit;
| |
− | tween.start = initialInUnit;
| |
− | tween.end = adjusted;
| |
− | }
| |
− | }
| |
− | return adjusted;
| |
− | }
| |
− |
| |
− |
| |
− | var defaultDisplayMap = {};
| |
− |
| |
− | function getDefaultDisplay( elem ) {
| |
− | var temp,
| |
− | doc = elem.ownerDocument,
| |
− | nodeName = elem.nodeName,
| |
− | display = defaultDisplayMap[ nodeName ];
| |
− |
| |
− | if ( display ) {
| |
− | return display;
| |
− | }
| |
− |
| |
− | temp = doc.body.appendChild( doc.createElement( nodeName ) );
| |
− | display = jQuery.css( temp, "display" );
| |
− |
| |
− | temp.parentNode.removeChild( temp );
| |
− |
| |
− | if ( display === "none" ) {
| |
− | display = "block";
| |
− | }
| |
− | defaultDisplayMap[ nodeName ] = display;
| |
− |
| |
− | return display;
| |
− | }
| |
− |
| |
− | function showHide( elements, show ) {
| |
− | var display, elem,
| |
− | values = [],
| |
− | index = 0,
| |
− | length = elements.length;
| |
− |
| |
− | // Determine new display value for elements that need to change
| |
− | for ( ; index < length; index++ ) {
| |
− | elem = elements[ index ];
| |
− | if ( !elem.style ) {
| |
− | continue;
| |
− | }
| |
− |
| |
− | display = elem.style.display;
| |
− | if ( show ) {
| |
− |
| |
− | // Since we force visibility upon cascade-hidden elements, an immediate (and slow)
| |
− | // check is required in this first loop unless we have a nonempty display value (either
| |
− | // inline or about-to-be-restored)
| |
− | if ( display === "none" ) {
| |
− | values[ index ] = dataPriv.get( elem, "display" ) || null;
| |
− | if ( !values[ index ] ) {
| |
− | elem.style.display = "";
| |
− | }
| |
− | }
| |
− | if ( elem.style.display === "" && isHiddenWithinTree( elem ) ) {
| |
− | values[ index ] = getDefaultDisplay( elem );
| |
− | }
| |
− | } else {
| |
− | if ( display !== "none" ) {
| |
− | values[ index ] = "none";
| |
− |
| |
− | // Remember what we're overwriting
| |
− | dataPriv.set( elem, "display", display );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Set the display of the elements in a second loop to avoid constant reflow
| |
− | for ( index = 0; index < length; index++ ) {
| |
− | if ( values[ index ] != null ) {
| |
− | elements[ index ].style.display = values[ index ];
| |
− | }
| |
− | }
| |
− |
| |
− | return elements;
| |
− | }
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | show: function() {
| |
− | return showHide( this, true );
| |
− | },
| |
− | hide: function() {
| |
− | return showHide( this );
| |
− | },
| |
− | toggle: function( state ) {
| |
− | if ( typeof state === "boolean" ) {
| |
− | return state ? this.show() : this.hide();
| |
− | }
| |
− |
| |
− | return this.each( function() {
| |
− | if ( isHiddenWithinTree( this ) ) {
| |
− | jQuery( this ).show();
| |
− | } else {
| |
− | jQuery( this ).hide();
| |
− | }
| |
− | } );
| |
− | }
| |
− | } );
| |
− | var rcheckableType = ( /^(?:checkbox|radio)$/i );
| |
− |
| |
− | var rtagName = ( /<([a-z][^\/\0>\x20\t\r\n\f]+)/i );
| |
− |
| |
− | var rscriptType = ( /^$|^module$|\/(?:java|ecma)script/i );
| |
− |
| |
− |
| |
− |
| |
− | // We have to close these tags to support XHTML (#13200)
| |
− | var wrapMap = {
| |
− |
| |
− | // Support: IE <=9 only
| |
− | option: [ 1, "<select multiple='multiple'>", "</select>" ],
| |
− |
| |
− | // XHTML parsers do not magically insert elements in the
| |
− | // same way that tag soup parsers do. So we cannot shorten
| |
− | // this by omitting <tbody> or other required elements.
| |
− | thead: [ 1, "<table>", "</table>" ],
| |
− | col: [ 2, "<table><colgroup>", "</colgroup></table>" ],
| |
− | tr: [ 2, "<table><tbody>", "</tbody></table>" ],
| |
− | td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ],
| |
− |
| |
− | _default: [ 0, "", "" ]
| |
− | };
| |
− |
| |
− | // Support: IE <=9 only
| |
− | wrapMap.optgroup = wrapMap.option;
| |
− |
| |
− | wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;
| |
− | wrapMap.th = wrapMap.td;
| |
− |
| |
− |
| |
− | function getAll( context, tag ) {
| |
− |
| |
− | // Support: IE <=9 - 11 only
| |
− | // Use typeof to avoid zero-argument method invocation on host objects (#15151)
| |
− | var ret;
| |
− |
| |
− | if ( typeof context.getElementsByTagName !== "undefined" ) {
| |
− | ret = context.getElementsByTagName( tag || "*" );
| |
− |
| |
− | } else if ( typeof context.querySelectorAll !== "undefined" ) {
| |
− | ret = context.querySelectorAll( tag || "*" );
| |
− |
| |
− | } else {
| |
− | ret = [];
| |
− | }
| |
− |
| |
− | if ( tag === undefined || tag && nodeName( context, tag ) ) {
| |
− | return jQuery.merge( [ context ], ret );
| |
− | }
| |
− |
| |
− | return ret;
| |
− | }
| |
− |
| |
− |
| |
− | // Mark scripts as having already been evaluated
| |
− | function setGlobalEval( elems, refElements ) {
| |
− | var i = 0,
| |
− | l = elems.length;
| |
− |
| |
− | for ( ; i < l; i++ ) {
| |
− | dataPriv.set(
| |
− | elems[ i ],
| |
− | "globalEval",
| |
− | !refElements || dataPriv.get( refElements[ i ], "globalEval" )
| |
− | );
| |
− | }
| |
− | }
| |
− |
| |
− |
| |
− | var rhtml = /<|&#?\w+;/;
| |
− |
| |
− | function buildFragment( elems, context, scripts, selection, ignored ) {
| |
− | var elem, tmp, tag, wrap, contains, j,
| |
− | fragment = context.createDocumentFragment(),
| |
− | nodes = [],
| |
− | i = 0,
| |
− | l = elems.length;
| |
− |
| |
− | for ( ; i < l; i++ ) {
| |
− | elem = elems[ i ];
| |
− |
| |
− | if ( elem || elem === 0 ) {
| |
− |
| |
− | // Add nodes directly
| |
− | if ( toType( elem ) === "object" ) {
| |
− |
| |
− | // Support: Android <=4.0 only, PhantomJS 1 only
| |
− | // push.apply(_, arraylike) throws on ancient WebKit
| |
− | jQuery.merge( nodes, elem.nodeType ? [ elem ] : elem );
| |
− |
| |
− | // Convert non-html into a text node
| |
− | } else if ( !rhtml.test( elem ) ) {
| |
− | nodes.push( context.createTextNode( elem ) );
| |
− |
| |
− | // Convert html into DOM nodes
| |
− | } else {
| |
− | tmp = tmp || fragment.appendChild( context.createElement( "div" ) );
| |
− |
| |
− | // Deserialize a standard representation
| |
− | tag = ( rtagName.exec( elem ) || [ "", "" ] )[ 1 ].toLowerCase();
| |
− | wrap = wrapMap[ tag ] || wrapMap._default;
| |
− | tmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ];
| |
− |
| |
− | // Descend through wrappers to the right content
| |
− | j = wrap[ 0 ];
| |
− | while ( j-- ) {
| |
− | tmp = tmp.lastChild;
| |
− | }
| |
− |
| |
− | // Support: Android <=4.0 only, PhantomJS 1 only
| |
− | // push.apply(_, arraylike) throws on ancient WebKit
| |
− | jQuery.merge( nodes, tmp.childNodes );
| |
− |
| |
− | // Remember the top-level container
| |
− | tmp = fragment.firstChild;
| |
− |
| |
− | // Ensure the created nodes are orphaned (#12392)
| |
− | tmp.textContent = "";
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Remove wrapper from fragment
| |
− | fragment.textContent = "";
| |
− |
| |
− | i = 0;
| |
− | while ( ( elem = nodes[ i++ ] ) ) {
| |
− |
| |
− | // Skip elements already in the context collection (trac-4087)
| |
− | if ( selection && jQuery.inArray( elem, selection ) > -1 ) {
| |
− | if ( ignored ) {
| |
− | ignored.push( elem );
| |
− | }
| |
− | continue;
| |
− | }
| |
− |
| |
− | contains = jQuery.contains( elem.ownerDocument, elem );
| |
− |
| |
− | // Append to fragment
| |
− | tmp = getAll( fragment.appendChild( elem ), "script" );
| |
− |
| |
− | // Preserve script evaluation history
| |
− | if ( contains ) {
| |
− | setGlobalEval( tmp );
| |
− | }
| |
− |
| |
− | // Capture executables
| |
− | if ( scripts ) {
| |
− | j = 0;
| |
− | while ( ( elem = tmp[ j++ ] ) ) {
| |
− | if ( rscriptType.test( elem.type || "" ) ) {
| |
− | scripts.push( elem );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return fragment;
| |
− | }
| |
− |
| |
− |
| |
− | ( function() {
| |
− | var fragment = document.createDocumentFragment(),
| |
− | div = fragment.appendChild( document.createElement( "div" ) ),
| |
− | input = document.createElement( "input" );
| |
− |
| |
− | // Support: Android 4.0 - 4.3 only
| |
− | // Check state lost if the name is set (#11217)
| |
− | // Support: Windows Web Apps (WWA)
| |
− | // `name` and `type` must use .setAttribute for WWA (#14901)
| |
− | input.setAttribute( "type", "radio" );
| |
− | input.setAttribute( "checked", "checked" );
| |
− | input.setAttribute( "name", "t" );
| |
− |
| |
− | div.appendChild( input );
| |
− |
| |
− | // Support: Android <=4.1 only
| |
− | // Older WebKit doesn't clone checked state correctly in fragments
| |
− | support.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked;
| |
− |
| |
− | // Support: IE <=11 only
| |
− | // Make sure textarea (and checkbox) defaultValue is properly cloned
| |
− | div.innerHTML = "<textarea>x</textarea>";
| |
− | support.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue;
| |
− | } )();
| |
− | var documentElement = document.documentElement;
| |
− |
| |
− |
| |
− |
| |
− | var
| |
− | rkeyEvent = /^key/,
| |
− | rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,
| |
− | rtypenamespace = /^([^.]*)(?:\.(.+)|)/;
| |
− |
| |
− | function returnTrue() {
| |
− | return true;
| |
− | }
| |
− |
| |
− | function returnFalse() {
| |
− | return false;
| |
− | }
| |
− |
| |
− | // Support: IE <=9 only
| |
− | // See #13393 for more info
| |
− | function safeActiveElement() {
| |
− | try {
| |
− | return document.activeElement;
| |
− | } catch ( err ) { }
| |
− | }
| |
− |
| |
− | function on( elem, types, selector, data, fn, one ) {
| |
− | var origFn, type;
| |
− |
| |
− | // 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 ) {
| |
− | on( elem, type, selector, data, types[ type ], one );
| |
− | }
| |
− | return 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 elem;
| |
− | }
| |
− |
| |
− | 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 elem.each( function() {
| |
− | jQuery.event.add( this, types, fn, data, selector );
| |
− | } );
| |
− | }
| |
− |
| |
− | /*
| |
− | * 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 handleObjIn, eventHandle, tmp,
| |
− | events, t, handleObj,
| |
− | special, handlers, type, namespaces, origType,
| |
− | elemData = dataPriv.get( 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;
| |
− | }
| |
− |
| |
− | // Ensure that invalid selectors throw exceptions at attach time
| |
− | // Evaluate against documentElement in case elem is a non-element node (e.g., document)
| |
− | if ( selector ) {
| |
− | jQuery.find.matchesSelector( documentElement, selector );
| |
− | }
| |
− |
| |
− | // Make sure that the handler has a unique ID, used to find/remove it later
| |
− | if ( !handler.guid ) {
| |
− | handler.guid = jQuery.guid++;
| |
− | }
| |
− |
| |
− | // 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 !== "undefined" && jQuery.event.triggered !== e.type ?
| |
− | jQuery.event.dispatch.apply( elem, arguments ) : undefined;
| |
− | };
| |
− | }
| |
− |
| |
− | // Handle multiple events separated by a space
| |
− | types = ( types || "" ).match( rnothtmlwhite ) || [ "" ];
| |
− | t = types.length;
| |
− | while ( t-- ) {
| |
− | tmp = rtypenamespace.exec( types[ t ] ) || [];
| |
− | type = origType = tmp[ 1 ];
| |
− | namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort();
| |
− |
| |
− | // There *must* be a type, no attaching namespace-only handlers
| |
− | if ( !type ) {
| |
− | continue;
| |
− | }
| |
− |
| |
− | // 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;
| |
− |
| |
− | // Update special based on newly reset type
| |
− | special = jQuery.event.special[ type ] || {};
| |
− |
| |
− | // 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 );
| |
− |
| |
− | // Init the event handler queue if we're the first
| |
− | if ( !( handlers = events[ type ] ) ) {
| |
− | handlers = events[ type ] = [];
| |
− | handlers.delegateCount = 0;
| |
− |
| |
− | // Only use addEventListener if the special events handler returns false
| |
− | if ( !special.setup ||
| |
− | special.setup.call( elem, data, namespaces, eventHandle ) === false ) {
| |
− |
| |
− | if ( elem.addEventListener ) {
| |
− | elem.addEventListener( type, eventHandle );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | if ( special.add ) {
| |
− | special.add.call( elem, handleObj );
| |
− |
| |
− | if ( !handleObj.handler.guid ) {
| |
− | handleObj.handler.guid = handler.guid;
| |
− | }
| |
− | }
| |
− |
| |
− | // Add to the element's handler list, delegates in front
| |
− | if ( selector ) {
| |
− | handlers.splice( handlers.delegateCount++, 0, handleObj );
| |
− | } else {
| |
− | handlers.push( handleObj );
| |
− | }
| |
− |
| |
− | // Keep track of which events have ever been used, for event optimization
| |
− | jQuery.event.global[ type ] = true;
| |
− | }
| |
− |
| |
− | },
| |
− |
| |
− | // Detach an event or set of events from an element
| |
− | remove: function( elem, types, handler, selector, mappedTypes ) {
| |
− |
| |
− | var j, origCount, tmp,
| |
− | events, t, handleObj,
| |
− | special, handlers, type, namespaces, origType,
| |
− | elemData = dataPriv.hasData( elem ) && dataPriv.get( elem );
| |
− |
| |
− | if ( !elemData || !( events = elemData.events ) ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // Once for each type.namespace in types; type may be omitted
| |
− | types = ( types || "" ).match( rnothtmlwhite ) || [ "" ];
| |
− | t = types.length;
| |
− | while ( t-- ) {
| |
− | tmp = rtypenamespace.exec( types[ t ] ) || [];
| |
− | type = origType = tmp[ 1 ];
| |
− | namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort();
| |
− |
| |
− | // 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;
| |
− | }
| |
− |
| |
− | special = jQuery.event.special[ type ] || {};
| |
− | type = ( selector ? special.delegateType : special.bindType ) || type;
| |
− | handlers = events[ type ] || [];
| |
− | tmp = tmp[ 2 ] &&
| |
− | new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" );
| |
− |
| |
− | // Remove matching events
| |
− | origCount = j = handlers.length;
| |
− | while ( j-- ) {
| |
− | handleObj = handlers[ j ];
| |
− |
| |
− | 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 );
| |
− |
| |
− | if ( handleObj.selector ) {
| |
− | handlers.delegateCount--;
| |
− | }
| |
− | if ( special.remove ) {
| |
− | special.remove.call( elem, handleObj );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // 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 );
| |
− | }
| |
− |
| |
− | delete events[ type ];
| |
− | }
| |
− | }
| |
− |
| |
− | // Remove data and the expando if it's no longer used
| |
− | if ( jQuery.isEmptyObject( events ) ) {
| |
− | dataPriv.remove( elem, "handle events" );
| |
− | }
| |
− | },
| |
− |
| |
− | dispatch: function( nativeEvent ) {
| |
− |
| |
− | // Make a writable jQuery.Event from the native event object
| |
− | var event = jQuery.event.fix( nativeEvent );
| |
− |
| |
− | var i, j, ret, matched, handleObj, handlerQueue,
| |
− | args = new Array( arguments.length ),
| |
− | handlers = ( dataPriv.get( 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;
| |
− |
| |
− | for ( i = 1; i < arguments.length; i++ ) {
| |
− | args[ i ] = arguments[ i ];
| |
− | }
| |
− |
| |
− | 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.rnamespace || event.rnamespace.test( handleObj.namespace ) ) {
| |
− |
| |
− | event.handleObj = handleObj;
| |
− | event.data = handleObj.data;
| |
− |
| |
− | ret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle ||
| |
− | handleObj.handler ).apply( matched.elem, args );
| |
− |
| |
− | if ( ret !== undefined ) {
| |
− | if ( ( event.result = ret ) === false ) {
| |
− | event.preventDefault();
| |
− | event.stopPropagation();
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Call the postDispatch hook for the mapped type
| |
− | if ( special.postDispatch ) {
| |
− | special.postDispatch.call( this, event );
| |
− | }
| |
− |
| |
− | return event.result;
| |
− | },
| |
− |
| |
− | handlers: function( event, handlers ) {
| |
− | var i, handleObj, sel, matchedHandlers, matchedSelectors,
| |
− | handlerQueue = [],
| |
− | delegateCount = handlers.delegateCount,
| |
− | cur = event.target;
| |
− |
| |
− | // Find delegate handlers
| |
− | if ( delegateCount &&
| |
− |
| |
− | // Support: IE <=9
| |
− | // Black-hole SVG <use> instance trees (trac-13180)
| |
− | cur.nodeType &&
| |
− |
| |
− | // Support: Firefox <=42
| |
− | // Suppress spec-violating clicks indicating a non-primary pointer button (trac-3861)
| |
− | // https://www.w3.org/TR/DOM-Level-3-Events/#event-type-click
| |
− | // Support: IE 11 only
| |
− | // ...but not arrow key "clicks" of radio inputs, which can have `button` -1 (gh-2343)
| |
− | !( event.type === "click" && event.button >= 1 ) ) {
| |
− |
| |
− | for ( ; cur !== this; cur = cur.parentNode || this ) {
| |
− |
| |
− | // Don't check non-elements (#13208)
| |
− | // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)
| |
− | if ( cur.nodeType === 1 && !( event.type === "click" && cur.disabled === true ) ) {
| |
− | matchedHandlers = [];
| |
− | matchedSelectors = {};
| |
− | for ( i = 0; i < delegateCount; i++ ) {
| |
− | handleObj = handlers[ i ];
| |
− |
| |
− | // Don't conflict with Object.prototype properties (#13203)
| |
− | sel = handleObj.selector + " ";
| |
− |
| |
− | if ( matchedSelectors[ sel ] === undefined ) {
| |
− | matchedSelectors[ sel ] = handleObj.needsContext ?
| |
− | jQuery( sel, this ).index( cur ) > -1 :
| |
− | jQuery.find( sel, this, null, [ cur ] ).length;
| |
− | }
| |
− | if ( matchedSelectors[ sel ] ) {
| |
− | matchedHandlers.push( handleObj );
| |
− | }
| |
− | }
| |
− | if ( matchedHandlers.length ) {
| |
− | handlerQueue.push( { elem: cur, handlers: matchedHandlers } );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Add the remaining (directly-bound) handlers
| |
− | cur = this;
| |
− | if ( delegateCount < handlers.length ) {
| |
− | handlerQueue.push( { elem: cur, handlers: handlers.slice( delegateCount ) } );
| |
− | }
| |
− |
| |
− | return handlerQueue;
| |
− | },
| |
− |
| |
− | addProp: function( name, hook ) {
| |
− | Object.defineProperty( jQuery.Event.prototype, name, {
| |
− | enumerable: true,
| |
− | configurable: true,
| |
− |
| |
− | get: isFunction( hook ) ?
| |
− | function() {
| |
− | if ( this.originalEvent ) {
| |
− | return hook( this.originalEvent );
| |
− | }
| |
− | } :
| |
− | function() {
| |
− | if ( this.originalEvent ) {
| |
− | return this.originalEvent[ name ];
| |
− | }
| |
− | },
| |
− |
| |
− | set: function( value ) {
| |
− | Object.defineProperty( this, name, {
| |
− | enumerable: true,
| |
− | configurable: true,
| |
− | writable: true,
| |
− | value: value
| |
− | } );
| |
− | }
| |
− | } );
| |
− | },
| |
− |
| |
− | fix: function( originalEvent ) {
| |
− | return originalEvent[ jQuery.expando ] ?
| |
− | originalEvent :
| |
− | new jQuery.Event( originalEvent );
| |
− | },
| |
− |
| |
− | 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 ) {
| |
− | this.focus();
| |
− | return false;
| |
− | }
| |
− | },
| |
− | 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 ( this.type === "checkbox" && this.click && nodeName( this, "input" ) ) {
| |
− | this.click();
| |
− | return false;
| |
− | }
| |
− | },
| |
− |
| |
− | // For cross-browser consistency, don't fire native .click() on links
| |
− | _default: function( event ) {
| |
− | return nodeName( event.target, "a" );
| |
− | }
| |
− | },
| |
− |
| |
− | beforeunload: {
| |
− | postDispatch: function( event ) {
| |
− |
| |
− | // Support: Firefox 20+
| |
− | // Firefox doesn't alert if the returnValue field is not set.
| |
− | if ( event.result !== undefined && event.originalEvent ) {
| |
− | event.originalEvent.returnValue = event.result;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | };
| |
− |
| |
− | jQuery.removeEvent = function( elem, type, handle ) {
| |
− |
| |
− | // This "if" is needed for plain objects
| |
− | if ( elem.removeEventListener ) {
| |
− | elem.removeEventListener( type, handle );
| |
− | }
| |
− | };
| |
− |
| |
− | jQuery.Event = function( src, props ) {
| |
− |
| |
− | // Allow instantiation without the 'new' keyword
| |
− | if ( !( this instanceof jQuery.Event ) ) {
| |
− | return new jQuery.Event( src, props );
| |
− | }
| |
− |
| |
− | // Event object
| |
− | if ( src && src.type ) {
| |
− | this.originalEvent = src;
| |
− | this.type = src.type;
| |
− |
| |
− | // 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.defaultPrevented === undefined &&
| |
− |
| |
− | // Support: Android <=2.3 only
| |
− | src.returnValue === false ?
| |
− | returnTrue :
| |
− | returnFalse;
| |
− |
| |
− | // Create target properties
| |
− | // Support: Safari <=6 - 7 only
| |
− | // Target should not be a text node (#504, #13143)
| |
− | this.target = ( src.target && src.target.nodeType === 3 ) ?
| |
− | src.target.parentNode :
| |
− | src.target;
| |
− |
| |
− | this.currentTarget = src.currentTarget;
| |
− | this.relatedTarget = src.relatedTarget;
| |
− |
| |
− | // Event type
| |
− | } else {
| |
− | this.type = src;
| |
− | }
| |
− |
| |
− | // Put explicitly provided properties onto the event object
| |
− | if ( props ) {
| |
− | jQuery.extend( this, props );
| |
− | }
| |
− |
| |
− | // Create a timestamp if incoming event doesn't have one
| |
− | this.timeStamp = src && src.timeStamp || Date.now();
| |
− |
| |
− | // Mark it as fixed
| |
− | this[ jQuery.expando ] = true;
| |
− | };
| |
− |
| |
− | // jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding
| |
− | // https://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html
| |
− | jQuery.Event.prototype = {
| |
− | constructor: jQuery.Event,
| |
− | isDefaultPrevented: returnFalse,
| |
− | isPropagationStopped: returnFalse,
| |
− | isImmediatePropagationStopped: returnFalse,
| |
− | isSimulated: false,
| |
− |
| |
− | preventDefault: function() {
| |
− | var e = this.originalEvent;
| |
− |
| |
− | this.isDefaultPrevented = returnTrue;
| |
− |
| |
− | if ( e && !this.isSimulated ) {
| |
− | e.preventDefault();
| |
− | }
| |
− | },
| |
− | stopPropagation: function() {
| |
− | var e = this.originalEvent;
| |
− |
| |
− | this.isPropagationStopped = returnTrue;
| |
− |
| |
− | if ( e && !this.isSimulated ) {
| |
− | e.stopPropagation();
| |
− | }
| |
− | },
| |
− | stopImmediatePropagation: function() {
| |
− | var e = this.originalEvent;
| |
− |
| |
− | this.isImmediatePropagationStopped = returnTrue;
| |
− |
| |
− | if ( e && !this.isSimulated ) {
| |
− | e.stopImmediatePropagation();
| |
− | }
| |
− |
| |
− | this.stopPropagation();
| |
− | }
| |
− | };
| |
− |
| |
− | // Includes all common event props including KeyEvent and MouseEvent specific props
| |
− | jQuery.each( {
| |
− | altKey: true,
| |
− | bubbles: true,
| |
− | cancelable: true,
| |
− | changedTouches: true,
| |
− | ctrlKey: true,
| |
− | detail: true,
| |
− | eventPhase: true,
| |
− | metaKey: true,
| |
− | pageX: true,
| |
− | pageY: true,
| |
− | shiftKey: true,
| |
− | view: true,
| |
− | "char": true,
| |
− | charCode: true,
| |
− | key: true,
| |
− | keyCode: true,
| |
− | button: true,
| |
− | buttons: true,
| |
− | clientX: true,
| |
− | clientY: true,
| |
− | offsetX: true,
| |
− | offsetY: true,
| |
− | pointerId: true,
| |
− | pointerType: true,
| |
− | screenX: true,
| |
− | screenY: true,
| |
− | targetTouches: true,
| |
− | toElement: true,
| |
− | touches: true,
| |
− |
| |
− | which: function( event ) {
| |
− | var button = event.button;
| |
− |
| |
− | // Add which for key events
| |
− | if ( event.which == null && rkeyEvent.test( event.type ) ) {
| |
− | return event.charCode != null ? event.charCode : event.keyCode;
| |
− | }
| |
− |
| |
− | // Add which for click: 1 === left; 2 === middle; 3 === right
| |
− | if ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) {
| |
− | if ( button & 1 ) {
| |
− | return 1;
| |
− | }
| |
− |
| |
− | if ( button & 2 ) {
| |
− | return 3;
| |
− | }
| |
− |
| |
− | if ( button & 4 ) {
| |
− | return 2;
| |
− | }
| |
− |
| |
− | return 0;
| |
− | }
| |
− |
| |
− | return event.which;
| |
− | }
| |
− | }, jQuery.event.addProp );
| |
− |
| |
− | // Create mouseenter/leave events using mouseover/out and event-time checks
| |
− | // so that event delegation works in jQuery.
| |
− | // Do the same for pointerenter/pointerleave and pointerover/pointerout
| |
− | //
| |
− | // Support: Safari 7 only
| |
− | // Safari sends mouseenter too often; see:
| |
− | // https://bugs.chromium.org/p/chromium/issues/detail?id=470258
| |
− | // for the description of the bug (it existed in older Chrome versions as well).
| |
− | jQuery.each( {
| |
− | mouseenter: "mouseover",
| |
− | mouseleave: "mouseout",
| |
− | pointerenter: "pointerover",
| |
− | pointerleave: "pointerout"
| |
− | }, function( orig, fix ) {
| |
− | jQuery.event.special[ orig ] = {
| |
− | delegateType: fix,
| |
− | bindType: fix,
| |
− |
| |
− | handle: function( event ) {
| |
− | var ret,
| |
− | target = this,
| |
− | related = event.relatedTarget,
| |
− | handleObj = event.handleObj;
| |
− |
| |
− | // For mouseenter/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;
| |
− | }
| |
− | };
| |
− | } );
| |
− |
| |
− | jQuery.fn.extend( {
| |
− |
| |
− | on: function( types, selector, data, fn ) {
| |
− | return on( this, types, selector, data, fn );
| |
− | },
| |
− | one: function( types, selector, data, fn ) {
| |
− | return on( this, 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 );
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | var
| |
− |
| |
− | /* eslint-disable max-len */
| |
− |
| |
− | // See https://github.com/eslint/eslint/issues/3229
| |
− | rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\/\0>\x20\t\r\n\f]*)[^>]*)\/>/gi,
| |
− |
| |
− | /* eslint-enable */
| |
− |
| |
− | // Support: IE <=10 - 11, Edge 12 - 13 only
| |
− | // In IE/Edge using regex groups here causes severe slowdowns.
| |
− | // See https://connect.microsoft.com/IE/feedback/details/1736512/
| |
− | rnoInnerhtml = /<script|<style|<link/i,
| |
− |
| |
− | // checked="checked" or checked
| |
− | rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i,
| |
− | rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;
| |
− |
| |
− | // Prefer a tbody over its parent table for containing new rows
| |
− | function manipulationTarget( elem, content ) {
| |
− | if ( nodeName( elem, "table" ) &&
| |
− | nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ) {
| |
− |
| |
− | return jQuery( elem ).children( "tbody" )[ 0 ] || elem;
| |
− | }
| |
− |
| |
− | return elem;
| |
− | }
| |
− |
| |
− | // Replace/restore the type attribute of script elements for safe DOM manipulation
| |
− | function disableScript( elem ) {
| |
− | elem.type = ( elem.getAttribute( "type" ) !== null ) + "/" + elem.type;
| |
− | return elem;
| |
− | }
| |
− | function restoreScript( elem ) {
| |
− | if ( ( elem.type || "" ).slice( 0, 5 ) === "true/" ) {
| |
− | elem.type = elem.type.slice( 5 );
| |
− | } else {
| |
− | elem.removeAttribute( "type" );
| |
− | }
| |
− |
| |
− | return elem;
| |
− | }
| |
− |
| |
− | function cloneCopyEvent( src, dest ) {
| |
− | var i, l, type, pdataOld, pdataCur, udataOld, udataCur, events;
| |
− |
| |
− | if ( dest.nodeType !== 1 ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // 1. Copy private data: events, handlers, etc.
| |
− | if ( dataPriv.hasData( src ) ) {
| |
− | pdataOld = dataPriv.access( src );
| |
− | pdataCur = dataPriv.set( dest, pdataOld );
| |
− | events = pdataOld.events;
| |
− |
| |
− | if ( events ) {
| |
− | delete pdataCur.handle;
| |
− | pdataCur.events = {};
| |
− |
| |
− | for ( type in events ) {
| |
− | for ( i = 0, l = events[ type ].length; i < l; i++ ) {
| |
− | jQuery.event.add( dest, type, events[ type ][ i ] );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // 2. Copy user data
| |
− | if ( dataUser.hasData( src ) ) {
| |
− | udataOld = dataUser.access( src );
| |
− | udataCur = jQuery.extend( {}, udataOld );
| |
− |
| |
− | dataUser.set( dest, udataCur );
| |
− | }
| |
− | }
| |
− |
| |
− | // Fix IE bugs, see support tests
| |
− | function fixInput( src, dest ) {
| |
− | var nodeName = dest.nodeName.toLowerCase();
| |
− |
| |
− | // Fails to persist the checked state of a cloned checkbox or radio button.
| |
− | if ( nodeName === "input" && rcheckableType.test( src.type ) ) {
| |
− | dest.checked = src.checked;
| |
− |
| |
− | // Fails to return the selected option to the default selected state when cloning options
| |
− | } else if ( nodeName === "input" || nodeName === "textarea" ) {
| |
− | dest.defaultValue = src.defaultValue;
| |
− | }
| |
− | }
| |
− |
| |
− | function domManip( collection, args, callback, ignored ) {
| |
− |
| |
− | // Flatten any nested arrays
| |
− | args = concat.apply( [], args );
| |
− |
| |
− | var fragment, first, scripts, hasScripts, node, doc,
| |
− | i = 0,
| |
− | l = collection.length,
| |
− | iNoClone = l - 1,
| |
− | value = args[ 0 ],
| |
− | valueIsFunction = isFunction( value );
| |
− |
| |
− | // We can't cloneNode fragments that contain checked, in WebKit
| |
− | if ( valueIsFunction ||
| |
− | ( l > 1 && typeof value === "string" &&
| |
− | !support.checkClone && rchecked.test( value ) ) ) {
| |
− | return collection.each( function( index ) {
| |
− | var self = collection.eq( index );
| |
− | if ( valueIsFunction ) {
| |
− | args[ 0 ] = value.call( this, index, self.html() );
| |
− | }
| |
− | domManip( self, args, callback, ignored );
| |
− | } );
| |
− | }
| |
− |
| |
− | if ( l ) {
| |
− | fragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored );
| |
− | first = fragment.firstChild;
| |
− |
| |
− | if ( fragment.childNodes.length === 1 ) {
| |
− | fragment = first;
| |
− | }
| |
− |
| |
− | // Require either new content or an interest in ignored elements to invoke the callback
| |
− | if ( first || ignored ) {
| |
− | scripts = jQuery.map( getAll( fragment, "script" ), disableScript );
| |
− | hasScripts = scripts.length;
| |
− |
| |
− | // Use the original fragment for the last item
| |
− | // instead of the first because it can end up
| |
− | // being emptied incorrectly in certain situations (#8070).
| |
− | for ( ; i < l; i++ ) {
| |
− | node = fragment;
| |
− |
| |
− | if ( i !== iNoClone ) {
| |
− | node = jQuery.clone( node, true, true );
| |
− |
| |
− | // Keep references to cloned scripts for later restoration
| |
− | if ( hasScripts ) {
| |
− |
| |
− | // Support: Android <=4.0 only, PhantomJS 1 only
| |
− | // push.apply(_, arraylike) throws on ancient WebKit
| |
− | jQuery.merge( scripts, getAll( node, "script" ) );
| |
− | }
| |
− | }
| |
− |
| |
− | callback.call( collection[ i ], node, i );
| |
− | }
| |
− |
| |
− | if ( hasScripts ) {
| |
− | doc = scripts[ scripts.length - 1 ].ownerDocument;
| |
− |
| |
− | // Reenable scripts
| |
− | jQuery.map( scripts, restoreScript );
| |
− |
| |
− | // Evaluate executable scripts on first document insertion
| |
− | for ( i = 0; i < hasScripts; i++ ) {
| |
− | node = scripts[ i ];
| |
− | if ( rscriptType.test( node.type || "" ) &&
| |
− | !dataPriv.access( node, "globalEval" ) &&
| |
− | jQuery.contains( doc, node ) ) {
| |
− |
| |
− | if ( node.src && ( node.type || "" ).toLowerCase() !== "module" ) {
| |
− |
| |
− | // Optional AJAX dependency, but won't run scripts if not present
| |
− | if ( jQuery._evalUrl ) {
| |
− | jQuery._evalUrl( node.src );
| |
− | }
| |
− | } else {
| |
− | DOMEval( node.textContent.replace( rcleanScript, "" ), doc, node );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return collection;
| |
− | }
| |
− |
| |
− | function remove( elem, selector, keepData ) {
| |
− | var node,
| |
− | nodes = selector ? jQuery.filter( selector, elem ) : elem,
| |
− | i = 0;
| |
− |
| |
− | for ( ; ( node = nodes[ i ] ) != null; i++ ) {
| |
− | if ( !keepData && node.nodeType === 1 ) {
| |
− | jQuery.cleanData( getAll( node ) );
| |
− | }
| |
− |
| |
− | if ( node.parentNode ) {
| |
− | if ( keepData && jQuery.contains( node.ownerDocument, node ) ) {
| |
− | setGlobalEval( getAll( node, "script" ) );
| |
− | }
| |
− | node.parentNode.removeChild( node );
| |
− | }
| |
− | }
| |
− |
| |
− | return elem;
| |
− | }
| |
− |
| |
− | jQuery.extend( {
| |
− | htmlPrefilter: function( html ) {
| |
− | return html.replace( rxhtmlTag, "<$1></$2>" );
| |
− | },
| |
− |
| |
− | clone: function( elem, dataAndEvents, deepDataAndEvents ) {
| |
− | var i, l, srcElements, destElements,
| |
− | clone = elem.cloneNode( true ),
| |
− | inPage = jQuery.contains( elem.ownerDocument, elem );
| |
− |
| |
− | // Fix IE cloning issues
| |
− | if ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&
| |
− | !jQuery.isXMLDoc( elem ) ) {
| |
− |
| |
− | // We eschew Sizzle here for performance reasons: https://jsperf.com/getall-vs-sizzle/2
| |
− | destElements = getAll( clone );
| |
− | srcElements = getAll( elem );
| |
− |
| |
− | for ( i = 0, l = srcElements.length; i < l; i++ ) {
| |
− | fixInput( srcElements[ i ], destElements[ i ] );
| |
− | }
| |
− | }
| |
− |
| |
− | // Copy the events from the original to the clone
| |
− | if ( dataAndEvents ) {
| |
− | if ( deepDataAndEvents ) {
| |
− | srcElements = srcElements || getAll( elem );
| |
− | destElements = destElements || getAll( clone );
| |
− |
| |
− | for ( i = 0, l = srcElements.length; i < l; i++ ) {
| |
− | cloneCopyEvent( srcElements[ i ], destElements[ i ] );
| |
− | }
| |
− | } else {
| |
− | cloneCopyEvent( elem, clone );
| |
− | }
| |
− | }
| |
− |
| |
− | // Preserve script evaluation history
| |
− | destElements = getAll( clone, "script" );
| |
− | if ( destElements.length > 0 ) {
| |
− | setGlobalEval( destElements, !inPage && getAll( elem, "script" ) );
| |
− | }
| |
− |
| |
− | // Return the cloned set
| |
− | return clone;
| |
− | },
| |
− |
| |
− | cleanData: function( elems ) {
| |
− | var data, elem, type,
| |
− | special = jQuery.event.special,
| |
− | i = 0;
| |
− |
| |
− | for ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {
| |
− | if ( acceptData( elem ) ) {
| |
− | if ( ( data = elem[ dataPriv.expando ] ) ) {
| |
− | if ( data.events ) {
| |
− | for ( type in data.events ) {
| |
− | if ( special[ type ] ) {
| |
− | jQuery.event.remove( elem, type );
| |
− |
| |
− | // This is a shortcut to avoid jQuery.event.remove's overhead
| |
− | } else {
| |
− | jQuery.removeEvent( elem, type, data.handle );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Support: Chrome <=35 - 45+
| |
− | // Assign undefined instead of using delete, see Data#remove
| |
− | elem[ dataPriv.expando ] = undefined;
| |
− | }
| |
− | if ( elem[ dataUser.expando ] ) {
| |
− |
| |
− | // Support: Chrome <=35 - 45+
| |
− | // Assign undefined instead of using delete, see Data#remove
| |
− | elem[ dataUser.expando ] = undefined;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | detach: function( selector ) {
| |
− | return remove( this, selector, true );
| |
− | },
| |
− |
| |
− | remove: function( selector ) {
| |
− | return remove( this, selector );
| |
− | },
| |
− |
| |
− | text: function( value ) {
| |
− | return access( this, function( value ) {
| |
− | return value === undefined ?
| |
− | jQuery.text( this ) :
| |
− | this.empty().each( function() {
| |
− | if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
| |
− | this.textContent = value;
| |
− | }
| |
− | } );
| |
− | }, null, value, arguments.length );
| |
− | },
| |
− |
| |
− | append: function() {
| |
− | return domManip( this, arguments, function( elem ) {
| |
− | if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
| |
− | var target = manipulationTarget( this, elem );
| |
− | target.appendChild( elem );
| |
− | }
| |
− | } );
| |
− | },
| |
− |
| |
− | prepend: function() {
| |
− | return domManip( this, arguments, function( elem ) {
| |
− | if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
| |
− | var target = manipulationTarget( this, elem );
| |
− | target.insertBefore( elem, target.firstChild );
| |
− | }
| |
− | } );
| |
− | },
| |
− |
| |
− | before: function() {
| |
− | return domManip( this, arguments, function( elem ) {
| |
− | if ( this.parentNode ) {
| |
− | this.parentNode.insertBefore( elem, this );
| |
− | }
| |
− | } );
| |
− | },
| |
− |
| |
− | after: function() {
| |
− | return domManip( this, arguments, function( elem ) {
| |
− | if ( this.parentNode ) {
| |
− | this.parentNode.insertBefore( elem, this.nextSibling );
| |
− | }
| |
− | } );
| |
− | },
| |
− |
| |
− | empty: function() {
| |
− | var elem,
| |
− | i = 0;
| |
− |
| |
− | for ( ; ( elem = this[ i ] ) != null; i++ ) {
| |
− | if ( elem.nodeType === 1 ) {
| |
− |
| |
− | // Prevent memory leaks
| |
− | jQuery.cleanData( getAll( elem, false ) );
| |
− |
| |
− | // Remove any remaining nodes
| |
− | elem.textContent = "";
| |
− | }
| |
− | }
| |
− |
| |
− | return this;
| |
− | },
| |
− |
| |
− | clone: function( dataAndEvents, deepDataAndEvents ) {
| |
− | dataAndEvents = dataAndEvents == null ? false : dataAndEvents;
| |
− | deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;
| |
− |
| |
− | return this.map( function() {
| |
− | return jQuery.clone( this, dataAndEvents, deepDataAndEvents );
| |
− | } );
| |
− | },
| |
− |
| |
− | html: function( value ) {
| |
− | return access( this, function( value ) {
| |
− | var elem = this[ 0 ] || {},
| |
− | i = 0,
| |
− | l = this.length;
| |
− |
| |
− | if ( value === undefined && elem.nodeType === 1 ) {
| |
− | return elem.innerHTML;
| |
− | }
| |
− |
| |
− | // See if we can take a shortcut and just use innerHTML
| |
− | if ( typeof value === "string" && !rnoInnerhtml.test( value ) &&
| |
− | !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) {
| |
− |
| |
− | value = jQuery.htmlPrefilter( value );
| |
− |
| |
− | try {
| |
− | for ( ; i < l; i++ ) {
| |
− | elem = this[ i ] || {};
| |
− |
| |
− | // Remove element nodes and prevent memory leaks
| |
− | if ( elem.nodeType === 1 ) {
| |
− | jQuery.cleanData( getAll( elem, false ) );
| |
− | elem.innerHTML = value;
| |
− | }
| |
− | }
| |
− |
| |
− | elem = 0;
| |
− |
| |
− | // If using innerHTML throws an exception, use the fallback method
| |
− | } catch ( e ) {}
| |
− | }
| |
− |
| |
− | if ( elem ) {
| |
− | this.empty().append( value );
| |
− | }
| |
− | }, null, value, arguments.length );
| |
− | },
| |
− |
| |
− | replaceWith: function() {
| |
− | var ignored = [];
| |
− |
| |
− | // Make the changes, replacing each non-ignored context element with the new content
| |
− | return domManip( this, arguments, function( elem ) {
| |
− | var parent = this.parentNode;
| |
− |
| |
− | if ( jQuery.inArray( this, ignored ) < 0 ) {
| |
− | jQuery.cleanData( getAll( this ) );
| |
− | if ( parent ) {
| |
− | parent.replaceChild( elem, this );
| |
− | }
| |
− | }
| |
− |
| |
− | // Force callback invocation
| |
− | }, ignored );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.each( {
| |
− | appendTo: "append",
| |
− | prependTo: "prepend",
| |
− | insertBefore: "before",
| |
− | insertAfter: "after",
| |
− | replaceAll: "replaceWith"
| |
− | }, function( name, original ) {
| |
− | jQuery.fn[ name ] = function( selector ) {
| |
− | var elems,
| |
− | ret = [],
| |
− | insert = jQuery( selector ),
| |
− | last = insert.length - 1,
| |
− | i = 0;
| |
− |
| |
− | for ( ; i <= last; i++ ) {
| |
− | elems = i === last ? this : this.clone( true );
| |
− | jQuery( insert[ i ] )[ original ]( elems );
| |
− |
| |
− | // Support: Android <=4.0 only, PhantomJS 1 only
| |
− | // .get() because push.apply(_, arraylike) throws on ancient WebKit
| |
− | push.apply( ret, elems.get() );
| |
− | }
| |
− |
| |
− | return this.pushStack( ret );
| |
− | };
| |
− | } );
| |
− | var rnumnonpx = new RegExp( "^(" + pnum + ")(?!px)[a-z%]+$", "i" );
| |
− |
| |
− | var getStyles = function( elem ) {
| |
− |
| |
− | // Support: IE <=11 only, Firefox <=30 (#15098, #14150)
| |
− | // IE throws on elements created in popups
| |
− | // FF meanwhile throws on frame elements through "defaultView.getComputedStyle"
| |
− | var view = elem.ownerDocument.defaultView;
| |
− |
| |
− | if ( !view || !view.opener ) {
| |
− | view = window;
| |
− | }
| |
− |
| |
− | return view.getComputedStyle( elem );
| |
− | };
| |
− |
| |
− | var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );
| |
− |
| |
− |
| |
− |
| |
− | ( function() {
| |
− |
| |
− | // Executing both pixelPosition & boxSizingReliable tests require only one layout
| |
− | // so they're executed at the same time to save the second computation.
| |
− | function computeStyleTests() {
| |
− |
| |
− | // This is a singleton, we need to execute it only once
| |
− | if ( !div ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | container.style.cssText = "position:absolute;left:-11111px;width:60px;" +
| |
− | "margin-top:1px;padding:0;border:0";
| |
− | div.style.cssText =
| |
− | "position:relative;display:block;box-sizing:border-box;overflow:scroll;" +
| |
− | "margin:auto;border:1px;padding:1px;" +
| |
− | "width:60%;top:1%";
| |
− | documentElement.appendChild( container ).appendChild( div );
| |
− |
| |
− | var divStyle = window.getComputedStyle( div );
| |
− | pixelPositionVal = divStyle.top !== "1%";
| |
− |
| |
− | // Support: Android 4.0 - 4.3 only, Firefox <=3 - 44
| |
− | reliableMarginLeftVal = roundPixelMeasures( divStyle.marginLeft ) === 12;
| |
− |
| |
− | // Support: Android 4.0 - 4.3 only, Safari <=9.1 - 10.1, iOS <=7.0 - 9.3
| |
− | // Some styles come back with percentage values, even though they shouldn't
| |
− | div.style.right = "60%";
| |
− | pixelBoxStylesVal = roundPixelMeasures( divStyle.right ) === 36;
| |
− |
| |
− | // Support: IE 9 - 11 only
| |
− | // Detect misreporting of content dimensions for box-sizing:border-box elements
| |
− | boxSizingReliableVal = roundPixelMeasures( divStyle.width ) === 36;
| |
− |
| |
− | // Support: IE 9 only
| |
− | // Detect overflow:scroll screwiness (gh-3699)
| |
− | div.style.position = "absolute";
| |
− | scrollboxSizeVal = div.offsetWidth === 36 || "absolute";
| |
− |
| |
− | documentElement.removeChild( container );
| |
− |
| |
− | // Nullify the div so it wouldn't be stored in the memory and
| |
− | // it will also be a sign that checks already performed
| |
− | div = null;
| |
− | }
| |
− |
| |
− | function roundPixelMeasures( measure ) {
| |
− | return Math.round( parseFloat( measure ) );
| |
− | }
| |
− |
| |
− | var pixelPositionVal, boxSizingReliableVal, scrollboxSizeVal, pixelBoxStylesVal,
| |
− | reliableMarginLeftVal,
| |
− | container = document.createElement( "div" ),
| |
− | div = document.createElement( "div" );
| |
− |
| |
− | // Finish early in limited (non-browser) environments
| |
− | if ( !div.style ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // Support: IE <=9 - 11 only
| |
− | // Style of cloned element affects source element cloned (#8908)
| |
− | div.style.backgroundClip = "content-box";
| |
− | div.cloneNode( true ).style.backgroundClip = "";
| |
− | support.clearCloneStyle = div.style.backgroundClip === "content-box";
| |
− |
| |
− | jQuery.extend( support, {
| |
− | boxSizingReliable: function() {
| |
− | computeStyleTests();
| |
− | return boxSizingReliableVal;
| |
− | },
| |
− | pixelBoxStyles: function() {
| |
− | computeStyleTests();
| |
− | return pixelBoxStylesVal;
| |
− | },
| |
− | pixelPosition: function() {
| |
− | computeStyleTests();
| |
− | return pixelPositionVal;
| |
− | },
| |
− | reliableMarginLeft: function() {
| |
− | computeStyleTests();
| |
− | return reliableMarginLeftVal;
| |
− | },
| |
− | scrollboxSize: function() {
| |
− | computeStyleTests();
| |
− | return scrollboxSizeVal;
| |
− | }
| |
− | } );
| |
− | } )();
| |
− |
| |
− |
| |
− | function curCSS( elem, name, computed ) {
| |
− | var width, minWidth, maxWidth, ret,
| |
− |
| |
− | // Support: Firefox 51+
| |
− | // Retrieving style before computed somehow
| |
− | // fixes an issue with getting wrong values
| |
− | // on detached elements
| |
− | style = elem.style;
| |
− |
| |
− | computed = computed || getStyles( elem );
| |
− |
| |
− | // getPropertyValue is needed for:
| |
− | // .css('filter') (IE 9 only, #12537)
| |
− | // .css('--customProperty) (#3144)
| |
− | if ( computed ) {
| |
− | ret = computed.getPropertyValue( name ) || computed[ name ];
| |
− |
| |
− | if ( ret === "" && !jQuery.contains( elem.ownerDocument, elem ) ) {
| |
− | ret = jQuery.style( elem, name );
| |
− | }
| |
− |
| |
− | // A tribute to the "awesome hack by Dean Edwards"
| |
− | // Android Browser returns percentage for some values,
| |
− | // but width seems to be reliably pixels.
| |
− | // This is against the CSSOM draft spec:
| |
− | // https://drafts.csswg.org/cssom/#resolved-values
| |
− | if ( !support.pixelBoxStyles() && rnumnonpx.test( ret ) && rboxStyle.test( name ) ) {
| |
− |
| |
− | // Remember the original values
| |
− | width = style.width;
| |
− | minWidth = style.minWidth;
| |
− | maxWidth = style.maxWidth;
| |
− |
| |
− | // Put in the new values to get a computed value out
| |
− | style.minWidth = style.maxWidth = style.width = ret;
| |
− | ret = computed.width;
| |
− |
| |
− | // Revert the changed values
| |
− | style.width = width;
| |
− | style.minWidth = minWidth;
| |
− | style.maxWidth = maxWidth;
| |
− | }
| |
− | }
| |
− |
| |
− | return ret !== undefined ?
| |
− |
| |
− | // Support: IE <=9 - 11 only
| |
− | // IE returns zIndex value as an integer.
| |
− | ret + "" :
| |
− | ret;
| |
− | }
| |
− |
| |
− |
| |
− | function addGetHookIf( conditionFn, hookFn ) {
| |
− |
| |
− | // Define the hook, we'll check on the first run if it's really needed.
| |
− | return {
| |
− | get: function() {
| |
− | if ( conditionFn() ) {
| |
− |
| |
− | // Hook not needed (or it's not possible to use it due
| |
− | // to missing dependency), remove it.
| |
− | delete this.get;
| |
− | return;
| |
− | }
| |
− |
| |
− | // Hook needed; redefine it so that the support test is not executed again.
| |
− | return ( this.get = hookFn ).apply( this, arguments );
| |
− | }
| |
− | };
| |
− | }
| |
− |
| |
− |
| |
− | var
| |
− |
| |
− | // Swappable if display is none or starts with table
| |
− | // except "table", "table-cell", or "table-caption"
| |
− | // See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display
| |
− | rdisplayswap = /^(none|table(?!-c[ea]).+)/,
| |
− | rcustomProp = /^--/,
| |
− | cssShow = { position: "absolute", visibility: "hidden", display: "block" },
| |
− | cssNormalTransform = {
| |
− | letterSpacing: "0",
| |
− | fontWeight: "400"
| |
− | },
| |
− |
| |
− | cssPrefixes = [ "Webkit", "Moz", "ms" ],
| |
− | emptyStyle = document.createElement( "div" ).style;
| |
− |
| |
− | // Return a css property mapped to a potentially vendor prefixed property
| |
− | function vendorPropName( name ) {
| |
− |
| |
− | // Shortcut for names that are not vendor prefixed
| |
− | if ( name in emptyStyle ) {
| |
− | return name;
| |
− | }
| |
− |
| |
− | // Check for vendor prefixed names
| |
− | var capName = name[ 0 ].toUpperCase() + name.slice( 1 ),
| |
− | i = cssPrefixes.length;
| |
− |
| |
− | while ( i-- ) {
| |
− | name = cssPrefixes[ i ] + capName;
| |
− | if ( name in emptyStyle ) {
| |
− | return name;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Return a property mapped along what jQuery.cssProps suggests or to
| |
− | // a vendor prefixed property.
| |
− | function finalPropName( name ) {
| |
− | var ret = jQuery.cssProps[ name ];
| |
− | if ( !ret ) {
| |
− | ret = jQuery.cssProps[ name ] = vendorPropName( name ) || name;
| |
− | }
| |
− | return ret;
| |
− | }
| |
− |
| |
− | function setPositiveNumber( elem, value, subtract ) {
| |
− |
| |
− | // Any relative (+/-) values have already been
| |
− | // normalized at this point
| |
− | var matches = rcssNum.exec( value );
| |
− | return matches ?
| |
− |
| |
− | // Guard against undefined "subtract", e.g., when used as in cssHooks
| |
− | Math.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || "px" ) :
| |
− | value;
| |
− | }
| |
− |
| |
− | function boxModelAdjustment( elem, dimension, box, isBorderBox, styles, computedVal ) {
| |
− | var i = dimension === "width" ? 1 : 0,
| |
− | extra = 0,
| |
− | delta = 0;
| |
− |
| |
− | // Adjustment may not be necessary
| |
− | if ( box === ( isBorderBox ? "border" : "content" ) ) {
| |
− | return 0;
| |
− | }
| |
− |
| |
− | for ( ; i < 4; i += 2 ) {
| |
− |
| |
− | // Both box models exclude margin
| |
− | if ( box === "margin" ) {
| |
− | delta += jQuery.css( elem, box + cssExpand[ i ], true, styles );
| |
− | }
| |
− |
| |
− | // If we get here with a content-box, we're seeking "padding" or "border" or "margin"
| |
− | if ( !isBorderBox ) {
| |
− |
| |
− | // Add padding
| |
− | delta += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles );
| |
− |
| |
− | // For "border" or "margin", add border
| |
− | if ( box !== "padding" ) {
| |
− | delta += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles );
| |
− |
| |
− | // But still keep track of it otherwise
| |
− | } else {
| |
− | extra += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles );
| |
− | }
| |
− |
| |
− | // If we get here with a border-box (content + padding + border), we're seeking "content" or
| |
− | // "padding" or "margin"
| |
− | } else {
| |
− |
| |
− | // For "content", subtract padding
| |
− | if ( box === "content" ) {
| |
− | delta -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles );
| |
− | }
| |
− |
| |
− | // For "content" or "padding", subtract border
| |
− | if ( box !== "margin" ) {
| |
− | delta -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Account for positive content-box scroll gutter when requested by providing computedVal
| |
− | if ( !isBorderBox && computedVal >= 0 ) {
| |
− |
| |
− | // offsetWidth/offsetHeight is a rounded sum of content, padding, scroll gutter, and border
| |
− | // Assuming integer scroll gutter, subtract the rest and round down
| |
− | delta += Math.max( 0, Math.ceil(
| |
− | elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] -
| |
− | computedVal -
| |
− | delta -
| |
− | extra -
| |
− | 0.5
| |
− | ) );
| |
− | }
| |
− |
| |
− | return delta;
| |
− | }
| |
− |
| |
− | function getWidthOrHeight( elem, dimension, extra ) {
| |
− |
| |
− | // Start with computed style
| |
− | var styles = getStyles( elem ),
| |
− | val = curCSS( elem, dimension, styles ),
| |
− | isBorderBox = jQuery.css( elem, "boxSizing", false, styles ) === "border-box",
| |
− | valueIsBorderBox = isBorderBox;
| |
− |
| |
− | // Support: Firefox <=54
| |
− | // Return a confounding non-pixel value or feign ignorance, as appropriate.
| |
− | if ( rnumnonpx.test( val ) ) {
| |
− | if ( !extra ) {
| |
− | return val;
| |
− | }
| |
− | val = "auto";
| |
− | }
| |
− |
| |
− | // Check for style in case a browser which returns unreliable values
| |
− | // for getComputedStyle silently falls back to the reliable elem.style
| |
− | valueIsBorderBox = valueIsBorderBox &&
| |
− | ( support.boxSizingReliable() || val === elem.style[ dimension ] );
| |
− |
| |
− | // Fall back to offsetWidth/offsetHeight when value is "auto"
| |
− | // This happens for inline elements with no explicit setting (gh-3571)
| |
− | // Support: Android <=4.1 - 4.3 only
| |
− | // Also use offsetWidth/offsetHeight for misreported inline dimensions (gh-3602)
| |
− | if ( val === "auto" ||
| |
− | !parseFloat( val ) && jQuery.css( elem, "display", false, styles ) === "inline" ) {
| |
− |
| |
− | val = elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ];
| |
− |
| |
− | // offsetWidth/offsetHeight provide border-box values
| |
− | valueIsBorderBox = true;
| |
− | }
| |
− |
| |
− | // Normalize "" and auto
| |
− | val = parseFloat( val ) || 0;
| |
− |
| |
− | // Adjust for the element's box model
| |
− | return ( val +
| |
− | boxModelAdjustment(
| |
− | elem,
| |
− | dimension,
| |
− | extra || ( isBorderBox ? "border" : "content" ),
| |
− | valueIsBorderBox,
| |
− | styles,
| |
− |
| |
− | // Provide the current computed size to request scroll gutter calculation (gh-3589)
| |
− | val
| |
− | )
| |
− | ) + "px";
| |
− | }
| |
− |
| |
− | jQuery.extend( {
| |
− |
| |
− | // Add in style property hooks for overriding the default
| |
− | // behavior of getting and setting a style property
| |
− | cssHooks: {
| |
− | opacity: {
| |
− | get: function( elem, computed ) {
| |
− | if ( computed ) {
| |
− |
| |
− | // We should always get a number back from opacity
| |
− | var ret = curCSS( elem, "opacity" );
| |
− | return ret === "" ? "1" : ret;
| |
− | }
| |
− | }
| |
− | }
| |
− | },
| |
− |
| |
− | // Don't automatically add "px" to these possibly-unitless properties
| |
− | cssNumber: {
| |
− | "animationIterationCount": true,
| |
− | "columnCount": true,
| |
− | "fillOpacity": true,
| |
− | "flexGrow": true,
| |
− | "flexShrink": true,
| |
− | "fontWeight": true,
| |
− | "lineHeight": true,
| |
− | "opacity": true,
| |
− | "order": true,
| |
− | "orphans": true,
| |
− | "widows": true,
| |
− | "zIndex": true,
| |
− | "zoom": true
| |
− | },
| |
− |
| |
− | // Add in properties whose names you wish to fix before
| |
− | // setting or getting the value
| |
− | cssProps: {},
| |
− |
| |
− | // Get and set the style property on a DOM Node
| |
− | style: function( elem, name, value, extra ) {
| |
− |
| |
− | // Don't set styles on text and comment nodes
| |
− | if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // Make sure that we're working with the right name
| |
− | var ret, type, hooks,
| |
− | origName = camelCase( name ),
| |
− | isCustomProp = rcustomProp.test( name ),
| |
− | style = elem.style;
| |
− |
| |
− | // Make sure that we're working with the right name. We don't
| |
− | // want to query the value if it is a CSS custom property
| |
− | // since they are user-defined.
| |
− | if ( !isCustomProp ) {
| |
− | name = finalPropName( origName );
| |
− | }
| |
− |
| |
− | // Gets hook for the prefixed version, then unprefixed version
| |
− | hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];
| |
− |
| |
− | // Check if we're setting a value
| |
− | if ( value !== undefined ) {
| |
− | type = typeof value;
| |
− |
| |
− | // Convert "+=" or "-=" to relative numbers (#7345)
| |
− | if ( type === "string" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) {
| |
− | value = adjustCSS( elem, name, ret );
| |
− |
| |
− | // Fixes bug #9237
| |
− | type = "number";
| |
− | }
| |
− |
| |
− | // Make sure that null and NaN values aren't set (#7116)
| |
− | if ( value == null || value !== value ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // If a number was passed in, add the unit (except for certain CSS properties)
| |
− | if ( type === "number" ) {
| |
− | value += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? "" : "px" );
| |
− | }
| |
− |
| |
− | // background-* props affect original clone's values
| |
− | if ( !support.clearCloneStyle && value === "" && name.indexOf( "background" ) === 0 ) {
| |
− | style[ name ] = "inherit";
| |
− | }
| |
− |
| |
− | // If a hook was provided, use that value, otherwise just set the specified value
| |
− | if ( !hooks || !( "set" in hooks ) ||
| |
− | ( value = hooks.set( elem, value, extra ) ) !== undefined ) {
| |
− |
| |
− | if ( isCustomProp ) {
| |
− | style.setProperty( name, value );
| |
− | } else {
| |
− | style[ name ] = value;
| |
− | }
| |
− | }
| |
− |
| |
− | } else {
| |
− |
| |
− | // If a hook was provided get the non-computed value from there
| |
− | if ( hooks && "get" in hooks &&
| |
− | ( ret = hooks.get( elem, false, extra ) ) !== undefined ) {
| |
− |
| |
− | return ret;
| |
− | }
| |
− |
| |
− | // Otherwise just get the value from the style object
| |
− | return style[ name ];
| |
− | }
| |
− | },
| |
− |
| |
− | css: function( elem, name, extra, styles ) {
| |
− | var val, num, hooks,
| |
− | origName = camelCase( name ),
| |
− | isCustomProp = rcustomProp.test( name );
| |
− |
| |
− | // Make sure that we're working with the right name. We don't
| |
− | // want to modify the value if it is a CSS custom property
| |
− | // since they are user-defined.
| |
− | if ( !isCustomProp ) {
| |
− | name = finalPropName( origName );
| |
− | }
| |
− |
| |
− | // Try prefixed name followed by the unprefixed name
| |
− | hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];
| |
− |
| |
− | // If a hook was provided get the computed value from there
| |
− | if ( hooks && "get" in hooks ) {
| |
− | val = hooks.get( elem, true, extra );
| |
− | }
| |
− |
| |
− | // Otherwise, if a way to get the computed value exists, use that
| |
− | if ( val === undefined ) {
| |
− | val = curCSS( elem, name, styles );
| |
− | }
| |
− |
| |
− | // Convert "normal" to computed value
| |
− | if ( val === "normal" && name in cssNormalTransform ) {
| |
− | val = cssNormalTransform[ name ];
| |
− | }
| |
− |
| |
− | // Make numeric if forced or a qualifier was provided and val looks numeric
| |
− | if ( extra === "" || extra ) {
| |
− | num = parseFloat( val );
| |
− | return extra === true || isFinite( num ) ? num || 0 : val;
| |
− | }
| |
− |
| |
− | return val;
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.each( [ "height", "width" ], function( i, dimension ) {
| |
− | jQuery.cssHooks[ dimension ] = {
| |
− | get: function( elem, computed, extra ) {
| |
− | if ( computed ) {
| |
− |
| |
− | // Certain elements can have dimension info if we invisibly show them
| |
− | // but it must have a current display style that would benefit
| |
− | return rdisplayswap.test( jQuery.css( elem, "display" ) ) &&
| |
− |
| |
− | // Support: Safari 8+
| |
− | // Table columns in Safari have non-zero offsetWidth & zero
| |
− | // getBoundingClientRect().width unless display is changed.
| |
− | // Support: IE <=11 only
| |
− | // Running getBoundingClientRect on a disconnected node
| |
− | // in IE throws an error.
| |
− | ( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ?
| |
− | swap( elem, cssShow, function() {
| |
− | return getWidthOrHeight( elem, dimension, extra );
| |
− | } ) :
| |
− | getWidthOrHeight( elem, dimension, extra );
| |
− | }
| |
− | },
| |
− |
| |
− | set: function( elem, value, extra ) {
| |
− | var matches,
| |
− | styles = getStyles( elem ),
| |
− | isBorderBox = jQuery.css( elem, "boxSizing", false, styles ) === "border-box",
| |
− | subtract = extra && boxModelAdjustment(
| |
− | elem,
| |
− | dimension,
| |
− | extra,
| |
− | isBorderBox,
| |
− | styles
| |
− | );
| |
− |
| |
− | // Account for unreliable border-box dimensions by comparing offset* to computed and
| |
− | // faking a content-box to get border and padding (gh-3699)
| |
− | if ( isBorderBox && support.scrollboxSize() === styles.position ) {
| |
− | subtract -= Math.ceil(
| |
− | elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] -
| |
− | parseFloat( styles[ dimension ] ) -
| |
− | boxModelAdjustment( elem, dimension, "border", false, styles ) -
| |
− | 0.5
| |
− | );
| |
− | }
| |
− |
| |
− | // Convert to pixels if value adjustment is needed
| |
− | if ( subtract && ( matches = rcssNum.exec( value ) ) &&
| |
− | ( matches[ 3 ] || "px" ) !== "px" ) {
| |
− |
| |
− | elem.style[ dimension ] = value;
| |
− | value = jQuery.css( elem, dimension );
| |
− | }
| |
− |
| |
− | return setPositiveNumber( elem, value, subtract );
| |
− | }
| |
− | };
| |
− | } );
| |
− |
| |
− | jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,
| |
− | function( elem, computed ) {
| |
− | if ( computed ) {
| |
− | return ( parseFloat( curCSS( elem, "marginLeft" ) ) ||
| |
− | elem.getBoundingClientRect().left -
| |
− | swap( elem, { marginLeft: 0 }, function() {
| |
− | return elem.getBoundingClientRect().left;
| |
− | } )
| |
− | ) + "px";
| |
− | }
| |
− | }
| |
− | );
| |
− |
| |
− | // These hooks are used by animate to expand properties
| |
− | jQuery.each( {
| |
− | margin: "",
| |
− | padding: "",
| |
− | border: "Width"
| |
− | }, function( prefix, suffix ) {
| |
− | jQuery.cssHooks[ prefix + suffix ] = {
| |
− | expand: function( value ) {
| |
− | var i = 0,
| |
− | expanded = {},
| |
− |
| |
− | // Assumes a single number if not a string
| |
− | parts = typeof value === "string" ? value.split( " " ) : [ value ];
| |
− |
| |
− | for ( ; i < 4; i++ ) {
| |
− | expanded[ prefix + cssExpand[ i ] + suffix ] =
| |
− | parts[ i ] || parts[ i - 2 ] || parts[ 0 ];
| |
− | }
| |
− |
| |
− | return expanded;
| |
− | }
| |
− | };
| |
− |
| |
− | if ( prefix !== "margin" ) {
| |
− | jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber;
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | css: function( name, value ) {
| |
− | return access( this, function( elem, name, value ) {
| |
− | var styles, len,
| |
− | map = {},
| |
− | i = 0;
| |
− |
| |
− | if ( Array.isArray( name ) ) {
| |
− | styles = getStyles( elem );
| |
− | len = name.length;
| |
− |
| |
− | for ( ; i < len; i++ ) {
| |
− | map[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles );
| |
− | }
| |
− |
| |
− | return map;
| |
− | }
| |
− |
| |
− | return value !== undefined ?
| |
− | jQuery.style( elem, name, value ) :
| |
− | jQuery.css( elem, name );
| |
− | }, name, value, arguments.length > 1 );
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | function Tween( elem, options, prop, end, easing ) {
| |
− | return new Tween.prototype.init( elem, options, prop, end, easing );
| |
− | }
| |
− | jQuery.Tween = Tween;
| |
− |
| |
− | Tween.prototype = {
| |
− | constructor: Tween,
| |
− | init: function( elem, options, prop, end, easing, unit ) {
| |
− | this.elem = elem;
| |
− | this.prop = prop;
| |
− | this.easing = easing || jQuery.easing._default;
| |
− | this.options = options;
| |
− | this.start = this.now = this.cur();
| |
− | this.end = end;
| |
− | this.unit = unit || ( jQuery.cssNumber[ prop ] ? "" : "px" );
| |
− | },
| |
− | cur: function() {
| |
− | var hooks = Tween.propHooks[ this.prop ];
| |
− |
| |
− | return hooks && hooks.get ?
| |
− | hooks.get( this ) :
| |
− | Tween.propHooks._default.get( this );
| |
− | },
| |
− | run: function( percent ) {
| |
− | var eased,
| |
− | hooks = Tween.propHooks[ this.prop ];
| |
− |
| |
− | if ( this.options.duration ) {
| |
− | this.pos = eased = jQuery.easing[ this.easing ](
| |
− | percent, this.options.duration * percent, 0, 1, this.options.duration
| |
− | );
| |
− | } else {
| |
− | this.pos = eased = percent;
| |
− | }
| |
− | this.now = ( this.end - this.start ) * eased + this.start;
| |
− |
| |
− | if ( this.options.step ) {
| |
− | this.options.step.call( this.elem, this.now, this );
| |
− | }
| |
− |
| |
− | if ( hooks && hooks.set ) {
| |
− | hooks.set( this );
| |
− | } else {
| |
− | Tween.propHooks._default.set( this );
| |
− | }
| |
− | return this;
| |
− | }
| |
− | };
| |
− |
| |
− | Tween.prototype.init.prototype = Tween.prototype;
| |
− |
| |
− | Tween.propHooks = {
| |
− | _default: {
| |
− | get: function( tween ) {
| |
− | var result;
| |
− |
| |
− | // Use a property on the element directly when it is not a DOM element,
| |
− | // or when there is no matching style property that exists.
| |
− | if ( tween.elem.nodeType !== 1 ||
| |
− | tween.elem[ tween.prop ] != null && tween.elem.style[ tween.prop ] == null ) {
| |
− | return tween.elem[ tween.prop ];
| |
− | }
| |
− |
| |
− | // Passing an empty string as a 3rd parameter to .css will automatically
| |
− | // attempt a parseFloat and fallback to a string if the parse fails.
| |
− | // Simple values such as "10px" are parsed to Float;
| |
− | // complex values such as "rotate(1rad)" are returned as-is.
| |
− | result = jQuery.css( tween.elem, tween.prop, "" );
| |
− |
| |
− | // Empty strings, null, undefined and "auto" are converted to 0.
| |
− | return !result || result === "auto" ? 0 : result;
| |
− | },
| |
− | set: function( tween ) {
| |
− |
| |
− | // Use step hook for back compat.
| |
− | // Use cssHook if its there.
| |
− | // Use .style if available and use plain properties where available.
| |
− | if ( jQuery.fx.step[ tween.prop ] ) {
| |
− | jQuery.fx.step[ tween.prop ]( tween );
| |
− | } else if ( tween.elem.nodeType === 1 &&
| |
− | ( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null ||
| |
− | jQuery.cssHooks[ tween.prop ] ) ) {
| |
− | jQuery.style( tween.elem, tween.prop, tween.now + tween.unit );
| |
− | } else {
| |
− | tween.elem[ tween.prop ] = tween.now;
| |
− | }
| |
− | }
| |
− | }
| |
− | };
| |
− |
| |
− | // Support: IE <=9 only
| |
− | // Panic based approach to setting things on disconnected nodes
| |
− | Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = {
| |
− | set: function( tween ) {
| |
− | if ( tween.elem.nodeType && tween.elem.parentNode ) {
| |
− | tween.elem[ tween.prop ] = tween.now;
| |
− | }
| |
− | }
| |
− | };
| |
− |
| |
− | jQuery.easing = {
| |
− | linear: function( p ) {
| |
− | return p;
| |
− | },
| |
− | swing: function( p ) {
| |
− | return 0.5 - Math.cos( p * Math.PI ) / 2;
| |
− | },
| |
− | _default: "swing"
| |
− | };
| |
− |
| |
− | jQuery.fx = Tween.prototype.init;
| |
− |
| |
− | // Back compat <1.8 extension point
| |
− | jQuery.fx.step = {};
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | var
| |
− | fxNow, inProgress,
| |
− | rfxtypes = /^(?:toggle|show|hide)$/,
| |
− | rrun = /queueHooks$/;
| |
− |
| |
− | function schedule() {
| |
− | if ( inProgress ) {
| |
− | if ( document.hidden === false && window.requestAnimationFrame ) {
| |
− | window.requestAnimationFrame( schedule );
| |
− | } else {
| |
− | window.setTimeout( schedule, jQuery.fx.interval );
| |
− | }
| |
− |
| |
− | jQuery.fx.tick();
| |
− | }
| |
− | }
| |
− |
| |
− | // Animations created synchronously will run synchronously
| |
− | function createFxNow() {
| |
− | window.setTimeout( function() {
| |
− | fxNow = undefined;
| |
− | } );
| |
− | return ( fxNow = Date.now() );
| |
− | }
| |
− |
| |
− | // Generate parameters to create a standard animation
| |
− | function genFx( type, includeWidth ) {
| |
− | var which,
| |
− | i = 0,
| |
− | attrs = { height: type };
| |
− |
| |
− | // If we include width, step value is 1 to do all cssExpand values,
| |
− | // otherwise step value is 2 to skip over Left and Right
| |
− | includeWidth = includeWidth ? 1 : 0;
| |
− | for ( ; i < 4; i += 2 - includeWidth ) {
| |
− | which = cssExpand[ i ];
| |
− | attrs[ "margin" + which ] = attrs[ "padding" + which ] = type;
| |
− | }
| |
− |
| |
− | if ( includeWidth ) {
| |
− | attrs.opacity = attrs.width = type;
| |
− | }
| |
− |
| |
− | return attrs;
| |
− | }
| |
− |
| |
− | function createTween( value, prop, animation ) {
| |
− | var tween,
| |
− | collection = ( Animation.tweeners[ prop ] || [] ).concat( Animation.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 tween;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | function defaultPrefilter( elem, props, opts ) {
| |
− | var prop, value, toggle, hooks, oldfire, propTween, restoreDisplay, display,
| |
− | isBox = "width" in props || "height" in props,
| |
− | anim = this,
| |
− | orig = {},
| |
− | style = elem.style,
| |
− | hidden = elem.nodeType && isHiddenWithinTree( elem ),
| |
− | dataShow = dataPriv.get( elem, "fxshow" );
| |
− |
| |
− | // Queue-skipping animations hijack the fx hooks
| |
− | if ( !opts.queue ) {
| |
− | hooks = jQuery._queueHooks( elem, "fx" );
| |
− | if ( hooks.unqueued == null ) {
| |
− | hooks.unqueued = 0;
| |
− | oldfire = hooks.empty.fire;
| |
− | hooks.empty.fire = function() {
| |
− | if ( !hooks.unqueued ) {
| |
− | oldfire();
| |
− | }
| |
− | };
| |
− | }
| |
− | hooks.unqueued++;
| |
− |
| |
− | anim.always( function() {
| |
− |
| |
− | // Ensure the complete handler is called before this completes
| |
− | anim.always( function() {
| |
− | hooks.unqueued--;
| |
− | if ( !jQuery.queue( elem, "fx" ).length ) {
| |
− | hooks.empty.fire();
| |
− | }
| |
− | } );
| |
− | } );
| |
− | }
| |
− |
| |
− | // Detect show/hide animations
| |
− | for ( prop in props ) {
| |
− | value = props[ prop ];
| |
− | if ( rfxtypes.test( value ) ) {
| |
− | delete props[ prop ];
| |
− | toggle = toggle || value === "toggle";
| |
− | if ( value === ( hidden ? "hide" : "show" ) ) {
| |
− |
| |
− | // Pretend to be hidden if this is a "show" and
| |
− | // there is still data from a stopped show/hide
| |
− | if ( value === "show" && dataShow && dataShow[ prop ] !== undefined ) {
| |
− | hidden = true;
| |
− |
| |
− | // Ignore all other no-op show/hide data
| |
− | } else {
| |
− | continue;
| |
− | }
| |
− | }
| |
− | orig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop );
| |
− | }
| |
− | }
| |
− |
| |
− | // Bail out if this is a no-op like .hide().hide()
| |
− | propTween = !jQuery.isEmptyObject( props );
| |
− | if ( !propTween && jQuery.isEmptyObject( orig ) ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // Restrict "overflow" and "display" styles during box animations
| |
− | if ( isBox && elem.nodeType === 1 ) {
| |
− |
| |
− | // Support: IE <=9 - 11, Edge 12 - 15
| |
− | // Record all 3 overflow attributes because IE does not infer the shorthand
| |
− | // from identically-valued overflowX and overflowY and Edge just mirrors
| |
− | // the overflowX value there.
| |
− | opts.overflow = [ style.overflow, style.overflowX, style.overflowY ];
| |
− |
| |
− | // Identify a display type, preferring old show/hide data over the CSS cascade
| |
− | restoreDisplay = dataShow && dataShow.display;
| |
− | if ( restoreDisplay == null ) {
| |
− | restoreDisplay = dataPriv.get( elem, "display" );
| |
− | }
| |
− | display = jQuery.css( elem, "display" );
| |
− | if ( display === "none" ) {
| |
− | if ( restoreDisplay ) {
| |
− | display = restoreDisplay;
| |
− | } else {
| |
− |
| |
− | // Get nonempty value(s) by temporarily forcing visibility
| |
− | showHide( [ elem ], true );
| |
− | restoreDisplay = elem.style.display || restoreDisplay;
| |
− | display = jQuery.css( elem, "display" );
| |
− | showHide( [ elem ] );
| |
− | }
| |
− | }
| |
− |
| |
− | // Animate inline elements as inline-block
| |
− | if ( display === "inline" || display === "inline-block" && restoreDisplay != null ) {
| |
− | if ( jQuery.css( elem, "float" ) === "none" ) {
| |
− |
| |
− | // Restore the original display value at the end of pure show/hide animations
| |
− | if ( !propTween ) {
| |
− | anim.done( function() {
| |
− | style.display = restoreDisplay;
| |
− | } );
| |
− | if ( restoreDisplay == null ) {
| |
− | display = style.display;
| |
− | restoreDisplay = display === "none" ? "" : display;
| |
− | }
| |
− | }
| |
− | style.display = "inline-block";
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | if ( opts.overflow ) {
| |
− | style.overflow = "hidden";
| |
− | anim.always( function() {
| |
− | style.overflow = opts.overflow[ 0 ];
| |
− | style.overflowX = opts.overflow[ 1 ];
| |
− | style.overflowY = opts.overflow[ 2 ];
| |
− | } );
| |
− | }
| |
− |
| |
− | // Implement show/hide animations
| |
− | propTween = false;
| |
− | for ( prop in orig ) {
| |
− |
| |
− | // General show/hide setup for this element animation
| |
− | if ( !propTween ) {
| |
− | if ( dataShow ) {
| |
− | if ( "hidden" in dataShow ) {
| |
− | hidden = dataShow.hidden;
| |
− | }
| |
− | } else {
| |
− | dataShow = dataPriv.access( elem, "fxshow", { display: restoreDisplay } );
| |
− | }
| |
− |
| |
− | // Store hidden/visible for toggle so `.stop().toggle()` "reverses"
| |
− | if ( toggle ) {
| |
− | dataShow.hidden = !hidden;
| |
− | }
| |
− |
| |
− | // Show elements before animating them
| |
− | if ( hidden ) {
| |
− | showHide( [ elem ], true );
| |
− | }
| |
− |
| |
− | /* eslint-disable no-loop-func */
| |
− |
| |
− | anim.done( function() {
| |
− |
| |
− | /* eslint-enable no-loop-func */
| |
− |
| |
− | // The final step of a "hide" animation is actually hiding the element
| |
− | if ( !hidden ) {
| |
− | showHide( [ elem ] );
| |
− | }
| |
− | dataPriv.remove( elem, "fxshow" );
| |
− | for ( prop in orig ) {
| |
− | jQuery.style( elem, prop, orig[ prop ] );
| |
− | }
| |
− | } );
| |
− | }
| |
− |
| |
− | // Per-property setup
| |
− | propTween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim );
| |
− | if ( !( prop in dataShow ) ) {
| |
− | dataShow[ prop ] = propTween.start;
| |
− | if ( hidden ) {
| |
− | propTween.end = propTween.start;
| |
− | propTween.start = 0;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | function propFilter( props, specialEasing ) {
| |
− | var index, name, easing, value, hooks;
| |
− |
| |
− | // camelCase, specialEasing and expand cssHook pass
| |
− | for ( index in props ) {
| |
− | name = camelCase( index );
| |
− | easing = specialEasing[ name ];
| |
− | value = props[ index ];
| |
− | if ( Array.isArray( value ) ) {
| |
− | easing = value[ 1 ];
| |
− | value = props[ index ] = value[ 0 ];
| |
− | }
| |
− |
| |
− | if ( index !== name ) {
| |
− | props[ name ] = value;
| |
− | delete props[ index ];
| |
− | }
| |
− |
| |
− | hooks = jQuery.cssHooks[ name ];
| |
− | if ( hooks && "expand" in hooks ) {
| |
− | value = hooks.expand( value );
| |
− | delete props[ name ];
| |
− |
| |
− | // Not quite $.extend, this won't overwrite existing keys.
| |
− | // Reusing 'index' because we have the correct "name"
| |
− | for ( index in value ) {
| |
− | if ( !( index in props ) ) {
| |
− | props[ index ] = value[ index ];
| |
− | specialEasing[ index ] = easing;
| |
− | }
| |
− | }
| |
− | } else {
| |
− | specialEasing[ name ] = easing;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | function Animation( elem, properties, options ) {
| |
− | var result,
| |
− | stopped,
| |
− | index = 0,
| |
− | length = Animation.prefilters.length,
| |
− | deferred = jQuery.Deferred().always( function() {
| |
− |
| |
− | // Don't match elem in the :animated selector
| |
− | delete tick.elem;
| |
− | } ),
| |
− | tick = function() {
| |
− | if ( stopped ) {
| |
− | return false;
| |
− | }
| |
− | var currentTime = fxNow || createFxNow(),
| |
− | remaining = Math.max( 0, animation.startTime + animation.duration - currentTime ),
| |
− |
| |
− | // Support: Android 2.3 only
| |
− | // Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497)
| |
− | temp = remaining / animation.duration || 0,
| |
− | percent = 1 - temp,
| |
− | index = 0,
| |
− | length = animation.tweens.length;
| |
− |
| |
− | for ( ; index < length; index++ ) {
| |
− | animation.tweens[ index ].run( percent );
| |
− | }
| |
− |
| |
− | deferred.notifyWith( elem, [ animation, percent, remaining ] );
| |
− |
| |
− | // If there's more to do, yield
| |
− | if ( percent < 1 && length ) {
| |
− | return remaining;
| |
− | }
| |
− |
| |
− | // If this was an empty animation, synthesize a final progress notification
| |
− | if ( !length ) {
| |
− | deferred.notifyWith( elem, [ animation, 1, 0 ] );
| |
− | }
| |
− |
| |
− | // Resolve the animation and report its conclusion
| |
− | deferred.resolveWith( elem, [ animation ] );
| |
− | return false;
| |
− | },
| |
− | animation = deferred.promise( {
| |
− | elem: elem,
| |
− | props: jQuery.extend( {}, properties ),
| |
− | opts: jQuery.extend( true, {
| |
− | specialEasing: {},
| |
− | easing: jQuery.easing._default
| |
− | }, options ),
| |
− | originalProperties: properties,
| |
− | originalOptions: options,
| |
− | startTime: fxNow || createFxNow(),
| |
− | duration: options.duration,
| |
− | tweens: [],
| |
− | createTween: function( prop, end ) {
| |
− | var tween = jQuery.Tween( elem, animation.opts, prop, end,
| |
− | animation.opts.specialEasing[ prop ] || animation.opts.easing );
| |
− | animation.tweens.push( tween );
| |
− | return tween;
| |
− | },
| |
− | stop: function( gotoEnd ) {
| |
− | var index = 0,
| |
− |
| |
− | // If we are going to the end, we want to run all the tweens
| |
− | // otherwise we skip this part
| |
− | length = gotoEnd ? animation.tweens.length : 0;
| |
− | if ( stopped ) {
| |
− | return this;
| |
− | }
| |
− | stopped = true;
| |
− | for ( ; index < length; index++ ) {
| |
− | animation.tweens[ index ].run( 1 );
| |
− | }
| |
− |
| |
− | // Resolve when we played the last frame; otherwise, reject
| |
− | if ( gotoEnd ) {
| |
− | deferred.notifyWith( elem, [ animation, 1, 0 ] );
| |
− | deferred.resolveWith( elem, [ animation, gotoEnd ] );
| |
− | } else {
| |
− | deferred.rejectWith( elem, [ animation, gotoEnd ] );
| |
− | }
| |
− | return this;
| |
− | }
| |
− | } ),
| |
− | props = animation.props;
| |
− |
| |
− | propFilter( props, animation.opts.specialEasing );
| |
− |
| |
− | for ( ; index < length; index++ ) {
| |
− | result = Animation.prefilters[ index ].call( animation, elem, props, animation.opts );
| |
− | if ( result ) {
| |
− | if ( isFunction( result.stop ) ) {
| |
− | jQuery._queueHooks( animation.elem, animation.opts.queue ).stop =
| |
− | result.stop.bind( result );
| |
− | }
| |
− | return result;
| |
− | }
| |
− | }
| |
− |
| |
− | jQuery.map( props, createTween, animation );
| |
− |
| |
− | if ( isFunction( animation.opts.start ) ) {
| |
− | animation.opts.start.call( elem, animation );
| |
− | }
| |
− |
| |
− | // Attach callbacks from options
| |
− | animation
| |
− | .progress( animation.opts.progress )
| |
− | .done( animation.opts.done, animation.opts.complete )
| |
− | .fail( animation.opts.fail )
| |
− | .always( animation.opts.always );
| |
− |
| |
− | jQuery.fx.timer(
| |
− | jQuery.extend( tick, {
| |
− | elem: elem,
| |
− | anim: animation,
| |
− | queue: animation.opts.queue
| |
− | } )
| |
− | );
| |
− |
| |
− | return animation;
| |
− | }
| |
− |
| |
− | jQuery.Animation = jQuery.extend( Animation, {
| |
− |
| |
− | tweeners: {
| |
− | "*": [ function( prop, value ) {
| |
− | var tween = this.createTween( prop, value );
| |
− | adjustCSS( tween.elem, prop, rcssNum.exec( value ), tween );
| |
− | return tween;
| |
− | } ]
| |
− | },
| |
− |
| |
− | tweener: function( props, callback ) {
| |
− | if ( isFunction( props ) ) {
| |
− | callback = props;
| |
− | props = [ "*" ];
| |
− | } else {
| |
− | props = props.match( rnothtmlwhite );
| |
− | }
| |
− |
| |
− | var prop,
| |
− | index = 0,
| |
− | length = props.length;
| |
− |
| |
− | for ( ; index < length; index++ ) {
| |
− | prop = props[ index ];
| |
− | Animation.tweeners[ prop ] = Animation.tweeners[ prop ] || [];
| |
− | Animation.tweeners[ prop ].unshift( callback );
| |
− | }
| |
− | },
| |
− |
| |
− | prefilters: [ defaultPrefilter ],
| |
− |
| |
− | prefilter: function( callback, prepend ) {
| |
− | if ( prepend ) {
| |
− | Animation.prefilters.unshift( callback );
| |
− | } else {
| |
− | Animation.prefilters.push( callback );
| |
− | }
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.speed = function( speed, easing, fn ) {
| |
− | var opt = speed && typeof speed === "object" ? jQuery.extend( {}, speed ) : {
| |
− | complete: fn || !fn && easing ||
| |
− | isFunction( speed ) && speed,
| |
− | duration: speed,
| |
− | easing: fn && easing || easing && !isFunction( easing ) && easing
| |
− | };
| |
− |
| |
− | // Go to the end state if fx are off
| |
− | if ( jQuery.fx.off ) {
| |
− | opt.duration = 0;
| |
− |
| |
− | } else {
| |
− | if ( typeof opt.duration !== "number" ) {
| |
− | if ( opt.duration in jQuery.fx.speeds ) {
| |
− | opt.duration = jQuery.fx.speeds[ opt.duration ];
| |
− |
| |
− | } else {
| |
− | opt.duration = jQuery.fx.speeds._default;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Normalize opt.queue - true/undefined/null -> "fx"
| |
− | if ( opt.queue == null || opt.queue === true ) {
| |
− | opt.queue = "fx";
| |
− | }
| |
− |
| |
− | // Queueing
| |
− | opt.old = opt.complete;
| |
− |
| |
− | opt.complete = function() {
| |
− | if ( isFunction( opt.old ) ) {
| |
− | opt.old.call( this );
| |
− | }
| |
− |
| |
− | if ( opt.queue ) {
| |
− | jQuery.dequeue( this, opt.queue );
| |
− | }
| |
− | };
| |
− |
| |
− | return opt;
| |
− | };
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | fadeTo: function( speed, to, easing, callback ) {
| |
− |
| |
− | // Show any hidden elements after setting opacity to 0
| |
− | return this.filter( isHiddenWithinTree ).css( "opacity", 0 ).show()
| |
− |
| |
− | // Animate to the value specified
| |
− | .end().animate( { opacity: to }, speed, easing, callback );
| |
− | },
| |
− | animate: function( prop, speed, easing, callback ) {
| |
− | var empty = jQuery.isEmptyObject( prop ),
| |
− | optall = jQuery.speed( speed, easing, callback ),
| |
− | doAnimation = function() {
| |
− |
| |
− | // Operate on a copy of prop so per-property easing won't be lost
| |
− | var anim = Animation( this, jQuery.extend( {}, prop ), optall );
| |
− |
| |
− | // Empty animations, or finishing resolves immediately
| |
− | if ( empty || dataPriv.get( this, "finish" ) ) {
| |
− | anim.stop( true );
| |
− | }
| |
− | };
| |
− | doAnimation.finish = doAnimation;
| |
− |
| |
− | return empty || optall.queue === false ?
| |
− | this.each( doAnimation ) :
| |
− | this.queue( optall.queue, doAnimation );
| |
− | },
| |
− | stop: function( type, clearQueue, gotoEnd ) {
| |
− | var stopQueue = function( hooks ) {
| |
− | var stop = hooks.stop;
| |
− | delete hooks.stop;
| |
− | stop( gotoEnd );
| |
− | };
| |
− |
| |
− | if ( typeof type !== "string" ) {
| |
− | gotoEnd = clearQueue;
| |
− | clearQueue = type;
| |
− | type = undefined;
| |
− | }
| |
− | if ( clearQueue && type !== false ) {
| |
− | this.queue( type || "fx", [] );
| |
− | }
| |
− |
| |
− | return this.each( function() {
| |
− | var dequeue = true,
| |
− | index = type != null && type + "queueHooks",
| |
− | timers = jQuery.timers,
| |
− | data = dataPriv.get( this );
| |
− |
| |
− | if ( index ) {
| |
− | if ( data[ index ] && data[ index ].stop ) {
| |
− | stopQueue( data[ index ] );
| |
− | }
| |
− | } else {
| |
− | for ( index in data ) {
| |
− | if ( data[ index ] && data[ index ].stop && rrun.test( index ) ) {
| |
− | stopQueue( data[ index ] );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | for ( index = timers.length; index--; ) {
| |
− | if ( timers[ index ].elem === this &&
| |
− | ( type == null || timers[ index ].queue === type ) ) {
| |
− |
| |
− | timers[ index ].anim.stop( gotoEnd );
| |
− | dequeue = false;
| |
− | timers.splice( index, 1 );
| |
− | }
| |
− | }
| |
− |
| |
− | // Start the next in the queue if the last step wasn't forced.
| |
− | // Timers currently will call their complete callbacks, which
| |
− | // will dequeue but only if they were gotoEnd.
| |
− | if ( dequeue || !gotoEnd ) {
| |
− | jQuery.dequeue( this, type );
| |
− | }
| |
− | } );
| |
− | },
| |
− | finish: function( type ) {
| |
− | if ( type !== false ) {
| |
− | type = type || "fx";
| |
− | }
| |
− | return this.each( function() {
| |
− | var index,
| |
− | data = dataPriv.get( this ),
| |
− | queue = data[ type + "queue" ],
| |
− | hooks = data[ type + "queueHooks" ],
| |
− | timers = jQuery.timers,
| |
− | length = queue ? queue.length : 0;
| |
− |
| |
− | // Enable finishing flag on private data
| |
− | data.finish = true;
| |
− |
| |
− | // Empty the queue first
| |
− | jQuery.queue( this, type, [] );
| |
− |
| |
− | if ( hooks && hooks.stop ) {
| |
− | hooks.stop.call( this, true );
| |
− | }
| |
− |
| |
− | // Look for any active animations, and finish them
| |
− | for ( index = timers.length; index--; ) {
| |
− | if ( timers[ index ].elem === this && timers[ index ].queue === type ) {
| |
− | timers[ index ].anim.stop( true );
| |
− | timers.splice( index, 1 );
| |
− | }
| |
− | }
| |
− |
| |
− | // Look for any animations in the old queue and finish them
| |
− | for ( index = 0; index < length; index++ ) {
| |
− | if ( queue[ index ] && queue[ index ].finish ) {
| |
− | queue[ index ].finish.call( this );
| |
− | }
| |
− | }
| |
− |
| |
− | // Turn off finishing flag
| |
− | delete data.finish;
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.each( [ "toggle", "show", "hide" ], function( i, name ) {
| |
− | var cssFn = jQuery.fn[ name ];
| |
− | jQuery.fn[ name ] = function( speed, easing, callback ) {
| |
− | return speed == null || typeof speed === "boolean" ?
| |
− | cssFn.apply( this, arguments ) :
| |
− | this.animate( genFx( name, true ), speed, easing, callback );
| |
− | };
| |
− | } );
| |
− |
| |
− | // Generate shortcuts for custom animations
| |
− | jQuery.each( {
| |
− | slideDown: genFx( "show" ),
| |
− | slideUp: genFx( "hide" ),
| |
− | slideToggle: genFx( "toggle" ),
| |
− | fadeIn: { opacity: "show" },
| |
− | fadeOut: { opacity: "hide" },
| |
− | fadeToggle: { opacity: "toggle" }
| |
− | }, function( name, props ) {
| |
− | jQuery.fn[ name ] = function( speed, easing, callback ) {
| |
− | return this.animate( props, speed, easing, callback );
| |
− | };
| |
− | } );
| |
− |
| |
− | jQuery.timers = [];
| |
− | jQuery.fx.tick = function() {
| |
− | var timer,
| |
− | i = 0,
| |
− | timers = jQuery.timers;
| |
− |
| |
− | fxNow = Date.now();
| |
− |
| |
− | for ( ; i < timers.length; i++ ) {
| |
− | timer = timers[ i ];
| |
− |
| |
− | // Run the timer and safely remove it when done (allowing for external removal)
| |
− | if ( !timer() && timers[ i ] === timer ) {
| |
− | timers.splice( i--, 1 );
| |
− | }
| |
− | }
| |
− |
| |
− | if ( !timers.length ) {
| |
− | jQuery.fx.stop();
| |
− | }
| |
− | fxNow = undefined;
| |
− | };
| |
− |
| |
− | jQuery.fx.timer = function( timer ) {
| |
− | jQuery.timers.push( timer );
| |
− | jQuery.fx.start();
| |
− | };
| |
− |
| |
− | jQuery.fx.interval = 13;
| |
− | jQuery.fx.start = function() {
| |
− | if ( inProgress ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | inProgress = true;
| |
− | schedule();
| |
− | };
| |
− |
| |
− | jQuery.fx.stop = function() {
| |
− | inProgress = null;
| |
− | };
| |
− |
| |
− | jQuery.fx.speeds = {
| |
− | slow: 600,
| |
− | fast: 200,
| |
− |
| |
− | // Default speed
| |
− | _default: 400
| |
− | };
| |
− |
| |
− |
| |
− | // Based off of the plugin by Clint Helfers, with permission.
| |
− | // https://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/
| |
− | jQuery.fn.delay = function( time, type ) {
| |
− | time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time;
| |
− | type = type || "fx";
| |
− |
| |
− | return this.queue( type, function( next, hooks ) {
| |
− | var timeout = window.setTimeout( next, time );
| |
− | hooks.stop = function() {
| |
− | window.clearTimeout( timeout );
| |
− | };
| |
− | } );
| |
− | };
| |
− |
| |
− |
| |
− | ( function() {
| |
− | var input = document.createElement( "input" ),
| |
− | select = document.createElement( "select" ),
| |
− | opt = select.appendChild( document.createElement( "option" ) );
| |
− |
| |
− | input.type = "checkbox";
| |
− |
| |
− | // Support: Android <=4.3 only
| |
− | // Default value for a checkbox should be "on"
| |
− | support.checkOn = input.value !== "";
| |
− |
| |
− | // Support: IE <=11 only
| |
− | // Must access selectedIndex to make default options select
| |
− | support.optSelected = opt.selected;
| |
− |
| |
− | // Support: IE <=11 only
| |
− | // An input loses its value after becoming a radio
| |
− | input = document.createElement( "input" );
| |
− | input.value = "t";
| |
− | input.type = "radio";
| |
− | support.radioValue = input.value === "t";
| |
− | } )();
| |
− |
| |
− |
| |
− | var boolHook,
| |
− | attrHandle = jQuery.expr.attrHandle;
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | attr: function( name, value ) {
| |
− | return access( this, jQuery.attr, name, value, arguments.length > 1 );
| |
− | },
| |
− |
| |
− | removeAttr: function( name ) {
| |
− | return this.each( function() {
| |
− | jQuery.removeAttr( this, name );
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.extend( {
| |
− | attr: function( elem, name, value ) {
| |
− | var ret, hooks,
| |
− | nType = elem.nodeType;
| |
− |
| |
− | // Don't get/set attributes on text, comment and attribute nodes
| |
− | if ( nType === 3 || nType === 8 || nType === 2 ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // Fallback to prop when attributes are not supported
| |
− | if ( typeof elem.getAttribute === "undefined" ) {
| |
− | return jQuery.prop( elem, name, value );
| |
− | }
| |
− |
| |
− | // Attribute hooks are determined by the lowercase version
| |
− | // Grab necessary hook if one is defined
| |
− | if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {
| |
− | hooks = jQuery.attrHooks[ name.toLowerCase() ] ||
| |
− | ( jQuery.expr.match.bool.test( name ) ? boolHook : undefined );
| |
− | }
| |
− |
| |
− | if ( value !== undefined ) {
| |
− | if ( value === null ) {
| |
− | jQuery.removeAttr( elem, name );
| |
− | return;
| |
− | }
| |
− |
| |
− | if ( hooks && "set" in hooks &&
| |
− | ( ret = hooks.set( elem, value, name ) ) !== undefined ) {
| |
− | return ret;
| |
− | }
| |
− |
| |
− | elem.setAttribute( name, value + "" );
| |
− | return value;
| |
− | }
| |
− |
| |
− | if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {
| |
− | return ret;
| |
− | }
| |
− |
| |
− | ret = jQuery.find.attr( elem, name );
| |
− |
| |
− | // Non-existent attributes return null, we normalize to undefined
| |
− | return ret == null ? undefined : ret;
| |
− | },
| |
− |
| |
− | attrHooks: {
| |
− | type: {
| |
− | set: function( elem, value ) {
| |
− | if ( !support.radioValue && value === "radio" &&
| |
− | nodeName( elem, "input" ) ) {
| |
− | var val = elem.value;
| |
− | elem.setAttribute( "type", value );
| |
− | if ( val ) {
| |
− | elem.value = val;
| |
− | }
| |
− | return value;
| |
− | }
| |
− | }
| |
− | }
| |
− | },
| |
− |
| |
− | removeAttr: function( elem, value ) {
| |
− | var name,
| |
− | i = 0,
| |
− |
| |
− | // Attribute names can contain non-HTML whitespace characters
| |
− | // https://html.spec.whatwg.org/multipage/syntax.html#attributes-2
| |
− | attrNames = value && value.match( rnothtmlwhite );
| |
− |
| |
− | if ( attrNames && elem.nodeType === 1 ) {
| |
− | while ( ( name = attrNames[ i++ ] ) ) {
| |
− | elem.removeAttribute( name );
| |
− | }
| |
− | }
| |
− | }
| |
− | } );
| |
− |
| |
− | // 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 {
| |
− | elem.setAttribute( name, name );
| |
− | }
| |
− | return name;
| |
− | }
| |
− | };
| |
− |
| |
− | jQuery.each( jQuery.expr.match.bool.source.match( /\w+/g ), function( i, name ) {
| |
− | var getter = attrHandle[ name ] || jQuery.find.attr;
| |
− |
| |
− | attrHandle[ name ] = function( elem, name, isXML ) {
| |
− | var ret, handle,
| |
− | lowercaseName = name.toLowerCase();
| |
− |
| |
− | if ( !isXML ) {
| |
− |
| |
− | // Avoid an infinite loop by temporarily removing this function from the getter
| |
− | handle = attrHandle[ lowercaseName ];
| |
− | attrHandle[ lowercaseName ] = ret;
| |
− | ret = getter( elem, name, isXML ) != null ?
| |
− | lowercaseName :
| |
− | null;
| |
− | attrHandle[ lowercaseName ] = handle;
| |
− | }
| |
− | return ret;
| |
− | };
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | var rfocusable = /^(?:input|select|textarea|button)$/i,
| |
− | rclickable = /^(?:a|area)$/i;
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | prop: function( name, value ) {
| |
− | return access( this, jQuery.prop, name, value, arguments.length > 1 );
| |
− | },
| |
− |
| |
− | removeProp: function( name ) {
| |
− | return this.each( function() {
| |
− | delete this[ jQuery.propFix[ name ] || name ];
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.extend( {
| |
− | prop: function( elem, name, value ) {
| |
− | var ret, hooks,
| |
− | nType = elem.nodeType;
| |
− |
| |
− | // Don't get/set properties on text, comment and attribute nodes
| |
− | if ( nType === 3 || nType === 8 || nType === 2 ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {
| |
− |
| |
− | // Fix name and attach hooks
| |
− | name = jQuery.propFix[ name ] || name;
| |
− | hooks = jQuery.propHooks[ name ];
| |
− | }
| |
− |
| |
− | if ( value !== undefined ) {
| |
− | if ( hooks && "set" in hooks &&
| |
− | ( ret = hooks.set( elem, value, name ) ) !== undefined ) {
| |
− | return ret;
| |
− | }
| |
− |
| |
− | return ( elem[ name ] = value );
| |
− | }
| |
− |
| |
− | if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {
| |
− | return ret;
| |
− | }
| |
− |
| |
− | return elem[ name ];
| |
− | },
| |
− |
| |
− | propHooks: {
| |
− | tabIndex: {
| |
− | get: function( elem ) {
| |
− |
| |
− | // Support: IE <=9 - 11 only
| |
− | // elem.tabIndex doesn't always return the
| |
− | // correct value when it hasn't been explicitly set
| |
− | // https://web.archive.org/web/20141116233347/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" );
| |
− |
| |
− | if ( tabindex ) {
| |
− | return parseInt( tabindex, 10 );
| |
− | }
| |
− |
| |
− | if (
| |
− | rfocusable.test( elem.nodeName ) ||
| |
− | rclickable.test( elem.nodeName ) &&
| |
− | elem.href
| |
− | ) {
| |
− | return 0;
| |
− | }
| |
− |
| |
− | return -1;
| |
− | }
| |
− | }
| |
− | },
| |
− |
| |
− | propFix: {
| |
− | "for": "htmlFor",
| |
− | "class": "className"
| |
− | }
| |
− | } );
| |
− |
| |
− | // Support: IE <=11 only
| |
− | // Accessing the selectedIndex property
| |
− | // forces the browser to respect setting selected
| |
− | // on the option
| |
− | // The getter ensures a default option is selected
| |
− | // when in an optgroup
| |
− | // eslint rule "no-unused-expressions" is disabled for this code
| |
− | // since it considers such accessions noop
| |
− | if ( !support.optSelected ) {
| |
− | jQuery.propHooks.selected = {
| |
− | get: function( elem ) {
| |
− |
| |
− | /* eslint no-unused-expressions: "off" */
| |
− |
| |
− | var parent = elem.parentNode;
| |
− | if ( parent && parent.parentNode ) {
| |
− | parent.parentNode.selectedIndex;
| |
− | }
| |
− | return null;
| |
− | },
| |
− | set: function( elem ) {
| |
− |
| |
− | /* eslint no-unused-expressions: "off" */
| |
− |
| |
− | var parent = elem.parentNode;
| |
− | if ( parent ) {
| |
− | parent.selectedIndex;
| |
− |
| |
− | if ( parent.parentNode ) {
| |
− | parent.parentNode.selectedIndex;
| |
− | }
| |
− | }
| |
− | }
| |
− | };
| |
− | }
| |
− |
| |
− | jQuery.each( [
| |
− | "tabIndex",
| |
− | "readOnly",
| |
− | "maxLength",
| |
− | "cellSpacing",
| |
− | "cellPadding",
| |
− | "rowSpan",
| |
− | "colSpan",
| |
− | "useMap",
| |
− | "frameBorder",
| |
− | "contentEditable"
| |
− | ], function() {
| |
− | jQuery.propFix[ this.toLowerCase() ] = this;
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // Strip and collapse whitespace according to HTML spec
| |
− | // https://infra.spec.whatwg.org/#strip-and-collapse-ascii-whitespace
| |
− | function stripAndCollapse( value ) {
| |
− | var tokens = value.match( rnothtmlwhite ) || [];
| |
− | return tokens.join( " " );
| |
− | }
| |
− |
| |
− |
| |
− | function getClass( elem ) {
| |
− | return elem.getAttribute && elem.getAttribute( "class" ) || "";
| |
− | }
| |
− |
| |
− | function classesToArray( value ) {
| |
− | if ( Array.isArray( value ) ) {
| |
− | return value;
| |
− | }
| |
− | if ( typeof value === "string" ) {
| |
− | return value.match( rnothtmlwhite ) || [];
| |
− | }
| |
− | return [];
| |
− | }
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | addClass: function( value ) {
| |
− | var classes, elem, cur, curValue, clazz, j, finalValue,
| |
− | i = 0;
| |
− |
| |
− | if ( isFunction( value ) ) {
| |
− | return this.each( function( j ) {
| |
− | jQuery( this ).addClass( value.call( this, j, getClass( this ) ) );
| |
− | } );
| |
− | }
| |
− |
| |
− | classes = classesToArray( value );
| |
− |
| |
− | if ( classes.length ) {
| |
− | while ( ( elem = this[ i++ ] ) ) {
| |
− | curValue = getClass( elem );
| |
− | cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " );
| |
− |
| |
− | if ( cur ) {
| |
− | j = 0;
| |
− | while ( ( clazz = classes[ j++ ] ) ) {
| |
− | if ( cur.indexOf( " " + clazz + " " ) < 0 ) {
| |
− | cur += clazz + " ";
| |
− | }
| |
− | }
| |
− |
| |
− | // Only assign if different to avoid unneeded rendering.
| |
− | finalValue = stripAndCollapse( cur );
| |
− | if ( curValue !== finalValue ) {
| |
− | elem.setAttribute( "class", finalValue );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return this;
| |
− | },
| |
− |
| |
− | removeClass: function( value ) {
| |
− | var classes, elem, cur, curValue, clazz, j, finalValue,
| |
− | i = 0;
| |
− |
| |
− | if ( isFunction( value ) ) {
| |
− | return this.each( function( j ) {
| |
− | jQuery( this ).removeClass( value.call( this, j, getClass( this ) ) );
| |
− | } );
| |
− | }
| |
− |
| |
− | if ( !arguments.length ) {
| |
− | return this.attr( "class", "" );
| |
− | }
| |
− |
| |
− | classes = classesToArray( value );
| |
− |
| |
− | if ( classes.length ) {
| |
− | while ( ( elem = this[ i++ ] ) ) {
| |
− | curValue = getClass( elem );
| |
− |
| |
− | // This expression is here for better compressibility (see addClass)
| |
− | cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " );
| |
− |
| |
− | if ( cur ) {
| |
− | j = 0;
| |
− | while ( ( clazz = classes[ j++ ] ) ) {
| |
− |
| |
− | // Remove *all* instances
| |
− | while ( cur.indexOf( " " + clazz + " " ) > -1 ) {
| |
− | cur = cur.replace( " " + clazz + " ", " " );
| |
− | }
| |
− | }
| |
− |
| |
− | // Only assign if different to avoid unneeded rendering.
| |
− | finalValue = stripAndCollapse( cur );
| |
− | if ( curValue !== finalValue ) {
| |
− | elem.setAttribute( "class", finalValue );
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return this;
| |
− | },
| |
− |
| |
− | toggleClass: function( value, stateVal ) {
| |
− | var type = typeof value,
| |
− | isValidValue = type === "string" || Array.isArray( value );
| |
− |
| |
− | if ( typeof stateVal === "boolean" && isValidValue ) {
| |
− | return stateVal ? this.addClass( value ) : this.removeClass( value );
| |
− | }
| |
− |
| |
− | if ( isFunction( value ) ) {
| |
− | return this.each( function( i ) {
| |
− | jQuery( this ).toggleClass(
| |
− | value.call( this, i, getClass( this ), stateVal ),
| |
− | stateVal
| |
− | );
| |
− | } );
| |
− | }
| |
− |
| |
− | return this.each( function() {
| |
− | var className, i, self, classNames;
| |
− |
| |
− | if ( isValidValue ) {
| |
− |
| |
− | // Toggle individual class names
| |
− | i = 0;
| |
− | self = jQuery( this );
| |
− | classNames = classesToArray( value );
| |
− |
| |
− | while ( ( className = classNames[ i++ ] ) ) {
| |
− |
| |
− | // Check each className given, space separated list
| |
− | if ( self.hasClass( className ) ) {
| |
− | self.removeClass( className );
| |
− | } else {
| |
− | self.addClass( className );
| |
− | }
| |
− | }
| |
− |
| |
− | // Toggle whole class name
| |
− | } else if ( value === undefined || type === "boolean" ) {
| |
− | className = getClass( this );
| |
− | if ( className ) {
| |
− |
| |
− | // Store className if set
| |
− | dataPriv.set( this, "__className__", className );
| |
− | }
| |
− |
| |
− | // 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.
| |
− | if ( this.setAttribute ) {
| |
− | this.setAttribute( "class",
| |
− | className || value === false ?
| |
− | "" :
| |
− | dataPriv.get( this, "__className__" ) || ""
| |
− | );
| |
− | }
| |
− | }
| |
− | } );
| |
− | },
| |
− |
| |
− | hasClass: function( selector ) {
| |
− | var className, elem,
| |
− | i = 0;
| |
− |
| |
− | className = " " + selector + " ";
| |
− | while ( ( elem = this[ i++ ] ) ) {
| |
− | if ( elem.nodeType === 1 &&
| |
− | ( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) {
| |
− | return true;
| |
− | }
| |
− | }
| |
− |
| |
− | return false;
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | var rreturn = /\r/g;
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | val: function( value ) {
| |
− | var hooks, ret, valueIsFunction,
| |
− | elem = this[ 0 ];
| |
− |
| |
− | if ( !arguments.length ) {
| |
− | if ( elem ) {
| |
− | hooks = jQuery.valHooks[ elem.type ] ||
| |
− | jQuery.valHooks[ elem.nodeName.toLowerCase() ];
| |
− |
| |
− | if ( hooks &&
| |
− | "get" in hooks &&
| |
− | ( ret = hooks.get( elem, "value" ) ) !== undefined
| |
− | ) {
| |
− | return ret;
| |
− | }
| |
− |
| |
− | ret = elem.value;
| |
− |
| |
− | // Handle most common string cases
| |
− | if ( typeof ret === "string" ) {
| |
− | return ret.replace( rreturn, "" );
| |
− | }
| |
− |
| |
− | // Handle cases where value is null/undef or number
| |
− | return ret == null ? "" : ret;
| |
− | }
| |
− |
| |
− | return;
| |
− | }
| |
− |
| |
− | valueIsFunction = isFunction( value );
| |
− |
| |
− | return this.each( function( i ) {
| |
− | var val;
| |
− |
| |
− | if ( this.nodeType !== 1 ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | if ( valueIsFunction ) {
| |
− | val = value.call( this, i, jQuery( this ).val() );
| |
− | } else {
| |
− | val = value;
| |
− | }
| |
− |
| |
− | // Treat null/undefined as ""; convert numbers to string
| |
− | if ( val == null ) {
| |
− | val = "";
| |
− |
| |
− | } else if ( typeof val === "number" ) {
| |
− | val += "";
| |
− |
| |
− | } else if ( Array.isArray( val ) ) {
| |
− | val = jQuery.map( val, function( value ) {
| |
− | return value == null ? "" : value + "";
| |
− | } );
| |
− | }
| |
− |
| |
− | 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;
| |
− | }
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− | jQuery.extend( {
| |
− | valHooks: {
| |
− | option: {
| |
− | get: function( elem ) {
| |
− |
| |
− | var val = jQuery.find.attr( elem, "value" );
| |
− | return val != null ?
| |
− | val :
| |
− |
| |
− | // Support: IE <=10 - 11 only
| |
− | // option.text throws exceptions (#14686, #14858)
| |
− | // Strip and collapse whitespace
| |
− | // https://html.spec.whatwg.org/#strip-and-collapse-whitespace
| |
− | stripAndCollapse( jQuery.text( elem ) );
| |
− | }
| |
− | },
| |
− | select: {
| |
− | get: function( elem ) {
| |
− | var value, option, i,
| |
− | options = elem.options,
| |
− | index = elem.selectedIndex,
| |
− | one = elem.type === "select-one",
| |
− | values = one ? null : [],
| |
− | max = one ? index + 1 : options.length;
| |
− |
| |
− | if ( index < 0 ) {
| |
− | i = max;
| |
− |
| |
− | } else {
| |
− | i = one ? index : 0;
| |
− | }
| |
− |
| |
− | // Loop through all the selected options
| |
− | for ( ; i < max; i++ ) {
| |
− | option = options[ i ];
| |
− |
| |
− | // Support: IE <=9 only
| |
− | // IE8-9 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
| |
− | !option.disabled &&
| |
− | ( !option.parentNode.disabled ||
| |
− | !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 values;
| |
− | },
| |
− |
| |
− | set: function( elem, value ) {
| |
− | var optionSet, option,
| |
− | options = elem.options,
| |
− | values = jQuery.makeArray( value ),
| |
− | i = options.length;
| |
− |
| |
− | while ( i-- ) {
| |
− | option = options[ i ];
| |
− |
| |
− | /* eslint-disable no-cond-assign */
| |
− |
| |
− | if ( option.selected =
| |
− | jQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1
| |
− | ) {
| |
− | optionSet = true;
| |
− | }
| |
− |
| |
− | /* eslint-enable no-cond-assign */
| |
− | }
| |
− |
| |
− | // Force browsers to behave consistently when non-matching value is set
| |
− | if ( !optionSet ) {
| |
− | elem.selectedIndex = -1;
| |
− | }
| |
− | return values;
| |
− | }
| |
− | }
| |
− | }
| |
− | } );
| |
− |
| |
− | // Radios and checkboxes getter/setter
| |
− | jQuery.each( [ "radio", "checkbox" ], function() {
| |
− | jQuery.valHooks[ this ] = {
| |
− | set: function( elem, value ) {
| |
− | if ( Array.isArray( value ) ) {
| |
− | return ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 );
| |
− | }
| |
− | }
| |
− | };
| |
− | if ( !support.checkOn ) {
| |
− | jQuery.valHooks[ this ].get = function( elem ) {
| |
− | return elem.getAttribute( "value" ) === null ? "on" : elem.value;
| |
− | };
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // Return jQuery for attributes-only inclusion
| |
− |
| |
− |
| |
− | support.focusin = "onfocusin" in window;
| |
− |
| |
− |
| |
− | var rfocusMorph = /^(?:focusinfocus|focusoutblur)$/,
| |
− | stopPropagationCallback = function( e ) {
| |
− | e.stopPropagation();
| |
− | };
| |
− |
| |
− | jQuery.extend( jQuery.event, {
| |
− |
| |
− | trigger: function( event, data, elem, onlyHandlers ) {
| |
− |
| |
− | var i, cur, tmp, bubbleType, ontype, handle, special, lastElement,
| |
− | eventPath = [ elem || document ],
| |
− | type = hasOwn.call( event, "type" ) ? event.type : event,
| |
− | namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split( "." ) : [];
| |
− |
| |
− | cur = lastElement = tmp = elem = elem || document;
| |
− |
| |
− | // Don't do events on text and comment nodes
| |
− | if ( elem.nodeType === 3 || elem.nodeType === 8 ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // focus/blur morphs to focusin/out; ensure we're not firing them right now
| |
− | if ( rfocusMorph.test( type + jQuery.event.triggered ) ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | if ( type.indexOf( "." ) > -1 ) {
| |
− |
| |
− | // 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;
| |
− |
| |
− | // 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 );
| |
− |
| |
− | // Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true)
| |
− | event.isTrigger = onlyHandlers ? 2 : 3;
| |
− | event.namespace = namespaces.join( "." );
| |
− | event.rnamespace = event.namespace ?
| |
− | new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ) :
| |
− | null;
| |
− |
| |
− | // Clean up the event in case it is being reused
| |
− | event.result = undefined;
| |
− | if ( !event.target ) {
| |
− | event.target = elem;
| |
− | }
| |
− |
| |
− | // Clone any incoming data and prepend the event, creating the handler arg list
| |
− | data = data == null ?
| |
− | [ event ] :
| |
− | jQuery.makeArray( data, [ event ] );
| |
− |
| |
− | // Allow special events to draw outside the lines
| |
− | special = jQuery.event.special[ type ] || {};
| |
− | if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // 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 && !isWindow( elem ) ) {
| |
− |
| |
− | bubbleType = special.delegateType || type;
| |
− | if ( !rfocusMorph.test( bubbleType + type ) ) {
| |
− | cur = cur.parentNode;
| |
− | }
| |
− | for ( ; cur; cur = cur.parentNode ) {
| |
− | eventPath.push( cur );
| |
− | tmp = cur;
| |
− | }
| |
− |
| |
− | // 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 );
| |
− | }
| |
− | }
| |
− |
| |
− | // Fire handlers on the event path
| |
− | i = 0;
| |
− | while ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) {
| |
− | lastElement = cur;
| |
− | event.type = i > 1 ?
| |
− | bubbleType :
| |
− | special.bindType || type;
| |
− |
| |
− | // jQuery handler
| |
− | handle = ( dataPriv.get( cur, "events" ) || {} )[ event.type ] &&
| |
− | dataPriv.get( cur, "handle" );
| |
− | if ( handle ) {
| |
− | handle.apply( cur, data );
| |
− | }
| |
− |
| |
− | // Native handler
| |
− | handle = ontype && cur[ ontype ];
| |
− | if ( handle && handle.apply && acceptData( cur ) ) {
| |
− | event.result = handle.apply( cur, data );
| |
− | if ( event.result === false ) {
| |
− | event.preventDefault();
| |
− | }
| |
− | }
| |
− | }
| |
− | event.type = type;
| |
− |
| |
− | // If nobody prevented the default action, do it now
| |
− | if ( !onlyHandlers && !event.isDefaultPrevented() ) {
| |
− |
| |
− | if ( ( !special._default ||
| |
− | special._default.apply( eventPath.pop(), data ) === false ) &&
| |
− | acceptData( elem ) ) {
| |
− |
| |
− | // Call a native DOM method on the target with the same name as the event.
| |
− | // Don't do default actions on window, that's where global variables be (#6170)
| |
− | if ( ontype && isFunction( elem[ type ] ) && !isWindow( elem ) ) {
| |
− |
| |
− | // Don't re-trigger an onFOO event when we call its FOO() method
| |
− | tmp = elem[ ontype ];
| |
− |
| |
− | if ( tmp ) {
| |
− | elem[ ontype ] = null;
| |
− | }
| |
− |
| |
− | // Prevent re-triggering of the same event, since we already bubbled it above
| |
− | jQuery.event.triggered = type;
| |
− |
| |
− | if ( event.isPropagationStopped() ) {
| |
− | lastElement.addEventListener( type, stopPropagationCallback );
| |
− | }
| |
− |
| |
− | elem[ type ]();
| |
− |
| |
− | if ( event.isPropagationStopped() ) {
| |
− | lastElement.removeEventListener( type, stopPropagationCallback );
| |
− | }
| |
− |
| |
− | jQuery.event.triggered = undefined;
| |
− |
| |
− | if ( tmp ) {
| |
− | elem[ ontype ] = tmp;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return event.result;
| |
− | },
| |
− |
| |
− | // Piggyback on a donor event to simulate a different one
| |
− | // Used only for `focus(in | out)` events
| |
− | simulate: function( type, elem, event ) {
| |
− | var e = jQuery.extend(
| |
− | new jQuery.Event(),
| |
− | event,
| |
− | {
| |
− | type: type,
| |
− | isSimulated: true
| |
− | }
| |
− | );
| |
− |
| |
− | jQuery.event.trigger( e, null, elem );
| |
− | }
| |
− |
| |
− | } );
| |
− |
| |
− | jQuery.fn.extend( {
| |
− |
| |
− | 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 );
| |
− | }
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | // Support: Firefox <=44
| |
− | // Firefox doesn't have focus(in | out) events
| |
− | // Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787
| |
− | //
| |
− | // Support: Chrome <=48 - 49, Safari <=9.0 - 9.1
| |
− | // focus(in | out) events fire after focus & blur events,
| |
− | // which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order
| |
− | // Related ticket - https://bugs.chromium.org/p/chromium/issues/detail?id=449857
| |
− | if ( !support.focusin ) {
| |
− | jQuery.each( { focus: "focusin", blur: "focusout" }, function( orig, fix ) {
| |
− |
| |
− | // Attach a single capturing handler on the document while someone wants focusin/focusout
| |
− | var handler = function( event ) {
| |
− | jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ) );
| |
− | };
| |
− |
| |
− | jQuery.event.special[ fix ] = {
| |
− | setup: function() {
| |
− | var doc = this.ownerDocument || this,
| |
− | attaches = dataPriv.access( doc, fix );
| |
− |
| |
− | if ( !attaches ) {
| |
− | doc.addEventListener( orig, handler, true );
| |
− | }
| |
− | dataPriv.access( doc, fix, ( attaches || 0 ) + 1 );
| |
− | },
| |
− | teardown: function() {
| |
− | var doc = this.ownerDocument || this,
| |
− | attaches = dataPriv.access( doc, fix ) - 1;
| |
− |
| |
− | if ( !attaches ) {
| |
− | doc.removeEventListener( orig, handler, true );
| |
− | dataPriv.remove( doc, fix );
| |
− |
| |
− | } else {
| |
− | dataPriv.access( doc, fix, attaches );
| |
− | }
| |
− | }
| |
− | };
| |
− | } );
| |
− | }
| |
− | var location = window.location;
| |
− |
| |
− | var nonce = Date.now();
| |
− |
| |
− | var rquery = ( /\?/ );
| |
− |
| |
− |
| |
− |
| |
− | // Cross-browser xml parsing
| |
− | jQuery.parseXML = function( data ) {
| |
− | var xml;
| |
− | if ( !data || typeof data !== "string" ) {
| |
− | return null;
| |
− | }
| |
− |
| |
− | // Support: IE 9 - 11 only
| |
− | // IE throws on parseFromString with invalid input.
| |
− | try {
| |
− | xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" );
| |
− | } catch ( e ) {
| |
− | xml = undefined;
| |
− | }
| |
− |
| |
− | if ( !xml || xml.getElementsByTagName( "parsererror" ).length ) {
| |
− | jQuery.error( "Invalid XML: " + data );
| |
− | }
| |
− | return xml;
| |
− | };
| |
− |
| |
− |
| |
− | var
| |
− | rbracket = /\[\]$/,
| |
− | rCRLF = /\r?\n/g,
| |
− | rsubmitterTypes = /^(?:submit|button|image|reset|file)$/i,
| |
− | rsubmittable = /^(?:input|select|textarea|keygen)/i;
| |
− |
| |
− | function buildParams( prefix, obj, traditional, add ) {
| |
− | var name;
| |
− |
| |
− | if ( Array.isArray( obj ) ) {
| |
− |
| |
− | // Serialize array item.
| |
− | jQuery.each( obj, function( i, v ) {
| |
− | if ( traditional || rbracket.test( prefix ) ) {
| |
− |
| |
− | // Treat each array item as a scalar.
| |
− | add( prefix, v );
| |
− |
| |
− | } else {
| |
− |
| |
− | // Item is non-scalar (array or object), encode its numeric index.
| |
− | buildParams(
| |
− | prefix + "[" + ( typeof v === "object" && v != null ? i : "" ) + "]",
| |
− | v,
| |
− | traditional,
| |
− | add
| |
− | );
| |
− | }
| |
− | } );
| |
− |
| |
− | } else if ( !traditional && toType( obj ) === "object" ) {
| |
− |
| |
− | // Serialize object item.
| |
− | for ( name in obj ) {
| |
− | buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add );
| |
− | }
| |
− |
| |
− | } else {
| |
− |
| |
− | // Serialize scalar item.
| |
− | add( prefix, obj );
| |
− | }
| |
− | }
| |
− |
| |
− | // Serialize an array of form elements or a set of
| |
− | // key/values into a query string
| |
− | jQuery.param = function( a, traditional ) {
| |
− | var prefix,
| |
− | s = [],
| |
− | add = function( key, valueOrFunction ) {
| |
− |
| |
− | // If value is a function, invoke it and use its return value
| |
− | var value = isFunction( valueOrFunction ) ?
| |
− | valueOrFunction() :
| |
− | valueOrFunction;
| |
− |
| |
− | s[ s.length ] = encodeURIComponent( key ) + "=" +
| |
− | encodeURIComponent( value == null ? "" : value );
| |
− | };
| |
− |
| |
− | // If an array was passed in, assume that it is an array of form elements.
| |
− | if ( Array.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {
| |
− |
| |
− | // Serialize the form elements
| |
− | jQuery.each( a, function() {
| |
− | add( this.name, this.value );
| |
− | } );
| |
− |
| |
− | } else {
| |
− |
| |
− | // If traditional, encode the "old" way (the way 1.3.2 or older
| |
− | // did it), otherwise encode params recursively.
| |
− | for ( prefix in a ) {
| |
− | buildParams( prefix, a[ prefix ], traditional, add );
| |
− | }
| |
− | }
| |
− |
| |
− | // Return the resulting serialization
| |
− | return s.join( "&" );
| |
− | };
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | serialize: function() {
| |
− | return jQuery.param( this.serializeArray() );
| |
− | },
| |
− | serializeArray: function() {
| |
− | return this.map( function() {
| |
− |
| |
− | // Can add propHook for "elements" to filter or add form elements
| |
− | var elements = jQuery.prop( this, "elements" );
| |
− | return elements ? jQuery.makeArray( elements ) : this;
| |
− | } )
| |
− | .filter( function() {
| |
− | var type = this.type;
| |
− |
| |
− | // Use .is( ":disabled" ) so that fieldset[disabled] works
| |
− | return this.name && !jQuery( this ).is( ":disabled" ) &&
| |
− | rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&
| |
− | ( this.checked || !rcheckableType.test( type ) );
| |
− | } )
| |
− | .map( function( i, elem ) {
| |
− | var val = jQuery( this ).val();
| |
− |
| |
− | if ( val == null ) {
| |
− | return null;
| |
− | }
| |
− |
| |
− | if ( Array.isArray( val ) ) {
| |
− | return jQuery.map( val, function( val ) {
| |
− | return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) };
| |
− | } );
| |
− | }
| |
− |
| |
− | return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) };
| |
− | } ).get();
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | var
| |
− | r20 = /%20/g,
| |
− | rhash = /#.*$/,
| |
− | rantiCache = /([?&])_=[^&]*/,
| |
− | rheaders = /^(.*?):[ \t]*([^\r\n]*)$/mg,
| |
− |
| |
− | // #7653, #8125, #8152: local protocol detection
| |
− | rlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,
| |
− | rnoContent = /^(?:GET|HEAD)$/,
| |
− | rprotocol = /^\/\//,
| |
− |
| |
− | /* Prefilters
| |
− | * 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example)
| |
− | * 2) These are called:
| |
− | * - BEFORE asking for a transport
| |
− | * - AFTER param serialization (s.data is a string if s.processData is true)
| |
− | * 3) key is the dataType
| |
− | * 4) the catchall symbol "*" can be used
| |
− | * 5) execution will start with transport dataType and THEN continue down to "*" if needed
| |
− | */
| |
− | prefilters = {},
| |
− |
| |
− | /* Transports bindings
| |
− | * 1) key is the dataType
| |
− | * 2) the catchall symbol "*" can be used
| |
− | * 3) selection will start with transport dataType and THEN go to "*" if needed
| |
− | */
| |
− | transports = {},
| |
− |
| |
− | // Avoid comment-prolog char sequence (#10098); must appease lint and evade compression
| |
− | allTypes = "*/".concat( "*" ),
| |
− |
| |
− | // Anchor tag for parsing the document origin
| |
− | originAnchor = document.createElement( "a" );
| |
− | originAnchor.href = location.href;
| |
− |
| |
− | // Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport
| |
− | function addToPrefiltersOrTransports( structure ) {
| |
− |
| |
− | // dataTypeExpression is optional and defaults to "*"
| |
− | return function( dataTypeExpression, func ) {
| |
− |
| |
− | if ( typeof dataTypeExpression !== "string" ) {
| |
− | func = dataTypeExpression;
| |
− | dataTypeExpression = "*";
| |
− | }
| |
− |
| |
− | var dataType,
| |
− | i = 0,
| |
− | dataTypes = dataTypeExpression.toLowerCase().match( rnothtmlwhite ) || [];
| |
− |
| |
− | if ( isFunction( func ) ) {
| |
− |
| |
− | // For each dataType in the dataTypeExpression
| |
− | while ( ( dataType = dataTypes[ i++ ] ) ) {
| |
− |
| |
− | // Prepend if requested
| |
− | if ( dataType[ 0 ] === "+" ) {
| |
− | dataType = dataType.slice( 1 ) || "*";
| |
− | ( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func );
| |
− |
| |
− | // Otherwise append
| |
− | } else {
| |
− | ( structure[ dataType ] = structure[ dataType ] || [] ).push( func );
| |
− | }
| |
− | }
| |
− | }
| |
− | };
| |
− | }
| |
− |
| |
− | // Base inspection function for prefilters and transports
| |
− | function inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) {
| |
− |
| |
− | var inspected = {},
| |
− | seekingTransport = ( structure === transports );
| |
− |
| |
− | function inspect( dataType ) {
| |
− | var selected;
| |
− | inspected[ dataType ] = true;
| |
− | jQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) {
| |
− | var dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR );
| |
− | if ( typeof dataTypeOrTransport === "string" &&
| |
− | !seekingTransport && !inspected[ dataTypeOrTransport ] ) {
| |
− |
| |
− | options.dataTypes.unshift( dataTypeOrTransport );
| |
− | inspect( dataTypeOrTransport );
| |
− | return false;
| |
− | } else if ( seekingTransport ) {
| |
− | return !( selected = dataTypeOrTransport );
| |
− | }
| |
− | } );
| |
− | return selected;
| |
− | }
| |
− |
| |
− | return inspect( options.dataTypes[ 0 ] ) || !inspected[ "*" ] && inspect( "*" );
| |
− | }
| |
− |
| |
− | // A special extend for ajax options
| |
− | // that takes "flat" options (not to be deep extended)
| |
− | // Fixes #9887
| |
− | function ajaxExtend( target, src ) {
| |
− | var key, deep,
| |
− | flatOptions = jQuery.ajaxSettings.flatOptions || {};
| |
− |
| |
− | for ( key in src ) {
| |
− | if ( src[ key ] !== undefined ) {
| |
− | ( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ];
| |
− | }
| |
− | }
| |
− | if ( deep ) {
| |
− | jQuery.extend( true, target, deep );
| |
− | }
| |
− |
| |
− | return target;
| |
− | }
| |
− |
| |
− | /* Handles responses to an ajax request:
| |
− | * - finds the right dataType (mediates between content-type and expected dataType)
| |
− | * - returns the corresponding response
| |
− | */
| |
− | function ajaxHandleResponses( s, jqXHR, responses ) {
| |
− |
| |
− | var ct, type, finalDataType, firstDataType,
| |
− | contents = s.contents,
| |
− | dataTypes = s.dataTypes;
| |
− |
| |
− | // Remove auto dataType and get content-type in the process
| |
− | while ( dataTypes[ 0 ] === "*" ) {
| |
− | dataTypes.shift();
| |
− | if ( ct === undefined ) {
| |
− | ct = s.mimeType || jqXHR.getResponseHeader( "Content-Type" );
| |
− | }
| |
− | }
| |
− |
| |
− | // Check if we're dealing with a known content-type
| |
− | if ( ct ) {
| |
− | for ( type in contents ) {
| |
− | if ( contents[ type ] && contents[ type ].test( ct ) ) {
| |
− | dataTypes.unshift( type );
| |
− | break;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Check to see if we have a response for the expected dataType
| |
− | if ( dataTypes[ 0 ] in responses ) {
| |
− | finalDataType = dataTypes[ 0 ];
| |
− | } else {
| |
− |
| |
− | // Try convertible dataTypes
| |
− | for ( type in responses ) {
| |
− | if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[ 0 ] ] ) {
| |
− | finalDataType = type;
| |
− | break;
| |
− | }
| |
− | if ( !firstDataType ) {
| |
− | firstDataType = type;
| |
− | }
| |
− | }
| |
− |
| |
− | // Or just use first one
| |
− | finalDataType = finalDataType || firstDataType;
| |
− | }
| |
− |
| |
− | // If we found a dataType
| |
− | // We add the dataType to the list if needed
| |
− | // and return the corresponding response
| |
− | if ( finalDataType ) {
| |
− | if ( finalDataType !== dataTypes[ 0 ] ) {
| |
− | dataTypes.unshift( finalDataType );
| |
− | }
| |
− | return responses[ finalDataType ];
| |
− | }
| |
− | }
| |
− |
| |
− | /* 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 = {},
| |
− |
| |
− | // Work with a copy of dataTypes in case we need to modify it for conversion
| |
− | dataTypes = s.dataTypes.slice();
| |
− |
| |
− | // Create converters map with lowercased keys
| |
− | if ( dataTypes[ 1 ] ) {
| |
− | for ( conv in s.converters ) {
| |
− | converters[ conv.toLowerCase() ] = s.converters[ conv ];
| |
− | }
| |
− | }
| |
− |
| |
− | 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 === "*" ) {
| |
− |
| |
− | current = prev;
| |
− |
| |
− | // Convert response if prev dataType is non-auto and differs from current
| |
− | } else if ( prev !== "*" && prev !== current ) {
| |
− |
| |
− | // Seek a direct converter
| |
− | conv = converters[ prev + " " + current ] || converters[ "* " + current ];
| |
− |
| |
− | // If none found, seek a pair
| |
− | if ( !conv ) {
| |
− | for ( conv2 in converters ) {
| |
− |
| |
− | // If conv2 outputs current
| |
− | tmp = conv2.split( " " );
| |
− | if ( tmp[ 1 ] === current ) {
| |
− |
| |
− | // If prev can be converted to accepted input
| |
− | conv = converters[ prev + " " + tmp[ 0 ] ] ||
| |
− | converters[ "* " + tmp[ 0 ] ];
| |
− | if ( conv ) {
| |
− |
| |
− | // Condense equivalence converters
| |
− | if ( conv === true ) {
| |
− | conv = converters[ conv2 ];
| |
− |
| |
− | // Otherwise, insert the intermediate dataType
| |
− | } else if ( converters[ conv2 ] !== true ) {
| |
− | current = tmp[ 0 ];
| |
− | dataTypes.unshift( tmp[ 1 ] );
| |
− | }
| |
− | break;
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Apply converter (if not an equivalence)
| |
− | if ( conv !== true ) {
| |
− |
| |
− | // Unless errors are allowed to bubble, catch and return them
| |
− | if ( conv && s.throws ) {
| |
− | response = conv( response );
| |
− | } else {
| |
− | try {
| |
− | response = conv( response );
| |
− | } catch ( e ) {
| |
− | return {
| |
− | state: "parsererror",
| |
− | error: conv ? e : "No conversion from " + prev + " to " + current
| |
− | };
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return { state: "success", data: response };
| |
− | }
| |
− |
| |
− | jQuery.extend( {
| |
− |
| |
− | // Counter for holding the number of active queries
| |
− | active: 0,
| |
− |
| |
− | // Last-Modified header cache for next request
| |
− | lastModified: {},
| |
− | etag: {},
| |
− |
| |
− | ajaxSettings: {
| |
− | url: location.href,
| |
− | type: "GET",
| |
− | isLocal: rlocalProtocol.test( location.protocol ),
| |
− | global: true,
| |
− | processData: true,
| |
− | async: true,
| |
− | contentType: "application/x-www-form-urlencoded; charset=UTF-8",
| |
− |
| |
− | /*
| |
− | timeout: 0,
| |
− | data: null,
| |
− | dataType: null,
| |
− | username: null,
| |
− | password: null,
| |
− | cache: null,
| |
− | throws: false,
| |
− | traditional: false,
| |
− | headers: {},
| |
− | */
| |
− |
| |
− | accepts: {
| |
− | "*": allTypes,
| |
− | text: "text/plain",
| |
− | html: "text/html",
| |
− | xml: "application/xml, text/xml",
| |
− | json: "application/json, text/javascript"
| |
− | },
| |
− |
| |
− | contents: {
| |
− | xml: /\bxml\b/,
| |
− | html: /\bhtml/,
| |
− | json: /\bjson\b/
| |
− | },
| |
− |
| |
− | responseFields: {
| |
− | xml: "responseXML",
| |
− | text: "responseText",
| |
− | json: "responseJSON"
| |
− | },
| |
− |
| |
− | // Data converters
| |
− | // Keys separate source (or catchall "*") and destination types with a single space
| |
− | converters: {
| |
− |
| |
− | // Convert anything to text
| |
− | "* text": String,
| |
− |
| |
− | // Text to html (true = no transformation)
| |
− | "text html": true,
| |
− |
| |
− | // Evaluate text as a json expression
| |
− | "text json": JSON.parse,
| |
− |
| |
− | // Parse text as xml
| |
− | "text xml": jQuery.parseXML
| |
− | },
| |
− |
| |
− | // For options that shouldn't be deep extended:
| |
− | // you can add your own custom options here if
| |
− | // and when you create one that shouldn't be
| |
− | // deep extended (see ajaxExtend)
| |
− | flatOptions: {
| |
− | url: true,
| |
− | context: true
| |
− | }
| |
− | },
| |
− |
| |
− | // Creates a full fledged settings object into target
| |
− | // with both ajaxSettings and settings fields.
| |
− | // If target is omitted, writes into ajaxSettings.
| |
− | ajaxSetup: function( target, settings ) {
| |
− | return settings ?
| |
− |
| |
− | // Building a settings object
| |
− | ajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) :
| |
− |
| |
− | // Extending ajaxSettings
| |
− | ajaxExtend( jQuery.ajaxSettings, target );
| |
− | },
| |
− |
| |
− | ajaxPrefilter: addToPrefiltersOrTransports( prefilters ),
| |
− | ajaxTransport: addToPrefiltersOrTransports( transports ),
| |
− |
| |
− | // Main method
| |
− | ajax: function( url, options ) {
| |
− |
| |
− | // If url is an object, simulate pre-1.5 signature
| |
− | if ( typeof url === "object" ) {
| |
− | options = url;
| |
− | url = undefined;
| |
− | }
| |
− |
| |
− | // Force options to be an object
| |
− | options = options || {};
| |
− |
| |
− | var transport,
| |
− |
| |
− | // URL without anti-cache param
| |
− | cacheURL,
| |
− |
| |
− | // Response headers
| |
− | responseHeadersString,
| |
− | responseHeaders,
| |
− |
| |
− | // timeout handle
| |
− | timeoutTimer,
| |
− |
| |
− | // Url cleanup var
| |
− | urlAnchor,
| |
− |
| |
− | // Request state (becomes false upon send and true upon completion)
| |
− | completed,
| |
− |
| |
− | // To know if global events are to be dispatched
| |
− | fireGlobals,
| |
− |
| |
− | // Loop variable
| |
− | i,
| |
− |
| |
− | // uncached part of the url
| |
− | uncached,
| |
− |
| |
− | // Create the final options object
| |
− | s = jQuery.ajaxSetup( {}, options ),
| |
− |
| |
− | // Callbacks context
| |
− | callbackContext = s.context || s,
| |
− |
| |
− | // Context for global events is callbackContext if it is a DOM node or jQuery collection
| |
− | globalEventContext = s.context &&
| |
− | ( callbackContext.nodeType || callbackContext.jquery ) ?
| |
− | jQuery( callbackContext ) :
| |
− | jQuery.event,
| |
− |
| |
− | // Deferreds
| |
− | deferred = jQuery.Deferred(),
| |
− | completeDeferred = jQuery.Callbacks( "once memory" ),
| |
− |
| |
− | // Status-dependent callbacks
| |
− | statusCode = s.statusCode || {},
| |
− |
| |
− | // Headers (they are sent all at once)
| |
− | requestHeaders = {},
| |
− | requestHeadersNames = {},
| |
− |
| |
− | // Default abort message
| |
− | strAbort = "canceled",
| |
− |
| |
− | // Fake xhr
| |
− | jqXHR = {
| |
− | readyState: 0,
| |
− |
| |
− | // Builds headers hashtable if needed
| |
− | getResponseHeader: function( key ) {
| |
− | var match;
| |
− | if ( completed ) {
| |
− | if ( !responseHeaders ) {
| |
− | responseHeaders = {};
| |
− | while ( ( match = rheaders.exec( responseHeadersString ) ) ) {
| |
− | responseHeaders[ match[ 1 ].toLowerCase() ] = match[ 2 ];
| |
− | }
| |
− | }
| |
− | match = responseHeaders[ key.toLowerCase() ];
| |
− | }
| |
− | return match == null ? null : match;
| |
− | },
| |
− |
| |
− | // Raw string
| |
− | getAllResponseHeaders: function() {
| |
− | return completed ? responseHeadersString : null;
| |
− | },
| |
− |
| |
− | // Caches the header
| |
− | setRequestHeader: function( name, value ) {
| |
− | if ( completed == null ) {
| |
− | name = requestHeadersNames[ name.toLowerCase() ] =
| |
− | requestHeadersNames[ name.toLowerCase() ] || name;
| |
− | requestHeaders[ name ] = value;
| |
− | }
| |
− | return this;
| |
− | },
| |
− |
| |
− | // Overrides response content-type header
| |
− | overrideMimeType: function( type ) {
| |
− | if ( completed == null ) {
| |
− | s.mimeType = type;
| |
− | }
| |
− | return this;
| |
− | },
| |
− |
| |
− | // Status-dependent callbacks
| |
− | statusCode: function( map ) {
| |
− | var code;
| |
− | if ( map ) {
| |
− | if ( completed ) {
| |
− |
| |
− | // Execute the appropriate callbacks
| |
− | jqXHR.always( map[ jqXHR.status ] );
| |
− | } else {
| |
− |
| |
− | // Lazy-add the new callbacks in a way that preserves old ones
| |
− | for ( code in map ) {
| |
− | statusCode[ code ] = [ statusCode[ code ], map[ code ] ];
| |
− | }
| |
− | }
| |
− | }
| |
− | return this;
| |
− | },
| |
− |
| |
− | // Cancel the request
| |
− | abort: function( statusText ) {
| |
− | var finalText = statusText || strAbort;
| |
− | if ( transport ) {
| |
− | transport.abort( finalText );
| |
− | }
| |
− | done( 0, finalText );
| |
− | return this;
| |
− | }
| |
− | };
| |
− |
| |
− | // Attach deferreds
| |
− | deferred.promise( jqXHR );
| |
− |
| |
− | // Add protocol if not provided (prefilters might expect it)
| |
− | // Handle falsy url in the settings object (#10093: consistency with old signature)
| |
− | // We also use the url parameter if available
| |
− | s.url = ( ( url || s.url || location.href ) + "" )
| |
− | .replace( rprotocol, location.protocol + "//" );
| |
− |
| |
− | // Alias method option to type as per ticket #12004
| |
− | s.type = options.method || options.type || s.method || s.type;
| |
− |
| |
− | // Extract dataTypes list
| |
− | s.dataTypes = ( s.dataType || "*" ).toLowerCase().match( rnothtmlwhite ) || [ "" ];
| |
− |
| |
− | // A cross-domain request is in order when the origin doesn't match the current origin.
| |
− | if ( s.crossDomain == null ) {
| |
− | urlAnchor = document.createElement( "a" );
| |
− |
| |
− | // Support: IE <=8 - 11, Edge 12 - 15
| |
− | // IE throws exception on accessing the href property if url is malformed,
| |
− | // e.g. http://example.com:80x/
| |
− | try {
| |
− | urlAnchor.href = s.url;
| |
− |
| |
− | // Support: IE <=8 - 11 only
| |
− | // Anchor's host property isn't correctly set when s.url is relative
| |
− | urlAnchor.href = urlAnchor.href;
| |
− | s.crossDomain = originAnchor.protocol + "//" + originAnchor.host !==
| |
− | urlAnchor.protocol + "//" + urlAnchor.host;
| |
− | } catch ( e ) {
| |
− |
| |
− | // If there is an error parsing the URL, assume it is crossDomain,
| |
− | // it can be rejected by the transport if it is invalid
| |
− | s.crossDomain = true;
| |
− | }
| |
− | }
| |
− |
| |
− | // Convert data if not already a string
| |
− | if ( s.data && s.processData && typeof s.data !== "string" ) {
| |
− | s.data = jQuery.param( s.data, s.traditional );
| |
− | }
| |
− |
| |
− | // Apply prefilters
| |
− | inspectPrefiltersOrTransports( prefilters, s, options, jqXHR );
| |
− |
| |
− | // If request was aborted inside a prefilter, stop there
| |
− | if ( completed ) {
| |
− | return jqXHR;
| |
− | }
| |
− |
| |
− | // We can fire global events as of now if asked to
| |
− | // Don't fire events if jQuery.event is undefined in an AMD-usage scenario (#15118)
| |
− | fireGlobals = jQuery.event && s.global;
| |
− |
| |
− | // Watch for a new set of requests
| |
− | if ( fireGlobals && jQuery.active++ === 0 ) {
| |
− | jQuery.event.trigger( "ajaxStart" );
| |
− | }
| |
− |
| |
− | // Uppercase the type
| |
− | s.type = s.type.toUpperCase();
| |
− |
| |
− | // Determine if request has content
| |
− | s.hasContent = !rnoContent.test( s.type );
| |
− |
| |
− | // Save the URL in case we're toying with the If-Modified-Since
| |
− | // and/or If-None-Match header later on
| |
− | // Remove hash to simplify url manipulation
| |
− | cacheURL = s.url.replace( rhash, "" );
| |
− |
| |
− | // More options handling for requests with no content
| |
− | if ( !s.hasContent ) {
| |
− |
| |
− | // Remember the hash so we can put it back
| |
− | uncached = s.url.slice( cacheURL.length );
| |
− |
| |
− | // If data is available and should be processed, append data to url
| |
− | if ( s.data && ( s.processData || typeof s.data === "string" ) ) {
| |
− | cacheURL += ( rquery.test( cacheURL ) ? "&" : "?" ) + s.data;
| |
− |
| |
− | // #9682: remove data so that it's not used in an eventual retry
| |
− | delete s.data;
| |
− | }
| |
− |
| |
− | // Add or update anti-cache param if needed
| |
− | if ( s.cache === false ) {
| |
− | cacheURL = cacheURL.replace( rantiCache, "$1" );
| |
− | uncached = ( rquery.test( cacheURL ) ? "&" : "?" ) + "_=" + ( nonce++ ) + uncached;
| |
− | }
| |
− |
| |
− | // Put hash and anti-cache on the URL that will be requested (gh-1732)
| |
− | s.url = cacheURL + uncached;
| |
− |
| |
− | // Change '%20' to '+' if this is encoded form body content (gh-2658)
| |
− | } else if ( s.data && s.processData &&
| |
− | ( s.contentType || "" ).indexOf( "application/x-www-form-urlencoded" ) === 0 ) {
| |
− | s.data = s.data.replace( r20, "+" );
| |
− | }
| |
− |
| |
− | // Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.
| |
− | if ( s.ifModified ) {
| |
− | if ( jQuery.lastModified[ cacheURL ] ) {
| |
− | jqXHR.setRequestHeader( "If-Modified-Since", jQuery.lastModified[ cacheURL ] );
| |
− | }
| |
− | if ( jQuery.etag[ cacheURL ] ) {
| |
− | jqXHR.setRequestHeader( "If-None-Match", jQuery.etag[ cacheURL ] );
| |
− | }
| |
− | }
| |
− |
| |
− | // Set the correct header, if data is being sent
| |
− | if ( s.data && s.hasContent && s.contentType !== false || options.contentType ) {
| |
− | jqXHR.setRequestHeader( "Content-Type", s.contentType );
| |
− | }
| |
− |
| |
− | // Set the Accepts header for the server, depending on the dataType
| |
− | jqXHR.setRequestHeader(
| |
− | "Accept",
| |
− | s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ?
| |
− | s.accepts[ s.dataTypes[ 0 ] ] +
| |
− | ( s.dataTypes[ 0 ] !== "*" ? ", " + allTypes + "; q=0.01" : "" ) :
| |
− | s.accepts[ "*" ]
| |
− | );
| |
− |
| |
− | // Check for headers option
| |
− | for ( i in s.headers ) {
| |
− | jqXHR.setRequestHeader( i, s.headers[ i ] );
| |
− | }
| |
− |
| |
− | // Allow custom headers/mimetypes and early abort
| |
− | if ( s.beforeSend &&
| |
− | ( s.beforeSend.call( callbackContext, jqXHR, s ) === false || completed ) ) {
| |
− |
| |
− | // Abort if not done already and return
| |
− | return jqXHR.abort();
| |
− | }
| |
− |
| |
− | // Aborting is no longer a cancellation
| |
− | strAbort = "abort";
| |
− |
| |
− | // Install callbacks on deferreds
| |
− | completeDeferred.add( s.complete );
| |
− | jqXHR.done( s.success );
| |
− | jqXHR.fail( s.error );
| |
− |
| |
− | // Get transport
| |
− | transport = inspectPrefiltersOrTransports( transports, s, options, jqXHR );
| |
− |
| |
− | // If no transport, we auto-abort
| |
− | if ( !transport ) {
| |
− | done( -1, "No Transport" );
| |
− | } else {
| |
− | jqXHR.readyState = 1;
| |
− |
| |
− | // Send global event
| |
− | if ( fireGlobals ) {
| |
− | globalEventContext.trigger( "ajaxSend", [ jqXHR, s ] );
| |
− | }
| |
− |
| |
− | // If request was aborted inside ajaxSend, stop there
| |
− | if ( completed ) {
| |
− | return jqXHR;
| |
− | }
| |
− |
| |
− | // Timeout
| |
− | if ( s.async && s.timeout > 0 ) {
| |
− | timeoutTimer = window.setTimeout( function() {
| |
− | jqXHR.abort( "timeout" );
| |
− | }, s.timeout );
| |
− | }
| |
− |
| |
− | try {
| |
− | completed = false;
| |
− | transport.send( requestHeaders, done );
| |
− | } catch ( e ) {
| |
− |
| |
− | // Rethrow post-completion exceptions
| |
− | if ( completed ) {
| |
− | throw e;
| |
− | }
| |
− |
| |
− | // Propagate others as results
| |
− | done( -1, e );
| |
− | }
| |
− | }
| |
− |
| |
− | // Callback for when everything is done
| |
− | function done( status, nativeStatusText, responses, headers ) {
| |
− | var isSuccess, success, error, response, modified,
| |
− | statusText = nativeStatusText;
| |
− |
| |
− | // Ignore repeat invocations
| |
− | if ( completed ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | completed = true;
| |
− |
| |
− | // Clear timeout if it exists
| |
− | if ( timeoutTimer ) {
| |
− | window.clearTimeout( timeoutTimer );
| |
− | }
| |
− |
| |
− | // Dereference transport for early garbage collection
| |
− | // (no matter how long the jqXHR object will be used)
| |
− | transport = undefined;
| |
− |
| |
− | // Cache response headers
| |
− | responseHeadersString = headers || "";
| |
− |
| |
− | // 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 ( isSuccess ) {
| |
− |
| |
− | // Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.
| |
− | if ( s.ifModified ) {
| |
− | modified = jqXHR.getResponseHeader( "Last-Modified" );
| |
− | if ( modified ) {
| |
− | jQuery.lastModified[ cacheURL ] = modified;
| |
− | }
| |
− | modified = jqXHR.getResponseHeader( "etag" );
| |
− | if ( modified ) {
| |
− | jQuery.etag[ cacheURL ] = modified;
| |
− | }
| |
− | }
| |
− |
| |
− | // if no content
| |
− | if ( status === 204 || s.type === "HEAD" ) {
| |
− | statusText = "nocontent";
| |
− |
| |
− | // if not modified
| |
− | } else if ( status === 304 ) {
| |
− | statusText = "notmodified";
| |
− |
| |
− | // If we have data, let's convert it
| |
− | } else {
| |
− | statusText = response.state;
| |
− | success = response.data;
| |
− | error = response.error;
| |
− | isSuccess = !error;
| |
− | }
| |
− | } else {
| |
− |
| |
− | // Extract error from statusText and normalize for non-aborts
| |
− | error = statusText;
| |
− | if ( status || !statusText ) {
| |
− | statusText = "error";
| |
− | if ( status < 0 ) {
| |
− | status = 0;
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | // Set data for the fake xhr object
| |
− | jqXHR.status = status;
| |
− | jqXHR.statusText = ( nativeStatusText || statusText ) + "";
| |
− |
| |
− | // Success/Error
| |
− | if ( isSuccess ) {
| |
− | deferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] );
| |
− | } else {
| |
− | deferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] );
| |
− | }
| |
− |
| |
− | // Status-dependent callbacks
| |
− | jqXHR.statusCode( statusCode );
| |
− | statusCode = undefined;
| |
− |
| |
− | if ( fireGlobals ) {
| |
− | globalEventContext.trigger( isSuccess ? "ajaxSuccess" : "ajaxError",
| |
− | [ jqXHR, s, isSuccess ? success : error ] );
| |
− | }
| |
− |
| |
− | // Complete
| |
− | completeDeferred.fireWith( callbackContext, [ jqXHR, statusText ] );
| |
− |
| |
− | if ( fireGlobals ) {
| |
− | globalEventContext.trigger( "ajaxComplete", [ jqXHR, s ] );
| |
− |
| |
− | // Handle the global AJAX counter
| |
− | if ( !( --jQuery.active ) ) {
| |
− | jQuery.event.trigger( "ajaxStop" );
| |
− | }
| |
− | }
| |
− | }
| |
− |
| |
− | return jqXHR;
| |
− | },
| |
− |
| |
− | 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 ( isFunction( data ) ) {
| |
− | type = type || callback;
| |
− | callback = data;
| |
− | data = undefined;
| |
− | }
| |
− |
| |
− | // The url can be an options object (which then must have .url)
| |
− | return jQuery.ajax( jQuery.extend( {
| |
− | url: url,
| |
− | type: method,
| |
− | dataType: type,
| |
− | data: data,
| |
− | success: callback
| |
− | }, jQuery.isPlainObject( url ) && url ) );
| |
− | };
| |
− | } );
| |
− |
| |
− |
| |
− | jQuery._evalUrl = function( url ) {
| |
− | return jQuery.ajax( {
| |
− | url: url,
| |
− |
| |
− | // Make this explicit, since user can override this through ajaxSetup (#11264)
| |
− | type: "GET",
| |
− | dataType: "script",
| |
− | cache: true,
| |
− | async: false,
| |
− | global: false,
| |
− | "throws": true
| |
− | } );
| |
− | };
| |
− |
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | wrapAll: function( html ) {
| |
− | var wrap;
| |
− |
| |
− | if ( this[ 0 ] ) {
| |
− | if ( isFunction( html ) ) {
| |
− | html = html.call( this[ 0 ] );
| |
− | }
| |
− |
| |
− | // The elements to wrap the target around
| |
− | 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.firstElementChild ) {
| |
− | elem = elem.firstElementChild;
| |
− | }
| |
− |
| |
− | return elem;
| |
− | } ).append( this );
| |
− | }
| |
− |
| |
− | return this;
| |
− | },
| |
− |
| |
− | wrapInner: function( html ) {
| |
− | if ( 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 htmlIsFunction = isFunction( html );
| |
− |
| |
− | return this.each( function( i ) {
| |
− | jQuery( this ).wrapAll( htmlIsFunction ? html.call( this, i ) : html );
| |
− | } );
| |
− | },
| |
− |
| |
− | unwrap: function( selector ) {
| |
− | this.parent( selector ).not( "body" ).each( function() {
| |
− | jQuery( this ).replaceWith( this.childNodes );
| |
− | } );
| |
− | return this;
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− | jQuery.expr.pseudos.hidden = function( elem ) {
| |
− | return !jQuery.expr.pseudos.visible( elem );
| |
− | };
| |
− | jQuery.expr.pseudos.visible = function( elem ) {
| |
− | return !!( elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length );
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | jQuery.ajaxSettings.xhr = function() {
| |
− | try {
| |
− | return new window.XMLHttpRequest();
| |
− | } catch ( e ) {}
| |
− | };
| |
− |
| |
− | var xhrSuccessStatus = {
| |
− |
| |
− | // File protocol always yields status code 0, assume 200
| |
− | 0: 200,
| |
− |
| |
− | // Support: IE <=9 only
| |
− | // #1450: sometimes IE returns 1223 when it should be 204
| |
− | 1223: 204
| |
− | },
| |
− | xhrSupported = jQuery.ajaxSettings.xhr();
| |
− |
| |
− | support.cors = !!xhrSupported && ( "withCredentials" in xhrSupported );
| |
− | support.ajax = xhrSupported = !!xhrSupported;
| |
− |
| |
− | jQuery.ajaxTransport( function( options ) {
| |
− | var callback, errorCallback;
| |
− |
| |
− | // Cross domain only allowed if supported through XMLHttpRequest
| |
− | if ( support.cors || xhrSupported && !options.crossDomain ) {
| |
− | return {
| |
− | send: function( headers, complete ) {
| |
− | var i,
| |
− | xhr = options.xhr();
| |
− |
| |
− | xhr.open(
| |
− | options.type,
| |
− | options.url,
| |
− | options.async,
| |
− | options.username,
| |
− | options.password
| |
− | );
| |
− |
| |
− | // Apply custom fields if provided
| |
− | if ( options.xhrFields ) {
| |
− | for ( i in options.xhrFields ) {
| |
− | xhr[ i ] = options.xhrFields[ i ];
| |
− | }
| |
− | }
| |
− |
| |
− | // Override mime type if needed
| |
− | if ( options.mimeType && xhr.overrideMimeType ) {
| |
− | xhr.overrideMimeType( options.mimeType );
| |
− | }
| |
− |
| |
− | // X-Requested-With header
| |
− | // For cross-domain requests, seeing as conditions for a preflight are
| |
− | // akin to a jigsaw puzzle, we simply never set it to be sure.
| |
− | // (it can always be set on a per-request basis or even using ajaxSetup)
| |
− | // For same-domain requests, won't change header if already provided.
| |
− | if ( !options.crossDomain && !headers[ "X-Requested-With" ] ) {
| |
− | headers[ "X-Requested-With" ] = "XMLHttpRequest";
| |
− | }
| |
− |
| |
− | // Set headers
| |
− | for ( i in headers ) {
| |
− | xhr.setRequestHeader( i, headers[ i ] );
| |
− | }
| |
− |
| |
− | // Callback
| |
− | callback = function( type ) {
| |
− | return function() {
| |
− | if ( callback ) {
| |
− | callback = errorCallback = xhr.onload =
| |
− | xhr.onerror = xhr.onabort = xhr.ontimeout =
| |
− | xhr.onreadystatechange = null;
| |
− |
| |
− | if ( type === "abort" ) {
| |
− | xhr.abort();
| |
− | } else if ( type === "error" ) {
| |
− |
| |
− | // Support: IE <=9 only
| |
− | // On a manual native abort, IE9 throws
| |
− | // errors on any property access that is not readyState
| |
− | if ( typeof xhr.status !== "number" ) {
| |
− | complete( 0, "error" );
| |
− | } else {
| |
− | complete(
| |
− |
| |
− | // File: protocol always yields status 0; see #8605, #14207
| |
− | xhr.status,
| |
− | xhr.statusText
| |
− | );
| |
− | }
| |
− | } else {
| |
− | complete(
| |
− | xhrSuccessStatus[ xhr.status ] || xhr.status,
| |
− | xhr.statusText,
| |
− |
| |
− | // Support: IE <=9 only
| |
− | // IE9 has no XHR2 but throws on binary (trac-11426)
| |
− | // For XHR2 non-text, let the caller handle it (gh-2498)
| |
− | ( xhr.responseType || "text" ) !== "text" ||
| |
− | typeof xhr.responseText !== "string" ?
| |
− | { binary: xhr.response } :
| |
− | { text: xhr.responseText },
| |
− | xhr.getAllResponseHeaders()
| |
− | );
| |
− | }
| |
− | }
| |
− | };
| |
− | };
| |
− |
| |
− | // Listen to events
| |
− | xhr.onload = callback();
| |
− | errorCallback = xhr.onerror = xhr.ontimeout = callback( "error" );
| |
− |
| |
− | // Support: IE 9 only
| |
− | // Use onreadystatechange to replace onabort
| |
− | // to handle uncaught aborts
| |
− | if ( xhr.onabort !== undefined ) {
| |
− | xhr.onabort = errorCallback;
| |
− | } else {
| |
− | xhr.onreadystatechange = function() {
| |
− |
| |
− | // Check readyState before timeout as it changes
| |
− | if ( xhr.readyState === 4 ) {
| |
− |
| |
− | // Allow onerror to be called first,
| |
− | // but that will not handle a native abort
| |
− | // Also, save errorCallback to a variable
| |
− | // as xhr.onerror cannot be accessed
| |
− | window.setTimeout( function() {
| |
− | if ( callback ) {
| |
− | errorCallback();
| |
− | }
| |
− | } );
| |
− | }
| |
− | };
| |
− | }
| |
− |
| |
− | // Create the abort callback
| |
− | callback = callback( "abort" );
| |
− |
| |
− | try {
| |
− |
| |
− | // Do send the request (this may raise an exception)
| |
− | xhr.send( options.hasContent && options.data || null );
| |
− | } catch ( e ) {
| |
− |
| |
− | // #14683: Only rethrow if this hasn't been notified as an error yet
| |
− | if ( callback ) {
| |
− | throw e;
| |
− | }
| |
− | }
| |
− | },
| |
− |
| |
− | abort: function() {
| |
− | if ( callback ) {
| |
− | callback();
| |
− | }
| |
− | }
| |
− | };
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // Prevent auto-execution of scripts when no explicit dataType was provided (See gh-2432)
| |
− | jQuery.ajaxPrefilter( function( s ) {
| |
− | if ( s.crossDomain ) {
| |
− | s.contents.script = false;
| |
− | }
| |
− | } );
| |
− |
| |
− | // Install script dataType
| |
− | jQuery.ajaxSetup( {
| |
− | accepts: {
| |
− | script: "text/javascript, application/javascript, " +
| |
− | "application/ecmascript, application/x-ecmascript"
| |
− | },
| |
− | contents: {
| |
− | script: /\b(?:java|ecma)script\b/
| |
− | },
| |
− | converters: {
| |
− | "text script": function( text ) {
| |
− | jQuery.globalEval( text );
| |
− | return text;
| |
− | }
| |
− | }
| |
− | } );
| |
− |
| |
− | // Handle cache's special case and crossDomain
| |
− | jQuery.ajaxPrefilter( "script", function( s ) {
| |
− | if ( s.cache === undefined ) {
| |
− | s.cache = false;
| |
− | }
| |
− | if ( s.crossDomain ) {
| |
− | s.type = "GET";
| |
− | }
| |
− | } );
| |
− |
| |
− | // Bind script tag hack transport
| |
− | jQuery.ajaxTransport( "script", function( s ) {
| |
− |
| |
− | // This transport only deals with cross domain requests
| |
− | if ( s.crossDomain ) {
| |
− | var script, callback;
| |
− | return {
| |
− | send: function( _, complete ) {
| |
− | script = jQuery( "<script>" ).prop( {
| |
− | charset: s.scriptCharset,
| |
− | src: s.url
| |
− | } ).on(
| |
− | "load error",
| |
− | callback = function( evt ) {
| |
− | script.remove();
| |
− | callback = null;
| |
− | if ( evt ) {
| |
− | complete( evt.type === "error" ? 404 : 200, evt.type );
| |
− | }
| |
− | }
| |
− | );
| |
− |
| |
− | // Use native DOM manipulation to avoid our domManip AJAX trickery
| |
− | document.head.appendChild( script[ 0 ] );
| |
− | },
| |
− | abort: function() {
| |
− | if ( callback ) {
| |
− | callback();
| |
− | }
| |
− | }
| |
− | };
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | var oldCallbacks = [],
| |
− | rjsonp = /(=)\?(?=&|$)|\?\?/;
| |
− |
| |
− | // Default jsonp settings
| |
− | jQuery.ajaxSetup( {
| |
− | jsonp: "callback",
| |
− | jsonpCallback: function() {
| |
− | var callback = oldCallbacks.pop() || ( jQuery.expando + "_" + ( nonce++ ) );
| |
− | this[ callback ] = true;
| |
− | return callback;
| |
− | }
| |
− | } );
| |
− |
| |
− | // Detect, normalize options and install callbacks for jsonp requests
| |
− | jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) {
| |
− |
| |
− | var callbackName, overwritten, responseContainer,
| |
− | jsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ?
| |
− | "url" :
| |
− | typeof s.data === "string" &&
| |
− | ( s.contentType || "" )
| |
− | .indexOf( "application/x-www-form-urlencoded" ) === 0 &&
| |
− | rjsonp.test( s.data ) && "data"
| |
− | );
| |
− |
| |
− | // Handle iff the expected data type is "jsonp" or we have a parameter to set
| |
− | if ( jsonProp || s.dataTypes[ 0 ] === "jsonp" ) {
| |
− |
| |
− | // Get callback name, remembering preexisting value associated with it
| |
− | callbackName = s.jsonpCallback = isFunction( s.jsonpCallback ) ?
| |
− | s.jsonpCallback() :
| |
− | s.jsonpCallback;
| |
− |
| |
− | // Insert callback into url or form data
| |
− | if ( jsonProp ) {
| |
− | s[ jsonProp ] = s[ jsonProp ].replace( rjsonp, "$1" + callbackName );
| |
− | } else if ( s.jsonp !== false ) {
| |
− | s.url += ( rquery.test( s.url ) ? "&" : "?" ) + s.jsonp + "=" + callbackName;
| |
− | }
| |
− |
| |
− | // Use data converter to retrieve json after script execution
| |
− | s.converters[ "script json" ] = function() {
| |
− | if ( !responseContainer ) {
| |
− | jQuery.error( callbackName + " was not called" );
| |
− | }
| |
− | return responseContainer[ 0 ];
| |
− | };
| |
− |
| |
− | // Force json dataType
| |
− | s.dataTypes[ 0 ] = "json";
| |
− |
| |
− | // Install callback
| |
− | overwritten = window[ callbackName ];
| |
− | window[ callbackName ] = function() {
| |
− | responseContainer = arguments;
| |
− | };
| |
− |
| |
− | // Clean-up function (fires after converters)
| |
− | jqXHR.always( function() {
| |
− |
| |
− | // If previous value didn't exist - remove it
| |
− | if ( overwritten === undefined ) {
| |
− | jQuery( window ).removeProp( callbackName );
| |
− |
| |
− | // Otherwise restore preexisting value
| |
− | } else {
| |
− | window[ callbackName ] = overwritten;
| |
− | }
| |
− |
| |
− | // Save back as free
| |
− | if ( s[ callbackName ] ) {
| |
− |
| |
− | // Make sure that re-using the options doesn't screw things around
| |
− | s.jsonpCallback = originalSettings.jsonpCallback;
| |
− |
| |
− | // Save the callback name for future use
| |
− | oldCallbacks.push( callbackName );
| |
− | }
| |
− |
| |
− | // Call if it was a function and we have a response
| |
− | if ( responseContainer && isFunction( overwritten ) ) {
| |
− | overwritten( responseContainer[ 0 ] );
| |
− | }
| |
− |
| |
− | responseContainer = overwritten = undefined;
| |
− | } );
| |
− |
| |
− | // Delegate to script
| |
− | return "script";
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // Support: Safari 8 only
| |
− | // In Safari 8 documents created via document.implementation.createHTMLDocument
| |
− | // collapse sibling forms: the second one becomes a child of the first one.
| |
− | // Because of that, this security measure has to be disabled in Safari 8.
| |
− | // https://bugs.webkit.org/show_bug.cgi?id=137337
| |
− | support.createHTMLDocument = ( function() {
| |
− | var body = document.implementation.createHTMLDocument( "" ).body;
| |
− | body.innerHTML = "<form></form><form></form>";
| |
− | return body.childNodes.length === 2;
| |
− | } )();
| |
− |
| |
− |
| |
− | // Argument "data" should be string of html
| |
− | // context (optional): If specified, the fragment will be created in this context,
| |
− | // defaults to document
| |
− | // keepScripts (optional): If true, will include scripts passed in the html string
| |
− | jQuery.parseHTML = function( data, context, keepScripts ) {
| |
− | if ( typeof data !== "string" ) {
| |
− | return [];
| |
− | }
| |
− | if ( typeof context === "boolean" ) {
| |
− | keepScripts = context;
| |
− | context = false;
| |
− | }
| |
− |
| |
− | var base, parsed, scripts;
| |
− |
| |
− | if ( !context ) {
| |
− |
| |
− | // Stop scripts or inline event handlers from being executed immediately
| |
− | // by using document.implementation
| |
− | if ( support.createHTMLDocument ) {
| |
− | context = document.implementation.createHTMLDocument( "" );
| |
− |
| |
− | // Set the base href for the created document
| |
− | // so any parsed elements with URLs
| |
− | // are based on the document's URL (gh-2965)
| |
− | base = context.createElement( "base" );
| |
− | base.href = document.location.href;
| |
− | context.head.appendChild( base );
| |
− | } else {
| |
− | context = document;
| |
− | }
| |
− | }
| |
− |
| |
− | parsed = rsingleTag.exec( data );
| |
− | scripts = !keepScripts && [];
| |
− |
| |
− | // Single tag
| |
− | if ( parsed ) {
| |
− | return [ context.createElement( parsed[ 1 ] ) ];
| |
− | }
| |
− |
| |
− | parsed = buildFragment( [ data ], context, scripts );
| |
− |
| |
− | if ( scripts && scripts.length ) {
| |
− | jQuery( scripts ).remove();
| |
− | }
| |
− |
| |
− | return jQuery.merge( [], parsed.childNodes );
| |
− | };
| |
− |
| |
− |
| |
− | /**
| |
− | * Load a url into a page
| |
− | */
| |
− | jQuery.fn.load = function( url, params, callback ) {
| |
− | var selector, type, response,
| |
− | self = this,
| |
− | off = url.indexOf( " " );
| |
− |
| |
− | if ( off > -1 ) {
| |
− | selector = stripAndCollapse( url.slice( off ) );
| |
− | url = url.slice( 0, off );
| |
− | }
| |
− |
| |
− | // If it's a function
| |
− | if ( isFunction( params ) ) {
| |
− |
| |
− | // We assume that it's the callback
| |
− | callback = params;
| |
− | params = undefined;
| |
− |
| |
− | // Otherwise, build a param string
| |
− | } else if ( params && typeof params === "object" ) {
| |
− | type = "POST";
| |
− | }
| |
− |
| |
− | // If we have elements to modify, make the request
| |
− | if ( self.length > 0 ) {
| |
− | jQuery.ajax( {
| |
− | url: url,
| |
− |
| |
− | // If "type" variable is undefined, then "GET" method will be used.
| |
− | // Make value of this field explicit since
| |
− | // user can override it through ajaxSetup method
| |
− | type: type || "GET",
| |
− | dataType: "html",
| |
− | data: params
| |
− | } ).done( function( responseText ) {
| |
− |
| |
− | // Save response for use in complete callback
| |
− | response = arguments;
| |
− |
| |
− | self.html( selector ?
| |
− |
| |
− | // If a selector was specified, locate the right elements in a dummy div
| |
− | // Exclude scripts to avoid IE 'Permission Denied' errors
| |
− | jQuery( "<div>" ).append( jQuery.parseHTML( responseText ) ).find( selector ) :
| |
− |
| |
− | // Otherwise use the full result
| |
− | responseText );
| |
− |
| |
− | // If the request succeeds, this function gets "data", "status", "jqXHR"
| |
− | // but they are ignored because response was set above.
| |
− | // If it fails, this function gets "jqXHR", "status", "error"
| |
− | } ).always( callback && function( jqXHR, status ) {
| |
− | self.each( function() {
| |
− | callback.apply( this, response || [ jqXHR.responseText, status, jqXHR ] );
| |
− | } );
| |
− | } );
| |
− | }
| |
− |
| |
− | return this;
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // Attach a bunch of functions for handling common AJAX events
| |
− | jQuery.each( [
| |
− | "ajaxStart",
| |
− | "ajaxStop",
| |
− | "ajaxComplete",
| |
− | "ajaxError",
| |
− | "ajaxSuccess",
| |
− | "ajaxSend"
| |
− | ], function( i, type ) {
| |
− | jQuery.fn[ type ] = function( fn ) {
| |
− | return this.on( type, fn );
| |
− | };
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | jQuery.expr.pseudos.animated = function( elem ) {
| |
− | return jQuery.grep( jQuery.timers, function( fn ) {
| |
− | return elem === fn.elem;
| |
− | } ).length;
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | jQuery.offset = {
| |
− | setOffset: function( elem, options, i ) {
| |
− | var curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition,
| |
− | position = jQuery.css( elem, "position" ),
| |
− | curElem = jQuery( elem ),
| |
− | props = {};
| |
− |
| |
− | // Set position first, in-case top/left are set even on static elem
| |
− | if ( position === "static" ) {
| |
− | elem.style.position = "relative";
| |
− | }
| |
− |
| |
− | curOffset = curElem.offset();
| |
− | curCSSTop = jQuery.css( elem, "top" );
| |
− | curCSSLeft = jQuery.css( elem, "left" );
| |
− | calculatePosition = ( position === "absolute" || position === "fixed" ) &&
| |
− | ( curCSSTop + curCSSLeft ).indexOf( "auto" ) > -1;
| |
− |
| |
− | // Need to be able to calculate position if either
| |
− | // top or left is auto and position is either absolute or fixed
| |
− | if ( calculatePosition ) {
| |
− | curPosition = curElem.position();
| |
− | curTop = curPosition.top;
| |
− | curLeft = curPosition.left;
| |
− |
| |
− | } else {
| |
− | curTop = parseFloat( curCSSTop ) || 0;
| |
− | curLeft = parseFloat( curCSSLeft ) || 0;
| |
− | }
| |
− |
| |
− | if ( isFunction( options ) ) {
| |
− |
| |
− | // Use jQuery.extend here to allow modification of coordinates argument (gh-1848)
| |
− | options = options.call( elem, i, jQuery.extend( {}, curOffset ) );
| |
− | }
| |
− |
| |
− | if ( options.top != null ) {
| |
− | props.top = ( options.top - curOffset.top ) + curTop;
| |
− | }
| |
− | if ( options.left != null ) {
| |
− | props.left = ( options.left - curOffset.left ) + curLeft;
| |
− | }
| |
− |
| |
− | if ( "using" in options ) {
| |
− | options.using.call( elem, props );
| |
− |
| |
− | } else {
| |
− | curElem.css( props );
| |
− | }
| |
− | }
| |
− | };
| |
− |
| |
− | jQuery.fn.extend( {
| |
− |
| |
− | // offset() relates an element's border box to the document origin
| |
− | offset: function( options ) {
| |
− |
| |
− | // Preserve chaining for setter
| |
− | if ( arguments.length ) {
| |
− | return options === undefined ?
| |
− | this :
| |
− | this.each( function( i ) {
| |
− | jQuery.offset.setOffset( this, options, i );
| |
− | } );
| |
− | }
| |
− |
| |
− | var rect, win,
| |
− | elem = this[ 0 ];
| |
− |
| |
− | if ( !elem ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | // Return zeros for disconnected and hidden (display: none) elements (gh-2310)
| |
− | // Support: IE <=11 only
| |
− | // Running getBoundingClientRect on a
| |
− | // disconnected node in IE throws an error
| |
− | if ( !elem.getClientRects().length ) {
| |
− | return { top: 0, left: 0 };
| |
− | }
| |
− |
| |
− | // Get document-relative position by adding viewport scroll to viewport-relative gBCR
| |
− | rect = elem.getBoundingClientRect();
| |
− | win = elem.ownerDocument.defaultView;
| |
− | return {
| |
− | top: rect.top + win.pageYOffset,
| |
− | left: rect.left + win.pageXOffset
| |
− | };
| |
− | },
| |
− |
| |
− | // position() relates an element's margin box to its offset parent's padding box
| |
− | // This corresponds to the behavior of CSS absolute positioning
| |
− | position: function() {
| |
− | if ( !this[ 0 ] ) {
| |
− | return;
| |
− | }
| |
− |
| |
− | var offsetParent, offset, doc,
| |
− | elem = this[ 0 ],
| |
− | parentOffset = { top: 0, left: 0 };
| |
− |
| |
− | // position:fixed elements are offset from the viewport, which itself always has zero offset
| |
− | if ( jQuery.css( elem, "position" ) === "fixed" ) {
| |
− |
| |
− | // Assume position:fixed implies availability of getBoundingClientRect
| |
− | offset = elem.getBoundingClientRect();
| |
− |
| |
− | } else {
| |
− | offset = this.offset();
| |
− |
| |
− | // Account for the *real* offset parent, which can be the document or its root element
| |
− | // when a statically positioned element is identified
| |
− | doc = elem.ownerDocument;
| |
− | offsetParent = elem.offsetParent || doc.documentElement;
| |
− | while ( offsetParent &&
| |
− | ( offsetParent === doc.body || offsetParent === doc.documentElement ) &&
| |
− | jQuery.css( offsetParent, "position" ) === "static" ) {
| |
− |
| |
− | offsetParent = offsetParent.parentNode;
| |
− | }
| |
− | if ( offsetParent && offsetParent !== elem && offsetParent.nodeType === 1 ) {
| |
− |
| |
− | // Incorporate borders into its offset, since they are outside its content origin
| |
− | parentOffset = jQuery( offsetParent ).offset();
| |
− | parentOffset.top += jQuery.css( offsetParent, "borderTopWidth", true );
| |
− | parentOffset.left += jQuery.css( offsetParent, "borderLeftWidth", true );
| |
− | }
| |
− | }
| |
− |
| |
− | // Subtract parent offsets and element margins
| |
− | return {
| |
− | top: offset.top - parentOffset.top - jQuery.css( elem, "marginTop", true ),
| |
− | left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true )
| |
− | };
| |
− | },
| |
− |
| |
− | // This method will return documentElement in the following cases:
| |
− | // 1) For the element inside the iframe without offsetParent, this method will return
| |
− | // documentElement of the parent window
| |
− | // 2) For the hidden or detached element
| |
− | // 3) For body or html element, i.e. in case of the html node - it will return itself
| |
− | //
| |
− | // but those exceptions were never presented as a real life use-cases
| |
− | // and might be considered as more preferable results.
| |
− | //
| |
− | // This logic, however, is not guaranteed and can change at any point in the future
| |
− | offsetParent: function() {
| |
− | return this.map( function() {
| |
− | var offsetParent = this.offsetParent;
| |
− |
| |
− | while ( offsetParent && jQuery.css( offsetParent, "position" ) === "static" ) {
| |
− | offsetParent = offsetParent.offsetParent;
| |
− | }
| |
− |
| |
− | return offsetParent || documentElement;
| |
− | } );
| |
− | }
| |
− | } );
| |
− |
| |
− | // Create scrollLeft and scrollTop methods
| |
− | jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( method, prop ) {
| |
− | var top = "pageYOffset" === prop;
| |
− |
| |
− | jQuery.fn[ method ] = function( val ) {
| |
− | return access( this, function( elem, method, val ) {
| |
− |
| |
− | // Coalesce documents and windows
| |
− | var win;
| |
− | if ( isWindow( elem ) ) {
| |
− | win = elem;
| |
− | } else if ( elem.nodeType === 9 ) {
| |
− | win = elem.defaultView;
| |
− | }
| |
− |
| |
− | if ( val === undefined ) {
| |
− | return win ? win[ prop ] : elem[ method ];
| |
− | }
| |
− |
| |
− | if ( win ) {
| |
− | win.scrollTo(
| |
− | !top ? val : win.pageXOffset,
| |
− | top ? val : win.pageYOffset
| |
− | );
| |
− |
| |
− | } else {
| |
− | elem[ method ] = val;
| |
− | }
| |
− | }, method, val, arguments.length );
| |
− | };
| |
− | } );
| |
− |
| |
− | // Support: Safari <=7 - 9.1, Chrome <=37 - 49
| |
− | // Add the top/left cssHooks using jQuery.fn.position
| |
− | // Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084
| |
− | // Blink bug: https://bugs.chromium.org/p/chromium/issues/detail?id=589347
| |
− | // getComputedStyle returns percent when specified for top/left/bottom/right;
| |
− | // rather than make the css module depend on the offset module, just check for it here
| |
− | jQuery.each( [ "top", "left" ], function( i, prop ) {
| |
− | jQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition,
| |
− | function( elem, computed ) {
| |
− | if ( computed ) {
| |
− | computed = curCSS( elem, prop );
| |
− |
| |
− | // If curCSS returns percentage, fallback to offset
| |
− | return rnumnonpx.test( computed ) ?
| |
− | jQuery( elem ).position()[ prop ] + "px" :
| |
− | computed;
| |
− | }
| |
− | }
| |
− | );
| |
− | } );
| |
− |
| |
− |
| |
− | // Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods
| |
− | jQuery.each( { Height: "height", Width: "width" }, function( name, type ) {
| |
− | jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name },
| |
− | function( defaultExtra, funcName ) {
| |
− |
| |
− | // Margin is only for outerHeight, outerWidth
| |
− | jQuery.fn[ funcName ] = function( margin, value ) {
| |
− | var chainable = arguments.length && ( defaultExtra || typeof margin !== "boolean" ),
| |
− | extra = defaultExtra || ( margin === true || value === true ? "margin" : "border" );
| |
− |
| |
− | return access( this, function( elem, type, value ) {
| |
− | var doc;
| |
− |
| |
− | if ( isWindow( elem ) ) {
| |
− |
| |
− | // $( window ).outerWidth/Height return w/h including scrollbars (gh-1729)
| |
− | return funcName.indexOf( "outer" ) === 0 ?
| |
− | elem[ "inner" + name ] :
| |
− | elem.document.documentElement[ "client" + name ];
| |
− | }
| |
− |
| |
− | // Get document width or height
| |
− | if ( elem.nodeType === 9 ) {
| |
− | doc = elem.documentElement;
| |
− |
| |
− | // Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height],
| |
− | // whichever is greatest
| |
− | return Math.max(
| |
− | elem.body[ "scroll" + name ], doc[ "scroll" + name ],
| |
− | elem.body[ "offset" + name ], doc[ "offset" + name ],
| |
− | doc[ "client" + name ]
| |
− | );
| |
− | }
| |
− |
| |
− | return value === undefined ?
| |
− |
| |
− | // Get width or height on the element, requesting but not forcing parseFloat
| |
− | jQuery.css( elem, type, extra ) :
| |
− |
| |
− | // Set width or height on the element
| |
− | jQuery.style( elem, type, value, extra );
| |
− | }, type, chainable ? margin : undefined, chainable );
| |
− | };
| |
− | } );
| |
− | } );
| |
− |
| |
− |
| |
− | jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " +
| |
− | "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +
| |
− | "change select submit keydown keypress keyup contextmenu" ).split( " " ),
| |
− | function( i, name ) {
| |
− |
| |
− | // Handle event binding
| |
− | jQuery.fn[ name ] = function( data, fn ) {
| |
− | return arguments.length > 0 ?
| |
− | this.on( name, null, data, fn ) :
| |
− | this.trigger( name );
| |
− | };
| |
− | } );
| |
− |
| |
− | jQuery.fn.extend( {
| |
− | hover: function( fnOver, fnOut ) {
| |
− | return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver );
| |
− | }
| |
− | } );
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | jQuery.fn.extend( {
| |
− |
| |
− | 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 );
| |
− | }
| |
− | } );
| |
− |
| |
− | // Bind a function to a context, optionally partially applying any
| |
− | // arguments.
| |
− | // jQuery.proxy is deprecated to promote standards (specifically Function#bind)
| |
− | // However, it is not slated for removal any time soon
| |
− | jQuery.proxy = function( fn, context ) {
| |
− | var tmp, args, proxy;
| |
− |
| |
− | if ( typeof context === "string" ) {
| |
− | tmp = fn[ context ];
| |
− | context = fn;
| |
− | fn = tmp;
| |
− | }
| |
− |
| |
− | // Quick check to determine if target is callable, in the spec
| |
− | // this throws a TypeError, but we will just return undefined.
| |
− | if ( !isFunction( fn ) ) {
| |
− | return undefined;
| |
− | }
| |
− |
| |
− | // Simulated bind
| |
− | args = slice.call( arguments, 2 );
| |
− | proxy = function() {
| |
− | return fn.apply( context || this, args.concat( slice.call( arguments ) ) );
| |
− | };
| |
− |
| |
− | // Set the guid of unique handler to the same of original handler, so it can be removed
| |
− | proxy.guid = fn.guid = fn.guid || jQuery.guid++;
| |
− |
| |
− | return proxy;
| |
− | };
| |
− |
| |
− | jQuery.holdReady = function( hold ) {
| |
− | if ( hold ) {
| |
− | jQuery.readyWait++;
| |
− | } else {
| |
− | jQuery.ready( true );
| |
− | }
| |
− | };
| |
− | jQuery.isArray = Array.isArray;
| |
− | jQuery.parseJSON = JSON.parse;
| |
− | jQuery.nodeName = nodeName;
| |
− | jQuery.isFunction = isFunction;
| |
− | jQuery.isWindow = isWindow;
| |
− | jQuery.camelCase = camelCase;
| |
− | jQuery.type = toType;
| |
− |
| |
− | jQuery.now = Date.now;
| |
− |
| |
− | jQuery.isNumeric = function( obj ) {
| |
− |
| |
− | // As of jQuery 3.0, isNumeric is limited to
| |
− | // strings and numbers (primitives or objects)
| |
− | // that can be coerced to finite numbers (gh-2662)
| |
− | var type = jQuery.type( obj );
| |
− | return ( type === "number" || type === "string" ) &&
| |
− |
| |
− | // parseFloat NaNs numeric-cast false positives ("")
| |
− | // ...but misinterprets leading-number strings, particularly hex literals ("0x...")
| |
− | // subtraction forces infinities to NaN
| |
− | !isNaN( obj - parseFloat( obj ) );
| |
− | };
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | // 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.
| |
− |
| |
− | // Note that for maximum portability, libraries that are not jQuery should
| |
− | // declare themselves as anonymous modules, and avoid setting a global if an
| |
− | // AMD loader is present. jQuery is a special case. For more information, see
| |
− | // https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon
| |
− |
| |
− | if ( typeof define === "function" && define.amd ) {
| |
− | define( "jquery", [], function() {
| |
− | return jQuery;
| |
− | } );
| |
− | }
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | var
| |
− |
| |
− | // Map over jQuery in case of overwrite
| |
− | _jQuery = window.jQuery,
| |
− |
| |
− | // Map over the $ in case of overwrite
| |
− | _$ = window.$;
| |
− |
| |
− | jQuery.noConflict = function( deep ) {
| |
− | if ( window.$ === jQuery ) {
| |
− | window.$ = _$;
| |
− | }
| |
− |
| |
− | if ( deep && window.jQuery === jQuery ) {
| |
− | window.jQuery = _jQuery;
| |
− | }
| |
− |
| |
− | return jQuery;
| |
− | };
| |
− |
| |
− | // Expose jQuery and $ identifiers, even in AMD
| |
− | // (#7102#comment:10, https://github.com/jquery/jquery/pull/557)
| |
− | // and CommonJS for browser emulators (#13566)
| |
− | if ( !noGlobal ) {
| |
− | window.jQuery = window.$ = jQuery;
| |
− | }
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | return jQuery;
| |
− | } );
| |
− | </script>
| |
− |
| |
− |
| |
− |
| |
− |
| |
− | <script type="text/javascript" >
| |
− | /*!
| |
− | * Bootstrap v4.0.0 (https://getbootstrap.com)
| |
− | * Copyright 2011-2018 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
| |
− | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
| |
− | */
| |
− | !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("jquery"),require("popper.js")):"function"==typeof define&&define.amd?define(["exports","jquery","popper.js"],e):e(t.bootstrap={},t.jQuery,t.Popper)}(this,function(t,e,n){"use strict";function i(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function s(t,e,n){return e&&i(t.prototype,e),n&&i(t,n),t}function r(){return(r=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var i in n)Object.prototype.hasOwnProperty.call(n,i)&&(t[i]=n[i])}return t}).apply(this,arguments)}e=e&&e.hasOwnProperty("default")?e.default:e,n=n&&n.hasOwnProperty("default")?n.default:n;var o,a,l,h,c,u,f,d,_,g,p,m,v,E,T,y,C,I,A,b,D,S,w,N,O,k,P=function(t){var e=!1;function n(e){var n=this,s=!1;return t(this).one(i.TRANSITION_END,function(){s=!0}),setTimeout(function(){s||i.triggerTransitionEnd(n)},e),this}var i={TRANSITION_END:"bsTransitionEnd",getUID:function(t){do{t+=~~(1e6*Math.random())}while(document.getElementById(t));return t},getSelectorFromElement:function(e){var n,i=e.getAttribute("data-target");i&&"#"!==i||(i=e.getAttribute("href")||""),"#"===i.charAt(0)&&(n=i,i=n="function"==typeof t.escapeSelector?t.escapeSelector(n).substr(1):n.replace(/(:|\.|\[|\]|,|=|@)/g,"\\$1"));try{return t(document).find(i).length>0?i:null}catch(t){return null}},reflow:function(t){return t.offsetHeight},triggerTransitionEnd:function(n){t(n).trigger(e.end)},supportsTransitionEnd:function(){return Boolean(e)},isElement:function(t){return(t[0]||t).nodeType},typeCheckConfig:function(t,e,n){for(var s in n)if(Object.prototype.hasOwnProperty.call(n,s)){var r=n[s],o=e[s],a=o&&i.isElement(o)?"element":(l=o,{}.toString.call(l).match(/\s([a-zA-Z]+)/)[1].toLowerCase());if(!new RegExp(r).test(a))throw new Error(t.toUpperCase()+': Option "'+s+'" provided type "'+a+'" but expected type "'+r+'".')}var l}};return e=("undefined"==typeof window||!window.QUnit)&&{end:"transitionend"},t.fn.emulateTransitionEnd=n,i.supportsTransitionEnd()&&(t.event.special[i.TRANSITION_END]={bindType:e.end,delegateType:e.end,handle:function(e){if(t(e.target).is(this))return e.handleObj.handler.apply(this,arguments)}}),i}(e),L=(a="alert",h="."+(l="bs.alert"),c=(o=e).fn[a],u={CLOSE:"close"+h,CLOSED:"closed"+h,CLICK_DATA_API:"click"+h+".data-api"},f="alert",d="fade",_="show",g=function(){function t(t){this._element=t}var e=t.prototype;return e.close=function(t){t=t||this._element;var e=this._getRootElement(t);this._triggerCloseEvent(e).isDefaultPrevented()||this._removeElement(e)},e.dispose=function(){o.removeData(this._element,l),this._element=null},e._getRootElement=function(t){var e=P.getSelectorFromElement(t),n=!1;return e&&(n=o(e)[0]),n||(n=o(t).closest("."+f)[0]),n},e._triggerCloseEvent=function(t){var e=o.Event(u.CLOSE);return o(t).trigger(e),e},e._removeElement=function(t){var e=this;o(t).removeClass(_),P.supportsTransitionEnd()&&o(t).hasClass(d)?o(t).one(P.TRANSITION_END,function(n){return e._destroyElement(t,n)}).emulateTransitionEnd(150):this._destroyElement(t)},e._destroyElement=function(t){o(t).detach().trigger(u.CLOSED).remove()},t._jQueryInterface=function(e){return this.each(function(){var n=o(this),i=n.data(l);i||(i=new t(this),n.data(l,i)),"close"===e&&i[e](this)})},t._handleDismiss=function(t){return function(e){e&&e.preventDefault(),t.close(this)}},s(t,null,[{key:"VERSION",get:function(){return"4.0.0"}}]),t}(),o(document).on(u.CLICK_DATA_API,'[data-dismiss="alert"]',g._handleDismiss(new g)),o.fn[a]=g._jQueryInterface,o.fn[a].Constructor=g,o.fn[a].noConflict=function(){return o.fn[a]=c,g._jQueryInterface},g),R=(m="button",E="."+(v="bs.button"),T=".data-api",y=(p=e).fn[m],C="active",I="btn",A="focus",b='[data-toggle^="button"]',D='[data-toggle="buttons"]',S="input",w=".active",N=".btn",O={CLICK_DATA_API:"click"+E+T,FOCUS_BLUR_DATA_API:"focus"+E+T+" blur"+E+T},k=function(){function t(t){this._element=t}var e=t.prototype;return e.toggle=function(){var t=!0,e=!0,n=p(this._element).closest(D)[0];if(n){var i=p(this._element).find(S)[0];if(i){if("radio"===i.type)if(i.checked&&p(this._element).hasClass(C))t=!1;else{var s=p(n).find(w)[0];s&&p(s).removeClass(C)}if(t){if(i.hasAttribute("disabled")||n.hasAttribute("disabled")||i.classList.contains("disabled")||n.classList.contains("disabled"))return;i.checked=!p(this._element).hasClass(C),p(i).trigger("change")}i.focus(),e=!1}}e&&this._element.setAttribute("aria-pressed",!p(this._element).hasClass(C)),t&&p(this._element).toggleClass(C)},e.dispose=function(){p.removeData(this._element,v),this._element=null},t._jQueryInterface=function(e){return this.each(function(){var n=p(this).data(v);n||(n=new t(this),p(this).data(v,n)),"toggle"===e&&n[e]()})},s(t,null,[{key:"VERSION",get:function(){return"4.0.0"}}]),t}(),p(document).on(O.CLICK_DATA_API,b,function(t){t.preventDefault();var e=t.target;p(e).hasClass(I)||(e=p(e).closest(N)),k._jQueryInterface.call(p(e),"toggle")}).on(O.FOCUS_BLUR_DATA_API,b,function(t){var e=p(t.target).closest(N)[0];p(e).toggleClass(A,/^focus(in)?$/.test(t.type))}),p.fn[m]=k._jQueryInterface,p.fn[m].Constructor=k,p.fn[m].noConflict=function(){return p.fn[m]=y,k._jQueryInterface},k),j=function(t){var e="carousel",n="bs.carousel",i="."+n,o=t.fn[e],a={interval:5e3,keyboard:!0,slide:!1,pause:"hover",wrap:!0},l={interval:"(number|boolean)",keyboard:"boolean",slide:"(boolean|string)",pause:"(string|boolean)",wrap:"boolean"},h="next",c="prev",u="left",f="right",d={SLIDE:"slide"+i,SLID:"slid"+i,KEYDOWN:"keydown"+i,MOUSEENTER:"mouseenter"+i,MOUSELEAVE:"mouseleave"+i,TOUCHEND:"touchend"+i,LOAD_DATA_API:"load"+i+".data-api",CLICK_DATA_API:"click"+i+".data-api"},_="carousel",g="active",p="slide",m="carousel-item-right",v="carousel-item-left",E="carousel-item-next",T="carousel-item-prev",y={ACTIVE:".active",ACTIVE_ITEM:".active.carousel-item",ITEM:".carousel-item",NEXT_PREV:".carousel-item-next, .carousel-item-prev",INDICATORS:".carousel-indicators",DATA_SLIDE:"[data-slide], [data-slide-to]",DATA_RIDE:'[data-ride="carousel"]'},C=function(){function o(e,n){this._items=null,this._interval=null,this._activeElement=null,this._isPaused=!1,this._isSliding=!1,this.touchTimeout=null,this._config=this._getConfig(n),this._element=t(e)[0],this._indicatorsElement=t(this._element).find(y.INDICATORS)[0],this._addEventListeners()}var C=o.prototype;return C.next=function(){this._isSliding||this._slide(h)},C.nextWhenVisible=function(){!document.hidden&&t(this._element).is(":visible")&&"hidden"!==t(this._element).css("visibility")&&this.next()},C.prev=function(){this._isSliding||this._slide(c)},C.pause=function(e){e||(this._isPaused=!0),t(this._element).find(y.NEXT_PREV)[0]&&P.supportsTransitionEnd()&&(P.triggerTransitionEnd(this._element),this.cycle(!0)),clearInterval(this._interval),this._interval=null},C.cycle=function(t){t||(this._isPaused=!1),this._interval&&(clearInterval(this._interval),this._interval=null),this._config.interval&&!this._isPaused&&(this._interval=setInterval((document.visibilityState?this.nextWhenVisible:this.next).bind(this),this._config.interval))},C.to=function(e){var n=this;this._activeElement=t(this._element).find(y.ACTIVE_ITEM)[0];var i=this._getItemIndex(this._activeElement);if(!(e>this._items.length-1||e<0))if(this._isSliding)t(this._element).one(d.SLID,function(){return n.to(e)});else{if(i===e)return this.pause(),void this.cycle();var s=e>i?h:c;this._slide(s,this._items[e])}},C.dispose=function(){t(this._element).off(i),t.removeData(this._element,n),this._items=null,this._config=null,this._element=null,this._interval=null,this._isPaused=null,this._isSliding=null,this._activeElement=null,this._indicatorsElement=null},C._getConfig=function(t){return t=r({},a,t),P.typeCheckConfig(e,t,l),t},C._addEventListeners=function(){var e=this;this._config.keyboard&&t(this._element).on(d.KEYDOWN,function(t){return e._keydown(t)}),"hover"===this._config.pause&&(t(this._element).on(d.MOUSEENTER,function(t){return e.pause(t)}).on(d.MOUSELEAVE,function(t){return e.cycle(t)}),"ontouchstart"in document.documentElement&&t(this._element).on(d.TOUCHEND,function(){e.pause(),e.touchTimeout&&clearTimeout(e.touchTimeout),e.touchTimeout=setTimeout(function(t){return e.cycle(t)},500+e._config.interval)}))},C._keydown=function(t){if(!/input|textarea/i.test(t.target.tagName))switch(t.which){case 37:t.preventDefault(),this.prev();break;case 39:t.preventDefault(),this.next()}},C._getItemIndex=function(e){return this._items=t.makeArray(t(e).parent().find(y.ITEM)),this._items.indexOf(e)},C._getItemByDirection=function(t,e){var n=t===h,i=t===c,s=this._getItemIndex(e),r=this._items.length-1;if((i&&0===s||n&&s===r)&&!this._config.wrap)return e;var o=(s+(t===c?-1:1))%this._items.length;return-1===o?this._items[this._items.length-1]:this._items[o]},C._triggerSlideEvent=function(e,n){var i=this._getItemIndex(e),s=this._getItemIndex(t(this._element).find(y.ACTIVE_ITEM)[0]),r=t.Event(d.SLIDE,{relatedTarget:e,direction:n,from:s,to:i});return t(this._element).trigger(r),r},C._setActiveIndicatorElement=function(e){if(this._indicatorsElement){t(this._indicatorsElement).find(y.ACTIVE).removeClass(g);var n=this._indicatorsElement.children[this._getItemIndex(e)];n&&t(n).addClass(g)}},C._slide=function(e,n){var i,s,r,o=this,a=t(this._element).find(y.ACTIVE_ITEM)[0],l=this._getItemIndex(a),c=n||a&&this._getItemByDirection(e,a),_=this._getItemIndex(c),C=Boolean(this._interval);if(e===h?(i=v,s=E,r=u):(i=m,s=T,r=f),c&&t(c).hasClass(g))this._isSliding=!1;else if(!this._triggerSlideEvent(c,r).isDefaultPrevented()&&a&&c){this._isSliding=!0,C&&this.pause(),this._setActiveIndicatorElement(c);var I=t.Event(d.SLID,{relatedTarget:c,direction:r,from:l,to:_});P.supportsTransitionEnd()&&t(this._element).hasClass(p)?(t(c).addClass(s),P.reflow(c),t(a).addClass(i),t(c).addClass(i),t(a).one(P.TRANSITION_END,function(){t(c).removeClass(i+" "+s).addClass(g),t(a).removeClass(g+" "+s+" "+i),o._isSliding=!1,setTimeout(function(){return t(o._element).trigger(I)},0)}).emulateTransitionEnd(600)):(t(a).removeClass(g),t(c).addClass(g),this._isSliding=!1,t(this._element).trigger(I)),C&&this.cycle()}},o._jQueryInterface=function(e){return this.each(function(){var i=t(this).data(n),s=r({},a,t(this).data());"object"==typeof e&&(s=r({},s,e));var l="string"==typeof e?e:s.slide;if(i||(i=new o(this,s),t(this).data(n,i)),"number"==typeof e)i.to(e);else if("string"==typeof l){if("undefined"==typeof i[l])throw new TypeError('No method named "'+l+'"');i[l]()}else s.interval&&(i.pause(),i.cycle())})},o._dataApiClickHandler=function(e){var i=P.getSelectorFromElement(this);if(i){var s=t(i)[0];if(s&&t(s).hasClass(_)){var a=r({},t(s).data(),t(this).data()),l=this.getAttribute("data-slide-to");l&&(a.interval=!1),o._jQueryInterface.call(t(s),a),l&&t(s).data(n).to(l),e.preventDefault()}}},s(o,null,[{key:"VERSION",get:function(){return"4.0.0"}},{key:"Default",get:function(){return a}}]),o}();return t(document).on(d.CLICK_DATA_API,y.DATA_SLIDE,C._dataApiClickHandler),t(window).on(d.LOAD_DATA_API,function(){t(y.DATA_RIDE).each(function(){var e=t(this);C._jQueryInterface.call(e,e.data())})}),t.fn[e]=C._jQueryInterface,t.fn[e].Constructor=C,t.fn[e].noConflict=function(){return t.fn[e]=o,C._jQueryInterface},C}(e),H=function(t){var e="collapse",n="bs.collapse",i="."+n,o=t.fn[e],a={toggle:!0,parent:""},l={toggle:"boolean",parent:"(string|element)"},h={SHOW:"show"+i,SHOWN:"shown"+i,HIDE:"hide"+i,HIDDEN:"hidden"+i,CLICK_DATA_API:"click"+i+".data-api"},c="show",u="collapse",f="collapsing",d="collapsed",_="width",g="height",p={ACTIVES:".show, .collapsing",DATA_TOGGLE:'[data-toggle="collapse"]'},m=function(){function i(e,n){this._isTransitioning=!1,this._element=e,this._config=this._getConfig(n),this._triggerArray=t.makeArray(t('[data-toggle="collapse"][href="#'+e.id+'"],[data-toggle="collapse"][data-target="#'+e.id+'"]'));for(var i=t(p.DATA_TOGGLE),s=0;s<i.length;s++){var r=i[s],o=P.getSelectorFromElement(r);null!==o&&t(o).filter(e).length>0&&(this._selector=o,this._triggerArray.push(r))}this._parent=this._config.parent?this._getParent():null,this._config.parent||this._addAriaAndCollapsedClass(this._element,this._triggerArray),this._config.toggle&&this.toggle()}var o=i.prototype;return o.toggle=function(){t(this._element).hasClass(c)?this.hide():this.show()},o.show=function(){var e,s,r=this;if(!this._isTransitioning&&!t(this._element).hasClass(c)&&(this._parent&&0===(e=t.makeArray(t(this._parent).find(p.ACTIVES).filter('[data-parent="'+this._config.parent+'"]'))).length&&(e=null),!(e&&(s=t(e).not(this._selector).data(n))&&s._isTransitioning))){var o=t.Event(h.SHOW);if(t(this._element).trigger(o),!o.isDefaultPrevented()){e&&(i._jQueryInterface.call(t(e).not(this._selector),"hide"),s||t(e).data(n,null));var a=this._getDimension();t(this._element).removeClass(u).addClass(f),this._element.style[a]=0,this._triggerArray.length>0&&t(this._triggerArray).removeClass(d).attr("aria-expanded",!0),this.setTransitioning(!0);var l=function(){t(r._element).removeClass(f).addClass(u).addClass(c),r._element.style[a]="",r.setTransitioning(!1),t(r._element).trigger(h.SHOWN)};if(P.supportsTransitionEnd()){var _="scroll"+(a[0].toUpperCase()+a.slice(1));t(this._element).one(P.TRANSITION_END,l).emulateTransitionEnd(600),this._element.style[a]=this._element[_]+"px"}else l()}}},o.hide=function(){var e=this;if(!this._isTransitioning&&t(this._element).hasClass(c)){var n=t.Event(h.HIDE);if(t(this._element).trigger(n),!n.isDefaultPrevented()){var i=this._getDimension();if(this._element.style[i]=this._element.getBoundingClientRect()[i]+"px",P.reflow(this._element),t(this._element).addClass(f).removeClass(u).removeClass(c),this._triggerArray.length>0)for(var s=0;s<this._triggerArray.length;s++){var r=this._triggerArray[s],o=P.getSelectorFromElement(r);if(null!==o)t(o).hasClass(c)||t(r).addClass(d).attr("aria-expanded",!1)}this.setTransitioning(!0);var a=function(){e.setTransitioning(!1),t(e._element).removeClass(f).addClass(u).trigger(h.HIDDEN)};this._element.style[i]="",P.supportsTransitionEnd()?t(this._element).one(P.TRANSITION_END,a).emulateTransitionEnd(600):a()}}},o.setTransitioning=function(t){this._isTransitioning=t},o.dispose=function(){t.removeData(this._element,n),this._config=null,this._parent=null,this._element=null,this._triggerArray=null,this._isTransitioning=null},o._getConfig=function(t){return(t=r({},a,t)).toggle=Boolean(t.toggle),P.typeCheckConfig(e,t,l),t},o._getDimension=function(){return t(this._element).hasClass(_)?_:g},o._getParent=function(){var e=this,n=null;P.isElement(this._config.parent)?(n=this._config.parent,"undefined"!=typeof this._config.parent.jquery&&(n=this._config.parent[0])):n=t(this._config.parent)[0];var s='[data-toggle="collapse"][data-parent="'+this._config.parent+'"]';return t(n).find(s).each(function(t,n){e._addAriaAndCollapsedClass(i._getTargetFromElement(n),[n])}),n},o._addAriaAndCollapsedClass=function(e,n){if(e){var i=t(e).hasClass(c);n.length>0&&t(n).toggleClass(d,!i).attr("aria-expanded",i)}},i._getTargetFromElement=function(e){var n=P.getSelectorFromElement(e);return n?t(n)[0]:null},i._jQueryInterface=function(e){return this.each(function(){var s=t(this),o=s.data(n),l=r({},a,s.data(),"object"==typeof e&&e);if(!o&&l.toggle&&/show|hide/.test(e)&&(l.toggle=!1),o||(o=new i(this,l),s.data(n,o)),"string"==typeof e){if("undefined"==typeof o[e])throw new TypeError('No method named "'+e+'"');o[e]()}})},s(i,null,[{key:"VERSION",get:function(){return"4.0.0"}},{key:"Default",get:function(){return a}}]),i}();return t(document).on(h.CLICK_DATA_API,p.DATA_TOGGLE,function(e){"A"===e.currentTarget.tagName&&e.preventDefault();var i=t(this),s=P.getSelectorFromElement(this);t(s).each(function(){var e=t(this),s=e.data(n)?"toggle":i.data();m._jQueryInterface.call(e,s)})}),t.fn[e]=m._jQueryInterface,t.fn[e].Constructor=m,t.fn[e].noConflict=function(){return t.fn[e]=o,m._jQueryInterface},m}(e),W=function(t){var e="dropdown",i="bs.dropdown",o="."+i,a=".data-api",l=t.fn[e],h=new RegExp("38|40|27"),c={HIDE:"hide"+o,HIDDEN:"hidden"+o,SHOW:"show"+o,SHOWN:"shown"+o,CLICK:"click"+o,CLICK_DATA_API:"click"+o+a,KEYDOWN_DATA_API:"keydown"+o+a,KEYUP_DATA_API:"keyup"+o+a},u="disabled",f="show",d="dropup",_="dropright",g="dropleft",p="dropdown-menu-right",m="dropdown-menu-left",v="position-static",E='[data-toggle="dropdown"]',T=".dropdown form",y=".dropdown-menu",C=".navbar-nav",I=".dropdown-menu .dropdown-item:not(.disabled)",A="top-start",b="top-end",D="bottom-start",S="bottom-end",w="right-start",N="left-start",O={offset:0,flip:!0,boundary:"scrollParent"},k={offset:"(number|string|function)",flip:"boolean",boundary:"(string|element)"},L=function(){function a(t,e){this._element=t,this._popper=null,this._config=this._getConfig(e),this._menu=this._getMenuElement(),this._inNavbar=this._detectNavbar(),this._addEventListeners()}var l=a.prototype;return l.toggle=function(){if(!this._element.disabled&&!t(this._element).hasClass(u)){var e=a._getParentFromElement(this._element),i=t(this._menu).hasClass(f);if(a._clearMenus(),!i){var s={relatedTarget:this._element},r=t.Event(c.SHOW,s);if(t(e).trigger(r),!r.isDefaultPrevented()){if(!this._inNavbar){if("undefined"==typeof n)throw new TypeError("Bootstrap dropdown require Popper.js (https://popper.js.org)");var o=this._element;t(e).hasClass(d)&&(t(this._menu).hasClass(m)||t(this._menu).hasClass(p))&&(o=e),"scrollParent"!==this._config.boundary&&t(e).addClass(v),this._popper=new n(o,this._menu,this._getPopperConfig())}"ontouchstart"in document.documentElement&&0===t(e).closest(C).length&&t("body").children().on("mouseover",null,t.noop),this._element.focus(),this._element.setAttribute("aria-expanded",!0),t(this._menu).toggleClass(f),t(e).toggleClass(f).trigger(t.Event(c.SHOWN,s))}}}},l.dispose=function(){t.removeData(this._element,i),t(this._element).off(o),this._element=null,this._menu=null,null!==this._popper&&(this._popper.destroy(),this._popper=null)},l.update=function(){this._inNavbar=this._detectNavbar(),null!==this._popper&&this._popper.scheduleUpdate()},l._addEventListeners=function(){var e=this;t(this._element).on(c.CLICK,function(t){t.preventDefault(),t.stopPropagation(),e.toggle()})},l._getConfig=function(n){return n=r({},this.constructor.Default,t(this._element).data(),n),P.typeCheckConfig(e,n,this.constructor.DefaultType),n},l._getMenuElement=function(){if(!this._menu){var e=a._getParentFromElement(this._element);this._menu=t(e).find(y)[0]}return this._menu},l._getPlacement=function(){var e=t(this._element).parent(),n=D;return e.hasClass(d)?(n=A,t(this._menu).hasClass(p)&&(n=b)):e.hasClass(_)?n=w:e.hasClass(g)?n=N:t(this._menu).hasClass(p)&&(n=S),n},l._detectNavbar=function(){return t(this._element).closest(".navbar").length>0},l._getPopperConfig=function(){var t=this,e={};return"function"==typeof this._config.offset?e.fn=function(e){return e.offsets=r({},e.offsets,t._config.offset(e.offsets)||{}),e}:e.offset=this._config.offset,{placement:this._getPlacement(),modifiers:{offset:e,flip:{enabled:this._config.flip},preventOverflow:{boundariesElement:this._config.boundary}}}},a._jQueryInterface=function(e){return this.each(function(){var n=t(this).data(i);if(n||(n=new a(this,"object"==typeof e?e:null),t(this).data(i,n)),"string"==typeof e){if("undefined"==typeof n[e])throw new TypeError('No method named "'+e+'"');n[e]()}})},a._clearMenus=function(e){if(!e||3!==e.which&&("keyup"!==e.type||9===e.which))for(var n=t.makeArray(t(E)),s=0;s<n.length;s++){var r=a._getParentFromElement(n[s]),o=t(n[s]).data(i),l={relatedTarget:n[s]};if(o){var h=o._menu;if(t(r).hasClass(f)&&!(e&&("click"===e.type&&/input|textarea/i.test(e.target.tagName)||"keyup"===e.type&&9===e.which)&&t.contains(r,e.target))){var u=t.Event(c.HIDE,l);t(r).trigger(u),u.isDefaultPrevented()||("ontouchstart"in document.documentElement&&t("body").children().off("mouseover",null,t.noop),n[s].setAttribute("aria-expanded","false"),t(h).removeClass(f),t(r).removeClass(f).trigger(t.Event(c.HIDDEN,l)))}}}},a._getParentFromElement=function(e){var n,i=P.getSelectorFromElement(e);return i&&(n=t(i)[0]),n||e.parentNode},a._dataApiKeydownHandler=function(e){if((/input|textarea/i.test(e.target.tagName)?!(32===e.which||27!==e.which&&(40!==e.which&&38!==e.which||t(e.target).closest(y).length)):h.test(e.which))&&(e.preventDefault(),e.stopPropagation(),!this.disabled&&!t(this).hasClass(u))){var n=a._getParentFromElement(this),i=t(n).hasClass(f);if((i||27===e.which&&32===e.which)&&(!i||27!==e.which&&32!==e.which)){var s=t(n).find(I).get();if(0!==s.length){var r=s.indexOf(e.target);38===e.which&&r>0&&r--,40===e.which&&r<s.length-1&&r++,r<0&&(r=0),s[r].focus()}}else{if(27===e.which){var o=t(n).find(E)[0];t(o).trigger("focus")}t(this).trigger("click")}}},s(a,null,[{key:"VERSION",get:function(){return"4.0.0"}},{key:"Default",get:function(){return O}},{key:"DefaultType",get:function(){return k}}]),a}();return t(document).on(c.KEYDOWN_DATA_API,E,L._dataApiKeydownHandler).on(c.KEYDOWN_DATA_API,y,L._dataApiKeydownHandler).on(c.CLICK_DATA_API+" "+c.KEYUP_DATA_API,L._clearMenus).on(c.CLICK_DATA_API,E,function(e){e.preventDefault(),e.stopPropagation(),L._jQueryInterface.call(t(this),"toggle")}).on(c.CLICK_DATA_API,T,function(t){t.stopPropagation()}),t.fn[e]=L._jQueryInterface,t.fn[e].Constructor=L,t.fn[e].noConflict=function(){return t.fn[e]=l,L._jQueryInterface},L}(e),M=function(t){var e="modal",n="bs.modal",i="."+n,o=t.fn.modal,a={backdrop:!0,keyboard:!0,focus:!0,show:!0},l={backdrop:"(boolean|string)",keyboard:"boolean",focus:"boolean",show:"boolean"},h={HIDE:"hide"+i,HIDDEN:"hidden"+i,SHOW:"show"+i,SHOWN:"shown"+i,FOCUSIN:"focusin"+i,RESIZE:"resize"+i,CLICK_DISMISS:"click.dismiss"+i,KEYDOWN_DISMISS:"keydown.dismiss"+i,MOUSEUP_DISMISS:"mouseup.dismiss"+i,MOUSEDOWN_DISMISS:"mousedown.dismiss"+i,CLICK_DATA_API:"click"+i+".data-api"},c="modal-scrollbar-measure",u="modal-backdrop",f="modal-open",d="fade",_="show",g={DIALOG:".modal-dialog",DATA_TOGGLE:'[data-toggle="modal"]',DATA_DISMISS:'[data-dismiss="modal"]',FIXED_CONTENT:".fixed-top, .fixed-bottom, .is-fixed, .sticky-top",STICKY_CONTENT:".sticky-top",NAVBAR_TOGGLER:".navbar-toggler"},p=function(){function o(e,n){this._config=this._getConfig(n),this._element=e,this._dialog=t(e).find(g.DIALOG)[0],this._backdrop=null,this._isShown=!1,this._isBodyOverflowing=!1,this._ignoreBackdropClick=!1,this._originalBodyPadding=0,this._scrollbarWidth=0}var p=o.prototype;return p.toggle=function(t){return this._isShown?this.hide():this.show(t)},p.show=function(e){var n=this;if(!this._isTransitioning&&!this._isShown){P.supportsTransitionEnd()&&t(this._element).hasClass(d)&&(this._isTransitioning=!0);var i=t.Event(h.SHOW,{relatedTarget:e});t(this._element).trigger(i),this._isShown||i.isDefaultPrevented()||(this._isShown=!0,this._checkScrollbar(),this._setScrollbar(),this._adjustDialog(),t(document.body).addClass(f),this._setEscapeEvent(),this._setResizeEvent(),t(this._element).on(h.CLICK_DISMISS,g.DATA_DISMISS,function(t){return n.hide(t)}),t(this._dialog).on(h.MOUSEDOWN_DISMISS,function(){t(n._element).one(h.MOUSEUP_DISMISS,function(e){t(e.target).is(n._element)&&(n._ignoreBackdropClick=!0)})}),this._showBackdrop(function(){return n._showElement(e)}))}},p.hide=function(e){var n=this;if(e&&e.preventDefault(),!this._isTransitioning&&this._isShown){var i=t.Event(h.HIDE);if(t(this._element).trigger(i),this._isShown&&!i.isDefaultPrevented()){this._isShown=!1;var s=P.supportsTransitionEnd()&&t(this._element).hasClass(d);s&&(this._isTransitioning=!0),this._setEscapeEvent(),this._setResizeEvent(),t(document).off(h.FOCUSIN),t(this._element).removeClass(_),t(this._element).off(h.CLICK_DISMISS),t(this._dialog).off(h.MOUSEDOWN_DISMISS),s?t(this._element).one(P.TRANSITION_END,function(t){return n._hideModal(t)}).emulateTransitionEnd(300):this._hideModal()}}},p.dispose=function(){t.removeData(this._element,n),t(window,document,this._element,this._backdrop).off(i),this._config=null,this._element=null,this._dialog=null,this._backdrop=null,this._isShown=null,this._isBodyOverflowing=null,this._ignoreBackdropClick=null,this._scrollbarWidth=null},p.handleUpdate=function(){this._adjustDialog()},p._getConfig=function(t){return t=r({},a,t),P.typeCheckConfig(e,t,l),t},p._showElement=function(e){var n=this,i=P.supportsTransitionEnd()&&t(this._element).hasClass(d);this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE||document.body.appendChild(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.scrollTop=0,i&&P.reflow(this._element),t(this._element).addClass(_),this._config.focus&&this._enforceFocus();var s=t.Event(h.SHOWN,{relatedTarget:e}),r=function(){n._config.focus&&n._element.focus(),n._isTransitioning=!1,t(n._element).trigger(s)};i?t(this._dialog).one(P.TRANSITION_END,r).emulateTransitionEnd(300):r()},p._enforceFocus=function(){var e=this;t(document).off(h.FOCUSIN).on(h.FOCUSIN,function(n){document!==n.target&&e._element!==n.target&&0===t(e._element).has(n.target).length&&e._element.focus()})},p._setEscapeEvent=function(){var e=this;this._isShown&&this._config.keyboard?t(this._element).on(h.KEYDOWN_DISMISS,function(t){27===t.which&&(t.preventDefault(),e.hide())}):this._isShown||t(this._element).off(h.KEYDOWN_DISMISS)},p._setResizeEvent=function(){var e=this;this._isShown?t(window).on(h.RESIZE,function(t){return e.handleUpdate(t)}):t(window).off(h.RESIZE)},p._hideModal=function(){var e=this;this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._isTransitioning=!1,this._showBackdrop(function(){t(document.body).removeClass(f),e._resetAdjustments(),e._resetScrollbar(),t(e._element).trigger(h.HIDDEN)})},p._removeBackdrop=function(){this._backdrop&&(t(this._backdrop).remove(),this._backdrop=null)},p._showBackdrop=function(e){var n=this,i=t(this._element).hasClass(d)?d:"";if(this._isShown&&this._config.backdrop){var s=P.supportsTransitionEnd()&&i;if(this._backdrop=document.createElement("div"),this._backdrop.className=u,i&&t(this._backdrop).addClass(i),t(this._backdrop).appendTo(document.body),t(this._element).on(h.CLICK_DISMISS,function(t){n._ignoreBackdropClick?n._ignoreBackdropClick=!1:t.target===t.currentTarget&&("static"===n._config.backdrop?n._element.focus():n.hide())}),s&&P.reflow(this._backdrop),t(this._backdrop).addClass(_),!e)return;if(!s)return void e();t(this._backdrop).one(P.TRANSITION_END,e).emulateTransitionEnd(150)}else if(!this._isShown&&this._backdrop){t(this._backdrop).removeClass(_);var r=function(){n._removeBackdrop(),e&&e()};P.supportsTransitionEnd()&&t(this._element).hasClass(d)?t(this._backdrop).one(P.TRANSITION_END,r).emulateTransitionEnd(150):r()}else e&&e()},p._adjustDialog=function(){var t=this._element.scrollHeight>document.documentElement.clientHeight;!this._isBodyOverflowing&&t&&(this._element.style.paddingLeft=this._scrollbarWidth+"px"),this._isBodyOverflowing&&!t&&(this._element.style.paddingRight=this._scrollbarWidth+"px")},p._resetAdjustments=function(){this._element.style.paddingLeft="",this._element.style.paddingRight=""},p._checkScrollbar=function(){var t=document.body.getBoundingClientRect();this._isBodyOverflowing=t.left+t.right<window.innerWidth,this._scrollbarWidth=this._getScrollbarWidth()},p._setScrollbar=function(){var e=this;if(this._isBodyOverflowing){t(g.FIXED_CONTENT).each(function(n,i){var s=t(i)[0].style.paddingRight,r=t(i).css("padding-right");t(i).data("padding-right",s).css("padding-right",parseFloat(r)+e._scrollbarWidth+"px")}),t(g.STICKY_CONTENT).each(function(n,i){var s=t(i)[0].style.marginRight,r=t(i).css("margin-right");t(i).data("margin-right",s).css("margin-right",parseFloat(r)-e._scrollbarWidth+"px")}),t(g.NAVBAR_TOGGLER).each(function(n,i){var s=t(i)[0].style.marginRight,r=t(i).css("margin-right");t(i).data("margin-right",s).css("margin-right",parseFloat(r)+e._scrollbarWidth+"px")});var n=document.body.style.paddingRight,i=t("body").css("padding-right");t("body").data("padding-right",n).css("padding-right",parseFloat(i)+this._scrollbarWidth+"px")}},p._resetScrollbar=function(){t(g.FIXED_CONTENT).each(function(e,n){var i=t(n).data("padding-right");"undefined"!=typeof i&&t(n).css("padding-right",i).removeData("padding-right")}),t(g.STICKY_CONTENT+", "+g.NAVBAR_TOGGLER).each(function(e,n){var i=t(n).data("margin-right");"undefined"!=typeof i&&t(n).css("margin-right",i).removeData("margin-right")});var e=t("body").data("padding-right");"undefined"!=typeof e&&t("body").css("padding-right",e).removeData("padding-right")},p._getScrollbarWidth=function(){var t=document.createElement("div");t.className=c,document.body.appendChild(t);var e=t.getBoundingClientRect().width-t.clientWidth;return document.body.removeChild(t),e},o._jQueryInterface=function(e,i){return this.each(function(){var s=t(this).data(n),a=r({},o.Default,t(this).data(),"object"==typeof e&&e);if(s||(s=new o(this,a),t(this).data(n,s)),"string"==typeof e){if("undefined"==typeof s[e])throw new TypeError('No method named "'+e+'"');s[e](i)}else a.show&&s.show(i)})},s(o,null,[{key:"VERSION",get:function(){return"4.0.0"}},{key:"Default",get:function(){return a}}]),o}();return t(document).on(h.CLICK_DATA_API,g.DATA_TOGGLE,function(e){var i,s=this,o=P.getSelectorFromElement(this);o&&(i=t(o)[0]);var a=t(i).data(n)?"toggle":r({},t(i).data(),t(this).data());"A"!==this.tagName&&"AREA"!==this.tagName||e.preventDefault();var l=t(i).one(h.SHOW,function(e){e.isDefaultPrevented()||l.one(h.HIDDEN,function(){t(s).is(":visible")&&s.focus()})});p._jQueryInterface.call(t(i),a,this)}),t.fn.modal=p._jQueryInterface,t.fn.modal.Constructor=p,t.fn.modal.noConflict=function(){return t.fn.modal=o,p._jQueryInterface},p}(e),U=function(t){var e="tooltip",i="bs.tooltip",o="."+i,a=t.fn[e],l=new RegExp("(^|\\s)bs-tooltip\\S+","g"),h={animation:"boolean",template:"string",title:"(string|element|function)",trigger:"string",delay:"(number|object)",html:"boolean",selector:"(string|boolean)",placement:"(string|function)",offset:"(number|string)",container:"(string|element|boolean)",fallbackPlacement:"(string|array)",boundary:"(string|element)"},c={AUTO:"auto",TOP:"top",RIGHT:"right",BOTTOM:"bottom",LEFT:"left"},u={animation:!0,template:'<div class="tooltip" role="tooltip"><div class="arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,selector:!1,placement:"top",offset:0,container:!1,fallbackPlacement:"flip",boundary:"scrollParent"},f="show",d="out",_={HIDE:"hide"+o,HIDDEN:"hidden"+o,SHOW:"show"+o,SHOWN:"shown"+o,INSERTED:"inserted"+o,CLICK:"click"+o,FOCUSIN:"focusin"+o,FOCUSOUT:"focusout"+o,MOUSEENTER:"mouseenter"+o,MOUSELEAVE:"mouseleave"+o},g="fade",p="show",m=".tooltip-inner",v=".arrow",E="hover",T="focus",y="click",C="manual",I=function(){function a(t,e){if("undefined"==typeof n)throw new TypeError("Bootstrap tooltips require Popper.js (https://popper.js.org)");this._isEnabled=!0,this._timeout=0,this._hoverState="",this._activeTrigger={},this._popper=null,this.element=t,this.config=this._getConfig(e),this.tip=null,this._setListeners()}var I=a.prototype;return I.enable=function(){this._isEnabled=!0},I.disable=function(){this._isEnabled=!1},I.toggleEnabled=function(){this._isEnabled=!this._isEnabled},I.toggle=function(e){if(this._isEnabled)if(e){var n=this.constructor.DATA_KEY,i=t(e.currentTarget).data(n);i||(i=new this.constructor(e.currentTarget,this._getDelegateConfig()),t(e.currentTarget).data(n,i)),i._activeTrigger.click=!i._activeTrigger.click,i._isWithActiveTrigger()?i._enter(null,i):i._leave(null,i)}else{if(t(this.getTipElement()).hasClass(p))return void this._leave(null,this);this._enter(null,this)}},I.dispose=function(){clearTimeout(this._timeout),t.removeData(this.element,this.constructor.DATA_KEY),t(this.element).off(this.constructor.EVENT_KEY),t(this.element).closest(".modal").off("hide.bs.modal"),this.tip&&t(this.tip).remove(),this._isEnabled=null,this._timeout=null,this._hoverState=null,this._activeTrigger=null,null!==this._popper&&this._popper.destroy(),this._popper=null,this.element=null,this.config=null,this.tip=null},I.show=function(){var e=this;if("none"===t(this.element).css("display"))throw new Error("Please use show on visible elements");var i=t.Event(this.constructor.Event.SHOW);if(this.isWithContent()&&this._isEnabled){t(this.element).trigger(i);var s=t.contains(this.element.ownerDocument.documentElement,this.element);if(i.isDefaultPrevented()||!s)return;var r=this.getTipElement(),o=P.getUID(this.constructor.NAME);r.setAttribute("id",o),this.element.setAttribute("aria-describedby",o),this.setContent(),this.config.animation&&t(r).addClass(g);var l="function"==typeof this.config.placement?this.config.placement.call(this,r,this.element):this.config.placement,h=this._getAttachment(l);this.addAttachmentClass(h);var c=!1===this.config.container?document.body:t(this.config.container);t(r).data(this.constructor.DATA_KEY,this),t.contains(this.element.ownerDocument.documentElement,this.tip)||t(r).appendTo(c),t(this.element).trigger(this.constructor.Event.INSERTED),this._popper=new n(this.element,r,{placement:h,modifiers:{offset:{offset:this.config.offset},flip:{behavior:this.config.fallbackPlacement},arrow:{element:v},preventOverflow:{boundariesElement:this.config.boundary}},onCreate:function(t){t.originalPlacement!==t.placement&&e._handlePopperPlacementChange(t)},onUpdate:function(t){e._handlePopperPlacementChange(t)}}),t(r).addClass(p),"ontouchstart"in document.documentElement&&t("body").children().on("mouseover",null,t.noop);var u=function(){e.config.animation&&e._fixTransition();var n=e._hoverState;e._hoverState=null,t(e.element).trigger(e.constructor.Event.SHOWN),n===d&&e._leave(null,e)};P.supportsTransitionEnd()&&t(this.tip).hasClass(g)?t(this.tip).one(P.TRANSITION_END,u).emulateTransitionEnd(a._TRANSITION_DURATION):u()}},I.hide=function(e){var n=this,i=this.getTipElement(),s=t.Event(this.constructor.Event.HIDE),r=function(){n._hoverState!==f&&i.parentNode&&i.parentNode.removeChild(i),n._cleanTipClass(),n.element.removeAttribute("aria-describedby"),t(n.element).trigger(n.constructor.Event.HIDDEN),null!==n._popper&&n._popper.destroy(),e&&e()};t(this.element).trigger(s),s.isDefaultPrevented()||(t(i).removeClass(p),"ontouchstart"in document.documentElement&&t("body").children().off("mouseover",null,t.noop),this._activeTrigger[y]=!1,this._activeTrigger[T]=!1,this._activeTrigger[E]=!1,P.supportsTransitionEnd()&&t(this.tip).hasClass(g)?t(i).one(P.TRANSITION_END,r).emulateTransitionEnd(150):r(),this._hoverState="")},I.update=function(){null!==this._popper&&this._popper.scheduleUpdate()},I.isWithContent=function(){return Boolean(this.getTitle())},I.addAttachmentClass=function(e){t(this.getTipElement()).addClass("bs-tooltip-"+e)},I.getTipElement=function(){return this.tip=this.tip||t(this.config.template)[0],this.tip},I.setContent=function(){var e=t(this.getTipElement());this.setElementContent(e.find(m),this.getTitle()),e.removeClass(g+" "+p)},I.setElementContent=function(e,n){var i=this.config.html;"object"==typeof n&&(n.nodeType||n.jquery)?i?t(n).parent().is(e)||e.empty().append(n):e.text(t(n).text()):e[i?"html":"text"](n)},I.getTitle=function(){var t=this.element.getAttribute("data-original-title");return t||(t="function"==typeof this.config.title?this.config.title.call(this.element):this.config.title),t},I._getAttachment=function(t){return c[t.toUpperCase()]},I._setListeners=function(){var e=this;this.config.trigger.split(" ").forEach(function(n){if("click"===n)t(e.element).on(e.constructor.Event.CLICK,e.config.selector,function(t){return e.toggle(t)});else if(n!==C){var i=n===E?e.constructor.Event.MOUSEENTER:e.constructor.Event.FOCUSIN,s=n===E?e.constructor.Event.MOUSELEAVE:e.constructor.Event.FOCUSOUT;t(e.element).on(i,e.config.selector,function(t){return e._enter(t)}).on(s,e.config.selector,function(t){return e._leave(t)})}t(e.element).closest(".modal").on("hide.bs.modal",function(){return e.hide()})}),this.config.selector?this.config=r({},this.config,{trigger:"manual",selector:""}):this._fixTitle()},I._fixTitle=function(){var t=typeof this.element.getAttribute("data-original-title");(this.element.getAttribute("title")||"string"!==t)&&(this.element.setAttribute("data-original-title",this.element.getAttribute("title")||""),this.element.setAttribute("title",""))},I._enter=function(e,n){var i=this.constructor.DATA_KEY;(n=n||t(e.currentTarget).data(i))||(n=new this.constructor(e.currentTarget,this._getDelegateConfig()),t(e.currentTarget).data(i,n)),e&&(n._activeTrigger["focusin"===e.type?T:E]=!0),t(n.getTipElement()).hasClass(p)||n._hoverState===f?n._hoverState=f:(clearTimeout(n._timeout),n._hoverState=f,n.config.delay&&n.config.delay.show?n._timeout=setTimeout(function(){n._hoverState===f&&n.show()},n.config.delay.show):n.show())},I._leave=function(e,n){var i=this.constructor.DATA_KEY;(n=n||t(e.currentTarget).data(i))||(n=new this.constructor(e.currentTarget,this._getDelegateConfig()),t(e.currentTarget).data(i,n)),e&&(n._activeTrigger["focusout"===e.type?T:E]=!1),n._isWithActiveTrigger()||(clearTimeout(n._timeout),n._hoverState=d,n.config.delay&&n.config.delay.hide?n._timeout=setTimeout(function(){n._hoverState===d&&n.hide()},n.config.delay.hide):n.hide())},I._isWithActiveTrigger=function(){for(var t in this._activeTrigger)if(this._activeTrigger[t])return!0;return!1},I._getConfig=function(n){return"number"==typeof(n=r({},this.constructor.Default,t(this.element).data(),n)).delay&&(n.delay={show:n.delay,hide:n.delay}),"number"==typeof n.title&&(n.title=n.title.toString()),"number"==typeof n.content&&(n.content=n.content.toString()),P.typeCheckConfig(e,n,this.constructor.DefaultType),n},I._getDelegateConfig=function(){var t={};if(this.config)for(var e in this.config)this.constructor.Default[e]!==this.config[e]&&(t[e]=this.config[e]);return t},I._cleanTipClass=function(){var e=t(this.getTipElement()),n=e.attr("class").match(l);null!==n&&n.length>0&&e.removeClass(n.join(""))},I._handlePopperPlacementChange=function(t){this._cleanTipClass(),this.addAttachmentClass(this._getAttachment(t.placement))},I._fixTransition=function(){var e=this.getTipElement(),n=this.config.animation;null===e.getAttribute("x-placement")&&(t(e).removeClass(g),this.config.animation=!1,this.hide(),this.show(),this.config.animation=n)},a._jQueryInterface=function(e){return this.each(function(){var n=t(this).data(i),s="object"==typeof e&&e;if((n||!/dispose|hide/.test(e))&&(n||(n=new a(this,s),t(this).data(i,n)),"string"==typeof e)){if("undefined"==typeof n[e])throw new TypeError('No method named "'+e+'"');n[e]()}})},s(a,null,[{key:"VERSION",get:function(){return"4.0.0"}},{key:"Default",get:function(){return u}},{key:"NAME",get:function(){return e}},{key:"DATA_KEY",get:function(){return i}},{key:"Event",get:function(){return _}},{key:"EVENT_KEY",get:function(){return o}},{key:"DefaultType",get:function(){return h}}]),a}();return t.fn[e]=I._jQueryInterface,t.fn[e].Constructor=I,t.fn[e].noConflict=function(){return t.fn[e]=a,I._jQueryInterface},I}(e),x=function(t){var e="popover",n="bs.popover",i="."+n,o=t.fn[e],a=new RegExp("(^|\\s)bs-popover\\S+","g"),l=r({},U.Default,{placement:"right",trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>'}),h=r({},U.DefaultType,{content:"(string|element|function)"}),c="fade",u="show",f=".popover-header",d=".popover-body",_={HIDE:"hide"+i,HIDDEN:"hidden"+i,SHOW:"show"+i,SHOWN:"shown"+i,INSERTED:"inserted"+i,CLICK:"click"+i,FOCUSIN:"focusin"+i,FOCUSOUT:"focusout"+i,MOUSEENTER:"mouseenter"+i,MOUSELEAVE:"mouseleave"+i},g=function(r){var o,g;function p(){return r.apply(this,arguments)||this}g=r,(o=p).prototype=Object.create(g.prototype),o.prototype.constructor=o,o.__proto__=g;var m=p.prototype;return m.isWithContent=function(){return this.getTitle()||this._getContent()},m.addAttachmentClass=function(e){t(this.getTipElement()).addClass("bs-popover-"+e)},m.getTipElement=function(){return this.tip=this.tip||t(this.config.template)[0],this.tip},m.setContent=function(){var e=t(this.getTipElement());this.setElementContent(e.find(f),this.getTitle());var n=this._getContent();"function"==typeof n&&(n=n.call(this.element)),this.setElementContent(e.find(d),n),e.removeClass(c+" "+u)},m._getContent=function(){return this.element.getAttribute("data-content")||this.config.content},m._cleanTipClass=function(){var e=t(this.getTipElement()),n=e.attr("class").match(a);null!==n&&n.length>0&&e.removeClass(n.join(""))},p._jQueryInterface=function(e){return this.each(function(){var i=t(this).data(n),s="object"==typeof e?e:null;if((i||!/destroy|hide/.test(e))&&(i||(i=new p(this,s),t(this).data(n,i)),"string"==typeof e)){if("undefined"==typeof i[e])throw new TypeError('No method named "'+e+'"');i[e]()}})},s(p,null,[{key:"VERSION",get:function(){return"4.0.0"}},{key:"Default",get:function(){return l}},{key:"NAME",get:function(){return e}},{key:"DATA_KEY",get:function(){return n}},{key:"Event",get:function(){return _}},{key:"EVENT_KEY",get:function(){return i}},{key:"DefaultType",get:function(){return h}}]),p}(U);return t.fn[e]=g._jQueryInterface,t.fn[e].Constructor=g,t.fn[e].noConflict=function(){return t.fn[e]=o,g._jQueryInterface},g}(e),K=function(t){var e="scrollspy",n="bs.scrollspy",i="."+n,o=t.fn[e],a={offset:10,method:"auto",target:""},l={offset:"number",method:"string",target:"(string|element)"},h={ACTIVATE:"activate"+i,SCROLL:"scroll"+i,LOAD_DATA_API:"load"+i+".data-api"},c="dropdown-item",u="active",f={DATA_SPY:'[data-spy="scroll"]',ACTIVE:".active",NAV_LIST_GROUP:".nav, .list-group",NAV_LINKS:".nav-link",NAV_ITEMS:".nav-item",LIST_ITEMS:".list-group-item",DROPDOWN:".dropdown",DROPDOWN_ITEMS:".dropdown-item",DROPDOWN_TOGGLE:".dropdown-toggle"},d="offset",_="position",g=function(){function o(e,n){var i=this;this._element=e,this._scrollElement="BODY"===e.tagName?window:e,this._config=this._getConfig(n),this._selector=this._config.target+" "+f.NAV_LINKS+","+this._config.target+" "+f.LIST_ITEMS+","+this._config.target+" "+f.DROPDOWN_ITEMS,this._offsets=[],this._targets=[],this._activeTarget=null,this._scrollHeight=0,t(this._scrollElement).on(h.SCROLL,function(t){return i._process(t)}),this.refresh(),this._process()}var g=o.prototype;return g.refresh=function(){var e=this,n=this._scrollElement===this._scrollElement.window?d:_,i="auto"===this._config.method?n:this._config.method,s=i===_?this._getScrollTop():0;this._offsets=[],this._targets=[],this._scrollHeight=this._getScrollHeight(),t.makeArray(t(this._selector)).map(function(e){var n,r=P.getSelectorFromElement(e);if(r&&(n=t(r)[0]),n){var o=n.getBoundingClientRect();if(o.width||o.height)return[t(n)[i]().top+s,r]}return null}).filter(function(t){return t}).sort(function(t,e){return t[0]-e[0]}).forEach(function(t){e._offsets.push(t[0]),e._targets.push(t[1])})},g.dispose=function(){t.removeData(this._element,n),t(this._scrollElement).off(i),this._element=null,this._scrollElement=null,this._config=null,this._selector=null,this._offsets=null,this._targets=null,this._activeTarget=null,this._scrollHeight=null},g._getConfig=function(n){if("string"!=typeof(n=r({},a,n)).target){var i=t(n.target).attr("id");i||(i=P.getUID(e),t(n.target).attr("id",i)),n.target="#"+i}return P.typeCheckConfig(e,n,l),n},g._getScrollTop=function(){return this._scrollElement===window?this._scrollElement.pageYOffset:this._scrollElement.scrollTop},g._getScrollHeight=function(){return this._scrollElement.scrollHeight||Math.max(document.body.scrollHeight,document.documentElement.scrollHeight)},g._getOffsetHeight=function(){return this._scrollElement===window?window.innerHeight:this._scrollElement.getBoundingClientRect().height},g._process=function(){var t=this._getScrollTop()+this._config.offset,e=this._getScrollHeight(),n=this._config.offset+e-this._getOffsetHeight();if(this._scrollHeight!==e&&this.refresh(),t>=n){var i=this._targets[this._targets.length-1];this._activeTarget!==i&&this._activate(i)}else{if(this._activeTarget&&t<this._offsets[0]&&this._offsets[0]>0)return this._activeTarget=null,void this._clear();for(var s=this._offsets.length;s--;){this._activeTarget!==this._targets[s]&&t>=this._offsets[s]&&("undefined"==typeof this._offsets[s+1]||t<this._offsets[s+1])&&this._activate(this._targets[s])}}},g._activate=function(e){this._activeTarget=e,this._clear();var n=this._selector.split(",");n=n.map(function(t){return t+'[data-target="'+e+'"],'+t+'[href="'+e+'"]'});var i=t(n.join(","));i.hasClass(c)?(i.closest(f.DROPDOWN).find(f.DROPDOWN_TOGGLE).addClass(u),i.addClass(u)):(i.addClass(u),i.parents(f.NAV_LIST_GROUP).prev(f.NAV_LINKS+", "+f.LIST_ITEMS).addClass(u),i.parents(f.NAV_LIST_GROUP).prev(f.NAV_ITEMS).children(f.NAV_LINKS).addClass(u)),t(this._scrollElement).trigger(h.ACTIVATE,{relatedTarget:e})},g._clear=function(){t(this._selector).filter(f.ACTIVE).removeClass(u)},o._jQueryInterface=function(e){return this.each(function(){var i=t(this).data(n);if(i||(i=new o(this,"object"==typeof e&&e),t(this).data(n,i)),"string"==typeof e){if("undefined"==typeof i[e])throw new TypeError('No method named "'+e+'"');i[e]()}})},s(o,null,[{key:"VERSION",get:function(){return"4.0.0"}},{key:"Default",get:function(){return a}}]),o}();return t(window).on(h.LOAD_DATA_API,function(){for(var e=t.makeArray(t(f.DATA_SPY)),n=e.length;n--;){var i=t(e[n]);g._jQueryInterface.call(i,i.data())}}),t.fn[e]=g._jQueryInterface,t.fn[e].Constructor=g,t.fn[e].noConflict=function(){return t.fn[e]=o,g._jQueryInterface},g}(e),V=function(t){var e="bs.tab",n="."+e,i=t.fn.tab,r={HIDE:"hide"+n,HIDDEN:"hidden"+n,SHOW:"show"+n,SHOWN:"shown"+n,CLICK_DATA_API:"click.bs.tab.data-api"},o="dropdown-menu",a="active",l="disabled",h="fade",c="show",u=".dropdown",f=".nav, .list-group",d=".active",_="> li > .active",g='[data-toggle="tab"], [data-toggle="pill"], [data-toggle="list"]',p=".dropdown-toggle",m="> .dropdown-menu .active",v=function(){function n(t){this._element=t}var i=n.prototype;return i.show=function(){var e=this;if(!(this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE&&t(this._element).hasClass(a)||t(this._element).hasClass(l))){var n,i,s=t(this._element).closest(f)[0],o=P.getSelectorFromElement(this._element);if(s){var h="UL"===s.nodeName?_:d;i=(i=t.makeArray(t(s).find(h)))[i.length-1]}var c=t.Event(r.HIDE,{relatedTarget:this._element}),u=t.Event(r.SHOW,{relatedTarget:i});if(i&&t(i).trigger(c),t(this._element).trigger(u),!u.isDefaultPrevented()&&!c.isDefaultPrevented()){o&&(n=t(o)[0]),this._activate(this._element,s);var g=function(){var n=t.Event(r.HIDDEN,{relatedTarget:e._element}),s=t.Event(r.SHOWN,{relatedTarget:i});t(i).trigger(n),t(e._element).trigger(s)};n?this._activate(n,n.parentNode,g):g()}}},i.dispose=function(){t.removeData(this._element,e),this._element=null},i._activate=function(e,n,i){var s=this,r=("UL"===n.nodeName?t(n).find(_):t(n).children(d))[0],o=i&&P.supportsTransitionEnd()&&r&&t(r).hasClass(h),a=function(){return s._transitionComplete(e,r,i)};r&&o?t(r).one(P.TRANSITION_END,a).emulateTransitionEnd(150):a()},i._transitionComplete=function(e,n,i){if(n){t(n).removeClass(c+" "+a);var s=t(n.parentNode).find(m)[0];s&&t(s).removeClass(a),"tab"===n.getAttribute("role")&&n.setAttribute("aria-selected",!1)}if(t(e).addClass(a),"tab"===e.getAttribute("role")&&e.setAttribute("aria-selected",!0),P.reflow(e),t(e).addClass(c),e.parentNode&&t(e.parentNode).hasClass(o)){var r=t(e).closest(u)[0];r&&t(r).find(p).addClass(a),e.setAttribute("aria-expanded",!0)}i&&i()},n._jQueryInterface=function(i){return this.each(function(){var s=t(this),r=s.data(e);if(r||(r=new n(this),s.data(e,r)),"string"==typeof i){if("undefined"==typeof r[i])throw new TypeError('No method named "'+i+'"');r[i]()}})},s(n,null,[{key:"VERSION",get:function(){return"4.0.0"}}]),n}();return t(document).on(r.CLICK_DATA_API,g,function(e){e.preventDefault(),v._jQueryInterface.call(t(this),"show")}),t.fn.tab=v._jQueryInterface,t.fn.tab.Constructor=v,t.fn.tab.noConflict=function(){return t.fn.tab=i,v._jQueryInterface},v}(e);!function(t){if("undefined"==typeof t)throw new TypeError("Bootstrap's JavaScript requires jQuery. jQuery must be included before Bootstrap's JavaScript.");var e=t.fn.jquery.split(" ")[0].split(".");if(e[0]<2&&e[1]<9||1===e[0]&&9===e[1]&&e[2]<1||e[0]>=4)throw new Error("Bootstrap's JavaScript requires at least jQuery v1.9.1 but less than v4.0.0")}(e),t.Util=P,t.Alert=L,t.Button=R,t.Carousel=j,t.Collapse=H,t.Dropdown=W,t.Modal=M,t.Popover=x,t.Scrollspy=K,t.Tab=V,t.Tooltip=U,Object.defineProperty(t,"__esModule",{value:!0})});
| |
− | //# sourceMappingURL=bootstrap.min.js.map
| |
− | </script>
| |
− |
| |
− |
| |
− | <div class="container-fluid vert">
| |
− | <div class="container">
| |
− | <!-- Navbar -->
| |
− |
| |
− | <nav class="navbar navbar-expand-lg navbar-light " >
| |
− | <img id="logo" src="https://static.igem.org/mediawiki/2018/3/37/T--Sorbonne_U_Paris--logo_fb.png" alt="logo"/>
| |
− | <a class="navbar-brand" href="https://2018.igem.org/Team:Sorbonne_U_Paris">Sorbonne U Paris</a>
| |
− |
| |
− | <!-- bouton menu qui apparaît quand on diminue la taille de l'écran -->
| |
− | <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarTogglerDemo02" aria-controls="navbarTogglerDemo02" aria-expanded="false" aria-label="Toggle navigation">
| |
− | <span class="navbar-toggler-icon"></span>
| |
− | </button>
| |
− |
| |
− | <div class="collapse navbar-collapse" id="navbarTogglerDemo02">
| |
− | <ul class="navbar-nav mr-auto mt-2 mt-lg-0 ">
| |
− | <!-- dropdown project -->
| |
− |
| |
− | <li class="nav-item dropdown nav-custom">
| |
− | <a class="nav-link dropdown-toggle " href="#" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" style="color:white">
| |
− | Project
| |
− | </a>
| |
− | <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
| |
− |
| |
− | <a class="dropdown-item " href="https://2018.igem.org/Team:Sorbonne_U_Paris/Description">Description</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Design">Design</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Experiments">Experiments</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Notebook">Notebook</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/InterLab">Interlab</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Model">Model</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Results">Results</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Demonstratel">Demonstrate</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Improve">Improve</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Attributions">Attributions</a>
| |
− | </div>
| |
− | </li>
| |
− |
| |
− | <!-- dropdown team -->
| |
− | <li class="nav-item dropdown nav-custom">
| |
− | <a class="nav-link dropdown-toggle" href="#" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" style="color:white">
| |
− | Team
| |
− | </a>
| |
− | <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Team">Team Members</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Collaborations">Collaborations</a>
| |
− |
| |
− | </li>
| |
− |
| |
− |
| |
− | <!-- dropdown parts -->
| |
− | <li class="nav-item dropdown nav-custom">
| |
− | <a class="nav-link dropdown-toggle" href="#" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" style="color:white">
| |
− | Parts
| |
− | </a>
| |
− | <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Parts">Parts Overview</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Basic_Part">Basic Parts</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Composite_Part">Composite Parts</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Part_Collection">Part Collection</a>
| |
− | </li>
| |
− |
| |
− | <!-- dropdown human practices -->
| |
− | <li class="nav-item dropdown nav-custom">
| |
− | <a class="nav-link dropdown-toggle" href="#" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" style="color:white">
| |
− | Human Practices
| |
− | </a>
| |
− | <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Human_Practices">Human Practices</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Public_Engagement">Education & Engagement</a>
| |
− | </li>
| |
− |
| |
− | <!-- link safety-->
| |
− | <li class="nav-item nav-custom">
| |
− | <a class="nav-link disabled"href="https://2018.igem.org/Team:Sorbonne_U_Paris/Safety" style="color:white">Safety</a>
| |
− | </li>
| |
− |
| |
− | <!-- link judgingForm -->
| |
− | <li class="nav-item nav-custom">
| |
− | <a class="nav-link disabled" href="https://igem.org/2018_Judging_Form?team=Sorbonne_U_Paris" style="color:white">Judging Form</a>
| |
− | </li>
| |
− |
| |
− | <!-- dropdown awards -->
| |
− |
| |
− | <li class="nav-item dropdown nav-custom">
| |
− | <a class="nav-link dropdown-toggle" href="#" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" style="color:white">
| |
− | Awards
| |
− | </a>
| |
− | <div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Applied_Design">Applied Design</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Entrepreneurship">Entrepreneurship</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Hardware">Hardware</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Measurement">Measurement</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Model">Model</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Plant">Plant</a>
| |
− | <a class="dropdown-item" href="https://2018.igem.org/Team:Sorbonne_U_Paris/Software">Software</a>
| |
− |
| |
− | </li>
| |
− | </div>
| |
− | </div>
| |
− | </div> <!-- fin du container-fluid vert -->
| |
| | | |
| <!-- Container logo étendu --> | | <!-- Container logo étendu --> |