1.html代码
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>我的朋友圈</title>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
<link type="text/css" rel="stylesheet" href="css/app.css">
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/rem.js"></script>
<link rel="stylesheet" type="text/css" href="css/swiper.min.css"/>
<script type="text/javascript" src="js/swiper.min.js"></script>
</head>
<body>
<div id="main">
<div id="list">
<ul>
<li>
<div class="po-avt-wrap"> <img class="po-avt data-avt" src="picture/0.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="po-name"><span class="data-name">张三</span></p>
<div class="post">
<p>大家好,听说国内冻成狗🐶?我这边还挺热~</p>
<p> <img class="list-img" src="picture/jt1.jpg" style="height: 80px;"> <img class="list-img" src="picture/yt3.jpg" style="height: 80px;"> <img class="list-img data-avt" src="picture/0.jpg" style="height: 80px;"> <img class="list-img data-avt" src="picture/guide2.png" style="height: 80px;"> </p>
</div>
<p class="time">刚刚</p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
</div>
<div class="r"></div>
<div class="cmt-wrap">
<div class="like"><img src="picture/l.png">空空空,陈冠希,杨幂,王思聪,陈赫,刘德华,马云...</div>
<div class="cmt-list">
<p><span>wu世勋-EXO:</span>나는 서명~</p>
<p><span>鹿晗:</span>我们在国内冻成狗,我也想跟哥您去热热~</p>
<p><span>权志龙:</span>나는 서명~</p>
<p><span>王思聪:</span>去哪玩啊?那么爽</p>
<p> <span class="data-name">张三</span> 回复 <span> 王思聪 </span> <span> : </span> 澳洲大堡礁,这边刚好是夏季,挺适合避寒的。 </p>
<p><span>杨幂:</span>😘私人飞机出行,求带上我~</p>
</div>
</div>
</div>
</li>
<li>
<div class="po-avt-wrap"> <img class="po-avt" src="picture/n5.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="po-name"> 王思聪 </p>
<div class="post">
<p> 那一年这兄弟三人发誓一定要出人头地 <br>
以后有福同享有难同当 <br>
如今: <br>
大哥只手遮天万人之上 <br>
二哥黄金万两富甲一方 <br>
三弟淡泊名利为人低调 </p>
<img class="list-img" src="picture/xa1.jpg" style="height: 80px;"> <img class="list-img" src="picture/ma1.jpg" style="height: 80px;"> <img class="data-avt list-img" src="picture/0.jpg" style="height: 80px;"> </div>
<p class="time"> 1分钟前 </p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
</div>
<div class="r"> </div>
<div class="cmt-wrap">
<div class="like"> <img src="picture/l.png"> 鹿晗,林更新,杨幂,angelababy,范冰冰... </div>
<div class="cmt-list">
<p> <span> 鹿晗: </span> 赞! </p>
<p> <span class="data-name">张三</span> <span> : </span> 低调低调。。 </p>
<p> <span> 王思聪 </span> 回复 <span class="data-name">张三</span> <span> : </span> 哥您就是太低调了 </p>
<p> <span> 习 </span> 回复 <span class="data-name">张三</span> <span> : </span> 好几天没见,我们该聚聚了 </p>
<p> <span> 马云 </span> 回复 <span class="data-name">张三</span> <span> : </span> 有笔大生意找你聊聊 </p>
</div>
</div>
</div>
</li>
<li>
<div class="po-avt-wrap"> <img class="po-avt" src="picture/a1.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="po-name"> 空空空 </p>
<p class="post"> 还是好困~ <img src="picture/c1.jpg"> </p>
<p class="time"> 2分钟前 </p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
<div class="r"> </div>
<div class="cmt-wrap">
<div class="like"> <img src="picture/l.png"> 陈赫,叫兽易小星,王思聪,陈冠希,余文乐... </div>
<div class="cmt-list">
<p> <span> 陈赫: </span> 怪我咯~ </p>
<p> <span> 陈冠希: </span> 怪我咯~ </p>
<p> <span class="data-name">张三</span> <span> : </span> 怪我咯~ </p>
<p> <span> 空空空 </span> 回复 <span class="data-name">张三</span> <span> : </span> 知道就好! </p>
</div>
</div>
</div>
</div>
</li>
<li>
<div class="po-avt-wrap"> <img class="po-avt" src="picture/a2.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="po-name"> 周杰伦 </p>
<div class="post">
<p> <b class="data-name">张三</b> ,决战夜你要加油!我们哎哟不错战队是最屌的! </p>
<img class="list-img" src="picture/c2.jpg" style="height: 80px;"> <img class="data-avt list-img" src="picture/0.jpg" style="height: 80px;"> </div>
<p class="time"> 2分钟前 </p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
</div>
<div class="r"> </div>
<div class="cmt-wrap">
<div class="like"> <img src="picture/l.png"> 汪峰,那英,庾澄庆 </div>
<div class="cmt-list">
<p> <span class="data-name">张三</span> <span> : </span> 杰伦老师,决战夜小公举会来吗。~ </p>
<p> <span> 周杰伦 </span> 回复 <span class="data-name">张三</span> <span> : </span> 你拿冠军了,我让你当小公举的小王纸。 </p>
</div>
</div>
</div>
</li>
<li>
<div class="po-avt-wrap"> <img class="po-avt" src="picture/a5.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="ads">推广<img src="picture/ads.png"></p>
<p class="po-name">金猫银猫CSmall官方</p>
<div class="post">金猫银猫CSmall情人节买珠宝赠永生花专场
<p><a class="ad-link" href="http://m.csmall.com/activity/3914.html">查看详情 <img src="picture/link.png"></a></p>
<a href="http://m.csmall.com/activity/3914.html"><img class="noplayimg" src="picture/asd888.jpg"></a></div>
<p class="time">45分钟前</p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
</div>
<div class="r"></div>
<div class="cmt-wrap">
<div class="like"><img src="picture/l.png">范冰冰,李晨,王思聪,王健林,...</div>
<div class="cmt-list">
<p><span>范冰冰:</span>珠宝再加上永生花,花永生,爱永恒,想想都觉得好浪漫哦~<img class="bq" src="picture/bq1.png"></p>
<p><span>李晨</span>回复<span>范冰冰 :</span>小肥羊~初七情人节见!定格我们的爱情吧❤</p>
<p><span>王思聪:</span>我女朋友多,团购才能搞定啊!</p>
</div>
</div>
</div>
</li>
<li>
<div class="po-avt-wrap"> <img class="po-avt" src="picture/a3.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="po-name"> 邓超 </p>
<div class="post">
<p> we are伐木累!欢迎加入跑男第三季! </p>
<p> <img class="list-img" src="picture/c3.jpg" style="height: 80px;"> <img class="list-img" src="picture/c4.jpg" style="height: 80px;"> <img class="data-avt list-img" src="picture/0.jpg" style="height: 80px;"> </p>
</div>
<p class="time"> 50分钟前 </p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
</div>
<div class="r"> </div>
<div class="cmt-wrap">
<div class="like"> <img src="picture/l.png"> <b class="data-name">张三</b> </div>
<div class="cmt-list">
<p> <span class="data-name">张三</span> <span> : </span> 超哥,当初为什么要选我。 </p>
<p> <span> 邓超 </span> 回复 <span class="data-name">张三</span> <span> : </span> 你是我认识的人当中,最快的! </p>
</div>
</div>
</div>
</li>
<li>
<div class="po-avt-wrap"> <img class="po-avt" src="picture/a4.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="po-name"> 范冰冰 </p>
<p class="post"> 我的生日趴,你为什么不来 <img class="data-avt" src="picture/0.jpg"> </p>
<p class="time"> 52分钟前 </p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
</div>
<div class="r"> </div>
<div class="cmt-wrap">
<div class="like"> <img src="picture/l.png"> <b class="data-name">张三</b> ,李晨,李治廷,黎明... </div>
<div class="cmt-list">
<p> <span> 李晨: </span> 呵呵。 </p>
<p> <span class="data-name">张三</span> <span> : </span> 最近忙,就酱。 </p>
</div>
</div>
</div>
</li>
<li>
<div class="po-avt-wrap"> <img class="po-avt" src="picture/a7.jpg"> </div>
<div class="po-cmt">
<div class="po-hd">
<p class="po-name"> 金星 </p>
<p class="post"> 完美! <img src="picture/c8.jpg"> </p>
<p class="time"> 55分钟前 </p>
<div class="tc1"> <img class="c-icon" src="picture/c.png">
<div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
</div>
</div>
<div class="r"> </div>
<div class="cmt-wrap">
<div class="cmt-list">
<p> <span class="data-name">张三</span> <span> : </span> 星姐,求虐! </p>
<p> <span> 金星 </span> 回复 <span class="data-name">张三</span> <span> : </span> 你呢,人长的挺好看,就是偏偏要靠才华。 </p>
</div>
</div>
</div>
</li>
</ul>
</div>
</div>
<div class="big_img">
<div class="swiper-container2">
<div class="swiper-wrapper">
</div>
</div>
<div class="swiper-pagination2"></div>
</div>
<script>
$(document).ready(function(){
/*调起大图 S*/
var mySwiper = new Swiper('.swiper-container2', {
loop: false,
pagination: '.swiper-pagination2',
})
$("#list").on("click", ".post img",
function() {
var imgBox = $(this).parents(".post").find("img");
var i = $(imgBox).index(this);
$(".big_img .swiper-wrapper").html("")
for(var j = 0 ,c = imgBox.length; j < c ;j++){
$(".big_img .swiper-wrapper").append('<div class="swiper-slide"><div class="cell"><img src="' + imgBox.eq(j).attr("src") + '" / ></div></div>');
}
mySwiper.updateSlidesSize();
mySwiper.updatePagination();
$(".big_img").css({
"z-index": 1001,
"opacity": "1"
});
mySwiper.slideTo(i, 0, false);
return false;
});
$(".big_img").on("click",
function() {
$(this).css({
"z-index": "-1",
"opacity": "0"
});
});
});
/*调起大图 E*/
</script>
</body>
</html>
2.css代码
(1)app.css
/**
* Created by Administrator on 2016/1/31.
*/
body { font-size:14px; }
#list, #list li, .po-hd, .post { overflow: hidden }
.po-cmt, .post .list-img:nth-child(1), .time {
float: left
}
#list li, .cmt-wrap, .r, .time { clear: both }
.btn, a { cursor: pointer }
blockquote, body, code, dd, div, dl, dt, fieldset, form, h1, h2, h3, h4, h5, h6, input, legend, li, ol, p, pre, td, textarea, th, ul { margin: 0; padding: 0 }
table { border-collapse: collapse; border-spacing: 0 }
fieldset, img { border: 0 }
address, caption, cite, code, dfn, em, strong, th, var { font-style: normal; font-weight: 400 }
ol, ul { list-style: none none }
caption, th { text-align: left }
h1, h2, h3, h4, h5, h6 { font-size: 100%; font-weight: 400 }
q::after, q::before {
content: ""
}
abbr, acronym { border: 0; font-variant: normal }
sup { vertical-align: text-top }
sub { vertical-align: text-bottom }
input, select, textarea { font-family: inherit; font-size: inherit; font-weight: inherit }
legend { color: #000 }
a { text-decoration: none }
input { -webkit-appearance: none }
* { -webkit-tap-highlight-color: transparent }
html { background-color: #fff; font-family: Arial, sans-serif; font-size: 13px }
.top { width:100%; position:fixed; left:0; top:0; z-index:3; }
.top a { font-size:14px; line-height:40px; color:#fff; padding-left:12px; }
.back a { padding-left:12px; }
.back a:before { font-family: "iconfont"; content: "\e613"; font-size:14px; line-height:40px; color:#fff; overflow:hidden; zoom:1; }
.back a span { text-indent:-500px; display:inline-block; }
.bg1 { width:100%; height:40px; background:#000; position:fixed; left:0; top:0; z-index:2; filter:alpha(opacity=60); -moz-opacity:0.6; -khtml-opacity: 0.6; opacity: 0.6; }
.camera { float:right; padding-right:12px; }
.camera a:before { font-family: "iconfont"; content: "\e62a"; font-size:14px; line-height:40px; color:#fff; overflow:hidden; zoom:1; }
.camera a span { display:none; }
.tc1 { position:relative; }
.tc2 { position:absolute; right:-100px; bottom:-23px; width:100px; height:30px; background:#000; z-index:2; transition:200ms;
-moz-transition:200ms; /* Firefox 4 */
-webkit-transition:200ms; /* Safari 和 Chrome */
-o-transition:200ms; /* Opera */ }
.po-hd .show { right:20px; }
.zan span, .pinglun span { font-size:12px; line-height:30px; color:#fff; vertical-align:top; padding-left:5px; }
.zan:before { font-family: "iconfont"; content: "\e690"; font-size:12px; line-height:30px; color:#fff; vertical-align:middle; padding-left:8px; }
.pinglun:before { font-family: "iconfont"; content: "\e690"; font-size:12px; line-height:30px; color:#fff; vertical-align:top; }
.nav1 { width:100%; font-size:12px; height:1.2rem; position:fixed; left:0; bottom:0; z-index:999999; background:#f5f5f5; border-top:1px #ddd solid; /* For IE 8 */ -ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999')"; /* For IE 5.5 - 7 */ filter: progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999'); }
.nav1 li { width:20%; float:left; text-align:center; padding-top:0.12rem; }
.nav1 li a { font-size:0.26rem; line-height:0.4rem; color:#949494; }
.nav1 li img { width:0.36rem; }
.nav1 .li1 img { width:0.9rem; margin-top:-0.5rem; border:0.08rem #f5f5f5 solid; border-radius:0.555rem; -moz-box-shadow: 0 0 10px 0px #999; /* For IE 8 */ -ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999')"; /* For IE 5.5 - 7 */ filter: progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999'); }
@media screen and (min-width:350px) {
html {
font-size: 15px
}
.cmt-wrap {
font-size: 14px
}
.time {
font-size: 13px
}
}
.hide { display: none }
header { position: relative }
#avt, #user-name { position: absolute }
#bg { width: 100% }
#user-name { text-align: right; right: 114px; bottom: 15px; color: #fff; font-weight: 700; font-size: 15px; text-shadow: 0 1px .5px #000 }
#share a, .btn { font-size: 14px }
.btn, b { font-weight: 400 }
#share a, #share p, .btn { text-align: center }
#avt { width: 74px; height: 74px; border: 1px solid #dbdbdb; right: 15px; bottom: -22px; padding: 1px; background-color: #fff }
#list li, .po-hd { position: relative; padding-bottom:3px; }
#list { padding: 30px 0 10px }
#list li { line-height: 1.5; border-bottom: 1px solid #e2e2e2; margin-top: 15px; padding-bottom: 15px }
#share a:nth-child(2), .ads, .po-avt {
position: absolute
}
.ads { color: #999; right: 5px; top: 0 }
.ads img { width: 10px; padding-left: 8px }
.ad-link { color: #3b5384 }
.post .ad-link img { width: 11px; padding: 0; display: inline-block }
.po-avt-wrap { padding-left: 10px }
.po-avt { width: 40px; height: 40px; top: 0; left: 10px }
.r { border-bottom: 8px solid #eee; border-left: 8px solid transparent; border-right: 8px solid transparent; width: 1px; margin-top: 5px; margin-left: 10px }
.po-cmt { padding-left: 60px; padding-right: 10px; width: 100%; box-sizing: border-box }
.po-name { color: #576b95 }
.post { color: #252525; padding-bottom: 10px }
.post img { padding: 10px 5px 0 0; display: block; max-height: 130px; max-width: 130px }
#share a, .btn { display: inline-block }
.post .list-img { width: 30%; max-height: 80px; max-width: 80px; padding-right: 5px; float: left; object-fit: cover }
.post .list-img:last-child { padding-right: 0 }
.time { color: #b1b1b1 }
.c-icon { width: 20px; float: right; position:relative; z-index:3; }
.cmt-wrap { width: 100%; background-color: #f8f8f8 }
.like { color: #576b95; padding: 5px 5px 3px 12px }
.like img { width: 12px; padding-right: 5px }
.cmt-list { padding: 5px 12px; color: #454545 }
.cmt-list p { padding-top: 3px }
.cmt-list span { color: #3b5384 }
#share a { border-radius: 5px; background-color: #26337e; color: #fff; line-height: 2.5; width: 138px; margin: 0 10px }
#share a:nth-child(1) {
position: absolute;
left: 50%;
margin-left: -148px
}
#share a:nth-child(2) {
right: 50%;
margin-right: -148px
}
#share p { padding: 45px 0 10px; color: #999 }
#guide { position: fixed; left: 0; top: 0; bottom: 0; right: 0; width: 100%; height: 100%; z-index: 9999; background-image: url(../images/guide2.png); background-repeat: no-repeat; background-position: right top; background-color: #191919; background-size: contain; opacity: .9 }
.btn { margin-bottom: 0; vertical-align: middle; -ms-touch-action: manipulation; touch-action: manipulation; background-image: none; border: 1px solid transparent; white-space: nowrap; padding: 6px 12px; line-height: 1.42857143; border-radius: 4px; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none }
.btn-success { color: #fff; background-color: #5cb85c; border-color: #4cae4c }
.btn-group-lg>.btn, .btn-lg { padding: 10px 16px; font-size: 18px; line-height: 1.3333333; border-radius: 6px }
.btn-block { display: block; width: 100% }
.bq { width: 13px; padding-left: 2px }
.hidenone { display: none }
.big_img{position: fixed;z-index: -1;opacity: 0;background: rgba(0,0,0,0.9);width: 100%;height: 100%;top:0;left:0;}
.big_img .swiper-container2 {position: relative;width: 100%;height: 100%;}
.big_img .swiper-container2 .swiper-wrapper{width: 100%;height: 100%;}
.big_img .swiper-slide{width: 100%;height: 100%;display: table}
.big_img .swiper-slide .cell{width: 100%;;height: 100%;display: table-cell;vertical-align: middle;text-align: center;}
.big_img .swiper-slide img{max-width: 90%;max-height: 80%;margin:0 auto;}
.big_img .swiper-pagination2{position: absolute; top:0.2rem;text-align: center;width: 100%;}
.big_img .swiper-pagination2 span{margin:0 0.05rem;}
(2)swiper.min.css
/**
* Swiper 3.3.1
* Most modern mobile touch slider and framework with hardware accelerated transitions
*
* http://www.idangero.us/swiper/
*
* Copyright 2016, Vladimir Kharlampidi
* The iDangero.us
* http://www.idangero.us/
*
* Licensed under MIT
*
* Released on: February 7, 2016
*/
.swiper-container {
margin: 0 auto;
position: relative;
overflow: hidden;
z-index: 1
}
.swiper-container-no-flexbox .swiper-slide {
float: left
}
.swiper-container-vertical>.swiper-wrapper {
-webkit-box-orient: vertical;
-moz-box-orient: vertical;
-ms-flex-direction: column;
-webkit-flex-direction: column;
flex-direction: column
}
.swiper-wrapper {
position: relative;
width: 100%;
height: 100%;
z-index: 1;
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-transition-property: -webkit-transform;
-moz-transition-property: -moz-transform;
-o-transition-property: -o-transform;
-ms-transition-property: -ms-transform;
transition-property: transform;
-webkit-box-sizing: content-box;
-moz-box-sizing: content-box;
box-sizing: content-box
}
.swiper-container-android .swiper-slide,.swiper-wrapper {
-webkit-transform: translate3d(0,0,0);
-moz-transform: translate3d(0,0,0);
-o-transform: translate(0,0);
-ms-transform: translate3d(0,0,0);
transform: translate3d(0,0,0)
}
.swiper-container-multirow>.swiper-wrapper {
-webkit-box-lines: multiple;
-moz-box-lines: multiple;
-ms-flex-wrap: wrap;
-webkit-flex-wrap: wrap;
flex-wrap: wrap
}
.swiper-container-free-mode>.swiper-wrapper {
-webkit-transition-timing-function: ease-out;
-moz-transition-timing-function: ease-out;
-ms-transition-timing-function: ease-out;
-o-transition-timing-function: ease-out;
transition-timing-function: ease-out;
margin: 0 auto
}
.swiper-slide {
-webkit-flex-shrink: 0;
-ms-flex: 0 0 auto;
flex-shrink: 0;
width: 100%;
height: 100%;
position: relative
}
.swiper-container-autoheight,.swiper-container-autoheight .swiper-slide {
height: auto
}
.swiper-container-autoheight .swiper-wrapper {
-webkit-box-align: start;
-ms-flex-align: start;
-webkit-align-items: flex-start;
align-items: flex-start;
-webkit-transition-property: -webkit-transform,height;
-moz-transition-property: -moz-transform;
-o-transition-property: -o-transform;
-ms-transition-property: -ms-transform;
transition-property: transform,height
}
.swiper-container .swiper-notification {
position: absolute;
left: 0;
top: 0;
pointer-events: none;
opacity: 0;
z-index: -1000
}
.swiper-wp8-horizontal {
-ms-touch-action: pan-y;
touch-action: pan-y
}
.swiper-wp8-vertical {
-ms-touch-action: pan-x;
touch-action: pan-x
}
.swiper-button-next,.swiper-button-prev {
position: absolute;
top: 50%;
width: 27px;
height: 44px;
margin-top: -22px;
z-index: 10;
cursor: pointer;
-moz-background-size: 27px 44px;
-webkit-background-size: 27px 44px;
background-size: 27px 44px;
background-position: center;
background-repeat: no-repeat
}
.swiper-button-next.swiper-button-disabled,.swiper-button-prev.swiper-button-disabled {
opacity: .35;
cursor: auto;
pointer-events: none
}
.swiper-button-prev,.swiper-container-rtl .swiper-button-next {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
left: 10px;
right: auto
}
.swiper-button-prev.swiper-button-black,.swiper-container-rtl .swiper-button-next.swiper-button-black {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E")
}
.swiper-button-prev.swiper-button-white,.swiper-container-rtl .swiper-button-next.swiper-button-white {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E")
}
.swiper-button-next,.swiper-container-rtl .swiper-button-prev {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
right: 10px;
left: auto
}
.swiper-button-next.swiper-button-black,.swiper-container-rtl .swiper-button-prev.swiper-button-black {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E")
}
.swiper-button-next.swiper-button-white,.swiper-container-rtl .swiper-button-prev.swiper-button-white {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E")
}
.swiper-pagination {
position: absolute;
text-align: center;
-webkit-transition: .3s;
-moz-transition: .3s;
-o-transition: .3s;
transition: .3s;
-webkit-transform: translate3d(0,0,0);
-ms-transform: translate3d(0,0,0);
-o-transform: translate3d(0,0,0);
transform: translate3d(0,0,0);
z-index: 10
}
.swiper-pagination.swiper-pagination-hidden {
opacity: 0
}
.swiper-container-horizontal>.swiper-pagination-bullets,.swiper-pagination-custom,.swiper-pagination-fraction {
bottom: 1px;
left: 0;
width: 100%
}
.swiper-pagination-bullet {
width: 8px;
height: 8px;
display: inline-block;
border-radius: 100%;
border: 1px solid #fff;
}
button.swiper-pagination-bullet {
border: none;
margin: 0;
padding: 0;
box-shadow: none;
-moz-appearance: none;
-ms-appearance: none;
-webkit-appearance: none;
appearance: none
}
.swiper-pagination-clickable .swiper-pagination-bullet {
cursor: pointer
}
.swiper-pagination-white .swiper-pagination-bullet {
background: #fff
}
.swiper-pagination-bullet-active {
opacity: 1;
background: #fff
}
.swiper-pagination-white .swiper-pagination-bullet-active {
background: #fff
}
.swiper-pagination-black .swiper-pagination-bullet-active {
background: #000
}
.swiper-container-vertical>.swiper-pagination-bullets {
right: 10px;
top: 50%;
-webkit-transform: translate3d(0,-50%,0);
-moz-transform: translate3d(0,-50%,0);
-o-transform: translate(0,-50%);
-ms-transform: translate3d(0,-50%,0);
transform: translate3d(0,-50%,0)
}
.swiper-container-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
margin: 5px 0;
display: block
}
.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
margin: 0 5px
}
.swiper-pagination-progress {
background: rgba(0,0,0,.25);
position: absolute
}
.swiper-pagination-progress .swiper-pagination-progressbar {
background: #007aff;
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
-webkit-transform: scale(0);
-ms-transform: scale(0);
-o-transform: scale(0);
transform: scale(0);
-webkit-transform-origin: left top;
-moz-transform-origin: left top;
-ms-transform-origin: left top;
-o-transform-origin: left top;
transform-origin: left top
}
.swiper-container-rtl .swiper-pagination-progress .swiper-pagination-progressbar {
-webkit-transform-origin: right top;
-moz-transform-origin: right top;
-ms-transform-origin: right top;
-o-transform-origin: right top;
transform-origin: right top
}
.swiper-container-horizontal>.swiper-pagination-progress {
width: 100%;
height: 4px;
left: 0;
top: 0
}
.swiper-container-vertical>.swiper-pagination-progress {
width: 4px;
height: 100%;
left: 0;
top: 0
}
.swiper-pagination-progress.swiper-pagination-white {
background: rgba(255,255,255,.5)
}
.swiper-pagination-progress.swiper-pagination-white .swiper-pagination-progressbar {
background: #fff
}
.swiper-pagination-progress.swiper-pagination-black .swiper-pagination-progressbar {
background: #000
}
.swiper-container-3d {
-webkit-perspective: 1200px;
-moz-perspective: 1200px;
-o-perspective: 1200px;
perspective: 1200px
}
.swiper-container-3d .swiper-cube-shadow,.swiper-container-3d .swiper-slide,.swiper-container-3d .swiper-slide-shadow-bottom,.swiper-container-3d .swiper-slide-shadow-left,.swiper-container-3d .swiper-slide-shadow-right,.swiper-container-3d .swiper-slide-shadow-top,.swiper-container-3d .swiper-wrapper {
-webkit-transform-style: preserve-3d;
-moz-transform-style: preserve-3d;
-ms-transform-style: preserve-3d;
transform-style: preserve-3d
}
.swiper-container-3d .swiper-slide-shadow-bottom,.swiper-container-3d .swiper-slide-shadow-left,.swiper-container-3d .swiper-slide-shadow-right,.swiper-container-3d .swiper-slide-shadow-top {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
pointer-events: none;
z-index: 10
}
.swiper-container-3d .swiper-slide-shadow-left {
background-image: -webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
background-image: -webkit-linear-gradient(right,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -moz-linear-gradient(right,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -o-linear-gradient(right,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: linear-gradient(to left,rgba(0,0,0,.5),rgba(0,0,0,0))
}
.swiper-container-3d .swiper-slide-shadow-right {
background-image: -webkit-gradient(linear,right top,left top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
background-image: -webkit-linear-gradient(left,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -moz-linear-gradient(left,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -o-linear-gradient(left,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: linear-gradient(to right,rgba(0,0,0,.5),rgba(0,0,0,0))
}
.swiper-container-3d .swiper-slide-shadow-top {
background-image: -webkit-gradient(linear,left top,left bottom,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
background-image: -webkit-linear-gradient(bottom,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -moz-linear-gradient(bottom,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -o-linear-gradient(bottom,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: linear-gradient(to top,rgba(0,0,0,.5),rgba(0,0,0,0))
}
.swiper-container-3d .swiper-slide-shadow-bottom {
background-image: -webkit-gradient(linear,left bottom,left top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
background-image: -webkit-linear-gradient(top,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -moz-linear-gradient(top,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: -o-linear-gradient(top,rgba(0,0,0,.5),rgba(0,0,0,0));
background-image: linear-gradient(to bottom,rgba(0,0,0,.5),rgba(0,0,0,0))
}
.swiper-container-coverflow .swiper-wrapper,.swiper-container-flip .swiper-wrapper {
-ms-perspective: 1200px
}
.swiper-container-cube,.swiper-container-flip {
overflow: visible
}
.swiper-container-cube .swiper-slide,.swiper-container-flip .swiper-slide {
pointer-events: none;
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
-ms-backface-visibility: hidden;
backface-visibility: hidden;
z-index: 1
}
.swiper-container-cube .swiper-slide .swiper-slide,.swiper-container-flip .swiper-slide .swiper-slide {
pointer-events: none
}
.swiper-container-cube .swiper-slide-active,.swiper-container-cube .swiper-slide-active .swiper-slide-active,.swiper-container-flip .swiper-slide-active,.swiper-container-flip .swiper-slide-active .swiper-slide-active {
pointer-events: auto
}
.swiper-container-cube .swiper-slide-shadow-bottom,.swiper-container-cube .swiper-slide-shadow-left,.swiper-container-cube .swiper-slide-shadow-right,.swiper-container-cube .swiper-slide-shadow-top,.swiper-container-flip .swiper-slide-shadow-bottom,.swiper-container-flip .swiper-slide-shadow-left,.swiper-container-flip .swiper-slide-shadow-right,.swiper-container-flip .swiper-slide-shadow-top {
z-index: 0;
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
-ms-backface-visibility: hidden;
backface-visibility: hidden
}
.swiper-container-cube .swiper-slide {
visibility: hidden;
-webkit-transform-origin: 0 0;
-moz-transform-origin: 0 0;
-ms-transform-origin: 0 0;
transform-origin: 0 0;
width: 100%;
height: 100%
}
.swiper-container-cube.swiper-container-rtl .swiper-slide {
-webkit-transform-origin: 100% 0;
-moz-transform-origin: 100% 0;
-ms-transform-origin: 100% 0;
transform-origin: 100% 0
}
.swiper-container-cube .swiper-slide-active,.swiper-container-cube .swiper-slide-next,.swiper-container-cube .swiper-slide-next+.swiper-slide,.swiper-container-cube .swiper-slide-prev {
pointer-events: auto;
visibility: visible
}
.swiper-container-cube .swiper-cube-shadow {
position: absolute;
left: 0;
bottom: 0;
width: 100%;
height: 100%;
background: #000;
opacity: .6;
-webkit-filter: blur(50px);
filter: blur(50px);
z-index: 0
}
.swiper-container-fade.swiper-container-free-mode .swiper-slide {
-webkit-transition-timing-function: ease-out;
-moz-transition-timing-function: ease-out;
-ms-transition-timing-function: ease-out;
-o-transition-timing-function: ease-out;
transition-timing-function: ease-out
}
.swiper-container-fade .swiper-slide {
pointer-events: none;
-webkit-transition-property: opacity;
-moz-transition-property: opacity;
-o-transition-property: opacity;
transition-property: opacity
}
.swiper-container-fade .swiper-slide .swiper-slide {
pointer-events: none
}
.swiper-container-fade .swiper-slide-active,.swiper-container-fade .swiper-slide-active .swiper-slide-active {
pointer-events: auto
}
.swiper-scrollbar {
border-radius: 10px;
position: relative;
-ms-touch-action: none;
background: rgba(0,0,0,.1)
}
.swiper-container-horizontal>.swiper-scrollbar {
position: absolute;
left: 1%;
bottom: 3px;
z-index: 50;
height: 5px;
width: 98%
}
.swiper-container-vertical>.swiper-scrollbar {
position: absolute;
right: 3px;
top: 1%;
z-index: 50;
width: 5px;
height: 98%
}
.swiper-scrollbar-drag {
height: 100%;
width: 100%;
position: relative;
background: rgba(0,0,0,.5);
border-radius: 10px;
left: 0;
top: 0
}
.swiper-scrollbar-cursor-drag {
cursor: move
}
.swiper-lazy-preloader {
width: 42px;
height: 42px;
position: absolute;
left: 50%;
top: 50%;
margin-left: -21px;
margin-top: -21px;
z-index: 10;
-webkit-transform-origin: 50%;
-moz-transform-origin: 50%;
transform-origin: 50%;
-webkit-animation: swiper-preloader-spin 1s steps(12,end) infinite;
-moz-animation: swiper-preloader-spin 1s steps(12,end) infinite;
animation: swiper-preloader-spin 1s steps(12,end) infinite
}
.swiper-lazy-preloader:after {
display: block;
content: "";
width: 100%;
height: 100%;
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%236c6c6c'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
background-position: 50%;
-webkit-background-size: 100%;
background-size: 100%;
background-repeat: no-repeat
}
.swiper-lazy-preloader-white:after {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%23fff'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
}
@-webkit-keyframes swiper-preloader-spin {
100% {
-webkit-transform: rotate(360deg)
}
}
@keyframes swiper-preloader-spin {
100% {
transform: rotate(360deg)
}
}
3.js
(1)jquery.min.js
/**
* Created by Administrator on 2016/1/31.
*/
/*! jQuery v1.11.0 | (c) 2005, 2014 jQuery Foundation, Inc. | jquery.org/license */
!
function(a, b) {
"object" == typeof module && "object" == typeof module.exports ? module.exports = a.document ? b(a, !0) : function(a) {
if (!a.document) throw new Error("jQuery requires a window with a document");
return b(a)
}: b(a)
} ("undefined" != typeof window ? window: this,
function(a, b) {
var c = [],
d = c.slice,
e = c.concat,
f = c.push,
g = c.indexOf,
h = {},
i = h.toString,
j = h.hasOwnProperty,
k = "".trim,
l = {},
m = "1.11.0",
n = function(a, b) {
return new n.fn.init(a, b)
},
o = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
p = /^-ms-/,
q = /-([\da-z])/gi,
r = function(a, b) {
return b.toUpperCase()
};
n.fn = n.prototype = {
jquery: m,
constructor: n,
selector: "",
length: 0,
toArray: function() {
return d.call(this)
},
get: function(a) {
return null != a ? 0 > a ? this[a + this.length] : this[a] : d.call(this)
},
pushStack: function(a) {
var b = n.merge(this.constructor(), a);
return b.prevObject = this,
b.context = this.context,
b
},
each: function(a, b) {
return n.each(this, a, b)
},
map: function(a) {
return this.pushStack(n.map(this,
function(b, c) {
return a.call(b, c, b)
}))
},
slice: function() {
return this.pushStack(d.apply(this, arguments))
},
first: function() {
return this.eq(0)
},
last: function() {
return this.eq( - 1)
},
eq: function(a) {
var b = this.length,
c = +a + (0 > a ? b: 0);
return this.pushStack(c >= 0 && b > c ? [this[c]] : [])
},
end: function() {
return this.prevObject || this.constructor(null)
},
push: f,
sort: c.sort,
splice: c.splice
},
n.extend = n.fn.extend = function() {
var a, b, c, d, e, f, g = arguments[0] || {},
h = 1,
i = arguments.length,
j = !1;
for ("boolean" == typeof g && (j = g, g = arguments[h] || {},
h++), "object" == typeof g || n.isFunction(g) || (g = {}), h === i && (g = this, h--); i > h; h++) if (null != (e = arguments[h])) for (d in e) a = g[d],
c = e[d],
g !== c && (j && c && (n.isPlainObject(c) || (b = n.isArray(c))) ? (b ? (b = !1, f = a && n.isArray(a) ? a: []) : f = a && n.isPlainObject(a) ? a: {},
g[d] = n.extend(j, f, c)) : void 0 !== c && (g[d] = c));
return g
},
n.extend({
expando: "jQuery" + (m + Math.random()).replace(/\D/g, ""),
isReady: !0,
error: function(a) {
throw new Error(a)
},
noop: function() {},
isFunction: function(a) {
return "function" === n.type(a)
},
isArray: Array.isArray ||
function(a) {
return "array" === n.type(a)
},
isWindow: function(a) {
return null != a && a == a.window
},
isNumeric: function(a) {
return a - parseFloat(a) >= 0
},
isEmptyObject: function(a) {
var b;
for (b in a) return ! 1;
return ! 0
},
isPlainObject: function(a) {
var b;
if (!a || "object" !== n.type(a) || a.nodeType || n.isWindow(a)) return ! 1;
try {
if (a.constructor && !j.call(a, "constructor") && !j.call(a.constructor.prototype, "isPrototypeOf")) return ! 1
} catch(c) {
return ! 1
}
if (l.ownLast) for (b in a) return j.call(a, b);
for (b in a);
return void 0 === b || j.call(a, b)
},
type: function(a) {
return null == a ? a + "": "object" == typeof a || "function" == typeof a ? h[i.call(a)] || "object": typeof a
},
globalEval: function(b) {
b && n.trim(b) && (a.execScript ||
function(b) {
a.eval.call(a, b)
})(b)
},
camelCase: function(a) {
return a.replace(p, "ms-").replace(q, r)
},
nodeName: function(a, b) {
return a.nodeName && a.nodeName.toLowerCase() === b.toLowerCase()
},
each: function(a, b, c) {
var d, e = 0,
f = a.length,
g = s(a);
if (c) {
if (g) {
for (; f > e; e++) if (d = b.apply(a[e], c), d === !1) break
} else for (e in a) if (d = b.apply(a[e], c), d === !1) break
} else if (g) {
for (; f > e; e++) if (d = b.call(a[e], e, a[e]), d === !1) break
} else for (e in a) if (d = b.call(a[e], e, a[e]), d === !1) break;
return a
},
trim: k && !k.call("\ufeff\xa0") ?
function(a) {
return null == a ? "": k.call(a)
}: function(a) {
return null == a ? "": (a + "").replace(o, "")
},
makeArray: function(a, b) {
var c = b || [];
return null != a && (s(Object(a)) ? n.merge(c, "string" == typeof a ? [a] : a) : f.call(c, a)),
c
},
inArray: function(a, b, c) {
var d;
if (b) {
if (g) return g.call(b, a, c);
for (d = b.length, c = c ? 0 > c ? Math.max(0, d + c) : c: 0; d > c; c++) if (c in b && b[c] === a) return c
}
return - 1
},
merge: function(a, b) {
var c = +b.length,
d = 0,
e = a.length;
while (c > d) a[e++] = b[d++];
if (c !== c) while (void 0 !== b[d]) a[e++] = b[d++];
return a.length = e,
a
},
grep: function(a, b, c) {
for (var d, e = [], f = 0, g = a.length, h = !c; g > f; f++) d = !b(a[f], f),
d !== h && e.push(a[f]);
return e
},
map: function(a, b, c) {
var d, f = 0,
g = a.length,
h = s(a),
i = [];
if (h) for (; g > f; f++) d = b(a[f], f, c),
null != d && i.push(d);
else for (f in a) d = b(a[f], f, c),
null != d && i.push(d);
return e.apply([], i)
},
guid: 1,
proxy: function(a, b) {
var c, e, f;
return "string" == typeof b && (f = a[b], b = a, a = f),
n.isFunction(a) ? (c = d.call(arguments, 2), e = function() {
return a.apply(b || this, c.concat(d.call(arguments)))
},
e.guid = a.guid = a.guid || n.guid++, e) : void 0
},
now: function() {
return + new Date
},
support: l
}),
n.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),
function(a, b) {
h["[object " + b + "]"] = b.toLowerCase()
});
function s(a) {
var b = a.length,
c = n.type(a);
return "function" === c || n.isWindow(a) ? !1 : 1 === a.nodeType && b ? !0 : "array" === c || 0 === b || "number" == typeof b && b > 0 && b - 1 in a
}
var t = function(a) {
var b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s = "sizzle" + -new Date,
t = a.document,
u = 0,
v = 0,
w = eb(),
x = eb(),
y = eb(),
z = function(a, b) {
return a === b && (j = !0),
0
},
A = "undefined",
B = 1 << 31,
C = {}.hasOwnProperty,
D = [],
E = D.pop,
F = D.push,
G = D.push,
H = D.slice,
I = D.indexOf ||
function(a) {
for (var b = 0,
c = this.length; c > b; b++) if (this[b] === a) return b;
return - 1
},
J = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
K = "[\\x20\\t\\r\\n\\f]",
L = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",
M = L.replace("w", "w#"),
N = "\\[" + K + "*(" + L + ")" + K + "*(?:([*^$|!~]?=)" + K + "*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|(" + M + ")|)|)" + K + "*\\]",
O = ":(" + L + ")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|" + N.replace(3, 8) + ")*)|.*)\\)|)",
P = new RegExp("^" + K + "+|((?:^|[^\\\\])(?:\\\\.)*)" + K + "+$", "g"),
Q = new RegExp("^" + K + "*," + K + "*"),
R = new RegExp("^" + K + "*([>+~]|" + K + ")" + K + "*"),
S = new RegExp("=" + K + "*([^\\]'\"]*?)" + K + "*\\]", "g"),
T = new RegExp(O),
U = new RegExp("^" + M + "$"),
V = {
ID: new RegExp("^#(" + L + ")"),
CLASS: new RegExp("^\\.(" + L + ")"),
TAG: new RegExp("^(" + L.replace("w", "w*") + ")"),
ATTR: new RegExp("^" + N),
PSEUDO: new RegExp("^" + O),
CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + K + "*(even|odd|(([+-]|)(\\d*)n|)" + K + "*(?:([+-]|)" + K + "*(\\d+)|))" + K + "*\\)|)", "i"),
bool: new RegExp("^(?:" + J + ")$", "i"),
needsContext: new RegExp("^" + K + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + K + "*((?:-\\d)?\\d*)" + K + "*\\)|)(?=[^-]|$)", "i")
},
W = /^(?:input|select|textarea|button)$/i,
X = /^h\d$/i,
Y = /^[^{]+\{\s*\[native \w/,
Z = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
$ = /[+~]/,
_ = /'|\\/g,
ab = new RegExp("\\\\([\\da-f]{1,6}" + K + "?|(" + K + ")|.)", "ig"),
bb = function(a, b, c) {
var d = "0x" + b - 65536;
return d !== d || c ? b: 0 > d ? String.fromCharCode(d + 65536) : String.fromCharCode(d >> 10 | 55296, 1023 & d | 56320)
};
try {
G.apply(D = H.call(t.childNodes), t.childNodes),
D[t.childNodes.length].nodeType
} catch(cb) {
G = {
apply: D.length ?
function(a, b) {
F.apply(a, H.call(b))
}: function(a, b) {
var c = a.length,
d = 0;
while (a[c++] = b[d++]);
a.length = c - 1
}
}
}
function db(a, b, d, e) {
var f, g, h, i, j, m, p, q, u, v;
if ((b ? b.ownerDocument || b: t) !== l && k(b), b = b || l, d = d || [], !a || "string" != typeof a) return d;
if (1 !== (i = b.nodeType) && 9 !== i) return [];
if (n && !e) {
if (f = Z.exec(a)) if (h = f[1]) {
if (9 === i) {
if (g = b.getElementById(h), !g || !g.parentNode) return d;
if (g.id === h) return d.push(g),
d
} else if (b.ownerDocument && (g = b.ownerDocument.getElementById(h)) && r(b, g) && g.id === h) return d.push(g),
d
} else {
if (f[2]) return G.apply(d, b.getElementsByTagName(a)),
d;
if ((h = f[3]) && c.getElementsByClassName && b.getElementsByClassName) return G.apply(d, b.getElementsByClassName(h)),
d
}
if (c.qsa && (!o || !o.test(a))) {
if (q = p = s, u = b, v = 9 === i && a, 1 === i && "object" !== b.nodeName.toLowerCase()) {
m = ob(a),
(p = b.getAttribute("id")) ? q = p.replace(_, "\\$&") : b.setAttribute("id", q),
q = "[id='" + q + "'] ",
j = m.length;
while (j--) m[j] = q + pb(m[j]);
u = $.test(a) && mb(b.parentNode) || b,
v = m.join(",")
}
if (v) try {
return G.apply(d, u.querySelectorAll(v)),
d
} catch(w) {} finally {
p || b.removeAttribute("id")
}
}
}
return xb(a.replace(P, "$1"), b, d, e)
}
function eb() {
var a = [];
function b(c, e) {
return a.push(c + " ") > d.cacheLength && delete b[a.shift()],
b[c + " "] = e
}
return b
}
function fb(a) {
return a[s] = !0,
a
}
function gb(a) {
var b = l.createElement("div");
try {
return !! a(b)
} catch(c) {
return ! 1
} finally {
b.parentNode && b.parentNode.removeChild(b),
b = null
}
}
function hb(a, b) {
var c = a.split("|"),
e = a.length;
while (e--) d.attrHandle[c[e]] = b
}
function ib(a, b) {
var c = b && a,
d = c && 1 === a.nodeType && 1 === b.nodeType && (~b.sourceIndex || B) - (~a.sourceIndex || B);
if (d) return d;
if (c) while (c = c.nextSibling) if (c === b) return - 1;
return a ? 1 : -1
}
function jb(a) {
return function(b) {
var c = b.nodeName.toLowerCase();
return "input" === c && b.type === a
}
}
function kb(a) {
return function(b) {
var c = b.nodeName.toLowerCase();
return ("input" === c || "button" === c) && b.type === a
}
}
function lb(a) {
return fb(function(b) {
return b = +b,
fb(function(c, d) {
var e, f = a([], c.length, b),
g = f.length;
while (g--) c[e = f[g]] && (c[e] = !(d[e] = c[e]))
})
})
}
function mb(a) {
return a && typeof a.getElementsByTagName !== A && a
}
c = db.support = {},
f = db.isXML = function(a) {
var b = a && (a.ownerDocument || a).documentElement;
return b ? "HTML" !== b.nodeName: !1
},
k = db.setDocument = function(a) {
var b, e = a ? a.ownerDocument || a: t,
g = e.defaultView;
return e !== l && 9 === e.nodeType && e.documentElement ? (l = e, m = e.documentElement, n = !f(e), g && g !== g.top && (g.addEventListener ? g.addEventListener("unload",
function() {
k()
},
!1) : g.attachEvent && g.attachEvent("onunload",
function() {
k()
})), c.attributes = gb(function(a) {
return a.className = "i",
!a.getAttribute("className")
}), c.getElementsByTagName = gb(function(a) {
return a.appendChild(e.createComment("")),
!a.getElementsByTagName("*").length
}), c.getElementsByClassName = Y.test(e.getElementsByClassName) && gb(function(a) {
return a.innerHTML = "<div class='a'></div><div class='a i'></div>",
a.firstChild.className = "i",
2 === a.getElementsByClassName("i").length
}), c.getById = gb(function(a) {
return m.appendChild(a).id = s,
!e.getElementsByName || !e.getElementsByName(s).length
}), c.getById ? (d.find.ID = function(a, b) {
if (typeof b.getElementById !== A && n) {
var c = b.getElementById(a);
return c && c.parentNode ? [c] : []
}
},
d.filter.ID = function(a) {
var b = a.replace(ab, bb);
return function(a) {
return a.getAttribute("id") === b
}
}) : (delete d.find.ID, d.filter.ID = function(a) {
var b = a.replace(ab, bb);
return function(a) {
var c = typeof a.getAttributeNode !== A && a.getAttributeNode("id");
return c && c.value === b
}
}), d.find.TAG = c.getElementsByTagName ?
function(a, b) {
return typeof b.getElementsByTagName !== A ? b.getElementsByTagName(a) : void 0
}: function(a, b) {
var c, d = [],
e = 0,
f = b.getElementsByTagName(a);
if ("*" === a) {
while (c = f[e++]) 1 === c.nodeType && d.push(c);
return d
}
return f
},
d.find.CLASS = c.getElementsByClassName &&
function(a, b) {
return typeof b.getElementsByClassName !== A && n ? b.getElementsByClassName(a) : void 0
},
p = [], o = [], (c.qsa = Y.test(e.querySelectorAll)) && (gb(function(a) {
a.innerHTML = "<select t=''><option selected=''></option></select>",
a.querySelectorAll("[t^='']").length && o.push("[*^$]=" + K + "*(?:''|\"\")"),
a.querySelectorAll("[selected]").length || o.push("\\[" + K + "*(?:value|" + J + ")"),
a.querySelectorAll(":checked").length || o.push(":checked")
}), gb(function(a) {
var b = e.createElement("input");
b.setAttribute("type", "hidden"),
a.appendChild(b).setAttribute("name", "D"),
a.querySelectorAll("[name=d]").length && o.push("name" + K + "*[*^$|!~]?="),
a.querySelectorAll(":enabled").length || o.push(":enabled", ":disabled"),
a.querySelectorAll("*,:x"),
o.push(",.*:")
})), (c.matchesSelector = Y.test(q = m.webkitMatchesSelector || m.mozMatchesSelector || m.oMatchesSelector || m.msMatchesSelector)) && gb(function(a) {
c.disconnectedMatch = q.call(a, "div"),
q.call(a, "[s!='']:x"),
p.push("!=", O)
}), o = o.length && new RegExp(o.join("|")), p = p.length && new RegExp(p.join("|")), b = Y.test(m.compareDocumentPosition), r = b || Y.test(m.contains) ?
function(a, b) {
var c = 9 === a.nodeType ? a.documentElement: a,
d = b && b.parentNode;
return a === d || !(!d || 1 !== d.nodeType || !(c.contains ? c.contains(d) : a.compareDocumentPosition && 16 & a.compareDocumentPosition(d)))
}: function(a, b) {
if (b) while (b = b.parentNode) if (b === a) return ! 0;
return ! 1
},
z = b ?
function(a, b) {
if (a === b) return j = !0,
0;
var d = !a.compareDocumentPosition - !b.compareDocumentPosition;
return d ? d: (d = (a.ownerDocument || a) === (b.ownerDocument || b) ? a.compareDocumentPosition(b) : 1, 1 & d || !c.sortDetached && b.compareDocumentPosition(a) === d ? a === e || a.ownerDocument === t && r(t, a) ? -1 : b === e || b.ownerDocument === t && r(t, b) ? 1 : i ? I.call(i, a) - I.call(i, b) : 0 : 4 & d ? -1 : 1)
}: function(a, b) {
if (a === b) return j = !0,
0;
var c, d = 0,
f = a.parentNode,
g = b.parentNode,
h = [a],
k = [b];
if (!f || !g) return a === e ? -1 : b === e ? 1 : f ? -1 : g ? 1 : i ? I.call(i, a) - I.call(i, b) : 0;
if (f === g) return ib(a, b);
c = a;
while (c = c.parentNode) h.unshift(c);
c = b;
while (c = c.parentNode) k.unshift(c);
while (h[d] === k[d]) d++;
return d ? ib(h[d], k[d]) : h[d] === t ? -1 : k[d] === t ? 1 : 0
},
e) : l
},
db.matches = function(a, b) {
return db(a, null, null, b)
},
db.matchesSelector = function(a, b) {
if ((a.ownerDocument || a) !== l && k(a), b = b.replace(S, "='$1']"), !(!c.matchesSelector || !n || p && p.test(b) || o && o.test(b))) try {
var d = q.call(a, b);
if (d || c.disconnectedMatch || a.document && 11 !== a.document.nodeType) return d
} catch(e) {}
return db(b, l, null, [a]).length > 0
},
db.contains = function(a, b) {
return (a.ownerDocument || a) !== l && k(a),
r(a, b)
},
db.attr = function(a, b) { (a.ownerDocument || a) !== l && k(a);
var e = d.attrHandle[b.toLowerCase()],
f = e && C.call(d.attrHandle, b.toLowerCase()) ? e(a, b, !n) : void 0;
return void 0 !== f ? f: c.attributes || !n ? a.getAttribute(b) : (f = a.getAttributeNode(b)) && f.specified ? f.value: null
},
db.error = function(a) {
throw new Error("Syntax error, unrecognized expression: " + a)
},
db.uniqueSort = function(a) {
var b, d = [],
e = 0,
f = 0;
if (j = !c.detectDuplicates, i = !c.sortStable && a.slice(0), a.sort(z), j) {
while (b = a[f++]) b === a[f] && (e = d.push(f));
while (e--) a.splice(d[e], 1)
}
return i = null,
a
},
e = db.getText = function(a) {
var b, c = "",
d = 0,
f = a.nodeType;
if (f) {
if (1 === f || 9 === f || 11 === f) {
if ("string" == typeof a.textContent) return a.textContent;
for (a = a.firstChild; a; a = a.nextSibling) c += e(a)
} else if (3 === f || 4 === f) return a.nodeValue
} else while (b = a[d++]) c += e(b);
return c
},
d = db.selectors = {
cacheLength: 50,
createPseudo: fb,
match: V,
attrHandle: {},
find: {},
relative: {
">": {
dir: "parentNode",
first: !0
},
" ": {
dir: "parentNode"
},
"+": {
dir: "previousSibling",
first: !0
},
"~": {
dir: "previousSibling"
}
},
preFilter: {
ATTR: function(a) {
return a[1] = a[1].replace(ab, bb),
a[3] = (a[4] || a[5] || "").replace(ab, bb),
"~=" === a[2] && (a[3] = " " + a[3] + " "),
a.slice(0, 4)
},
CHILD: function(a) {
return a[1] = a[1].toLowerCase(),
"nth" === a[1].slice(0, 3) ? (a[3] || db.error(a[0]), a[4] = +(a[4] ? a[5] + (a[6] || 1) : 2 * ("even" === a[3] || "odd" === a[3])), a[5] = +(a[7] + a[8] || "odd" === a[3])) : a[3] && db.error(a[0]),
a
},
PSEUDO: function(a) {
var b, c = !a[5] && a[2];
return V.CHILD.test(a[0]) ? null: (a[3] && void 0 !== a[4] ? a[2] = a[4] : c && T.test(c) && (b = ob(c, !0)) && (b = c.indexOf(")", c.length - b) - c.length) && (a[0] = a[0].slice(0, b), a[2] = c.slice(0, b)), a.slice(0, 3))
}
},
filter: {
TAG: function(a) {
var b = a.replace(ab, bb).toLowerCase();
return "*" === a ?
function() {
return ! 0
}: function(a) {
return a.nodeName && a.nodeName.toLowerCase() === b
}
},
CLASS: function(a) {
var b = w[a + " "];
return b || (b = new RegExp("(^|" + K + ")" + a + "(" + K + "|$)")) && w(a,
function(a) {
return b.test("string" == typeof a.className && a.className || typeof a.getAttribute !== A && a.getAttribute("class") || "")
})
},
ATTR: function(a, b, c) {
return function(d) {
var e = db.attr(d, a);
return null == e ? "!=" === b: b ? (e += "", "=" === b ? e === c: "!=" === b ? e !== c: "^=" === b ? c && 0 === e.indexOf(c) : "*=" === b ? c && e.indexOf(c) > -1 : "$=" === b ? c && e.slice( - c.length) === c: "~=" === b ? (" " + e + " ").indexOf(c) > -1 : "|=" === b ? e === c || e.slice(0, c.length + 1) === c + "-": !1) : !0
}
},
CHILD: function(a, b, c, d, e) {
var f = "nth" !== a.slice(0, 3),
g = "last" !== a.slice( - 4),
h = "of-type" === b;
return 1 === d && 0 === e ?
function(a) {
return !! a.parentNode
}: function(b, c, i) {
var j, k, l, m, n, o, p = f !== g ? "nextSibling": "previousSibling",
q = b.parentNode,
r = h && b.nodeName.toLowerCase(),
t = !i && !h;
if (q) {
if (f) {
while (p) {
l = b;
while (l = l[p]) if (h ? l.nodeName.toLowerCase() === r: 1 === l.nodeType) return ! 1;
o = p = "only" === a && !o && "nextSibling"
}
return ! 0
}
if (o = [g ? q.firstChild: q.lastChild], g && t) {
k = q[s] || (q[s] = {}),
j = k[a] || [],
n = j[0] === u && j[1],
m = j[0] === u && j[2],
l = n && q.childNodes[n];
while (l = ++n && l && l[p] || (m = n = 0) || o.pop()) if (1 === l.nodeType && ++m && l === b) {
k[a] = [u, n, m];
break
}
} else if (t && (j = (b[s] || (b[s] = {}))[a]) && j[0] === u) m = j[1];
else while (l = ++n && l && l[p] || (m = n = 0) || o.pop()) if ((h ? l.nodeName.toLowerCase() === r: 1 === l.nodeType) && ++m && (t && ((l[s] || (l[s] = {}))[a] = [u, m]), l === b)) break;
return m -= e,
m === d || m % d === 0 && m / d >= 0
}
}
},
PSEUDO: function(a, b) {
var c, e = d.pseudos[a] || d.setFilters[a.toLowerCase()] || db.error("unsupported pseudo: " + a);
return e[s] ? e(b) : e.length > 1 ? (c = [a, a, "", b], d.setFilters.hasOwnProperty(a.toLowerCase()) ? fb(function(a, c) {
var d, f = e(a, b),
g = f.length;
while (g--) d = I.call(a, f[g]),
a[d] = !(c[d] = f[g])
}) : function(a) {
return e(a, 0, c)
}) : e
}
},
pseudos: {
not: fb(function(a) {
var b = [],
c = [],
d = g(a.replace(P, "$1"));
return d[s] ? fb(function(a, b, c, e) {
var f, g = d(a, null, e, []),
h = a.length;
while (h--)(f = g[h]) && (a[h] = !(b[h] = f))
}) : function(a, e, f) {
return b[0] = a,
d(b, null, f, c),
!c.pop()
}
}),
has: fb(function(a) {
return function(b) {
return db(a, b).length > 0
}
}),
contains: fb(function(a) {
return function(b) {
return (b.textContent || b.innerText || e(b)).indexOf(a) > -1
}
}),
lang: fb(function(a) {
return U.test(a || "") || db.error("unsupported lang: " + a),
a = a.replace(ab, bb).toLowerCase(),
function(b) {
var c;
do
if (c = n ? b.lang: b.getAttribute("xml:lang") || b.getAttribute("lang")) return c = c.toLowerCase(),
c === a || 0 === c.indexOf(a + "-");
while ((b = b.parentNode) && 1 === b.nodeType);
return ! 1
}
}),
target: function(b) {
var c = a.location && a.location.hash;
return c && c.slice(1) === b.id
},
root: function(a) {
return a === m
},
focus: function(a) {
return a === l.activeElement && (!l.hasFocus || l.hasFocus()) && !!(a.type || a.href || ~a.tabIndex)
},
enabled: function(a) {
return a.disabled === !1
},
disabled: function(a) {
return a.disabled === !0
},
checked: function(a) {
var b = a.nodeName.toLowerCase();
return "input" === b && !!a.checked || "option" === b && !!a.selected
},
selected: function(a) {
return a.parentNode && a.parentNode.selectedIndex,
a.selected === !0
},
empty: function(a) {
for (a = a.firstChild; a; a = a.nextSibling) if (a.nodeType < 6) return ! 1;
return ! 0
},
parent: function(a) {
return ! d.pseudos.empty(a)
},
header: function(a) {
return X.test(a.nodeName)
},
input: function(a) {
return W.test(a.nodeName)
},
button: function(a) {
var b = a.nodeName.toLowerCase();
return "input" === b && "button" === a.type || "button" === b
},
text: function(a) {
var b;
return "input" === a.nodeName.toLowerCase() && "text" === a.type && (null == (b = a.getAttribute("type")) || "text" === b.toLowerCase())
},
first: lb(function() {
return [0]
}),
last: lb(function(a, b) {
return [b - 1]
}),
eq: lb(function(a, b, c) {
return [0 > c ? c + b: c]
}),
even: lb(function(a, b) {
for (var c = 0; b > c; c += 2) a.push(c);
return a
}),
odd: lb(function(a, b) {
for (var c = 1; b > c; c += 2) a.push(c);
return a
}),
lt: lb(function(a, b, c) {
for (var d = 0 > c ? c + b: c; --d >= 0;) a.push(d);
return a
}),
gt: lb(function(a, b, c) {
for (var d = 0 > c ? c + b: c; ++d < b;) a.push(d);
return a
})
}
},
d.pseudos.nth = d.pseudos.eq;
for (b in {
radio: !0,
checkbox: !0,
file: !0,
password: !0,
image: !0
}) d.pseudos[b] = jb(b);
for (b in {
submit: !0,
reset: !0
}) d.pseudos[b] = kb(b);
function nb() {}
nb.prototype = d.filters = d.pseudos,
d.setFilters = new nb;
function ob(a, b) {
var c, e, f, g, h, i, j, k = x[a + " "];
if (k) return b ? 0 : k.slice(0);
h = a,
i = [],
j = d.preFilter;
while (h) { (!c || (e = Q.exec(h))) && (e && (h = h.slice(e[0].length) || h), i.push(f = [])),
c = !1,
(e = R.exec(h)) && (c = e.shift(), f.push({
value: c,
type: e[0].replace(P, " ")
}), h = h.slice(c.length));
for (g in d.filter) ! (e = V[g].exec(h)) || j[g] && !(e = j[g](e)) || (c = e.shift(), f.push({
value: c,
type: g,
matches: e
}), h = h.slice(c.length));
if (!c) break
}
return b ? h.length: h ? db.error(a) : x(a, i).slice(0)
}
function pb(a) {
for (var b = 0,
c = a.length,
d = ""; c > b; b++) d += a[b].value;
return d
}
function qb(a, b, c) {
var d = b.dir,
e = c && "parentNode" === d,
f = v++;
return b.first ?
function(b, c, f) {
while (b = b[d]) if (1 === b.nodeType || e) return a(b, c, f)
}: function(b, c, g) {
var h, i, j = [u, f];
if (g) {
while (b = b[d]) if ((1 === b.nodeType || e) && a(b, c, g)) return ! 0
} else while (b = b[d]) if (1 === b.nodeType || e) {
if (i = b[s] || (b[s] = {}), (h = i[d]) && h[0] === u && h[1] === f) return j[2] = h[2];
if (i[d] = j, j[2] = a(b, c, g)) return ! 0
}
}
}
function rb(a) {
return a.length > 1 ?
function(b, c, d) {
var e = a.length;
while (e--) if (!a[e](b, c, d)) return ! 1;
return ! 0
}: a[0]
}
function sb(a, b, c, d, e) {
for (var f, g = [], h = 0, i = a.length, j = null != b; i > h; h++)(f = a[h]) && (!c || c(f, d, e)) && (g.push(f), j && b.push(h));
return g
}
function tb(a, b, c, d, e, f) {
return d && !d[s] && (d = tb(d)),
e && !e[s] && (e = tb(e, f)),
fb(function(f, g, h, i) {
var j, k, l, m = [],
n = [],
o = g.length,
p = f || wb(b || "*", h.nodeType ? [h] : h, []),
q = !a || !f && b ? p: sb(p, m, a, h, i),
r = c ? e || (f ? a: o || d) ? [] : g: q;
if (c && c(q, r, h, i), d) {
j = sb(r, n),
d(j, [], h, i),
k = j.length;
while (k--)(l = j[k]) && (r[n[k]] = !(q[n[k]] = l))
}
if (f) {
if (e || a) {
if (e) {
j = [],
k = r.length;
while (k--)(l = r[k]) && j.push(q[k] = l);
e(null, r = [], j, i)
}
k = r.length;
while (k--)(l = r[k]) && (j = e ? I.call(f, l) : m[k]) > -1 && (f[j] = !(g[j] = l))
}
} else r = sb(r === g ? r.splice(o, r.length) : r),
e ? e(null, g, r, i) : G.apply(g, r)
})
}
function ub(a) {
for (var b, c, e, f = a.length,
g = d.relative[a[0].type], i = g || d.relative[" "], j = g ? 1 : 0, k = qb(function(a) {
return a === b
},
i, !0), l = qb(function(a) {
return I.call(b, a) > -1
},
i, !0), m = [function(a, c, d) {
return ! g && (d || c !== h) || ((b = c).nodeType ? k(a, c, d) : l(a, c, d))
}]; f > j; j++) if (c = d.relative[a[j].type]) m = [qb(rb(m), c)];
else {
if (c = d.filter[a[j].type].apply(null, a[j].matches), c[s]) {
for (e = ++j; f > e; e++) if (d.relative[a[e].type]) break;
return tb(j > 1 && rb(m), j > 1 && pb(a.slice(0, j - 1).concat({
value: " " === a[j - 2].type ? "*": ""
})).replace(P, "$1"), c, e > j && ub(a.slice(j, e)), f > e && ub(a = a.slice(e)), f > e && pb(a))
}
m.push(c)
}
return rb(m)
}
function vb(a, b) {
var c = b.length > 0,
e = a.length > 0,
f = function(f, g, i, j, k) {
var m, n, o, p = 0,
q = "0",
r = f && [],
s = [],
t = h,
v = f || e && d.find.TAG("*", k),
w = u += null == t ? 1 : Math.random() || .1,
x = v.length;
for (k && (h = g !== l && g); q !== x && null != (m = v[q]); q++) {
if (e && m) {
n = 0;
while (o = a[n++]) if (o(m, g, i)) {
j.push(m);
break
}
k && (u = w)
}
c && ((m = !o && m) && p--, f && r.push(m))
}
if (p += q, c && q !== p) {
n = 0;
while (o = b[n++]) o(r, s, g, i);
if (f) {
if (p > 0) while (q--) r[q] || s[q] || (s[q] = E.call(j));
s = sb(s)
}
G.apply(j, s),
k && !f && s.length > 0 && p + b.length > 1 && db.uniqueSort(j)
}
return k && (u = w, h = t),
r
};
return c ? fb(f) : f
}
g = db.compile = function(a, b) {
var c, d = [],
e = [],
f = y[a + " "];
if (!f) {
b || (b = ob(a)),
c = b.length;
while (c--) f = ub(b[c]),
f[s] ? d.push(f) : e.push(f);
f = y(a, vb(e, d))
}
return f
};
function wb(a, b, c) {
for (var d = 0,
e = b.length; e > d; d++) db(a, b[d], c);
return c
}
function xb(a, b, e, f) {
var h, i, j, k, l, m = ob(a);
if (!f && 1 === m.length) {
if (i = m[0] = m[0].slice(0), i.length > 2 && "ID" === (j = i[0]).type && c.getById && 9 === b.nodeType && n && d.relative[i[1].type]) {
if (b = (d.find.ID(j.matches[0].replace(ab, bb), b) || [])[0], !b) return e;
a = a.slice(i.shift().value.length)
}
h = V.needsContext.test(a) ? 0 : i.length;
while (h--) {
if (j = i[h], d.relative[k = j.type]) break;
if ((l = d.find[k]) && (f = l(j.matches[0].replace(ab, bb), $.test(i[0].type) && mb(b.parentNode) || b))) {
if (i.splice(h, 1), a = f.length && pb(i), !a) return G.apply(e, f),
e;
break
}
}
}
return g(a, m)(f, b, !n, e, $.test(a) && mb(b.parentNode) || b),
e
}
return c.sortStable = s.split("").sort(z).join("") === s,
c.detectDuplicates = !!j,
k(),
c.sortDetached = gb(function(a) {
return 1 & a.compareDocumentPosition(l.createElement("div"))
}),
gb(function(a) {
return a.innerHTML = "<a href='#'></a>",
"#" === a.firstChild.getAttribute("href")
}) || hb("type|href|height|width",
function(a, b, c) {
return c ? void 0 : a.getAttribute(b, "type" === b.toLowerCase() ? 1 : 2)
}),
c.attributes && gb(function(a) {
return a.innerHTML = "<input/>",
a.firstChild.setAttribute("value", ""),
"" === a.firstChild.getAttribute("value")
}) || hb("value",
function(a, b, c) {
return c || "input" !== a.nodeName.toLowerCase() ? void 0 : a.defaultValue
}),
gb(function(a) {
return null == a.getAttribute("disabled")
}) || hb(J,
function(a, b, c) {
var d;
return c ? void 0 : a[b] === !0 ? b.toLowerCase() : (d = a.getAttributeNode(b)) && d.specified ? d.value: null
}),
db
} (a);
n.find = t,
n.expr = t.selectors,
n.expr[":"] = n.expr.pseudos,
n.unique = t.uniqueSort,
n.text = t.getText,
n.isXMLDoc = t.isXML,
n.contains = t.contains;
var u = n.expr.match.needsContext,
v = /^<(\w+)\s*\/?>(?:<\/\1>|)$/,
w = /^.[^:#\[\.,]*$/;
function x(a, b, c) {
if (n.isFunction(b)) return n.grep(a,
function(a, d) {
return !! b.call(a, d, a) !== c
});
if (b.nodeType) return n.grep(a,
function(a) {
return a === b !== c
});
if ("string" == typeof b) {
if (w.test(b)) return n.filter(b, a, c);
b = n.filter(b, a)
}
return n.grep(a,
function(a) {
return n.inArray(a, b) >= 0 !== c
})
}
n.filter = function(a, b, c) {
var d = b[0];
return c && (a = ":not(" + a + ")"),
1 === b.length && 1 === d.nodeType ? n.find.matchesSelector(d, a) ? [d] : [] : n.find.matches(a, n.grep(b,
function(a) {
return 1 === a.nodeType
}))
},
n.fn.extend({
find: function(a) {
var b, c = [],
d = this,
e = d.length;
if ("string" != typeof a) return this.pushStack(n(a).filter(function() {
for (b = 0; e > b; b++) if (n.contains(d[b], this)) return ! 0
}));
for (b = 0; e > b; b++) n.find(a, d[b], c);
return c = this.pushStack(e > 1 ? n.unique(c) : c),
c.selector = this.selector ? this.selector + " " + a: a,
c
},
filter: function(a) {
return this.pushStack(x(this, a || [], !1))
},
not: function(a) {
return this.pushStack(x(this, a || [], !0))
},
is: function(a) {
return !! x(this, "string" == typeof a && u.test(a) ? n(a) : a || [], !1).length
}
});
var y, z = a.document,
A = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,
B = n.fn.init = function(a, b) {
var c, d;
if (!a) return this;
if ("string" == typeof a) {
if (c = "<" === a.charAt(0) && ">" === a.charAt(a.length - 1) && a.length >= 3 ? [null, a, null] : A.exec(a), !c || !c[1] && b) return ! b || b.jquery ? (b || y).find(a) : this.constructor(b).find(a);
if (c[1]) {
if (b = b instanceof n ? b[0] : b, n.merge(this, n.parseHTML(c[1], b && b.nodeType ? b.ownerDocument || b: z, !0)), v.test(c[1]) && n.isPlainObject(b)) for (c in b) n.isFunction(this[c]) ? this[c](b[c]) : this.attr(c, b[c]);
return this
}
if (d = z.getElementById(c[2]), d && d.parentNode) {
if (d.id !== c[2]) return y.find(a);
this.length = 1,
this[0] = d
}
return this.context = z,
this.selector = a,
this
}
return a.nodeType ? (this.context = this[0] = a, this.length = 1, this) : n.isFunction(a) ? "undefined" != typeof y.ready ? y.ready(a) : a(n) : (void 0 !== a.selector && (this.selector = a.selector, this.context = a.context), n.makeArray(a, this))
};
B.prototype = n.fn,
y = n(z);
var C = /^(?:parents|prev(?:Until|All))/,
D = {
children: !0,
contents: !0,
next: !0,
prev: !0
};
n.extend({
dir: function(a, b, c) {
var d = [],
e = a[b];
while (e && 9 !== e.nodeType && (void 0 === c || 1 !== e.nodeType || !n(e).is(c))) 1 === e.nodeType && d.push(e),
e = e[b];
return d
},
sibling: function(a, b) {
for (var c = []; a; a = a.nextSibling) 1 === a.nodeType && a !== b && c.push(a);
return c
}
}),
n.fn.extend({
has: function(a) {
var b, c = n(a, this),
d = c.length;
return this.filter(function() {
for (b = 0; d > b; b++) if (n.contains(this, c[b])) return ! 0
})
},
closest: function(a, b) {
for (var c, d = 0,
e = this.length,
f = [], g = u.test(a) || "string" != typeof a ? n(a, b || this.context) : 0; e > d; d++) for (c = this[d]; c && c !== b; c = c.parentNode) if (c.nodeType < 11 && (g ? g.index(c) > -1 : 1 === c.nodeType && n.find.matchesSelector(c, a))) {
f.push(c);
break
}
return this.pushStack(f.length > 1 ? n.unique(f) : f)
},
index: function(a) {
return a ? "string" == typeof a ? n.inArray(this[0], n(a)) : n.inArray(a.jquery ? a[0] : a, this) : this[0] && this[0].parentNode ? this.first().prevAll().length: -1
},
add: function(a, b) {
return this.pushStack(n.unique(n.merge(this.get(), n(a, b))))
},
addBack: function(a) {
return this.add(null == a ? this.prevObject: this.prevObject.filter(a))
}
});
function E(a, b) {
do a = a[b];
while (a && 1 !== a.nodeType);
return a
}
n.each({
parent: function(a) {
var b = a.parentNode;
return b && 11 !== b.nodeType ? b: null
},
parents: function(a) {
return n.dir(a, "parentNode")
},
parentsUntil: function(a, b, c) {
return n.dir(a, "parentNode", c)
},
next: function(a) {
return E(a, "nextSibling")
},
prev: function(a) {
return E(a, "previousSibling")
},
nextAll: function(a) {
return n.dir(a, "nextSibling")
},
prevAll: function(a) {
return n.dir(a, "previousSibling")
},
nextUntil: function(a, b, c) {
return n.dir(a, "nextSibling", c)
},
prevUntil: function(a, b, c) {
return n.dir(a, "previousSibling", c)
},
siblings: function(a) {
return n.sibling((a.parentNode || {}).firstChild, a)
},
children: function(a) {
return n.sibling(a.firstChild)
},
contents: function(a) {
return n.nodeName(a, "iframe") ? a.contentDocument || a.contentWindow.document: n.merge([], a.childNodes)
}
},
function(a, b) {
n.fn[a] = function(c, d) {
var e = n.map(this, b, c);
return "Until" !== a.slice( - 5) && (d = c),
d && "string" == typeof d && (e = n.filter(d, e)),
this.length > 1 && (D[a] || (e = n.unique(e)), C.test(a) && (e = e.reverse())),
this.pushStack(e)
}
});
var F = /\S+/g,
G = {};
function H(a) {
var b = G[a] = {};
return n.each(a.match(F) || [],
function(a, c) {
b[c] = !0
}),
b
}
n.Callbacks = function(a) {
a = "string" == typeof a ? G[a] || H(a) : n.extend({},
a);
var b, c, d, e, f, g, h = [],
i = !a.once && [],
j = function(l) {
for (c = a.memory && l, d = !0, f = g || 0, g = 0, e = h.length, b = !0; h && e > f; f++) if (h[f].apply(l[0], l[1]) === !1 && a.stopOnFalse) {
c = !1;
break
}
b = !1,
h && (i ? i.length && j(i.shift()) : c ? h = [] : k.disable())
},
k = {
add: function() {
if (h) {
var d = h.length; !
function f(b) {
n.each(b,
function(b, c) {
var d = n.type(c);
"function" === d ? a.unique && k.has(c) || h.push(c) : c && c.length && "string" !== d && f(c)
})
} (arguments),
b ? e = h.length: c && (g = d, j(c))
}
return this
},
remove: function() {
return h && n.each(arguments,
function(a, c) {
var d;
while ((d = n.inArray(c, h, d)) > -1) h.splice(d, 1),
b && (e >= d && e--, f >= d && f--)
}),
this
},
has: function(a) {
return a ? n.inArray(a, h) > -1 : !(!h || !h.length)
},
empty: function() {
return h = [],
e = 0,
this
},
disable: function() {
return h = i = c = void 0,
this
},
disabled: function() {
return ! h
},
lock: function() {
return i = void 0,
c || k.disable(),
this
},
locked: function() {
return ! i
},
fireWith: function(a, c) {
return ! h || d && !i || (c = c || [], c = [a, c.slice ? c.slice() : c], b ? i.push(c) : j(c)),
this
},
fire: function() {
return k.fireWith(this, arguments),
this
},
fired: function() {
return !! d
}
};
return k
},
n.extend({
Deferred: function(a) {
var b = [["resolve", "done", n.Callbacks("once memory"), "resolved"], ["reject", "fail", n.Callbacks("once memory"), "rejected"], ["notify", "progress", n.Callbacks("memory")]],
c = "pending",
d = {
state: function() {
return c
},
always: function() {
return e.done(arguments).fail(arguments),
this
},
then: function() {
var a = arguments;
return n.Deferred(function(c) {
n.each(b,
function(b, f) {
var g = n.isFunction(a[b]) && a[b];
e[f[1]](function() {
var a = g && g.apply(this, arguments);
a && n.isFunction(a.promise) ? a.promise().done(c.resolve).fail(c.reject).progress(c.notify) : c[f[0] + "With"](this === d ? c.promise() : this, g ? [a] : arguments)
})
}),
a = null
}).promise()
},
promise: function(a) {
return null != a ? n.extend(a, d) : d
}
},
e = {};
return d.pipe = d.then,
n.each(b,
function(a, f) {
var g = f[2],
h = f[3];
d[f[1]] = g.add,
h && g.add(function() {
c = h
},
b[1 ^ a][2].disable, b[2][2].lock),
e[f[0]] = function() {
return e[f[0] + "With"](this === e ? d: this, arguments),
this
},
e[f[0] + "With"] = g.fireWith
}),
d.promise(e),
a && a.call(e, e),
e
},
when: function(a) {
var b = 0,
c = d.call(arguments),
e = c.length,
f = 1 !== e || a && n.isFunction(a.promise) ? e: 0,
g = 1 === f ? a: n.Deferred(),
h = function(a, b, c) {
return function(e) {
b[a] = this,
c[a] = arguments.length > 1 ? d.call(arguments) : e,
c === i ? g.notifyWith(b, c) : --f || g.resolveWith(b, c)
}
},
i,
j,
k;
if (e > 1) for (i = new Array(e), j = new Array(e), k = new Array(e); e > b; b++) c[b] && n.isFunction(c[b].promise) ? c[b].promise().done(h(b, k, c)).fail(g.reject).progress(h(b, j, i)) : --f;
return f || g.resolveWith(k, c),
g.promise()
}
});
var I;
n.fn.ready = function(a) {
return n.ready.promise().done(a),
this
},
n.extend({
isReady: !1,
readyWait: 1,
holdReady: function(a) {
a ? n.readyWait++:n.ready(!0)
},
ready: function(a) {
if (a === !0 ? !--n.readyWait: !n.isReady) {
if (!z.body) return setTimeout(n.ready);
n.isReady = !0,
a !== !0 && --n.readyWait > 0 || (I.resolveWith(z, [n]), n.fn.trigger && n(z).trigger("ready").off("ready"))
}
}
});
function J() {
z.addEventListener ? (z.removeEventListener("DOMContentLoaded", K, !1), a.removeEventListener("load", K, !1)) : (z.detachEvent("onreadystatechange", K), a.detachEvent("onload", K))
}
function K() { (z.addEventListener || "load" === event.type || "complete" === z.readyState) && (J(), n.ready())
}
n.ready.promise = function(b) {
if (!I) if (I = n.Deferred(), "complete" === z.readyState) setTimeout(n.ready);
else if (z.addEventListener) z.addEventListener("DOMContentLoaded", K, !1),
a.addEventListener("load", K, !1);
else {
z.attachEvent("onreadystatechange", K),
a.attachEvent("onload", K);
var c = !1;
try {
c = null == a.frameElement && z.documentElement
} catch(d) {}
c && c.doScroll && !
function e() {
if (!n.isReady) {
try {
c.doScroll("left")
} catch(a) {
return setTimeout(e, 50)
}
J(),
n.ready()
}
} ()
}
return I.promise(b)
};
var L = "undefined",
M;
for (M in n(l)) break;
l.ownLast = "0" !== M,
l.inlineBlockNeedsLayout = !1,
n(function() {
var a, b, c = z.getElementsByTagName("body")[0];
c && (a = z.createElement("div"), a.style.cssText = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px", b = z.createElement("div"), c.appendChild(a).appendChild(b), typeof b.style.zoom !== L && (b.style.cssText = "border:0;margin:0;width:1px;padding:1px;display:inline;zoom:1", (l.inlineBlockNeedsLayout = 3 === b.offsetWidth) && (c.style.zoom = 1)), c.removeChild(a), a = b = null)
}),
function() {
var a = z.createElement("div");
if (null == l.deleteExpando) {
l.deleteExpando = !0;
try {
delete a.test
} catch(b) {
l.deleteExpando = !1
}
}
a = null
} (),
n.acceptData = function(a) {
var b = n.noData[(a.nodeName + " ").toLowerCase()],
c = +a.nodeType || 1;
return 1 !== c && 9 !== c ? !1 : !b || b !== !0 && a.getAttribute("classid") === b
};
var N = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
O = /([A-Z])/g;
function P(a, b, c) {
if (void 0 === c && 1 === a.nodeType) {
var d = "data-" + b.replace(O, "-$1").toLowerCase();
if (c = a.getAttribute(d), "string" == typeof c) {
try {
c = "true" === c ? !0 : "false" === c ? !1 : "null" === c ? null: +c + "" === c ? +c: N.test(c) ? n.parseJSON(c) : c
} catch(e) {}
n.data(a, b, c)
} else c = void 0
}
return c
}
function Q(a) {
var b;
for (b in a) if (("data" !== b || !n.isEmptyObject(a[b])) && "toJSON" !== b) return ! 1;
return ! 0
}
function R(a, b, d, e) {
if (n.acceptData(a)) {
var f, g, h = n.expando,
i = a.nodeType,
j = i ? n.cache: a,
k = i ? a[h] : a[h] && h;
if (k && j[k] && (e || j[k].data) || void 0 !== d || "string" != typeof b) return k || (k = i ? a[h] = c.pop() || n.guid++:h),
j[k] || (j[k] = i ? {}: {
toJSON: n.noop
}),
("object" == typeof b || "function" == typeof b) && (e ? j[k] = n.extend(j[k], b) : j[k].data = n.extend(j[k].data, b)),
g = j[k],
e || (g.data || (g.data = {}), g = g.data),
void 0 !== d && (g[n.camelCase(b)] = d),
"string" == typeof b ? (f = g[b], null == f && (f = g[n.camelCase(b)])) : f = g,
f
}
}
function S(a, b, c) {
if (n.acceptData(a)) {
var d, e, f = a.nodeType,
g = f ? n.cache: a,
h = f ? a[n.expando] : n.expando;
if (g[h]) {
if (b && (d = c ? g[h] : g[h].data)) {
n.isArray(b) ? b = b.concat(n.map(b, n.camelCase)) : b in d ? b = [b] : (b = n.camelCase(b), b = b in d ? [b] : b.split(" ")),
e = b.length;
while (e--) delete d[b[e]];
if (c ? !Q(d) : !n.isEmptyObject(d)) return
} (c || (delete g[h].data, Q(g[h]))) && (f ? n.cleanData([a], !0) : l.deleteExpando || g != g.window ? delete g[h] : g[h] = null)
}
}
}
n.extend({
cache: {},
noData: {
"applet ": !0,
"embed ": !0,
"object ": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
},
hasData: function(a) {
return a = a.nodeType ? n.cache[a[n.expando]] : a[n.expando],
!!a && !Q(a)
},
data: function(a, b, c) {
return R(a, b, c)
},
removeData: function(a, b) {
return S(a, b)
},
_data: function(a, b, c) {
return R(a, b, c, !0)
},
_removeData: function(a, b) {
return S(a, b, !0)
}
}),
n.fn.extend({
data: function(a, b) {
var c, d, e, f = this[0],
g = f && f.attributes;
if (void 0 === a) {
if (this.length && (e = n.data(f), 1 === f.nodeType && !n._data(f, "parsedAttrs"))) {
c = g.length;
while (c--) d = g[c].name,
0 === d.indexOf("data-") && (d = n.camelCase(d.slice(5)), P(f, d, e[d]));
n._data(f, "parsedAttrs", !0)
}
return e
}
return "object" == typeof a ? this.each(function() {
n.data(this, a)
}) : arguments.length > 1 ? this.each(function() {
n.data(this, a, b)
}) : f ? P(f, a, n.data(f, a)) : void 0
},
removeData: function(a) {
return this.each(function() {
n.removeData(this, a)
})
}
}),
n.extend({
queue: function(a, b, c) {
var d;
return a ? (b = (b || "fx") + "queue", d = n._data(a, b), c && (!d || n.isArray(c) ? d = n._data(a, b, n.makeArray(c)) : d.push(c)), d || []) : void 0
},
dequeue: function(a, b) {
b = b || "fx";
var c = n.queue(a, b),
d = c.length,
e = c.shift(),
f = n._queueHooks(a, b),
g = function() {
n.dequeue(a, b)
};
"inprogress" === e && (e = c.shift(), d--),
e && ("fx" === b && c.unshift("inprogress"), delete f.stop, e.call(a, g, f)),
!d && f && f.empty.fire()
},
_queueHooks: function(a, b) {
var c = b + "queueHooks";
return n._data(a, c) || n._data(a, c, {
empty: n.Callbacks("once memory").add(function() {
n._removeData(a, b + "queue"),
n._removeData(a, c)
})
})
}
}),
n.fn.extend({
queue: function(a, b) {
var c = 2;
return "string" != typeof a && (b = a, a = "fx", c--),
arguments.length < c ? n.queue(this[0], a) : void 0 === b ? this: this.each(function() {
var c = n.queue(this, a, b);
n._queueHooks(this, a),
"fx" === a && "inprogress" !== c[0] && n.dequeue(this, a)
})
},
dequeue: function(a) {
return this.each(function() {
n.dequeue(this, a)
})
},
clearQueue: function(a) {
return this.queue(a || "fx", [])
},
promise: function(a, b) {
var c, d = 1,
e = n.Deferred(),
f = this,
g = this.length,
h = function() {--d || e.resolveWith(f, [f])
};
"string" != typeof a && (b = a, a = void 0),
a = a || "fx";
while (g--) c = n._data(f[g], a + "queueHooks"),
c && c.empty && (d++, c.empty.add(h));
return h(),
e.promise(b)
}
});
var T = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
U = ["Top", "Right", "Bottom", "Left"],
V = function(a, b) {
return a = b || a,
"none" === n.css(a, "display") || !n.contains(a.ownerDocument, a)
},
W = n.access = function(a, b, c, d, e, f, g) {
var h = 0,
i = a.length,
j = null == c;
if ("object" === n.type(c)) {
e = !0;
for (h in c) n.access(a, b, h, c[h], !0, f, g)
} else if (void 0 !== d && (e = !0, n.isFunction(d) || (g = !0), j && (g ? (b.call(a, d), b = null) : (j = b, b = function(a, b, c) {
return j.call(n(a), c)
})), b)) for (; i > h; h++) b(a[h], c, g ? d: d.call(a[h], h, b(a[h], c)));
return e ? a: j ? b.call(a) : i ? b(a[0], c) : f
},
X = /^(?:checkbox|radio)$/i; !
function() {
var a = z.createDocumentFragment(),
b = z.createElement("div"),
c = z.createElement("input");
if (b.setAttribute("className", "t"), b.innerHTML = " <link/><table></table><a href='/a'>a</a>", l.leadingWhitespace = 3 === b.firstChild.nodeType, l.tbody = !b.getElementsByTagName("tbody").length, l.htmlSerialize = !!b.getElementsByTagName("link").length, l.html5Clone = "<:nav></:nav>" !== z.createElement("nav").cloneNode(!0).outerHTML, c.type = "checkbox", c.checked = !0, a.appendChild(c), l.appendChecked = c.checked, b.innerHTML = "<textarea>x</textarea>", l.noCloneChecked = !!b.cloneNode(!0).lastChild.defaultValue, a.appendChild(b), b.innerHTML = "<input type='radio' checked='checked' name='t'/>", l.checkClone = b.cloneNode(!0).cloneNode(!0).lastChild.checked, l.noCloneEvent = !0, b.attachEvent && (b.attachEvent("onclick",
function() {
l.noCloneEvent = !1
}), b.cloneNode(!0).click()), null == l.deleteExpando) {
l.deleteExpando = !0;
try {
delete b.test
} catch(d) {
l.deleteExpando = !1
}
}
a = b = c = null
} (),
function() {
var b, c, d = z.createElement("div");
for (b in {
submit: !0,
change: !0,
focusin: !0
}) c = "on" + b,
(l[b + "Bubbles"] = c in a) || (d.setAttribute(c, "t"), l[b + "Bubbles"] = d.attributes[c].expando === !1);
d = null
} ();
var Y = /^(?:input|select|textarea)$/i,
Z = /^key/,
$ = /^(?:mouse|contextmenu)|click/,
_ = /^(?:focusinfocus|focusoutblur)$/,
ab = /^([^.]*)(?:\.(.+)|)$/;
function bb() {
return ! 0
}
function cb() {
return ! 1
}
function db() {
try {
return z.activeElement
} catch(a) {}
}
n.event = {
global: {},
add: function(a, b, c, d, e) {
var f, g, h, i, j, k, l, m, o, p, q, r = n._data(a);
if (r) {
c.handler && (i = c, c = i.handler, e = i.selector),
c.guid || (c.guid = n.guid++),
(g = r.events) || (g = r.events = {}),
(k = r.handle) || (k = r.handle = function(a) {
return typeof n === L || a && n.event.triggered === a.type ? void 0 : n.event.dispatch.apply(k.elem, arguments)
},
k.elem = a),
b = (b || "").match(F) || [""],
h = b.length;
while (h--) f = ab.exec(b[h]) || [],
o = q = f[1],
p = (f[2] || "").split(".").sort(),
o && (j = n.event.special[o] || {},
o = (e ? j.delegateType: j.bindType) || o, j = n.event.special[o] || {},
l = n.extend({
type: o,
origType: q,
data: d,
handler: c,
guid: c.guid,
selector: e,
needsContext: e && n.expr.match.needsContext.test(e),
namespace: p.join(".")
},
i), (m = g[o]) || (m = g[o] = [], m.delegateCount = 0, j.setup && j.setup.call(a, d, p, k) !== !1 || (a.addEventListener ? a.addEventListener(o, k, !1) : a.attachEvent && a.attachEvent("on" + o, k))), j.add && (j.add.call(a, l), l.handler.guid || (l.handler.guid = c.guid)), e ? m.splice(m.delegateCount++, 0, l) : m.push(l), n.event.global[o] = !0);
a = null
}
},
remove: function(a, b, c, d, e) {
var f, g, h, i, j, k, l, m, o, p, q, r = n.hasData(a) && n._data(a);
if (r && (k = r.events)) {
b = (b || "").match(F) || [""],
j = b.length;
while (j--) if (h = ab.exec(b[j]) || [], o = q = h[1], p = (h[2] || "").split(".").sort(), o) {
l = n.event.special[o] || {},
o = (d ? l.delegateType: l.bindType) || o,
m = k[o] || [],
h = h[2] && new RegExp("(^|\\.)" + p.join("\\.(?:.*\\.|)") + "(\\.|$)"),
i = f = m.length;
while (f--) g = m[f],
!e && q !== g.origType || c && c.guid !== g.guid || h && !h.test(g.namespace) || d && d !== g.selector && ("**" !== d || !g.selector) || (m.splice(f, 1), g.selector && m.delegateCount--, l.remove && l.remove.call(a, g));
i && !m.length && (l.teardown && l.teardown.call(a, p, r.handle) !== !1 || n.removeEvent(a, o, r.handle), delete k[o])
} else for (o in k) n.event.remove(a, o + b[j], c, d, !0);
n.isEmptyObject(k) && (delete r.handle, n._removeData(a, "events"))
}
},
trigger: function(b, c, d, e) {
var f, g, h, i, k, l, m, o = [d || z],
p = j.call(b, "type") ? b.type: b,
q = j.call(b, "namespace") ? b.namespace.split(".") : [];
if (h = l = d = d || z, 3 !== d.nodeType && 8 !== d.nodeType && !_.test(p + n.event.triggered) && (p.indexOf(".") >= 0 && (q = p.split("."), p = q.shift(), q.sort()), g = p.indexOf(":") < 0 && "on" + p, b = b[n.expando] ? b: new n.Event(p, "object" == typeof b && b), b.isTrigger = e ? 2 : 3, b.namespace = q.join("."), b.namespace_re = b.namespace ? new RegExp("(^|\\.)" + q.join("\\.(?:.*\\.|)") + "(\\.|$)") : null, b.result = void 0, b.target || (b.target = d), c = null == c ? [b] : n.makeArray(c, [b]), k = n.event.special[p] || {},
e || !k.trigger || k.trigger.apply(d, c) !== !1)) {
if (!e && !k.noBubble && !n.isWindow(d)) {
for (i = k.delegateType || p, _.test(i + p) || (h = h.parentNode); h; h = h.parentNode) o.push(h),
l = h;
l === (d.ownerDocument || z) && o.push(l.defaultView || l.parentWindow || a)
}
m = 0;
while ((h = o[m++]) && !b.isPropagationStopped()) b.type = m > 1 ? i: k.bindType || p,
f = (n._data(h, "events") || {})[b.type] && n._data(h, "handle"),
f && f.apply(h, c),
f = g && h[g],
f && f.apply && n.acceptData(h) && (b.result = f.apply(h, c), b.result === !1 && b.preventDefault());
if (b.type = p, !e && !b.isDefaultPrevented() && (!k._default || k._default.apply(o.pop(), c) === !1) && n.acceptData(d) && g && d[p] && !n.isWindow(d)) {
l = d[g],
l && (d[g] = null),
n.event.triggered = p;
try {
d[p]()
} catch(r) {}
n.event.triggered = void 0,
l && (d[g] = l)
}
return b.result
}
},
dispatch: function(a) {
a = n.event.fix(a);
var b, c, e, f, g, h = [],
i = d.call(arguments),
j = (n._data(this, "events") || {})[a.type] || [],
k = n.event.special[a.type] || {};
if (i[0] = a, a.delegateTarget = this, !k.preDispatch || k.preDispatch.call(this, a) !== !1) {
h = n.event.handlers.call(this, a, j),
b = 0;
while ((f = h[b++]) && !a.isPropagationStopped()) {
a.currentTarget = f.elem,
g = 0;
while ((e = f.handlers[g++]) && !a.isImmediatePropagationStopped())(!a.namespace_re || a.namespace_re.test(e.namespace)) && (a.handleObj = e, a.data = e.data, c = ((n.event.special[e.origType] || {}).handle || e.handler).apply(f.elem, i), void 0 !== c && (a.result = c) === !1 && (a.preventDefault(), a.stopPropagation()))
}
return k.postDispatch && k.postDispatch.call(this, a),
a.result
}
},
handlers: function(a, b) {
var c, d, e, f, g = [],
h = b.delegateCount,
i = a.target;
if (h && i.nodeType && (!a.button || "click" !== a.type)) for (; i != this; i = i.parentNode || this) if (1 === i.nodeType && (i.disabled !== !0 || "click" !== a.type)) {
for (e = [], f = 0; h > f; f++) d = b[f],
c = d.selector + " ",
void 0 === e[c] && (e[c] = d.needsContext ? n(c, this).index(i) >= 0 : n.find(c, this, null, [i]).length),
e[c] && e.push(d);
e.length && g.push({
elem: i,
handlers: e
})
}
return h < b.length && g.push({
elem: this,
handlers: b.slice(h)
}),
g
},
fix: function(a) {
if (a[n.expando]) return a;
var b, c, d, e = a.type,
f = a,
g = this.fixHooks[e];
g || (this.fixHooks[e] = g = $.test(e) ? this.mouseHooks: Z.test(e) ? this.keyHooks: {}),
d = g.props ? this.props.concat(g.props) : this.props,
a = new n.Event(f),
b = d.length;
while (b--) c = d[b],
a[c] = f[c];
return a.target || (a.target = f.srcElement || z),
3 === a.target.nodeType && (a.target = a.target.parentNode),
a.metaKey = !!a.metaKey,
g.filter ? g.filter(a, f) : a
},
props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),
fixHooks: {},
keyHooks: {
props: "char charCode key keyCode".split(" "),
filter: function(a, b) {
return null == a.which && (a.which = null != b.charCode ? b.charCode: b.keyCode),
a
}
},
mouseHooks: {
props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),
filter: function(a, b) {
var c, d, e, f = b.button,
g = b.fromElement;
return null == a.pageX && null != b.clientX && (d = a.target.ownerDocument || z, e = d.documentElement, c = d.body, a.pageX = b.clientX + (e && e.scrollLeft || c && c.scrollLeft || 0) - (e && e.clientLeft || c && c.clientLeft || 0), a.pageY = b.clientY + (e && e.scrollTop || c && c.scrollTop || 0) - (e && e.clientTop || c && c.clientTop || 0)),
!a.relatedTarget && g && (a.relatedTarget = g === a.target ? b.toElement: g),
a.which || void 0 === f || (a.which = 1 & f ? 1 : 2 & f ? 3 : 4 & f ? 2 : 0),
a
}
},
special: {
load: {
noBubble: !0
},
focus: {
trigger: function() {
if (this !== db() && this.focus) try {
return this.focus(),
!1
} catch(a) {}
},
delegateType: "focusin"
},
blur: {
trigger: function() {
return this === db() && this.blur ? (this.blur(), !1) : void 0
},
delegateType: "focusout"
},
click: {
trigger: function() {
return n.nodeName(this, "input") && "checkbox" === this.type && this.click ? (this.click(), !1) : void 0
},
_default: function(a) {
return n.nodeName(a.target, "a")
}
},
beforeunload: {
postDispatch: function(a) {
void 0 !== a.result && (a.originalEvent.returnValue = a.result)
}
}
},
simulate: function(a, b, c, d) {
var e = n.extend(new n.Event, c, {
type: a,
isSimulated: !0,
originalEvent: {}
});
d ? n.event.trigger(e, null, b) : n.event.dispatch.call(b, e),
e.isDefaultPrevented() && c.preventDefault()
}
},
n.removeEvent = z.removeEventListener ?
function(a, b, c) {
a.removeEventListener && a.removeEventListener(b, c, !1)
}: function(a, b, c) {
var d = "on" + b;
a.detachEvent && (typeof a[d] === L && (a[d] = null), a.detachEvent(d, c))
},
n.Event = function(a, b) {
return this instanceof n.Event ? (a && a.type ? (this.originalEvent = a, this.type = a.type, this.isDefaultPrevented = a.defaultPrevented || void 0 === a.defaultPrevented && (a.returnValue === !1 || a.getPreventDefault && a.getPreventDefault()) ? bb: cb) : this.type = a, b && n.extend(this, b), this.timeStamp = a && a.timeStamp || n.now(), void(this[n.expando] = !0)) : new n.Event(a, b)
},
n.Event.prototype = {
isDefaultPrevented: cb,
isPropagationStopped: cb,
isImmediatePropagationStopped: cb,
preventDefault: function() {
var a = this.originalEvent;
this.isDefaultPrevented = bb,
a && (a.preventDefault ? a.preventDefault() : a.returnValue = !1)
},
stopPropagation: function() {
var a = this.originalEvent;
this.isPropagationStopped = bb,
a && (a.stopPropagation && a.stopPropagation(), a.cancelBubble = !0)
},
stopImmediatePropagation: function() {
this.isImmediatePropagationStopped = bb,
this.stopPropagation()
}
},
n.each({
mouseenter: "mouseover",
mouseleave: "mouseout"
},
function(a, b) {
n.event.special[a] = {
delegateType: b,
bindType: b,
handle: function(a) {
var c, d = this,
e = a.relatedTarget,
f = a.handleObj;
return (!e || e !== d && !n.contains(d, e)) && (a.type = f.origType, c = f.handler.apply(this, arguments), a.type = b),
c
}
}
}),
l.submitBubbles || (n.event.special.submit = {
setup: function() {
return n.nodeName(this, "form") ? !1 : void n.event.add(this, "click._submit keypress._submit",
function(a) {
var b = a.target,
c = n.nodeName(b, "input") || n.nodeName(b, "button") ? b.form: void 0;
c && !n._data(c, "submitBubbles") && (n.event.add(c, "submit._submit",
function(a) {
a._submit_bubble = !0
}), n._data(c, "submitBubbles", !0))
})
},
postDispatch: function(a) {
a._submit_bubble && (delete a._submit_bubble, this.parentNode && !a.isTrigger && n.event.simulate("submit", this.parentNode, a, !0))
},
teardown: function() {
return n.nodeName(this, "form") ? !1 : void n.event.remove(this, "._submit")
}
}),
l.changeBubbles || (n.event.special.change = {
setup: function() {
return Y.test(this.nodeName) ? (("checkbox" === this.type || "radio" === this.type) && (n.event.add(this, "propertychange._change",
function(a) {
"checked" === a.originalEvent.propertyName && (this._just_changed = !0)
}), n.event.add(this, "click._change",
function(a) {
this._just_changed && !a.isTrigger && (this._just_changed = !1),
n.event.simulate("change", this, a, !0)
})), !1) : void n.event.add(this, "beforeactivate._change",
function(a) {
var b = a.target;
Y.test(b.nodeName) && !n._data(b, "changeBubbles") && (n.event.add(b, "change._change",
function(a) { ! this.parentNode || a.isSimulated || a.isTrigger || n.event.simulate("change", this.parentNode, a, !0)
}), n._data(b, "changeBubbles", !0))
})
},
handle: function(a) {
var b = a.target;
return this !== b || a.isSimulated || a.isTrigger || "radio" !== b.type && "checkbox" !== b.type ? a.handleObj.handler.apply(this, arguments) : void 0
},
teardown: function() {
return n.event.remove(this, "._change"),
!Y.test(this.nodeName)
}
}),
l.focusinBubbles || n.each({
focus: "focusin",
blur: "focusout"
},
function(a, b) {
var c = function(a) {
n.event.simulate(b, a.target, n.event.fix(a), !0)
};
n.event.special[b] = {
setup: function() {
var d = this.ownerDocument || this,
e = n._data(d, b);
e || d.addEventListener(a, c, !0),
n._data(d, b, (e || 0) + 1)
},
teardown: function() {
var d = this.ownerDocument || this,
e = n._data(d, b) - 1;
e ? n._data(d, b, e) : (d.removeEventListener(a, c, !0), n._removeData(d, b))
}
}
}),
n.fn.extend({
on: function(a, b, c, d, e) {
var f, g;
if ("object" == typeof a) {
"string" != typeof b && (c = c || b, b = void 0);
for (f in a) this.on(f, b, c, a[f], e);
return this
}
if (null == c && null == d ? (d = b, c = b = void 0) : null == d && ("string" == typeof b ? (d = c, c = void 0) : (d = c, c = b, b = void 0)), d === !1) d = cb;
else if (!d) return this;
return 1 === e && (g = d, d = function(a) {
return n().off(a),
g.apply(this, arguments)
},
d.guid = g.guid || (g.guid = n.guid++)),
this.each(function() {
n.event.add(this, a, d, c, b)
})
},
one: function(a, b, c, d) {
return this.on(a, b, c, d, 1)
},
off: function(a, b, c) {
var d, e;
if (a && a.preventDefault && a.handleObj) return d = a.handleObj,
n(a.delegateTarget).off(d.namespace ? d.origType + "." + d.namespace: d.origType, d.selector, d.handler),
this;
if ("object" == typeof a) {
for (e in a) this.off(e, b, a[e]);
return this
}
return (b === !1 || "function" == typeof b) && (c = b, b = void 0),
c === !1 && (c = cb),
this.each(function() {
n.event.remove(this, a, c, b)
})
},
trigger: function(a, b) {
return this.each(function() {
n.event.trigger(a, b, this)
})
},
triggerHandler: function(a, b) {
var c = this[0];
return c ? n.event.trigger(a, b, c, !0) : void 0
}
});
function eb(a) {
var b = fb.split("|"),
c = a.createDocumentFragment();
if (c.createElement) while (b.length) c.createElement(b.pop());
return c
}
var fb = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",
gb = / jQuery\d+="(?:null|\d+)"/g,
hb = new RegExp("<(?:" + fb + ")[\\s/>]", "i"),
ib = /^\s+/,
jb = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,
kb = /<([\w:]+)/,
lb = /<tbody/i,
mb = /<|&#?\w+;/,
nb = /<(?:script|style|link)/i,
ob = /checked\s*(?:[^=]|=\s*.checked.)/i,
pb = /^$|\/(?:java|ecma)script/i,
qb = /^true\/(.*)/,
rb = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,
sb = {
option: [1, "<select multiple='multiple'>", "</select>"],
legend: [1, "<fieldset>", "</fieldset>"],
area: [1, "<map>", "</map>"],
param: [1, "<object>", "</object>"],
thead: [1, "<table>", "</table>"],
tr: [2, "<table><tbody>", "</tbody></table>"],
col: [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"],
td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
_default: l.htmlSerialize ? [0, "", ""] : [1, "X<div>", "</div>"]
},
tb = eb(z),
ub = tb.appendChild(z.createElement("div"));
sb.optgroup = sb.option,
sb.tbody = sb.tfoot = sb.colgroup = sb.caption = sb.thead,
sb.th = sb.td;
function vb(a, b) {
var c, d, e = 0,
f = typeof a.getElementsByTagName !== L ? a.getElementsByTagName(b || "*") : typeof a.querySelectorAll !== L ? a.querySelectorAll(b || "*") : void 0;
if (!f) for (f = [], c = a.childNodes || a; null != (d = c[e]); e++) ! b || n.nodeName(d, b) ? f.push(d) : n.merge(f, vb(d, b));
return void 0 === b || b && n.nodeName(a, b) ? n.merge([a], f) : f
}
function wb(a) {
X.test(a.type) && (a.defaultChecked = a.checked)
}
function xb(a, b) {
return n.nodeName(a, "table") && n.nodeName(11 !== b.nodeType ? b: b.firstChild, "tr") ? a.getElementsByTagName("tbody")[0] || a.appendChild(a.ownerDocument.createElement("tbody")) : a
}
function yb(a) {
return a.type = (null !== n.find.attr(a, "type")) + "/" + a.type,
a
}
function zb(a) {
var b = qb.exec(a.type);
return b ? a.type = b[1] : a.removeAttribute("type"),
a
}
function Ab(a, b) {
for (var c, d = 0; null != (c = a[d]); d++) n._data(c, "globalEval", !b || n._data(b[d], "globalEval"))
}
function Bb(a, b) {
if (1 === b.nodeType && n.hasData(a)) {
var c, d, e, f = n._data(a),
g = n._data(b, f),
h = f.events;
if (h) {
delete g.handle,
g.events = {};
for (c in h) for (d = 0, e = h[c].length; e > d; d++) n.event.add(b, c, h[c][d])
}
g.data && (g.data = n.extend({},
g.data))
}
}
function Cb(a, b) {
var c, d, e;
if (1 === b.nodeType) {
if (c = b.nodeName.toLowerCase(), !l.noCloneEvent && b[n.expando]) {
e = n._data(b);
for (d in e.events) n.removeEvent(b, d, e.handle);
b.removeAttribute(n.expando)
}
"script" === c && b.text !== a.text ? (yb(b).text = a.text, zb(b)) : "object" === c ? (b.parentNode && (b.outerHTML = a.outerHTML), l.html5Clone && a.innerHTML && !n.trim(b.innerHTML) && (b.innerHTML = a.innerHTML)) : "input" === c && X.test(a.type) ? (b.defaultChecked = b.checked = a.checked, b.value !== a.value && (b.value = a.value)) : "option" === c ? b.defaultSelected = b.selected = a.defaultSelected: ("input" === c || "textarea" === c) && (b.defaultValue = a.defaultValue)
}
}
n.extend({
clone: function(a, b, c) {
var d, e, f, g, h, i = n.contains(a.ownerDocument, a);
if (l.html5Clone || n.isXMLDoc(a) || !hb.test("<" + a.nodeName + ">") ? f = a.cloneNode(!0) : (ub.innerHTML = a.outerHTML, ub.removeChild(f = ub.firstChild)), !(l.noCloneEvent && l.noCloneChecked || 1 !== a.nodeType && 11 !== a.nodeType || n.isXMLDoc(a))) for (d = vb(f), h = vb(a), g = 0; null != (e = h[g]); ++g) d[g] && Cb(e, d[g]);
if (b) if (c) for (h = h || vb(a), d = d || vb(f), g = 0; null != (e = h[g]); g++) Bb(e, d[g]);
else Bb(a, f);
return d = vb(f, "script"),
d.length > 0 && Ab(d, !i && vb(a, "script")),
d = h = e = null,
f
},
buildFragment: function(a, b, c, d) {
for (var e, f, g, h, i, j, k, m = a.length,
o = eb(b), p = [], q = 0; m > q; q++) if (f = a[q], f || 0 === f) if ("object" === n.type(f)) n.merge(p, f.nodeType ? [f] : f);
else if (mb.test(f)) {
h = h || o.appendChild(b.createElement("div")),
i = (kb.exec(f) || ["", ""])[1].toLowerCase(),
k = sb[i] || sb._default,
h.innerHTML = k[1] + f.replace(jb, "<$1></$2>") + k[2],
e = k[0];
while (e--) h = h.lastChild;
if (!l.leadingWhitespace && ib.test(f) && p.push(b.createTextNode(ib.exec(f)[0])), !l.tbody) {
f = "table" !== i || lb.test(f) ? "<table>" !== k[1] || lb.test(f) ? 0 : h: h.firstChild,
e = f && f.childNodes.length;
while (e--) n.nodeName(j = f.childNodes[e], "tbody") && !j.childNodes.length && f.removeChild(j)
}
n.merge(p, h.childNodes),
h.textContent = "";
while (h.firstChild) h.removeChild(h.firstChild);
h = o.lastChild
} else p.push(b.createTextNode(f));
h && o.removeChild(h),
l.appendChecked || n.grep(vb(p, "input"), wb),
q = 0;
while (f = p[q++]) if ((!d || -1 === n.inArray(f, d)) && (g = n.contains(f.ownerDocument, f), h = vb(o.appendChild(f), "script"), g && Ab(h), c)) {
e = 0;
while (f = h[e++]) pb.test(f.type || "") && c.push(f)
}
return h = null,
o
},
cleanData: function(a, b) {
for (var d, e, f, g, h = 0,
i = n.expando,
j = n.cache,
k = l.deleteExpando,
m = n.event.special; null != (d = a[h]); h++) if ((b || n.acceptData(d)) && (f = d[i], g = f && j[f])) {
if (g.events) for (e in g.events) m[e] ? n.event.remove(d, e) : n.removeEvent(d, e, g.handle);
j[f] && (delete j[f], k ? delete d[i] : typeof d.removeAttribute !== L ? d.removeAttribute(i) : d[i] = null, c.push(f))
}
}
}),
n.fn.extend({
text: function(a) {
return W(this,
function(a) {
return void 0 === a ? n.text(this) : this.empty().append((this[0] && this[0].ownerDocument || z).createTextNode(a))
},
null, a, arguments.length)
},
append: function() {
return this.domManip(arguments,
function(a) {
if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
var b = xb(this, a);
b.appendChild(a)
}
})
},
prepend: function() {
return this.domManip(arguments,
function(a) {
if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
var b = xb(this, a);
b.insertBefore(a, b.firstChild)
}
})
},
before: function() {
return this.domManip(arguments,
function(a) {
this.parentNode && this.parentNode.insertBefore(a, this)
})
},
after: function() {
return this.domManip(arguments,
function(a) {
this.parentNode && this.parentNode.insertBefore(a, this.nextSibling)
})
},
remove: function(a, b) {
for (var c, d = a ? n.filter(a, this) : this, e = 0; null != (c = d[e]); e++) b || 1 !== c.nodeType || n.cleanData(vb(c)),
c.parentNode && (b && n.contains(c.ownerDocument, c) && Ab(vb(c, "script")), c.parentNode.removeChild(c));
return this
},
empty: function() {
for (var a, b = 0; null != (a = this[b]); b++) {
1 === a.nodeType && n.cleanData(vb(a, !1));
while (a.firstChild) a.removeChild(a.firstChild);
a.options && n.nodeName(a, "select") && (a.options.length = 0)
}
return this
},
clone: function(a, b) {
return a = null == a ? !1 : a,
b = null == b ? a: b,
this.map(function() {
return n.clone(this, a, b)
})
},
html: function(a) {
return W(this,
function(a) {
var b = this[0] || {},
c = 0,
d = this.length;
if (void 0 === a) return 1 === b.nodeType ? b.innerHTML.replace(gb, "") : void 0;
if (! ("string" != typeof a || nb.test(a) || !l.htmlSerialize && hb.test(a) || !l.leadingWhitespace && ib.test(a) || sb[(kb.exec(a) || ["", ""])[1].toLowerCase()])) {
a = a.replace(jb, "<$1></$2>");
try {
for (; d > c; c++) b = this[c] || {},
1 === b.nodeType && (n.cleanData(vb(b, !1)), b.innerHTML = a);
b = 0
} catch(e) {}
}
b && this.empty().append(a)
},
null, a, arguments.length)
},
replaceWith: function() {
var a = arguments[0];
return this.domManip(arguments,
function(b) {
a = this.parentNode,
n.cleanData(vb(this)),
a && a.replaceChild(b, this)
}),
a && (a.length || a.nodeType) ? this: this.remove()
},
detach: function(a) {
return this.remove(a, !0)
},
domManip: function(a, b) {
a = e.apply([], a);
var c, d, f, g, h, i, j = 0,
k = this.length,
m = this,
o = k - 1,
p = a[0],
q = n.isFunction(p);
if (q || k > 1 && "string" == typeof p && !l.checkClone && ob.test(p)) return this.each(function(c) {
var d = m.eq(c);
q && (a[0] = p.call(this, c, d.html())),
d.domManip(a, b)
});
if (k && (i = n.buildFragment(a, this[0].ownerDocument, !1, this), c = i.firstChild, 1 === i.childNodes.length && (i = c), c)) {
for (g = n.map(vb(i, "script"), yb), f = g.length; k > j; j++) d = i,
j !== o && (d = n.clone(d, !0, !0), f && n.merge(g, vb(d, "script"))),
b.call(this[j], d, j);
if (f) for (h = g[g.length - 1].ownerDocument, n.map(g, zb), j = 0; f > j; j++) d = g[j],
pb.test(d.type || "") && !n._data(d, "globalEval") && n.contains(h, d) && (d.src ? n._evalUrl && n._evalUrl(d.src) : n.globalEval((d.text || d.textContent || d.innerHTML || "").replace(rb, "")));
i = c = null
}
return this
}
}),
n.each({
appendTo: "append",
prependTo: "prepend",
insertBefore: "before",
insertAfter: "after",
replaceAll: "replaceWith"
},
function(a, b) {
n.fn[a] = function(a) {
for (var c, d = 0,
e = [], g = n(a), h = g.length - 1; h >= d; d++) c = d === h ? this: this.clone(!0),
n(g[d])[b](c),
f.apply(e, c.get());
return this.pushStack(e)
}
});
var Db, Eb = {};
function Fb(b, c) {
var d = n(c.createElement(b)).appendTo(c.body),
e = a.getDefaultComputedStyle ? a.getDefaultComputedStyle(d[0]).display: n.css(d[0], "display");
return d.detach(),
e
}
function Gb(a) {
var b = z,
c = Eb[a];
return c || (c = Fb(a, b), "none" !== c && c || (Db = (Db || n("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement), b = (Db[0].contentWindow || Db[0].contentDocument).document, b.write(), b.close(), c = Fb(a, b), Db.detach()), Eb[a] = c),
c
} !
function() {
var a, b, c = z.createElement("div"),
d = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;padding:0;margin:0;border:0";
c.innerHTML = " <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
a = c.getElementsByTagName("a")[0],
a.style.cssText = "float:left;opacity:.5",
l.opacity = /^0.5/.test(a.style.opacity),
l.cssFloat = !!a.style.cssFloat,
c.style.backgroundClip = "content-box",
c.cloneNode(!0).style.backgroundClip = "",
l.clearCloneStyle = "content-box" === c.style.backgroundClip,
a = c = null,
l.shrinkWrapBlocks = function() {
var a, c, e, f;
if (null == b) {
if (a = z.getElementsByTagName("body")[0], !a) return;
f = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px",
c = z.createElement("div"),
e = z.createElement("div"),
a.appendChild(c).appendChild(e),
b = !1,
typeof e.style.zoom !== L && (e.style.cssText = d + ";width:1px;padding:1px;zoom:1", e.innerHTML = "<div></div>", e.firstChild.style.width = "5px", b = 3 !== e.offsetWidth),
a.removeChild(c),
a = c = e = null
}
return b
}
} ();
var Hb = /^margin/,
Ib = new RegExp("^(" + T + ")(?!px)[a-z%]+$", "i"),
Jb,
Kb,
Lb = /^(top|right|bottom|left)$/;
a.getComputedStyle ? (Jb = function(a) {
return a.ownerDocument.defaultView.getComputedStyle(a, null)
},
Kb = function(a, b, c) {
var d, e, f, g, h = a.style;
return c = c || Jb(a),
g = c ? c.getPropertyValue(b) || c[b] : void 0,
c && ("" !== g || n.contains(a.ownerDocument, a) || (g = n.style(a, b)), Ib.test(g) && Hb.test(b) && (d = h.width, e = h.minWidth, f = h.maxWidth, h.minWidth = h.maxWidth = h.width = g, g = c.width, h.width = d, h.minWidth = e, h.maxWidth = f)),
void 0 === g ? g: g + ""
}) : z.documentElement.currentStyle && (Jb = function(a) {
return a.currentStyle
},
Kb = function(a, b, c) {
var d, e, f, g, h = a.style;
return c = c || Jb(a),
g = c ? c[b] : void 0,
null == g && h && h[b] && (g = h[b]),
Ib.test(g) && !Lb.test(b) && (d = h.left, e = a.runtimeStyle, f = e && e.left, f && (e.left = a.currentStyle.left), h.left = "fontSize" === b ? "1em": g, g = h.pixelLeft + "px", h.left = d, f && (e.left = f)),
void 0 === g ? g: g + "" || "auto"
});
function Mb(a, b) {
return {
get: function() {
var c = a();
if (null != c) return c ? void delete this.get: (this.get = b).apply(this, arguments)
}
}
} !
function() {
var b, c, d, e, f, g, h = z.createElement("div"),
i = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px",
j = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;padding:0;margin:0;border:0";
h.innerHTML = " <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
b = h.getElementsByTagName("a")[0],
b.style.cssText = "float:left;opacity:.5",
l.opacity = /^0.5/.test(b.style.opacity),
l.cssFloat = !!b.style.cssFloat,
h.style.backgroundClip = "content-box",
h.cloneNode(!0).style.backgroundClip = "",
l.clearCloneStyle = "content-box" === h.style.backgroundClip,
b = h = null,
n.extend(l, {
reliableHiddenOffsets: function() {
if (null != c) return c;
var a, b, d, e = z.createElement("div"),
f = z.getElementsByTagName("body")[0];
if (f) return e.setAttribute("className", "t"),
e.innerHTML = " <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
a = z.createElement("div"),
a.style.cssText = i,
f.appendChild(a).appendChild(e),
e.innerHTML = "<table><tr><td></td><td>t</td></tr></table>",
b = e.getElementsByTagName("td"),
b[0].style.cssText = "padding:0;margin:0;border:0;display:none",
d = 0 === b[0].offsetHeight,
b[0].style.display = "",
b[1].style.display = "none",
c = d && 0 === b[0].offsetHeight,
f.removeChild(a),
e = f = null,
c
},
boxSizing: function() {
return null == d && k(),
d
},
boxSizingReliable: function() {
return null == e && k(),
e
},
pixelPosition: function() {
return null == f && k(),
f
},
reliableMarginRight: function() {
var b, c, d, e;
if (null == g && a.getComputedStyle) {
if (b = z.getElementsByTagName("body")[0], !b) return;
c = z.createElement("div"),
d = z.createElement("div"),
c.style.cssText = i,
b.appendChild(c).appendChild(d),
e = d.appendChild(z.createElement("div")),
e.style.cssText = d.style.cssText = j,
e.style.marginRight = e.style.width = "0",
d.style.width = "1px",
g = !parseFloat((a.getComputedStyle(e, null) || {}).marginRight),
b.removeChild(c)
}
return g
}
});
function k() {
var b, c, h = z.getElementsByTagName("body")[0];
h && (b = z.createElement("div"), c = z.createElement("div"), b.style.cssText = i, h.appendChild(b).appendChild(c), c.style.cssText = "-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;position:absolute;display:block;padding:1px;border:1px;width:4px;margin-top:1%;top:1%", n.swap(h, null != h.style.zoom ? {
zoom: 1
}: {},
function() {
d = 4 === c.offsetWidth
}), e = !0, f = !1, g = !0, a.getComputedStyle && (f = "1%" !== (a.getComputedStyle(c, null) || {}).top, e = "4px" === (a.getComputedStyle(c, null) || {
width: "4px"
}).width), h.removeChild(b), c = h = null)
}
} (),
n.swap = function(a, b, c, d) {
var e, f, g = {};
for (f in b) g[f] = a.style[f],
a.style[f] = b[f];
e = c.apply(a, d || []);
for (f in b) a.style[f] = g[f];
return e
};
var Nb = /alpha\([^)]*\)/i,
Ob = /opacity\s*=\s*([^)]*)/,
Pb = /^(none|table(?!-c[ea]).+)/,
Qb = new RegExp("^(" + T + ")(.*)$", "i"),
Rb = new RegExp("^([+-])=(" + T + ")", "i"),
Sb = {
position: "absolute",
visibility: "hidden",
display: "block"
},
Tb = {
letterSpacing: 0,
fontWeight: 400
},
Ub = ["Webkit", "O", "Moz", "ms"];
function Vb(a, b) {
if (b in a) return b;
var c = b.charAt(0).toUpperCase() + b.slice(1),
d = b,
e = Ub.length;
while (e--) if (b = Ub[e] + c, b in a) return b;
return d
}
function Wb(a, b) {
for (var c, d, e, f = [], g = 0, h = a.length; h > g; g++) d = a[g],
d.style && (f[g] = n._data(d, "olddisplay"), c = d.style.display, b ? (f[g] || "none" !== c || (d.style.display = ""), "" === d.style.display && V(d) && (f[g] = n._data(d, "olddisplay", Gb(d.nodeName)))) : f[g] || (e = V(d), (c && "none" !== c || !e) && n._data(d, "olddisplay", e ? c: n.css(d, "display"))));
for (g = 0; h > g; g++) d = a[g],
d.style && (b && "none" !== d.style.display && "" !== d.style.display || (d.style.display = b ? f[g] || "": "none"));
return a
}
function Xb(a, b, c) {
var d = Qb.exec(b);
return d ? Math.max(0, d[1] - (c || 0)) + (d[2] || "px") : b
}
function Yb(a, b, c, d, e) {
for (var f = c === (d ? "border": "content") ? 4 : "width" === b ? 1 : 0, g = 0; 4 > f; f += 2)"margin" === c && (g += n.css(a, c + U[f], !0, e)),
d ? ("content" === c && (g -= n.css(a, "padding" + U[f], !0, e)), "margin" !== c && (g -= n.css(a, "border" + U[f] + "Width", !0, e))) : (g += n.css(a, "padding" + U[f], !0, e), "padding" !== c && (g += n.css(a, "border" + U[f] + "Width", !0, e)));
return g
}
function Zb(a, b, c) {
var d = !0,
e = "width" === b ? a.offsetWidth: a.offsetHeight,
f = Jb(a),
g = l.boxSizing() && "border-box" === n.css(a, "boxSizing", !1, f);
if (0 >= e || null == e) {
if (e = Kb(a, b, f), (0 > e || null == e) && (e = a.style[b]), Ib.test(e)) return e;
d = g && (l.boxSizingReliable() || e === a.style[b]),
e = parseFloat(e) || 0
}
return e + Yb(a, b, c || (g ? "border": "content"), d, f) + "px"
}
n.extend({
cssHooks: {
opacity: {
get: function(a, b) {
if (b) {
var c = Kb(a, "opacity");
return "" === c ? "1": c
}
}
}
},
cssNumber: {
columnCount: !0,
fillOpacity: !0,
fontWeight: !0,
lineHeight: !0,
opacity: !0,
order: !0,
orphans: !0,
widows: !0,
zIndex: !0,
zoom: !0
},
cssProps: {
"float": l.cssFloat ? "cssFloat": "styleFloat"
},
style: function(a, b, c, d) {
if (a && 3 !== a.nodeType && 8 !== a.nodeType && a.style) {
var e, f, g, h = n.camelCase(b),
i = a.style;
if (b = n.cssProps[h] || (n.cssProps[h] = Vb(i, h)), g = n.cssHooks[b] || n.cssHooks[h], void 0 === c) return g && "get" in g && void 0 !== (e = g.get(a, !1, d)) ? e: i[b];
if (f = typeof c, "string" === f && (e = Rb.exec(c)) && (c = (e[1] + 1) * e[2] + parseFloat(n.css(a, b)), f = "number"), null != c && c === c && ("number" !== f || n.cssNumber[h] || (c += "px"), l.clearCloneStyle || "" !== c || 0 !== b.indexOf("background") || (i[b] = "inherit"), !(g && "set" in g && void 0 === (c = g.set(a, c, d))))) try {
i[b] = "",
i[b] = c
} catch(j) {}
}
},
css: function(a, b, c, d) {
var e, f, g, h = n.camelCase(b);
return b = n.cssProps[h] || (n.cssProps[h] = Vb(a.style, h)),
g = n.cssHooks[b] || n.cssHooks[h],
g && "get" in g && (f = g.get(a, !0, c)),
void 0 === f && (f = Kb(a, b, d)),
"normal" === f && b in Tb && (f = Tb[b]),
"" === c || c ? (e = parseFloat(f), c === !0 || n.isNumeric(e) ? e || 0 : f) : f
}
}),
n.each(["height", "width"],
function(a, b) {
n.cssHooks[b] = {
get: function(a, c, d) {
return c ? 0 === a.offsetWidth && Pb.test(n.css(a, "display")) ? n.swap(a, Sb,
function() {
return Zb(a, b, d)
}) : Zb(a, b, d) : void 0
},
set: function(a, c, d) {
var e = d && Jb(a);
return Xb(a, c, d ? Yb(a, b, d, l.boxSizing() && "border-box" === n.css(a, "boxSizing", !1, e), e) : 0)
}
}
}),
l.opacity || (n.cssHooks.opacity = {
get: function(a, b) {
return Ob.test((b && a.currentStyle ? a.currentStyle.filter: a.style.filter) || "") ? .01 * parseFloat(RegExp.$1) + "": b ? "1": ""
},
set: function(a, b) {
var c = a.style,
d = a.currentStyle,
e = n.isNumeric(b) ? "alpha(opacity=" + 100 * b + ")": "",
f = d && d.filter || c.filter || "";
c.zoom = 1,
(b >= 1 || "" === b) && "" === n.trim(f.replace(Nb, "")) && c.removeAttribute && (c.removeAttribute("filter"), "" === b || d && !d.filter) || (c.filter = Nb.test(f) ? f.replace(Nb, e) : f + " " + e)
}
}),
n.cssHooks.marginRight = Mb(l.reliableMarginRight,
function(a, b) {
return b ? n.swap(a, {
display: "inline-block"
},
Kb, [a, "marginRight"]) : void 0
}),
n.each({
margin: "",
padding: "",
border: "Width"
},
function(a, b) {
n.cssHooks[a + b] = {
expand: function(c) {
for (var d = 0,
e = {},
f = "string" == typeof c ? c.split(" ") : [c]; 4 > d; d++) e[a + U[d] + b] = f[d] || f[d - 2] || f[0];
return e
}
},
Hb.test(a) || (n.cssHooks[a + b].set = Xb)
}),
n.fn.extend({
css: function(a, b) {
return W(this,
function(a, b, c) {
var d, e, f = {},
g = 0;
if (n.isArray(b)) {
for (d = Jb(a), e = b.length; e > g; g++) f[b[g]] = n.css(a, b[g], !1, d);
return f
}
return void 0 !== c ? n.style(a, b, c) : n.css(a, b)
},
a, b, arguments.length > 1)
},
show: function() {
return Wb(this, !0)
},
hide: function() {
return Wb(this)
},
toggle: function(a) {
return "boolean" == typeof a ? a ? this.show() : this.hide() : this.each(function() {
V(this) ? n(this).show() : n(this).hide()
})
}
});
function $b(a, b, c, d, e) {
return new $b.prototype.init(a, b, c, d, e)
}
n.Tween = $b,
$b.prototype = {
constructor: $b,
init: function(a, b, c, d, e, f) {
this.elem = a,
this.prop = c,
this.easing = e || "swing",
this.options = b,
this.start = this.now = this.cur(),
this.end = d,
this.unit = f || (n.cssNumber[c] ? "": "px")
},
cur: function() {
var a = $b.propHooks[this.prop];
return a && a.get ? a.get(this) : $b.propHooks._default.get(this)
},
run: function(a) {
var b, c = $b.propHooks[this.prop];
return this.pos = b = this.options.duration ? n.easing[this.easing](a, this.options.duration * a, 0, 1, this.options.duration) : a,
this.now = (this.end - this.start) * b + this.start,
this.options.step && this.options.step.call(this.elem, this.now, this),
c && c.set ? c.set(this) : $b.propHooks._default.set(this),
this
}
},
$b.prototype.init.prototype = $b.prototype,
$b.propHooks = {
_default: {
get: function(a) {
var b;
return null == a.elem[a.prop] || a.elem.style && null != a.elem.style[a.prop] ? (b = n.css(a.elem, a.prop, ""), b && "auto" !== b ? b: 0) : a.elem[a.prop]
},
set: function(a) {
n.fx.step[a.prop] ? n.fx.step[a.prop](a) : a.elem.style && (null != a.elem.style[n.cssProps[a.prop]] || n.cssHooks[a.prop]) ? n.style(a.elem, a.prop, a.now + a.unit) : a.elem[a.prop] = a.now
}
}
},
$b.propHooks.scrollTop = $b.propHooks.scrollLeft = {
set: function(a) {
a.elem.nodeType && a.elem.parentNode && (a.elem[a.prop] = a.now)
}
},
n.easing = {
linear: function(a) {
return a
},
swing: function(a) {
return.5 - Math.cos(a * Math.PI) / 2
}
},
n.fx = $b.prototype.init,
n.fx.step = {};
var _b, ac, bc = /^(?:toggle|show|hide)$/,
cc = new RegExp("^(?:([+-])=|)(" + T + ")([a-z%]*)$", "i"),
dc = /queueHooks$/,
ec = [jc],
fc = {
"*": [function(a, b) {
var c = this.createTween(a, b),
d = c.cur(),
e = cc.exec(b),
f = e && e[3] || (n.cssNumber[a] ? "": "px"),
g = (n.cssNumber[a] || "px" !== f && +d) && cc.exec(n.css(c.elem, a)),
h = 1,
i = 20;
if (g && g[3] !== f) {
f = f || g[3],
e = e || [],
g = +d || 1;
do h = h || ".5",
g /= h,
n.style(c.elem, a, g + f);
while (h !== (h = c.cur() / d) && 1 !== h && --i)
}
return e && (g = c.start = +g || +d || 0, c.unit = f, c.end = e[1] ? g + (e[1] + 1) * e[2] : +e[2]),
c
}]
};
function gc() {
return setTimeout(function() {
_b = void 0
}),
_b = n.now()
}
function hc(a, b) {
var c, d = {
height: a
},
e = 0;
for (b = b ? 1 : 0; 4 > e; e += 2 - b) c = U[e],
d["margin" + c] = d["padding" + c] = a;
return b && (d.opacity = d.width = a),
d
}
function ic(a, b, c) {
for (var d, e = (fc[b] || []).concat(fc["*"]), f = 0, g = e.length; g > f; f++) if (d = e[f].call(c, b, a)) return d
}
function jc(a, b, c) {
var d, e, f, g, h, i, j, k, m = this,
o = {},
p = a.style,
q = a.nodeType && V(a),
r = n._data(a, "fxshow");
c.queue || (h = n._queueHooks(a, "fx"), null == h.unqueued && (h.unqueued = 0, i = h.empty.fire, h.empty.fire = function() {
h.unqueued || i()
}), h.unqueued++, m.always(function() {
m.always(function() {
h.unqueued--,
n.queue(a, "fx").length || h.empty.fire()
})
})),
1 === a.nodeType && ("height" in b || "width" in b) && (c.overflow = [p.overflow, p.overflowX, p.overflowY], j = n.css(a, "display"), k = Gb(a.nodeName), "none" === j && (j = k), "inline" === j && "none" === n.css(a, "float") && (l.inlineBlockNeedsLayout && "inline" !== k ? p.zoom = 1 : p.display = "inline-block")),
c.overflow && (p.overflow = "hidden", l.shrinkWrapBlocks() || m.always(function() {
p.overflow = c.overflow[0],
p.overflowX = c.overflow[1],
p.overflowY = c.overflow[2]
}));
for (d in b) if (e = b[d], bc.exec(e)) {
if (delete b[d], f = f || "toggle" === e, e === (q ? "hide": "show")) {
if ("show" !== e || !r || void 0 === r[d]) continue;
q = !0
}
o[d] = r && r[d] || n.style(a, d)
}
if (!n.isEmptyObject(o)) {
r ? "hidden" in r && (q = r.hidden) : r = n._data(a, "fxshow", {}),
f && (r.hidden = !q),
q ? n(a).show() : m.done(function() {
n(a).hide()
}),
m.done(function() {
var b;
n._removeData(a, "fxshow");
for (b in o) n.style(a, b, o[b])
});
for (d in o) g = ic(q ? r[d] : 0, d, m),
d in r || (r[d] = g.start, q && (g.end = g.start, g.start = "width" === d || "height" === d ? 1 : 0))
}
}
function kc(a, b) {
var c, d, e, f, g;
for (c in a) if (d = n.camelCase(c), e = b[d], f = a[c], n.isArray(f) && (e = f[1], f = a[c] = f[0]), c !== d && (a[d] = f, delete a[c]), g = n.cssHooks[d], g && "expand" in g) {
f = g.expand(f),
delete a[d];
for (c in f) c in a || (a[c] = f[c], b[c] = e)
} else b[d] = e
}
function lc(a, b, c) {
var d, e, f = 0,
g = ec.length,
h = n.Deferred().always(function() {
delete i.elem
}),
i = function() {
if (e) return ! 1;
for (var b = _b || gc(), c = Math.max(0, j.startTime + j.duration - b), d = c / j.duration || 0, f = 1 - d, g = 0, i = j.tweens.length; i > g; g++) j.tweens[g].run(f);
return h.notifyWith(a, [j, f, c]),
1 > f && i ? c: (h.resolveWith(a, [j]), !1)
},
j = h.promise({
elem: a,
props: n.extend({},
b),
opts: n.extend(!0, {
specialEasing: {}
},
c),
originalProperties: b,
originalOptions: c,
startTime: _b || gc(),
duration: c.duration,
tweens: [],
createTween: function(b, c) {
var d = n.Tween(a, j.opts, b, c, j.opts.specialEasing[b] || j.opts.easing);
return j.tweens.push(d),
d
},
stop: function(b) {
var c = 0,
d = b ? j.tweens.length: 0;
if (e) return this;
for (e = !0; d > c; c++) j.tweens[c].run(1);
return b ? h.resolveWith(a, [j, b]) : h.rejectWith(a, [j, b]),
this
}
}),
k = j.props;
for (kc(k, j.opts.specialEasing); g > f; f++) if (d = ec[f].call(j, a, k, j.opts)) return d;
return n.map(k, ic, j),
n.isFunction(j.opts.start) && j.opts.start.call(a, j),
n.fx.timer(n.extend(i, {
elem: a,
anim: j,
queue: j.opts.queue
})),
j.progress(j.opts.progress).done(j.opts.done, j.opts.complete).fail(j.opts.fail).always(j.opts.always)
}
n.Animation = n.extend(lc, {
tweener: function(a, b) {
n.isFunction(a) ? (b = a, a = ["*"]) : a = a.split(" ");
for (var c, d = 0,
e = a.length; e > d; d++) c = a[d],
fc[c] = fc[c] || [],
fc[c].unshift(b)
},
prefilter: function(a, b) {
b ? ec.unshift(a) : ec.push(a)
}
}),
n.speed = function(a, b, c) {
var d = a && "object" == typeof a ? n.extend({},
a) : {
complete: c || !c && b || n.isFunction(a) && a,
duration: a,
easing: c && b || b && !n.isFunction(b) && b
};
return d.duration = n.fx.off ? 0 : "number" == typeof d.duration ? d.duration: d.duration in n.fx.speeds ? n.fx.speeds[d.duration] : n.fx.speeds._default,
(null == d.queue || d.queue === !0) && (d.queue = "fx"),
d.old = d.complete,
d.complete = function() {
n.isFunction(d.old) && d.old.call(this),
d.queue && n.dequeue(this, d.queue)
},
d
},
n.fn.extend({
fadeTo: function(a, b, c, d) {
return this.filter(V).css("opacity", 0).show().end().animate({
opacity: b
},
a, c, d)
},
animate: function(a, b, c, d) {
var e = n.isEmptyObject(a),
f = n.speed(b, c, d),
g = function() {
var b = lc(this, n.extend({},
a), f); (e || n._data(this, "finish")) && b.stop(!0)
};
return g.finish = g,
e || f.queue === !1 ? this.each(g) : this.queue(f.queue, g)
},
stop: function(a, b, c) {
var d = function(a) {
var b = a.stop;
delete a.stop,
b(c)
};
return "string" != typeof a && (c = b, b = a, a = void 0),
b && a !== !1 && this.queue(a || "fx", []),
this.each(function() {
var b = !0,
e = null != a && a + "queueHooks",
f = n.timers,
g = n._data(this);
if (e) g[e] && g[e].stop && d(g[e]);
else for (e in g) g[e] && g[e].stop && dc.test(e) && d(g[e]);
for (e = f.length; e--;) f[e].elem !== this || null != a && f[e].queue !== a || (f[e].anim.stop(c), b = !1, f.splice(e, 1)); (b || !c) && n.dequeue(this, a)
})
},
finish: function(a) {
return a !== !1 && (a = a || "fx"),
this.each(function() {
var b, c = n._data(this),
d = c[a + "queue"],
e = c[a + "queueHooks"],
f = n.timers,
g = d ? d.length: 0;
for (c.finish = !0, n.queue(this, a, []), e && e.stop && e.stop.call(this, !0), b = f.length; b--;) f[b].elem === this && f[b].queue === a && (f[b].anim.stop(!0), f.splice(b, 1));
for (b = 0; g > b; b++) d[b] && d[b].finish && d[b].finish.call(this);
delete c.finish
})
}
}),
n.each(["toggle", "show", "hide"],
function(a, b) {
var c = n.fn[b];
n.fn[b] = function(a, d, e) {
return null == a || "boolean" == typeof a ? c.apply(this, arguments) : this.animate(hc(b, !0), a, d, e)
}
}),
n.each({
slideDown: hc("show"),
slideUp: hc("hide"),
slideToggle: hc("toggle"),
fadeIn: {
opacity: "show"
},
fadeOut: {
opacity: "hide"
},
fadeToggle: {
opacity: "toggle"
}
},
function(a, b) {
n.fn[a] = function(a, c, d) {
return this.animate(b, a, c, d)
}
}),
n.timers = [],
n.fx.tick = function() {
var a, b = n.timers,
c = 0;
for (_b = n.now(); c < b.length; c++) a = b[c],
a() || b[c] !== a || b.splice(c--, 1);
b.length || n.fx.stop(),
_b = void 0
},
n.fx.timer = function(a) {
n.timers.push(a),
a() ? n.fx.start() : n.timers.pop()
},
n.fx.interval = 13,
n.fx.start = function() {
ac || (ac = setInterval(n.fx.tick, n.fx.interval))
},
n.fx.stop = function() {
clearInterval(ac),
ac = null
},
n.fx.speeds = {
slow: 600,
fast: 200,
_default: 400
},
n.fn.delay = function(a, b) {
return a = n.fx ? n.fx.speeds[a] || a: a,
b = b || "fx",
this.queue(b,
function(b, c) {
var d = setTimeout(b, a);
c.stop = function() {
clearTimeout(d)
}
})
},
function() {
var a, b, c, d, e = z.createElement("div");
e.setAttribute("className", "t"),
e.innerHTML = " <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
a = e.getElementsByTagName("a")[0],
c = z.createElement("select"),
d = c.appendChild(z.createElement("option")),
b = e.getElementsByTagName("input")[0],
a.style.cssText = "top:1px",
l.getSetAttribute = "t" !== e.className,
l.style = /top/.test(a.getAttribute("style")),
l.hrefNormalized = "/a" === a.getAttribute("href"),
l.checkOn = !!b.value,
l.optSelected = d.selected,
l.enctype = !!z.createElement("form").enctype,
c.disabled = !0,
l.optDisabled = !d.disabled,
b = z.createElement("input"),
b.setAttribute("value", ""),
l.input = "" === b.getAttribute("value"),
b.value = "t",
b.setAttribute("type", "radio"),
l.radioValue = "t" === b.value,
a = b = c = d = e = null
} ();
var mc = /\r/g;
n.fn.extend({
val: function(a) {
var b, c, d, e = this[0]; {
if (arguments.length) return d = n.isFunction(a),
this.each(function(c) {
var e;
1 === this.nodeType && (e = d ? a.call(this, c, n(this).val()) : a, null == e ? e = "": "number" == typeof e ? e += "": n.isArray(e) && (e = n.map(e,
function(a) {
return null == a ? "": a + ""
})), b = n.valHooks[this.type] || n.valHooks[this.nodeName.toLowerCase()], b && "set" in b && void 0 !== b.set(this, e, "value") || (this.value = e))
});
if (e) return b = n.valHooks[e.type] || n.valHooks[e.nodeName.toLowerCase()],
b && "get" in b && void 0 !== (c = b.get(e, "value")) ? c: (c = e.value, "string" == typeof c ? c.replace(mc, "") : null == c ? "": c)
}
}
}),
n.extend({
valHooks: {
option: {
get: function(a) {
var b = n.find.attr(a, "value");
return null != b ? b: n.text(a)
}
},
select: {
get: function(a) {
for (var b, c, d = a.options,
e = a.selectedIndex,
f = "select-one" === a.type || 0 > e,
g = f ? null: [], h = f ? e + 1 : d.length, i = 0 > e ? h: f ? e: 0; h > i; i++) if (c = d[i], !(!c.selected && i !== e || (l.optDisabled ? c.disabled: null !== c.getAttribute("disabled")) || c.parentNode.disabled && n.nodeName(c.parentNode, "optgroup"))) {
if (b = n(c).val(), f) return b;
g.push(b)
}
return g
},
set: function(a, b) {
var c, d, e = a.options,
f = n.makeArray(b),
g = e.length;
while (g--) if (d = e[g], n.inArray(n.valHooks.option.get(d), f) >= 0) try {
d.selected = c = !0
} catch(h) {
d.scrollHeight
} else d.selected = !1;
return c || (a.selectedIndex = -1),
e
}
}
}
}),
n.each(["radio", "checkbox"],
function() {
n.valHooks[this] = {
set: function(a, b) {
return n.isArray(b) ? a.checked = n.inArray(n(a).val(), b) >= 0 : void 0
}
},
l.checkOn || (n.valHooks[this].get = function(a) {
return null === a.getAttribute("value") ? "on": a.value
})
});
var nc, oc, pc = n.expr.attrHandle,
qc = /^(?:checked|selected)$/i,
rc = l.getSetAttribute,
sc = l.input;
n.fn.extend({
attr: function(a, b) {
return W(this, n.attr, a, b, arguments.length > 1)
},
removeAttr: function(a) {
return this.each(function() {
n.removeAttr(this, a)
})
}
}),
n.extend({
attr: function(a, b, c) {
var d, e, f = a.nodeType;
if (a && 3 !== f && 8 !== f && 2 !== f) return typeof a.getAttribute === L ? n.prop(a, b, c) : (1 === f && n.isXMLDoc(a) || (b = b.toLowerCase(), d = n.attrHooks[b] || (n.expr.match.bool.test(b) ? oc: nc)), void 0 === c ? d && "get" in d && null !== (e = d.get(a, b)) ? e: (e = n.find.attr(a, b), null == e ? void 0 : e) : null !== c ? d && "set" in d && void 0 !== (e = d.set(a, c, b)) ? e: (a.setAttribute(b, c + ""), c) : void n.removeAttr(a, b))
},
removeAttr: function(a, b) {
var c, d, e = 0,
f = b && b.match(F);
if (f && 1 === a.nodeType) while (c = f[e++]) d = n.propFix[c] || c,
n.expr.match.bool.test(c) ? sc && rc || !qc.test(c) ? a[d] = !1 : a[n.camelCase("default-" + c)] = a[d] = !1 : n.attr(a, c, ""),
a.removeAttribute(rc ? c: d)
},
attrHooks: {
type: {
set: function(a, b) {
if (!l.radioValue && "radio" === b && n.nodeName(a, "input")) {
var c = a.value;
return a.setAttribute("type", b),
c && (a.value = c),
b
}
}
}
}
}),
oc = {
set: function(a, b, c) {
return b === !1 ? n.removeAttr(a, c) : sc && rc || !qc.test(c) ? a.setAttribute(!rc && n.propFix[c] || c, c) : a[n.camelCase("default-" + c)] = a[c] = !0,
c
}
},
n.each(n.expr.match.bool.source.match(/\w+/g),
function(a, b) {
var c = pc[b] || n.find.attr;
pc[b] = sc && rc || !qc.test(b) ?
function(a, b, d) {
var e, f;
return d || (f = pc[b], pc[b] = e, e = null != c(a, b, d) ? b.toLowerCase() : null, pc[b] = f),
e
}: function(a, b, c) {
return c ? void 0 : a[n.camelCase("default-" + b)] ? b.toLowerCase() : null
}
}),
sc && rc || (n.attrHooks.value = {
set: function(a, b, c) {
return n.nodeName(a, "input") ? void(a.defaultValue = b) : nc && nc.set(a, b, c)
}
}),
rc || (nc = {
set: function(a, b, c) {
var d = a.getAttributeNode(c);
return d || a.setAttributeNode(d = a.ownerDocument.createAttribute(c)),
d.value = b += "",
"value" === c || b === a.getAttribute(c) ? b: void 0
}
},
pc.id = pc.name = pc.coords = function(a, b, c) {
var d;
return c ? void 0 : (d = a.getAttributeNode(b)) && "" !== d.value ? d.value: null
},
n.valHooks.button = {
get: function(a, b) {
var c = a.getAttributeNode(b);
return c && c.specified ? c.value: void 0
},
set: nc.set
},
n.attrHooks.contenteditable = {
set: function(a, b, c) {
nc.set(a, "" === b ? !1 : b, c)
}
},
n.each(["width", "height"],
function(a, b) {
n.attrHooks[b] = {
set: function(a, c) {
return "" === c ? (a.setAttribute(b, "auto"), c) : void 0
}
}
})),
l.style || (n.attrHooks.style = {
get: function(a) {
return a.style.cssText || void 0
},
set: function(a, b) {
return a.style.cssText = b + ""
}
});
var tc = /^(?:input|select|textarea|button|object)$/i,
uc = /^(?:a|area)$/i;
n.fn.extend({
prop: function(a, b) {
return W(this, n.prop, a, b, arguments.length > 1)
},
removeProp: function(a) {
return a = n.propFix[a] || a,
this.each(function() {
try {
this[a] = void 0,
delete this[a]
} catch(b) {}
})
}
}),
n.extend({
propFix: {
"for": "htmlFor",
"class": "className"
},
prop: function(a, b, c) {
var d, e, f, g = a.nodeType;
if (a && 3 !== g && 8 !== g && 2 !== g) return f = 1 !== g || !n.isXMLDoc(a),
f && (b = n.propFix[b] || b, e = n.propHooks[b]),
void 0 !== c ? e && "set" in e && void 0 !== (d = e.set(a, c, b)) ? d: a[b] = c: e && "get" in e && null !== (d = e.get(a, b)) ? d: a[b]
},
propHooks: {
tabIndex: {
get: function(a) {
var b = n.find.attr(a, "tabindex");
return b ? parseInt(b, 10) : tc.test(a.nodeName) || uc.test(a.nodeName) && a.href ? 0 : -1
}
}
}
}),
l.hrefNormalized || n.each(["href", "src"],
function(a, b) {
n.propHooks[b] = {
get: function(a) {
return a.getAttribute(b, 4)
}
}
}),
l.optSelected || (n.propHooks.selected = {
get: function(a) {
var b = a.parentNode;
return b && (b.selectedIndex, b.parentNode && b.parentNode.selectedIndex),
null
}
}),
n.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"],
function() {
n.propFix[this.toLowerCase()] = this
}),
l.enctype || (n.propFix.enctype = "encoding");
var vc = /[\t\r\n\f]/g;
n.fn.extend({
addClass: function(a) {
var b, c, d, e, f, g, h = 0,
i = this.length,
j = "string" == typeof a && a;
if (n.isFunction(a)) return this.each(function(b) {
n(this).addClass(a.call(this, b, this.className))
});
if (j) for (b = (a || "").match(F) || []; i > h; h++) if (c = this[h], d = 1 === c.nodeType && (c.className ? (" " + c.className + " ").replace(vc, " ") : " ")) {
f = 0;
while (e = b[f++]) d.indexOf(" " + e + " ") < 0 && (d += e + " ");
g = n.trim(d),
c.className !== g && (c.className = g)
}
return this
},
removeClass: function(a) {
var b, c, d, e, f, g, h = 0,
i = this.length,
j = 0 === arguments.length || "string" == typeof a && a;
if (n.isFunction(a)) return this.each(function(b) {
n(this).removeClass(a.call(this, b, this.className))
});
if (j) for (b = (a || "").match(F) || []; i > h; h++) if (c = this[h], d = 1 === c.nodeType && (c.className ? (" " + c.className + " ").replace(vc, " ") : "")) {
f = 0;
while (e = b[f++]) while (d.indexOf(" " + e + " ") >= 0) d = d.replace(" " + e + " ", " ");
g = a ? n.trim(d) : "",
c.className !== g && (c.className = g)
}
return this
},
toggleClass: function(a, b) {
var c = typeof a;
return "boolean" == typeof b && "string" === c ? b ? this.addClass(a) : this.removeClass(a) : this.each(n.isFunction(a) ?
function(c) {
n(this).toggleClass(a.call(this, c, this.className, b), b)
}: function() {
if ("string" === c) {
var b, d = 0,
e = n(this),
f = a.match(F) || [];
while (b = f[d++]) e.hasClass(b) ? e.removeClass(b) : e.addClass(b)
} else(c === L || "boolean" === c) && (this.className && n._data(this, "__className__", this.className), this.className = this.className || a === !1 ? "": n._data(this, "__className__") || "")
})
},
hasClass: function(a) {
for (var b = " " + a + " ",
c = 0,
d = this.length; d > c; c++) if (1 === this[c].nodeType && (" " + this[c].className + " ").replace(vc, " ").indexOf(b) >= 0) return ! 0;
return ! 1
}
}),
n.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),
function(a, b) {
n.fn[b] = function(a, c) {
return arguments.length > 0 ? this.on(b, null, a, c) : this.trigger(b)
}
}),
n.fn.extend({
hover: function(a, b) {
return this.mouseenter(a).mouseleave(b || a)
},
bind: function(a, b, c) {
return this.on(a, null, b, c)
},
unbind: function(a, b) {
return this.off(a, null, b)
},
delegate: function(a, b, c, d) {
return this.on(b, a, c, d)
},
undelegate: function(a, b, c) {
return 1 === arguments.length ? this.off(a, "**") : this.off(b, a || "**", c)
}
});
var wc = n.now(),
xc = /\?/,
yc = /(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g;
n.parseJSON = function(b) {
if (a.JSON && a.JSON.parse) return a.JSON.parse(b + "");
var c, d = null,
e = n.trim(b + "");
return e && !n.trim(e.replace(yc,
function(a, b, e, f) {
return c && b && (d = 0),
0 === d ? a: (c = e || b, d += !f - !e, "")
})) ? Function("return " + e)() : n.error("Invalid JSON: " + b)
},
n.parseXML = function(b) {
var c, d;
if (!b || "string" != typeof b) return null;
try {
a.DOMParser ? (d = new DOMParser, c = d.parseFromString(b, "text/xml")) : (c = new ActiveXObject("Microsoft.XMLDOM"), c.async = "false", c.loadXML(b))
} catch(e) {
c = void 0
}
return c && c.documentElement && !c.getElementsByTagName("parsererror").length || n.error("Invalid XML: " + b),
c
};
var zc, Ac, Bc = /#.*$/,
Cc = /([?&])_=[^&]*/,
Dc = /^(.*?):[ \t]*([^\r\n]*)\r?$/gm,
Ec = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,
Fc = /^(?:GET|HEAD)$/,
Gc = /^\/\//,
Hc = /^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,
Ic = {},
Jc = {},
Kc = "*/".concat("*");
try {
Ac = location.href
} catch(Lc) {
Ac = z.createElement("a"),
Ac.href = "",
Ac = Ac.href
}
zc = Hc.exec(Ac.toLowerCase()) || [];
function Mc(a) {
return function(b, c) {
"string" != typeof b && (c = b, b = "*");
var d, e = 0,
f = b.toLowerCase().match(F) || [];
if (n.isFunction(c)) while (d = f[e++])"+" === d.charAt(0) ? (d = d.slice(1) || "*", (a[d] = a[d] || []).unshift(c)) : (a[d] = a[d] || []).push(c)
}
}
function Nc(a, b, c, d) {
var e = {},
f = a === Jc;
function g(h) {
var i;
return e[h] = !0,
n.each(a[h] || [],
function(a, h) {
var j = h(b, c, d);
return "string" != typeof j || f || e[j] ? f ? !(i = j) : void 0 : (b.dataTypes.unshift(j), g(j), !1)
}),
i
}
return g(b.dataTypes[0]) || !e["*"] && g("*")
}
function Oc(a, b) {
var c, d, e = n.ajaxSettings.flatOptions || {};
for (d in b) void 0 !== b[d] && ((e[d] ? a: c || (c = {}))[d] = b[d]);
return c && n.extend(!0, a, c),
a
}
function Pc(a, b, c) {
var d, e, f, g, h = a.contents,
i = a.dataTypes;
while ("*" === i[0]) i.shift(),
void 0 === e && (e = a.mimeType || b.getResponseHeader("Content-Type"));
if (e) for (g in h) if (h[g] && h[g].test(e)) {
i.unshift(g);
break
}
if (i[0] in c) f = i[0];
else {
for (g in c) {
if (!i[0] || a.converters[g + " " + i[0]]) {
f = g;
break
}
d || (d = g)
}
f = f || d
}
return f ? (f !== i[0] && i.unshift(f), c[f]) : void 0
}
function Qc(a, b, c, d) {
var e, f, g, h, i, j = {},
k = a.dataTypes.slice();
if (k[1]) for (g in a.converters) j[g.toLowerCase()] = a.converters[g];
f = k.shift();
while (f) if (a.responseFields[f] && (c[a.responseFields[f]] = b), !i && d && a.dataFilter && (b = a.dataFilter(b, a.dataType)), i = f, f = k.shift()) if ("*" === f) f = i;
else if ("*" !== i && i !== f) {
if (g = j[i + " " + f] || j["* " + f], !g) for (e in j) if (h = e.split(" "), h[1] === f && (g = j[i + " " + h[0]] || j["* " + h[0]])) {
g === !0 ? g = j[e] : j[e] !== !0 && (f = h[0], k.unshift(h[1]));
break
}
if (g !== !0) if (g && a["throws"]) b = g(b);
else try {
b = g(b)
} catch(l) {
return {
state: "parsererror",
error: g ? l: "No conversion from " + i + " to " + f
}
}
}
return {
state: "success",
data: b
}
}
n.extend({
active: 0,
lastModified: {},
etag: {},
ajaxSettings: {
url: Ac,
type: "GET",
isLocal: Ec.test(zc[1]),
global: !0,
processData: !0,
async: !0,
contentType: "application/x-www-form-urlencoded; charset=UTF-8",
accepts: {
"*": Kc,
text: "text/plain",
html: "text/html",
xml: "application/xml, text/xml",
json: "application/json, text/javascript"
},
contents: {
xml: /xml/,
html: /html/,
json: /json/
},
responseFields: {
xml: "responseXML",
text: "responseText",
json: "responseJSON"
},
converters: {
"* text": String,
"text html": !0,
"text json": n.parseJSON,
"text xml": n.parseXML
},
flatOptions: {
url: !0,
context: !0
}
},
ajaxSetup: function(a, b) {
return b ? Oc(Oc(a, n.ajaxSettings), b) : Oc(n.ajaxSettings, a)
},
ajaxPrefilter: Mc(Ic),
ajaxTransport: Mc(Jc),
ajax: function(a, b) {
"object" == typeof a && (b = a, a = void 0),
b = b || {};
var c, d, e, f, g, h, i, j, k = n.ajaxSetup({},
b),
l = k.context || k,
m = k.context && (l.nodeType || l.jquery) ? n(l) : n.event,
o = n.Deferred(),
p = n.Callbacks("once memory"),
q = k.statusCode || {},
r = {},
s = {},
t = 0,
u = "canceled",
v = {
readyState: 0,
getResponseHeader: function(a) {
var b;
if (2 === t) {
if (!j) {
j = {};
while (b = Dc.exec(f)) j[b[1].toLowerCase()] = b[2]
}
b = j[a.toLowerCase()]
}
return null == b ? null: b
},
getAllResponseHeaders: function() {
return 2 === t ? f: null
},
setRequestHeader: function(a, b) {
var c = a.toLowerCase();
return t || (a = s[c] = s[c] || a, r[a] = b),
this
},
overrideMimeType: function(a) {
return t || (k.mimeType = a),
this
},
statusCode: function(a) {
var b;
if (a) if (2 > t) for (b in a) q[b] = [q[b], a[b]];
else v.always(a[v.status]);
return this
},
abort: function(a) {
var b = a || u;
return i && i.abort(b),
x(0, b),
this
}
};
if (o.promise(v).complete = p.add, v.success = v.done, v.error = v.fail, k.url = ((a || k.url || Ac) + "").replace(Bc, "").replace(Gc, zc[1] + "//"), k.type = b.method || b.type || k.method || k.type, k.dataTypes = n.trim(k.dataType || "*").toLowerCase().match(F) || [""], null == k.crossDomain && (c = Hc.exec(k.url.toLowerCase()), k.crossDomain = !(!c || c[1] === zc[1] && c[2] === zc[2] && (c[3] || ("http:" === c[1] ? "80": "443")) === (zc[3] || ("http:" === zc[1] ? "80": "443")))), k.data && k.processData && "string" != typeof k.data && (k.data = n.param(k.data, k.traditional)), Nc(Ic, k, b, v), 2 === t) return v;
h = k.global,
h && 0 === n.active++&&n.event.trigger("ajaxStart"),
k.type = k.type.toUpperCase(),
k.hasContent = !Fc.test(k.type),
e = k.url,
k.hasContent || (k.data && (e = k.url += (xc.test(e) ? "&": "?") + k.data, delete k.data), k.cache === !1 && (k.url = Cc.test(e) ? e.replace(Cc, "$1_=" + wc++) : e + (xc.test(e) ? "&": "?") + "_=" + wc++)),
k.ifModified && (n.lastModified[e] && v.setRequestHeader("If-Modified-Since", n.lastModified[e]), n.etag[e] && v.setRequestHeader("If-None-Match", n.etag[e])),
(k.data && k.hasContent && k.contentType !== !1 || b.contentType) && v.setRequestHeader("Content-Type", k.contentType),
v.setRequestHeader("Accept", k.dataTypes[0] && k.accepts[k.dataTypes[0]] ? k.accepts[k.dataTypes[0]] + ("*" !== k.dataTypes[0] ? ", " + Kc + "; q=0.01": "") : k.accepts["*"]);
for (d in k.headers) v.setRequestHeader(d, k.headers[d]);
if (k.beforeSend && (k.beforeSend.call(l, v, k) === !1 || 2 === t)) return v.abort();
u = "abort";
for (d in {
success: 1,
error: 1,
complete: 1
}) v[d](k[d]);
if (i = Nc(Jc, k, b, v)) {
v.readyState = 1,
h && m.trigger("ajaxSend", [v, k]),
k.async && k.timeout > 0 && (g = setTimeout(function() {
v.abort("timeout")
},
k.timeout));
try {
t = 1,
i.send(r, x)
} catch(w) {
if (! (2 > t)) throw w;
x( - 1, w)
}
} else x( - 1, "No Transport");
function x(a, b, c, d) {
var j, r, s, u, w, x = b;
2 !== t && (t = 2, g && clearTimeout(g), i = void 0, f = d || "", v.readyState = a > 0 ? 4 : 0, j = a >= 200 && 300 > a || 304 === a, c && (u = Pc(k, v, c)), u = Qc(k, u, v, j), j ? (k.ifModified && (w = v.getResponseHeader("Last-Modified"), w && (n.lastModified[e] = w), w = v.getResponseHeader("etag"), w && (n.etag[e] = w)), 204 === a || "HEAD" === k.type ? x = "nocontent": 304 === a ? x = "notmodified": (x = u.state, r = u.data, s = u.error, j = !s)) : (s = x, (a || !x) && (x = "error", 0 > a && (a = 0))), v.status = a, v.statusText = (b || x) + "", j ? o.resolveWith(l, [r, x, v]) : o.rejectWith(l, [v, x, s]), v.statusCode(q), q = void 0, h && m.trigger(j ? "ajaxSuccess": "ajaxError", [v, k, j ? r: s]), p.fireWith(l, [v, x]), h && (m.trigger("ajaxComplete", [v, k]), --n.active || n.event.trigger("ajaxStop")))
}
return v
},
getJSON: function(a, b, c) {
return n.get(a, b, c, "json")
},
getScript: function(a, b) {
return n.get(a, void 0, b, "script")
}
}),
n.each(["get", "post"],
function(a, b) {
n[b] = function(a, c, d, e) {
return n.isFunction(c) && (e = e || d, d = c, c = void 0),
n.ajax({
url: a,
type: b,
dataType: e,
data: c,
success: d
})
}
}),
n.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"],
function(a, b) {
n.fn[b] = function(a) {
return this.on(b, a)
}
}),
n._evalUrl = function(a) {
return n.ajax({
url: a,
type: "GET",
dataType: "script",
async: !1,
global: !1,
"throws": !0
})
},
n.fn.extend({
wrapAll: function(a) {
if (n.isFunction(a)) return this.each(function(b) {
n(this).wrapAll(a.call(this, b))
});
if (this[0]) {
var b = n(a, this[0].ownerDocument).eq(0).clone(!0);
this[0].parentNode && b.insertBefore(this[0]),
b.map(function() {
var a = this;
while (a.firstChild && 1 === a.firstChild.nodeType) a = a.firstChild;
return a
}).append(this)
}
return this
},
wrapInner: function(a) {
return this.each(n.isFunction(a) ?
function(b) {
n(this).wrapInner(a.call(this, b))
}: function() {
var b = n(this),
c = b.contents();
c.length ? c.wrapAll(a) : b.append(a)
})
},
wrap: function(a) {
var b = n.isFunction(a);
return this.each(function(c) {
n(this).wrapAll(b ? a.call(this, c) : a)
})
},
unwrap: function() {
return this.parent().each(function() {
n.nodeName(this, "body") || n(this).replaceWith(this.childNodes)
}).end()
}
}),
n.expr.filters.hidden = function(a) {
return a.offsetWidth <= 0 && a.offsetHeight <= 0 || !l.reliableHiddenOffsets() && "none" === (a.style && a.style.display || n.css(a, "display"))
},
n.expr.filters.visible = function(a) {
return ! n.expr.filters.hidden(a)
};
var Rc = /%20/g,
Sc = /\[\]$/,
Tc = /\r?\n/g,
Uc = /^(?:submit|button|image|reset|file)$/i,
Vc = /^(?:input|select|textarea|keygen)/i;
function Wc(a, b, c, d) {
var e;
if (n.isArray(b)) n.each(b,
function(b, e) {
c || Sc.test(a) ? d(a, e) : Wc(a + "[" + ("object" == typeof e ? b: "") + "]", e, c, d)
});
else if (c || "object" !== n.type(b)) d(a, b);
else for (e in b) Wc(a + "[" + e + "]", b[e], c, d)
}
n.param = function(a, b) {
var c, d = [],
e = function(a, b) {
b = n.isFunction(b) ? b() : null == b ? "": b,
d[d.length] = encodeURIComponent(a) + "=" + encodeURIComponent(b)
};
if (void 0 === b && (b = n.ajaxSettings && n.ajaxSettings.traditional), n.isArray(a) || a.jquery && !n.isPlainObject(a)) n.each(a,
function() {
e(this.name, this.value)
});
else for (c in a) Wc(c, a[c], b, e);
return d.join("&").replace(Rc, "+")
},
n.fn.extend({
serialize: function() {
return n.param(this.serializeArray())
},
serializeArray: function() {
return this.map(function() {
var a = n.prop(this, "elements");
return a ? n.makeArray(a) : this
}).filter(function() {
var a = this.type;
return this.name && !n(this).is(":disabled") && Vc.test(this.nodeName) && !Uc.test(a) && (this.checked || !X.test(a))
}).map(function(a, b) {
var c = n(this).val();
return null == c ? null: n.isArray(c) ? n.map(c,
function(a) {
return {
name: b.name,
value: a.replace(Tc, "\r\n")
}
}) : {
name: b.name,
value: c.replace(Tc, "\r\n")
}
}).get()
}
}),
n.ajaxSettings.xhr = void 0 !== a.ActiveXObject ?
function() {
return ! this.isLocal && /^(get|post|head|put|delete|options)$/i.test(this.type) && $c() || _c()
}: $c;
var Xc = 0,
Yc = {},
Zc = n.ajaxSettings.xhr();
a.ActiveXObject && n(a).on("unload",
function() {
for (var a in Yc) Yc[a](void 0, !0)
}),
l.cors = !!Zc && "withCredentials" in Zc,
Zc = l.ajax = !!Zc,
Zc && n.ajaxTransport(function(a) {
if (!a.crossDomain || l.cors) {
var b;
return {
send: function(c, d) {
var e, f = a.xhr(),
g = ++Xc;
if (f.open(a.type, a.url, a.async, a.username, a.password), a.xhrFields) for (e in a.xhrFields) f[e] = a.xhrFields[e];
a.mimeType && f.overrideMimeType && f.overrideMimeType(a.mimeType),
a.crossDomain || c["X-Requested-With"] || (c["X-Requested-With"] = "XMLHttpRequest");
for (e in c) void 0 !== c[e] && f.setRequestHeader(e, c[e] + "");
f.send(a.hasContent && a.data || null),
b = function(c, e) {
var h, i, j;
if (b && (e || 4 === f.readyState)) if (delete Yc[g], b = void 0, f.onreadystatechange = n.noop, e) 4 !== f.readyState && f.abort();
else {
j = {},
h = f.status,
"string" == typeof f.responseText && (j.text = f.responseText);
try {
i = f.statusText
} catch(k) {
i = ""
}
h || !a.isLocal || a.crossDomain ? 1223 === h && (h = 204) : h = j.text ? 200 : 404
}
j && d(h, i, j, f.getAllResponseHeaders())
},
a.async ? 4 === f.readyState ? setTimeout(b) : f.onreadystatechange = Yc[g] = b: b()
},
abort: function() {
b && b(void 0, !0)
}
}
}
});
function $c() {
try {
return new a.XMLHttpRequest
} catch(b) {}
}
function _c() {
try {
return new a.ActiveXObject("Microsoft.XMLHTTP")
} catch(b) {}
}
n.ajaxSetup({
accepts: {
script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"
},
contents: {
script: /(?:java|ecma)script/
},
converters: {
"text script": function(a) {
return n.globalEval(a),
a
}
}
}),
n.ajaxPrefilter("script",
function(a) {
void 0 === a.cache && (a.cache = !1),
a.crossDomain && (a.type = "GET", a.global = !1)
}),
n.ajaxTransport("script",
function(a) {
if (a.crossDomain) {
var b, c = z.head || n("head")[0] || z.documentElement;
return {
send: function(d, e) {
b = z.createElement("script"),
b.async = !0,
a.scriptCharset && (b.charset = a.scriptCharset),
b.src = a.url,
b.onload = b.onreadystatechange = function(a, c) { (c || !b.readyState || /loaded|complete/.test(b.readyState)) && (b.onload = b.onreadystatechange = null, b.parentNode && b.parentNode.removeChild(b), b = null, c || e(200, "success"))
},
c.insertBefore(b, c.firstChild)
},
abort: function() {
b && b.onload(void 0, !0)
}
}
}
});
var ad = [],
bd = /(=)\?(?=&|$)|\?\?/;
n.ajaxSetup({
jsonp: "callback",
jsonpCallback: function() {
var a = ad.pop() || n.expando + "_" + wc++;
return this[a] = !0,
a
}
}),
n.ajaxPrefilter("json jsonp",
function(b, c, d) {
var e, f, g, h = b.jsonp !== !1 && (bd.test(b.url) ? "url": "string" == typeof b.data && !(b.contentType || "").indexOf("application/x-www-form-urlencoded") && bd.test(b.data) && "data");
return h || "jsonp" === b.dataTypes[0] ? (e = b.jsonpCallback = n.isFunction(b.jsonpCallback) ? b.jsonpCallback() : b.jsonpCallback, h ? b[h] = b[h].replace(bd, "$1" + e) : b.jsonp !== !1 && (b.url += (xc.test(b.url) ? "&": "?") + b.jsonp + "=" + e), b.converters["script json"] = function() {
return g || n.error(e + " was not called"),
g[0]
},
b.dataTypes[0] = "json", f = a[e], a[e] = function() {
g = arguments
},
d.always(function() {
a[e] = f,
b[e] && (b.jsonpCallback = c.jsonpCallback, ad.push(e)),
g && n.isFunction(f) && f(g[0]),
g = f = void 0
}), "script") : void 0
}),
n.parseHTML = function(a, b, c) {
if (!a || "string" != typeof a) return null;
"boolean" == typeof b && (c = b, b = !1),
b = b || z;
var d = v.exec(a),
e = !c && [];
return d ? [b.createElement(d[1])] : (d = n.buildFragment([a], b, e), e && e.length && n(e).remove(), n.merge([], d.childNodes))
};
var cd = n.fn.load;
n.fn.load = function(a, b, c) {
if ("string" != typeof a && cd) return cd.apply(this, arguments);
var d, e, f, g = this,
h = a.indexOf(" ");
return h >= 0 && (d = a.slice(h, a.length), a = a.slice(0, h)),
n.isFunction(b) ? (c = b, b = void 0) : b && "object" == typeof b && (f = "POST"),
g.length > 0 && n.ajax({
url: a,
type: f,
dataType: "html",
data: b
}).done(function(a) {
e = arguments,
g.html(d ? n("<div>").append(n.parseHTML(a)).find(d) : a)
}).complete(c &&
function(a, b) {
g.each(c, e || [a.responseText, b, a])
}),
this
},
n.expr.filters.animated = function(a) {
return n.grep(n.timers,
function(b) {
return a === b.elem
}).length
};
var dd = a.document.documentElement;
function ed(a) {
return n.isWindow(a) ? a: 9 === a.nodeType ? a.defaultView || a.parentWindow: !1
}
n.offset = {
setOffset: function(a, b, c) {
var d, e, f, g, h, i, j, k = n.css(a, "position"),
l = n(a),
m = {};
"static" === k && (a.style.position = "relative"),
h = l.offset(),
f = n.css(a, "top"),
i = n.css(a, "left"),
j = ("absolute" === k || "fixed" === k) && n.inArray("auto", [f, i]) > -1,
j ? (d = l.position(), g = d.top, e = d.left) : (g = parseFloat(f) || 0, e = parseFloat(i) || 0),
n.isFunction(b) && (b = b.call(a, c, h)),
null != b.top && (m.top = b.top - h.top + g),
null != b.left && (m.left = b.left - h.left + e),
"using" in b ? b.using.call(a, m) : l.css(m)
}
},
n.fn.extend({
offset: function(a) {
if (arguments.length) return void 0 === a ? this: this.each(function(b) {
n.offset.setOffset(this, a, b)
});
var b, c, d = {
top: 0,
left: 0
},
e = this[0],
f = e && e.ownerDocument;
if (f) return b = f.documentElement,
n.contains(b, e) ? (typeof e.getBoundingClientRect !== L && (d = e.getBoundingClientRect()), c = ed(f), {
top: d.top + (c.pageYOffset || b.scrollTop) - (b.clientTop || 0),
left: d.left + (c.pageXOffset || b.scrollLeft) - (b.clientLeft || 0)
}) : d
},
position: function() {
if (this[0]) {
var a, b, c = {
top: 0,
left: 0
},
d = this[0];
return "fixed" === n.css(d, "position") ? b = d.getBoundingClientRect() : (a = this.offsetParent(), b = this.offset(), n.nodeName(a[0], "html") || (c = a.offset()), c.top += n.css(a[0], "borderTopWidth", !0), c.left += n.css(a[0], "borderLeftWidth", !0)),
{
top: b.top - c.top - n.css(d, "marginTop", !0),
left: b.left - c.left - n.css(d, "marginLeft", !0)
}
}
},
offsetParent: function() {
return this.map(function() {
var a = this.offsetParent || dd;
while (a && !n.nodeName(a, "html") && "static" === n.css(a, "position")) a = a.offsetParent;
return a || dd
})
}
}),
n.each({
scrollLeft: "pageXOffset",
scrollTop: "pageYOffset"
},
function(a, b) {
var c = /Y/.test(b);
n.fn[a] = function(d) {
return W(this,
function(a, d, e) {
var f = ed(a);
return void 0 === e ? f ? b in f ? f[b] : f.document.documentElement[d] : a[d] : void(f ? f.scrollTo(c ? n(f).scrollLeft() : e, c ? e: n(f).scrollTop()) : a[d] = e)
},
a, d, arguments.length, null)
}
}),
n.each(["top", "left"],
function(a, b) {
n.cssHooks[b] = Mb(l.pixelPosition,
function(a, c) {
return c ? (c = Kb(a, b), Ib.test(c) ? n(a).position()[b] + "px": c) : void 0
})
}),
n.each({
Height: "height",
Width: "width"
},
function(a, b) {
n.each({
padding: "inner" + a,
content: b,
"": "outer" + a
},
function(c, d) {
n.fn[d] = function(d, e) {
var f = arguments.length && (c || "boolean" != typeof d),
g = c || (d === !0 || e === !0 ? "margin": "border");
return W(this,
function(b, c, d) {
var e;
return n.isWindow(b) ? b.document.documentElement["client" + a] : 9 === b.nodeType ? (e = b.documentElement, Math.max(b.body["scroll" + a], e["scroll" + a], b.body["offset" + a], e["offset" + a], e["client" + a])) : void 0 === d ? n.css(b, c, g) : n.style(b, c, d, g)
},
b, f ? d: void 0, f, null)
}
})
}),
n.fn.size = function() {
return this.length
},
n.fn.andSelf = n.fn.addBack,
"function" == typeof define && define.amd && define("jquery", [],
function() {
return n
});
var fd = a.jQuery,
gd = a.$;
return n.noConflict = function(b) {
return a.$ === n && (a.$ = gd),
b && a.jQuery === n && (a.jQuery = fd),
n
},
typeof b === L && (a.jQuery = a.$ = n),
n
});
//# sourceMappingURL=jquery.min.map
(2)rem.js
(function (doc, win) {
var docEl = doc.documentElement,
resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
recalc = function () {
var clientWidth = docEl.clientWidth;
if (!clientWidth) return;
docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';
};
if (!doc.addEventListener) return;
win.addEventListener(resizeEvt, recalc, false);
doc.addEventListener('DOMContentLoaded', recalc, false);
recalc();
})(document, window);
(3)swiper.min.js
/**
* Swiper 3.3.1
* Most modern mobile touch slider and framework with hardware accelerated transitions
*
* http://www.idangero.us/swiper/
*
* Copyright 2016, Vladimir Kharlampidi
* The iDangero.us
* http://www.idangero.us/
*
* Licensed under MIT
*
* Released on: February 7, 2016
*/
!
function() {
"use strict";
function e(e) {
e.fn.swiper = function(a) {
var r;
return e(this).each(function() {
var e = new t(this, a);
r || (r = e)
}),
r
}
}
var a, t = function(e, i) {
function s(e) {
return Math.floor(e)
}
function n() {
b.autoplayTimeoutId = setTimeout(function() {
b.params.loop ? (b.fixLoop(), b._slideNext(), b.emit("onAutoplay", b)) : b.isEnd ? i.autoplayStopOnLast ? b.stopAutoplay() : (b._slideTo(0), b.emit("onAutoplay", b)) : (b._slideNext(), b.emit("onAutoplay", b))
},
b.params.autoplay)
}
function o(e, t) {
var r = a(e.target);
if (!r.is(t)) if ("string" == typeof t) r = r.parents(t);
else if (t.nodeType) {
var i;
return r.parents().each(function(e, a) {
a === t && (i = t)
}),
i ? t: void 0
}
if (0 !== r.length) return r[0]
}
function l(e, a) {
a = a || {};
var t = window.MutationObserver || window.WebkitMutationObserver,
r = new t(function(e) {
e.forEach(function(e) {
b.onResize(!0),
b.emit("onObserverUpdate", b, e)
})
});
r.observe(e, {
attributes: "undefined" == typeof a.attributes ? !0 : a.attributes,
childList: "undefined" == typeof a.childList ? !0 : a.childList,
characterData: "undefined" == typeof a.characterData ? !0 : a.characterData
}),
b.observers.push(r)
}
function p(e) {
e.originalEvent && (e = e.originalEvent);
var a = e.keyCode || e.charCode;
if (!b.params.allowSwipeToNext && (b.isHorizontal() && 39 === a || !b.isHorizontal() && 40 === a)) return ! 1;
if (!b.params.allowSwipeToPrev && (b.isHorizontal() && 37 === a || !b.isHorizontal() && 38 === a)) return ! 1;
if (! (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey || document.activeElement && document.activeElement.nodeName && ("input" === document.activeElement.nodeName.toLowerCase() || "textarea" === document.activeElement.nodeName.toLowerCase()))) {
if (37 === a || 39 === a || 38 === a || 40 === a) {
var t = !1;
if (b.container.parents(".swiper-slide").length > 0 && 0 === b.container.parents(".swiper-slide-active").length) return;
var r = {
left: window.pageXOffset,
top: window.pageYOffset
},
i = window.innerWidth,
s = window.innerHeight,
n = b.container.offset();
b.rtl && (n.left = n.left - b.container[0].scrollLeft);
for (var o = [[n.left, n.top], [n.left + b.width, n.top], [n.left, n.top + b.height], [n.left + b.width, n.top + b.height]], l = 0; l < o.length; l++) {
var p = o[l];
p[0] >= r.left && p[0] <= r.left + i && p[1] >= r.top && p[1] <= r.top + s && (t = !0)
}
if (!t) return
}
b.isHorizontal() ? ((37 === a || 39 === a) && (e.preventDefault ? e.preventDefault() : e.returnValue = !1), (39 === a && !b.rtl || 37 === a && b.rtl) && b.slideNext(), (37 === a && !b.rtl || 39 === a && b.rtl) && b.slidePrev()) : ((38 === a || 40 === a) && (e.preventDefault ? e.preventDefault() : e.returnValue = !1), 40 === a && b.slideNext(), 38 === a && b.slidePrev())
}
}
function d(e) {
e.originalEvent && (e = e.originalEvent);
var a = b.mousewheel.event,
t = 0,
r = b.rtl ? -1 : 1;
if ("mousewheel" === a) if (b.params.mousewheelForceToAxis) if (b.isHorizontal()) {
if (! (Math.abs(e.wheelDeltaX) > Math.abs(e.wheelDeltaY))) return;
t = e.wheelDeltaX * r
} else {
if (! (Math.abs(e.wheelDeltaY) > Math.abs(e.wheelDeltaX))) return;
t = e.wheelDeltaY
} else t = Math.abs(e.wheelDeltaX) > Math.abs(e.wheelDeltaY) ? -e.wheelDeltaX * r: -e.wheelDeltaY;
else if ("DOMMouseScroll" === a) t = -e.detail;
else if ("wheel" === a) if (b.params.mousewheelForceToAxis) if (b.isHorizontal()) {
if (! (Math.abs(e.deltaX) > Math.abs(e.deltaY))) return;
t = -e.deltaX * r
} else {
if (! (Math.abs(e.deltaY) > Math.abs(e.deltaX))) return;
t = -e.deltaY
} else t = Math.abs(e.deltaX) > Math.abs(e.deltaY) ? -e.deltaX * r: -e.deltaY;
if (0 !== t) {
if (b.params.mousewheelInvert && (t = -t), b.params.freeMode) {
var i = b.getWrapperTranslate() + t * b.params.mousewheelSensitivity,
s = b.isBeginning,
n = b.isEnd;
if (i >= b.minTranslate() && (i = b.minTranslate()), i <= b.maxTranslate() && (i = b.maxTranslate()), b.setWrapperTransition(0), b.setWrapperTranslate(i), b.updateProgress(), b.updateActiveIndex(), (!s && b.isBeginning || !n && b.isEnd) && b.updateClasses(), b.params.freeModeSticky ? (clearTimeout(b.mousewheel.timeout), b.mousewheel.timeout = setTimeout(function() {
b.slideReset()
},
300)) : b.params.lazyLoading && b.lazy && b.lazy.load(), 0 === i || i === b.maxTranslate()) return
} else {
if ((new window.Date).getTime() - b.mousewheel.lastScrollTime > 60) if (0 > t) if (b.isEnd && !b.params.loop || b.animating) {
if (b.params.mousewheelReleaseOnEdges) return ! 0
} else b.slideNext();
else if (b.isBeginning && !b.params.loop || b.animating) {
if (b.params.mousewheelReleaseOnEdges) return ! 0
} else b.slidePrev();
b.mousewheel.lastScrollTime = (new window.Date).getTime()
}
return b.params.autoplay && b.stopAutoplay(),
e.preventDefault ? e.preventDefault() : e.returnValue = !1,
!1
}
}
function u(e, t) {
e = a(e);
var r, i, s, n = b.rtl ? -1 : 1;
r = e.attr("data-swiper-parallax") || "0",
i = e.attr("data-swiper-parallax-x"),
s = e.attr("data-swiper-parallax-y"),
i || s ? (i = i || "0", s = s || "0") : b.isHorizontal() ? (i = r, s = "0") : (s = r, i = "0"),
i = i.indexOf("%") >= 0 ? parseInt(i, 10) * t * n + "%": i * t * n + "px",
s = s.indexOf("%") >= 0 ? parseInt(s, 10) * t + "%": s * t + "px",
e.transform("translate3d(" + i + ", " + s + ",0px)")
}
function c(e) {
return 0 !== e.indexOf("on") && (e = e[0] !== e[0].toUpperCase() ? "on" + e[0].toUpperCase() + e.substring(1) : "on" + e),
e
}
if (! (this instanceof t)) return new t(e, i);
var m = {
direction: "horizontal",
touchEventsTarget: "container",
initialSlide: 0,
speed: 300,
autoplay: !1,
autoplayDisableOnInteraction: !0,
autoplayStopOnLast: !1,
iOSEdgeSwipeDetection: !1,
iOSEdgeSwipeThreshold: 20,
freeMode: !1,
freeModeMomentum: !0,
freeModeMomentumRatio: 1,
freeModeMomentumBounce: !0,
freeModeMomentumBounceRatio: 1,
freeModeSticky: !1,
freeModeMinimumVelocity: .02,
autoHeight: !1,
setWrapperSize: !1,
virtualTranslate: !1,
effect: "slide",
coverflow: {
rotate: 50,
stretch: 0,
depth: 100,
modifier: 1,
slideShadows: !0
},
flip: {
slideShadows: !0,
limitRotation: !0
},
cube: {
slideShadows: !0,
shadow: !0,
shadowOffset: 20,
shadowScale: .94
},
fade: {
crossFade: !1
},
parallax: !1,
scrollbar: null,
scrollbarHide: !0,
scrollbarDraggable: !1,
scrollbarSnapOnRelease: !1,
keyboardControl: !1,
mousewheelControl: !1,
mousewheelReleaseOnEdges: !1,
mousewheelInvert: !1,
mousewheelForceToAxis: !1,
mousewheelSensitivity: 1,
hashnav: !1,
breakpoints: void 0,
spaceBetween: 0,
slidesPerView: 1,
slidesPerColumn: 1,
slidesPerColumnFill: "column",
slidesPerGroup: 1,
centeredSlides: !1,
slidesOffsetBefore: 0,
slidesOffsetAfter: 0,
roundLengths: !1,
touchRatio: 1,
touchAngle: 45,
simulateTouch: !0,
shortSwipes: !0,
longSwipes: !0,
longSwipesRatio: .5,
longSwipesMs: 300,
followFinger: !0,
onlyExternal: !1,
threshold: 0,
touchMoveStopPropagation: !0,
uniqueNavElements: !0,
pagination: null,
paginationElement: "span",
paginationClickable: !1,
paginationHide: !1,
paginationBulletRender: null,
paginationProgressRender: null,
paginationFractionRender: null,
paginationCustomRender: null,
paginationType: "bullets",
resistance: !0,
resistanceRatio: .85,
nextButton: null,
prevButton: null,
watchSlidesProgress: !1,
watchSlidesVisibility: !1,
grabCursor: !1,
preventClicks: !0,
preventClicksPropagation: !0,
slideToClickedSlide: !1,
lazyLoading: !1,
lazyLoadingInPrevNext: !1,
lazyLoadingInPrevNextAmount: 1,
lazyLoadingOnTransitionStart: !1,
preloadImages: !0,
updateOnImagesReady: !0,
loop: !1,
loopAdditionalSlides: 0,
loopedSlides: null,
control: void 0,
controlInverse: !1,
controlBy: "slide",
allowSwipeToPrev: !0,
allowSwipeToNext: !0,
swipeHandler: null,
noSwiping: !0,
noSwipingClass: "swiper-no-swiping",
slideClass: "swiper-slide",
slideActiveClass: "swiper-slide-active",
slideVisibleClass: "swiper-slide-visible",
slideDuplicateClass: "swiper-slide-duplicate",
slideNextClass: "swiper-slide-next",
slidePrevClass: "swiper-slide-prev",
wrapperClass: "swiper-wrapper",
bulletClass: "swiper-pagination-bullet",
bulletActiveClass: "swiper-pagination-bullet-active",
buttonDisabledClass: "swiper-button-disabled",
paginationCurrentClass: "swiper-pagination-current",
paginationTotalClass: "swiper-pagination-total",
paginationHiddenClass: "swiper-pagination-hidden",
paginationProgressbarClass: "swiper-pagination-progressbar",
observer: !1,
observeParents: !1,
a11y: !1,
prevSlideMessage: "Previous slide",
nextSlideMessage: "Next slide",
firstSlideMessage: "This is the first slide",
lastSlideMessage: "This is the last slide",
paginationBulletMessage: "Go to slide {{index}}",
runCallbacksOnInit: !0
},
h = i && i.virtualTranslate;
i = i || {};
var f = {};
for (var g in i) if ("object" != typeof i[g] || null === i[g] || (i[g].nodeType || i[g] === window || i[g] === document || "undefined" != typeof r && i[g] instanceof r || "undefined" != typeof jQuery && i[g] instanceof jQuery)) f[g] = i[g];
else {
f[g] = {};
for (var v in i[g]) f[g][v] = i[g][v]
}
for (var w in m) if ("undefined" == typeof i[w]) i[w] = m[w];
else if ("object" == typeof i[w]) for (var y in m[w])"undefined" == typeof i[w][y] && (i[w][y] = m[w][y]);
var b = this;
if (b.params = i, b.originalParams = f, b.classNames = [], "undefined" != typeof a && "undefined" != typeof r && (a = r), ("undefined" != typeof a || (a = "undefined" == typeof r ? window.Dom7 || window.Zepto || window.jQuery: r)) && (b.$ = a, b.currentBreakpoint = void 0, b.getActiveBreakpoint = function() {
if (!b.params.breakpoints) return ! 1;
var e, a = !1,
t = [];
for (e in b.params.breakpoints) b.params.breakpoints.hasOwnProperty(e) && t.push(e);
t.sort(function(e, a) {
return parseInt(e, 10) > parseInt(a, 10)
});
for (var r = 0; r < t.length; r++) e = t[r],
e >= window.innerWidth && !a && (a = e);
return a || "max"
},
b.setBreakpoint = function() {
var e = b.getActiveBreakpoint();
if (e && b.currentBreakpoint !== e) {
var a = e in b.params.breakpoints ? b.params.breakpoints[e] : b.originalParams,
t = b.params.loop && a.slidesPerView !== b.params.slidesPerView;
for (var r in a) b.params[r] = a[r];
b.currentBreakpoint = e,
t && b.destroyLoop && b.reLoop(!0)
}
},
b.params.breakpoints && b.setBreakpoint(), b.container = a(e), 0 !== b.container.length)) {
if (b.container.length > 1) {
var x = [];
return b.container.each(function() {
x.push(new t(this, i))
}),
x
}
b.container[0].swiper = b,
b.container.data("swiper", b),
b.classNames.push("swiper-container-" + b.params.direction),
b.params.freeMode && b.classNames.push("swiper-container-free-mode"),
b.support.flexbox || (b.classNames.push("swiper-container-no-flexbox"), b.params.slidesPerColumn = 1),
b.params.autoHeight && b.classNames.push("swiper-container-autoheight"),
(b.params.parallax || b.params.watchSlidesVisibility) && (b.params.watchSlidesProgress = !0),
["cube", "coverflow", "flip"].indexOf(b.params.effect) >= 0 && (b.support.transforms3d ? (b.params.watchSlidesProgress = !0, b.classNames.push("swiper-container-3d")) : b.params.effect = "slide"),
"slide" !== b.params.effect && b.classNames.push("swiper-container-" + b.params.effect),
"cube" === b.params.effect && (b.params.resistanceRatio = 0, b.params.slidesPerView = 1, b.params.slidesPerColumn = 1, b.params.slidesPerGroup = 1, b.params.centeredSlides = !1, b.params.spaceBetween = 0, b.params.virtualTranslate = !0, b.params.setWrapperSize = !1),
("fade" === b.params.effect || "flip" === b.params.effect) && (b.params.slidesPerView = 1, b.params.slidesPerColumn = 1, b.params.slidesPerGroup = 1, b.params.watchSlidesProgress = !0, b.params.spaceBetween = 0, b.params.setWrapperSize = !1, "undefined" == typeof h && (b.params.virtualTranslate = !0)),
b.params.grabCursor && b.support.touch && (b.params.grabCursor = !1),
b.wrapper = b.container.children("." + b.params.wrapperClass),
b.params.pagination && (b.paginationContainer = a(b.params.pagination), b.params.uniqueNavElements && "string" == typeof b.params.pagination && b.paginationContainer.length > 1 && 1 === b.container.find(b.params.pagination).length && (b.paginationContainer = b.container.find(b.params.pagination)), "bullets" === b.params.paginationType && b.params.paginationClickable ? b.paginationContainer.addClass("swiper-pagination-clickable") : b.params.paginationClickable = !1, b.paginationContainer.addClass("swiper-pagination-" + b.params.paginationType)),
(b.params.nextButton || b.params.prevButton) && (b.params.nextButton && (b.nextButton = a(b.params.nextButton), b.params.uniqueNavElements && "string" == typeof b.params.nextButton && b.nextButton.length > 1 && 1 === b.container.find(b.params.nextButton).length && (b.nextButton = b.container.find(b.params.nextButton))), b.params.prevButton && (b.prevButton = a(b.params.prevButton), b.params.uniqueNavElements && "string" == typeof b.params.prevButton && b.prevButton.length > 1 && 1 === b.container.find(b.params.prevButton).length && (b.prevButton = b.container.find(b.params.prevButton)))),
b.isHorizontal = function() {
return "horizontal" === b.params.direction
},
b.rtl = b.isHorizontal() && ("rtl" === b.container[0].dir.toLowerCase() || "rtl" === b.container.css("direction")),
b.rtl && b.classNames.push("swiper-container-rtl"),
b.rtl && (b.wrongRTL = "-webkit-box" === b.wrapper.css("display")),
b.params.slidesPerColumn > 1 && b.classNames.push("swiper-container-multirow"),
b.device.android && b.classNames.push("swiper-container-android"),
b.container.addClass(b.classNames.join(" ")),
b.translate = 0,
b.progress = 0,
b.velocity = 0,
b.lockSwipeToNext = function() {
b.params.allowSwipeToNext = !1
},
b.lockSwipeToPrev = function() {
b.params.allowSwipeToPrev = !1
},
b.lockSwipes = function() {
b.params.allowSwipeToNext = b.params.allowSwipeToPrev = !1
},
b.unlockSwipeToNext = function() {
b.params.allowSwipeToNext = !0
},
b.unlockSwipeToPrev = function() {
b.params.allowSwipeToPrev = !0
},
b.unlockSwipes = function() {
b.params.allowSwipeToNext = b.params.allowSwipeToPrev = !0
},
b.params.grabCursor && (b.container[0].style.cursor = "move", b.container[0].style.cursor = "-webkit-grab", b.container[0].style.cursor = "-moz-grab", b.container[0].style.cursor = "grab"),
b.imagesToLoad = [],
b.imagesLoaded = 0,
b.loadImage = function(e, a, t, r, i) {
function s() {
i && i()
}
var n;
e.complete && r ? s() : a ? (n = new window.Image, n.onload = s, n.onerror = s, t && (n.srcset = t), a && (n.src = a)) : s()
},
b.preloadImages = function() {
function e() {
"undefined" != typeof b && null !== b && (void 0 !== b.imagesLoaded && b.imagesLoaded++, b.imagesLoaded === b.imagesToLoad.length && (b.params.updateOnImagesReady && b.update(), b.emit("onImagesReady", b)))
}
b.imagesToLoad = b.container.find("img");
for (var a = 0; a < b.imagesToLoad.length; a++) b.loadImage(b.imagesToLoad[a], b.imagesToLoad[a].currentSrc || b.imagesToLoad[a].getAttribute("src"), b.imagesToLoad[a].srcset || b.imagesToLoad[a].getAttribute("srcset"), !0, e)
},
b.autoplayTimeoutId = void 0,
b.autoplaying = !1,
b.autoplayPaused = !1,
b.startAutoplay = function() {
return "undefined" != typeof b.autoplayTimeoutId ? !1 : b.params.autoplay ? b.autoplaying ? !1 : (b.autoplaying = !0, b.emit("onAutoplayStart", b), void n()) : !1
},
b.stopAutoplay = function(e) {
b.autoplayTimeoutId && (b.autoplayTimeoutId && clearTimeout(b.autoplayTimeoutId), b.autoplaying = !1, b.autoplayTimeoutId = void 0, b.emit("onAutoplayStop", b))
},
b.pauseAutoplay = function(e) {
b.autoplayPaused || (b.autoplayTimeoutId && clearTimeout(b.autoplayTimeoutId), b.autoplayPaused = !0, 0 === e ? (b.autoplayPaused = !1, n()) : b.wrapper.transitionEnd(function() {
b && (b.autoplayPaused = !1, b.autoplaying ? n() : b.stopAutoplay())
}))
},
b.minTranslate = function() {
return - b.snapGrid[0]
},
b.maxTranslate = function() {
return - b.snapGrid[b.snapGrid.length - 1]
},
b.updateAutoHeight = function() {
var e = b.slides.eq(b.activeIndex)[0];
if ("undefined" != typeof e) {
var a = e.offsetHeight;
a && b.wrapper.css("height", a + "px")
}
},
b.updateContainerSize = function() {
var e, a;
e = "undefined" != typeof b.params.width ? b.params.width: b.container[0].clientWidth,
a = "undefined" != typeof b.params.height ? b.params.height: b.container[0].clientHeight,
0 === e && b.isHorizontal() || 0 === a && !b.isHorizontal() || (e = e - parseInt(b.container.css("padding-left"), 10) - parseInt(b.container.css("padding-right"), 10), a = a - parseInt(b.container.css("padding-top"), 10) - parseInt(b.container.css("padding-bottom"), 10), b.width = e, b.height = a, b.size = b.isHorizontal() ? b.width: b.height)
},
b.updateSlidesSize = function() {
b.slides = b.wrapper.children("." + b.params.slideClass),
b.snapGrid = [],
b.slidesGrid = [],
b.slidesSizesGrid = [];
var e, a = b.params.spaceBetween,
t = -b.params.slidesOffsetBefore,
r = 0,
i = 0;
if ("undefined" != typeof b.size) {
"string" == typeof a && a.indexOf("%") >= 0 && (a = parseFloat(a.replace("%", "")) / 100 * b.size),
b.virtualSize = -a,
b.rtl ? b.slides.css({
marginLeft: "",
marginTop: ""
}) : b.slides.css({
marginRight: "",
marginBottom: ""
});
var n;
b.params.slidesPerColumn > 1 && (n = Math.floor(b.slides.length / b.params.slidesPerColumn) === b.slides.length / b.params.slidesPerColumn ? b.slides.length: Math.ceil(b.slides.length / b.params.slidesPerColumn) * b.params.slidesPerColumn, "auto" !== b.params.slidesPerView && "row" === b.params.slidesPerColumnFill && (n = Math.max(n, b.params.slidesPerView * b.params.slidesPerColumn)));
var o, l = b.params.slidesPerColumn,
p = n / l,
d = p - (b.params.slidesPerColumn * p - b.slides.length);
for (e = 0; e < b.slides.length; e++) {
o = 0;
var u = b.slides.eq(e);
if (b.params.slidesPerColumn > 1) {
var c, m, h;
"column" === b.params.slidesPerColumnFill ? (m = Math.floor(e / l), h = e - m * l, (m > d || m === d && h === l - 1) && ++h >= l && (h = 0, m++), c = m + h * n / l, u.css({
"-webkit-box-ordinal-group": c,
"-moz-box-ordinal-group": c,
"-ms-flex-order": c,
"-webkit-order": c,
order: c
})) : (h = Math.floor(e / p), m = e - h * p),
u.css({
"margin-top": 0 !== h && b.params.spaceBetween && b.params.spaceBetween + "px"
}).attr("data-swiper-column", m).attr("data-swiper-row", h)
}
"none" !== u.css("display") && ("auto" === b.params.slidesPerView ? (o = b.isHorizontal() ? u.outerWidth(!0) : u.outerHeight(!0), b.params.roundLengths && (o = s(o))) : (o = (b.size - (b.params.slidesPerView - 1) * a) / b.params.slidesPerView, b.params.roundLengths && (o = s(o)), b.isHorizontal() ? b.slides[e].style.width = o + "px": b.slides[e].style.height = o + "px"), b.slides[e].swiperSlideSize = o, b.slidesSizesGrid.push(o), b.params.centeredSlides ? (t = t + o / 2 + r / 2 + a, 0 === e && (t = t - b.size / 2 - a), Math.abs(t) < .001 && (t = 0), i % b.params.slidesPerGroup === 0 && b.snapGrid.push(t), b.slidesGrid.push(t)) : (i % b.params.slidesPerGroup === 0 && b.snapGrid.push(t), b.slidesGrid.push(t), t = t + o + a), b.virtualSize += o + a, r = o, i++)
}
b.virtualSize = Math.max(b.virtualSize, b.size) + b.params.slidesOffsetAfter;
var f;
if (b.rtl && b.wrongRTL && ("slide" === b.params.effect || "coverflow" === b.params.effect) && b.wrapper.css({
width: b.virtualSize + b.params.spaceBetween + "px"
}), (!b.support.flexbox || b.params.setWrapperSize) && (b.isHorizontal() ? b.wrapper.css({
width: b.virtualSize + b.params.spaceBetween + "px"
}) : b.wrapper.css({
height: b.virtualSize + b.params.spaceBetween + "px"
})), b.params.slidesPerColumn > 1 && (b.virtualSize = (o + b.params.spaceBetween) * n, b.virtualSize = Math.ceil(b.virtualSize / b.params.slidesPerColumn) - b.params.spaceBetween, b.wrapper.css({
width: b.virtualSize + b.params.spaceBetween + "px"
}), b.params.centeredSlides)) {
for (f = [], e = 0; e < b.snapGrid.length; e++) b.snapGrid[e] < b.virtualSize + b.snapGrid[0] && f.push(b.snapGrid[e]);
b.snapGrid = f
}
if (!b.params.centeredSlides) {
for (f = [], e = 0; e < b.snapGrid.length; e++) b.snapGrid[e] <= b.virtualSize - b.size && f.push(b.snapGrid[e]);
b.snapGrid = f,
Math.floor(b.virtualSize - b.size) - Math.floor(b.snapGrid[b.snapGrid.length - 1]) > 1 && b.snapGrid.push(b.virtualSize - b.size)
}
0 === b.snapGrid.length && (b.snapGrid = [0]),
0 !== b.params.spaceBetween && (b.isHorizontal() ? b.rtl ? b.slides.css({
marginLeft: a + "px"
}) : b.slides.css({
marginRight: a + "px"
}) : b.slides.css({
marginBottom: a + "px"
})),
b.params.watchSlidesProgress && b.updateSlidesOffset()
}
},
b.updateSlidesOffset = function() {
for (var e = 0; e < b.slides.length; e++) b.slides[e].swiperSlideOffset = b.isHorizontal() ? b.slides[e].offsetLeft: b.slides[e].offsetTop
},
b.updateSlidesProgress = function(e) {
if ("undefined" == typeof e && (e = b.translate || 0), 0 !== b.slides.length) {
"undefined" == typeof b.slides[0].swiperSlideOffset && b.updateSlidesOffset();
var a = -e;
b.rtl && (a = e),
b.slides.removeClass(b.params.slideVisibleClass);
for (var t = 0; t < b.slides.length; t++) {
var r = b.slides[t],
i = (a - r.swiperSlideOffset) / (r.swiperSlideSize + b.params.spaceBetween);
if (b.params.watchSlidesVisibility) {
var s = -(a - r.swiperSlideOffset),
n = s + b.slidesSizesGrid[t],
o = s >= 0 && s < b.size || n > 0 && n <= b.size || 0 >= s && n >= b.size;
o && b.slides.eq(t).addClass(b.params.slideVisibleClass)
}
r.progress = b.rtl ? -i: i
}
}
},
b.updateProgress = function(e) {
"undefined" == typeof e && (e = b.translate || 0);
var a = b.maxTranslate() - b.minTranslate(),
t = b.isBeginning,
r = b.isEnd;
0 === a ? (b.progress = 0, b.isBeginning = b.isEnd = !0) : (b.progress = (e - b.minTranslate()) / a, b.isBeginning = b.progress <= 0, b.isEnd = b.progress >= 1),
b.isBeginning && !t && b.emit("onReachBeginning", b),
b.isEnd && !r && b.emit("onReachEnd", b),
b.params.watchSlidesProgress && b.updateSlidesProgress(e),
b.emit("onProgress", b, b.progress)
},
b.updateActiveIndex = function() {
var e, a, t, r = b.rtl ? b.translate: -b.translate;
for (a = 0; a < b.slidesGrid.length; a++)"undefined" != typeof b.slidesGrid[a + 1] ? r >= b.slidesGrid[a] && r < b.slidesGrid[a + 1] - (b.slidesGrid[a + 1] - b.slidesGrid[a]) / 2 ? e = a: r >= b.slidesGrid[a] && r < b.slidesGrid[a + 1] && (e = a + 1) : r >= b.slidesGrid[a] && (e = a); (0 > e || "undefined" == typeof e) && (e = 0),
t = Math.floor(e / b.params.slidesPerGroup),
t >= b.snapGrid.length && (t = b.snapGrid.length - 1),
e !== b.activeIndex && (b.snapIndex = t, b.previousIndex = b.activeIndex, b.activeIndex = e, b.updateClasses())
},
b.updateClasses = function() {
b.slides.removeClass(b.params.slideActiveClass + " " + b.params.slideNextClass + " " + b.params.slidePrevClass);
var e = b.slides.eq(b.activeIndex);
e.addClass(b.params.slideActiveClass);
var t = e.next("." + b.params.slideClass).addClass(b.params.slideNextClass);
b.params.loop && 0 === t.length && b.slides.eq(0).addClass(b.params.slideNextClass);
var r = e.prev("." + b.params.slideClass).addClass(b.params.slidePrevClass);
if (b.params.loop && 0 === r.length && b.slides.eq( - 1).addClass(b.params.slidePrevClass), b.paginationContainer && b.paginationContainer.length > 0) {
var i, s = b.params.loop ? Math.ceil((b.slides.length - 2 * b.loopedSlides) / b.params.slidesPerGroup) : b.snapGrid.length;
if (b.params.loop ? (i = Math.ceil((b.activeIndex - b.loopedSlides) / b.params.slidesPerGroup), i > b.slides.length - 1 - 2 * b.loopedSlides && (i -= b.slides.length - 2 * b.loopedSlides), i > s - 1 && (i -= s), 0 > i && "bullets" !== b.params.paginationType && (i = s + i)) : i = "undefined" != typeof b.snapIndex ? b.snapIndex: b.activeIndex || 0, "bullets" === b.params.paginationType && b.bullets && b.bullets.length > 0 && (b.bullets.removeClass(b.params.bulletActiveClass), b.paginationContainer.length > 1 ? b.bullets.each(function() {
a(this).index() === i && a(this).addClass(b.params.bulletActiveClass)
}) : b.bullets.eq(i).addClass(b.params.bulletActiveClass)), "fraction" === b.params.paginationType && (b.paginationContainer.find("." + b.params.paginationCurrentClass).text(i + 1), b.paginationContainer.find("." + b.params.paginationTotalClass).text(s)), "progress" === b.params.paginationType) {
var n = (i + 1) / s,
o = n,
l = 1;
b.isHorizontal() || (l = n, o = 1),
b.paginationContainer.find("." + b.params.paginationProgressbarClass).transform("translate3d(0,0,0) scaleX(" + o + ") scaleY(" + l + ")").transition(b.params.speed)
}
"custom" === b.params.paginationType && b.params.paginationCustomRender && (b.paginationContainer.html(b.params.paginationCustomRender(b, i + 1, s)), b.emit("onPaginationRendered", b, b.paginationContainer[0]))
}
b.params.loop || (b.params.prevButton && b.prevButton && b.prevButton.length > 0 && (b.isBeginning ? (b.prevButton.addClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.disable(b.prevButton)) : (b.prevButton.removeClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.enable(b.prevButton))), b.params.nextButton && b.nextButton && b.nextButton.length > 0 && (b.isEnd ? (b.nextButton.addClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.disable(b.nextButton)) : (b.nextButton.removeClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.enable(b.nextButton))))
},
b.updatePagination = function() {
if (b.params.pagination && b.paginationContainer && b.paginationContainer.length > 0) {
var e = "";
if ("bullets" === b.params.paginationType) {
for (var a = b.params.loop ? Math.ceil((b.slides.length - 2 * b.loopedSlides) / b.params.slidesPerGroup) : b.snapGrid.length, t = 0; a > t; t++) e += b.params.paginationBulletRender ? b.params.paginationBulletRender(t, b.params.bulletClass) : "<" + b.params.paginationElement + ' class="' + b.params.bulletClass + '"></' + b.params.paginationElement + ">";
b.paginationContainer.html(e),
b.bullets = b.paginationContainer.find("." + b.params.bulletClass),
b.params.paginationClickable && b.params.a11y && b.a11y && b.a11y.initPagination()
}
"fraction" === b.params.paginationType && (e = b.params.paginationFractionRender ? b.params.paginationFractionRender(b, b.params.paginationCurrentClass, b.params.paginationTotalClass) : '<span class="' + b.params.paginationCurrentClass + '"></span> / <span class="' + b.params.paginationTotalClass + '"></span>', b.paginationContainer.html(e)),
"progress" === b.params.paginationType && (e = b.params.paginationProgressRender ? b.params.paginationProgressRender(b, b.params.paginationProgressbarClass) : '<span class="' + b.params.paginationProgressbarClass + '"></span>', b.paginationContainer.html(e)),
"custom" !== b.params.paginationType && b.emit("onPaginationRendered", b, b.paginationContainer[0])
}
},
b.update = function(e) {
function a() {
r = Math.min(Math.max(b.translate, b.maxTranslate()), b.minTranslate()),
b.setWrapperTranslate(r),
b.updateActiveIndex(),
b.updateClasses()
}
if (b.updateContainerSize(), b.updateSlidesSize(), b.updateProgress(), b.updatePagination(), b.updateClasses(), b.params.scrollbar && b.scrollbar && b.scrollbar.set(), e) {
var t, r;
b.controller && b.controller.spline && (b.controller.spline = void 0),
b.params.freeMode ? (a(), b.params.autoHeight && b.updateAutoHeight()) : (t = ("auto" === b.params.slidesPerView || b.params.slidesPerView > 1) && b.isEnd && !b.params.centeredSlides ? b.slideTo(b.slides.length - 1, 0, !1, !0) : b.slideTo(b.activeIndex, 0, !1, !0), t || a())
} else b.params.autoHeight && b.updateAutoHeight()
},
b.onResize = function(e) {
b.params.breakpoints && b.setBreakpoint();
var a = b.params.allowSwipeToPrev,
t = b.params.allowSwipeToNext;
b.params.allowSwipeToPrev = b.params.allowSwipeToNext = !0,
b.updateContainerSize(),
b.updateSlidesSize(),
("auto" === b.params.slidesPerView || b.params.freeMode || e) && b.updatePagination(),
b.params.scrollbar && b.scrollbar && b.scrollbar.set(),
b.controller && b.controller.spline && (b.controller.spline = void 0);
var r = !1;
if (b.params.freeMode) {
var i = Math.min(Math.max(b.translate, b.maxTranslate()), b.minTranslate());
b.setWrapperTranslate(i),
b.updateActiveIndex(),
b.updateClasses(),
b.params.autoHeight && b.updateAutoHeight()
} else b.updateClasses(),
r = ("auto" === b.params.slidesPerView || b.params.slidesPerView > 1) && b.isEnd && !b.params.centeredSlides ? b.slideTo(b.slides.length - 1, 0, !1, !0) : b.slideTo(b.activeIndex, 0, !1, !0);
b.params.lazyLoading && !r && b.lazy && b.lazy.load(),
b.params.allowSwipeToPrev = a,
b.params.allowSwipeToNext = t
};
var T = ["mousedown", "mousemove", "mouseup"];
window.navigator.pointerEnabled ? T = ["pointerdown", "pointermove", "pointerup"] : window.navigator.msPointerEnabled && (T = ["MSPointerDown", "MSPointerMove", "MSPointerUp"]),
b.touchEvents = {
start: b.support.touch || !b.params.simulateTouch ? "touchstart": T[0],
move: b.support.touch || !b.params.simulateTouch ? "touchmove": T[1],
end: b.support.touch || !b.params.simulateTouch ? "touchend": T[2]
},
(window.navigator.pointerEnabled || window.navigator.msPointerEnabled) && ("container" === b.params.touchEventsTarget ? b.container: b.wrapper).addClass("swiper-wp8-" + b.params.direction),
b.initEvents = function(e) {
var a = e ? "off": "on",
t = e ? "removeEventListener": "addEventListener",
r = "container" === b.params.touchEventsTarget ? b.container[0] : b.wrapper[0],
s = b.support.touch ? r: document,
n = b.params.nested ? !0 : !1;
b.browser.ie ? (r[t](b.touchEvents.start, b.onTouchStart, !1), s[t](b.touchEvents.move, b.onTouchMove, n), s[t](b.touchEvents.end, b.onTouchEnd, !1)) : (b.support.touch && (r[t](b.touchEvents.start, b.onTouchStart, !1), r[t](b.touchEvents.move, b.onTouchMove, n), r[t](b.touchEvents.end, b.onTouchEnd, !1)), !i.simulateTouch || b.device.ios || b.device.android || (r[t]("mousedown", b.onTouchStart, !1), document[t]("mousemove", b.onTouchMove, n), document[t]("mouseup", b.onTouchEnd, !1))),
window[t]("resize", b.onResize),
b.params.nextButton && b.nextButton && b.nextButton.length > 0 && (b.nextButton[a]("click", b.onClickNext), b.params.a11y && b.a11y && b.nextButton[a]("keydown", b.a11y.onEnterKey)),
b.params.prevButton && b.prevButton && b.prevButton.length > 0 && (b.prevButton[a]("click", b.onClickPrev), b.params.a11y && b.a11y && b.prevButton[a]("keydown", b.a11y.onEnterKey)),
b.params.pagination && b.params.paginationClickable && (b.paginationContainer[a]("click", "." + b.params.bulletClass, b.onClickIndex), b.params.a11y && b.a11y && b.paginationContainer[a]("keydown", "." + b.params.bulletClass, b.a11y.onEnterKey)),
(b.params.preventClicks || b.params.preventClicksPropagation) && r[t]("click", b.preventClicks, !0)
},
b.attachEvents = function() {
b.initEvents()
},
b.detachEvents = function() {
b.initEvents(!0)
},
b.allowClick = !0,
b.preventClicks = function(e) {
b.allowClick || (b.params.preventClicks && e.preventDefault(), b.params.preventClicksPropagation && b.animating && (e.stopPropagation(), e.stopImmediatePropagation()))
},
b.onClickNext = function(e) {
e.preventDefault(),
(!b.isEnd || b.params.loop) && b.slideNext()
},
b.onClickPrev = function(e) {
e.preventDefault(),
(!b.isBeginning || b.params.loop) && b.slidePrev()
},
b.onClickIndex = function(e) {
e.preventDefault();
var t = a(this).index() * b.params.slidesPerGroup;
b.params.loop && (t += b.loopedSlides),
b.slideTo(t)
},
b.updateClickedSlide = function(e) {
var t = o(e, "." + b.params.slideClass),
r = !1;
if (t) for (var i = 0; i < b.slides.length; i++) b.slides[i] === t && (r = !0);
if (!t || !r) return b.clickedSlide = void 0,
void(b.clickedIndex = void 0);
if (b.clickedSlide = t, b.clickedIndex = a(t).index(), b.params.slideToClickedSlide && void 0 !== b.clickedIndex && b.clickedIndex !== b.activeIndex) {
var s, n = b.clickedIndex;
if (b.params.loop) {
if (b.animating) return;
s = a(b.clickedSlide).attr("data-swiper-slide-index"),
b.params.centeredSlides ? n < b.loopedSlides - b.params.slidesPerView / 2 || n > b.slides.length - b.loopedSlides + b.params.slidesPerView / 2 ? (b.fixLoop(), n = b.wrapper.children("." + b.params.slideClass + '[data-swiper-slide-index="' + s + '"]:not(.swiper-slide-duplicate)').eq(0).index(), setTimeout(function() {
b.slideTo(n)
},
0)) : b.slideTo(n) : n > b.slides.length - b.params.slidesPerView ? (b.fixLoop(), n = b.wrapper.children("." + b.params.slideClass + '[data-swiper-slide-index="' + s + '"]:not(.swiper-slide-duplicate)').eq(0).index(), setTimeout(function() {
b.slideTo(n)
},
0)) : b.slideTo(n)
} else b.slideTo(n)
}
};
var S, C, z, M, E, P, k, I, L, B, D = "input, select, textarea, button",
H = Date.now(),
A = [];
b.animating = !1,
b.touches = {
startX: 0,
startY: 0,
currentX: 0,
currentY: 0,
diff: 0
};
var G, O;
if (b.onTouchStart = function(e) {
if (e.originalEvent && (e = e.originalEvent), G = "touchstart" === e.type, G || !("which" in e) || 3 !== e.which) {
if (b.params.noSwiping && o(e, "." + b.params.noSwipingClass)) return void(b.allowClick = !0);
if (!b.params.swipeHandler || o(e, b.params.swipeHandler)) {
var t = b.touches.currentX = "touchstart" === e.type ? e.targetTouches[0].pageX: e.pageX,
r = b.touches.currentY = "touchstart" === e.type ? e.targetTouches[0].pageY: e.pageY;
if (! (b.device.ios && b.params.iOSEdgeSwipeDetection && t <= b.params.iOSEdgeSwipeThreshold)) {
if (S = !0, C = !1, z = !0, E = void 0, O = void 0, b.touches.startX = t, b.touches.startY = r, M = Date.now(), b.allowClick = !0, b.updateContainerSize(), b.swipeDirection = void 0, b.params.threshold > 0 && (I = !1), "touchstart" !== e.type) {
var i = !0;
a(e.target).is(D) && (i = !1),
document.activeElement && a(document.activeElement).is(D) && document.activeElement.blur(),
i && e.preventDefault()
}
b.emit("onTouchStart", b, e)
}
}
}
},
b.onTouchMove = function(e) {
if (e.originalEvent && (e = e.originalEvent), !G || "mousemove" !== e.type) {
if (e.preventedByNestedSwiper) return b.touches.startX = "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX,
void(b.touches.startY = "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY);
if (b.params.onlyExternal) return b.allowClick = !1,
void(S && (b.touches.startX = b.touches.currentX = "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX, b.touches.startY = b.touches.currentY = "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY, M = Date.now()));
if (G && document.activeElement && e.target === document.activeElement && a(e.target).is(D)) return C = !0,
void(b.allowClick = !1);
if (z && b.emit("onTouchMove", b, e), !(e.targetTouches && e.targetTouches.length > 1)) {
if (b.touches.currentX = "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX, b.touches.currentY = "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY, "undefined" == typeof E) {
var t = 180 * Math.atan2(Math.abs(b.touches.currentY - b.touches.startY), Math.abs(b.touches.currentX - b.touches.startX)) / Math.PI;
E = b.isHorizontal() ? t > b.params.touchAngle: 90 - t > b.params.touchAngle
}
if (E && b.emit("onTouchMoveOpposite", b, e), "undefined" == typeof O && b.browser.ieTouch && (b.touches.currentX !== b.touches.startX || b.touches.currentY !== b.touches.startY) && (O = !0), S) {
if (E) return void(S = !1);
if (O || !b.browser.ieTouch) {
b.allowClick = !1,
b.emit("onSliderMove", b, e),
e.preventDefault(),
b.params.touchMoveStopPropagation && !b.params.nested && e.stopPropagation(),
C || (i.loop && b.fixLoop(), k = b.getWrapperTranslate(), b.setWrapperTransition(0), b.animating && b.wrapper.trigger("webkitTransitionEnd transitionend oTransitionEnd MSTransitionEnd msTransitionEnd"), b.params.autoplay && b.autoplaying && (b.params.autoplayDisableOnInteraction ? b.stopAutoplay() : b.pauseAutoplay()), B = !1, b.params.grabCursor && (b.container[0].style.cursor = "move", b.container[0].style.cursor = "-webkit-grabbing", b.container[0].style.cursor = "-moz-grabbin", b.container[0].style.cursor = "grabbing")),
C = !0;
var r = b.touches.diff = b.isHorizontal() ? b.touches.currentX - b.touches.startX: b.touches.currentY - b.touches.startY;
r *= b.params.touchRatio,
b.rtl && (r = -r),
b.swipeDirection = r > 0 ? "prev": "next",
P = r + k;
var s = !0;
if (r > 0 && P > b.minTranslate() ? (s = !1, b.params.resistance && (P = b.minTranslate() - 1 + Math.pow( - b.minTranslate() + k + r, b.params.resistanceRatio))) : 0 > r && P < b.maxTranslate() && (s = !1, b.params.resistance && (P = b.maxTranslate() + 1 - Math.pow(b.maxTranslate() - k - r, b.params.resistanceRatio))), s && (e.preventedByNestedSwiper = !0), !b.params.allowSwipeToNext && "next" === b.swipeDirection && k > P && (P = k), !b.params.allowSwipeToPrev && "prev" === b.swipeDirection && P > k && (P = k), b.params.followFinger) {
if (b.params.threshold > 0) {
if (! (Math.abs(r) > b.params.threshold || I)) return void(P = k);
if (!I) return I = !0,
b.touches.startX = b.touches.currentX,
b.touches.startY = b.touches.currentY,
P = k,
void(b.touches.diff = b.isHorizontal() ? b.touches.currentX - b.touches.startX: b.touches.currentY - b.touches.startY)
} (b.params.freeMode || b.params.watchSlidesProgress) && b.updateActiveIndex(),
b.params.freeMode && (0 === A.length && A.push({
position: b.touches[b.isHorizontal() ? "startX": "startY"],
time: M
}), A.push({
position: b.touches[b.isHorizontal() ? "currentX": "currentY"],
time: (new window.Date).getTime()
})),
b.updateProgress(P),
b.setWrapperTranslate(P)
}
}
}
}
}
},
b.onTouchEnd = function(e) {
if (e.originalEvent && (e = e.originalEvent), z && b.emit("onTouchEnd", b, e), z = !1, S) {
b.params.grabCursor && C && S && (b.container[0].style.cursor = "move", b.container[0].style.cursor = "-webkit-grab", b.container[0].style.cursor = "-moz-grab", b.container[0].style.cursor = "grab");
var t = Date.now(),
r = t - M;
if (b.allowClick && (b.updateClickedSlide(e), b.emit("onTap", b, e), 300 > r && t - H > 300 && (L && clearTimeout(L), L = setTimeout(function() {
b && (b.params.paginationHide && b.paginationContainer.length > 0 && !a(e.target).hasClass(b.params.bulletClass) && b.paginationContainer.toggleClass(b.params.paginationHiddenClass), b.emit("onClick", b, e))
},
300)), 300 > r && 300 > t - H && (L && clearTimeout(L), b.emit("onDoubleTap", b, e))), H = Date.now(), setTimeout(function() {
b && (b.allowClick = !0)
},
0), !S || !C || !b.swipeDirection || 0 === b.touches.diff || P === k) return void(S = C = !1);
S = C = !1;
var i;
if (i = b.params.followFinger ? b.rtl ? b.translate: -b.translate: -P, b.params.freeMode) {
if (i < -b.minTranslate()) return void b.slideTo(b.activeIndex);
if (i > -b.maxTranslate()) return void(b.slides.length < b.snapGrid.length ? b.slideTo(b.snapGrid.length - 1) : b.slideTo(b.slides.length - 1));
if (b.params.freeModeMomentum) {
if (A.length > 1) {
var s = A.pop(),
n = A.pop(),
o = s.position - n.position,
l = s.time - n.time;
b.velocity = o / l,
b.velocity = b.velocity / 2,
Math.abs(b.velocity) < b.params.freeModeMinimumVelocity && (b.velocity = 0),
(l > 150 || (new window.Date).getTime() - s.time > 300) && (b.velocity = 0)
} else b.velocity = 0;
A.length = 0;
var p = 1e3 * b.params.freeModeMomentumRatio,
d = b.velocity * p,
u = b.translate + d;
b.rtl && (u = -u);
var c, m = !1,
h = 20 * Math.abs(b.velocity) * b.params.freeModeMomentumBounceRatio;
if (u < b.maxTranslate()) b.params.freeModeMomentumBounce ? (u + b.maxTranslate() < -h && (u = b.maxTranslate() - h), c = b.maxTranslate(), m = !0, B = !0) : u = b.maxTranslate();
else if (u > b.minTranslate()) b.params.freeModeMomentumBounce ? (u - b.minTranslate() > h && (u = b.minTranslate() + h), c = b.minTranslate(), m = !0, B = !0) : u = b.minTranslate();
else if (b.params.freeModeSticky) {
var f, g = 0;
for (g = 0; g < b.snapGrid.length; g += 1) if (b.snapGrid[g] > -u) {
f = g;
break
}
u = Math.abs(b.snapGrid[f] - u) < Math.abs(b.snapGrid[f - 1] - u) || "next" === b.swipeDirection ? b.snapGrid[f] : b.snapGrid[f - 1],
b.rtl || (u = -u)
}
if (0 !== b.velocity) p = b.rtl ? Math.abs(( - u - b.translate) / b.velocity) : Math.abs((u - b.translate) / b.velocity);
else if (b.params.freeModeSticky) return void b.slideReset();
b.params.freeModeMomentumBounce && m ? (b.updateProgress(c), b.setWrapperTransition(p), b.setWrapperTranslate(u), b.onTransitionStart(), b.animating = !0, b.wrapper.transitionEnd(function() {
b && B && (b.emit("onMomentumBounce", b), b.setWrapperTransition(b.params.speed), b.setWrapperTranslate(c), b.wrapper.transitionEnd(function() {
b && b.onTransitionEnd()
}))
})) : b.velocity ? (b.updateProgress(u), b.setWrapperTransition(p), b.setWrapperTranslate(u), b.onTransitionStart(), b.animating || (b.animating = !0, b.wrapper.transitionEnd(function() {
b && b.onTransitionEnd()
}))) : b.updateProgress(u),
b.updateActiveIndex()
}
return void((!b.params.freeModeMomentum || r >= b.params.longSwipesMs) && (b.updateProgress(), b.updateActiveIndex()))
}
var v, w = 0,
y = b.slidesSizesGrid[0];
for (v = 0; v < b.slidesGrid.length; v += b.params.slidesPerGroup)"undefined" != typeof b.slidesGrid[v + b.params.slidesPerGroup] ? i >= b.slidesGrid[v] && i < b.slidesGrid[v + b.params.slidesPerGroup] && (w = v, y = b.slidesGrid[v + b.params.slidesPerGroup] - b.slidesGrid[v]) : i >= b.slidesGrid[v] && (w = v, y = b.slidesGrid[b.slidesGrid.length - 1] - b.slidesGrid[b.slidesGrid.length - 2]);
var x = (i - b.slidesGrid[w]) / y;
if (r > b.params.longSwipesMs) {
if (!b.params.longSwipes) return void b.slideTo(b.activeIndex);
"next" === b.swipeDirection && (x >= b.params.longSwipesRatio ? b.slideTo(w + b.params.slidesPerGroup) : b.slideTo(w)),
"prev" === b.swipeDirection && (x > 1 - b.params.longSwipesRatio ? b.slideTo(w + b.params.slidesPerGroup) : b.slideTo(w))
} else {
if (!b.params.shortSwipes) return void b.slideTo(b.activeIndex);
"next" === b.swipeDirection && b.slideTo(w + b.params.slidesPerGroup),
"prev" === b.swipeDirection && b.slideTo(w)
}
}
},
b._slideTo = function(e, a) {
return b.slideTo(e, a, !0, !0)
},
b.slideTo = function(e, a, t, r) {
"undefined" == typeof t && (t = !0),
"undefined" == typeof e && (e = 0),
0 > e && (e = 0),
b.snapIndex = Math.floor(e / b.params.slidesPerGroup),
b.snapIndex >= b.snapGrid.length && (b.snapIndex = b.snapGrid.length - 1);
var i = -b.snapGrid[b.snapIndex];
b.params.autoplay && b.autoplaying && (r || !b.params.autoplayDisableOnInteraction ? b.pauseAutoplay(a) : b.stopAutoplay()),
b.updateProgress(i);
for (var s = 0; s < b.slidesGrid.length; s++) - Math.floor(100 * i) >= Math.floor(100 * b.slidesGrid[s]) && (e = s);
return ! b.params.allowSwipeToNext && i < b.translate && i < b.minTranslate() ? !1 : !b.params.allowSwipeToPrev && i > b.translate && i > b.maxTranslate() && (b.activeIndex || 0) !== e ? !1 : ("undefined" == typeof a && (a = b.params.speed), b.previousIndex = b.activeIndex || 0, b.activeIndex = e, b.rtl && -i === b.translate || !b.rtl && i === b.translate ? (b.params.autoHeight && b.updateAutoHeight(), b.updateClasses(), "slide" !== b.params.effect && b.setWrapperTranslate(i), !1) : (b.updateClasses(), b.onTransitionStart(t), 0 === a ? (b.setWrapperTranslate(i), b.setWrapperTransition(0), b.onTransitionEnd(t)) : (b.setWrapperTranslate(i), b.setWrapperTransition(a), b.animating || (b.animating = !0, b.wrapper.transitionEnd(function() {
b && b.onTransitionEnd(t)
}))), !0))
},
b.onTransitionStart = function(e) {
"undefined" == typeof e && (e = !0),
b.params.autoHeight && b.updateAutoHeight(),
b.lazy && b.lazy.onTransitionStart(),
e && (b.emit("onTransitionStart", b), b.activeIndex !== b.previousIndex && (b.emit("onSlideChangeStart", b), b.activeIndex > b.previousIndex ? b.emit("onSlideNextStart", b) : b.emit("onSlidePrevStart", b)))
},
b.onTransitionEnd = function(e) {
b.animating = !1,
b.setWrapperTransition(0),
"undefined" == typeof e && (e = !0),
b.lazy && b.lazy.onTransitionEnd(),
e && (b.emit("onTransitionEnd", b), b.activeIndex !== b.previousIndex && (b.emit("onSlideChangeEnd", b), b.activeIndex > b.previousIndex ? b.emit("onSlideNextEnd", b) : b.emit("onSlidePrevEnd", b))),
b.params.hashnav && b.hashnav && b.hashnav.setHash()
},
b.slideNext = function(e, a, t) {
if (b.params.loop) {
if (b.animating) return ! 1;
b.fixLoop();
b.container[0].clientLeft;
return b.slideTo(b.activeIndex + b.params.slidesPerGroup, a, e, t)
}
return b.slideTo(b.activeIndex + b.params.slidesPerGroup, a, e, t)
},
b._slideNext = function(e) {
return b.slideNext(!0, e, !0)
},
b.slidePrev = function(e, a, t) {
if (b.params.loop) {
if (b.animating) return ! 1;
b.fixLoop();
b.container[0].clientLeft;
return b.slideTo(b.activeIndex - 1, a, e, t)
}
return b.slideTo(b.activeIndex - 1, a, e, t)
},
b._slidePrev = function(e) {
return b.slidePrev(!0, e, !0)
},
b.slideReset = function(e, a, t) {
return b.slideTo(b.activeIndex, a, e)
},
b.setWrapperTransition = function(e, a) {
b.wrapper.transition(e),
"slide" !== b.params.effect && b.effects[b.params.effect] && b.effects[b.params.effect].setTransition(e),
b.params.parallax && b.parallax && b.parallax.setTransition(e),
b.params.scrollbar && b.scrollbar && b.scrollbar.setTransition(e),
b.params.control && b.controller && b.controller.setTransition(e, a),
b.emit("onSetTransition", b, e)
},
b.setWrapperTranslate = function(e, a, t) {
var r = 0,
i = 0,
n = 0;
b.isHorizontal() ? r = b.rtl ? -e: e: i = e,
b.params.roundLengths && (r = s(r), i = s(i)),
b.params.virtualTranslate || (b.support.transforms3d ? b.wrapper.transform("translate3d(" + r + "px, " + i + "px, " + n + "px)") : b.wrapper.transform("translate(" + r + "px, " + i + "px)")),
b.translate = b.isHorizontal() ? r: i;
var o, l = b.maxTranslate() - b.minTranslate();
o = 0 === l ? 0 : (e - b.minTranslate()) / l,
o !== b.progress && b.updateProgress(e),
a && b.updateActiveIndex(),
"slide" !== b.params.effect && b.effects[b.params.effect] && b.effects[b.params.effect].setTranslate(b.translate),
b.params.parallax && b.parallax && b.parallax.setTranslate(b.translate),
b.params.scrollbar && b.scrollbar && b.scrollbar.setTranslate(b.translate),
b.params.control && b.controller && b.controller.setTranslate(b.translate, t),
b.emit("onSetTranslate", b, b.translate)
},
b.getTranslate = function(e, a) {
var t, r, i, s;
return "undefined" == typeof a && (a = "x"),
b.params.virtualTranslate ? b.rtl ? -b.translate: b.translate: (i = window.getComputedStyle(e, null), window.WebKitCSSMatrix ? (r = i.transform || i.webkitTransform, r.split(",").length > 6 && (r = r.split(", ").map(function(e) {
return e.replace(",", ".")
}).join(", ")), s = new window.WebKitCSSMatrix("none" === r ? "": r)) : (s = i.MozTransform || i.OTransform || i.MsTransform || i.msTransform || i.transform || i.getPropertyValue("transform").replace("translate(", "matrix(1, 0, 0, 1,"), t = s.toString().split(",")), "x" === a && (r = window.WebKitCSSMatrix ? s.m41: 16 === t.length ? parseFloat(t[12]) : parseFloat(t[4])), "y" === a && (r = window.WebKitCSSMatrix ? s.m42: 16 === t.length ? parseFloat(t[13]) : parseFloat(t[5])), b.rtl && r && (r = -r), r || 0)
},
b.getWrapperTranslate = function(e) {
return "undefined" == typeof e && (e = b.isHorizontal() ? "x": "y"),
b.getTranslate(b.wrapper[0], e)
},
b.observers = [], b.initObservers = function() {
if (b.params.observeParents) for (var e = b.container.parents(), a = 0; a < e.length; a++) l(e[a]);
l(b.container[0], {
childList: !1
}),
l(b.wrapper[0], {
attributes: !1
})
},
b.disconnectObservers = function() {
for (var e = 0; e < b.observers.length; e++) b.observers[e].disconnect();
b.observers = []
},
b.createLoop = function() {
b.wrapper.children("." + b.params.slideClass + "." + b.params.slideDuplicateClass).remove();
var e = b.wrapper.children("." + b.params.slideClass);
"auto" !== b.params.slidesPerView || b.params.loopedSlides || (b.params.loopedSlides = e.length),
b.loopedSlides = parseInt(b.params.loopedSlides || b.params.slidesPerView, 10),
b.loopedSlides = b.loopedSlides + b.params.loopAdditionalSlides,
b.loopedSlides > e.length && (b.loopedSlides = e.length);
var t, r = [],
i = [];
for (e.each(function(t, s) {
var n = a(this);
t < b.loopedSlides && i.push(s),
t < e.length && t >= e.length - b.loopedSlides && r.push(s),
n.attr("data-swiper-slide-index", t)
}), t = 0; t < i.length; t++) b.wrapper.append(a(i[t].cloneNode(!0)).addClass(b.params.slideDuplicateClass));
for (t = r.length - 1; t >= 0; t--) b.wrapper.prepend(a(r[t].cloneNode(!0)).addClass(b.params.slideDuplicateClass))
},
b.destroyLoop = function() {
b.wrapper.children("." + b.params.slideClass + "." + b.params.slideDuplicateClass).remove(),
b.slides.removeAttr("data-swiper-slide-index")
},
b.reLoop = function(e) {
var a = b.activeIndex - b.loopedSlides;
b.destroyLoop(),
b.createLoop(),
b.updateSlidesSize(),
e && b.slideTo(a + b.loopedSlides, 0, !1)
},
b.fixLoop = function() {
var e;
b.activeIndex < b.loopedSlides ? (e = b.slides.length - 3 * b.loopedSlides + b.activeIndex, e += b.loopedSlides, b.slideTo(e, 0, !1, !0)) : ("auto" === b.params.slidesPerView && b.activeIndex >= 2 * b.loopedSlides || b.activeIndex > b.slides.length - 2 * b.params.slidesPerView) && (e = -b.slides.length + b.activeIndex + b.loopedSlides, e += b.loopedSlides, b.slideTo(e, 0, !1, !0))
},
b.appendSlide = function(e) {
if (b.params.loop && b.destroyLoop(), "object" == typeof e && e.length) for (var a = 0; a < e.length; a++) e[a] && b.wrapper.append(e[a]);
else b.wrapper.append(e);
b.params.loop && b.createLoop(),
b.params.observer && b.support.observer || b.update(!0)
},
b.prependSlide = function(e) {
b.params.loop && b.destroyLoop();
var a = b.activeIndex + 1;
if ("object" == typeof e && e.length) {
for (var t = 0; t < e.length; t++) e[t] && b.wrapper.prepend(e[t]);
a = b.activeIndex + e.length
} else b.wrapper.prepend(e);
b.params.loop && b.createLoop(),
b.params.observer && b.support.observer || b.update(!0),
b.slideTo(a, 0, !1)
},
b.removeSlide = function(e) {
b.params.loop && (b.destroyLoop(), b.slides = b.wrapper.children("." + b.params.slideClass));
var a, t = b.activeIndex;
if ("object" == typeof e && e.length) {
for (var r = 0; r < e.length; r++) a = e[r],
b.slides[a] && b.slides.eq(a).remove(),
t > a && t--;
t = Math.max(t, 0)
} else a = e,
b.slides[a] && b.slides.eq(a).remove(),
t > a && t--,
t = Math.max(t, 0);
b.params.loop && b.createLoop(),
b.params.observer && b.support.observer || b.update(!0),
b.params.loop ? b.slideTo(t + b.loopedSlides, 0, !1) : b.slideTo(t, 0, !1)
},
b.removeAllSlides = function() {
for (var e = [], a = 0; a < b.slides.length; a++) e.push(a);
b.removeSlide(e)
},
b.effects = {
fade: {
setTranslate: function() {
for (var e = 0; e < b.slides.length; e++) {
var a = b.slides.eq(e),
t = a[0].swiperSlideOffset,
r = -t;
b.params.virtualTranslate || (r -= b.translate);
var i = 0;
b.isHorizontal() || (i = r, r = 0);
var s = b.params.fade.crossFade ? Math.max(1 - Math.abs(a[0].progress), 0) : 1 + Math.min(Math.max(a[0].progress, -1), 0);
a.css({
opacity: s
}).transform("translate3d(" + r + "px, " + i + "px, 0px)")
}
},
setTransition: function(e) {
if (b.slides.transition(e), b.params.virtualTranslate && 0 !== e) {
var a = !1;
b.slides.transitionEnd(function() {
if (!a && b) {
a = !0,
b.animating = !1;
for (var e = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"], t = 0; t < e.length; t++) b.wrapper.trigger(e[t])
}
})
}
}
},
flip: {
setTranslate: function() {
for (var e = 0; e < b.slides.length; e++) {
var t = b.slides.eq(e),
r = t[0].progress;
b.params.flip.limitRotation && (r = Math.max(Math.min(t[0].progress, 1), -1));
var i = t[0].swiperSlideOffset,
s = -180 * r,
n = s,
o = 0,
l = -i,
p = 0;
if (b.isHorizontal() ? b.rtl && (n = -n) : (p = l, l = 0, o = -n, n = 0), t[0].style.zIndex = -Math.abs(Math.round(r)) + b.slides.length, b.params.flip.slideShadows) {
var d = b.isHorizontal() ? t.find(".swiper-slide-shadow-left") : t.find(".swiper-slide-shadow-top"),
u = b.isHorizontal() ? t.find(".swiper-slide-shadow-right") : t.find(".swiper-slide-shadow-bottom");
0 === d.length && (d = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "left": "top") + '"></div>'), t.append(d)),
0 === u.length && (u = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "right": "bottom") + '"></div>'), t.append(u)),
d.length && (d[0].style.opacity = Math.max( - r, 0)),
u.length && (u[0].style.opacity = Math.max(r, 0))
}
t.transform("translate3d(" + l + "px, " + p + "px, 0px) rotateX(" + o + "deg) rotateY(" + n + "deg)")
}
},
setTransition: function(e) {
if (b.slides.transition(e).find(".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left").transition(e), b.params.virtualTranslate && 0 !== e) {
var t = !1;
b.slides.eq(b.activeIndex).transitionEnd(function() {
if (!t && b && a(this).hasClass(b.params.slideActiveClass)) {
t = !0,
b.animating = !1;
for (var e = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"], r = 0; r < e.length; r++) b.wrapper.trigger(e[r])
}
})
}
}
},
cube: {
setTranslate: function() {
var e, t = 0;
b.params.cube.shadow && (b.isHorizontal() ? (e = b.wrapper.find(".swiper-cube-shadow"), 0 === e.length && (e = a('<div class="swiper-cube-shadow"></div>'), b.wrapper.append(e)), e.css({
height: b.width + "px"
})) : (e = b.container.find(".swiper-cube-shadow"), 0 === e.length && (e = a('<div class="swiper-cube-shadow"></div>'), b.container.append(e))));
for (var r = 0; r < b.slides.length; r++) {
var i = b.slides.eq(r),
s = 90 * r,
n = Math.floor(s / 360);
b.rtl && (s = -s, n = Math.floor( - s / 360));
var o = Math.max(Math.min(i[0].progress, 1), -1),
l = 0,
p = 0,
d = 0;
r % 4 === 0 ? (l = 4 * -n * b.size, d = 0) : (r - 1) % 4 === 0 ? (l = 0, d = 4 * -n * b.size) : (r - 2) % 4 === 0 ? (l = b.size + 4 * n * b.size, d = b.size) : (r - 3) % 4 === 0 && (l = -b.size, d = 3 * b.size + 4 * b.size * n),
b.rtl && (l = -l),
b.isHorizontal() || (p = l, l = 0);
var u = "rotateX(" + (b.isHorizontal() ? 0 : -s) + "deg) rotateY(" + (b.isHorizontal() ? s: 0) + "deg) translate3d(" + l + "px, " + p + "px, " + d + "px)";
if (1 >= o && o > -1 && (t = 90 * r + 90 * o, b.rtl && (t = 90 * -r - 90 * o)), i.transform(u), b.params.cube.slideShadows) {
var c = b.isHorizontal() ? i.find(".swiper-slide-shadow-left") : i.find(".swiper-slide-shadow-top"),
m = b.isHorizontal() ? i.find(".swiper-slide-shadow-right") : i.find(".swiper-slide-shadow-bottom");
0 === c.length && (c = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "left": "top") + '"></div>'), i.append(c)),
0 === m.length && (m = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "right": "bottom") + '"></div>'), i.append(m)),
c.length && (c[0].style.opacity = Math.max( - o, 0)),
m.length && (m[0].style.opacity = Math.max(o, 0))
}
}
if (b.wrapper.css({
"-webkit-transform-origin": "50% 50% -" + b.size / 2 + "px",
"-moz-transform-origin": "50% 50% -" + b.size / 2 + "px",
"-ms-transform-origin": "50% 50% -" + b.size / 2 + "px",
"transform-origin": "50% 50% -" + b.size / 2 + "px"
}), b.params.cube.shadow) if (b.isHorizontal()) e.transform("translate3d(0px, " + (b.width / 2 + b.params.cube.shadowOffset) + "px, " + -b.width / 2 + "px) rotateX(90deg) rotateZ(0deg) scale(" + b.params.cube.shadowScale + ")");
else {
var h = Math.abs(t) - 90 * Math.floor(Math.abs(t) / 90),
f = 1.5 - (Math.sin(2 * h * Math.PI / 360) / 2 + Math.cos(2 * h * Math.PI / 360) / 2),
g = b.params.cube.shadowScale,
v = b.params.cube.shadowScale / f,
w = b.params.cube.shadowOffset;
e.transform("scale3d(" + g + ", 1, " + v + ") translate3d(0px, " + (b.height / 2 + w) + "px, " + -b.height / 2 / v + "px) rotateX(-90deg)")
}
var y = b.isSafari || b.isUiWebView ? -b.size / 2 : 0;
b.wrapper.transform("translate3d(0px,0," + y + "px) rotateX(" + (b.isHorizontal() ? 0 : t) + "deg) rotateY(" + (b.isHorizontal() ? -t: 0) + "deg)")
},
setTransition: function(e) {
b.slides.transition(e).find(".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left").transition(e),
b.params.cube.shadow && !b.isHorizontal() && b.container.find(".swiper-cube-shadow").transition(e)
}
},
coverflow: {
setTranslate: function() {
for (var e = b.translate,
t = b.isHorizontal() ? -e + b.width / 2 : -e + b.height / 2, r = b.isHorizontal() ? b.params.coverflow.rotate: -b.params.coverflow.rotate, i = b.params.coverflow.depth, s = 0, n = b.slides.length; n > s; s++) {
var o = b.slides.eq(s),
l = b.slidesSizesGrid[s],
p = o[0].swiperSlideOffset,
d = (t - p - l / 2) / l * b.params.coverflow.modifier,
u = b.isHorizontal() ? r * d: 0,
c = b.isHorizontal() ? 0 : r * d,
m = -i * Math.abs(d),
h = b.isHorizontal() ? 0 : b.params.coverflow.stretch * d,
f = b.isHorizontal() ? b.params.coverflow.stretch * d: 0;
Math.abs(f) < .001 && (f = 0),
Math.abs(h) < .001 && (h = 0),
Math.abs(m) < .001 && (m = 0),
Math.abs(u) < .001 && (u = 0),
Math.abs(c) < .001 && (c = 0);
var g = "translate3d(" + f + "px," + h + "px," + m + "px) rotateX(" + c + "deg) rotateY(" + u + "deg)";
if (o.transform(g), o[0].style.zIndex = -Math.abs(Math.round(d)) + 1, b.params.coverflow.slideShadows) {
var v = b.isHorizontal() ? o.find(".swiper-slide-shadow-left") : o.find(".swiper-slide-shadow-top"),
w = b.isHorizontal() ? o.find(".swiper-slide-shadow-right") : o.find(".swiper-slide-shadow-bottom");
0 === v.length && (v = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "left": "top") + '"></div>'), o.append(v)),
0 === w.length && (w = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "right": "bottom") + '"></div>'), o.append(w)),
v.length && (v[0].style.opacity = d > 0 ? d: 0),
w.length && (w[0].style.opacity = -d > 0 ? -d: 0)
}
}
if (b.browser.ie) {
var y = b.wrapper[0].style;
y.perspectiveOrigin = t + "px 50%"
}
},
setTransition: function(e) {
b.slides.transition(e).find(".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left").transition(e)
}
}
},
b.lazy = {
initialImageLoaded: !1,
loadImageInSlide: function(e, t) {
if ("undefined" != typeof e && ("undefined" == typeof t && (t = !0), 0 !== b.slides.length)) {
var r = b.slides.eq(e),
i = r.find(".swiper-lazy:not(.swiper-lazy-loaded):not(.swiper-lazy-loading)"); ! r.hasClass("swiper-lazy") || r.hasClass("swiper-lazy-loaded") || r.hasClass("swiper-lazy-loading") || (i = i.add(r[0])),
0 !== i.length && i.each(function() {
var e = a(this);
e.addClass("swiper-lazy-loading");
var i = e.attr("data-background"),
s = e.attr("data-src"),
n = e.attr("data-srcset");
b.loadImage(e[0], s || i, n, !1,
function() {
if (i ? (e.css("background-image", 'url("' + i + '")'), e.removeAttr("data-background")) : (n && (e.attr("srcset", n), e.removeAttr("data-srcset")), s && (e.attr("src", s), e.removeAttr("data-src"))), e.addClass("swiper-lazy-loaded").removeClass("swiper-lazy-loading"), r.find(".swiper-lazy-preloader, .preloader").remove(), b.params.loop && t) {
var a = r.attr("data-swiper-slide-index");
if (r.hasClass(b.params.slideDuplicateClass)) {
var o = b.wrapper.children('[data-swiper-slide-index="' + a + '"]:not(.' + b.params.slideDuplicateClass + ")");
b.lazy.loadImageInSlide(o.index(), !1)
} else {
var l = b.wrapper.children("." + b.params.slideDuplicateClass + '[data-swiper-slide-index="' + a + '"]');
b.lazy.loadImageInSlide(l.index(), !1)
}
}
b.emit("onLazyImageReady", b, r[0], e[0])
}),
b.emit("onLazyImageLoad", b, r[0], e[0])
})
}
},
load: function() {
var e;
if (b.params.watchSlidesVisibility) b.wrapper.children("." + b.params.slideVisibleClass).each(function() {
b.lazy.loadImageInSlide(a(this).index())
});
else if (b.params.slidesPerView > 1) for (e = b.activeIndex; e < b.activeIndex + b.params.slidesPerView; e++) b.slides[e] && b.lazy.loadImageInSlide(e);
else b.lazy.loadImageInSlide(b.activeIndex);
if (b.params.lazyLoadingInPrevNext) if (b.params.slidesPerView > 1 || b.params.lazyLoadingInPrevNextAmount && b.params.lazyLoadingInPrevNextAmount > 1) {
var t = b.params.lazyLoadingInPrevNextAmount,
r = b.params.slidesPerView,
i = Math.min(b.activeIndex + r + Math.max(t, r), b.slides.length),
s = Math.max(b.activeIndex - Math.max(r, t), 0);
for (e = b.activeIndex + b.params.slidesPerView; i > e; e++) b.slides[e] && b.lazy.loadImageInSlide(e);
for (e = s; e < b.activeIndex; e++) b.slides[e] && b.lazy.loadImageInSlide(e)
} else {
var n = b.wrapper.children("." + b.params.slideNextClass);
n.length > 0 && b.lazy.loadImageInSlide(n.index());
var o = b.wrapper.children("." + b.params.slidePrevClass);
o.length > 0 && b.lazy.loadImageInSlide(o.index())
}
},
onTransitionStart: function() {
b.params.lazyLoading && (b.params.lazyLoadingOnTransitionStart || !b.params.lazyLoadingOnTransitionStart && !b.lazy.initialImageLoaded) && b.lazy.load()
},
onTransitionEnd: function() {
b.params.lazyLoading && !b.params.lazyLoadingOnTransitionStart && b.lazy.load()
}
},
b.scrollbar = {
isTouched: !1,
setDragPosition: function(e) {
var a = b.scrollbar,
t = b.isHorizontal() ? "touchstart" === e.type || "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX || e.clientX: "touchstart" === e.type || "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY || e.clientY,
r = t - a.track.offset()[b.isHorizontal() ? "left": "top"] - a.dragSize / 2,
i = -b.minTranslate() * a.moveDivider,
s = -b.maxTranslate() * a.moveDivider;
i > r ? r = i: r > s && (r = s),
r = -r / a.moveDivider,
b.updateProgress(r),
b.setWrapperTranslate(r, !0)
},
dragStart: function(e) {
var a = b.scrollbar;
a.isTouched = !0,
e.preventDefault(),
e.stopPropagation(),
a.setDragPosition(e),
clearTimeout(a.dragTimeout),
a.track.transition(0),
b.params.scrollbarHide && a.track.css("opacity", 1),
b.wrapper.transition(100),
a.drag.transition(100),
b.emit("onScrollbarDragStart", b)
},
dragMove: function(e) {
var a = b.scrollbar;
a.isTouched && (e.preventDefault ? e.preventDefault() : e.returnValue = !1, a.setDragPosition(e), b.wrapper.transition(0), a.track.transition(0), a.drag.transition(0), b.emit("onScrollbarDragMove", b))
},
dragEnd: function(e) {
var a = b.scrollbar;
a.isTouched && (a.isTouched = !1, b.params.scrollbarHide && (clearTimeout(a.dragTimeout), a.dragTimeout = setTimeout(function() {
a.track.css("opacity", 0),
a.track.transition(400)
},
1e3)), b.emit("onScrollbarDragEnd", b), b.params.scrollbarSnapOnRelease && b.slideReset())
},
enableDraggable: function() {
var e = b.scrollbar,
t = b.support.touch ? e.track: document;
a(e.track).on(b.touchEvents.start, e.dragStart),
a(t).on(b.touchEvents.move, e.dragMove),
a(t).on(b.touchEvents.end, e.dragEnd)
},
disableDraggable: function() {
var e = b.scrollbar,
t = b.support.touch ? e.track: document;
a(e.track).off(b.touchEvents.start, e.dragStart),
a(t).off(b.touchEvents.move, e.dragMove),
a(t).off(b.touchEvents.end, e.dragEnd)
},
set: function() {
if (b.params.scrollbar) {
var e = b.scrollbar;
e.track = a(b.params.scrollbar),
b.params.uniqueNavElements && "string" == typeof b.params.scrollbar && e.track.length > 1 && 1 === b.container.find(b.params.scrollbar).length && (e.track = b.container.find(b.params.scrollbar)),
e.drag = e.track.find(".swiper-scrollbar-drag"),
0 === e.drag.length && (e.drag = a('<div class="swiper-scrollbar-drag"></div>'), e.track.append(e.drag)),
e.drag[0].style.width = "",
e.drag[0].style.height = "",
e.trackSize = b.isHorizontal() ? e.track[0].offsetWidth: e.track[0].offsetHeight,
e.divider = b.size / b.virtualSize,
e.moveDivider = e.divider * (e.trackSize / b.size),
e.dragSize = e.trackSize * e.divider,
b.isHorizontal() ? e.drag[0].style.width = e.dragSize + "px": e.drag[0].style.height = e.dragSize + "px",
e.divider >= 1 ? e.track[0].style.display = "none": e.track[0].style.display = "",
b.params.scrollbarHide && (e.track[0].style.opacity = 0)
}
},
setTranslate: function() {
if (b.params.scrollbar) {
var e, a = b.scrollbar,
t = (b.translate || 0, a.dragSize);
e = (a.trackSize - a.dragSize) * b.progress,
b.rtl && b.isHorizontal() ? (e = -e, e > 0 ? (t = a.dragSize - e, e = 0) : -e + a.dragSize > a.trackSize && (t = a.trackSize + e)) : 0 > e ? (t = a.dragSize + e, e = 0) : e + a.dragSize > a.trackSize && (t = a.trackSize - e),
b.isHorizontal() ? (b.support.transforms3d ? a.drag.transform("translate3d(" + e + "px, 0, 0)") : a.drag.transform("translateX(" + e + "px)"), a.drag[0].style.width = t + "px") : (b.support.transforms3d ? a.drag.transform("translate3d(0px, " + e + "px, 0)") : a.drag.transform("translateY(" + e + "px)"), a.drag[0].style.height = t + "px"),
b.params.scrollbarHide && (clearTimeout(a.timeout), a.track[0].style.opacity = 1, a.timeout = setTimeout(function() {
a.track[0].style.opacity = 0,
a.track.transition(400)
},
1e3))
}
},
setTransition: function(e) {
b.params.scrollbar && b.scrollbar.drag.transition(e)
}
},
b.controller = {
LinearSpline: function(e, a) {
this.x = e,
this.y = a,
this.lastIndex = e.length - 1;
var t, r;
this.x.length;
this.interpolate = function(e) {
return e ? (r = i(this.x, e), t = r - 1, (e - this.x[t]) * (this.y[r] - this.y[t]) / (this.x[r] - this.x[t]) + this.y[t]) : 0
};
var i = function() {
var e, a, t;
return function(r, i) {
for (a = -1, e = r.length; e - a > 1;) r[t = e + a >> 1] <= i ? a = t: e = t;
return e
}
} ()
},
getInterpolateFunction: function(e) {
b.controller.spline || (b.controller.spline = b.params.loop ? new b.controller.LinearSpline(b.slidesGrid, e.slidesGrid) : new b.controller.LinearSpline(b.snapGrid, e.snapGrid))
},
setTranslate: function(e, a) {
function r(a) {
e = a.rtl && "horizontal" === a.params.direction ? -b.translate: b.translate,
"slide" === b.params.controlBy && (b.controller.getInterpolateFunction(a), s = -b.controller.spline.interpolate( - e)),
s && "container" !== b.params.controlBy || (i = (a.maxTranslate() - a.minTranslate()) / (b.maxTranslate() - b.minTranslate()), s = (e - b.minTranslate()) * i + a.minTranslate()),
b.params.controlInverse && (s = a.maxTranslate() - s),
a.updateProgress(s),
a.setWrapperTranslate(s, !1, b),
a.updateActiveIndex()
}
var i, s, n = b.params.control;
if (b.isArray(n)) for (var o = 0; o < n.length; o++) n[o] !== a && n[o] instanceof t && r(n[o]);
else n instanceof t && a !== n && r(n)
},
setTransition: function(e, a) {
function r(a) {
a.setWrapperTransition(e, b),
0 !== e && (a.onTransitionStart(), a.wrapper.transitionEnd(function() {
s && (a.params.loop && "slide" === b.params.controlBy && a.fixLoop(), a.onTransitionEnd())
}))
}
var i, s = b.params.control;
if (b.isArray(s)) for (i = 0; i < s.length; i++) s[i] !== a && s[i] instanceof t && r(s[i]);
else s instanceof t && a !== s && r(s)
}
},
b.hashnav = {
init: function() {
if (b.params.hashnav) {
b.hashnav.initialized = !0;
var e = document.location.hash.replace("#", "");
if (e) for (var a = 0,
t = 0,
r = b.slides.length; r > t; t++) {
var i = b.slides.eq(t),
s = i.attr("data-hash");
if (s === e && !i.hasClass(b.params.slideDuplicateClass)) {
var n = i.index();
b.slideTo(n, a, b.params.runCallbacksOnInit, !0)
}
}
}
},
setHash: function() {
b.hashnav.initialized && b.params.hashnav && (document.location.hash = b.slides.eq(b.activeIndex).attr("data-hash") || "")
}
},
b.disableKeyboardControl = function() {
b.params.keyboardControl = !1,
a(document).off("keydown", p)
},
b.enableKeyboardControl = function() {
b.params.keyboardControl = !0,
a(document).on("keydown", p)
},
b.mousewheel = {
event: !1,
lastScrollTime: (new window.Date).getTime()
},
b.params.mousewheelControl) {
try {
new window.WheelEvent("wheel"),
b.mousewheel.event = "wheel"
} catch(N) { (window.WheelEvent || b.container[0] && "wheel" in b.container[0]) && (b.mousewheel.event = "wheel")
} ! b.mousewheel.event && window.WheelEvent,
b.mousewheel.event || void 0 === document.onmousewheel || (b.mousewheel.event = "mousewheel"),
b.mousewheel.event || (b.mousewheel.event = "DOMMouseScroll")
}
b.disableMousewheelControl = function() {
return b.mousewheel.event ? (b.container.off(b.mousewheel.event, d), !0) : !1
},
b.enableMousewheelControl = function() {
return b.mousewheel.event ? (b.container.on(b.mousewheel.event, d), !0) : !1
},
b.parallax = {
setTranslate: function() {
b.container.children("[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y]").each(function() {
u(this, b.progress)
}),
b.slides.each(function() {
var e = a(this);
e.find("[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y]").each(function() {
var a = Math.min(Math.max(e[0].progress, -1), 1);
u(this, a)
})
})
},
setTransition: function(e) {
"undefined" == typeof e && (e = b.params.speed),
b.container.find("[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y]").each(function() {
var t = a(this),
r = parseInt(t.attr("data-swiper-parallax-duration"), 10) || e;
0 === e && (r = 0),
t.transition(r)
})
}
},
b._plugins = [];
for (var R in b.plugins) {
var W = b.plugins[R](b, b.params[R]);
W && b._plugins.push(W)
}
return b.callPlugins = function(e) {
for (var a = 0; a < b._plugins.length; a++) e in b._plugins[a] && b._plugins[a][e](arguments[1], arguments[2], arguments[3], arguments[4], arguments[5])
},
b.emitterEventListeners = {},
b.emit = function(e) {
b.params[e] && b.params[e](arguments[1], arguments[2], arguments[3], arguments[4], arguments[5]);
var a;
if (b.emitterEventListeners[e]) for (a = 0; a < b.emitterEventListeners[e].length; a++) b.emitterEventListeners[e][a](arguments[1], arguments[2], arguments[3], arguments[4], arguments[5]);
b.callPlugins && b.callPlugins(e, arguments[1], arguments[2], arguments[3], arguments[4], arguments[5])
},
b.on = function(e, a) {
return e = c(e),
b.emitterEventListeners[e] || (b.emitterEventListeners[e] = []),
b.emitterEventListeners[e].push(a),
b
},
b.off = function(e, a) {
var t;
if (e = c(e), "undefined" == typeof a) return b.emitterEventListeners[e] = [],
b;
if (b.emitterEventListeners[e] && 0 !== b.emitterEventListeners[e].length) {
for (t = 0; t < b.emitterEventListeners[e].length; t++) b.emitterEventListeners[e][t] === a && b.emitterEventListeners[e].splice(t, 1);
return b
}
},
b.once = function(e, a) {
e = c(e);
var t = function() {
a(arguments[0], arguments[1], arguments[2], arguments[3], arguments[4]),
b.off(e, t)
};
return b.on(e, t),
b
},
b.a11y = {
makeFocusable: function(e) {
return e.attr("tabIndex", "0"),
e
},
addRole: function(e, a) {
return e.attr("role", a),
e
},
addLabel: function(e, a) {
return e.attr("aria-label", a),
e
},
disable: function(e) {
return e.attr("aria-disabled", !0),
e
},
enable: function(e) {
return e.attr("aria-disabled", !1),
e
},
onEnterKey: function(e) {
13 === e.keyCode && (a(e.target).is(b.params.nextButton) ? (b.onClickNext(e), b.isEnd ? b.a11y.notify(b.params.lastSlideMessage) : b.a11y.notify(b.params.nextSlideMessage)) : a(e.target).is(b.params.prevButton) && (b.onClickPrev(e), b.isBeginning ? b.a11y.notify(b.params.firstSlideMessage) : b.a11y.notify(b.params.prevSlideMessage)), a(e.target).is("." + b.params.bulletClass) && a(e.target)[0].click())
},
liveRegion: a('<span class="swiper-notification" aria-live="assertive" aria-atomic="true"></span>'),
notify: function(e) {
var a = b.a11y.liveRegion;
0 !== a.length && (a.html(""), a.html(e))
},
init: function() {
b.params.nextButton && b.nextButton && b.nextButton.length > 0 && (b.a11y.makeFocusable(b.nextButton), b.a11y.addRole(b.nextButton, "button"), b.a11y.addLabel(b.nextButton, b.params.nextSlideMessage)),
b.params.prevButton && b.prevButton && b.prevButton.length > 0 && (b.a11y.makeFocusable(b.prevButton), b.a11y.addRole(b.prevButton, "button"), b.a11y.addLabel(b.prevButton, b.params.prevSlideMessage)),
a(b.container).append(b.a11y.liveRegion)
},
initPagination: function() {
b.params.pagination && b.params.paginationClickable && b.bullets && b.bullets.length && b.bullets.each(function() {
var e = a(this);
b.a11y.makeFocusable(e),
b.a11y.addRole(e, "button"),
b.a11y.addLabel(e, b.params.paginationBulletMessage.replace(/{{index}}/, e.index() + 1))
})
},
destroy: function() {
b.a11y.liveRegion && b.a11y.liveRegion.length > 0 && b.a11y.liveRegion.remove()
}
},
b.init = function() {
b.params.loop && b.createLoop(),
b.updateContainerSize(),
b.updateSlidesSize(),
b.updatePagination(),
b.params.scrollbar && b.scrollbar && (b.scrollbar.set(), b.params.scrollbarDraggable && b.scrollbar.enableDraggable()),
"slide" !== b.params.effect && b.effects[b.params.effect] && (b.params.loop || b.updateProgress(), b.effects[b.params.effect].setTranslate()),
b.params.loop ? b.slideTo(b.params.initialSlide + b.loopedSlides, 0, b.params.runCallbacksOnInit) : (b.slideTo(b.params.initialSlide, 0, b.params.runCallbacksOnInit), 0 === b.params.initialSlide && (b.parallax && b.params.parallax && b.parallax.setTranslate(), b.lazy && b.params.lazyLoading && (b.lazy.load(), b.lazy.initialImageLoaded = !0))),
b.attachEvents(),
b.params.observer && b.support.observer && b.initObservers(),
b.params.preloadImages && !b.params.lazyLoading && b.preloadImages(),
b.params.autoplay && b.startAutoplay(),
b.params.keyboardControl && b.enableKeyboardControl && b.enableKeyboardControl(),
b.params.mousewheelControl && b.enableMousewheelControl && b.enableMousewheelControl(),
b.params.hashnav && b.hashnav && b.hashnav.init(),
b.params.a11y && b.a11y && b.a11y.init(),
b.emit("onInit", b)
},
b.cleanupStyles = function() {
b.container.removeClass(b.classNames.join(" ")).removeAttr("style"),
b.wrapper.removeAttr("style"),
b.slides && b.slides.length && b.slides.removeClass([b.params.slideVisibleClass, b.params.slideActiveClass, b.params.slideNextClass, b.params.slidePrevClass].join(" ")).removeAttr("style").removeAttr("data-swiper-column").removeAttr("data-swiper-row"),
b.paginationContainer && b.paginationContainer.length && b.paginationContainer.removeClass(b.params.paginationHiddenClass),
b.bullets && b.bullets.length && b.bullets.removeClass(b.params.bulletActiveClass),
b.params.prevButton && a(b.params.prevButton).removeClass(b.params.buttonDisabledClass),
b.params.nextButton && a(b.params.nextButton).removeClass(b.params.buttonDisabledClass),
b.params.scrollbar && b.scrollbar && (b.scrollbar.track && b.scrollbar.track.length && b.scrollbar.track.removeAttr("style"), b.scrollbar.drag && b.scrollbar.drag.length && b.scrollbar.drag.removeAttr("style"))
},
b.destroy = function(e, a) {
b.detachEvents(),
b.stopAutoplay(),
b.params.scrollbar && b.scrollbar && b.params.scrollbarDraggable && b.scrollbar.disableDraggable(),
b.params.loop && b.destroyLoop(),
a && b.cleanupStyles(),
b.disconnectObservers(),
b.params.keyboardControl && b.disableKeyboardControl && b.disableKeyboardControl(),
b.params.mousewheelControl && b.disableMousewheelControl && b.disableMousewheelControl(),
b.params.a11y && b.a11y && b.a11y.destroy(),
b.emit("onDestroy"),
e !== !1 && (b = null)
},
b.init(),
b
}
};
t.prototype = {
isSafari: function() {
var e = navigator.userAgent.toLowerCase();
return e.indexOf("safari") >= 0 && e.indexOf("chrome") < 0 && e.indexOf("android") < 0
} (),
isUiWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(navigator.userAgent),
isArray: function(e) {
return "[object Array]" === Object.prototype.toString.apply(e)
},
browser: {
ie: window.navigator.pointerEnabled || window.navigator.msPointerEnabled,
ieTouch: window.navigator.msPointerEnabled && window.navigator.msMaxTouchPoints > 1 || window.navigator.pointerEnabled && window.navigator.maxTouchPoints > 1
},
device: function() {
var e = navigator.userAgent,
a = e.match(/(Android);?[\s\/]+([\d.]+)?/),
t = e.match(/(iPad).*OS\s([\d_]+)/),
r = e.match(/(iPod)(.*OS\s([\d_]+))?/),
i = !t && e.match(/(iPhone\sOS)\s([\d_]+)/);
return {
ios: t || i || r,
android: a
}
} (),
support: {
touch: window.Modernizr && Modernizr.touch === !0 ||
function() {
return !! ("ontouchstart" in window || window.DocumentTouch && document instanceof DocumentTouch)
} (),
transforms3d: window.Modernizr && Modernizr.csstransforms3d === !0 ||
function() {
var e = document.createElement("div").style;
return "webkitPerspective" in e || "MozPerspective" in e || "OPerspective" in e || "MsPerspective" in e || "perspective" in e
} (),
flexbox: function() {
for (var e = document.createElement("div").style, a = "alignItems webkitAlignItems webkitBoxAlign msFlexAlign mozBoxAlign webkitFlexDirection msFlexDirection mozBoxDirection mozBoxOrient webkitBoxDirection webkitBoxOrient".split(" "), t = 0; t < a.length; t++) if (a[t] in e) return ! 0
} (),
observer: function() {
return "MutationObserver" in window || "WebkitMutationObserver" in window
} ()
},
plugins: {}
};
for (var r = (function() {
var e = function(e) {
var a = this,
t = 0;
for (t = 0; t < e.length; t++) a[t] = e[t];
return a.length = e.length,
this
},
a = function(a, t) {
var r = [],
i = 0;
if (a && !t && a instanceof e) return a;
if (a) if ("string" == typeof a) {
var s, n, o = a.trim();
if (o.indexOf("<") >= 0 && o.indexOf(">") >= 0) {
var l = "div";
for (0 === o.indexOf("<li") && (l = "ul"), 0 === o.indexOf("<tr") && (l = "tbody"), (0 === o.indexOf("<td") || 0 === o.indexOf("<th")) && (l = "tr"), 0 === o.indexOf("<tbody") && (l = "table"), 0 === o.indexOf("<option") && (l = "select"), n = document.createElement(l), n.innerHTML = a, i = 0; i < n.childNodes.length; i++) r.push(n.childNodes[i])
} else for (s = t || "#" !== a[0] || a.match(/[ .<>:~]/) ? (t || document).querySelectorAll(a) : [document.getElementById(a.split("#")[1])], i = 0; i < s.length; i++) s[i] && r.push(s[i])
} else if (a.nodeType || a === window || a === document) r.push(a);
else if (a.length > 0 && a[0].nodeType) for (i = 0; i < a.length; i++) r.push(a[i]);
return new e(r)
};
return e.prototype = {
addClass: function(e) {
if ("undefined" == typeof e) return this;
for (var a = e.split(" "), t = 0; t < a.length; t++) for (var r = 0; r < this.length; r++) this[r].classList.add(a[t]);
return this
},
removeClass: function(e) {
for (var a = e.split(" "), t = 0; t < a.length; t++) for (var r = 0; r < this.length; r++) this[r].classList.remove(a[t]);
return this
},
hasClass: function(e) {
return this[0] ? this[0].classList.contains(e) : !1
},
toggleClass: function(e) {
for (var a = e.split(" "), t = 0; t < a.length; t++) for (var r = 0; r < this.length; r++) this[r].classList.toggle(a[t]);
return this
},
attr: function(e, a) {
if (1 === arguments.length && "string" == typeof e) return this[0] ? this[0].getAttribute(e) : void 0;
for (var t = 0; t < this.length; t++) if (2 === arguments.length) this[t].setAttribute(e, a);
else for (var r in e) this[t][r] = e[r],
this[t].setAttribute(r, e[r]);
return this
},
removeAttr: function(e) {
for (var a = 0; a < this.length; a++) this[a].removeAttribute(e);
return this
},
data: function(e, a) {
if ("undefined" != typeof a) {
for (var t = 0; t < this.length; t++) {
var r = this[t];
r.dom7ElementDataStorage || (r.dom7ElementDataStorage = {}),
r.dom7ElementDataStorage[e] = a
}
return this
}
if (this[0]) {
var i = this[0].getAttribute("data-" + e);
return i ? i: this[0].dom7ElementDataStorage && e in this[0].dom7ElementDataStorage ? this[0].dom7ElementDataStorage[e] : void 0
}
},
transform: function(e) {
for (var a = 0; a < this.length; a++) {
var t = this[a].style;
t.webkitTransform = t.MsTransform = t.msTransform = t.MozTransform = t.OTransform = t.transform = e
}
return this
},
transition: function(e) {
"string" != typeof e && (e += "ms");
for (var a = 0; a < this.length; a++) {
var t = this[a].style;
t.webkitTransitionDuration = t.MsTransitionDuration = t.msTransitionDuration = t.MozTransitionDuration = t.OTransitionDuration = t.transitionDuration = e
}
return this
},
on: function(e, t, r, i) {
function s(e) {
var i = e.target;
if (a(i).is(t)) r.call(i, e);
else for (var s = a(i).parents(), n = 0; n < s.length; n++) a(s[n]).is(t) && r.call(s[n], e)
}
var n, o, l = e.split(" ");
for (n = 0; n < this.length; n++) if ("function" == typeof t || t === !1) for ("function" == typeof t && (r = arguments[1], i = arguments[2] || !1), o = 0; o < l.length; o++) this[n].addEventListener(l[o], r, i);
else for (o = 0; o < l.length; o++) this[n].dom7LiveListeners || (this[n].dom7LiveListeners = []),
this[n].dom7LiveListeners.push({
listener: r,
liveListener: s
}),
this[n].addEventListener(l[o], s, i);
return this
},
off: function(e, a, t, r) {
for (var i = e.split(" "), s = 0; s < i.length; s++) for (var n = 0; n < this.length; n++) if ("function" == typeof a || a === !1)"function" == typeof a && (t = arguments[1], r = arguments[2] || !1),
this[n].removeEventListener(i[s], t, r);
else if (this[n].dom7LiveListeners) for (var o = 0; o < this[n].dom7LiveListeners.length; o++) this[n].dom7LiveListeners[o].listener === t && this[n].removeEventListener(i[s], this[n].dom7LiveListeners[o].liveListener, r);
return this
},
once: function(e, a, t, r) {
function i(n) {
t(n),
s.off(e, a, i, r)
}
var s = this;
"function" == typeof a && (a = !1, t = arguments[1], r = arguments[2]),
s.on(e, a, i, r)
},
trigger: function(e, a) {
for (var t = 0; t < this.length; t++) {
var r;
try {
r = new window.CustomEvent(e, {
detail: a,
bubbles: !0,
cancelable: !0
})
} catch(i) {
r = document.createEvent("Event"),
r.initEvent(e, !0, !0),
r.detail = a
}
this[t].dispatchEvent(r)
}
return this
},
transitionEnd: function(e) {
function a(s) {
if (s.target === this) for (e.call(this, s), t = 0; t < r.length; t++) i.off(r[t], a)
}
var t, r = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"],
i = this;
if (e) for (t = 0; t < r.length; t++) i.on(r[t], a);
return this
},
width: function() {
return this[0] === window ? window.innerWidth: this.length > 0 ? parseFloat(this.css("width")) : null
},
outerWidth: function(e) {
return this.length > 0 ? e ? this[0].offsetWidth + parseFloat(this.css("margin-right")) + parseFloat(this.css("margin-left")) : this[0].offsetWidth: null
},
height: function() {
return this[0] === window ? window.innerHeight: this.length > 0 ? parseFloat(this.css("height")) : null
},
outerHeight: function(e) {
return this.length > 0 ? e ? this[0].offsetHeight + parseFloat(this.css("margin-top")) + parseFloat(this.css("margin-bottom")) : this[0].offsetHeight: null
},
offset: function() {
if (this.length > 0) {
var e = this[0],
a = e.getBoundingClientRect(),
t = document.body,
r = e.clientTop || t.clientTop || 0,
i = e.clientLeft || t.clientLeft || 0,
s = window.pageYOffset || e.scrollTop,
n = window.pageXOffset || e.scrollLeft;
return {
top: a.top + s - r,
left: a.left + n - i
}
}
return null
},
css: function(e, a) {
var t;
if (1 === arguments.length) {
if ("string" != typeof e) {
for (t = 0; t < this.length; t++) for (var r in e) this[t].style[r] = e[r];
return this
}
if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(e)
}
if (2 === arguments.length && "string" == typeof e) {
for (t = 0; t < this.length; t++) this[t].style[e] = a;
return this
}
return this
},
each: function(e) {
for (var a = 0; a < this.length; a++) e.call(this[a], a, this[a]);
return this
},
html: function(e) {
if ("undefined" == typeof e) return this[0] ? this[0].innerHTML: void 0;
for (var a = 0; a < this.length; a++) this[a].innerHTML = e;
return this
},
text: function(e) {
if ("undefined" == typeof e) return this[0] ? this[0].textContent.trim() : null;
for (var a = 0; a < this.length; a++) this[a].textContent = e;
return this
},
is: function(t) {
if (!this[0]) return ! 1;
var r, i;
if ("string" == typeof t) {
var s = this[0];
if (s === document) return t === document;
if (s === window) return t === window;
if (s.matches) return s.matches(t);
if (s.webkitMatchesSelector) return s.webkitMatchesSelector(t);
if (s.mozMatchesSelector) return s.mozMatchesSelector(t);
if (s.msMatchesSelector) return s.msMatchesSelector(t);
for (r = a(t), i = 0; i < r.length; i++) if (r[i] === this[0]) return ! 0;
return ! 1
}
if (t === document) return this[0] === document;
if (t === window) return this[0] === window;
if (t.nodeType || t instanceof e) {
for (r = t.nodeType ? [t] : t, i = 0; i < r.length; i++) if (r[i] === this[0]) return ! 0;
return ! 1
}
return ! 1
},
index: function() {
if (this[0]) {
for (var e = this[0], a = 0; null !== (e = e.previousSibling);) 1 === e.nodeType && a++;
return a
}
},
eq: function(a) {
if ("undefined" == typeof a) return this;
var t, r = this.length;
return a > r - 1 ? new e([]) : 0 > a ? (t = r + a, new e(0 > t ? [] : [this[t]])) : new e([this[a]])
},
append: function(a) {
var t, r;
for (t = 0; t < this.length; t++) if ("string" == typeof a) {
var i = document.createElement("div");
for (i.innerHTML = a; i.firstChild;) this[t].appendChild(i.firstChild)
} else if (a instanceof e) for (r = 0; r < a.length; r++) this[t].appendChild(a[r]);
else this[t].appendChild(a);
return this
},
prepend: function(a) {
var t, r;
for (t = 0; t < this.length; t++) if ("string" == typeof a) {
var i = document.createElement("div");
for (i.innerHTML = a, r = i.childNodes.length - 1; r >= 0; r--) this[t].insertBefore(i.childNodes[r], this[t].childNodes[0])
} else if (a instanceof e) for (r = 0; r < a.length; r++) this[t].insertBefore(a[r], this[t].childNodes[0]);
else this[t].insertBefore(a, this[t].childNodes[0]);
return this
},
insertBefore: function(e) {
for (var t = a(e), r = 0; r < this.length; r++) if (1 === t.length) t[0].parentNode.insertBefore(this[r], t[0]);
else if (t.length > 1) for (var i = 0; i < t.length; i++) t[i].parentNode.insertBefore(this[r].cloneNode(!0), t[i])
},
insertAfter: function(e) {
for (var t = a(e), r = 0; r < this.length; r++) if (1 === t.length) t[0].parentNode.insertBefore(this[r], t[0].nextSibling);
else if (t.length > 1) for (var i = 0; i < t.length; i++) t[i].parentNode.insertBefore(this[r].cloneNode(!0), t[i].nextSibling)
},
next: function(t) {
return new e(this.length > 0 ? t ? this[0].nextElementSibling && a(this[0].nextElementSibling).is(t) ? [this[0].nextElementSibling] : [] : this[0].nextElementSibling ? [this[0].nextElementSibling] : [] : [])
},
nextAll: function(t) {
var r = [],
i = this[0];
if (!i) return new e([]);
for (; i.nextElementSibling;) {
var s = i.nextElementSibling;
t ? a(s).is(t) && r.push(s) : r.push(s),
i = s
}
return new e(r)
},
prev: function(t) {
return new e(this.length > 0 ? t ? this[0].previousElementSibling && a(this[0].previousElementSibling).is(t) ? [this[0].previousElementSibling] : [] : this[0].previousElementSibling ? [this[0].previousElementSibling] : [] : [])
},
prevAll: function(t) {
var r = [],
i = this[0];
if (!i) return new e([]);
for (; i.previousElementSibling;) {
var s = i.previousElementSibling;
t ? a(s).is(t) && r.push(s) : r.push(s),
i = s
}
return new e(r)
},
parent: function(e) {
for (var t = [], r = 0; r < this.length; r++) e ? a(this[r].parentNode).is(e) && t.push(this[r].parentNode) : t.push(this[r].parentNode);
return a(a.unique(t))
},
parents: function(e) {
for (var t = [], r = 0; r < this.length; r++) for (var i = this[r].parentNode; i;) e ? a(i).is(e) && t.push(i) : t.push(i),
i = i.parentNode;
return a(a.unique(t))
},
find: function(a) {
for (var t = [], r = 0; r < this.length; r++) for (var i = this[r].querySelectorAll(a), s = 0; s < i.length; s++) t.push(i[s]);
return new e(t)
},
children: function(t) {
for (var r = [], i = 0; i < this.length; i++) for (var s = this[i].childNodes, n = 0; n < s.length; n++) t ? 1 === s[n].nodeType && a(s[n]).is(t) && r.push(s[n]) : 1 === s[n].nodeType && r.push(s[n]);
return new e(a.unique(r))
},
remove: function() {
for (var e = 0; e < this.length; e++) this[e].parentNode && this[e].parentNode.removeChild(this[e]);
return this
},
add: function() {
var e, t, r = this;
for (e = 0; e < arguments.length; e++) {
var i = a(arguments[e]);
for (t = 0; t < i.length; t++) r[r.length] = i[t],
r.length++
}
return r
}
},
a.fn = e.prototype,
a.unique = function(e) {
for (var a = [], t = 0; t < e.length; t++) - 1 === a.indexOf(e[t]) && a.push(e[t]);
return a
},
a
} ()), i = ["jQuery", "Zepto", "Dom7"], s = 0; s < i.length; s++) window[i[s]] && e(window[i[s]]);
var n;
n = "undefined" == typeof r ? window.Dom7 || window.Zepto || window.jQuery: r,
n && ("transitionEnd" in n.fn || (n.fn.transitionEnd = function(e) {
function a(s) {
if (s.target === this) for (e.call(this, s), t = 0; t < r.length; t++) i.off(r[t], a)
}
var t, r = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"],
i = this;
if (e) for (t = 0; t < r.length; t++) i.on(r[t], a);
return this
}), "transform" in n.fn || (n.fn.transform = function(e) {
for (var a = 0; a < this.length; a++) {
var t = this[a].style;
t.webkitTransform = t.MsTransform = t.msTransform = t.MozTransform = t.OTransform = t.transform = e
}
return this
}), "transition" in n.fn || (n.fn.transition = function(e) {
"string" != typeof e && (e += "ms");
for (var a = 0; a < this.length; a++) {
var t = this[a].style;
t.webkitTransitionDuration = t.MsTransitionDuration = t.msTransitionDuration = t.MozTransitionDuration = t.OTransitionDuration = t.transitionDuration = e
}
return this
})),
window.Swiper = t
} (),
"undefined" != typeof module ? module.exports = window.Swiper: "function" == typeof define && define.amd && define([],
function() {
"use strict";
return window.Swiper
});
//# sourceMappingURL=maps/swiper.min.js.map
网友评论