日历插件

代码运行效果:

<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <meta http-equiv="x-ua-compatible" content="ie=7" />
    <title>jQuery实现带有节假日设置的万年历代码</title>
    <link href="~/日历/images/all.css" rel="stylesheet" />
    <link href="~/日历/images/skin.css" rel="stylesheet" />
    <link href="~/日历/images/fontSize12.css" rel="stylesheet" />
    <link href="~/日历/images/calendar.css" rel="stylesheet" />
    <script src="~/日历/js/jquery.js"></script>
    <script src="~/日历/js/calendar.js"></script>
</head>
<body style="height:98%;">
    <div class="main">
        <div class="pathBar" style="margin-bottom:2px;">
            <div class="pathBarPos"> </div>
        </div>
        <div id="myrl" style="width:820px; margin-left:auto; margin-right:auto; height:840px; overflow:hidden;">
            <form name=CLD>
                <table class="biao" width="800px" id="huiyi8">
                    <tbody>
                        <tr>
                            <td class="calTit" colspan=7 style="height:30px;padding-top:3px;text-align:center;">
                                <a href="#" title="上一年" id="nianjian" class="ymNaviBtn lsArrow"></a> <a href="#" title="上一月" id="yuejian" class="ymNaviBtn lArrow"></a><div style="width:250px; float:left; padding-left:230px;"> <span id="dateSelectionRili" class="dateSelectionRili" style="cursor:hand;color: white; border-bottom: 1px solid white;" onclick="dateSelection.show()"> <span id="nian" class="topDateFont"></span><span class="topDateFont">年</span><span id="yue" class="topDateFont"></span><span class="topDateFont">月</span> <span class="dateSelectionBtn cal_next" onclick="dateSelection.show()">▼</span></span>   <font id=GZ class="topDateFont"></font></div>
                                <!--新加导航功能-->
                                <div style="left: 250px; display: none;" id="dateSelectionDiv">
                                    <div id="dateSelectionHeader"></div>
                                    <div id="dateSelectionBody">
                                        <div id="yearList">
                                            <div id="yearListPrev" onclick="dateSelection.prevYearPage()"><</div>
                                            <div id="yearListContent"></div>
                                            <div id="yearListNext" onclick="dateSelection.nextYearPage()">></div>
                                        </div>
                                        <div id="dateSeparator"></div>
                                        <div id="monthList">
                                            <div id="monthListContent">
                                                <span id="SM0" class="month" onclick="dateSelection.setMonth(0)">1</span>
                                                <span id="SM1" class="month" onclick="dateSelection.setMonth(1)">2</span>
                                                <span id="SM2" class="month" onclick="dateSelection.setMonth(2)">3</span>
                                                <span id="SM3" class="month" onclick="dateSelection.setMonth(3)">4</span>
                                                <span id="SM4" class="month" onclick="dateSelection.setMonth(4)">5</span>
                                                <span id="SM5" class="month" onclick="dateSelection.setMonth(5)">6</span><span id="SM6" class="month" onclick="dateSelection.setMonth(6)">7</span>
                                                <span id="SM7" class="month" onclick="dateSelection.setMonth(7)">8</span>
                                                <span id="SM8" class="month" onclick="dateSelection.setMonth(8)">9</span>
                                                <span id="SM9" class="month" onclick="dateSelection.setMonth(9)">10</span>
                                                <span id="SM10" class="month" onclick="dateSelection.setMonth(10)">11</span>
                                                <span id="SM11" class="month curr" onclick="dateSelection.setMonth(11)">12</span>
                                            </div>
                                            <div style="clear:both;"></div>
                                        </div>
                                        <div id="dateSelectionBtn">
                                            <div id="dateSelectionTodayBtn" onclick="dateSelection.goToday()">今天</div>
                                            <div id="dateSelectionOkBtn" onclick="dateSelection.go()">确定</div>
                                            <div id="dateSelectionCancelBtn" onclick="dateSelection.hide()">取消</div>
                                        </div>
                                    </div>
                                    <div id="dateSelectionFooter"></div>
                                </div>
                                <a href="#" id="nianjia" title="下一年" class="ymNaviBtn rsArrow" style="float:right;"></a> <a href="#" id="yuejia" title="下一月" class="ymNaviBtn rArrow" style="float:right;"></a>
                            </td>
                        </tr>
                        <tr class="calWeekTit" style="font-size:12px; height:20px;text-align:center;">
                            <td width="100" class="red">星期日</td>
                            <td width="100">星期一</td>
                            <td width="100">星期二</td>
                            <td width="100">星期三</td>
                            <td width="100">星期四</td>
                            <td width="100">星期五</td>
                            <td width="100" class="red">星期六</td>
                        </tr>
                        <script language="JavaScript">
        var gNum;
        for (var i = 0; i < 6; i++) {
            document.write('<tr align=center height="50" id="tt">');
        for (var j = 0; j < 7; j++) {
        gNum = i * 7 + j ;
            document.write('<td  id="GD' + gNum + '" on="0" ><font  id="SD' + gNum + '" style="font-size:22px;"  face="Arial"');
        if (j == 0)  document.write('color=red');
        if (j == 6)
        if (i % 2 == 1)  document.write('color=red');
        else  document.write('color=red');
            document.write('  TITLE="">  </font><br><font  id="LD' + gNum + '"  size=2  style="white-space:nowrap;overflow:hidden;cursor:default;">  </font></td>');
        }
            document.write('</tr>');
        }
                        </script>
                    </tbody>
                </table>
                </td>
                <td width="100%" align="center">
                    <table border="1" cellpadding="5" cellspacing="5">
                        <tr align="center">
                            <td><input type="button" value="提交" class="button6" onclick="h_submit();"></td>
                            <td><input type="button" value="重置" class="button6" onclick="rebuild();"></td>
                        </tr>
                    </table>
                </td>
                </tr>
                </table>
            </form>
        </div>
    </div>
    <script language="JavaScript">
//提交
function h_submit(){
	if(hDays==""){
		alert("没有选中任何日期!");
	}
	else{
		alert(hDays);
	}
}
//重置
function rebuild(){
	$("#huiyi8 td").removeClass("selday").attr("on",0);
	hDays=[];
}
    </script>
    <div id="details" style="margin-top:-1px;"></div>
</body>
</html>

all.css插件代码:

@charset "utf-8";
/* CSS Document */

HTML{
height:100%; width:100%;}
BODY{
margin:0px; word-wrap:break-word;  word-break:break-all; height:100%; width:100%;}
IMG{
border:0px;}
A{
text-decoration:none; color:#000000;}
A:hover{
text-decoration:none;}
TABLE{
cellpadding:0; cellspacing:0; margin-left:auto; margin-right:auto; border-collapse:collapse;} 
.btn{
width:auto; height:20px; line-height:22px; padding-left:7px; padding-right:7px; margin-top:2px; float:left; cursor:pointer; margin-left:5px; overflow:hidden;}
.btn:hover{
text-decoration:none;}
.btnActive{
width:auto; height:20px; line-height:22px; padding-left:7px; padding-right:7px; margin-top:2px; float:left; cursor:pointer; margin-left:5px; overflow:hidden;}
.btn img{
margin-right:4px; margin-top:3px; width:15px; height:15px; float:left;}
.tableIcon{
width:18px; height:18px;}
.overFlowH{
overflow:hidden;}
.tAC{
text-align:center;}
.W100XHYA{
width:100%; overflow-x:hidden; overflow-y:auto;}
.W1H1OFH{
width:100%; height:100%; overflow:hidden;}
.W160{
width:160px; overflow:hidden;}
.W85{
width:90px; overflow:hidden;}
.W75{
width:75px; overflow:hidden;}
.W70{
width:70px; overflow:hidden;}
.W60{
width:56px; overflow:hidden;}
.W50{
width:50px; margin-left:auto; margin-right:auto;}
.W35{
width:35px; overflow:hidden;}
.LH25{
line-height:25px;}
.FLMR8{
float:left; margin-right:8px;}
.FLML8{
float:left; margin-left:4px;}
.ML5{
margin-left:5px;}
.H21{
height:21px; overflow:hidden;}
.W200H22{
width:190px; height:21px; line-height:22px; overflow:hidden;}
.W60H22{
width:60px; height:21px; line-height:22px; overflow:hidden;}
.MarL15{
margin-left:15px;}
.W50OFH{
width:40%; overflow:hidden;}
.H25BrdBtm{
height:25px; line-height:25px;}

/*main*/
.mainLef{
width:5px; height:26px; float:left;  overflow:hidden;}
.mainRig{
width:5px; height:26px; float:left; overflow:hidden;}
.mainCen{
height:26px; float:left; overflow:hidden;}
.mainCen SPAN{
float:left; margin-top:2px;}
.mainCen STRONG{
line-height:27px; float:left; width:100px;}
.mainCen A{
float:right; line-height:27px;}
.mainCen A:hover{
text-decoration:underline;}
.mainCont{
height:105px; padding-left:5px; margin-bottom:5px; background-color:#FFFFFF; overflow:hidden;}




/*main*/
.main{
width:99%; margin-top:5px; height:100%; background-color:#FFFFFF; margin-left:auto; margin-right:auto; overflow:hidden;}
.bgMain{
width:99%; margin-top:5px; height:100%; margin-left:auto; margin-right:auto; overflow:hidden;}
.indexMain{
width:100%; margin-top:5px; height:100%; overflow:hidden;}
/

.cadTit{
width:260px; height:32px; overflow:hidden;}
.cadCont{
width:258px; height:auto; background-color:#FFFFFF; overflow:hidden;}
.ymNaviss{
width:256px; height:20px; line-height:20px; margin-top:1px; margin-left:auto; margin-right:auto; overflow:hidden;}
.ymNavis{
width:160px; line-height:20px; margin-left:auto; margin-right:auto; overflow:hidden;}
.ymNavis SPAN{
float:left; margin-left:3px; margin-right:3px; width:70px; text-align:center;}
.ymNaviBtn{
height:15px; width:15px; margin-top:2px; float:left; margin-left:3px; margin-right:3px; overflow:hidden;}

.cadTable{
margin-bottom:1px; background-color:#FFFFFF; text-align:center;}
.red{
color:#FF0000;}
.cadTable thead{
height:20px; overflow:hidden;}
.cadTable tbody tr{
height:18px;}
.cadTable tbody td A{
width:100%; height:100%; float:left;}
.cadTable tbody td A:hover{
background-color:#fdfdcf;}

skin.css插件代码:

/* CSS Document */

BODY {
    background-color: #ccdbf0;
}


.topBar {
    background-image: url(topBarC.gif);
    border: 1px solid #99BBE8;
}

.topBar SPAN {
    color: #15428B;
}


/*main*/
.main {
    border: 1px solid #99BBE8;
}


.lsArrow{
background-image:url(tool-sprites.gif); background-position:0px 180px;}
.lsArrow:hover{
background-image:url(tool-sprites.gif); background-position:15px 180px;}
.lArrow{
background-image:url(tool-sprites.gif); background-position:0px 255px;}
.lArrow:hover{
background-image:url(tool-sprites.gif); background-position:15px 255px;}
.rsArrow{
background-image:url(tool-sprites.gif); background-position:0px 195px;}
.rsArrow:hover{
background-image:url(tool-sprites.gif); background-position:15px 195px;}
.rArrow{
background-image:url(tool-sprites.gif); background-position:0px 240px;}
.rArrow:hover{
background-image:url(tool-sprites.gif); background-position:15px 240px;}


.cadTable thead tr{
background-color:#99BBE8;}
.cadTable tbody td{
border:1px solid #99BBE8;}



/*calendar*/
.calTit{
background-image:url(calTit.jpg);}
.calWeekTit{
background-color:#99BBE8; color:#15428B;}
.calTit FONT{
color:#15428B;}
table.biao td {
border: 1px solid #99BBE8;}
.pop{
border:1px solid #99BBE8;}
#teshu{
background-color:#e6eef7; background-image:url(topBarC.gif);}
.jinri {
background: #cfdff0;}
.cal_next{
color:#15428B;}
.selday {
background: #FBBB67;}

fontSize12.css插件代码:

@charset "utf-8";
/* CSS Document */

DIV{
font-size:12px;}
A{
font-size:12px;}
SPAN{
font-size:12px;}
FONT{
font-size:12px;}
TD{
font-size:12px;}
TH{
font-size:12px;}

calendar.css插件代码:

html {
    overflow-x: hidden;
    overflow-y: auto;
}

#myrl {
    width: 490px;
    height: 352px;
    margin: 0px auto;
    margin-top:20px;
    position: relative;

}

#teshu {
    float: right;
	text-align:right;
	padding-right:5px;
	font-size:14px;
	height:25px;
	line-height:25px;
	width:285px;
    margin-top: 0px;
}

#box {
    position: absolute;
    top: 0px;
    right: 0px;
    padding: 0
}



.unover {
    background: #f4f1f1;
    cursor: auto;
}

.pop {
    width: 290px;
    height: 180px;
    background-color: #ffffff;
	font-size:12px;
	color:#000000;

    position: absolute;
}
.pop FONT{
padding-left:5px;}

table.biao {
    border-collapse: collapse;
    font-family: "Times New Roman", "宋体";
}



.over {
    background: #f0e68c;)
}

.tt:hover {
    background: #f9fbc9;
    text-decoration: none;
}

.imag1 {
    margin-right: 2px;
}

.topDateFont{
font-size:14px; color:#000000;}
.calTit FONT{
margin-top:2px;}
.calTit SPAN{
margin-top:2px; font-weight:bold;}



/*===== dateSelection =====*/
#dateSelectionDiv {
	border: 1px solid #f8c173;
	background: #fefef1;
	position: absolute;
	top: 25px;
	z-index: 20;
	width: 160px;
	display: none;
}

#dateSelectionHeader {
	width: 100%;
	font-size: 0;
}
#dateSelectionBody {
	width: 100%;
}
#dateSelectionFooter {
	width: 100%;
	font-size: 0;
}
#dateSeparator {
	margin: 0 auto;
	width: 152px;
	height: 2px;
	font-size: 0;
}
#dateSelectionBtn {
	margin: 0 auto;
	width: 133px;
	height: 20px;
	line-height: 20px;
}
#dateSelectionTodayBtn {
	float: left;
	width: 41px;
	height: 20px;
	cursor: pointer;
}
#dateSelectionOkBtn {
	float: left;
	text-align: center;
	margin: 0 5px 0 5px;
	width: 41px;
	height: 20px;
	cursor: pointer;
}
#dateSelectionCancelBtn {
	float: right;
	text-align: right;
	width: 41px;
	height: 20px;
	cursor: pointer;
}
#yearList {
	width: 158px;
	height: 20px;
	line-height: 20px;
	color: green;
}

#yearListPrev {
	float: left;
	margin-left: 3px;
	text-align: left;
	width: 8px;
	height: 20px;
	cursor: pointer;
}

#yearListNext {
	float: right;
	margin-right: 3px;
	text-align: right;
	width: 8px;
	height: 20px;
	cursor: pointer;
}

#yearListContent {
	float: left;
	height: 20px;
}

#yearListContent .year {
	float: left;
	display: block;
	width: 33px;
	height: 20px;
	font-size: 11px;
	text-align: center;
	cursor: pointer;
}

#yearListContent .curr {
	color: red;
}

#monthList {
	margin: 0 1px 0 1px;
	padding: 0 15px 0 15px;
}

#monthListContent .month {
	float: left;
	display: block;
	width: 17px;
	height: 15px;
	margin: 2px;
	line-height: 15px;
	text-align: center;
	cursor: pointer;
}

#monthListContent .curr {
	color: red;
}

jquery.js插件代码:

/*
 * jQuery JavaScript Library v1.3.2
 * http://jquery.com/
 *
 * Copyright (c) 2009 John Resig
 * Dual licensed under the MIT and GPL licenses.
 * http://docs.jquery.com/License
 *
 * Date: 2009-02-19 17:34:21 -0500 (Thu, 19 Feb 2009)
 * Revision: 6246
 */
(function() {
    var l = this,g,y = l.jQuery,p = l.$,o = l.jQuery = l.$ = function(E, F) {
        return new o.fn.init(E, F)
    },D = /^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/,f = /^.[^:#\[\.,]*$/;
    o.fn = o.prototype = {init:function(E, H) {
        E = E || document;
        if (E.nodeType) {
            this[0] = E;
            this.length = 1;
            this.context = E;
            return this
        }
        if (typeof E === "string") {
            var G = D.exec(E);
            if (G && (G[1] || !H)) {
                if (G[1]) {
                    E = o.clean([G[1]], H)
                } else {
                    var I = document.getElementById(G[3]);
                    if (I && I.id != G[3]) {
                        return o().find(E)
                    }
                    var F = o(I || []);
                    F.context = document;
                    F.selector = E;
                    return F
                }
            } else {
                return o(H).find(E)
            }
        } else {
            if (o.isFunction(E)) {
                return o(document).ready(E)
            }
        }
        if (E.selector && E.context) {
            this.selector = E.selector;
            this.context = E.context
        }
        return this.setArray(o.isArray(E) ? E : o.makeArray(E))
    },selector:"",jquery:"1.3.2",size:function() {
        return this.length
    },get:function(E) {
        return E === g ? Array.prototype.slice.call(this) : this[E]
    },pushStack:function(F, H, E) {
        var G = o(F);
        G.prevObject = this;
        G.context = this.context;
        if (H === "find") {
            G.selector = this.selector + (this.selector ? " " : "") + E
        } else {
            if (H) {
                G.selector = this.selector + "." + H + "(" + E + ")"
            }
        }
        return G
    },setArray:function(E) {
        this.length = 0;
        Array.prototype.push.apply(this, E);
        return this
    },each:function(F, E) {
        return o.each(this, F, E)
    },index:function(E) {
        return o.inArray(E && E.jquery ? E[0] : E, this)
    },attr:function(F, H, G) {
        var E = F;
        if (typeof F === "string") {
            if (H === g) {
                return this[0] && o[G || "attr"](this[0], F)
            } else {
                E = {};
                E[F] = H
            }
        }
        return this.each(function(I) {
            for (F in E) {
                o.attr(G ? this.style : this, F, o.prop(this, E[F], G, I, F))
            }
        })
    },css:function(E, F) {
        if ((E == "width" || E == "height") && parseFloat(F) < 0) {
            F = g
        }
        return this.attr(E, F, "curCSS")
    },text:function(F) {
        if (typeof F !== "object" && F != null) {
            return this.empty().append((this[0] && this[0].ownerDocument || document).createTextNode(F))
        }
        var E = "";
        o.each(F || this, function() {
            o.each(this.childNodes, function() {
                if (this.nodeType != 8) {
                    E += this.nodeType != 1 ? this.nodeValue : o.fn.text([this])
                }
            })
        });
        return E
    },wrapAll:function(E) {
        if (this[0]) {
            var F = o(E, this[0].ownerDocument).clone();
            if (this[0].parentNode) {
                F.insertBefore(this[0])
            }
            F.map(function() {
                var G = this;
                while (G.firstChild) {
                    G = G.firstChild
                }
                return G
            }).append(this)
        }
        return this
    },wrapInner:function(E) {
        return this.each(function() {
            o(this).contents().wrapAll(E)
        })
    },wrap:function(E) {
        return this.each(function() {
            o(this).wrapAll(E)
        })
    },append:function() {
        return this.domManip(arguments, true, function(E) {
            if (this.nodeType == 1) {
                this.appendChild(E)
            }
        })
    },prepend:function() {
        return this.domManip(arguments, true, function(E) {
            if (this.nodeType == 1) {
                this.insertBefore(E, this.firstChild)
            }
        })
    },before:function() {
        return this.domManip(arguments, false, function(E) {
            this.parentNode.insertBefore(E, this)
        })
    },after:function() {
        return this.domManip(arguments, false, function(E) {
            this.parentNode.insertBefore(E, this.nextSibling)
        })
    },end:function() {
        return this.prevObject || o([])
    },push:[].push,sort:[].sort,splice:[].splice,find:function(E) {
        if (this.length === 1) {
            var F = this.pushStack([], "find", E);
            F.length = 0;
            o.find(E, this[0], F);
            return F
        } else {
            return this.pushStack(o.unique(o.map(this, function(G) {
                return o.find(E, G)
            })), "find", E)
        }
    },clone:function(G) {
        var E = this.map(function() {
            if (!o.support.noCloneEvent && !o.isXMLDoc(this)) {
                var I = this.outerHTML;
                if (!I) {
                    var J = this.ownerDocument.createElement("div");
                    J.appendChild(this.cloneNode(true));
                    I = J.innerHTML
                }
                return o.clean([I.replace(/ jQuery\d+="(?:\d+|null)"/g, "").replace(/^\s*/, "")])[0]
            } else {
                return this.cloneNode(true)
            }
        });
        if (G === true) {
            var H = this.find("*").andSelf(),F = 0;
            E.find("*").andSelf().each(function() {
                if (this.nodeName !== H[F].nodeName) {
                    return
                }
                var I = o.data(H[F], "events");
                for (var K in I) {
                    for (var J in I[K]) {
                        o.event.add(this, K, I[K][J], I[K][J].data)
                    }
                }
                F++
            })
        }
        return E
    },filter:function(E) {
        return this.pushStack(o.isFunction(E) && o.grep(this, function(G, F) {
            return E.call(G, F)
        }) || o.multiFilter(E, o.grep(this, function(F) {
            return F.nodeType === 1
        })), "filter", E)
    },closest:function(E) {
        var G = o.expr.match.POS.test(E) ? o(E) : null,F = 0;
        return this.map(function() {
            var H = this;
            while (H && H.ownerDocument) {
                if (G ? G.index(H) > -1 : o(H).is(E)) {
                    o.data(H, "closest", F);
                    return H
                }
                H = H.parentNode;
                F++
            }
        })
    },not:function(E) {
        if (typeof E === "string") {
            if (f.test(E)) {
                return this.pushStack(o.multiFilter(E, this, true), "not", E)
            } else {
                E = o.multiFilter(E, this)
            }
        }
        var F = E.length && E[E.length - 1] !== g && !E.nodeType;
        return this.filter(function() {
            return F ? o.inArray(this, E) < 0 : this != E
        })
    },add:function(E) {
        return this.pushStack(o.unique(o.merge(this.get(), typeof E === "string" ? o(E) : o.makeArray(E))))
    },is:function(E) {
        return !!E && o.multiFilter(E, this).length > 0
    },hasClass:function(E) {
        return !!E && this.is("." + E)
    },val:function(K) {
        if (K === g) {
            var E = this[0];
            if (E) {
                if (o.nodeName(E, "option")) {
                    return(E.attributes.value || {}).specified ? E.value : E.text
                }
                if (o.nodeName(E, "select")) {
                    var I = E.selectedIndex,L = [],M = E.options,H = E.type == "select-one";
                    if (I < 0) {
                        return null
                    }
                    for (var F = H ? I : 0,J = H ? I + 1 : M.length; F < J; F++) {
                        var G = M[F];
                        if (G.selected) {
                            K = o(G).val();
                            if (H) {
                                return K
                            }
                            L.push(K)
                        }
                    }
                    return L
                }
                return(E.value || "").replace(/\r/g, "")
            }
            return g
        }
        if (typeof K === "number") {
            K += ""
        }
        return this.each(function() {
            if (this.nodeType != 1) {
                return
            }
            if (o.isArray(K) && /radio|checkbox/.test(this.type)) {
                this.checked = (o.inArray(this.value, K) >= 0 || o.inArray(this.name, K) >= 0)
            } else {
                if (o.nodeName(this, "select")) {
                    var N = o.makeArray(K);
                    o("option", this).each(function() {
                        this.selected = (o.inArray(this.value, N) >= 0 || o.inArray(this.text, N) >= 0)
                    });
                    if (!N.length) {
                        this.selectedIndex = -1
                    }
                } else {
                    this.value = K
                }
            }
        })
    },html:function(E) {
        return E === g ? (this[0] ? this[0].innerHTML.replace(/ jQuery\d+="(?:\d+|null)"/g, "") : null) : this.empty().append(E)
    },replaceWith:function(E) {
        return this.after(E).remove()
    },eq:function(E) {
        return this.slice(E, +E + 1)
    },slice:function() {
        return this.pushStack(Array.prototype.slice.apply(this, arguments), "slice", Array.prototype.slice.call(arguments).join(","))
    },map:function(E) {
        return this.pushStack(o.map(this, function(G, F) {
            return E.call(G, F, G)
        }))
    },andSelf:function() {
        return this.add(this.prevObject)
    },domManip:function(J, M, L) {
        if (this[0]) {
            var I = (this[0].ownerDocument || this[0]).createDocumentFragment(),F = o.clean(J, (this[0].ownerDocument || this[0]), I),H = I.firstChild;
            if (H) {
                for (var G = 0,E = this.length; G < E; G++) {
                    L.call(K(this[G], H), this.length > 1 || G > 0 ? I.cloneNode(true) : I)
                }
            }
            if (F) {
                o.each(F, z)
            }
        }
        return this;
        function K(N, O) {
            return M && o.nodeName(N, "table") && o.nodeName(O, "tr") ? (N.getElementsByTagName("tbody")[0] || N.appendChild(N.ownerDocument.createElement("tbody"))) : N
        }
    }};
    o.fn.init.prototype = o.fn;
    function z(E, F) {
        if (F.src) {
            o.ajax({url:F.src,async:false,dataType:"script"})
        } else {
            o.globalEval(F.text || F.textContent || F.innerHTML || "")
        }
        if (F.parentNode) {
            F.parentNode.removeChild(F)
        }
    }

    function e() {
        return +new Date
    }

    o.extend = o.fn.extend = function() {
        var J = arguments[0] || {},H = 1,I = arguments.length,E = false,G;
        if (typeof J === "boolean") {
            E = J;
            J = arguments[1] || {};
            H = 2
        }
        if (typeof J !== "object" && !o.isFunction(J)) {
            J = {}
        }
        if (I == H) {
            J = this;
            --H
        }
        for (; H < I; H++) {
            if ((G = arguments[H]) != null) {
                for (var F in G) {
                    var K = J[F],L = G[F];
                    if (J === L) {
                        continue
                    }
                    if (E && L && typeof L === "object" && !L.nodeType) {
                        J[F] = o.extend(E, K || (L.length != null ? [] : {}), L)
                    } else {
                        if (L !== g) {
                            J[F] = L
                        }
                    }
                }
            }
        }
        return J
    };
    var b = /z-?index|font-?weight|opacity|zoom|line-?height/i,q = document.defaultView || {},s = Object.prototype.toString;
    o.extend({noConflict:function(E) {
        l.$ = p;
        if (E) {
            l.jQuery = y
        }
        return o
    },isFunction:function(E) {
        return s.call(E) === "[object Function]"
    },isArray:function(E) {
        return s.call(E) === "[object Array]"
    },isXMLDoc:function(E) {
        return E.nodeType === 9 && E.documentElement.nodeName !== "HTML" || !!E.ownerDocument && o.isXMLDoc(E.ownerDocument)
    },globalEval:function(G) {
        if (G && /\S/.test(G)) {
            var F = document.getElementsByTagName("head")[0] || document.documentElement,E = document.createElement("script");
            E.type = "text/javascript";
            if (o.support.scriptEval) {
                E.appendChild(document.createTextNode(G))
            } else {
                E.text = G
            }
            F.insertBefore(E, F.firstChild);
            F.removeChild(E)
        }
    },nodeName:function(F, E) {
        return F.nodeName && F.nodeName.toUpperCase() == E.toUpperCase()
    },each:function(G, K, F) {
        var E,H = 0,I = G.length;
        if (F) {
            if (I === g) {
                for (E in G) {
                    if (K.apply(G[E], F) === false) {
                        break
                    }
                }
            } else {
                for (; H < I;) {
                    if (K.apply(G[H++], F) === false) {
                        break
                    }
                }
            }
        } else {
            if (I === g) {
                for (E in G) {
                    if (K.call(G[E], E, G[E]) === false) {
                        break
                    }
                }
            } else {
                for (var J = G[0]; H < I && K.call(J, H, J) !== false; J = G[++H]) {
                }
            }
        }
        return G
    },prop:function(H, I, G, F, E) {
        if (o.isFunction(I)) {
            I = I.call(H, F)
        }
        return typeof I === "number" && G == "curCSS" && !b.test(E) ? I + "px" : I
    },className:{add:function(E, F) {
        o.each((F || "").split(/\s+/), function(G, H) {
            if (E.nodeType == 1 && !o.className.has(E.className, H)) {
                E.className += (E.className ? " " : "") + H
            }
        })
    },remove:function(E, F) {
        if (E.nodeType == 1) {
            E.className = F !== g ? o.grep(E.className.split(/\s+/), function(G) {
                return !o.className.has(F, G)
            }).join(" ") : ""
        }
    },has:function(F, E) {
        return F && o.inArray(E, (F.className || F).toString().split(/\s+/)) > -1
    }},swap:function(H, G, I) {
        var E = {};
        for (var F in G) {
            E[F] = H.style[F];
            H.style[F] = G[F]
        }
        I.call(H);
        for (var F in G) {
            H.style[F] = E[F]
        }
    },css:function(H, F, J, E) {
        if (F == "width" || F == "height") {
            var L,G = {position:"absolute",visibility:"hidden",display:"block"},K = F == "width" ? ["Left","Right"] : ["Top","Bottom"];

            function I() {
                L = F == "width" ? H.offsetWidth : H.offsetHeight;
                if (E === "border") {
                    return
                }
                o.each(K, function() {
                    if (!E) {
                        L -= parseFloat(o.curCSS(H, "padding" + this, true)) || 0
                    }
                    if (E === "margin") {
                        L += parseFloat(o.curCSS(H, "margin" + this, true)) || 0
                    } else {
                        L -= parseFloat(o.curCSS(H, "border" + this + "Width", true)) || 0
                    }
                })
            }

            if (H.offsetWidth !== 0) {
                I()
            } else {
                o.swap(H, G, I)
            }
            return Math.max(0, Math.round(L))
        }
        return o.curCSS(H, F, J)
    },curCSS:function(I, F, G) {
        var L,E = I.style;
        if (F == "opacity" && !o.support.opacity) {
            L = o.attr(E, "opacity");
            return L == "" ? "1" : L
        }
        if (F.match(/float/i)) {
            F = w
        }
        if (!G && E && E[F]) {
            L = E[F]
        } else {
            if (q.getComputedStyle) {
                if (F.match(/float/i)) {
                    F = "float"
                }
                F = F.replace(/([A-Z])/g, "-$1").toLowerCase();
                var M = q.getComputedStyle(I, null);
                if (M) {
                    L = M.getPropertyValue(F)
                }
                if (F == "opacity" && L == "") {
                    L = "1"
                }
            } else {
                if (I.currentStyle) {
                    var J = F.replace(/\-(\w)/g, function(N, O) {
                        return O.toUpperCase()
                    });
                    L = I.currentStyle[F] || I.currentStyle[J];
                    if (!/^\d+(px)?$/i.test(L) && /^\d/.test(L)) {
                        var H = E.left,K = I.runtimeStyle.left;
                        I.runtimeStyle.left = I.currentStyle.left;
                        E.left = L || 0;
                        L = E.pixelLeft + "px";
                        E.left = H;
                        I.runtimeStyle.left = K
                    }
                }
            }
        }
        return L
    },clean:function(F, K, I) {
        K = K || document;
        if (typeof K.createElement === "undefined") {
            K = K.ownerDocument || K[0] && K[0].ownerDocument || document
        }
        if (!I && F.length === 1 && typeof F[0] === "string") {
            var H = /^<(\w+)\s*\/?>$/.exec(F[0]);
            if (H) {
                return[K.createElement(H[1])]
            }
        }
        var G = [],E = [],L = K.createElement("div");
        o.each(F, function(P, S) {
            if (typeof S === "number") {
                S += ""
            }
            if (!S) {
                return
            }
            if (typeof S === "string") {
                S = S.replace(/(<(\w+)[^>]*?)\/>/g, function(U, V, T) {
                    return T.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i) ? U : V + "></" + T + ">"
                });
                var O = S.replace(/^\s+/, "").substring(0, 10).toLowerCase();
                var Q = !O.indexOf("<opt") && [1,"<select multiple='multiple'>","</select>"] || !O.indexOf("<leg") && [1,"<fieldset>","</fieldset>"] || O.match(/^<(thead|tbody|tfoot|colg|cap)/) && [1,"<table>","</table>"] || !O.indexOf("<tr") && [2,"<table><tbody>","</tbody></table>"] || (!O.indexOf("<td") || !O.indexOf("<th")) && [3,"<table><tbody><tr>","</tr></tbody></table>"] || !O.indexOf("<col") && [2,"<table><tbody></tbody><colgroup>","</colgroup></table>"] || !o.support.htmlSerialize && [1,"div<div>","</div>"] || [0,"",""];
                L.innerHTML = Q[1] + S + Q[2];
                while (Q[0]--) {
                    L = L.lastChild
                }
                if (!o.support.tbody) {
                    var R = /<tbody/i.test(S),N = !O.indexOf("<table") && !R ? L.firstChild && L.firstChild.childNodes : Q[1] == "<table>" && !R ? L.childNodes : [];
                    for (var M = N.length - 1; M >= 0; --M) {
                        if (o.nodeName(N[M], "tbody") && !N[M].childNodes.length) {
                            N[M].parentNode.removeChild(N[M])
                        }
                    }
                }
                if (!o.support.leadingWhitespace && /^\s/.test(S)) {
                    L.insertBefore(K.createTextNode(S.match(/^\s*/)[0]), L.firstChild)
                }
                S = o.makeArray(L.childNodes)
            }
            if (S.nodeType) {
                G.push(S)
            } else {
                G = o.merge(G, S)
            }
        });
        if (I) {
            for (var J = 0; G[J]; J++) {
                if (o.nodeName(G[J], "script") && (!G[J].type || G[J].type.toLowerCase() === "text/javascript")) {
                    E.push(G[J].parentNode ? G[J].parentNode.removeChild(G[J]) : G[J])
                } else {
                    if (G[J].nodeType === 1) {
                        G.splice.apply(G, [J + 1,0].concat(o.makeArray(G[J].getElementsByTagName("script"))))
                    }
                    I.appendChild(G[J])
                }
            }
            return E
        }
        return G
    },attr:function(J, G, K) {
        if (!J || J.nodeType == 3 || J.nodeType == 8) {
            return g
        }
        var H = !o.isXMLDoc(J),L = K !== g;
        G = H && o.props[G] || G;
        if (J.tagName) {
            var F = /href|src|style/.test(G);
            if (G == "selected" && J.parentNode) {
                J.parentNode.selectedIndex
            }
            if (G in J && H && !F) {
                if (L) {
                    if (G == "type" && o.nodeName(J, "input") && J.parentNode) {
                        throw"type property can't be changed"
                    }
                    J[G] = K
                }
                if (o.nodeName(J, "form") && J.getAttributeNode(G)) {
                    return J.getAttributeNode(G).nodeValue
                }
                if (G == "tabIndex") {
                    var I = J.getAttributeNode("tabIndex");
                    return I && I.specified ? I.value : J.nodeName.match(/(button|input|object|select|textarea)/i) ? 0 : J.nodeName.match(/^(a|area)$/i) && J.href ? 0 : g
                }
                return J[G]
            }
            if (!o.support.style && H && G == "style") {
                return o.attr(J.style, "cssText", K)
            }
            if (L) {
                J.setAttribute(G, "" + K)
            }
            var E = !o.support.hrefNormalized && H && F ? J.getAttribute(G, 2) : J.getAttribute(G);
            return E === null ? g : E
        }
        if (!o.support.opacity && G == "opacity") {
            if (L) {
                J.zoom = 1;
                J.filter = (J.filter || "").replace(/alpha\([^)]*\)/, "") + (parseInt(K) + "" == "NaN" ? "" : "alpha(opacity=" + K * 100 + ")")
            }
            return J.filter && J.filter.indexOf("opacity=") >= 0 ? (parseFloat(J.filter.match(/opacity=([^)]*)/)[1]) / 100) + "" : ""
        }
        G = G.replace(/-([a-z])/ig, function(M, N) {
            return N.toUpperCase()
        });
        if (L) {
            J[G] = K
        }
        return J[G]
    },trim:function(E) {
        return(E || "").replace(/^\s+|\s+$/g, "")
    },makeArray:function(G) {
        var E = [];
        if (G != null) {
            var F = G.length;
            if (F == null || typeof G === "string" || o.isFunction(G) || G.setInterval) {
                E[0] = G
            } else {
                while (F) {
                    E[--F] = G[F]
                }
            }
        }
        return E
    },inArray:function(G, H) {
        for (var E = 0,F = H.length; E < F; E++) {
            if (H[E] === G) {
                return E
            }
        }
        return -1
    },merge:function(H, E) {
        var F = 0,G,I = H.length;
        if (!o.support.getAll) {
            while ((G = E[F++]) != null) {
                if (G.nodeType != 8) {
                    H[I++] = G
                }
            }
        } else {
            while ((G = E[F++]) != null) {
                H[I++] = G
            }
        }
        return H
    },unique:function(K) {
        var F = [],E = {};
        try {
            for (var G = 0,H = K.length; G < H; G++) {
                var J = o.data(K[G]);
                if (!E[J]) {
                    E[J] = true;
                    F.push(K[G])
                }
            }
        } catch(I) {
            F = K
        }
        return F
    },grep:function(F, J, E) {
        var G = [];
        for (var H = 0,I = F.length; H < I; H++) {
            if (!E != !J(F[H], H)) {
                G.push(F[H])
            }
        }
        return G
    },map:function(E, J) {
        var F = [];
        for (var G = 0,H = E.length; G < H; G++) {
            var I = J(E[G], G);
            if (I != null) {
                F[F.length] = I
            }
        }
        return F.concat.apply([], F)
    }});
    var C = navigator.userAgent.toLowerCase();
    o.browser = {version:(C.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/) || [0,"0"])[1],safari:/webkit/.test(C),opera:/opera/.test(C),msie:/msie/.test(C) && !/opera/.test(C),mozilla:/mozilla/.test(C) && !/(compatible|webkit)/.test(C)};
    o.each({parent:function(E) {
        return E.parentNode
    },parents:function(E) {
        return o.dir(E, "parentNode")
    },next:function(E) {
        return o.nth(E, 2, "nextSibling")
    },prev:function(E) {
        return o.nth(E, 2, "previousSibling")
    },nextAll:function(E) {
        return o.dir(E, "nextSibling")
    },prevAll:function(E) {
        return o.dir(E, "previousSibling")
    },siblings:function(E) {
        return o.sibling(E.parentNode.firstChild, E)
    },children:function(E) {
        return o.sibling(E.firstChild)
    },contents:function(E) {
        return o.nodeName(E, "iframe") ? E.contentDocument || E.contentWindow.document : o.makeArray(E.childNodes)
    }}, function(E, F) {
        o.fn[E] = function(G) {
            var H = o.map(this, F);
            if (G && typeof G == "string") {
                H = o.multiFilter(G, H)
            }
            return this.pushStack(o.unique(H), E, G)
        }
    });
    o.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"}, function(E, F) {
        o.fn[E] = function(G) {
            var J = [],L = o(G);
            for (var K = 0,H = L.length; K < H; K++) {
                var I = (K > 0 ? this.clone(true) : this).get();
                o.fn[F].apply(o(L[K]), I);
                J = J.concat(I)
            }
            return this.pushStack(J, E, G)
        }
    });
    o.each({removeAttr:function(E) {
        o.attr(this, E, "");
        if (this.nodeType == 1) {
            this.removeAttribute(E)
        }
    },addClass:function(E) {
        o.className.add(this, E)
    },removeClass:function(E) {
        o.className.remove(this, E)
    },toggleClass:function(F, E) {
        if (typeof E !== "boolean") {
            E = !o.className.has(this, F)
        }
        o.className[E ? "add" : "remove"](this, F)
    },remove:function(E) {
        if (!E || o.filter(E, [this]).length) {
            o("*", this).add([this]).each(function() {
                o.event.remove(this);
                o.removeData(this)
            });
            if (this.parentNode) {
                this.parentNode.removeChild(this)
            }
        }
    },empty:function() {
        o(this).children().remove();
        while (this.firstChild) {
            this.removeChild(this.firstChild)
        }
    }}, function(E, F) {
        o.fn[E] = function() {
            return this.each(F, arguments)
        }
    });
    function j(E, F) {
        return E[0] && parseInt(o.curCSS(E[0], F, true), 10) || 0
    }

    var h = "jQuery" + e(),v = 0,A = {};
    o.extend({cache:{},data:function(F, E, G) {
        F = F == l ? A : F;
        var H = F[h];
        if (!H) {
            H = F[h] = ++v
        }
        if (E && !o.cache[H]) {
            o.cache[H] = {}
        }
        if (G !== g) {
            o.cache[H][E] = G
        }
        return E ? o.cache[H][E] : H
    },removeData:function(F, E) {
        F = F == l ? A : F;
        var H = F[h];
        if (E) {
            if (o.cache[H]) {
                delete o.cache[H][E];
                E = "";
                for (E in o.cache[H]) {
                    break
                }
                if (!E) {
                    o.removeData(F)
                }
            }
        } else {
            try {
                delete F[h]
            } catch(G) {
                if (F.removeAttribute) {
                    F.removeAttribute(h)
                }
            }
            delete o.cache[H]
        }
    },queue:function(F, E, H) {
        if (F) {
            E = (E || "fx") + "queue";
            var G = o.data(F, E);
            if (!G || o.isArray(H)) {
                G = o.data(F, E, o.makeArray(H))
            } else {
                if (H) {
                    G.push(H)
                }
            }
        }
        return G
    },dequeue:function(H, G) {
        var E = o.queue(H, G),F = E.shift();
        if (!G || G === "fx") {
            F = E[0]
        }
        if (F !== g) {
            F.call(H)
        }
    }});
    o.fn.extend({data:function(E, G) {
        var H = E.split(".");
        H[1] = H[1] ? "." + H[1] : "";
        if (G === g) {
            var F = this.triggerHandler("getData" + H[1] + "!", [H[0]]);
            if (F === g && this.length) {
                F = o.data(this[0], E)
            }
            return F === g && H[1] ? this.data(H[0]) : F
        } else {
            return this.trigger("setData" + H[1] + "!", [H[0],G]).each(function() {
                o.data(this, E, G)
            })
        }
    },removeData:function(E) {
        return this.each(function() {
            o.removeData(this, E)
        })
    },queue:function(E, F) {
        if (typeof E !== "string") {
            F = E;
            E = "fx"
        }
        if (F === g) {
            return o.queue(this[0], E)
        }
        return this.each(function() {
            var G = o.queue(this, E, F);
            if (E == "fx" && G.length == 1) {
                G[0].call(this)
            }
        })
    },dequeue:function(E) {
        return this.each(function() {
            o.dequeue(this, E)
        })
    }});
    /*
     * Sizzle CSS Selector Engine - v0.9.3
     *  Copyright 2009, The Dojo Foundation
     *  Released under the MIT, BSD, and GPL Licenses.
     *  More information: http://sizzlejs.com/
     */
    (function() {
        var R = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?/g,L = 0,H = Object.prototype.toString;
        var F = function(Y, U, ab, ac) {
            ab = ab || [];
            U = U || document;
            if (U.nodeType !== 1 && U.nodeType !== 9) {
                return[]
            }
            if (!Y || typeof Y !== "string") {
                return ab
            }
            var Z = [],W,af,ai,T,ad,V,X = true;
            R.lastIndex = 0;
            while ((W = R.exec(Y)) !== null) {
                Z.push(W[1]);
                if (W[2]) {
                    V = RegExp.rightContext;
                    break
                }
            }
            if (Z.length > 1 && M.exec(Y)) {
                if (Z.length === 2 && I.relative[Z[0]]) {
                    af = J(Z[0] + Z[1], U)
                } else {
                    af = I.relative[Z[0]] ? [U] : F(Z.shift(), U);
                    while (Z.length) {
                        Y = Z.shift();
                        if (I.relative[Y]) {
                            Y += Z.shift()
                        }
                        af = J(Y, af)
                    }
                }
            } else {
                var ae = ac ? {expr:Z.pop(),set:E(ac)} : F.find(Z.pop(), Z.length === 1 && U.parentNode ? U.parentNode : U, Q(U));
                af = F.filter(ae.expr, ae.set);
                if (Z.length > 0) {
                    ai = E(af)
                } else {
                    X = false
                }
                while (Z.length) {
                    var ah = Z.pop(),ag = ah;
                    if (!I.relative[ah]) {
                        ah = ""
                    } else {
                        ag = Z.pop()
                    }
                    if (ag == null) {
                        ag = U
                    }
                    I.relative[ah](ai, ag, Q(U))
                }
            }
            if (!ai) {
                ai = af
            }
            if (!ai) {
                throw"Syntax error, unrecognized expression: " + (ah || Y)
            }
            if (H.call(ai) === "[object Array]") {
                if (!X) {
                    ab.push.apply(ab, ai)
                } else {
                    if (U.nodeType === 1) {
                        for (var aa = 0; ai[aa] != null; aa++) {
                            if (ai[aa] && (ai[aa] === true || ai[aa].nodeType === 1 && K(U, ai[aa]))) {
                                ab.push(af[aa])
                            }
                        }
                    } else {
                        for (var aa = 0; ai[aa] != null; aa++) {
                            if (ai[aa] && ai[aa].nodeType === 1) {
                                ab.push(af[aa])
                            }
                        }
                    }
                }
            } else {
                E(ai, ab)
            }
            if (V) {
                F(V, U, ab, ac);
                if (G) {
                    hasDuplicate = false;
                    ab.sort(G);
                    if (hasDuplicate) {
                        for (var aa = 1; aa < ab.length; aa++) {
                            if (ab[aa] === ab[aa - 1]) {
                                ab.splice(aa--, 1)
                            }
                        }
                    }
                }
            }
            return ab
        };
        F.matches = function(T, U) {
            return F(T, null, null, U)
        };
        F.find = function(aa, T, ab) {
            var Z,X;
            if (!aa) {
                return[]
            }
            for (var W = 0,V = I.order.length; W < V; W++) {
                var Y = I.order[W],X;
                if ((X = I.match[Y].exec(aa))) {
                    var U = RegExp.leftContext;
                    if (U.substr(U.length - 1) !== "\\") {
                        X[1] = (X[1] || "").replace(/\\/g, "");
                        Z = I.find[Y](X, T, ab);
                        if (Z != null) {
                            aa = aa.replace(I.match[Y], "");
                            break
                        }
                    }
                }
            }
            if (!Z) {
                Z = T.getElementsByTagName("*")
            }
            return{set:Z,expr:aa}
        };
        F.filter = function(ad, ac, ag, W) {
            var V = ad,ai = [],aa = ac,Y,T,Z = ac && ac[0] && Q(ac[0]);
            while (ad && ac.length) {
                for (var ab in I.filter) {
                    if ((Y = I.match[ab].exec(ad)) != null) {
                        var U = I.filter[ab],ah,af;
                        T = false;
                        if (aa == ai) {
                            ai = []
                        }
                        if (I.preFilter[ab]) {
                            Y = I.preFilter[ab](Y, aa, ag, ai, W, Z);
                            if (!Y) {
                                T = ah = true
                            } else {
                                if (Y === true) {
                                    continue
                                }
                            }
                        }
                        if (Y) {
                            for (var X = 0; (af = aa[X]) != null; X++) {
                                if (af) {
                                    ah = U(af, Y, X, aa);
                                    var ae = W ^ !!ah;
                                    if (ag && ah != null) {
                                        if (ae) {
                                            T = true
                                        } else {
                                            aa[X] = false
                                        }
                                    } else {
                                        if (ae) {
                                            ai.push(af);
                                            T = true
                                        }
                                    }
                                }
                            }
                        }
                        if (ah !== g) {
                            if (!ag) {
                                aa = ai
                            }
                            ad = ad.replace(I.match[ab], "");
                            if (!T) {
                                return[]
                            }
                            break
                        }
                    }
                }
                if (ad == V) {
                    if (T == null) {
                        throw"Syntax error, unrecognized expression: " + ad
                    } else {
                        break
                    }
                }
                V = ad
            }
            return aa
        };
        var I = F.selectors = {order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF_-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF_-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*_-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF_-]|\\.)+)(?:\((['"]*)((?:\([^\)]+\)|[^\2\(\)]*)+)\2\))?/},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(T) {
            return T.getAttribute("href")
        }},relative:{"+":function(aa, T, Z) {
            var X = typeof T === "string",ab = X && !/\W/.test(T),Y = X && !ab;
            if (ab && !Z) {
                T = T.toUpperCase()
            }
            for (var W = 0,V = aa.length,U; W < V; W++) {
                if ((U = aa[W])) {
                    while ((U = U.previousSibling) && U.nodeType !== 1) {
                    }
                    aa[W] = Y || U && U.nodeName === T ? U || false : U === T
                }
            }
            if (Y) {
                F.filter(T, aa, true)
            }
        },">":function(Z, U, aa) {
            var X = typeof U === "string";
            if (X && !/\W/.test(U)) {
                U = aa ? U : U.toUpperCase();
                for (var V = 0,T = Z.length; V < T; V++) {
                    var Y = Z[V];
                    if (Y) {
                        var W = Y.parentNode;
                        Z[V] = W.nodeName === U ? W : false
                    }
                }
            } else {
                for (var V = 0,T = Z.length; V < T; V++) {
                    var Y = Z[V];
                    if (Y) {
                        Z[V] = X ? Y.parentNode : Y.parentNode === U
                    }
                }
                if (X) {
                    F.filter(U, Z, true)
                }
            }
        },"":function(W, U, Y) {
            var V = L++,T = S;
            if (!U.match(/\W/)) {
                var X = U = Y ? U : U.toUpperCase();
                T = P
            }
            T("parentNode", U, V, W, X, Y)
        },"~":function(W, U, Y) {
            var V = L++,T = S;
            if (typeof U === "string" && !U.match(/\W/)) {
                var X = U = Y ? U : U.toUpperCase();
                T = P
            }
            T("previousSibling", U, V, W, X, Y)
        }},find:{ID:function(U, V, W) {
            if (typeof V.getElementById !== "undefined" && !W) {
                var T = V.getElementById(U[1]);
                return T ? [T] : []
            }
        },NAME:function(V, Y, Z) {
            if (typeof Y.getElementsByName !== "undefined") {
                var U = [],X = Y.getElementsByName(V[1]);
                for (var W = 0,T = X.length; W < T; W++) {
                    if (X[W].getAttribute("name") === V[1]) {
                        U.push(X[W])
                    }
                }
                return U.length === 0 ? null : U
            }
        },TAG:function(T, U) {
            return U.getElementsByTagName(T[1])
        }},preFilter:{CLASS:function(W, U, V, T, Z, aa) {
            W = " " + W[1].replace(/\\/g, "") + " ";
            if (aa) {
                return W
            }
            for (var X = 0,Y; (Y = U[X]) != null; X++) {
                if (Y) {
                    if (Z ^ (Y.className && (" " + Y.className + " ").indexOf(W) >= 0)) {
                        if (!V) {
                            T.push(Y)
                        }
                    } else {
                        if (V) {
                            U[X] = false
                        }
                    }
                }
            }
            return false
        },ID:function(T) {
            return T[1].replace(/\\/g, "")
        },TAG:function(U, T) {
            for (var V = 0; T[V] === false; V++) {
            }
            return T[V] && Q(T[V]) ? U[1] : U[1].toUpperCase()
        },CHILD:function(T) {
            if (T[1] == "nth") {
                var U = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(T[2] == "even" && "2n" || T[2] == "odd" && "2n+1" || !/\D/.test(T[2]) && "0n+" + T[2] || T[2]);
                T[2] = (U[1] + (U[2] || 1)) - 0;
                T[3] = U[3] - 0
            }
            T[0] = L++;
            return T
        },ATTR:function(X, U, V, T, Y, Z) {
            var W = X[1].replace(/\\/g, "");
            if (!Z && I.attrMap[W]) {
                X[1] = I.attrMap[W]
            }
            if (X[2] === "~=") {
                X[4] = " " + X[4] + " "
            }
            return X
        },PSEUDO:function(X, U, V, T, Y) {
            if (X[1] === "not") {
                if (X[3].match(R).length > 1 || /^\w/.test(X[3])) {
                    X[3] = F(X[3], null, null, U)
                } else {
                    var W = F.filter(X[3], U, V, true ^ Y);
                    if (!V) {
                        T.push.apply(T, W)
                    }
                    return false
                }
            } else {
                if (I.match.POS.test(X[0]) || I.match.CHILD.test(X[0])) {
                    return true
                }
            }
            return X
        },POS:function(T) {
            T.unshift(true);
            return T
        }},filters:{enabled:function(T) {
            return T.disabled === false && T.type !== "hidden"
        },disabled:function(T) {
            return T.disabled === true
        },checked:function(T) {
            return T.checked === true
        },selected:function(T) {
            T.parentNode.selectedIndex;
            return T.selected === true
        },parent:function(T) {
            return !!T.firstChild
        },empty:function(T) {
            return !T.firstChild
        },has:function(V, U, T) {
            return !!F(T[3], V).length
        },header:function(T) {
            return/h\d/i.test(T.nodeName)
        },text:function(T) {
            return"text" === T.type
        },radio:function(T) {
            return"radio" === T.type
        },checkbox:function(T) {
            return"checkbox" === T.type
        },file:function(T) {
            return"file" === T.type
        },password:function(T) {
            return"password" === T.type
        },submit:function(T) {
            return"submit" === T.type
        },image:function(T) {
            return"image" === T.type
        },reset:function(T) {
            return"reset" === T.type
        },button:function(T) {
            return"button" === T.type || T.nodeName.toUpperCase() === "BUTTON"
        },input:function(T) {
            return/input|select|textarea|button/i.test(T.nodeName)
        }},setFilters:{first:function(U, T) {
            return T === 0
        },last:function(V, U, T, W) {
            return U === W.length - 1
        },even:function(U, T) {
            return T % 2 === 0
        },odd:function(U, T) {
            return T % 2 === 1
        },lt:function(V, U, T) {
            return U < T[3] - 0
        },gt:function(V, U, T) {
            return U > T[3] - 0
        },nth:function(V, U, T) {
            return T[3] - 0 == U
        },eq:function(V, U, T) {
            return T[3] - 0 == U
        }},filter:{PSEUDO:function(Z, V, W, aa) {
            var U = V[1],X = I.filters[U];
            if (X) {
                return X(Z, W, V, aa)
            } else {
                if (U === "contains") {
                    return(Z.textContent || Z.innerText || "").indexOf(V[3]) >= 0
                } else {
                    if (U === "not") {
                        var Y = V[3];
                        for (var W = 0,T = Y.length; W < T; W++) {
                            if (Y[W] === Z) {
                                return false
                            }
                        }
                        return true
                    }
                }
            }
        },CHILD:function(T, W) {
            var Z = W[1],U = T;
            switch (Z) {case"only":case"first":while (U = U.previousSibling) {
                if (U.nodeType === 1) {
                    return false
                }
            }if (Z == "first") {
                return true
            }U = T;case"last":while (U = U.nextSibling) {
                if (U.nodeType === 1) {
                    return false
                }
            }return true;case"nth":var V = W[2],ac = W[3];if (V == 1 && ac == 0) {
                return true
            }var Y = W[0],ab = T.parentNode;if (ab && (ab.sizcache !== Y || !T.nodeIndex)) {
                var X = 0;
                for (U = ab.firstChild; U; U = U.nextSibling) {
                    if (U.nodeType === 1) {
                        U.nodeIndex = ++X
                    }
                }
                ab.sizcache = Y
            }var aa = T.nodeIndex - ac;if (V == 0) {
                return aa == 0
            } else {
                return(aa % V == 0 && aa / V >= 0)
            }
            }
        },ID:function(U, T) {
            return U.nodeType === 1 && U.getAttribute("id") === T
        },TAG:function(U, T) {
            return(T === "*" && U.nodeType === 1) || U.nodeName === T
        },CLASS:function(U, T) {
            return(" " + (U.className || U.getAttribute("class")) + " ").indexOf(T) > -1
        },ATTR:function(Y, W) {
            var V = W[1],T = I.attrHandle[V] ? I.attrHandle[V](Y) : Y[V] != null ? Y[V] : Y.getAttribute(V),Z = T + "",X = W[2],U = W[4];
            return T == null ? X === "!=" : X === "=" ? Z === U : X === "*=" ? Z.indexOf(U) >= 0 : X === "~=" ? (" " + Z + " ").indexOf(U) >= 0 : !U ? Z && T !== false : X === "!=" ? Z != U : X === "^=" ? Z.indexOf(U) === 0 : X === "$=" ? Z.substr(Z.length - U.length) === U : X === "|=" ? Z === U || Z.substr(0, U.length + 1) === U + "-" : false
        },POS:function(X, U, V, Y) {
            var T = U[2],W = I.setFilters[T];
            if (W) {
                return W(X, V, U, Y)
            }
        }}};
        var M = I.match.POS;
        for (var O in I.match) {
            I.match[O] = RegExp(I.match[O].source + /(?![^\[]*\])(?![^\(]*\))/.source)
        }
        var E = function(U, T) {
            U = Array.prototype.slice.call(U);
            if (T) {
                T.push.apply(T, U);
                return T
            }
            return U
        };
        try {
            Array.prototype.slice.call(document.documentElement.childNodes)
        } catch(N) {
            E = function(X, W) {
                var U = W || [];
                if (H.call(X) === "[object Array]") {
                    Array.prototype.push.apply(U, X)
                } else {
                    if (typeof X.length === "number") {
                        for (var V = 0,T = X.length; V < T; V++) {
                            U.push(X[V])
                        }
                    } else {
                        for (var V = 0; X[V]; V++) {
                            U.push(X[V])
                        }
                    }
                }
                return U
            }
        }
        var G;
        if (document.documentElement.compareDocumentPosition) {
            G = function(U, T) {
                var V = U.compareDocumentPosition(T) & 4 ? -1 : U === T ? 0 : 1;
                if (V === 0) {
                    hasDuplicate = true
                }
                return V
            }
        } else {
            if ("sourceIndex" in document.documentElement) {
                G = function(U, T) {
                    var V = U.sourceIndex - T.sourceIndex;
                    if (V === 0) {
                        hasDuplicate = true
                    }
                    return V
                }
            } else {
                if (document.createRange) {
                    G = function(W, U) {
                        var V = W.ownerDocument.createRange(),T = U.ownerDocument.createRange();
                        V.selectNode(W);
                        V.collapse(true);
                        T.selectNode(U);
                        T.collapse(true);
                        var X = V.compareBoundaryPoints(Range.START_TO_END, T);
                        if (X === 0) {
                            hasDuplicate = true
                        }
                        return X
                    }
                }
            }
        }
        (function() {
            var U = document.createElement("form"),V = "script" + (new Date).getTime();
            U.innerHTML = "<input name='" + V + "'/>";
            var T = document.documentElement;
            T.insertBefore(U, T.firstChild);
            if (!!document.getElementById(V)) {
                I.find.ID = function(X, Y, Z) {
                    if (typeof Y.getElementById !== "undefined" && !Z) {
                        var W = Y.getElementById(X[1]);
                        return W ? W.id === X[1] || typeof W.getAttributeNode !== "undefined" && W.getAttributeNode("id").nodeValue === X[1] ? [W] : g : []
                    }
                };
                I.filter.ID = function(Y, W) {
                    var X = typeof Y.getAttributeNode !== "undefined" && Y.getAttributeNode("id");
                    return Y.nodeType === 1 && X && X.nodeValue === W
                }
            }
            T.removeChild(U)
        })();
        (function() {
            var T = document.createElement("div");
            T.appendChild(document.createComment(""));
            if (T.getElementsByTagName("*").length > 0) {
                I.find.TAG = function(U, Y) {
                    var X = Y.getElementsByTagName(U[1]);
                    if (U[1] === "*") {
                        var W = [];
                        for (var V = 0; X[V]; V++) {
                            if (X[V].nodeType === 1) {
                                W.push(X[V])
                            }
                        }
                        X = W
                    }
                    return X
                }
            }
            T.innerHTML = "<a href='#'></a>";
            if (T.firstChild && typeof T.firstChild.getAttribute !== "undefined" && T.firstChild.getAttribute("href") !== "#") {
                I.attrHandle.href = function(U) {
                    return U.getAttribute("href", 2)
                }
            }
        })();
        if (document.querySelectorAll) {
            (function() {
                var T = F,U = document.createElement("div");
                U.innerHTML = "<p class='TEST'></p>";
                if (U.querySelectorAll && U.querySelectorAll(".TEST").length === 0) {
                    return
                }
                F = function(Y, X, V, W) {
                    X = X || document;
                    if (!W && X.nodeType === 9 && !Q(X)) {
                        try {
                            return E(X.querySelectorAll(Y), V)
                        } catch(Z) {
                        }
                    }
                    return T(Y, X, V, W)
                };
                F.find = T.find;
                F.filter = T.filter;
                F.selectors = T.selectors;
                F.matches = T.matches
            })()
        }
        if (document.getElementsByClassName && document.documentElement.getElementsByClassName) {
            (function() {
                var T = document.createElement("div");
                T.innerHTML = "<div class='test e'></div><div class='test'></div>";
                if (T.getElementsByClassName("e").length === 0) {
                    return
                }
                T.lastChild.className = "e";
                if (T.getElementsByClassName("e").length === 1) {
                    return
                }
                I.order.splice(1, 0, "CLASS");
                I.find.CLASS = function(U, V, W) {
                    if (typeof V.getElementsByClassName !== "undefined" && !W) {
                        return V.getElementsByClassName(U[1])
                    }
                }
            })()
        }
        function P(U, Z, Y, ad, aa, ac) {
            var ab = U == "previousSibling" && !ac;
            for (var W = 0,V = ad.length; W < V; W++) {
                var T = ad[W];
                if (T) {
                    if (ab && T.nodeType === 1) {
                        T.sizcache = Y;
                        T.sizset = W
                    }
                    T = T[U];
                    var X = false;
                    while (T) {
                        if (T.sizcache === Y) {
                            X = ad[T.sizset];
                            break
                        }
                        if (T.nodeType === 1 && !ac) {
                            T.sizcache = Y;
                            T.sizset = W
                        }
                        if (T.nodeName === Z) {
                            X = T;
                            break
                        }
                        T = T[U]
                    }
                    ad[W] = X
                }
            }
        }

        function S(U, Z, Y, ad, aa, ac) {
            var ab = U == "previousSibling" && !ac;
            for (var W = 0,V = ad.length; W < V; W++) {
                var T = ad[W];
                if (T) {
                    if (ab && T.nodeType === 1) {
                        T.sizcache = Y;
                        T.sizset = W
                    }
                    T = T[U];
                    var X = false;
                    while (T) {
                        if (T.sizcache === Y) {
                            X = ad[T.sizset];
                            break
                        }
                        if (T.nodeType === 1) {
                            if (!ac) {
                                T.sizcache = Y;
                                T.sizset = W
                            }
                            if (typeof Z !== "string") {
                                if (T === Z) {
                                    X = true;
                                    break
                                }
                            } else {
                                if (F.filter(Z, [T]).length > 0) {
                                    X = T;
                                    break
                                }
                            }
                        }
                        T = T[U]
                    }
                    ad[W] = X
                }
            }
        }

        var K = document.compareDocumentPosition ? function(U, T) {
            return U.compareDocumentPosition(T) & 16
        } : function(U, T) {
            return U !== T && (U.contains ? U.contains(T) : true)
        };
        var Q = function(T) {
            return T.nodeType === 9 && T.documentElement.nodeName !== "HTML" || !!T.ownerDocument && Q(T.ownerDocument)
        };
        var J = function(T, aa) {
            var W = [],X = "",Y,V = aa.nodeType ? [aa] : aa;
            while ((Y = I.match.PSEUDO.exec(T))) {
                X += Y[0];
                T = T.replace(I.match.PSEUDO, "")
            }
            T = I.relative[T] ? T + "*" : T;
            for (var Z = 0,U = V.length; Z < U; Z++) {
                F(T, V[Z], W)
            }
            return F.filter(X, W)
        };
        o.find = F;
        o.filter = F.filter;
        o.expr = F.selectors;
        o.expr[":"] = o.expr.filters;
        F.selectors.filters.hidden = function(T) {
            return T.offsetWidth === 0 || T.offsetHeight === 0
        };
        F.selectors.filters.visible = function(T) {
            return T.offsetWidth > 0 || T.offsetHeight > 0
        };
        F.selectors.filters.animated = function(T) {
            return o.grep(o.timers, function(U) {
                return T === U.elem
            }).length
        };
        o.multiFilter = function(V, T, U) {
            if (U) {
                V = ":not(" + V + ")"
            }
            return F.matches(V, T)
        };
        o.dir = function(V, U) {
            var T = [],W = V[U];
            while (W && W != document) {
                if (W.nodeType == 1) {
                    T.push(W)
                }
                W = W[U]
            }
            return T
        };
        o.nth = function(X, T, V, W) {
            T = T || 1;
            var U = 0;
            for (; X; X = X[V]) {
                if (X.nodeType == 1 && ++U == T) {
                    break
                }
            }
            return X
        };
        o.sibling = function(V, U) {
            var T = [];
            for (; V; V = V.nextSibling) {
                if (V.nodeType == 1 && V != U) {
                    T.push(V)
                }
            }
            return T
        };
        return;
        l.Sizzle = F
    })();
    o.event = {add:function(I, F, H, K) {
        if (I.nodeType == 3 || I.nodeType == 8) {
            return
        }
        if (I.setInterval && I != l) {
            I = l
        }
        if (!H.guid) {
            H.guid = this.guid++
        }
        if (K !== g) {
            var G = H;
            H = this.proxy(G);
            H.data = K
        }
        var E = o.data(I, "events") || o.data(I, "events", {}),J = o.data(I, "handle") || o.data(I, "handle", function() {
            return typeof o !== "undefined" && !o.event.triggered ? o.event.handle.apply(arguments.callee.elem, arguments) : g
        });
        J.elem = I;
        o.each(F.split(/\s+/), function(M, N) {
            var O = N.split(".");
            N = O.shift();
            H.type = O.slice().sort().join(".");
            var L = E[N];
            if (o.event.specialAll[N]) {
                o.event.specialAll[N].setup.call(I, K, O)
            }
            if (!L) {
                L = E[N] = {};
                if (!o.event.special[N] || o.event.special[N].setup.call(I, K, O) === false) {
                    if (I.addEventListener) {
                        I.addEventListener(N, J, false)
                    } else {
                        if (I.attachEvent) {
                            I.attachEvent("on" + N, J)
                        }
                    }
                }
            }
            L[H.guid] = H;
            o.event.global[N] = true
        });
        I = null
    },guid:1,global:{},remove:function(K, H, J) {
        if (K.nodeType == 3 || K.nodeType == 8) {
            return
        }
        var G = o.data(K, "events"),F,E;
        if (G) {
            if (H === g || (typeof H === "string" && H.charAt(0) == ".")) {
                for (var I in G) {
                    this.remove(K, I + (H || ""))
                }
            } else {
                if (H.type) {
                    J = H.handler;
                    H = H.type
                }
                o.each(H.split(/\s+/), function(M, O) {
                    var Q = O.split(".");
                    O = Q.shift();
                    var N = RegExp("(^|\\.)" + Q.slice().sort().join(".*\\.") + "(\\.|$)");
                    if (G[O]) {
                        if (J) {
                            delete G[O][J.guid]
                        } else {
                            for (var P in G[O]) {
                                if (N.test(G[O][P].type)) {
                                    delete G[O][P]
                                }
                            }
                        }
                        if (o.event.specialAll[O]) {
                            o.event.specialAll[O].teardown.call(K, Q)
                        }
                        for (F in G[O]) {
                            break
                        }
                        if (!F) {
                            if (!o.event.special[O] || o.event.special[O].teardown.call(K, Q) === false) {
                                if (K.removeEventListener) {
                                    K.removeEventListener(O, o.data(K, "handle"), false)
                                } else {
                                    if (K.detachEvent) {
                                        K.detachEvent("on" + O, o.data(K, "handle"))
                                    }
                                }
                            }
                            F = null;
                            delete G[O]
                        }
                    }
                })
            }
            for (F in G) {
                break
            }
            if (!F) {
                var L = o.data(K, "handle");
                if (L) {
                    L.elem = null
                }
                o.removeData(K, "events");
                o.removeData(K, "handle")
            }
        }
    },trigger:function(I, K, H, E) {
        var G = I.type || I;
        if (!E) {
            I = typeof I === "object" ? I[h] ? I : o.extend(o.Event(G), I) : o.Event(G);
            if (G.indexOf("!") >= 0) {
                I.type = G = G.slice(0, -1);
                I.exclusive = true
            }
            if (!H) {
                I.stopPropagation();
                if (this.global[G]) {
                    o.each(o.cache, function() {
                        if (this.events && this.events[G]) {
                            o.event.trigger(I, K, this.handle.elem)
                        }
                    })
                }
            }
            if (!H || H.nodeType == 3 || H.nodeType == 8) {
                return g
            }
            I.result = g;
            I.target = H;
            K = o.makeArray(K);
            K.unshift(I)
        }
        I.currentTarget = H;
        var J = o.data(H, "handle");
        if (J) {
            J.apply(H, K)
        }
        if ((!H[G] || (o.nodeName(H, "a") && G == "click")) && H["on" + G] && H["on" + G].apply(H, K) === false) {
            I.result = false
        }
        if (!E && H[G] && !I.isDefaultPrevented() && !(o.nodeName(H, "a") && G == "click")) {
            this.triggered = true;
            try {
                H[G]()
            } catch(L) {
            }
        }
        this.triggered = false;
        if (!I.isPropagationStopped()) {
            var F = H.parentNode || H.ownerDocument;
            if (F) {
                o.event.trigger(I, K, F, true)
            }
        }
    },handle:function(K) {
        var J,E;
        K = arguments[0] = o.event.fix(K || l.event);
        K.currentTarget = this;
        var L = K.type.split(".");
        K.type = L.shift();
        J = !L.length && !K.exclusive;
        var I = RegExp("(^|\\.)" + L.slice().sort().join(".*\\.") + "(\\.|$)");
        E = (o.data(this, "events") || {})[K.type];
        for (var G in E) {
            var H = E[G];
            if (J || I.test(H.type)) {
                K.handler = H;
                K.data = H.data;
                var F = H.apply(this, arguments);
                if (F !== g) {
                    K.result = F;
                    if (F === false) {
                        K.preventDefault();
                        K.stopPropagation()
                    }
                }
                if (K.isImmediatePropagationStopped()) {
                    break
                }
            }
        }
    },props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(H) {
        if (H[h]) {
            return H
        }
        var F = H;
        H = o.Event(F);
        for (var G = this.props.length,J; G;) {
            J = this.props[--G];
            H[J] = F[J]
        }
        if (!H.target) {
            H.target = H.srcElement || document
        }
        if (H.target.nodeType == 3) {
            H.target = H.target.parentNode
        }
        if (!H.relatedTarget && H.fromElement) {
            H.relatedTarget = H.fromElement == H.target ? H.toElement : H.fromElement
        }
        if (H.pageX == null && H.clientX != null) {
            var I = document.documentElement,E = document.body;
            H.pageX = H.clientX + (I && I.scrollLeft || E && E.scrollLeft || 0) - (I.clientLeft || 0);
            H.pageY = H.clientY + (I && I.scrollTop || E && E.scrollTop || 0) - (I.clientTop || 0)
        }
        if (!H.which && ((H.charCode || H.charCode === 0) ? H.charCode : H.keyCode)) {
            H.which = H.charCode || H.keyCode
        }
        if (!H.metaKey && H.ctrlKey) {
            H.metaKey = H.ctrlKey
        }
        if (!H.which && H.button) {
            H.which = (H.button & 1 ? 1 : (H.button & 2 ? 3 : (H.button & 4 ? 2 : 0)))
        }
        return H
    },proxy:function(F, E) {
        E = E || function() {
            return F.apply(this, arguments)
        };
        E.guid = F.guid = F.guid || E.guid || this.guid++;
        return E
    },special:{ready:{setup:B,teardown:function() {
    }}},specialAll:{live:{setup:function(E, F) {
        o.event.add(this, F[0], c)
    },teardown:function(G) {
        if (G.length) {
            var E = 0,F = RegExp("(^|\\.)" + G[0] + "(\\.|$)");
            o.each((o.data(this, "events").live || {}), function() {
                if (F.test(this.type)) {
                    E++
                }
            });
            if (E < 1) {
                o.event.remove(this, G[0], c)
            }
        }
    }}}};
    o.Event = function(E) {
        if (!this.preventDefault) {
            return new o.Event(E)
        }
        if (E && E.type) {
            this.originalEvent = E;
            this.type = E.type
        } else {
            this.type = E
        }
        this.timeStamp = e();
        this[h] = true
    };
    function k() {
        return false
    }

    function u() {
        return true
    }

    o.Event.prototype = {preventDefault:function() {
        this.isDefaultPrevented = u;
        var E = this.originalEvent;
        if (!E) {
            return
        }
        if (E.preventDefault) {
            E.preventDefault()
        }
        E.returnValue = false
    },stopPropagation:function() {
        this.isPropagationStopped = u;
        var E = this.originalEvent;
        if (!E) {
            return
        }
        if (E.stopPropagation) {
            E.stopPropagation()
        }
        E.cancelBubble = true
    },stopImmediatePropagation:function() {
        this.isImmediatePropagationStopped = u;
        this.stopPropagation()
    },isDefaultPrevented:k,isPropagationStopped:k,isImmediatePropagationStopped:k};
    var a = function(F) {
        var E = F.relatedTarget;
        while (E && E != this) {
            try {
                E = E.parentNode
            } catch(G) {
                E = this
            }
        }
        if (E != this) {
            F.type = F.data;
            o.event.handle.apply(this, arguments)
        }
    };
    o.each({mouseover:"mouseenter",mouseout:"mouseleave"}, function(F, E) {
        o.event.special[E] = {setup:function() {
            o.event.add(this, F, a, E)
        },teardown:function() {
            o.event.remove(this, F, a)
        }}
    });
    o.fn.extend({bind:function(F, G, E) {
        return F == "unload" ? this.one(F, G, E) : this.each(function() {
            o.event.add(this, F, E || G, E && G)
        })
    },one:function(G, H, F) {
        var E = o.event.proxy(F || H, function(I) {
            o(this).unbind(I, E);
            return(F || H).apply(this, arguments)
        });
        return this.each(function() {
            o.event.add(this, G, E, F && H)
        })
    },unbind:function(F, E) {
        return this.each(function() {
            o.event.remove(this, F, E)
        })
    },trigger:function(E, F) {
        return this.each(function() {
            o.event.trigger(E, F, this)
        })
    },triggerHandler:function(E, G) {
        if (this[0]) {
            var F = o.Event(E);
            F.preventDefault();
            F.stopPropagation();
            o.event.trigger(F, G, this[0]);
            return F.result
        }
    },toggle:function(G) {
        var E = arguments,F = 1;
        while (F < E.length) {
            o.event.proxy(G, E[F++])
        }
        return this.click(o.event.proxy(G, function(H) {
            this.lastToggle = (this.lastToggle || 0) % F;
            H.preventDefault();
            return E[this.lastToggle++].apply(this, arguments) || false
        }))
    },hover:function(E, F) {
        return this.mouseenter(E).mouseleave(F)
    },ready:function(E) {
        B();
        if (o.isReady) {
            E.call(document, o)
        } else {
            o.readyList.push(E)
        }
        return this
    },live:function(G, F) {
        var E = o.event.proxy(F);
        E.guid += this.selector + G;
        o(document).bind(i(G, this.selector), this.selector, E);
        return this
    },die:function(F, E) {
        o(document).unbind(i(F, this.selector), E ? {guid:E.guid + this.selector + F} : null);
        return this
    }});
    function c(H) {
        var E = RegExp("(^|\\.)" + H.type + "(\\.|$)"),G = true,F = [];
        o.each(o.data(this, "events").live || [], function(I, J) {
            if (E.test(J.type)) {
                var K = o(H.target).closest(J.data)[0];
                if (K) {
                    F.push({elem:K,fn:J})
                }
            }
        });
        F.sort(function(J, I) {
            return o.data(J.elem, "closest") - o.data(I.elem, "closest")
        });
        o.each(F, function() {
            if (this.fn.call(this.elem, H, this.fn.data) === false) {
                return(G = false)
            }
        });
        return G
    }

    function i(F, E) {
        return["live",F,E.replace(/\./g, "`").replace(/ /g, "|")].join(".")
    }

    o.extend({isReady:false,readyList:[],ready:function() {
        if (!o.isReady) {
            o.isReady = true;
            if (o.readyList) {
                o.each(o.readyList, function() {
                    this.call(document, o)
                });
                o.readyList = null
            }
            o(document).triggerHandler("ready")
        }
    }});
    var x = false;

    function B() {
        if (x) {
            return
        }
        x = true;
        if (document.addEventListener) {
            document.addEventListener("DOMContentLoaded", function() {
                document.removeEventListener("DOMContentLoaded", arguments.callee, false);
                o.ready()
            }, false)
        } else {
            if (document.attachEvent) {
                document.attachEvent("onreadystatechange", function() {
                    if (document.readyState === "complete") {
                        document.detachEvent("onreadystatechange", arguments.callee);
                        o.ready()
                    }
                });
                if (document.documentElement.doScroll && l == l.top) {
                    (function() {
                        if (o.isReady) {
                            return
                        }
                        try {
                            document.documentElement.doScroll("left")
                        } catch(E) {
                            setTimeout(arguments.callee, 0);
                            return
                        }
                        o.ready()
                    })()
                }
            }
        }
        o.event.add(l, "load", o.ready)
    }

    o.each(("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error").split(","), function(F, E) {
        o.fn[E] = function(G) {
            return G ? this.bind(E, G) : this.trigger(E)
        }
    });
    o(l).bind("unload", function() {
        for (var E in o.cache) {
            if (E != 1 && o.cache[E].handle) {
                o.event.remove(o.cache[E].handle.elem)
            }
        }
    });
    (function() {
        o.support = {};
        var F = document.documentElement,G = document.createElement("script"),K = document.createElement("div"),J = "script" + (new Date).getTime();
        K.style.display = "none";
        K.innerHTML = '   <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>';
        var H = K.getElementsByTagName("*"),E = K.getElementsByTagName("a")[0];
        if (!H || !H.length || !E) {
            return
        }
        o.support = {leadingWhitespace:K.firstChild.nodeType == 3,tbody:!K.getElementsByTagName("tbody").length,objectAll:!!K.getElementsByTagName("object")[0].getElementsByTagName("*").length,htmlSerialize:!!K.getElementsByTagName("link").length,style:/red/.test(E.getAttribute("style")),hrefNormalized:E.getAttribute("href") === "/a",opacity:E.style.opacity === "0.5",cssFloat:!!E.style.cssFloat,scriptEval:false,noCloneEvent:true,boxModel:null};
        G.type = "text/javascript";
        try {
            G.appendChild(document.createTextNode("window." + J + "=1;"))
        } catch(I) {
        }
        F.insertBefore(G, F.firstChild);
        if (l[J]) {
            o.support.scriptEval = true;
            delete l[J]
        }
        F.removeChild(G);
        if (K.attachEvent && K.fireEvent) {
            K.attachEvent("onclick", function() {
                o.support.noCloneEvent = false;
                K.detachEvent("onclick", arguments.callee)
            });
            K.cloneNode(true).fireEvent("onclick")
        }
        o(function() {
            var L = document.createElement("div");
            L.style.width = L.style.paddingLeft = "1px";
            document.body.appendChild(L);
            o.boxModel = o.support.boxModel = L.offsetWidth === 2;
            document.body.removeChild(L).style.display = "none"
        })
    })();
    var w = o.support.cssFloat ? "cssFloat" : "styleFloat";
    o.props = {"for":"htmlFor","class":"className","float":w,cssFloat:w,styleFloat:w,readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",tabindex:"tabIndex"};
    o.fn.extend({_load:o.fn.load,load:function(G, J, K) {
        if (typeof G !== "string") {
            return this._load(G)
        }
        var I = G.indexOf(" ");
        if (I >= 0) {
            var E = G.slice(I, G.length);
            G = G.slice(0, I)
        }
        var H = "GET";
        if (J) {
            if (o.isFunction(J)) {
                K = J;
                J = null
            } else {
                if (typeof J === "object") {
                    J = o.param(J);
                    H = "POST"
                }
            }
        }
        var F = this;
        o.ajax({url:G,type:H,dataType:"html",data:J,complete:function(M, L) {
            if (L == "success" || L == "notmodified") {
                F.html(E ? o("<div/>").append(M.responseText.replace(/<script(.|\s)*?\/script>/g, "")).find(E) : M.responseText)
            }
            if (K) {
                F.each(K, [M.responseText,L,M])
            }
        }});
        return this
    },serialize:function() {
        return o.param(this.serializeArray())
    },serializeArray:function() {
        return this.map(function() {
            return this.elements ? o.makeArray(this.elements) : this
        }).filter(function() {
            return this.name && !this.disabled && (this.checked || /select|textarea/i.test(this.nodeName) || /text|hidden|password|search/i.test(this.type))
        }).map(function(E, F) {
            var G = o(this).val();
            return G == null ? null : o.isArray(G) ? o.map(G, function(I, H) {
                return{name:F.name,value:I}
            }) : {name:F.name,value:G}
        }).get()
    }});
    o.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","), function(E, F) {
        o.fn[F] = function(G) {
            return this.bind(F, G)
        }
    });
    var r = e();
    o.extend({get:function(E, G, H, F) {
        if (o.isFunction(G)) {
            H = G;
            G = null
        }
        return o.ajax({type:"GET",url:E,data:G,success:H,dataType:F})
    },getScript:function(E, F) {
        return o.get(E, null, F, "script")
    },getJSON:function(E, F, G) {
        return o.get(E, F, G, "json")
    },post:function(E, G, H, F) {
        if (o.isFunction(G)) {
            H = G;
            G = {}
        }
        return o.ajax({type:"POST",url:E,data:G,success:H,dataType:F})
    },ajaxSetup:function(E) {
        o.extend(o.ajaxSettings, E)
    },ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:function() {
        return l.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest()
    },accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},ajax:function(M) {
        M = o.extend(true, M, o.extend(true, {}, o.ajaxSettings, M));
        var W,F = /=\?(&|$)/g,R,V,G = M.type.toUpperCase();
        if (M.data && M.processData && typeof M.data !== "string") {
            M.data = o.param(M.data)
        }
        if (M.dataType == "jsonp") {
            if (G == "GET") {
                if (!M.url.match(F)) {
                    M.url += (M.url.match(/\?/) ? "&" : "?") + (M.jsonp || "callback") + "=?"
                }
            } else {
                if (!M.data || !M.data.match(F)) {
                    M.data = (M.data ? M.data + "&" : "") + (M.jsonp || "callback") + "=?"
                }
            }
            M.dataType = "json"
        }
        if (M.dataType == "json" && (M.data && M.data.match(F) || M.url.match(F))) {
            W = "jsonp" + r++;
            if (M.data) {
                M.data = (M.data + "").replace(F, "=" + W + "$1")
            }
            M.url = M.url.replace(F, "=" + W + "$1");
            M.dataType = "script";
            l[W] = function(X) {
                V = X;
                I();
                L();
                l[W] = g;
                try {
                    delete l[W]
                } catch(Y) {
                }
                if (H) {
                    H.removeChild(T)
                }
            }
        }
        if (M.dataType == "script" && M.cache == null) {
            M.cache = false
        }
        if (M.cache === false && G == "GET") {
            var E = e();
            var U = M.url.replace(/(\?|&)_=.*?(&|$)/, "$1_=" + E + "$2");
            M.url = U + ((U == M.url) ? (M.url.match(/\?/) ? "&" : "?") + "_=" + E : "")
        }
        if (M.data && G == "GET") {
            M.url += (M.url.match(/\?/) ? "&" : "?") + M.data;
            M.data = null
        }
        if (M.global && !o.active++) {
            o.event.trigger("ajaxStart")
        }
        var Q = /^(\w+:)?\/\/([^\/?#]+)/.exec(M.url);
        if (M.dataType == "script" && G == "GET" && Q && (Q[1] && Q[1] != location.protocol || Q[2] != location.host)) {
            var H = document.getElementsByTagName("head")[0];
            var T = document.createElement("script");
            T.src = M.url;
            if (M.scriptCharset) {
                T.charset = M.scriptCharset
            }
            if (!W) {
                var O = false;
                T.onload = T.onreadystatechange = function() {
                    if (!O && (!this.readyState || this.readyState == "loaded" || this.readyState == "complete")) {
                        O = true;
                        I();
                        L();
                        T.onload = T.onreadystatechange = null;
                        H.removeChild(T)
                    }
                }
            }
            H.appendChild(T);
            return g
        }
        var K = false;
        var J = M.xhr();
        if (M.userName) {
            J.open(G, M.url, M.async, M.userName, M.password)
        } else {
            J.open(G, M.url, M.async)
        }
        try {
            if (M.data) {
                J.setRequestHeader("Content-Type", M.contentType)
            }
            if (M.ifModified) {
                J.setRequestHeader("If-Modified-Since", o.lastModified[M.url] || "Thu, 01 Jan 1970 00:00:00 GMT")
            }
            J.setRequestHeader("X-Requested-With", "XMLHttpRequest");
            J.setRequestHeader("Accept", M.dataType && M.accepts[M.dataType] ? M.accepts[M.dataType] + ", */*" : M.accepts._default)
        } catch(S) {
        }
        if (M.beforeSend && M.beforeSend(J, M) === false) {
            if (M.global && !--o.active) {
                o.event.trigger("ajaxStop")
            }
            J.abort();
            return false
        }
        if (M.global) {
            o.event.trigger("ajaxSend", [J,M])
        }
        var N = function(X) {
            if (J != null && J.readyState == 0) {
                if (P) {
                    clearInterval(P);
                    P = null;
                    if (M.global && !--o.active) {
                        o.event.trigger("ajaxStop")
                    }
                }
            } else {
                if (!K && J && (J != null && J.readyState == 4 || X == "timeout")) {
                    K = true;
                    if (P) {
                        clearInterval(P);
                        P = null
                    }
                    R = X == "timeout" ? "timeout" : !o.httpSuccess(J) ? "error" : M.ifModified && o.httpNotModified(J, M.url) ? "notmodified" : "success";
                    if (R == "success") {
                        try {
                            V = o.httpData(J, M.dataType, M)
                        } catch(Z) {
                            R = "parsererror"
                        }
                    }
                    if (R == "success") {
                        var Y;
                        try {
                            Y = J.getResponseHeader("Last-Modified")
                        } catch(Z) {
                        }
                        if (M.ifModified && Y) {
                            o.lastModified[M.url] = Y
                        }
                        if (!W) {
                            I()
                        }
                    } else {
                        o.handleError(M, J, R)
                    }
                    L();
                    if (X) {
                        J.abort()
                    }
                    if (M.async) {
                        J = null
                    }
                }
            }
        };
        if (M.async) {
            var P = setInterval(N, 13);
            if (M.timeout > 0) {
                setTimeout(function() {
                    if (J && !K) {
                        N("timeout")
                    }
                }, M.timeout)
            }
        }
        try {
            J.send(M.data)
        } catch(S) {
            o.handleError(M, J, null, S)
        }
        if (!M.async) {
            N()
        }
        function I() {
            if (M.success) {
                M.success(V, R)
            }
            if (M.global) {
                o.event.trigger("ajaxSuccess", [J,M])
            }
        }

        function L() {
            if (M.complete) {
                M.complete(J, R)
            }
            if (M.global) {
                o.event.trigger("ajaxComplete", [J,M])
            }
            if (M.global && !--o.active) {
                o.event.trigger("ajaxStop")
            }
        }

        return J
    },handleError:function(F, H, E, G) {
        if (F.error) {
            F.error(H, E, G)
        }
        if (F.global) {
            o.event.trigger("ajaxError", [H,F,G])
        }
    },active:0,httpSuccess:function(F) {
        try {
            return !F.status && location.protocol == "file:" || (F.status >= 200 && F.status < 300) || F.status == 304 || F.status == 1223
        } catch(E) {
        }
        return false
    },httpNotModified:function(G, E) {
        try {
            var H = G.getResponseHeader("Last-Modified");
            return G.status == 304 || H == o.lastModified[E]
        } catch(F) {
        }
        return false
    },httpData:function(J, H, G) {
        var F = J.getResponseHeader("content-type"),E = H == "xml" || !H && F && F.indexOf("xml") >= 0,I = E ? J.responseXML : J.responseText;
        if (E && I.documentElement.tagName == "parsererror") {
            throw"parsererror"
        }
        if (G && G.dataFilter) {
            I = G.dataFilter(I, H)
        }
        if (typeof I === "string") {
            if (H == "script") {
                o.globalEval(I)
            }
            if (H == "json") {
                I = l["eval"]("(" + I + ")")
            }
        }
        return I
    },param:function(E) {
        var G = [];

        function H(I, J) {
            G[G.length] = encodeURIComponent(I) + "=" + encodeURIComponent(J)
        }

        if (o.isArray(E) || E.jquery) {
            o.each(E, function() {
                H(this.name, this.value)
            })
        } else {
            for (var F in E) {
                if (o.isArray(E[F])) {
                    o.each(E[F], function() {
                        H(F, this)
                    })
                } else {
                    H(F, o.isFunction(E[F]) ? E[F]() : E[F])
                }
            }
        }
        return G.join("&").replace(/%20/g, "+")
    }});
    var m = {},n,d = [
        ["height","marginTop","marginBottom","paddingTop","paddingBottom"],
        ["width","marginLeft","marginRight","paddingLeft","paddingRight"],
        ["opacity"]
    ];

    function t(F, E) {
        var G = {};
        o.each(d.concat.apply([], d.slice(0, E)), function() {
            G[this] = F
        });
        return G
    }

    o.fn.extend({show:function(J, L) {
        if (J) {
            return this.animate(t("show", 3), J, L)
        } else {
            for (var H = 0,F = this.length; H < F; H++) {
                var E = o.data(this[H], "olddisplay");
                this[H].style.display = E || "";
                if (o.css(this[H], "display") === "none") {
                    var G = this[H].tagName,K;
                    if (m[G]) {
                        K = m[G]
                    } else {
                        var I = o("<" + G + " />").appendTo("body");
                        K = I.css("display");
                        if (K === "none") {
                            K = "block"
                        }
                        I.remove();
                        m[G] = K
                    }
                    o.data(this[H], "olddisplay", K)
                }
            }
            for (var H = 0,F = this.length; H < F; H++) {
                this[H].style.display = o.data(this[H], "olddisplay") || ""
            }
            return this
        }
    },hide:function(H, I) {
        if (H) {
            return this.animate(t("hide", 3), H, I)
        } else {
            for (var G = 0,F = this.length; G < F; G++) {
                var E = o.data(this[G], "olddisplay");
                if (!E && E !== "none") {
                    o.data(this[G], "olddisplay", o.css(this[G], "display"))
                }
            }
            for (var G = 0,F = this.length; G < F; G++) {
                this[G].style.display = "none"
            }
            return this
        }
    },_toggle:o.fn.toggle,toggle:function(G, F) {
        var E = typeof G === "boolean";
        return o.isFunction(G) && o.isFunction(F) ? this._toggle.apply(this, arguments) : G == null || E ? this.each(function() {
            var H = E ? G : o(this).is(":hidden");
            o(this)[H ? "show" : "hide"]()
        }) : this.animate(t("toggle", 3), G, F)
    },fadeTo:function(E, G, F) {
        return this.animate({opacity:G}, E, F)
    },animate:function(I, F, H, G) {
        var E = o.speed(F, H, G);
        return this[E.queue === false ? "each" : "queue"](function() {
            var K = o.extend({}, E),M,L = this.nodeType == 1 && o(this).is(":hidden"),J = this;
            for (M in I) {
                if (I[M] == "hide" && L || I[M] == "show" && !L) {
                    return K.complete.call(this)
                }
                if ((M == "height" || M == "width") && this.style) {
                    K.display = o.css(this, "display");
                    K.overflow = this.style.overflow
                }
            }
            if (K.overflow != null) {
                this.style.overflow = "hidden"
            }
            K.curAnim = o.extend({}, I);
            o.each(I, function(O, S) {
                var R = new o.fx(J, K, O);
                if (/toggle|show|hide/.test(S)) {
                    R[S == "toggle" ? L ? "show" : "hide" : S](I)
                } else {
                    var Q = S.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/),T = R.cur(true) || 0;
                    if (Q) {
                        var N = parseFloat(Q[2]),P = Q[3] || "px";
                        if (P != "px") {
                            J.style[O] = (N || 1) + P;
                            T = ((N || 1) / R.cur(true)) * T;
                            J.style[O] = T + P
                        }
                        if (Q[1]) {
                            N = ((Q[1] == "-=" ? -1 : 1) * N) + T
                        }
                        R.custom(T, N, P)
                    } else {
                        R.custom(T, S, "")
                    }
                }
            });
            return true
        })
    },stop:function(F, E) {
        var G = o.timers;
        if (F) {
            this.queue([])
        }
        this.each(function() {
            for (var H = G.length - 1; H >= 0; H--) {
                if (G[H].elem == this) {
                    if (E) {
                        G[H](true)
                    }
                    G.splice(H, 1)
                }
            }
        });
        if (!E) {
            this.dequeue()
        }
        return this
    }});
    o.each({slideDown:t("show", 1),slideUp:t("hide", 1),slideToggle:t("toggle", 1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}}, function(E, F) {
        o.fn[E] = function(G, H) {
            return this.animate(F, G, H)
        }
    });
    o.extend({speed:function(G, H, F) {
        var E = typeof G === "object" ? G : {complete:F || !F && H || o.isFunction(G) && G,duration:G,easing:F && H || H && !o.isFunction(H) && H};
        E.duration = o.fx.off ? 0 : typeof E.duration === "number" ? E.duration : o.fx.speeds[E.duration] || o.fx.speeds._default;
        E.old = E.complete;
        E.complete = function() {
            if (E.queue !== false) {
                o(this).dequeue()
            }
            if (o.isFunction(E.old)) {
                E.old.call(this)
            }
        };
        return E
    },easing:{linear:function(G, H, E, F) {
        return E + F * G
    },swing:function(G, H, E, F) {
        return((-Math.cos(G * Math.PI) / 2) + 0.5) * F + E
    }},timers:[],fx:function(F, E, G) {
        this.options = E;
        this.elem = F;
        this.prop = G;
        if (!E.orig) {
            E.orig = {}
        }
    }});
    o.fx.prototype = {update:function() {
        if (this.options.step) {
            this.options.step.call(this.elem, this.now, this)
        }
        (o.fx.step[this.prop] || o.fx.step._default)(this);
        if ((this.prop == "height" || this.prop == "width") && this.elem.style) {
            this.elem.style.display = "block"
        }
    },cur:function(F) {
        if (this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null)) {
            return this.elem[this.prop]
        }
        var E = parseFloat(o.css(this.elem, this.prop, F));
        return E && E > -10000 ? E : parseFloat(o.curCSS(this.elem, this.prop)) || 0
    },custom:function(I, H, G) {
        this.startTime = e();
        this.start = I;
        this.end = H;
        this.unit = G || this.unit || "px";
        this.now = this.start;
        this.pos = this.state = 0;
        var E = this;

        function F(J) {
            return E.step(J)
        }

        F.elem = this.elem;
        if (F() && o.timers.push(F) && !n) {
            n = setInterval(function() {
                var K = o.timers;
                for (var J = 0; J < K.length; J++) {
                    if (!K[J]()) {
                        K.splice(J--, 1)
                    }
                }
                if (!K.length) {
                    clearInterval(n);
                    n = g
                }
            }, 13)
        }
    },show:function() {
        this.options.orig[this.prop] = o.attr(this.elem.style, this.prop);
        this.options.show = true;
        this.custom(this.prop == "width" || this.prop == "height" ? 1 : 0, this.cur());
        o(this.elem).show()
    },hide:function() {
        this.options.orig[this.prop] = o.attr(this.elem.style, this.prop);
        this.options.hide = true;
        this.custom(this.cur(), 0)
    },step:function(H) {
        var G = e();
        if (H || G >= this.options.duration + this.startTime) {
            this.now = this.end;
            this.pos = this.state = 1;
            this.update();
            this.options.curAnim[this.prop] = true;
            var E = true;
            for (var F in this.options.curAnim) {
                if (this.options.curAnim[F] !== true) {
                    E = false
                }
            }
            if (E) {
                if (this.options.display != null) {
                    this.elem.style.overflow = this.options.overflow;
                    this.elem.style.display = this.options.display;
                    if (o.css(this.elem, "display") == "none") {
                        this.elem.style.display = "block"
                    }
                }
                if (this.options.hide) {
                    o(this.elem).hide()
                }
                if (this.options.hide || this.options.show) {
                    for (var I in this.options.curAnim) {
                        o.attr(this.elem.style, I, this.options.orig[I])
                    }
                }
                this.options.complete.call(this.elem)
            }
            return false
        } else {
            var J = G - this.startTime;
            this.state = J / this.options.duration;
            this.pos = o.easing[this.options.easing || (o.easing.swing ? "swing" : "linear")](this.state, J, 0, 1, this.options.duration);
            this.now = this.start + ((this.end - this.start) * this.pos);
            this.update()
        }
        return true
    }};
    o.extend(o.fx, {speeds:{slow:600,fast:200,_default:400},step:{opacity:function(E) {
        o.attr(E.elem.style, "opacity", E.now)
    },_default:function(E) {
        if (E.elem.style && E.elem.style[E.prop] != null) {
            E.elem.style[E.prop] = E.now + E.unit
        } else {
            E.elem[E.prop] = E.now
        }
    }}});
    if (document.documentElement.getBoundingClientRect) {
        o.fn.offset = function() {
            if (!this[0]) {
                return{top:0,left:0}
            }
            if (this[0] === this[0].ownerDocument.body) {
                return o.offset.bodyOffset(this[0])
            }
            var G = this[0].getBoundingClientRect(),J = this[0].ownerDocument,F = J.body,E = J.documentElement,L = E.clientTop || F.clientTop || 0,K = E.clientLeft || F.clientLeft || 0,I = G.top + (self.pageYOffset || o.boxModel && E.scrollTop || F.scrollTop) - L,H = G.left + (self.pageXOffset || o.boxModel && E.scrollLeft || F.scrollLeft) - K;
            return{top:I,left:H}
        }
    } else {
        o.fn.offset = function() {
            if (!this[0]) {
                return{top:0,left:0}
            }
            if (this[0] === this[0].ownerDocument.body) {
                return o.offset.bodyOffset(this[0])
            }
            o.offset.initialized || o.offset.initialize();
            var J = this[0],G = J.offsetParent,F = J,O = J.ownerDocument,M,H = O.documentElement,K = O.body,L = O.defaultView,E = L.getComputedStyle(J, null),N = J.offsetTop,I = J.offsetLeft;
            while ((J = J.parentNode) && J !== K && J !== H) {
                M = L.getComputedStyle(J, null);
                N -= J.scrollTop,I -= J.scrollLeft;
                if (J === G) {
                    N += J.offsetTop,I += J.offsetLeft;
                    if (o.offset.doesNotAddBorder && !(o.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i.test(J.tagName))) {
                        N += parseInt(M.borderTopWidth, 10) || 0,I += parseInt(M.borderLeftWidth, 10) || 0
                    }
                    F = G,G = J.offsetParent
                }
                if (o.offset.subtractsBorderForOverflowNotVisible && M.overflow !== "visible") {
                    N += parseInt(M.borderTopWidth, 10) || 0,I += parseInt(M.borderLeftWidth, 10) || 0
                }
                E = M
            }
            if (E.position === "relative" || E.position === "static") {
                N += K.offsetTop,I += K.offsetLeft
            }
            if (E.position === "fixed") {
                N += Math.max(H.scrollTop, K.scrollTop),I += Math.max(H.scrollLeft, K.scrollLeft)
            }
            return{top:N,left:I}
        }
    }
    o.offset = {initialize:function() {
        if (this.initialized) {
            return
        }
        var L = document.body,F = document.createElement("div"),H,G,N,I,M,E,J = L.style.marginTop,K = '<div style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"><div></div></div><table style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;" cellpadding="0" cellspacing="0"><tr><td></td></tr></table>';
        M = {position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"};
        for (E in M) {
            F.style[E] = M[E]
        }
        F.innerHTML = K;
        L.insertBefore(F, L.firstChild);
        H = F.firstChild,G = H.firstChild,I = H.nextSibling.firstChild.firstChild;
        this.doesNotAddBorder = (G.offsetTop !== 5);
        this.doesAddBorderForTableAndCells = (I.offsetTop === 5);
        H.style.overflow = "hidden",H.style.position = "relative";
        this.subtractsBorderForOverflowNotVisible = (G.offsetTop === -5);
        L.style.marginTop = "1px";
        this.doesNotIncludeMarginInBodyOffset = (L.offsetTop === 0);
        L.style.marginTop = J;
        L.removeChild(F);
        this.initialized = true
    },bodyOffset:function(E) {
        o.offset.initialized || o.offset.initialize();
        var G = E.offsetTop,F = E.offsetLeft;
        if (o.offset.doesNotIncludeMarginInBodyOffset) {
            G += parseInt(o.curCSS(E, "marginTop", true), 10) || 0,F += parseInt(o.curCSS(E, "marginLeft", true), 10) || 0
        }
        return{top:G,left:F}
    }};
    o.fn.extend({position:function() {
        var I = 0,H = 0,F;
        if (this[0]) {
            var G = this.offsetParent(),J = this.offset(),E = /^body|html$/i.test(G[0].tagName) ? {top:0,left:0} : G.offset();
            J.top -= j(this, "marginTop");
            J.left -= j(this, "marginLeft");
            E.top += j(G, "borderTopWidth");
            E.left += j(G, "borderLeftWidth");
            F = {top:J.top - E.top,left:J.left - E.left}
        }
        return F
    },offsetParent:function() {
        var E = this[0].offsetParent || document.body;
        while (E && (!/^body|html$/i.test(E.tagName) && o.css(E, "position") == "static")) {
            E = E.offsetParent
        }
        return o(E)
    }});
    o.each(["Left","Top"], function(F, E) {
        var G = "scroll" + E;
        o.fn[G] = function(H) {
            if (!this[0]) {
                return null
            }
            return H !== g ? this.each(function() {
                this == l || this == document ? l.scrollTo(!F ? H : o(l).scrollLeft(), F ? H : o(l).scrollTop()) : this[G] = H
            }) : this[0] == l || this[0] == document ? self[F ? "pageYOffset" : "pageXOffset"] || o.boxModel && document.documentElement[G] || document.body[G] : this[0][G]
        }
    });
    o.each(["Height","Width"], function(I, G) {
        var E = I ? "Left" : "Top",H = I ? "Right" : "Bottom",F = G.toLowerCase();
        o.fn["inner" + G] = function() {
            return this[0] ? o.css(this[0], F, false, "padding") : null
        };
        o.fn["outer" + G] = function(K) {
            return this[0] ? o.css(this[0], F, false, K ? "margin" : "border") : null
        };
        var J = G.toLowerCase();
        o.fn[J] = function(K) {
            return this[0] == l ? document.compatMode == "CSS1Compat" && document.documentElement["client" + G] || document.body["client" + G] : this[0] == document ? Math.max(document.documentElement["client" + G], document.body["scroll" + G], document.documentElement["scroll" + G], document.body["offset" + G], document.documentElement["offset" + G]) : K === g ? (this.length ? o.css(this[0], J) : null) : this.css(J, typeof K === "string" ? K : K + "px")
        }
    })
})();

function isIP(strIP) {
    if (isNull(strIP))  return false;
    var re = /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g;
    if (re.test(strIP)) {
        if (RegExp.$1 < 256 && RegExp.$2 < 256 && RegExp.$3 < 256 && RegExp.$4 < 256)  return true;
    }
    return false;
}
function isNull(str) {
    if (str == "") return true;
    var regu = "^[ ]+$";
    var re = new RegExp(regu);
    return re.test(str);
}
function detectBrower() {
    var sUserAgent = navigator.userAgent;
    var isOpera = sUserAgent.indexOf("Opera") > -1;
    if (isOpera) return "Opera";
    var isKHTML = sUserAgent.indexOf("KHTML") > -1 || sUserAgent.indexOf("Konqueror") > -1 || sUserAgent.indexOf("AppleWebKit") > -1;
    var isSafari = sUserAgent.indexOf("AppleWebKit") > -1 && isKHTML;
    var isKonq = sUserAgent.indexOf("Konqueror") > -1 && isKHTML;
    if (isSafari) return "Safari";
    if (isKonq) return "Konqueror";
    var isIE = sUserAgent.indexOf("compatible") > -1 && sUserAgent.indexOf("MSIE") > -1 && !isOpera;
    if (isIE) return "IE";
    var isMoz = sUserAgent.indexOf("Gecko") > -1 && !isKHTML;
    if (isMoz) return "Mozilla";
    return "None";
}

calendar.js插件代码:

/*
*功能:带有节假日设置的万年历
*作者:www.sucaijiayuan.com
*/
var lunarInfo = new Array(
        0x4bd8, 0x4ae0, 0xa570, 0x54d5, 0xd260, 0xd950, 0x5554, 0x56af, 0x9ad0, 0x55d2,
        0x4ae0, 0xa5b6, 0xa4d0, 0xd250, 0xd255, 0xb54f, 0xd6a0, 0xada2, 0x95b0, 0x4977,
        0x497f, 0xa4b0, 0xb4b5, 0x6a50, 0x6d40, 0xab54, 0x2b6f, 0x9570, 0x52f2, 0x4970,
        0x6566, 0xd4a0, 0xea50, 0x6a95, 0x5adf, 0x2b60, 0x86e3, 0x92ef, 0xc8d7, 0xc95f,
        0xd4a0, 0xd8a6, 0xb55f, 0x56a0, 0xa5b4, 0x25df, 0x92d0, 0xd2b2, 0xa950, 0xb557,
        0x6ca0, 0xb550, 0x5355, 0x4daf, 0xa5b0, 0x4573, 0x52bf, 0xa9a8, 0xe950, 0x6aa0,
        0xaea6, 0xab50, 0x4b60, 0xaae4, 0xa570, 0x5260, 0xf263, 0xd950, 0x5b57, 0x56a0,
        0x96d0, 0x4dd5, 0x4ad0, 0xa4d0, 0xd4d4, 0xd250, 0xd558, 0xb540, 0xb6a0, 0x95a6,
        0x95bf, 0x49b0, 0xa974, 0xa4b0, 0xb27a, 0x6a50, 0x6d40, 0xaf46, 0xab60, 0x9570,
        0x4af5, 0x4970, 0x64b0, 0x74a3, 0xea50, 0x6b58, 0x5ac0, 0xab60, 0x96d5, 0x92e0,
        0xc960, 0xd954, 0xd4a0, 0xda50, 0x7552, 0x56a0, 0xabb7, 0x25d0, 0x92d0, 0xcab5,
        0xa950, 0xb4a0, 0xbaa4, 0xad50, 0x55d9, 0x4ba0, 0xa5b0, 0x5176, 0x52bf, 0xa930,
        0x7954, 0x6aa0, 0xad50, 0x5b52, 0x4b60, 0xa6e6, 0xa4e0, 0xd260, 0xea65, 0xd530,
        0x5aa0, 0x76a3, 0x96d0, 0x4afb, 0x4ad0, 0xa4d0, 0xd0b6, 0xd25f, 0xd520, 0xdd45,
        0xb5a0, 0x56d0, 0x55b2, 0x49b0, 0xa577, 0xa4b0, 0xaa50, 0xb255, 0x6d2f, 0xada0,
        0x4b63, 0x937f, 0x49f8, 0x4970, 0x64b0, 0x68a6, 0xea5f, 0x6b20, 0xa6c4, 0xaaef,
        0x92e0, 0xd2e3, 0xc960, 0xd557, 0xd4a0, 0xda50, 0x5d55, 0x56a0, 0xa6d0, 0x55d4,
        0x52d0, 0xa9b8, 0xa950, 0xb4a0, 0xb6a6, 0xad50, 0x55a0, 0xaba4, 0xa5b0, 0x52b0,
        0xb273, 0x6930, 0x7337, 0x6aa0, 0xad50, 0x4b55, 0x4b6f, 0xa570, 0x54e4, 0xd260,
        0xe968, 0xd520, 0xdaa0, 0x6aa6, 0x56df, 0x4ae0, 0xa9d4, 0xa4d0, 0xd150, 0xf252,
        0xd520);

var solarMonth = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
var Gan = new Array("甲", "乙", "丙", "丁", "戊", "己", "庚", "辛", "壬", "癸");
var Zhi = new Array("子", "丑", "寅", "卯", "辰", "巳", "午", "未", "申", "酉", "戌", "亥");
var Animals = new Array("鼠", "牛", "虎", "兔", "龙", "蛇", "马", "羊", "猴", "鸡", "狗", "猪");
var solarTerm = new Array("小寒", "大寒", "立春", "雨水", "惊蛰", "春分", "清明", "谷雨", "立夏", "小满", "芒种", "夏至", "小暑", "大暑", "立秋", "处暑", "白露", "秋分", "寒露", "霜降", "立冬", "小雪", "大雪", "冬至")
var sTermInfo = new Array(0, 21208, 42467, 63836, 85337, 107014, 128867, 150921, 173149, 195551, 218072, 240693, 263343, 285989, 308563, 331033, 353350, 375494, 397447, 419210, 440795, 462224, 483532, 504758)
var nStr1 = new Array('日', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十')
var nStr2 = new Array('初', '十', '廿', '卅', ' ')

var jcName0 = new Array('建', '除', '满', '平', '定', '执', '破', '危', '成', '收', '开', '闭');
var jcName1 = new Array('闭', '建', '除', '满', '平', '定', '执', '破', '危', '成', '收', '开');
var jcName2 = new Array('开', '闭', '建', '除', '满', '平', '定', '执', '破', '危', '成', '收');
var jcName3 = new Array('收', '开', '闭', '建', '除', '满', '平', '定', '执', '破', '危', '成');
var jcName4 = new Array('成', '收', '开', '闭', '建', '除', '满', '平', '定', '执', '破', '危');
var jcName5 = new Array('危', '成', '收', '开', '闭', '建', '除', '满', '平', '定', '执', '破');
var jcName6 = new Array('破', '危', '成', '收', '开', '闭', '建', '除', '满', '平', '定', '执');
var jcName7 = new Array('执', '破', '危', '成', '收', '开', '闭', '建', '除', '满', '平', '定');
var jcName8 = new Array('定', '执', '破', '危', '成', '收', '开', '闭', '建', '除', '满', '平');
var jcName9 = new Array('平', '定', '执', '破', '危', '成', '收', '开', '闭', '建', '除', '满');
var jcName10 = new Array('满', '平', '定', '执', '破', '危', '成', '收', '开', '闭', '建', '除');
var jcName11 = new Array('除', '满', '平', '定', '执', '破', '危', '成', '收', '开', '闭', '建');

function jcr(d) {
    var jcrjx;
    if (d == '建') jcrjx = '<span style="vertical-align:middle; margin:1px; font-size:12px"><img src="images/yi.gif"/></span> 出行.上任.会友.上书.见工<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 动土.开仓.嫁娶.纳采';
    if (d == '除') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 除服.疗病.出行.拆卸.入宅<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 求官.上任.开张.搬家.探病';
    if (d == '满') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 祈福.祭祀.结亲.开市.交易<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 服药.求医.栽种.动土.迁移';
    if (d == '平') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 祭祀.修填.涂泥.余事勿取<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 移徙.入宅.嫁娶.开市.安葬';
    if (d == '定') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 易.立券.会友.签约.纳畜<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 种植.置业.卖田.掘井.造船';
    if (d == '执') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 祈福.祭祀.求子.结婚.立约<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 开市.交易.搬家.远行';
    if (d == '破') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 求医.赴考.祭祀.余事勿取<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 动土.出行.移徙.开市.修造';
    if (d == '危') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 经营.交易.求官.纳畜.动土<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 登高.行船.安床.入宅.博彩';
    if (d == '成') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 祈福.入学.开市.求医.成服<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 词讼.安门.移徙';
    if (d == '收') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 祭祀.求财.签约.嫁娶.订盟<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 开市.安床.安葬.入宅.破土';
    if (d == '开') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 疗病.结婚.交易.入仓.求职<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 安葬.动土.针灸';
    if (d == '闭') jcrjx = '<span style="vertical-align:middle; margin:1px;"><img src="images/yi.gif"/></span> 祭祀.交易.收财.安葬<br><br><span style="vertical-align:middle; margin:1px;"><img src="images/ji.gif"/></span> 宴会.安床.出行.嫁娶.移徙';
    return(jcrjx);
}

//国历节日  *表示放假日
var sFtv = new Array(
        "0101*元旦",
        "0106  中国13亿人口日",
        "0110  中国110宣传日",

        "0202  世界湿地日",
        "0204  世界抗癌症日",
        "0210  世界气象日",
        "0214  情人节",
        "0221  国际母语日",
        "0207  国际声援南非日",

        "0303  全国爱耳日",
        "0308  妇女节",
        "0312  植树节 孙中山逝世纪念日",
        "0315  消费者权益保护日",
        "0321  世界森林日",
        "0322  世界水日",
        "0323  世界气象日",
        "0324  世界防治结核病日",

        "0401  愚人节",
        "0407  世界卫生日",
        "0422  世界地球日",

        "0501*国际劳动节",
        "0504  中国青年节",
        "0505  全国碘缺乏病日",
        "0508  世界红十字日",
        "0512  国际护士节",
        "0515  国际家庭日",
        "0517  世界电信日",
        "0518  国际博物馆日",
        "0519  中国汶川地震哀悼日 全国助残日",
        "0520  全国学生营养日",
        "0522  国际生物多样性日",
        "0523  国际牛奶日",
        "0531  世界无烟日",

        "0601  国际儿童节",
        "0605  世界环境日",
        "0606  全国爱眼日",
        "0617  防治荒漠化和干旱日",
        "0623  国际奥林匹克日",
        "0625  全国土地日",
        "0626  国际反毒品日",

        "0701  建党节 香港回归纪念日",
        "0707  抗日战争纪念日",
        "0711  世界人口日",

        "0801  八一建军节",
        "0815  日本正式宣布无条件投降日",

        "0908  国际扫盲日",
        "0909  毛泽东逝世纪念日",
        "0910  教师节",
        "0916  国际臭氧层保护日",
        "0917  国际和平日",
        "0918  九·一八事变纪念日",
        "0920  国际爱牙日",
        "0927  世界旅游日",
        "0928  孔子诞辰",

        "1001*国庆节 国际音乐节 国际老人节",
        "1002  国际减轻自然灾害日",
        "1004  世界动物日",
        "1007  国际住房日",
        "1008  世界视觉日 全国高血压日",
        "1009  世界邮政日",
        "1010  辛亥革命纪念日 世界精神卫生日",
        "1015  国际盲人节",
        "1016  世界粮食节",
        "1017  世界消除贫困日",
        "1022  世界传统医药日",
        "1024  联合国日",
        "1025  人类天花绝迹日",
        "1026  足球诞生日",
        "1031  万圣节",

        "1107  十月社会主义革命纪念日",
        "1108  中国记者日",
        "1109  消防宣传日",
        "1110  世界青年节",
        "1112  孙中山诞辰",
        "1114  世界糖尿病日",
        "1117  国际大学生节",

        "1201  世界艾滋病日",
        "1203  世界残疾人日",
        "1209  世界足球日",
        "1210  世界人权日",
        "1212  西安事变纪念日",
        "1213  南京大屠杀",
        "1220  澳门回归纪念日",
        "1221  国际篮球日",
        "1224  平安夜",
        "1225  圣诞节 世界强化免疫日",
        "1226  毛泽东诞辰")
//农历节日  *表示放假日
var lFtv = new Array(
        "0101*春节",
        "0102*大年初二",
        "0103*大年初三",
        "0104*大年初四",
        "0105*大年初五",
        "0106*大年初六",
        "0107*大年初七",
        "0105  路神生日",
        "0115  元宵节",
        "0202  龙抬头",
        "0219  观世音圣诞",
        "0404  寒食节",
        "0408  佛诞节 ",
        "0505*端午节",
        "0606  天贶节 姑姑节",
        "0624  彝族火把节",
        "0707  七夕情人节",
        "0714  鬼节(南方)",
        "0715  盂兰节",
        "0730  地藏节",
        "0815*中秋节",
        "0909  重阳节",
        "1001  祭祖节",
        "1117  阿弥陀佛圣诞",
        "1208  腊八节 释迦如来成道日",
        "1223  过小年",
        "1229*腊月二十九",
        "0100*除夕");
//某月的第几个星期几; 5,6,7,8 表示到数第 1,2,3,4 个星期几
var wFtv = new Array(
        "0110  黑人节",
        "0150  世界麻风日",
        "0121  日本成人节",
        "0520  母亲节",
        "0530  全国助残日",
        "0630  父亲节",
        "0716  合作节",
        "0730  被奴役国家周",
        "0932  国际和平日",
        "0940  国际聋人节 世界儿童日",
        "1011  国际住房日",
        "1144  感恩节")

/*****************************************************************************
 日期计算
 *****************************************************************************/

//====================================== 返回农历 y年的总天数
function lYearDays(y) {
    var i, sum = 348;
    for (i = 0x8000; i > 0x8; i >>= 1) sum += (lunarInfo[y - 1900] & i) ? 1 : 0;
    return(sum + leapDays(y));
}

//====================================== 返回农历 y年闰月的天数
function leapDays(y) {
    if (leapMonth(y)) return( (lunarInfo[y - 1899] & 0xf) == 0xf ? 30 : 29);
    else return(0);
}

//====================================== 返回农历 y年闰哪个月 1-12 , 没闰返回 0
function leapMonth(y) {
    var lm = lunarInfo[y - 1900] & 0xf;
    return(lm == 0xf ? 0 : lm);
}

//====================================== 返回农历 y年m月的总天数
function monthDays(y, m) {
    return( (lunarInfo[y - 1900] & (0x10000 >> m)) ? 30 : 29 );
}

//====================================== 算出农历, 传入日期控件, 返回农历日期控件
//                                       该控件属性有 .year .month .day .isLeap
function Lunar(objDate) {

    var i, leap = 0, temp = 0;
    var offset = (Date.UTC(objDate.getFullYear(), objDate.getMonth(), objDate.getDate()) - Date.UTC(1900, 0, 31)) / 86400000;

    for (i = 1900; i < 2100 && offset > 0; i++) {
        temp = lYearDays(i);
        offset -= temp;
    }

    if (offset < 0) {
        offset += temp;
        i--;
    }

    this.year = i;

    leap = leapMonth(i); //闰哪个月
    this.isLeap = false;

    for (i = 1; i < 13 && offset > 0; i++) {
        //闰月
        if (leap > 0 && i == (leap + 1) && this.isLeap == false) {
            --i;
            this.isLeap = true;
            temp = leapDays(this.year);
        }
        else {
            temp = monthDays(this.year, i);
        }

        //解除闰月
        if (this.isLeap == true && i == (leap + 1)) this.isLeap = false;

        offset -= temp;
    }

    if (offset == 0 && leap > 0 && i == leap + 1)
        if (this.isLeap) {
            this.isLeap = false;
        }
        else {
            this.isLeap = true;
            --i;
        }

    if (offset < 0) {
        offset += temp;
        --i;
    }

    this.month = i;
    this.day = offset + 1;
}

//==============================返回公历 y年某m+1月的天数
function solarDays(y, m) {
    if (m == 1)
        return(((y % 4 == 0) && (y % 100 != 0) || (y % 400 == 0)) ? 29 : 28);
    else
        return(solarMonth[m]);
}
//============================== 传入 offset 返回干支, 0=甲子
function cyclical(num) {
    return(Gan[num % 10] + Zhi[num % 12]);
}

//============================== 阴历属性
function calElement(sYear, sMonth, sDay, week, lYear, lMonth, lDay, isLeap, cYear, cMonth, cDay) {

    this.isToday = false;
    //瓣句
    this.sYear = sYear;   //公元年4位数字
    this.sMonth = sMonth;  //公元月数字
    this.sDay = sDay;    //公元日数字
    this.week = week;    //星期, 1个中文
    //农历
    this.lYear = lYear;   //公元年4位数字
    this.lMonth = lMonth;  //农历月数字
    this.lDay = lDay;    //农历日数字
    this.isLeap = isLeap;  //是否为农历闰月?
    //八字
    this.cYear = cYear;   //年柱, 2个中文
    this.cMonth = cMonth;  //月柱, 2个中文
    this.cDay = cDay;    //日柱, 2个中文

    this.color = '';

    this.lunarFestival = ''; //农历节日
    this.solarFestival = ''; //公历节日
    this.solarTerms = ''; //节气
}

//===== 某年的第n个节气为几日(从0小寒起算)
function sTerm(y, n) {
    var offDate = new Date(( 31556925974.7 * (y - 1900) + sTermInfo[n] * 60000  ) + Date.UTC(1900, 0, 6, 2, 5));
    return(offDate.getUTCDate());
}

//============================== 返回阴历 (y年,m+1月)
function cyclical6(num, num2) {
    if (num == 0) return(jcName0[num2]);
    if (num == 1) return(jcName1[num2]);
    if (num == 2) return(jcName2[num2]);
    if (num == 3) return(jcName3[num2]);
    if (num == 4) return(jcName4[num2]);
    if (num == 5) return(jcName5[num2]);
    if (num == 6) return(jcName6[num2]);
    if (num == 7) return(jcName7[num2]);
    if (num == 8) return(jcName8[num2]);
    if (num == 9) return(jcName9[num2]);
    if (num == 10) return(jcName10[num2]);
    if (num == 11) return(jcName11[num2]);
}
function CalConv2(yy, mm, dd, y, d, m, dt, nm, nd) {
    var dy = d + '' + dd
    if ((yy == 0 && dd == 6) || (yy == 6 && dd == 0) || (yy == 1 && dd == 7) || (yy == 7 && dd == 1) || (yy == 2 && dd == 8) || (yy == 8 && dd == 2) || (yy == 3 && dd == 9) || (yy == 9 && dd == 3) || (yy == 4 && dd == 10) || (yy == 10 && dd == 4) || (yy == 5 && dd == 11) || (yy == 11 && dd == 5)) {
        return '<FONT color=#0000A0>日值岁破 大事不宜</font>';
    }
    else if ((mm == 0 && dd == 6) || (mm == 6 && dd == 0) || (mm == 1 && dd == 7) || (mm == 7 && dd == 1) || (mm == 2 && dd == 8) || (mm == 8 && dd == 2) || (mm == 3 && dd == 9) || (mm == 9 && dd == 3) || (mm == 4 && dd == 10) || (mm == 10 && dd == 4) || (mm == 5 && dd == 11) || (mm == 11 && dd == 5)) {
        return '<FONT color=#0000A0>日值月破 大事不宜</font>';
    }
    else if ((y == 0 && dy == '911') || (y == 1 && dy == '55') || (y == 2 && dy == '111') || (y == 3 && dy == '75') || (y == 4 && dy == '311') || (y == 5 && dy == '95') || (y == 6 && dy == '511') || (y == 7 && dy == '15') || (y == 8 && dy == '711') || (y == 9 && dy == '35')) {
        return '<FONT color=#0000A0>日值上朔 大事不宜</font>';
    }
    else if ((m == 1 && dt == 13) || (m == 2 && dt == 11) || (m == 3 && dt == 9) || (m == 4 && dt == 7) || (m == 5 && dt == 5) || (m == 6 && dt == 3) || (m == 7 && dt == 1) || (m == 7 && dt == 29) || (m == 8 && dt == 27) || (m == 9 && dt == 25) || (m == 10 && dt == 23) || (m == 11 && dt == 21) || (m == 12 && dt == 19)) {
        return '<FONT color=#0000A0>日值杨公十三忌 大事不宜</font>';
    }
    else {
        return 0;
    }
}


function calendar(y, m) {

    var sDObj, lDObj, lY, lM, lD = 1, lL, lX = 0, tmp1, tmp2, lM2,lY2,lD2,tmp3,dayglus,bsg,xs,xs1,fs,fs1,cs,cs1
    var cY, cM, cD; //年柱,月柱,日柱
    var lDPOS = new Array(3);
    var n = 0;
    var firstLM = 0;

    sDObj = new Date(y, m, 1, 0, 0, 0, 0);    //当月一日日期

    this.length = solarDays(y, m);    //公历当月天数
    this.firstWeek = sDObj.getDay();    //公历当月1日星期几

    ////////年柱 1900年立春后为庚子年(60进制36)
    if (m < 2) cY = cyclical(y - 1900 + 36 - 1);
    else cY = cyclical(y - 1900 + 36);
    var term2 = sTerm(y, 2); //立春日期

    ////////月柱 1900年1月小寒以前为 丙子月(60进制12)
    var firstNode = sTerm(y, m * 2) //返回当月「节」为几日开始
    cM = cyclical((y - 1900) * 12 + m + 12);

    lM2 = (y - 1900) * 12 + m + 12;
    //当月一日与 1900/1/1 相差天数
    //1900/1/1与 1970/1/1 相差25567日, 1900/1/1 日柱为甲戌日(60进制10)
    var dayCyclical = Date.UTC(y, m, 1, 0, 0, 0, 0) / 86400000 + 25567 + 10;

    for (var i = 0; i < this.length; i++) {

        if (lD > lX) {
            sDObj = new Date(y, m, i + 1);    //当月一日日期
            lDObj = new Lunar(sDObj);     //农历
            lY = lDObj.year;           //农历年
            lM = lDObj.month;          //农历月
            lD = lDObj.day;            //农历日
            lL = lDObj.isLeap;         //农历是否闰月
            lX = lL ? leapDays(lY) : monthDays(lY, lM); //农历当月最后一天

            if (n == 0) firstLM = lM;
            lDPOS[n++] = i - lD + 1;
        }

        //依节气调整二月分的年柱, 以立春为界
        if (m == 1 && (i + 1) == term2) {
            cY = cyclical(y - 1900 + 36);
            lY2 = (y - 1900 + 36);
        }
        //依节气月柱, 以「节」为界
        if ((i + 1) == firstNode) {
            cM = cyclical((y - 1900) * 12 + m + 13);
            lM2 = (y - 1900) * 12 + m + 13;
        }
        //日柱
        cD = cyclical(dayCyclical + i);
        lD2 = (dayCyclical + i);

        this[i] = new calElement(y, m + 1, i + 1, nStr1[(i + this.firstWeek) % 7],
                lY, lM, lD++, lL,
                cY, cM, cD);


        this[i].sgz5 = CalConv2(lY2 % 12, lM2 % 12, (lD2) % 12, lY2 % 10, (lD2) % 10, lM, lD - 1, m + 1, cs1);
        this[i].sgz3 = cyclical6(lM2 % 12, (lD2) % 12);


    }

    //节气
    tmp1 = sTerm(y, m * 2) - 1;
    tmp2 = sTerm(y, m * 2 + 1) - 1;
    this[tmp1].solarTerms = solarTerm[m * 2];
    this[tmp2].solarTerms = solarTerm[m * 2 + 1];
    if (m == 3) this[tmp1].color = 'red'; //清明颜色

    //国历节日
    for (i  in  sFtv)
        if (sFtv[i].match(/^(\d{2})(\d{2})([\s\*])(.+)$/))
            if (Number(RegExp.$1) == (m + 1)) {
                this[Number(RegExp.$2) - 1].solarFestival += RegExp.$4 + '  '
                if (RegExp.$3 == '*')  this[Number(RegExp.$2) - 1].color = 'red'
            }


    //农历节日
    for (i  in  lFtv)
        if (lFtv[i].match(/^(\d{2})(.{2})([\s\*])(.+)$/)) {
            tmp1 = Number(RegExp.$1) - firstLM
            if (tmp1 == -11)  tmp1 = 1
            if (tmp1 >= 0 && tmp1 < n) {
                tmp2 = lDPOS[tmp1] + Number(RegExp.$2) - 1
                if (tmp2 >= 0 && tmp2 < this.length) {
                    this[tmp2].lunarFestival += RegExp.$4 + '  '
                    if (RegExp.$3 == '*')  this[tmp2].color = 'red'
                }
            }
        }

    //复活节只出现在3或4月
    if (m == 2 || m == 3) {
        var estDay = new easter(y);
        if (m == estDay.m)
            this[estDay.d - 1].solarFestival = this[estDay.d - 1].solarFestival + ' 复活节(Easter Sunday)';
    }


    //黑色星期五
    if ((this.firstWeek + 12) % 7 == 5)
        this[12].solarFestival += '黑色星期五';

    //今日
    if (y == tY && m == tM) this[tD - 1].isToday = true;
}

//======================================= 返回该年的复活节(春分后第一次满月周后的第一主日)
function easter(y) {

    var term2 = sTerm(y, 5); //取得春分日期
    var dayTerm2 = new Date(Date.UTC(y, 2, term2, 0, 0, 0, 0)); //取得春分的公历日期控件(春分一定出现在3月)
    var lDayTerm2 = new Lunar(dayTerm2); //取得取得春分农历

    if (lDayTerm2.day < 15) //取得下个月圆的相差天数
        var lMlen = 15 - lDayTerm2.day;
    else
        var lMlen = (lDayTerm2.isLeap ? leapDays(y) : monthDays(y, lDayTerm2.month)) - lDayTerm2.day + 15;

    //一天等于 1000*60*60*24 = 86400000 毫秒
    var l15 = new Date(dayTerm2.getTime() + 86400000 * lMlen); //求出第一次月圆为公历几日
    var dayEaster = new Date(l15.getTime() + 86400000 * ( 7 - l15.getUTCDay() )); //求出下个周日

    this.m = dayEaster.getUTCMonth();
    this.d = dayEaster.getUTCDate();

}
//======================  中文日期
function cDay(d) {
    var s;

    switch (d) {
        case  10:
            s = '初十';  break;
        case  20:
            s = '二十';  break;
            break;
        case  30:
            s = '三十';  break;
            break;
        default  :
            s = nStr2[Math.floor(d / 10)];
            s += nStr1[d % 10];
    }
    return(s);
}
var cld;
//存放节假日
var hDays = [];
function drawCld(SY, SM) {

    var i,sD,s,size;
    cld = new calendar(SY, SM);


    $("#GZ")[0].innerHTML = '  农历' + cyclical(SY - 1900 + 36) + '年 【' + Animals[(SY - 4) % 12] + '年】';

    for (i = 0; i < 42; i++) {
        sObj = $("#SD" + i)[0];

        lObj = $("#LD" + i)[0];

        sObj.className = '';

        sD = i - cld.firstWeek;

        if (sD > -1 && sD < cld.length) {  //日期内
            sObj.innerHTML = sD + 1;
            //wly 注册点击事件
						$("#GD" + i).unbind('click').click(function(){mOck(this,sD + 1);});
						var nowDays = SY+''+addZ((SM+1))+addZ((sD+1));
						var hstr = hDays.join();
						if(hstr.indexOf(nowDays)>-1){
							 $("#GD" + i).addClass("selday");
							}
            if (cld[sD].isToday)  $("#GD" + i).addClass("jinri");  //今日颜色

            sObj.style.color = cld[sD].color;  //国定假日颜色

            if (cld[sD].lDay == 1)  //显示农历月
                lObj.innerHTML = '<b>' + (cld[sD].isLeap ? '闰' : '') + cld[sD].lMonth + '月' + (monthDays(cld[sD].lYear, cld[sD].lMonth) == 29 ? '小' : '大') + '</b>';
            else  //显示农历日
                lObj.innerHTML = cDay(cld[sD].lDay);

            s = cld[sD].lunarFestival;
            if (s.length > 0) {  //农历节日
                if (s.length > 8)  s = s.substr(0, 5) + '...';
                s = s.fontcolor('red');
            }
            else {  //国历节日
                s = cld[sD].solarFestival;
                if (s.length > 0) {
                    if (s.length > 8)  s = s.substr(0, 5) + '...';
                    s = (s == '黑色星期五') ? s.fontcolor('black') : s.fontcolor('#0066FF');
                }
                else {  //廿四节气
                    s = cld[sD].solarTerms;
                    if (s.length > 0)  s = s.fontcolor('limegreen');
                }
            }
            if (cld[sD].solarTerms == '清明') s = '清明节'.fontcolor('red');
            if (cld[sD].solarTerms == '芒种') s = '芒种'.fontcolor('red');
            if (cld[sD].solarTerms == '夏至') s = '夏至'.fontcolor('red');
            if (cld[sD].solarTerms == '冬至') s = '冬至'.fontcolor('red');

            if (s.length > 0)  lObj.innerHTML = s;

        }
        else {  //非日期
            $("#GD" + i).addClass("unover");

        }
    }
}


/*清除数据*/
function clear() {
    for (i = 0; i < 42; i++) {
        sObj = $("#SD" + i)[0];
        sObj.innerHTML = '';
        lObj = $("#LD" + i)[0];
        lObj.innerHTML = '';
        $("#GD" + i).removeClass("unover");
        $("#GD" + i).removeClass("jinri");
        $("#GD" + i).removeClass("selday");

    }

}


var Today = new Date();
var tY = Today.getFullYear();
var tM = Today.getMonth();

var tD = Today.getDate();
//////////////////////////////////////////////////////////////////////////////

var width = "130";
var offsetX = 2;
var offsetY = 18;

var x = 0;
var y = 0;
var snow = 0;
var sw = 0;
var cnt = 0;
var dStyle;


// 将农历iLunarMonth月格式化成农历表示的字符串
function FormatLunarMonth(iLunarMonth) {
    var szText = new String("正二三四五六七八九十");
    var strMonth;
    if (iLunarMonth <= 10) {
        strMonth = szText.substr(iLunarMonth - 1, 1);
    }
    else if (iLunarMonth == 11) strMonth = "十一";
    else strMonth = "十二";
    return strMonth + "月";
}
// 将农历iLunarDay日格式化成农历表示的字符串
function FormatLunarDay(iLunarDay) {
    var szText1 = new String("初十廿三");
    var szText2 = new String("一二三四五六七八九十");
    var strDay;
    if ((iLunarDay != 20) && (iLunarDay != 30)) {
        strDay = szText1.substr((iLunarDay - 1) / 10, 1) + szText2.substr((iLunarDay - 1) % 10, 1);
    }
    else if (iLunarDay != 20) {
        strDay = szText1.substr(iLunarDay / 10, 1) + "十";
    }
    else {
        strDay = "二十";
    }
    return strDay;
}
//显示详细日期资料
function mOvr(thisObj, v) {
    var s,festival,jy;

    sObj = $("#SD" + v);
    var d = sObj.html() - 1;

    if (sObj.html() != '') {
        if (cld[d].sgz5 != 0) {

            jy = cld[d].sgz5;
        } else {
            jy = jcr(cld[d].sgz3);

        }

        var arr = [];
        if (cld[d].solarTerms == '' && cld[d].solarFestival == '' && cld[d].lunarFestival == '')

            arr.push('<div id="teshu"></div>');
        else
        arr.push('<div id="teshu"><FONT  COLOR="#ff0000"  STYLE="font-size:12px;">' + cld[d].solarTerms + ' ' + cld[d].solarFestival + ' ' + cld[d].lunarFestival + '</FONT></div>');

        arr.push('<div style="width:65px; height:30px; color:#666666; float:left; font-size:60px; text-align:center;">' + cld[d].sDay + '</div>');
        arr.push('<font color="black" style="font-weight:bold;font-size:13px;">    ' + cld[d].sYear + '年' + cld[d].sMonth + '月' + cld[d].sDay + '日</font>');
        arr.push('<font style="font-size:12px;line-height:28px"><b>' + '星期' + cld[d].week + '</b></font><br>');
        arr.push('<font style="font-size:12px;color:#000000;" >农历' + (cld[d].isLeap ? '闰' : ' ') + FormatLunarMonth(cld[d].lMonth) + FormatLunarDay(cld[d].lDay) + '</font>');
        arr.push('<font style="font-size:12px">  ' + cld[d].cYear + '年 ' + cld[d].cMonth + '月 ' + cld[d].cDay + '日</font><br><br>');
        arr.push('<div style="width:95%; height:70px; margin-top:30px; padding-top:8px; border-top:1px solid #CCCCCC; margin-left:auto; margin-right:auto;">' + jy + '</div>');

        //thisObj.style.backgroundColor = '#fbfbad';
        var d = $(thisObj);
        var pos = d.offset();
        var t = pos.top + d.height() + 5; // 弹出框的上边位置
        var l = pos.left + d.width() - 150;  // 弹出框的左边位置


        <!--

        var winWidth = 0;

        var winHeight = 0;

        function findDimensions() {

            // 获取窗口宽度

            if (window.innerWidth)

                winWidth = window.innerWidth;

            else if ((document.body) && (document.body.clientWidth))

                winWidth = document.body.clientWidth;

            // 获取窗口高度

            if (window.innerHeight)

                winHeight = window.innerHeight;

            else if ((document.body) && (document.body.clientHeight))

                winHeight = document.body.clientHeight;

            // 通过深入 Document 内部对 body 进行检测,获取窗口大小

            if (document.documentElement && document.documentElement.clientHeight && document.documentElement.clientWidth) {

                winHeight = document.documentElement.clientHeight;

                winWidth = document.documentElement.clientWidth;

            }

            // 结果输出至两个文本框


        }

        findDimensions();

        // 调用函数,获取数值

        window.onresize = findDimensions;

        //-->
        /* alert("h:"+winHeight+"w:"+winWidth)*/

        if (winHeight - pos.top < 230) {
            t = pos.top + d.height() - 180;
            l = pos.left + d.width() + 5;

        }

        if (winWidth - pos.left < 350) {

            t = pos.top + d.height() - 180;
            l = pos.left + d.width() - 360;

            if (pos.top < 216) {
                t = pos.top + d.height() - 100;
                l = pos.left + d.width() - 360;
            }
        }


        $("#details").addClass("pop");
        $("#details").css({ "top": t, "left": l }).show();
        $("#details").html(arr.join(""));


        if (snow == 0) {

            snow = 1;

        }


    }
}
//------王立岩------start------
//日期点击函数
function mOck(thisObj, v){
	var onoff = thisObj.attributes["on"].value;
	var dayContainer = thisObj.getElementsByTagName("font")[0];
	//记录是否为周末
	var lx='0';
	var nian = $('#nian').text();
	var yue = $('#yue').text();
	var dayJson = "";
	var day = dayContainer.innerHTML;
	var dayColor = dayContainer.attributes["color"];
	var dayF = nian+'/'+addZ(yue)+'/'+addZ(day);
	if(dayColor&&dayColor.value=='red'&&getH(dayF)){
		 lx = '1';
	}
	dayJson = '{holiday:'+nian+addZ(yue)+addZ(day)+',lx:'+lx+'}';
	if(onoff == '0'){
		//thisObj.style.background='#FBBB67';
		thisObj.setAttribute("class", "selday"); 
		thisObj.attributes["on"].value='1';
		hDays.push(dayJson);
   }else{
   	//thisObj.style.background='';
   	thisObj.setAttribute("class", "");
   	thisObj.attributes["on"].value='0';
   	delArry(hDays,dayJson);
	}
}
//删除数组指定元素
function delArry(arr,obj){
	for (var i = arr.length - 1; i > -1; i--) { 
        if (arr[i] == obj) { 
            arr.splice(i, 1);//参数(删除的元素下标,从该下标起删除几个元素)
       }
      }
}
//去重数组
function delMoreArry(){
	var newArray = [],
      temp = {};
  for(var i = 0; i < this.length; i++){
           temp[typeof(this[i])+this[i]] = this[i];
      }
  for(var j in temp){
           newArray.push(temp[j]);
     }
 return newArray;
}
function addZ(obj){
	 return obj<10?'0'+obj:obj;
	}
function getH(obj){
	 var d = new Date(Date.parse(obj));
	 var c=d.getDay();
	 if(c==0||c==6){
	 	 return true;
	 	}else{
	 	return false;	
	 	}
	 //switch(c){    case 0:        a='星期日';        break;    case 1:        a='星期一';        break;    case 2:        a='星期二';        break;    case 3:        a='星期三';    case 4:        a='星期四';    case 5:        a='星期五';    case 6:        a='星期六';}
	}
//------王立岩------end---
//清除详细日期资料
function mOut(thisObj) {

 //   thisObj.style.backgroundColor = '';
    if (cnt >= 1) {
        sw = 0
    }
    if (sw == 0) {
        snow = 0;
        document.getElementById("details").style.display = 'none';
    }
    else  cnt++;
}


/*初始化日期*/

$(function() {
    initRiliIndex();
    clear();
    $("#nian").html(tY);
    $("#yue").html(tM + 1);
    drawCld(tY, tM);

    /*年份递减*/
    $("#nianjian").click(function() {
        dateSelection.goPrevYear();

    });
    /*年份递加*/
    $("#nianjia").click(function() {
        dateSelection.goNextYear();

    });

    /*月份递减*/
    $("#yuejian").click(function() {

        dateSelection.goPrevMonth();
    });

    /*月份递加*/
    $("#yuejia").click(function() {
        dateSelection.goNextMonth();

    });


});


var global = {
    currYear : -1, // 当前年
    currMonth : -1, // 当前月,0-11
    currDate : null, // 当前点选的日期
    uid : null,
    username : null,
    email : null,
    single : false
    // 是否为独立页调用,如果是值为日历id,使用时请注意对0的判断,使用 single !== false 或者 single === false
};

var dateSelection = {
    currYear : -1,
    currMonth : -1,

    minYear : 1901,
    maxYear : 2100,

    beginYear : 0,
    endYear : 0,

    tmpYear : -1,
    tmpMonth : -1,

    init : function(year, month) {
        if (typeof year == 'undefined' || typeof month == 'undefined') {
            year = global.currYear;
            month = global.currMonth;
        }
        this.setYear(year);
        this.setMonth(month);
        this.showYearContent();
        this.showMonthContent();
    },
    show : function() {
        document.getElementById('dateSelectionDiv').style.display = 'block';
    },
    hide : function() {
        this.rollback();
        document.getElementById('dateSelectionDiv').style.display = 'none';
    },
    today : function() {
        var today = new Date();
        var year = today.getFullYear();
        var month = today.getMonth();

        if (this.currYear != year || this.currMonth != month) {
            if (this.tmpYear == year && this.tmpMonth == month) {
                this.rollback();
            } else {
                this.init(year, month);
                this.commit();
            }
        }
    },
    go : function() {
        if (this.currYear == this.tmpYear && this.currMonth == this.tmpMonth) {
            this.rollback();
        } else {
            this.commit();
        }
        this.hide();
    },
    goToday : function() {
        this.today();
        this.hide();
    },
    goPrevMonth : function() {
        this.prevMonth();
        this.commit();
    },
    goNextMonth : function() {
        this.nextMonth();
        this.commit();
    },
    goPrevYear : function() {
        this.prevYear();
        this.commit();
    },
    goNextYear : function() {
        this.nextYear();
        this.commit();
    },
    changeView : function() {
        global.currYear = this.currYear;
        global.currMonth = this.currMonth;
        clear();
        $("#nian").html(global.currYear);
        $("#yue").html(parseInt(global.currMonth) + 1);
        drawCld(global.currYear, global.currMonth);


    },
    commit : function() {
        if (this.tmpYear != -1 || this.tmpMonth != -1) {
            // 如果发生了变化
            if (this.currYear != this.tmpYear
                    || this.currMonth != this.tmpMonth) {
                // 执行某操作
                this.showYearContent();
                this.showMonthContent();
                this.changeView();


            }

            this.tmpYear = -1;
            this.tmpMonth = -1;
        }
    },
    rollback : function() {
        if (this.tmpYear != -1) {
            this.setYear(this.tmpYear);
        }
        if (this.tmpMonth != -1) {
            this.setMonth(this.tmpMonth);
        }
        this.tmpYear = -1;
        this.tmpMonth = -1;
        this.showYearContent();
        this.showMonthContent();
    },
    prevMonth : function() {
        var month = this.currMonth - 1;
        if (month == -1) {
            var year = this.currYear - 1;
            if (year >= this.minYear) {
                month = 11;
                this.setYear(year);
            } else {
                month = 0;
            }
        }
        this.setMonth(month);
    },
    nextMonth : function() {
        var month = this.currMonth + 1;
        if (month == 12) {
            var year = this.currYear + 1;
            if (year <= this.maxYear) {
                month = 0;
                this.setYear(year);
            } else {
                month = 11;
            }
        }
        this.setMonth(month);
    },
    prevYear : function() {
        var year = this.currYear - 1;
        if (year >= this.minYear) {
            this.setYear(year);
        }
    },
    nextYear : function() {
        var year = this.currYear + 1;
        if (year <= this.maxYear) {
            this.setYear(year);
        }
    },
    prevYearPage : function() {
        this.endYear = this.beginYear - 1;
        this.showYearContent(null, this.endYear);
    },
    nextYearPage : function() {
        this.beginYear = this.endYear + 1;
        this.showYearContent(this.beginYear, null);
    },
    selectYear : function() {//杨:select
        var selectY = $('select[@name="SY"] option[@selected]').text();
        this.setYear(selectY);
        this.commit();
    },
    selectMonth : function() {
        var selectM = $('select[@name="SM"] option[@selected]').text();
        this.setMonth(selectM - 1);
        this.commit();
    },
    setYear : function(value) {
        if (this.tmpYear == -1 && this.currYear != -1) {
            this.tmpYear = this.currYear;
        }
        $('#SY' + this.currYear).removeClass('curr');
        this.currYear = value;
        $('#SY' + this.currYear).addClass('curr');
    },
    setMonth : function(value) {
        if (this.tmpMonth == -1 && this.currMonth != -1) {
            this.tmpMonth = this.currMonth;
        }
        $('#SM' + this.currMonth).removeClass('curr');
        this.currMonth = value;
        $('#SM' + this.currMonth).addClass('curr');
    },
    showYearContent : function(beginYear, endYear) {
        if (!beginYear) {
            if (!endYear) {
                endYear = this.currYear + 1;
            }
            this.endYear = endYear;
            if (this.endYear > this.maxYear) {
                this.endYear = this.maxYear;
            }
            this.beginYear = this.endYear - 3;
            if (this.beginYear < this.minYear) {
                this.beginYear = this.minYear;
                this.endYear = this.beginYear + 3;
            }
        }
        if (!endYear) {
            if (!beginYear) {
                beginYear = this.currYear - 2;
            }
            this.beginYear = beginYear;
            if (this.beginYear < this.minYear) {
                this.beginYear = this.minYear;
            }
            this.endYear = this.beginYear + 3;
            if (this.endYear > this.maxYear) {
                this.endYear = this.maxYear;
                this.beginYear = this.endYear - 3;
            }
        }

        var s = '';
        for (var i = this.beginYear; i <= this.endYear; i++) {
            s += '<span id="SY' + i
                    + '" class="year" onclick="dateSelection.setYear(' + i
                    + ')">' + i + '</span>';
        }
        document.getElementById('yearListContent').innerHTML = s;
        $('#SY' + this.currYear).addClass('curr');
    },
    showMonthContent : function() {
        var s = '';
        for (var i = 0; i < 12; i++) {
            s += '<span id="SM' + i
                    + '" class="month" onclick="dateSelection.setMonth(' + i
                    + ')">' + (i + 1).toString() + '</span>';
        }
        document.getElementById('monthListContent').innerHTML = s;
        $('#SM' + this.currMonth).addClass('curr');
    },
    //根据节假日去相关的月份
	 goHoliday : function(N){
		this.setMonth(N);
		this.commit();
	}
};
function initRiliIndex() {
    var dateObj = new Date();
    global.currYear = dateObj.getFullYear();
    global.currMonth = dateObj.getMonth();

    dateSelection.init();

}


阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页