日历插件

来源:互联网 发布:java if else嵌套 编辑:程序博客网 时间:2024/05/01 13:18

代码运行效果:

<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 , 没闰返回 0function 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 .isLeapfunction 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();}


0 0