diff options
| author | David Cramer | 2011-05-10 00:02:39 -0700 | 
|---|---|---|
| committer | David Cramer | 2011-05-10 00:02:39 -0700 | 
| commit | 875a26213b9c623ddc90bfcf92f419ac8b45d007 (patch) | |
| tree | 458cfcc32d2d31ea54a6538aaae0d8b0ff2b0af9 | |
| parent | 3292aff531d4dee5cf30a003d5d2ee745f718f86 (diff) | |
| parent | bbf99c1639bfec6d2edc4473f8adb278970db7a5 (diff) | |
| download | django-debug-toolbar-875a26213b9c623ddc90bfcf92f419ac8b45d007.tar.bz2 | |
Merge branch 'master' into andrepl-master
Conflicts:
	debug_toolbar/middleware.py
34 files changed, 7496 insertions, 442 deletions
| @@ -1,6 +1,28 @@  News for django-debug-toolbar  ============================= +0.8.5 (2011 Apr 25) +------------------- + +* Ensure if we're overriding the urlconf that we're resetting handler404/500. + +* Updated middleware logic to avoid work if content-type isn't right. + +* Change .load() calls to GET to avoid CSRF protection. + +* Updated SQL panel to match Django's which now includes logging. + +* Added basic multi-db support. + +* Some HTML validation fixes. + +* Added support for `executemany`. Thanks to postal2600. + +* Added support for LogBook. Thanks to Vincent Driessen. + +* Added clean_params method to DatabaseStatTracker to scrub non-unicode +  data for displaying on the sql panel. Thanks to Matthew J Morrison +  0.8.4 (2010 Nov 8)  ------------------ @@ -16,7 +16,7 @@ Currently, the following panels have been written and are working:  - Templates and context used, and their template paths  - SQL queries including time to execute and links to EXPLAIN each query  - List of signals, their args and receivers -- Logging output via Python's built-in logging module +- Logging output via Python's built-in logging, or via the `logbook <http://logbook.pocoo.org>`_ module  There is also one Django management command currently: @@ -182,4 +182,4 @@ output in the shell::  TODOs and BUGS  ============== -See: http://github.com/robhudson/django-debug-toolbar/issues +See: https://github.com/django-debug-toolbar/django-debug-toolbar/issues diff --git a/debug_toolbar/__init__.py b/debug_toolbar/__init__.py index df5bb74..90f9e2f 100644 --- a/debug_toolbar/__init__.py +++ b/debug_toolbar/__init__.py @@ -1,2 +1,2 @@ -VERSION = (0, 8, 4) +VERSION = (0, 8, 5)  __version__ = '.'.join(map(str, VERSION)) diff --git a/debug_toolbar/media/debug_toolbar/Makefile b/debug_toolbar/media/debug_toolbar/Makefile index 5d3eb74..95f91bb 100644 --- a/debug_toolbar/media/debug_toolbar/Makefile +++ b/debug_toolbar/media/debug_toolbar/Makefile @@ -2,7 +2,8 @@  all: compress_js compress_css  compress_js: -	java -jar ~/bin/yuicompressor.jar js/toolbar.js > js/toolbar.min.js +	java -jar ~/bin/yuicompressor.jar js/jquery.js > js/toolbar.min.js +	java -jar ~/bin/yuicompressor.jar js/toolbar.js >> js/toolbar.min.js  compress_css:  	java -jar ~/bin/yuicompressor.jar --type css css/toolbar.css > css/toolbar.min.css diff --git a/debug_toolbar/media/debug_toolbar/css/toolbar.css b/debug_toolbar/media/debug_toolbar/css/toolbar.css index 223869d..820617f 100644 --- a/debug_toolbar/media/debug_toolbar/css/toolbar.css +++ b/debug_toolbar/media/debug_toolbar/css/toolbar.css @@ -1,3 +1,17 @@ +/* http://www.positioniseverything.net/easyclearing.html */ +.clearfix:after { +    content: ".";  +    display: block;  +    height: 0;  +    clear: both;  +    visibility: hidden; +} +.clearfix {display: inline-block;} +/* Hides from IE-mac \*/ +.clearfix {display: block;} +* html .clearfix {height: 1%;} +/* end hide from IE-mac */ +  /* Debug Toolbar CSS Reset, adapted from Eric Meyer's CSS Reset */  #djDebug {color:#000;background:#FFF;}  #djDebug, #djDebug div, #djDebug span, #djDebug applet, #djDebug object, #djDebug iframe, @@ -73,6 +87,7 @@  #djDebug #djDebugToolbar li.active {  	background-image:url(../img/indicator.png); +	background-image:url();  	background-repeat:no-repeat;  	background-position:left center;  	background-color:#333; @@ -117,6 +132,7 @@  	text-align:center;  	text-indent:-999999px;  	background:#000 url(../img/djdt_vertical.png) no-repeat left center; +	background-image:url();  	opacity:0.5;  } @@ -180,7 +196,7 @@  	bottom:0;  	left:0;  	height:auto; -	padding:0 0 0 20px; +	padding:5px 0 0 20px;  }  #djDebug .djDebugPanelContent .scroll { @@ -294,18 +310,22 @@  	height:40px;  	width:40px;  	background:url(../img/close.png) no-repeat center center; +	background-image: url();  }  #djDebug .panelContent .djDebugClose:hover {  	background-image:url(../img/close_hover.png); +	background-image: url();  }  #djDebug .panelContent .djDebugClose.djDebugBack {  	background-image:url(../img/back.png); +	background-image: url();  }  #djDebug .panelContent .djDebugClose.djDebugBack:hover  {  	background-image:url(../img/back_hover.png); +	background-image: url();  }  #djDebug .panelContent dt, #djDebug .panelContent dd { @@ -349,11 +369,34 @@  	position:relative;  } +#djDebug .djDebugCollapse { +    display: inline-block; +    background: #ddd; +    background: url() 0 3px repeat-x; +    width: 18px; +    text-indent: -10000em; +} +#djDebug .djSelected .djDebugCollapse { +    background: inherit; +    text-indent: 0; +    width: auto; +    display: inline; +} +#djDebug .djUnselected { +    display: none; +} +#djDebug tr.djHiddenByDefault { +    display: none; +} +#djDebug tr.djSelected { +    display: table-row; +} +  #djDebug .djDebugSql {  	z-index:100000002;  } -#djDebug .djSQLHideStacktraceDiv tbody th { +#djDebug .djSQLDetailsDiv tbody th {  	text-align: left;  } @@ -394,3 +437,141 @@  #djDebug .highlight .nv { color:#333 } /* Name.Variable */  #djDebug .highlight .s2 { color:#333 } /* Literal.String.Double */  #djDebug .highlight .cp { color:#333 } /* Comment.Preproc */ + +#djDebug .timeline { +    width: 30%; +} +#djDebug .djDebugTimeline { +    position: relative; +    height: 100%; +    min-height: 100%; +} +#djDebug div.djDebugLineChart { +    position: absolute; +    left: 0; +    right: 0; +    top: 0; +    bottom: 0; +    vertical-align: middle; +} +#djDebug div.djDebugLineChart strong { +    text-indent: -10000em; +    display: block; +    font-weight: normal; +    vertical-align: middle; +    background-color:#ccc; +} + +#djDebug div.djDebugLineChartWarning strong { +    background-color:#900; +} + +#djDebug .djDebugInTransaction div.djDebugLineChart strong { +    background-color: #d3ff82; +} +#djDebug .djDebugStartTransaction div.djDebugLineChart strong { +    border-left: 1px solid #94b24d; +} +#djDebug .djDebugEndTransaction div.djDebugLineChart strong { +    border-right: 1px solid #94b24d; +} +#djDebug .djDebugHover div.djDebugLineChart strong { +    background-color: #000; +} +#djDebug .djDebugInTransaction.djDebugHover div.djDebugLineChart strong { +    background-color: #94b24d; +} + + +#djDebug .panelContent ul.stats { +    position: relative;  +} +#djDebug .panelContent ul.stats li { +    width: 30%; +    float: left; +} +#djDebug .panelContent ul.stats li strong.label { +    display: block; +} +#djDebug .panelContent ul.stats li span.color { +    height: 12px; +    width: 3px; +    display: inline-block; +} +#djDebug .panelContent ul.stats li span.info { +    display: block; +    padding-left: 5px; +} + +#djDebug .panelcontent thead th { +    white-space: nowrap; +} +#djDebug .djDebugRowWarning .time { +    color: red; +} +#djdebug .panelcontent table .toggle { +    width: 14px; +    padding-top: 3px; +} +#djdebug .panelcontent table .actions { +    min-width: 70px; +} +#djdebug .panelcontent table .color { +    width: 3px; +} +#djdebug .panelcontent table .color span { +    width: 3px; +    height: 12px; +    overflow: hidden; +    padding: 0; +} +#djDebug .djToggleSwitch { +    text-decoration: none; +    border: 1px solid #999; +    height: 12px; +    width: 12px; +    line-height: 12px; +    text-align: center; +    color: #777; +    display: inline-block; +    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#FFF', endColorstr='#DCDCDC'); /* for IE */ +    background: -webkit-gradient(linear, left top, left bottom, from(#FFF), to(#DCDCDC)); /* for webkit browsers */ +    background:-moz-linear-gradient(center top , #FFFFFF 0pt, #DCDCDC 100%) repeat scroll 0 0 transparent; +} +#djDebug .djNoToggleSwitch { +    height: 14px; +    width: 14px; +    display: inline-block; +} + +#djDebug .djSQLDetailsDiv { +    margin-top:0.8em; +} +#djDebug .djSQLDetailsDiv pre { +    color: #777; +    border:1px solid #ccc; +    border-collapse:collapse; +    background-color:#fff; +    display:block; +    overflow: auto; +    padding:2px 3px; +    margin-bottom: 3px; +    font-family:Consolas, Monaco, "Bitstream Vera Sans Mono", "Lucida Console", monospace; +} +#djDebug .stack span { +    color: #000; +    font-weight: bold; +} +#djDebug .stack span.path { +    color: #777; +    font-weight: normal; +} +#djDebug .stack span.code { +    font-weight: normal; +} + +@media print { +    #djDebug { +        display: none; +    } +} diff --git a/debug_toolbar/media/debug_toolbar/css/toolbar.min.css b/debug_toolbar/media/debug_toolbar/css/toolbar.min.css index 2f2d7db..5088442 100644 --- a/debug_toolbar/media/debug_toolbar/css/toolbar.min.css +++ b/debug_toolbar/media/debug_toolbar/css/toolbar.min.css @@ -1 +1 @@ -#djDebug{color:#000;background:#FFF;}#djDebug,#djDebug div,#djDebug span,#djDebug applet,#djDebug object,#djDebug iframe,#djDebug h1,#djDebug h2,#djDebug h3,#djDebug h4,#djDebug h5,#djDebug h6,#djDebug p,#djDebug blockquote,#djDebug pre,#djDebug a,#djDebug abbr,#djDebug acronym,#djDebug address,#djDebug big,#djDebug cite,#djDebug code,#djDebug del,#djDebug dfn,#djDebug em,#djDebug font,#djDebug img,#djDebug ins,#djDebug kbd,#djDebug q,#djDebug s,#djDebug samp,#djDebug small,#djDebug strike,#djDebug strong,#djDebug sub,#djDebug sup,#djDebug tt,#djDebug var,#djDebug b,#djDebug u,#djDebug i,#djDebug center,#djDebug dl,#djDebug dt,#djDebug dd,#djDebug ol,#djDebug ul,#djDebug li,#djDebug fieldset,#djDebug form,#djDebug label,#djDebug legend,#djDebug table,#djDebug caption,#djDebug tbody,#djDebug tfoot,#djDebug thead,#djDebug tr,#djDebug th,#djDebug td{margin:0;padding:0;border:0;outline:0;font-size:12px;line-height:1.5em;color:#000;vertical-align:baseline;background:transparent;font-family:sans-serif;text-align:left;}#djDebug #djDebugToolbar{background:#111;width:200px;z-index:100000000;position:fixed;top:0;bottom:0;right:0;opacity:.9;}#djDebug #djDebugToolbar small{color:#999;}#djDebug #djDebugToolbar ul{margin:0;padding:0;list-style:none;}#djDebug #djDebugToolbar li{border-bottom:1px solid #222;color:#fff;display:block;font-weight:bold;float:none;margin:0;padding:0;position:relative;width:auto;}#djDebug #djDebugToolbar li>a,#djDebug #djDebugToolbar li>div.contentless{font-weight:normal;font-style:normal;text-decoration:none;display:block;font-size:16px;padding:10px 10px 5px 25px;color:#fff;}#djDebug #djDebugToolbar li a:hover{color:#111;background-color:#ffc;}#djDebug #djDebugToolbar li.active{background-image:url(../img/indicator.png);background-repeat:no-repeat;background-position:left center;background-color:#333;padding-left:10px;}#djDebug #djDebugToolbar li.active a:hover{color:#b36a60;background-color:transparent;}#djDebug #djDebugToolbar li small{font-size:12px;color:#999;font-style:normal;text-decoration:none;font-variant:small-caps;}#djDebug #djDebugToolbarHandle{position:fixed;background:#fff;border:1px solid #111;top:30px;right:0;z-index:100000000;opacity:.75;}#djDebug a#djShowToolBarButton{display:block;height:75px;width:30px;border-right:none;border-bottom:4px solid #fff;border-top:4px solid #fff;border-left:4px solid #fff;color:#fff;font-size:10px;font-weight:bold;text-decoration:none;text-align:center;text-indent:-999999px;background:#000 url(../img/djdt_vertical.png) no-repeat left center;opacity:.5;}#djDebug a#djShowToolBarButton:hover{background-color:#111;padding-right:6px;border-top-color:#FFE761;border-left-color:#FFE761;border-bottom-color:#FFE761;opacity:1.0;}#djDebug code{display:block;font-family:Consolas,Monaco,"Bitstream Vera Sans Mono","Lucida Console",monospace;white-space:pre;overflow:auto;}#djDebug tr.djDebugOdd{background-color:#f5f5f5;}#djDebug .panelContent{display:none;position:fixed;margin:0;top:0;right:200px;bottom:0;left:0;background-color:#eee;color:#666;z-index:100000000;}#djDebug .panelContent>div{border-bottom:1px solid #ddd;}#djDebug .djDebugPanelTitle{position:absolute;background-color:#ffc;color:#666;padding-left:20px;top:0;right:0;left:0;height:50px;}#djDebug .djDebugPanelTitle code{display:inline;font-size:inherit;}#djDebug .djDebugPanelContent{position:absolute;top:50px;right:0;bottom:0;left:0;height:auto;padding:0 0 0 20px;}#djDebug .djDebugPanelContent .scroll{height:100%;overflow:auto;display:block;padding:0 10px 0 0;}#djDebug h3{font-size:24px;font-weight:normal;line-height:50px;}#djDebug h4{font-size:20px;font-weight:bold;margin-top:.8em;}#djDebug .panelContent table{border:1px solid #ccc;border-collapse:collapse;width:100%;background-color:#fff;display:block;margin-top:.8em;overflow:auto;}#djDebug .panelContent tbody td,#djDebug .panelContent tbody th{vertical-align:top;padding:2px 3px;}#djDebug .panelContent thead th{padding:1px 6px 1px 3px;text-align:left;font-weight:bold;font-size:14px;}#djDebug .panelContent tbody th{width:12em;text-align:right;color:#666;padding-right:.5em;}#djDebug .djTemplateHideContextDiv{background-color:#fff;}#djDebug .panelContent .djDebugClose{text-indent:-9999999px;display:block;position:absolute;top:4px;right:15px;height:40px;width:40px;background:url(../img/close.png) no-repeat center center;}#djDebug .panelContent .djDebugClose:hover{background-image:url(../img/close_hover.png);}#djDebug .panelContent .djDebugClose.djDebugBack{background-image:url(../img/back.png);}#djDebug .panelContent .djDebugClose.djDebugBack:hover{background-image:url(../img/back_hover.png);}#djDebug .panelContent dt,#djDebug .panelContent dd{display:block;}#djDebug .panelContent dt{margin-top:.75em;}#djDebug .panelContent dd{margin-left:10px;}#djDebug a.toggleTemplate{padding:4px;background-color:#bbb;-moz-border-radius:3px;-webkit-border-radius:3px;}#djDebug a.toggleTemplate:hover{padding:4px;background-color:#444;color:#ffe761;-moz-border-radius:3px;-webkit-border-radius:3px;}#djDebug a.djTemplateShowContext,#djDebug a.djTemplateShowContext span.toggleArrow{color:#999;}#djDebug a.djTemplateShowContext:hover,#djDebug a.djTemplateShowContext:hover span.toggleArrow{color:#000;cursor:pointer;}#djDebug .djDebugSqlWrap{position:relative;}#djDebug .djDebugSql{z-index:100000002;}#djDebug .djSQLHideStacktraceDiv tbody th{text-align:left;}#djDebug .djSqlExplain td{white-space:pre;}#djDebug span.djDebugLineChart{background-color:#777;height:3px;position:absolute;bottom:0;top:0;left:0;display:block;z-index:1000000001;}#djDebug span.djDebugLineChartWarning{background-color:#900;}#djDebug .highlight{color:#000;}#djDebug .highlight .err{color:#000;}#djDebug .highlight .g{color:#000;}#djDebug .highlight .k{color:#000;font-weight:bold;}#djDebug .highlight .o{color:#000;}#djDebug .highlight .n{color:#000;}#djDebug .highlight .mi{color:#000;font-weight:bold;}#djDebug .highlight .l{color:#000;}#djDebug .highlight .x{color:#000;}#djDebug .highlight .p{color:#000;}#djDebug .highlight .m{color:#000;font-weight:bold;}#djDebug .highlight .s{color:#333;}#djDebug .highlight .w{color:#888;}#djDebug .highlight .il{color:#000;font-weight:bold;}#djDebug .highlight .na{color:#333;}#djDebug .highlight .nt{color:#000;font-weight:bold;}#djDebug .highlight .nv{color:#333;}#djDebug .highlight .s2{color:#333;}#djDebug .highlight .cp{color:#333;}
\ No newline at end of file +.clearfix:after{content:".";display:block;height:0;clear:both;visibility:hidden;}.clearfix{display:inline-block;}/* Hides from IE-mac \*/ .clearfix{display:block;}* html .clearfix{height:1%;}/* end hide from IE-mac */ #djDebug{color:#000;background:#FFF;}#djDebug,#djDebug div,#djDebug span,#djDebug applet,#djDebug object,#djDebug iframe,#djDebug h1,#djDebug h2,#djDebug h3,#djDebug h4,#djDebug h5,#djDebug h6,#djDebug p,#djDebug blockquote,#djDebug pre,#djDebug a,#djDebug abbr,#djDebug acronym,#djDebug address,#djDebug big,#djDebug cite,#djDebug code,#djDebug del,#djDebug dfn,#djDebug em,#djDebug font,#djDebug img,#djDebug ins,#djDebug kbd,#djDebug q,#djDebug s,#djDebug samp,#djDebug small,#djDebug strike,#djDebug strong,#djDebug sub,#djDebug sup,#djDebug tt,#djDebug var,#djDebug b,#djDebug u,#djDebug i,#djDebug center,#djDebug dl,#djDebug dt,#djDebug dd,#djDebug ol,#djDebug ul,#djDebug li,#djDebug fieldset,#djDebug form,#djDebug label,#djDebug legend,#djDebug table,#djDebug caption,#djDebug tbody,#djDebug tfoot,#djDebug thead,#djDebug tr,#djDebug th,#djDebug td{margin:0;padding:0;border:0;outline:0;font-size:12px;line-height:1.5em;color:#000;vertical-align:baseline;background:transparent;font-family:sans-serif;text-align:left;}#djDebug #djDebugToolbar{background:#111;width:200px;z-index:100000000;position:fixed;top:0;bottom:0;right:0;opacity:.9;}#djDebug #djDebugToolbar small{color:#999;}#djDebug #djDebugToolbar ul{margin:0;padding:0;list-style:none;}#djDebug #djDebugToolbar li{border-bottom:1px solid #222;color:#fff;display:block;font-weight:bold;float:none;margin:0;padding:0;position:relative;width:auto;}#djDebug #djDebugToolbar li>a,#djDebug #djDebugToolbar li>div.contentless{font-weight:normal;font-style:normal;text-decoration:none;display:block;font-size:16px;padding:10px 10px 5px 25px;color:#fff;}#djDebug #djDebugToolbar li a:hover{color:#111;background-color:#ffc;}#djDebug #djDebugToolbar li.active{background-image:url(../img/indicator.png);background-image:url();background-repeat:no-repeat;background-position:left center;background-color:#333;padding-left:10px;}#djDebug #djDebugToolbar li.active a:hover{color:#b36a60;background-color:transparent;}#djDebug #djDebugToolbar li small{font-size:12px;color:#999;font-style:normal;text-decoration:none;font-variant:small-caps;}#djDebug #djDebugToolbarHandle{position:fixed;background:#fff;border:1px solid #111;top:30px;right:0;z-index:100000000;opacity:.75;}#djDebug a#djShowToolBarButton{display:block;height:75px;width:30px;border-right:none;border-bottom:4px solid #fff;border-top:4px solid #fff;border-left:4px solid #fff;color:#fff;font-size:10px;font-weight:bold;text-decoration:none;text-align:center;text-indent:-999999px;background:#000 url(../img/djdt_vertical.png) no-repeat left center;background-image:url();opacity:.5;}#djDebug a#djShowToolBarButton:hover{background-color:#111;padding-right:6px;border-top-color:#FFE761;border-left-color:#FFE761;border-bottom-color:#FFE761;opacity:1.0;}#djDebug code{display:block;font-family:Consolas,Monaco,"Bitstream Vera Sans Mono","Lucida Console",monospace;white-space:pre;overflow:auto;}#djDebug tr.djDebugOdd{background-color:#f5f5f5;}#djDebug .panelContent{display:none;position:fixed;margin:0;top:0;right:200px;bottom:0;left:0;background-color:#eee;color:#666;z-index:100000000;}#djDebug .panelContent>div{border-bottom:1px solid #ddd;}#djDebug .djDebugPanelTitle{position:absolute;background-color:#ffc;color:#666;padding-left:20px;top:0;right:0;left:0;height:50px;}#djDebug .djDebugPanelTitle code{display:inline;font-size:inherit;}#djDebug .djDebugPanelContent{position:absolute;top:50px;right:0;bottom:0;left:0;height:auto;padding:5px 0 0 20px;}#djDebug .djDebugPanelContent .scroll{height:100%;overflow:auto;display:block;padding:0 10px 0 0;}#djDebug h3{font-size:24px;font-weight:normal;line-height:50px;}#djDebug h4{font-size:20px;font-weight:bold;margin-top:.8em;}#djDebug .panelContent table{border:1px solid #ccc;border-collapse:collapse;width:100%;background-color:#fff;display:block;margin-top:.8em;overflow:auto;}#djDebug .panelContent tbody td,#djDebug .panelContent tbody th{vertical-align:top;padding:2px 3px;}#djDebug .panelContent thead th{padding:1px 6px 1px 3px;text-align:left;font-weight:bold;font-size:14px;}#djDebug .panelContent tbody th{width:12em;text-align:right;color:#666;padding-right:.5em;}#djDebug .djTemplateHideContextDiv{background-color:#fff;}#djDebug .panelContent .djDebugClose{text-indent:-9999999px;display:block;position:absolute;top:4px;right:15px;height:40px;width:40px;background:url(../img/close.png) no-repeat center center;background-image:url();}#djDebug .panelContent .djDebugClose:hover{background-image:url(../img/close_hover.png);background-image:url();}#djDebug .panelContent .djDebugClose.djDebugBack{background-image:url(../img/back.png);background-image:url();}#djDebug .panelContent .djDebugClose.djDebugBack:hover{background-image:url(../img/back_hover.png);background-image:url();}#djDebug .panelContent dt,#djDebug .panelContent dd{display:block;}#djDebug .panelContent dt{margin-top:.75em;}#djDebug .panelContent dd{margin-left:10px;}#djDebug a.toggleTemplate{padding:4px;background-color:#bbb;-moz-border-radius:3px;-webkit-border-radius:3px;}#djDebug a.toggleTemplate:hover{padding:4px;background-color:#444;color:#ffe761;-moz-border-radius:3px;-webkit-border-radius:3px;}#djDebug a.djTemplateShowContext,#djDebug a.djTemplateShowContext span.toggleArrow{color:#999;}#djDebug a.djTemplateShowContext:hover,#djDebug a.djTemplateShowContext:hover span.toggleArrow{color:#000;cursor:pointer;}#djDebug .djDebugSqlWrap{position:relative;}#djDebug .djDebugCollapse{display:inline-block;background:#ddd;background:url() 0 3px repeat-x;width:18px;text-indent:-10000em;}#djDebug .djSelected .djDebugCollapse{background:inherit;text-indent:0;width:auto;display:inline;}#djDebug .djUnselected{display:none;}#djDebug tr.djHiddenByDefault{display:none;}#djDebug tr.djSelected{display:table-row;}#djDebug .djDebugSql{z-index:100000002;}#djDebug .djSQLDetailsDiv tbody th{text-align:left;}#djDebug .djSqlExplain td{white-space:pre;}#djDebug span.djDebugLineChart{background-color:#777;height:3px;position:absolute;bottom:0;top:0;left:0;display:block;z-index:1000000001;}#djDebug span.djDebugLineChartWarning{background-color:#900;}#djDebug .highlight{color:#000;}#djDebug .highlight .err{color:#000;}#djDebug .highlight .g{color:#000;}#djDebug .highlight .k{color:#000;font-weight:bold;}#djDebug .highlight .o{color:#000;}#djDebug .highlight .n{color:#000;}#djDebug .highlight .mi{color:#000;font-weight:bold;}#djDebug .highlight .l{color:#000;}#djDebug .highlight .x{color:#000;}#djDebug .highlight .p{color:#000;}#djDebug .highlight .m{color:#000;font-weight:bold;}#djDebug .highlight .s{color:#333;}#djDebug .highlight .w{color:#888;}#djDebug .highlight .il{color:#000;font-weight:bold;}#djDebug .highlight .na{color:#333;}#djDebug .highlight .nt{color:#000;font-weight:bold;}#djDebug .highlight .nv{color:#333;}#djDebug .highlight .s2{color:#333;}#djDebug .highlight .cp{color:#333;}#djDebug .timeline{width:30%;}#djDebug .djDebugTimeline{position:relative;height:100%;min-height:100%;}#djDebug div.djDebugLineChart{position:absolute;left:0;right:0;top:0;bottom:0;vertical-align:middle;}#djDebug div.djDebugLineChart strong{text-indent:-10000em;display:block;font-weight:normal;vertical-align:middle;background-color:#ccc;}#djDebug div.djDebugLineChartWarning strong{background-color:#900;}#djDebug .djDebugInTransaction div.djDebugLineChart strong{background-color:#d3ff82;}#djDebug .djDebugStartTransaction div.djDebugLineChart strong{border-left:1px solid #94b24d;}#djDebug .djDebugEndTransaction div.djDebugLineChart strong{border-right:1px solid #94b24d;}#djDebug .djDebugHover div.djDebugLineChart strong{background-color:#000;}#djDebug .djDebugInTransaction.djDebugHover div.djDebugLineChart strong{background-color:#94b24d;}#djDebug .panelContent ul.stats{position:relative;}#djDebug .panelContent ul.stats li{width:30%;float:left;}#djDebug .panelContent ul.stats li strong.label{display:block;}#djDebug .panelContent ul.stats li span.color{height:12px;width:3px;display:inline-block;}#djDebug .panelContent ul.stats li span.info{display:block;padding-left:5px;}#djDebug .panelcontent thead th{white-space:nowrap;}#djDebug .djDebugRowWarning .time{color:red;}#djdebug .panelcontent table .toggle{width:14px;padding-top:3px;}#djdebug .panelcontent table .actions{min-width:70px;}#djdebug .panelcontent table .color{width:3px;}#djdebug .panelcontent table .color span{width:3px;height:12px;overflow:hidden;padding:0;}#djDebug .djToggleSwitch{text-decoration:none;border:1px solid #999;height:12px;width:12px;line-height:12px;text-align:center;color:#777;display:inline-block;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#FFF',endColorstr='#DCDCDC');background:-webkit-gradient(linear,left top,left bottom,from(#FFF),to(#DCDCDC));background:-moz-linear-gradient(center top,#FFF 0,#DCDCDC 100%) repeat scroll 0 0 transparent;}#djDebug .djNoToggleSwitch{height:14px;width:14px;display:inline-block;}#djDebug .djSQLDetailsDiv{margin-top:.8em;}#djDebug .djSQLDetailsDiv pre{color:#777;border:1px solid #ccc;border-collapse:collapse;background-color:#fff;display:block;overflow:auto;padding:2px 3px;margin-bottom:3px;font-family:Consolas,Monaco,"Bitstream Vera Sans Mono","Lucida Console",monospace;}#djDebug .stack span{color:#000;font-weight:bold;}#djDebug .stack span.path{color:#777;font-weight:normal;}#djDebug .stack span.code{font-weight:normal;}@media print{#djDebug{display:none;}}
\ No newline at end of file diff --git a/debug_toolbar/media/debug_toolbar/img/dot.gif b/debug_toolbar/media/debug_toolbar/img/dot.gifBinary files differ new file mode 100644 index 0000000..9009f29 --- /dev/null +++ b/debug_toolbar/media/debug_toolbar/img/dot.gif diff --git a/debug_toolbar/media/debug_toolbar/js/jquery.js b/debug_toolbar/media/debug_toolbar/js/jquery.js index 0c7294c..26cbb47 100644 --- a/debug_toolbar/media/debug_toolbar/js/jquery.js +++ b/debug_toolbar/media/debug_toolbar/js/jquery.js @@ -13,140 +13,6066 @@   *   * Date: Mon Jan 25 19:43:33 2010 -0500   */ -(function(z,v){function la(){if(!c.isReady){try{r.documentElement.doScroll("left")}catch(a){setTimeout(la,1);return}c.ready()}}function Ma(a,b){b.src?c.ajax({url:b.src,async:false,dataType:"script"}):c.globalEval(b.text||b.textContent||b.innerHTML||"");b.parentNode&&b.parentNode.removeChild(b)}function X(a,b,d,f,e,i){var j=a.length;if(typeof b==="object"){for(var n in b)X(a,n,b[n],f,e,d);return a}if(d!==v){f=!i&&f&&c.isFunction(d);for(n=0;n<j;n++)e(a[n],b,f?d.call(a[n],n,e(a[n],b)):d,i);return a}return j? -e(a[0],b):null}function J(){return(new Date).getTime()}function Y(){return false}function Z(){return true}function ma(a,b,d){d[0].type=a;return c.event.handle.apply(b,d)}function na(a){var b,d=[],f=[],e=arguments,i,j,n,o,m,s,x=c.extend({},c.data(this,"events").live);if(!(a.button&&a.type==="click")){for(o in x){j=x[o];if(j.live===a.type||j.altLive&&c.inArray(a.type,j.altLive)>-1){i=j.data;i.beforeFilter&&i.beforeFilter[a.type]&&!i.beforeFilter[a.type](a)||f.push(j.selector)}else delete x[o]}i=c(a.target).closest(f, -a.currentTarget);m=0;for(s=i.length;m<s;m++)for(o in x){j=x[o];n=i[m].elem;f=null;if(i[m].selector===j.selector){if(j.live==="mouseenter"||j.live==="mouseleave")f=c(a.relatedTarget).closest(j.selector)[0];if(!f||f!==n)d.push({elem:n,fn:j})}}m=0;for(s=d.length;m<s;m++){i=d[m];a.currentTarget=i.elem;a.data=i.fn.data;if(i.fn.apply(i.elem,e)===false){b=false;break}}return b}}function oa(a,b){return"live."+(a?a+".":"")+b.replace(/\./g,"`").replace(/ /g,"&")}function pa(a){return!a||!a.parentNode||a.parentNode.nodeType=== -11}function qa(a,b){var d=0;b.each(function(){if(this.nodeName===(a[d]&&a[d].nodeName)){var f=c.data(a[d++]),e=c.data(this,f);if(f=f&&f.events){delete e.handle;e.events={};for(var i in f)for(var j in f[i])c.event.add(this,i,f[i][j],f[i][j].data)}}})}function ra(a,b,d){var f,e,i;if(a.length===1&&typeof a[0]==="string"&&a[0].length<512&&a[0].indexOf("<option")<0&&(c.support.checkClone||!sa.test(a[0]))){e=true;if(i=c.fragments[a[0]])if(i!==1)f=i}if(!f){b=b&&b[0]?b[0].ownerDocument||b[0]:r;f=b.createDocumentFragment(); -c.clean(a,b,f,d)}if(e)c.fragments[a[0]]=i?f:1;return{fragment:f,cacheable:e}}function K(a,b){var d={};c.each(ta.concat.apply([],ta.slice(0,b)),function(){d[this]=a});return d}function ua(a){return"scrollTo"in a&&a.document?a:a.nodeType===9?a.defaultView||a.parentWindow:false}var c=function(a,b){return new c.fn.init(a,b)},Na=z.jQuery,Oa=z.$,r=z.document,S,Pa=/^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/,Qa=/^.[^:#\[\.,]*$/,Ra=/\S/,Sa=/^(\s|\u00A0)+|(\s|\u00A0)+$/g,Ta=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,O=navigator.userAgent, -va=false,P=[],L,$=Object.prototype.toString,aa=Object.prototype.hasOwnProperty,ba=Array.prototype.push,Q=Array.prototype.slice,wa=Array.prototype.indexOf;c.fn=c.prototype={init:function(a,b){var d,f;if(!a)return this;if(a.nodeType){this.context=this[0]=a;this.length=1;return this}if(typeof a==="string")if((d=Pa.exec(a))&&(d[1]||!b))if(d[1]){f=b?b.ownerDocument||b:r;if(a=Ta.exec(a))if(c.isPlainObject(b)){a=[r.createElement(a[1])];c.fn.attr.call(a,b,true)}else a=[f.createElement(a[1])];else{a=ra([d[1]], -[f]);a=(a.cacheable?a.fragment.cloneNode(true):a.fragment).childNodes}}else{if(b=r.getElementById(d[2])){if(b.id!==d[2])return S.find(a);this.length=1;this[0]=b}this.context=r;this.selector=a;return this}else if(!b&&/^\w+$/.test(a)){this.selector=a;this.context=r;a=r.getElementsByTagName(a)}else return!b||b.jquery?(b||S).find(a):c(b).find(a);else if(c.isFunction(a))return S.ready(a);if(a.selector!==v){this.selector=a.selector;this.context=a.context}return c.isArray(a)?this.setArray(a):c.makeArray(a, -this)},selector:"",jquery:"1.4.1",length:0,size:function(){return this.length},toArray:function(){return Q.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this.slice(a)[0]:this[a]},pushStack:function(a,b,d){a=c(a||null);a.prevObject=this;a.context=this.context;if(b==="find")a.selector=this.selector+(this.selector?" ":"")+d;else if(b)a.selector=this.selector+"."+b+"("+d+")";return a},setArray:function(a){this.length=0;ba.apply(this,a);return this},each:function(a,b){return c.each(this, -a,b)},ready:function(a){c.bindReady();if(c.isReady)a.call(r,c);else P&&P.push(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(Q.apply(this,arguments),"slice",Q.call(arguments).join(","))},map:function(a){return this.pushStack(c.map(this,function(b,d){return a.call(b,d,b)}))},end:function(){return this.prevObject||c(null)},push:ba,sort:[].sort,splice:[].splice}; -c.fn.init.prototype=c.fn;c.extend=c.fn.extend=function(){var a=arguments[0]||{},b=1,d=arguments.length,f=false,e,i,j,n;if(typeof a==="boolean"){f=a;a=arguments[1]||{};b=2}if(typeof a!=="object"&&!c.isFunction(a))a={};if(d===b){a=this;--b}for(;b<d;b++)if((e=arguments[b])!=null)for(i in e){j=a[i];n=e[i];if(a!==n)if(f&&n&&(c.isPlainObject(n)||c.isArray(n))){j=j&&(c.isPlainObject(j)||c.isArray(j))?j:c.isArray(n)?[]:{};a[i]=c.extend(f,j,n)}else if(n!==v)a[i]=n}return a};c.extend({noConflict:function(a){z.$= -Oa;if(a)z.jQuery=Na;return c},isReady:false,ready:function(){if(!c.isReady){if(!r.body)return setTimeout(c.ready,13);c.isReady=true;if(P){for(var a,b=0;a=P[b++];)a.call(r,c);P=null}c.fn.triggerHandler&&c(r).triggerHandler("ready")}},bindReady:function(){if(!va){va=true;if(r.readyState==="complete")return c.ready();if(r.addEventListener){r.addEventListener("DOMContentLoaded",L,false);z.addEventListener("load",c.ready,false)}else if(r.attachEvent){r.attachEvent("onreadystatechange",L);z.attachEvent("onload", -c.ready);var a=false;try{a=z.frameElement==null}catch(b){}r.documentElement.doScroll&&a&&la()}}},isFunction:function(a){return $.call(a)==="[object Function]"},isArray:function(a){return $.call(a)==="[object Array]"},isPlainObject:function(a){if(!a||$.call(a)!=="[object Object]"||a.nodeType||a.setInterval)return false;if(a.constructor&&!aa.call(a,"constructor")&&!aa.call(a.constructor.prototype,"isPrototypeOf"))return false;var b;for(b in a);return b===v||aa.call(a,b)},isEmptyObject:function(a){for(var b in a)return false; -return true},error:function(a){throw a;},parseJSON:function(a){if(typeof a!=="string"||!a)return null;if(/^[\],:{}\s]*$/.test(a.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,"@").replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,"]").replace(/(?:^|:|,)(?:\s*\[)+/g,"")))return z.JSON&&z.JSON.parse?z.JSON.parse(a):(new Function("return "+a))();else c.error("Invalid JSON: "+a)},noop:function(){},globalEval:function(a){if(a&&Ra.test(a)){var b=r.getElementsByTagName("head")[0]|| -r.documentElement,d=r.createElement("script");d.type="text/javascript";if(c.support.scriptEval)d.appendChild(r.createTextNode(a));else d.text=a;b.insertBefore(d,b.firstChild);b.removeChild(d)}},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,b,d){var f,e=0,i=a.length,j=i===v||c.isFunction(a);if(d)if(j)for(f in a){if(b.apply(a[f],d)===false)break}else for(;e<i;){if(b.apply(a[e++],d)===false)break}else if(j)for(f in a){if(b.call(a[f],f,a[f])===false)break}else for(d= -a[0];e<i&&b.call(d,e,d)!==false;d=a[++e]);return a},trim:function(a){return(a||"").replace(Sa,"")},makeArray:function(a,b){b=b||[];if(a!=null)a.length==null||typeof a==="string"||c.isFunction(a)||typeof a!=="function"&&a.setInterval?ba.call(b,a):c.merge(b,a);return b},inArray:function(a,b){if(b.indexOf)return b.indexOf(a);for(var d=0,f=b.length;d<f;d++)if(b[d]===a)return d;return-1},merge:function(a,b){var d=a.length,f=0;if(typeof b.length==="number")for(var e=b.length;f<e;f++)a[d++]=b[f];else for(;b[f]!== -v;)a[d++]=b[f++];a.length=d;return a},grep:function(a,b,d){for(var f=[],e=0,i=a.length;e<i;e++)!d!==!b(a[e],e)&&f.push(a[e]);return f},map:function(a,b,d){for(var f=[],e,i=0,j=a.length;i<j;i++){e=b(a[i],i,d);if(e!=null)f[f.length]=e}return f.concat.apply([],f)},guid:1,proxy:function(a,b,d){if(arguments.length===2)if(typeof b==="string"){d=a;a=d[b];b=v}else if(b&&!c.isFunction(b)){d=b;b=v}if(!b&&a)b=function(){return a.apply(d||this,arguments)};if(a)b.guid=a.guid=a.guid||b.guid||c.guid++;return b}, -uaMatch:function(a){a=a.toLowerCase();a=/(webkit)[ \/]([\w.]+)/.exec(a)||/(opera)(?:.*version)?[ \/]([\w.]+)/.exec(a)||/(msie) ([\w.]+)/.exec(a)||!/compatible/.test(a)&&/(mozilla)(?:.*? rv:([\w.]+))?/.exec(a)||[];return{browser:a[1]||"",version:a[2]||"0"}},browser:{}});O=c.uaMatch(O);if(O.browser){c.browser[O.browser]=true;c.browser.version=O.version}if(c.browser.webkit)c.browser.safari=true;if(wa)c.inArray=function(a,b){return wa.call(b,a)};S=c(r);if(r.addEventListener)L=function(){r.removeEventListener("DOMContentLoaded", -L,false);c.ready()};else if(r.attachEvent)L=function(){if(r.readyState==="complete"){r.detachEvent("onreadystatechange",L);c.ready()}};(function(){c.support={};var a=r.documentElement,b=r.createElement("script"),d=r.createElement("div"),f="script"+J();d.style.display="none";d.innerHTML="   <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>";var e=d.getElementsByTagName("*"),i=d.getElementsByTagName("a")[0];if(!(!e||!e.length||!i)){c.support= -{leadingWhitespace:d.firstChild.nodeType===3,tbody:!d.getElementsByTagName("tbody").length,htmlSerialize:!!d.getElementsByTagName("link").length,style:/red/.test(i.getAttribute("style")),hrefNormalized:i.getAttribute("href")==="/a",opacity:/^0.55$/.test(i.style.opacity),cssFloat:!!i.style.cssFloat,checkOn:d.getElementsByTagName("input")[0].value==="on",optSelected:r.createElement("select").appendChild(r.createElement("option")).selected,checkClone:false,scriptEval:false,noCloneEvent:true,boxModel:null}; -b.type="text/javascript";try{b.appendChild(r.createTextNode("window."+f+"=1;"))}catch(j){}a.insertBefore(b,a.firstChild);if(z[f]){c.support.scriptEval=true;delete z[f]}a.removeChild(b);if(d.attachEvent&&d.fireEvent){d.attachEvent("onclick",function n(){c.support.noCloneEvent=false;d.detachEvent("onclick",n)});d.cloneNode(true).fireEvent("onclick")}d=r.createElement("div");d.innerHTML="<input type='radio' name='radiotest' checked='checked'/>";a=r.createDocumentFragment();a.appendChild(d.firstChild); -c.support.checkClone=a.cloneNode(true).cloneNode(true).lastChild.checked;c(function(){var n=r.createElement("div");n.style.width=n.style.paddingLeft="1px";r.body.appendChild(n);c.boxModel=c.support.boxModel=n.offsetWidth===2;r.body.removeChild(n).style.display="none"});a=function(n){var o=r.createElement("div");n="on"+n;var m=n in o;if(!m){o.setAttribute(n,"return;");m=typeof o[n]==="function"}return m};c.support.submitBubbles=a("submit");c.support.changeBubbles=a("change");a=b=d=e=i=null}})();c.props= -{"for":"htmlFor","class":"className",readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",colspan:"colSpan",tabindex:"tabIndex",usemap:"useMap",frameborder:"frameBorder"};var G="jQuery"+J(),Ua=0,xa={},Va={};c.extend({cache:{},expando:G,noData:{embed:true,object:true,applet:true},data:function(a,b,d){if(!(a.nodeName&&c.noData[a.nodeName.toLowerCase()])){a=a==z?xa:a;var f=a[G],e=c.cache;if(!b&&!f)return null;f||(f=++Ua);if(typeof b==="object"){a[G]=f;e=e[f]=c.extend(true, -{},b)}else e=e[f]?e[f]:typeof d==="undefined"?Va:(e[f]={});if(d!==v){a[G]=f;e[b]=d}return typeof b==="string"?e[b]:e}},removeData:function(a,b){if(!(a.nodeName&&c.noData[a.nodeName.toLowerCase()])){a=a==z?xa:a;var d=a[G],f=c.cache,e=f[d];if(b){if(e){delete e[b];c.isEmptyObject(e)&&c.removeData(a)}}else{try{delete a[G]}catch(i){a.removeAttribute&&a.removeAttribute(G)}delete f[d]}}}});c.fn.extend({data:function(a,b){if(typeof a==="undefined"&&this.length)return c.data(this[0]);else if(typeof a==="object")return this.each(function(){c.data(this, -a)});var d=a.split(".");d[1]=d[1]?"."+d[1]:"";if(b===v){var f=this.triggerHandler("getData"+d[1]+"!",[d[0]]);if(f===v&&this.length)f=c.data(this[0],a);return f===v&&d[1]?this.data(d[0]):f}else return this.trigger("setData"+d[1]+"!",[d[0],b]).each(function(){c.data(this,a,b)})},removeData:function(a){return this.each(function(){c.removeData(this,a)})}});c.extend({queue:function(a,b,d){if(a){b=(b||"fx")+"queue";var f=c.data(a,b);if(!d)return f||[];if(!f||c.isArray(d))f=c.data(a,b,c.makeArray(d));else f.push(d); -return f}},dequeue:function(a,b){b=b||"fx";var d=c.queue(a,b),f=d.shift();if(f==="inprogress")f=d.shift();if(f){b==="fx"&&d.unshift("inprogress");f.call(a,function(){c.dequeue(a,b)})}}});c.fn.extend({queue:function(a,b){if(typeof a!=="string"){b=a;a="fx"}if(b===v)return c.queue(this[0],a);return this.each(function(){var d=c.queue(this,a,b);a==="fx"&&d[0]!=="inprogress"&&c.dequeue(this,a)})},dequeue:function(a){return this.each(function(){c.dequeue(this,a)})},delay:function(a,b){a=c.fx?c.fx.speeds[a]|| -a:a;b=b||"fx";return this.queue(b,function(){var d=this;setTimeout(function(){c.dequeue(d,b)},a)})},clearQueue:function(a){return this.queue(a||"fx",[])}});var ya=/[\n\t]/g,ca=/\s+/,Wa=/\r/g,Xa=/href|src|style/,Ya=/(button|input)/i,Za=/(button|input|object|select|textarea)/i,$a=/^(a|area)$/i,za=/radio|checkbox/;c.fn.extend({attr:function(a,b){return X(this,a,b,true,c.attr)},removeAttr:function(a){return this.each(function(){c.attr(this,a,"");this.nodeType===1&&this.removeAttribute(a)})},addClass:function(a){if(c.isFunction(a))return this.each(function(o){var m= -c(this);m.addClass(a.call(this,o,m.attr("class")))});if(a&&typeof a==="string")for(var b=(a||"").split(ca),d=0,f=this.length;d<f;d++){var e=this[d];if(e.nodeType===1)if(e.className)for(var i=" "+e.className+" ",j=0,n=b.length;j<n;j++){if(i.indexOf(" "+b[j]+" ")<0)e.className+=" "+b[j]}else e.className=a}return this},removeClass:function(a){if(c.isFunction(a))return this.each(function(o){var m=c(this);m.removeClass(a.call(this,o,m.attr("class")))});if(a&&typeof a==="string"||a===v)for(var b=(a||"").split(ca), -d=0,f=this.length;d<f;d++){var e=this[d];if(e.nodeType===1&&e.className)if(a){for(var i=(" "+e.className+" ").replace(ya," "),j=0,n=b.length;j<n;j++)i=i.replace(" "+b[j]+" "," ");e.className=i.substring(1,i.length-1)}else e.className=""}return this},toggleClass:function(a,b){var d=typeof a,f=typeof b==="boolean";if(c.isFunction(a))return this.each(function(e){var i=c(this);i.toggleClass(a.call(this,e,i.attr("class"),b),b)});return this.each(function(){if(d==="string")for(var e,i=0,j=c(this),n=b,o= -a.split(ca);e=o[i++];){n=f?n:!j.hasClass(e);j[n?"addClass":"removeClass"](e)}else if(d==="undefined"||d==="boolean"){this.className&&c.data(this,"__className__",this.className);this.className=this.className||a===false?"":c.data(this,"__className__")||""}})},hasClass:function(a){a=" "+a+" ";for(var b=0,d=this.length;b<d;b++)if((" "+this[b].className+" ").replace(ya," ").indexOf(a)>-1)return true;return false},val:function(a){if(a===v){var b=this[0];if(b){if(c.nodeName(b,"option"))return(b.attributes.value|| -{}).specified?b.value:b.text;if(c.nodeName(b,"select")){var d=b.selectedIndex,f=[],e=b.options;b=b.type==="select-one";if(d<0)return null;var i=b?d:0;for(d=b?d+1:e.length;i<d;i++){var j=e[i];if(j.selected){a=c(j).val();if(b)return a;f.push(a)}}return f}if(za.test(b.type)&&!c.support.checkOn)return b.getAttribute("value")===null?"on":b.value;return(b.value||"").replace(Wa,"")}return v}var n=c.isFunction(a);return this.each(function(o){var m=c(this),s=a;if(this.nodeType===1){if(n)s=a.call(this,o,m.val()); -if(typeof s==="number")s+="";if(c.isArray(s)&&za.test(this.type))this.checked=c.inArray(m.val(),s)>=0;else if(c.nodeName(this,"select")){var x=c.makeArray(s);c("option",this).each(function(){this.selected=c.inArray(c(this).val(),x)>=0});if(!x.length)this.selectedIndex=-1}else this.value=s}})}});c.extend({attrFn:{val:true,css:true,html:true,text:true,data:true,width:true,height:true,offset:true},attr:function(a,b,d,f){if(!a||a.nodeType===3||a.nodeType===8)return v;if(f&&b in c.attrFn)return c(a)[b](d); -f=a.nodeType!==1||!c.isXMLDoc(a);var e=d!==v;b=f&&c.props[b]||b;if(a.nodeType===1){var i=Xa.test(b);if(b in a&&f&&!i){if(e){b==="type"&&Ya.test(a.nodeName)&&a.parentNode&&c.error("type property can't be changed");a[b]=d}if(c.nodeName(a,"form")&&a.getAttributeNode(b))return a.getAttributeNode(b).nodeValue;if(b==="tabIndex")return(b=a.getAttributeNode("tabIndex"))&&b.specified?b.value:Za.test(a.nodeName)||$a.test(a.nodeName)&&a.href?0:v;return a[b]}if(!c.support.style&&f&&b==="style"){if(e)a.style.cssText= -""+d;return a.style.cssText}e&&a.setAttribute(b,""+d);a=!c.support.hrefNormalized&&f&&i?a.getAttribute(b,2):a.getAttribute(b);return a===null?v:a}return c.style(a,b,d)}});var ab=function(a){return a.replace(/[^\w\s\.\|`]/g,function(b){return"\\"+b})};c.event={add:function(a,b,d,f){if(!(a.nodeType===3||a.nodeType===8)){if(a.setInterval&&a!==z&&!a.frameElement)a=z;if(!d.guid)d.guid=c.guid++;if(f!==v){d=c.proxy(d);d.data=f}var e=c.data(a,"events")||c.data(a,"events",{}),i=c.data(a,"handle"),j;if(!i){j= -function(){return typeof c!=="undefined"&&!c.event.triggered?c.event.handle.apply(j.elem,arguments):v};i=c.data(a,"handle",j)}if(i){i.elem=a;b=b.split(/\s+/);for(var n,o=0;n=b[o++];){var m=n.split(".");n=m.shift();if(o>1){d=c.proxy(d);if(f!==v)d.data=f}d.type=m.slice(0).sort().join(".");var s=e[n],x=this.special[n]||{};if(!s){s=e[n]={};if(!x.setup||x.setup.call(a,f,m,d)===false)if(a.addEventListener)a.addEventListener(n,i,false);else a.attachEvent&&a.attachEvent("on"+n,i)}if(x.add)if((m=x.add.call(a, -d,f,m,s))&&c.isFunction(m)){m.guid=m.guid||d.guid;m.data=m.data||d.data;m.type=m.type||d.type;d=m}s[d.guid]=d;this.global[n]=true}a=null}}},global:{},remove:function(a,b,d){if(!(a.nodeType===3||a.nodeType===8)){var f=c.data(a,"events"),e,i,j;if(f){if(b===v||typeof b==="string"&&b.charAt(0)===".")for(i in f)this.remove(a,i+(b||""));else{if(b.type){d=b.handler;b=b.type}b=b.split(/\s+/);for(var n=0;i=b[n++];){var o=i.split(".");i=o.shift();var m=!o.length,s=c.map(o.slice(0).sort(),ab);s=new RegExp("(^|\\.)"+ -s.join("\\.(?:.*\\.)?")+"(\\.|$)");var x=this.special[i]||{};if(f[i]){if(d){j=f[i][d.guid];delete f[i][d.guid]}else for(var A in f[i])if(m||s.test(f[i][A].type))delete f[i][A];x.remove&&x.remove.call(a,o,j);for(e in f[i])break;if(!e){if(!x.teardown||x.teardown.call(a,o)===false)if(a.removeEventListener)a.removeEventListener(i,c.data(a,"handle"),false);else a.detachEvent&&a.detachEvent("on"+i,c.data(a,"handle"));e=null;delete f[i]}}}}for(e in f)break;if(!e){if(A=c.data(a,"handle"))A.elem=null;c.removeData(a, -"events");c.removeData(a,"handle")}}}},trigger:function(a,b,d,f){var e=a.type||a;if(!f){a=typeof a==="object"?a[G]?a:c.extend(c.Event(e),a):c.Event(e);if(e.indexOf("!")>=0){a.type=e=e.slice(0,-1);a.exclusive=true}if(!d){a.stopPropagation();this.global[e]&&c.each(c.cache,function(){this.events&&this.events[e]&&c.event.trigger(a,b,this.handle.elem)})}if(!d||d.nodeType===3||d.nodeType===8)return v;a.result=v;a.target=d;b=c.makeArray(b);b.unshift(a)}a.currentTarget=d;(f=c.data(d,"handle"))&&f.apply(d, -b);f=d.parentNode||d.ownerDocument;try{if(!(d&&d.nodeName&&c.noData[d.nodeName.toLowerCase()]))if(d["on"+e]&&d["on"+e].apply(d,b)===false)a.result=false}catch(i){}if(!a.isPropagationStopped()&&f)c.event.trigger(a,b,f,true);else if(!a.isDefaultPrevented()){d=a.target;var j;if(!(c.nodeName(d,"a")&&e==="click")&&!(d&&d.nodeName&&c.noData[d.nodeName.toLowerCase()])){try{if(d[e]){if(j=d["on"+e])d["on"+e]=null;this.triggered=true;d[e]()}}catch(n){}if(j)d["on"+e]=j;this.triggered=false}}},handle:function(a){var b, -d;a=arguments[0]=c.event.fix(a||z.event);a.currentTarget=this;d=a.type.split(".");a.type=d.shift();b=!d.length&&!a.exclusive;var f=new RegExp("(^|\\.)"+d.slice(0).sort().join("\\.(?:.*\\.)?")+"(\\.|$)");d=(c.data(this,"events")||{})[a.type];for(var e in d){var i=d[e];if(b||f.test(i.type)){a.handler=i;a.data=i.data;i=i.apply(this,arguments);if(i!==v){a.result=i;if(i===false){a.preventDefault();a.stopPropagation()}}if(a.isImmediatePropagationStopped())break}}return a.result},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "), -fix:function(a){if(a[G])return a;var b=a;a=c.Event(b);for(var d=this.props.length,f;d;){f=this.props[--d];a[f]=b[f]}if(!a.target)a.target=a.srcElement||r;if(a.target.nodeType===3)a.target=a.target.parentNode;if(!a.relatedTarget&&a.fromElement)a.relatedTarget=a.fromElement===a.target?a.toElement:a.fromElement;if(a.pageX==null&&a.clientX!=null){b=r.documentElement;d=r.body;a.pageX=a.clientX+(b&&b.scrollLeft||d&&d.scrollLeft||0)-(b&&b.clientLeft||d&&d.clientLeft||0);a.pageY=a.clientY+(b&&b.scrollTop|| -d&&d.scrollTop||0)-(b&&b.clientTop||d&&d.clientTop||0)}if(!a.which&&(a.charCode||a.charCode===0?a.charCode:a.keyCode))a.which=a.charCode||a.keyCode;if(!a.metaKey&&a.ctrlKey)a.metaKey=a.ctrlKey;if(!a.which&&a.button!==v)a.which=a.button&1?1:a.button&2?3:a.button&4?2:0;return a},guid:1E8,proxy:c.proxy,special:{ready:{setup:c.bindReady,teardown:c.noop},live:{add:function(a,b){c.extend(a,b||{});a.guid+=b.selector+b.live;b.liveProxy=a;c.event.add(this,b.live,na,b)},remove:function(a){if(a.length){var b= -0,d=new RegExp("(^|\\.)"+a[0]+"(\\.|$)");c.each(c.data(this,"events").live||{},function(){d.test(this.type)&&b++});b<1&&c.event.remove(this,a[0],na)}},special:{}},beforeunload:{setup:function(a,b,d){if(this.setInterval)this.onbeforeunload=d;return false},teardown:function(a,b){if(this.onbeforeunload===b)this.onbeforeunload=null}}}};c.Event=function(a){if(!this.preventDefault)return new c.Event(a);if(a&&a.type){this.originalEvent=a;this.type=a.type}else this.type=a;this.timeStamp=J();this[G]=true}; -c.Event.prototype={preventDefault:function(){this.isDefaultPrevented=Z;var a=this.originalEvent;if(a){a.preventDefault&&a.preventDefault();a.returnValue=false}},stopPropagation:function(){this.isPropagationStopped=Z;var a=this.originalEvent;if(a){a.stopPropagation&&a.stopPropagation();a.cancelBubble=true}},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=Z;this.stopPropagation()},isDefaultPrevented:Y,isPropagationStopped:Y,isImmediatePropagationStopped:Y};var Aa=function(a){for(var b= -a.relatedTarget;b&&b!==this;)try{b=b.parentNode}catch(d){break}if(b!==this){a.type=a.data;c.event.handle.apply(this,arguments)}},Ba=function(a){a.type=a.data;c.event.handle.apply(this,arguments)};c.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(a,b){c.event.special[a]={setup:function(d){c.event.add(this,b,d&&d.selector?Ba:Aa,a)},teardown:function(d){c.event.remove(this,b,d&&d.selector?Ba:Aa)}}});if(!c.support.submitBubbles)c.event.special.submit={setup:function(a,b,d){if(this.nodeName.toLowerCase()!== -"form"){c.event.add(this,"click.specialSubmit."+d.guid,function(f){var e=f.target,i=e.type;if((i==="submit"||i==="image")&&c(e).closest("form").length)return ma("submit",this,arguments)});c.event.add(this,"keypress.specialSubmit."+d.guid,function(f){var e=f.target,i=e.type;if((i==="text"||i==="password")&&c(e).closest("form").length&&f.keyCode===13)return ma("submit",this,arguments)})}else return false},remove:function(a,b){c.event.remove(this,"click.specialSubmit"+(b?"."+b.guid:""));c.event.remove(this, -"keypress.specialSubmit"+(b?"."+b.guid:""))}};if(!c.support.changeBubbles){var da=/textarea|input|select/i;function Ca(a){var b=a.type,d=a.value;if(b==="radio"||b==="checkbox")d=a.checked;else if(b==="select-multiple")d=a.selectedIndex>-1?c.map(a.options,function(f){return f.selected}).join("-"):"";else if(a.nodeName.toLowerCase()==="select")d=a.selectedIndex;return d}function ea(a,b){var d=a.target,f,e;if(!(!da.test(d.nodeName)||d.readOnly)){f=c.data(d,"_change_data");e=Ca(d);if(a.type!=="focusout"|| -d.type!=="radio")c.data(d,"_change_data",e);if(!(f===v||e===f))if(f!=null||e){a.type="change";return c.event.trigger(a,b,d)}}}c.event.special.change={filters:{focusout:ea,click:function(a){var b=a.target,d=b.type;if(d==="radio"||d==="checkbox"||b.nodeName.toLowerCase()==="select")return ea.call(this,a)},keydown:function(a){var b=a.target,d=b.type;if(a.keyCode===13&&b.nodeName.toLowerCase()!=="textarea"||a.keyCode===32&&(d==="checkbox"||d==="radio")||d==="select-multiple")return ea.call(this,a)},beforeactivate:function(a){a= -a.target;a.nodeName.toLowerCase()==="input"&&a.type==="radio"&&c.data(a,"_change_data",Ca(a))}},setup:function(a,b,d){for(var f in T)c.event.add(this,f+".specialChange."+d.guid,T[f]);return da.test(this.nodeName)},remove:function(a,b){for(var d in T)c.event.remove(this,d+".specialChange"+(b?"."+b.guid:""),T[d]);return da.test(this.nodeName)}};var T=c.event.special.change.filters}r.addEventListener&&c.each({focus:"focusin",blur:"focusout"},function(a,b){function d(f){f=c.event.fix(f);f.type=b;return c.event.handle.call(this, -f)}c.event.special[b]={setup:function(){this.addEventListener(a,d,true)},teardown:function(){this.removeEventListener(a,d,true)}}});c.each(["bind","one"],function(a,b){c.fn[b]=function(d,f,e){if(typeof d==="object"){for(var i in d)this[b](i,f,d[i],e);return this}if(c.isFunction(f)){e=f;f=v}var j=b==="one"?c.proxy(e,function(n){c(this).unbind(n,j);return e.apply(this,arguments)}):e;return d==="unload"&&b!=="one"?this.one(d,f,e):this.each(function(){c.event.add(this,d,j,f)})}});c.fn.extend({unbind:function(a, -b){if(typeof a==="object"&&!a.preventDefault){for(var d in a)this.unbind(d,a[d]);return this}return this.each(function(){c.event.remove(this,a,b)})},trigger:function(a,b){return this.each(function(){c.event.trigger(a,b,this)})},triggerHandler:function(a,b){if(this[0]){a=c.Event(a);a.preventDefault();a.stopPropagation();c.event.trigger(a,b,this[0]);return a.result}},toggle:function(a){for(var b=arguments,d=1;d<b.length;)c.proxy(a,b[d++]);return this.click(c.proxy(a,function(f){var e=(c.data(this,"lastToggle"+ -a.guid)||0)%d;c.data(this,"lastToggle"+a.guid,e+1);f.preventDefault();return b[e].apply(this,arguments)||false}))},hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}});c.each(["live","die"],function(a,b){c.fn[b]=function(d,f,e){var i,j=0;if(c.isFunction(f)){e=f;f=v}for(d=(d||"").split(/\s+/);(i=d[j++])!=null;){i=i==="focus"?"focusin":i==="blur"?"focusout":i==="hover"?d.push("mouseleave")&&"mouseenter":i;b==="live"?c(this.context).bind(oa(i,this.selector),{data:f,selector:this.selector, -live:i},e):c(this.context).unbind(oa(i,this.selector),e?{guid:e.guid+this.selector+i}:null)}return this}});c.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error".split(" "),function(a,b){c.fn[b]=function(d){return d?this.bind(b,d):this.trigger(b)};if(c.attrFn)c.attrFn[b]=true});z.attachEvent&&!z.addEventListener&&z.attachEvent("onunload",function(){for(var a in c.cache)if(c.cache[a].handle)try{c.event.remove(c.cache[a].handle.elem)}catch(b){}}); -(function(){function a(g){for(var h="",k,l=0;g[l];l++){k=g[l];if(k.nodeType===3||k.nodeType===4)h+=k.nodeValue;else if(k.nodeType!==8)h+=a(k.childNodes)}return h}function b(g,h,k,l,q,p){q=0;for(var u=l.length;q<u;q++){var t=l[q];if(t){t=t[g];for(var y=false;t;){if(t.sizcache===k){y=l[t.sizset];break}if(t.nodeType===1&&!p){t.sizcache=k;t.sizset=q}if(t.nodeName.toLowerCase()===h){y=t;break}t=t[g]}l[q]=y}}}function d(g,h,k,l,q,p){q=0;for(var u=l.length;q<u;q++){var t=l[q];if(t){t=t[g];for(var y=false;t;){if(t.sizcache=== -k){y=l[t.sizset];break}if(t.nodeType===1){if(!p){t.sizcache=k;t.sizset=q}if(typeof h!=="string"){if(t===h){y=true;break}}else if(o.filter(h,[t]).length>0){y=t;break}}t=t[g]}l[q]=y}}}var f=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,e=0,i=Object.prototype.toString,j=false,n=true;[0,0].sort(function(){n=false;return 0});var o=function(g,h,k,l){k=k||[];var q=h=h||r;if(h.nodeType!==1&&h.nodeType!==9)return[];if(!g|| -typeof g!=="string")return k;for(var p=[],u,t,y,R,H=true,M=w(h),I=g;(f.exec(""),u=f.exec(I))!==null;){I=u[3];p.push(u[1]);if(u[2]){R=u[3];break}}if(p.length>1&&s.exec(g))if(p.length===2&&m.relative[p[0]])t=fa(p[0]+p[1],h);else for(t=m.relative[p[0]]?[h]:o(p.shift(),h);p.length;){g=p.shift();if(m.relative[g])g+=p.shift();t=fa(g,t)}else{if(!l&&p.length>1&&h.nodeType===9&&!M&&m.match.ID.test(p[0])&&!m.match.ID.test(p[p.length-1])){u=o.find(p.shift(),h,M);h=u.expr?o.filter(u.expr,u.set)[0]:u.set[0]}if(h){u= -l?{expr:p.pop(),set:A(l)}:o.find(p.pop(),p.length===1&&(p[0]==="~"||p[0]==="+")&&h.parentNode?h.parentNode:h,M);t=u.expr?o.filter(u.expr,u.set):u.set;if(p.length>0)y=A(t);else H=false;for(;p.length;){var D=p.pop();u=D;if(m.relative[D])u=p.pop();else D="";if(u==null)u=h;m.relative[D](y,u,M)}}else y=[]}y||(y=t);y||o.error(D||g);if(i.call(y)==="[object Array]")if(H)if(h&&h.nodeType===1)for(g=0;y[g]!=null;g++){if(y[g]&&(y[g]===true||y[g].nodeType===1&&E(h,y[g])))k.push(t[g])}else for(g=0;y[g]!=null;g++)y[g]&& -y[g].nodeType===1&&k.push(t[g]);else k.push.apply(k,y);else A(y,k);if(R){o(R,q,k,l);o.uniqueSort(k)}return k};o.uniqueSort=function(g){if(C){j=n;g.sort(C);if(j)for(var h=1;h<g.length;h++)g[h]===g[h-1]&&g.splice(h--,1)}return g};o.matches=function(g,h){return o(g,null,null,h)};o.find=function(g,h,k){var l,q;if(!g)return[];for(var p=0,u=m.order.length;p<u;p++){var t=m.order[p];if(q=m.leftMatch[t].exec(g)){var y=q[1];q.splice(1,1);if(y.substr(y.length-1)!=="\\"){q[1]=(q[1]||"").replace(/\\/g,"");l=m.find[t](q, -h,k);if(l!=null){g=g.replace(m.match[t],"");break}}}}l||(l=h.getElementsByTagName("*"));return{set:l,expr:g}};o.filter=function(g,h,k,l){for(var q=g,p=[],u=h,t,y,R=h&&h[0]&&w(h[0]);g&&h.length;){for(var H in m.filter)if((t=m.leftMatch[H].exec(g))!=null&&t[2]){var M=m.filter[H],I,D;D=t[1];y=false;t.splice(1,1);if(D.substr(D.length-1)!=="\\"){if(u===p)p=[];if(m.preFilter[H])if(t=m.preFilter[H](t,u,k,p,l,R)){if(t===true)continue}else y=I=true;if(t)for(var U=0;(D=u[U])!=null;U++)if(D){I=M(D,t,U,u);var Da= -l^!!I;if(k&&I!=null)if(Da)y=true;else u[U]=false;else if(Da){p.push(D);y=true}}if(I!==v){k||(u=p);g=g.replace(m.match[H],"");if(!y)return[];break}}}if(g===q)if(y==null)o.error(g);else break;q=g}return u};o.error=function(g){throw"Syntax error, unrecognized expression: "+g;};var m=o.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\))?/},leftMatch:{},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(g){return g.getAttribute("href")}},relative:{"+":function(g,h){var k=typeof h==="string",l=k&&!/\W/.test(h);k=k&&!l;if(l)h=h.toLowerCase();l=0;for(var q=g.length, -p;l<q;l++)if(p=g[l]){for(;(p=p.previousSibling)&&p.nodeType!==1;);g[l]=k||p&&p.nodeName.toLowerCase()===h?p||false:p===h}k&&o.filter(h,g,true)},">":function(g,h){var k=typeof h==="string";if(k&&!/\W/.test(h)){h=h.toLowerCase();for(var l=0,q=g.length;l<q;l++){var p=g[l];if(p){k=p.parentNode;g[l]=k.nodeName.toLowerCase()===h?k:false}}}else{l=0;for(q=g.length;l<q;l++)if(p=g[l])g[l]=k?p.parentNode:p.parentNode===h;k&&o.filter(h,g,true)}},"":function(g,h,k){var l=e++,q=d;if(typeof h==="string"&&!/\W/.test(h)){var p= -h=h.toLowerCase();q=b}q("parentNode",h,l,g,p,k)},"~":function(g,h,k){var l=e++,q=d;if(typeof h==="string"&&!/\W/.test(h)){var p=h=h.toLowerCase();q=b}q("previousSibling",h,l,g,p,k)}},find:{ID:function(g,h,k){if(typeof h.getElementById!=="undefined"&&!k)return(g=h.getElementById(g[1]))?[g]:[]},NAME:function(g,h){if(typeof h.getElementsByName!=="undefined"){var k=[];h=h.getElementsByName(g[1]);for(var l=0,q=h.length;l<q;l++)h[l].getAttribute("name")===g[1]&&k.push(h[l]);return k.length===0?null:k}}, -TAG:function(g,h){return h.getElementsByTagName(g[1])}},preFilter:{CLASS:function(g,h,k,l,q,p){g=" "+g[1].replace(/\\/g,"")+" ";if(p)return g;p=0;for(var u;(u=h[p])!=null;p++)if(u)if(q^(u.className&&(" "+u.className+" ").replace(/[\t\n]/g," ").indexOf(g)>=0))k||l.push(u);else if(k)h[p]=false;return false},ID:function(g){return g[1].replace(/\\/g,"")},TAG:function(g){return g[1].toLowerCase()},CHILD:function(g){if(g[1]==="nth"){var h=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2]==="even"&&"2n"||g[2]==="odd"&& -"2n+1"||!/\D/.test(g[2])&&"0n+"+g[2]||g[2]);g[2]=h[1]+(h[2]||1)-0;g[3]=h[3]-0}g[0]=e++;return g},ATTR:function(g,h,k,l,q,p){h=g[1].replace(/\\/g,"");if(!p&&m.attrMap[h])g[1]=m.attrMap[h];if(g[2]==="~=")g[4]=" "+g[4]+" ";return g},PSEUDO:function(g,h,k,l,q){if(g[1]==="not")if((f.exec(g[3])||"").length>1||/^\w/.test(g[3]))g[3]=o(g[3],null,null,h);else{g=o.filter(g[3],h,k,true^q);k||l.push.apply(l,g);return false}else if(m.match.POS.test(g[0])||m.match.CHILD.test(g[0]))return true;return g},POS:function(g){g.unshift(true); -return g}},filters:{enabled:function(g){return g.disabled===false&&g.type!=="hidden"},disabled:function(g){return g.disabled===true},checked:function(g){return g.checked===true},selected:function(g){return g.selected===true},parent:function(g){return!!g.firstChild},empty:function(g){return!g.firstChild},has:function(g,h,k){return!!o(k[3],g).length},header:function(g){return/h\d/i.test(g.nodeName)},text:function(g){return"text"===g.type},radio:function(g){return"radio"===g.type},checkbox:function(g){return"checkbox"=== -g.type},file:function(g){return"file"===g.type},password:function(g){return"password"===g.type},submit:function(g){return"submit"===g.type},image:function(g){return"image"===g.type},reset:function(g){return"reset"===g.type},button:function(g){return"button"===g.type||g.nodeName.toLowerCase()==="button"},input:function(g){return/input|select|textarea|button/i.test(g.nodeName)}},setFilters:{first:function(g,h){return h===0},last:function(g,h,k,l){return h===l.length-1},even:function(g,h){return h%2=== -0},odd:function(g,h){return h%2===1},lt:function(g,h,k){return h<k[3]-0},gt:function(g,h,k){return h>k[3]-0},nth:function(g,h,k){return k[3]-0===h},eq:function(g,h,k){return k[3]-0===h}},filter:{PSEUDO:function(g,h,k,l){var q=h[1],p=m.filters[q];if(p)return p(g,k,h,l);else if(q==="contains")return(g.textContent||g.innerText||a([g])||"").indexOf(h[3])>=0;else if(q==="not"){h=h[3];k=0;for(l=h.length;k<l;k++)if(h[k]===g)return false;return true}else o.error("Syntax error, unrecognized expression: "+ -q)},CHILD:function(g,h){var k=h[1],l=g;switch(k){case "only":case "first":for(;l=l.previousSibling;)if(l.nodeType===1)return false;if(k==="first")return true;l=g;case "last":for(;l=l.nextSibling;)if(l.nodeType===1)return false;return true;case "nth":k=h[2];var q=h[3];if(k===1&&q===0)return true;h=h[0];var p=g.parentNode;if(p&&(p.sizcache!==h||!g.nodeIndex)){var u=0;for(l=p.firstChild;l;l=l.nextSibling)if(l.nodeType===1)l.nodeIndex=++u;p.sizcache=h}g=g.nodeIndex-q;return k===0?g===0:g%k===0&&g/k>= -0}},ID:function(g,h){return g.nodeType===1&&g.getAttribute("id")===h},TAG:function(g,h){return h==="*"&&g.nodeType===1||g.nodeName.toLowerCase()===h},CLASS:function(g,h){return(" "+(g.className||g.getAttribute("class"))+" ").indexOf(h)>-1},ATTR:function(g,h){var k=h[1];g=m.attrHandle[k]?m.attrHandle[k](g):g[k]!=null?g[k]:g.getAttribute(k);k=g+"";var l=h[2];h=h[4];return g==null?l==="!=":l==="="?k===h:l==="*="?k.indexOf(h)>=0:l==="~="?(" "+k+" ").indexOf(h)>=0:!h?k&&g!==false:l==="!="?k!==h:l==="^="? -k.indexOf(h)===0:l==="$="?k.substr(k.length-h.length)===h:l==="|="?k===h||k.substr(0,h.length+1)===h+"-":false},POS:function(g,h,k,l){var q=m.setFilters[h[2]];if(q)return q(g,k,h,l)}}},s=m.match.POS;for(var x in m.match){m.match[x]=new RegExp(m.match[x].source+/(?![^\[]*\])(?![^\(]*\))/.source);m.leftMatch[x]=new RegExp(/(^(?:.|\r|\n)*?)/.source+m.match[x].source.replace(/\\(\d+)/g,function(g,h){return"\\"+(h-0+1)}))}var A=function(g,h){g=Array.prototype.slice.call(g,0);if(h){h.push.apply(h,g);return h}return g}; -try{Array.prototype.slice.call(r.documentElement.childNodes,0)}catch(B){A=function(g,h){h=h||[];if(i.call(g)==="[object Array]")Array.prototype.push.apply(h,g);else if(typeof g.length==="number")for(var k=0,l=g.length;k<l;k++)h.push(g[k]);else for(k=0;g[k];k++)h.push(g[k]);return h}}var C;if(r.documentElement.compareDocumentPosition)C=function(g,h){if(!g.compareDocumentPosition||!h.compareDocumentPosition){if(g==h)j=true;return g.compareDocumentPosition?-1:1}g=g.compareDocumentPosition(h)&4?-1:g=== -h?0:1;if(g===0)j=true;return g};else if("sourceIndex"in r.documentElement)C=function(g,h){if(!g.sourceIndex||!h.sourceIndex){if(g==h)j=true;return g.sourceIndex?-1:1}g=g.sourceIndex-h.sourceIndex;if(g===0)j=true;return g};else if(r.createRange)C=function(g,h){if(!g.ownerDocument||!h.ownerDocument){if(g==h)j=true;return g.ownerDocument?-1:1}var k=g.ownerDocument.createRange(),l=h.ownerDocument.createRange();k.setStart(g,0);k.setEnd(g,0);l.setStart(h,0);l.setEnd(h,0);g=k.compareBoundaryPoints(Range.START_TO_END, -l);if(g===0)j=true;return g};(function(){var g=r.createElement("div"),h="script"+(new Date).getTime();g.innerHTML="<a name='"+h+"'/>";var k=r.documentElement;k.insertBefore(g,k.firstChild);if(r.getElementById(h)){m.find.ID=function(l,q,p){if(typeof q.getElementById!=="undefined"&&!p)return(q=q.getElementById(l[1]))?q.id===l[1]||typeof q.getAttributeNode!=="undefined"&&q.getAttributeNode("id").nodeValue===l[1]?[q]:v:[]};m.filter.ID=function(l,q){var p=typeof l.getAttributeNode!=="undefined"&&l.getAttributeNode("id"); -return l.nodeType===1&&p&&p.nodeValue===q}}k.removeChild(g);k=g=null})();(function(){var g=r.createElement("div");g.appendChild(r.createComment(""));if(g.getElementsByTagName("*").length>0)m.find.TAG=function(h,k){k=k.getElementsByTagName(h[1]);if(h[1]==="*"){h=[];for(var l=0;k[l];l++)k[l].nodeType===1&&h.push(k[l]);k=h}return k};g.innerHTML="<a href='#'></a>";if(g.firstChild&&typeof g.firstChild.getAttribute!=="undefined"&&g.firstChild.getAttribute("href")!=="#")m.attrHandle.href=function(h){return h.getAttribute("href", -2)};g=null})();r.querySelectorAll&&function(){var g=o,h=r.createElement("div");h.innerHTML="<p class='TEST'></p>";if(!(h.querySelectorAll&&h.querySelectorAll(".TEST").length===0)){o=function(l,q,p,u){q=q||r;if(!u&&q.nodeType===9&&!w(q))try{return A(q.querySelectorAll(l),p)}catch(t){}return g(l,q,p,u)};for(var k in g)o[k]=g[k];h=null}}();(function(){var g=r.createElement("div");g.innerHTML="<div class='test e'></div><div class='test'></div>";if(!(!g.getElementsByClassName||g.getElementsByClassName("e").length=== -0)){g.lastChild.className="e";if(g.getElementsByClassName("e").length!==1){m.order.splice(1,0,"CLASS");m.find.CLASS=function(h,k,l){if(typeof k.getElementsByClassName!=="undefined"&&!l)return k.getElementsByClassName(h[1])};g=null}}})();var E=r.compareDocumentPosition?function(g,h){return g.compareDocumentPosition(h)&16}:function(g,h){return g!==h&&(g.contains?g.contains(h):true)},w=function(g){return(g=(g?g.ownerDocument||g:0).documentElement)?g.nodeName!=="HTML":false},fa=function(g,h){var k=[], -l="",q;for(h=h.nodeType?[h]:h;q=m.match.PSEUDO.exec(g);){l+=q[0];g=g.replace(m.match.PSEUDO,"")}g=m.relative[g]?g+"*":g;q=0;for(var p=h.length;q<p;q++)o(g,h[q],k);return o.filter(l,k)};c.find=o;c.expr=o.selectors;c.expr[":"]=c.expr.filters;c.unique=o.uniqueSort;c.getText=a;c.isXMLDoc=w;c.contains=E})();var bb=/Until$/,cb=/^(?:parents|prevUntil|prevAll)/,db=/,/;Q=Array.prototype.slice;var Ea=function(a,b,d){if(c.isFunction(b))return c.grep(a,function(e,i){return!!b.call(e,i,e)===d});else if(b.nodeType)return c.grep(a, -function(e){return e===b===d});else if(typeof b==="string"){var f=c.grep(a,function(e){return e.nodeType===1});if(Qa.test(b))return c.filter(b,f,!d);else b=c.filter(b,f)}return c.grep(a,function(e){return c.inArray(e,b)>=0===d})};c.fn.extend({find:function(a){for(var b=this.pushStack("","find",a),d=0,f=0,e=this.length;f<e;f++){d=b.length;c.find(a,this[f],b);if(f>0)for(var i=d;i<b.length;i++)for(var j=0;j<d;j++)if(b[j]===b[i]){b.splice(i--,1);break}}return b},has:function(a){var b=c(a);return this.filter(function(){for(var d= -0,f=b.length;d<f;d++)if(c.contains(this,b[d]))return true})},not:function(a){return this.pushStack(Ea(this,a,false),"not",a)},filter:function(a){return this.pushStack(Ea(this,a,true),"filter",a)},is:function(a){return!!a&&c.filter(a,this).length>0},closest:function(a,b){if(c.isArray(a)){var d=[],f=this[0],e,i={},j;if(f&&a.length){e=0;for(var n=a.length;e<n;e++){j=a[e];i[j]||(i[j]=c.expr.match.POS.test(j)?c(j,b||this.context):j)}for(;f&&f.ownerDocument&&f!==b;){for(j in i){e=i[j];if(e.jquery?e.index(f)> --1:c(f).is(e)){d.push({selector:j,elem:f});delete i[j]}}f=f.parentNode}}return d}var o=c.expr.match.POS.test(a)?c(a,b||this.context):null;return this.map(function(m,s){for(;s&&s.ownerDocument&&s!==b;){if(o?o.index(s)>-1:c(s).is(a))return s;s=s.parentNode}return null})},index:function(a){if(!a||typeof a==="string")return c.inArray(this[0],a?c(a):this.parent().children());return c.inArray(a.jquery?a[0]:a,this)},add:function(a,b){a=typeof a==="string"?c(a,b||this.context):c.makeArray(a);b=c.merge(this.get(), -a);return this.pushStack(pa(a[0])||pa(b[0])?b:c.unique(b))},andSelf:function(){return this.add(this.prevObject)}});c.each({parent:function(a){return(a=a.parentNode)&&a.nodeType!==11?a:null},parents:function(a){return c.dir(a,"parentNode")},parentsUntil:function(a,b,d){return c.dir(a,"parentNode",d)},next:function(a){return c.nth(a,2,"nextSibling")},prev:function(a){return c.nth(a,2,"previousSibling")},nextAll:function(a){return c.dir(a,"nextSibling")},prevAll:function(a){return c.dir(a,"previousSibling")}, -nextUntil:function(a,b,d){return c.dir(a,"nextSibling",d)},prevUntil:function(a,b,d){return c.dir(a,"previousSibling",d)},siblings:function(a){return c.sibling(a.parentNode.firstChild,a)},children:function(a){return c.sibling(a.firstChild)},contents:function(a){return c.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:c.makeArray(a.childNodes)}},function(a,b){c.fn[a]=function(d,f){var e=c.map(this,b,d);bb.test(a)||(f=d);if(f&&typeof f==="string")e=c.filter(f,e);e=this.length>1?c.unique(e): -e;if((this.length>1||db.test(f))&&cb.test(a))e=e.reverse();return this.pushStack(e,a,Q.call(arguments).join(","))}});c.extend({filter:function(a,b,d){if(d)a=":not("+a+")";return c.find.matches(a,b)},dir:function(a,b,d){var f=[];for(a=a[b];a&&a.nodeType!==9&&(d===v||a.nodeType!==1||!c(a).is(d));){a.nodeType===1&&f.push(a);a=a[b]}return f},nth:function(a,b,d){b=b||1;for(var f=0;a;a=a[d])if(a.nodeType===1&&++f===b)break;return a},sibling:function(a,b){for(var d=[];a;a=a.nextSibling)a.nodeType===1&&a!== -b&&d.push(a);return d}});var Fa=/ jQuery\d+="(?:\d+|null)"/g,V=/^\s+/,Ga=/(<([\w:]+)[^>]*?)\/>/g,eb=/^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i,Ha=/<([\w:]+)/,fb=/<tbody/i,gb=/<|&\w+;/,sa=/checked\s*(?:[^=]|=\s*.checked.)/i,Ia=function(a,b,d){return eb.test(d)?a:b+"></"+d+">"},F={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"], -col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],area:[1,"<map>","</map>"],_default:[0,"",""]};F.optgroup=F.option;F.tbody=F.tfoot=F.colgroup=F.caption=F.thead;F.th=F.td;if(!c.support.htmlSerialize)F._default=[1,"div<div>","</div>"];c.fn.extend({text:function(a){if(c.isFunction(a))return this.each(function(b){var d=c(this);d.text(a.call(this,b,d.text()))});if(typeof a!=="object"&&a!==v)return this.empty().append((this[0]&&this[0].ownerDocument||r).createTextNode(a));return c.getText(this)}, -wrapAll:function(a){if(c.isFunction(a))return this.each(function(d){c(this).wrapAll(a.call(this,d))});if(this[0]){var b=c(a,this[0].ownerDocument).eq(0).clone(true);this[0].parentNode&&b.insertBefore(this[0]);b.map(function(){for(var d=this;d.firstChild&&d.firstChild.nodeType===1;)d=d.firstChild;return d}).append(this)}return this},wrapInner:function(a){if(c.isFunction(a))return this.each(function(b){c(this).wrapInner(a.call(this,b))});return this.each(function(){var b=c(this),d=b.contents();d.length? -d.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){c(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){c.nodeName(this,"body")||c(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments, -false,function(b){this.parentNode.insertBefore(b,this)});else if(arguments.length){var a=c(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,this.nextSibling)});else if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,c(arguments[0]).toArray());return a}},clone:function(a){var b=this.map(function(){if(!c.support.noCloneEvent&& -!c.isXMLDoc(this)){var d=this.outerHTML,f=this.ownerDocument;if(!d){d=f.createElement("div");d.appendChild(this.cloneNode(true));d=d.innerHTML}return c.clean([d.replace(Fa,"").replace(V,"")],f)[0]}else return this.cloneNode(true)});if(a===true){qa(this,b);qa(this.find("*"),b.find("*"))}return b},html:function(a){if(a===v)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(Fa,""):null;else if(typeof a==="string"&&!/<script/i.test(a)&&(c.support.leadingWhitespace||!V.test(a))&&!F[(Ha.exec(a)|| -["",""])[1].toLowerCase()]){a=a.replace(Ga,Ia);try{for(var b=0,d=this.length;b<d;b++)if(this[b].nodeType===1){c.cleanData(this[b].getElementsByTagName("*"));this[b].innerHTML=a}}catch(f){this.empty().append(a)}}else c.isFunction(a)?this.each(function(e){var i=c(this),j=i.html();i.empty().append(function(){return a.call(this,e,j)})}):this.empty().append(a);return this},replaceWith:function(a){if(this[0]&&this[0].parentNode){if(c.isFunction(a))return this.each(function(b){var d=c(this),f=d.html();d.replaceWith(a.call(this, -b,f))});else a=c(a).detach();return this.each(function(){var b=this.nextSibling,d=this.parentNode;c(this).remove();b?c(b).before(a):c(d).append(a)})}else return this.pushStack(c(c.isFunction(a)?a():a),"replaceWith",a)},detach:function(a){return this.remove(a,true)},domManip:function(a,b,d){function f(s){return c.nodeName(s,"table")?s.getElementsByTagName("tbody")[0]||s.appendChild(s.ownerDocument.createElement("tbody")):s}var e,i,j=a[0],n=[];if(!c.support.checkClone&&arguments.length===3&&typeof j=== -"string"&&sa.test(j))return this.each(function(){c(this).domManip(a,b,d,true)});if(c.isFunction(j))return this.each(function(s){var x=c(this);a[0]=j.call(this,s,b?x.html():v);x.domManip(a,b,d)});if(this[0]){e=a[0]&&a[0].parentNode&&a[0].parentNode.nodeType===11?{fragment:a[0].parentNode}:ra(a,this,n);if(i=e.fragment.firstChild){b=b&&c.nodeName(i,"tr");for(var o=0,m=this.length;o<m;o++)d.call(b?f(this[o],i):this[o],e.cacheable||this.length>1||o>0?e.fragment.cloneNode(true):e.fragment)}n&&c.each(n, -Ma)}return this}});c.fragments={};c.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){c.fn[a]=function(d){var f=[];d=c(d);for(var e=0,i=d.length;e<i;e++){var j=(e>0?this.clone(true):this).get();c.fn[b].apply(c(d[e]),j);f=f.concat(j)}return this.pushStack(f,a,d.selector)}});c.each({remove:function(a,b){if(!a||c.filter(a,[this]).length){if(!b&&this.nodeType===1){c.cleanData(this.getElementsByTagName("*"));c.cleanData([this])}this.parentNode&& -this.parentNode.removeChild(this)}},empty:function(){for(this.nodeType===1&&c.cleanData(this.getElementsByTagName("*"));this.firstChild;)this.removeChild(this.firstChild)}},function(a,b){c.fn[a]=function(){return this.each(b,arguments)}});c.extend({clean:function(a,b,d,f){b=b||r;if(typeof b.createElement==="undefined")b=b.ownerDocument||b[0]&&b[0].ownerDocument||r;var e=[];c.each(a,function(i,j){if(typeof j==="number")j+="";if(j){if(typeof j==="string"&&!gb.test(j))j=b.createTextNode(j);else if(typeof j=== -"string"){j=j.replace(Ga,Ia);var n=(Ha.exec(j)||["",""])[1].toLowerCase(),o=F[n]||F._default,m=o[0];i=b.createElement("div");for(i.innerHTML=o[1]+j+o[2];m--;)i=i.lastChild;if(!c.support.tbody){m=fb.test(j);n=n==="table"&&!m?i.firstChild&&i.firstChild.childNodes:o[1]==="<table>"&&!m?i.childNodes:[];for(o=n.length-1;o>=0;--o)c.nodeName(n[o],"tbody")&&!n[o].childNodes.length&&n[o].parentNode.removeChild(n[o])}!c.support.leadingWhitespace&&V.test(j)&&i.insertBefore(b.createTextNode(V.exec(j)[0]),i.firstChild); -j=c.makeArray(i.childNodes)}if(j.nodeType)e.push(j);else e=c.merge(e,j)}});if(d)for(a=0;e[a];a++)if(f&&c.nodeName(e[a],"script")&&(!e[a].type||e[a].type.toLowerCase()==="text/javascript"))f.push(e[a].parentNode?e[a].parentNode.removeChild(e[a]):e[a]);else{e[a].nodeType===1&&e.splice.apply(e,[a+1,0].concat(c.makeArray(e[a].getElementsByTagName("script"))));d.appendChild(e[a])}return e},cleanData:function(a){for(var b=0,d;(d=a[b])!=null;b++){c.event.remove(d);c.removeData(d)}}});var hb=/z-?index|font-?weight|opacity|zoom|line-?height/i, -Ja=/alpha\([^)]*\)/,Ka=/opacity=([^)]*)/,ga=/float/i,ha=/-([a-z])/ig,ib=/([A-Z])/g,jb=/^-?\d+(?:px)?$/i,kb=/^-?\d/,lb={position:"absolute",visibility:"hidden",display:"block"},mb=["Left","Right"],nb=["Top","Bottom"],ob=r.defaultView&&r.defaultView.getComputedStyle,La=c.support.cssFloat?"cssFloat":"styleFloat",ia=function(a,b){return b.toUpperCase()};c.fn.css=function(a,b){return X(this,a,b,true,function(d,f,e){if(e===v)return c.curCSS(d,f);if(typeof e==="number"&&!hb.test(f))e+="px";c.style(d,f,e)})}; -c.extend({style:function(a,b,d){if(!a||a.nodeType===3||a.nodeType===8)return v;if((b==="width"||b==="height")&&parseFloat(d)<0)d=v;var f=a.style||a,e=d!==v;if(!c.support.opacity&&b==="opacity"){if(e){f.zoom=1;b=parseInt(d,10)+""==="NaN"?"":"alpha(opacity="+d*100+")";a=f.filter||c.curCSS(a,"filter")||"";f.filter=Ja.test(a)?a.replace(Ja,b):b}return f.filter&&f.filter.indexOf("opacity=")>=0?parseFloat(Ka.exec(f.filter)[1])/100+"":""}if(ga.test(b))b=La;b=b.replace(ha,ia);if(e)f[b]=d;return f[b]},css:function(a, -b,d,f){if(b==="width"||b==="height"){var e,i=b==="width"?mb:nb;function j(){e=b==="width"?a.offsetWidth:a.offsetHeight;f!=="border"&&c.each(i,function(){f||(e-=parseFloat(c.curCSS(a,"padding"+this,true))||0);if(f==="margin")e+=parseFloat(c.curCSS(a,"margin"+this,true))||0;else e-=parseFloat(c.curCSS(a,"border"+this+"Width",true))||0})}a.offsetWidth!==0?j():c.swap(a,lb,j);return Math.max(0,Math.round(e))}return c.curCSS(a,b,d)},curCSS:function(a,b,d){var f,e=a.style;if(!c.support.opacity&&b==="opacity"&& -a.currentStyle){f=Ka.test(a.currentStyle.filter||"")?parseFloat(RegExp.$1)/100+"":"";return f===""?"1":f}if(ga.test(b))b=La;if(!d&&e&&e[b])f=e[b];else if(ob){if(ga.test(b))b="float";b=b.replace(ib,"-$1").toLowerCase();e=a.ownerDocument.defaultView;if(!e)return null;if(a=e.getComputedStyle(a,null))f=a.getPropertyValue(b);if(b==="opacity"&&f==="")f="1"}else if(a.currentStyle){d=b.replace(ha,ia);f=a.currentStyle[b]||a.currentStyle[d];if(!jb.test(f)&&kb.test(f)){b=e.left;var i=a.runtimeStyle.left;a.runtimeStyle.left= -a.currentStyle.left;e.left=d==="fontSize"?"1em":f||0;f=e.pixelLeft+"px";e.left=b;a.runtimeStyle.left=i}}return f},swap:function(a,b,d){var f={};for(var e in b){f[e]=a.style[e];a.style[e]=b[e]}d.call(a);for(e in b)a.style[e]=f[e]}});if(c.expr&&c.expr.filters){c.expr.filters.hidden=function(a){var b=a.offsetWidth,d=a.offsetHeight,f=a.nodeName.toLowerCase()==="tr";return b===0&&d===0&&!f?true:b>0&&d>0&&!f?false:c.curCSS(a,"display")==="none"};c.expr.filters.visible=function(a){return!c.expr.filters.hidden(a)}}var pb= -J(),qb=/<script(.|\s)*?\/script>/gi,rb=/select|textarea/i,sb=/color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i,N=/=\?(&|$)/,ja=/\?/,tb=/(\?|&)_=.*?(&|$)/,ub=/^(\w+:)?\/\/([^\/?#]+)/,vb=/%20/g;c.fn.extend({_load:c.fn.load,load:function(a,b,d){if(typeof a!=="string")return this._load(a);else if(!this.length)return this;var f=a.indexOf(" ");if(f>=0){var e=a.slice(f,a.length);a=a.slice(0,f)}f="GET";if(b)if(c.isFunction(b)){d=b;b=null}else if(typeof b==="object"){b= -c.param(b,c.ajaxSettings.traditional);f="POST"}var i=this;c.ajax({url:a,type:f,dataType:"html",data:b,complete:function(j,n){if(n==="success"||n==="notmodified")i.html(e?c("<div />").append(j.responseText.replace(qb,"")).find(e):j.responseText);d&&i.each(d,[j.responseText,n,j])}});return this},serialize:function(){return c.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?c.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&& -(this.checked||rb.test(this.nodeName)||sb.test(this.type))}).map(function(a,b){a=c(this).val();return a==null?null:c.isArray(a)?c.map(a,function(d){return{name:b.name,value:d}}):{name:b.name,value:a}}).get()}});c.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){c.fn[b]=function(d){return this.bind(b,d)}});c.extend({get:function(a,b,d,f){if(c.isFunction(b)){f=f||d;d=b;b=null}return c.ajax({type:"GET",url:a,data:b,success:d,dataType:f})},getScript:function(a, -b){return c.get(a,null,b,"script")},getJSON:function(a,b,d){return c.get(a,b,d,"json")},post:function(a,b,d,f){if(c.isFunction(b)){f=f||d;d=b;b={}}return c.ajax({type:"POST",url:a,data:b,success:d,dataType:f})},ajaxSetup:function(a){c.extend(c.ajaxSettings,a)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:z.XMLHttpRequest&&(z.location.protocol!=="file:"||!z.ActiveXObject)?function(){return new z.XMLHttpRequest}: -function(){try{return new z.ActiveXObject("Microsoft.XMLHTTP")}catch(a){}},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},etag:{},ajax:function(a){function b(){e.success&&e.success.call(o,n,j,w);e.global&&f("ajaxSuccess",[w,e])}function d(){e.complete&&e.complete.call(o,w,j);e.global&&f("ajaxComplete",[w,e]);e.global&&!--c.active&&c.event.trigger("ajaxStop")} -function f(q,p){(e.context?c(e.context):c.event).trigger(q,p)}var e=c.extend(true,{},c.ajaxSettings,a),i,j,n,o=a&&a.context||e,m=e.type.toUpperCase();if(e.data&&e.processData&&typeof e.data!=="string")e.data=c.param(e.data,e.traditional);if(e.dataType==="jsonp"){if(m==="GET")N.test(e.url)||(e.url+=(ja.test(e.url)?"&":"?")+(e.jsonp||"callback")+"=?");else if(!e.data||!N.test(e.data))e.data=(e.data?e.data+"&":"")+(e.jsonp||"callback")+"=?";e.dataType="json"}if(e.dataType==="json"&&(e.data&&N.test(e.data)|| -N.test(e.url))){i=e.jsonpCallback||"jsonp"+pb++;if(e.data)e.data=(e.data+"").replace(N,"="+i+"$1");e.url=e.url.replace(N,"="+i+"$1");e.dataType="script";z[i]=z[i]||function(q){n=q;b();d();z[i]=v;try{delete z[i]}catch(p){}A&&A.removeChild(B)}}if(e.dataType==="script"&&e.cache===null)e.cache=false;if(e.cache===false&&m==="GET"){var s=J(),x=e.url.replace(tb,"$1_="+s+"$2");e.url=x+(x===e.url?(ja.test(e.url)?"&":"?")+"_="+s:"")}if(e.data&&m==="GET")e.url+=(ja.test(e.url)?"&":"?")+e.data;e.global&&!c.active++&& -c.event.trigger("ajaxStart");s=(s=ub.exec(e.url))&&(s[1]&&s[1]!==location.protocol||s[2]!==location.host);if(e.dataType==="script"&&m==="GET"&&s){var A=r.getElementsByTagName("head")[0]||r.documentElement,B=r.createElement("script");B.src=e.url;if(e.scriptCharset)B.charset=e.scriptCharset;if(!i){var C=false;B.onload=B.onreadystatechange=function(){if(!C&&(!this.readyState||this.readyState==="loaded"||this.readyState==="complete")){C=true;b();d();B.onload=B.onreadystatechange=null;A&&B.parentNode&& -A.removeChild(B)}}}A.insertBefore(B,A.firstChild);return v}var E=false,w=e.xhr();if(w){e.username?w.open(m,e.url,e.async,e.username,e.password):w.open(m,e.url,e.async);try{if(e.data||a&&a.contentType)w.setRequestHeader("Content-Type",e.contentType);if(e.ifModified){c.lastModified[e.url]&&w.setRequestHeader("If-Modified-Since",c.lastModified[e.url]);c.etag[e.url]&&w.setRequestHeader("If-None-Match",c.etag[e.url])}s||w.setRequestHeader("X-Requested-With","XMLHttpRequest");w.setRequestHeader("Accept", -e.dataType&&e.accepts[e.dataType]?e.accepts[e.dataType]+", */*":e.accepts._default)}catch(fa){}if(e.beforeSend&&e.beforeSend.call(o,w,e)===false){e.global&&!--c.active&&c.event.trigger("ajaxStop");w.abort();return false}e.global&&f("ajaxSend",[w,e]);var g=w.onreadystatechange=function(q){if(!w||w.readyState===0||q==="abort"){E||d();E=true;if(w)w.onreadystatechange=c.noop}else if(!E&&w&&(w.readyState===4||q==="timeout")){E=true;w.onreadystatechange=c.noop;j=q==="timeout"?"timeout":!c.httpSuccess(w)? -"error":e.ifModified&&c.httpNotModified(w,e.url)?"notmodified":"success";var p;if(j==="success")try{n=c.httpData(w,e.dataType,e)}catch(u){j="parsererror";p=u}if(j==="success"||j==="notmodified")i||b();else c.handleError(e,w,j,p);d();q==="timeout"&&w.abort();if(e.async)w=null}};try{var h=w.abort;w.abort=function(){w&&h.call(w);g("abort")}}catch(k){}e.async&&e.timeout>0&&setTimeout(function(){w&&!E&&g("timeout")},e.timeout);try{w.send(m==="POST"||m==="PUT"||m==="DELETE"?e.data:null)}catch(l){c.handleError(e, -w,null,l);d()}e.async||g();return w}},handleError:function(a,b,d,f){if(a.error)a.error.call(a.context||a,b,d,f);if(a.global)(a.context?c(a.context):c.event).trigger("ajaxError",[b,a,f])},active:0,httpSuccess:function(a){try{return!a.status&&location.protocol==="file:"||a.status>=200&&a.status<300||a.status===304||a.status===1223||a.status===0}catch(b){}return false},httpNotModified:function(a,b){var d=a.getResponseHeader("Last-Modified"),f=a.getResponseHeader("Etag");if(d)c.lastModified[b]=d;if(f)c.etag[b]= -f;return a.status===304||a.status===0},httpData:function(a,b,d){var f=a.getResponseHeader("content-type")||"",e=b==="xml"||!b&&f.indexOf("xml")>=0;a=e?a.responseXML:a.responseText;e&&a.documentElement.nodeName==="parsererror"&&c.error("parsererror");if(d&&d.dataFilter)a=d.dataFilter(a,b);if(typeof a==="string")if(b==="json"||!b&&f.indexOf("json")>=0)a=c.parseJSON(a);else if(b==="script"||!b&&f.indexOf("javascript")>=0)c.globalEval(a);return a},param:function(a,b){function d(j,n){if(c.isArray(n))c.each(n, -function(o,m){b?f(j,m):d(j+"["+(typeof m==="object"||c.isArray(m)?o:"")+"]",m)});else!b&&n!=null&&typeof n==="object"?c.each(n,function(o,m){d(j+"["+o+"]",m)}):f(j,n)}function f(j,n){n=c.isFunction(n)?n():n;e[e.length]=encodeURIComponent(j)+"="+encodeURIComponent(n)}var e=[];if(b===v)b=c.ajaxSettings.traditional;if(c.isArray(a)||a.jquery)c.each(a,function(){f(this.name,this.value)});else for(var i in a)d(i,a[i]);return e.join("&").replace(vb,"+")}});var ka={},wb=/toggle|show|hide/,xb=/^([+-]=)?([\d+-.]+)(.*)$/, -W,ta=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];c.fn.extend({show:function(a,b){if(a||a===0)return this.animate(K("show",3),a,b);else{a=0;for(b=this.length;a<b;a++){var d=c.data(this[a],"olddisplay");this[a].style.display=d||"";if(c.css(this[a],"display")==="none"){d=this[a].nodeName;var f;if(ka[d])f=ka[d];else{var e=c("<"+d+" />").appendTo("body");f=e.css("display");if(f==="none")f="block";e.remove(); -ka[d]=f}c.data(this[a],"olddisplay",f)}}a=0;for(b=this.length;a<b;a++)this[a].style.display=c.data(this[a],"olddisplay")||"";return this}},hide:function(a,b){if(a||a===0)return this.animate(K("hide",3),a,b);else{a=0;for(b=this.length;a<b;a++){var d=c.data(this[a],"olddisplay");!d&&d!=="none"&&c.data(this[a],"olddisplay",c.css(this[a],"display"))}a=0;for(b=this.length;a<b;a++)this[a].style.display="none";return this}},_toggle:c.fn.toggle,toggle:function(a,b){var d=typeof a==="boolean";if(c.isFunction(a)&& -c.isFunction(b))this._toggle.apply(this,arguments);else a==null||d?this.each(function(){var f=d?a:c(this).is(":hidden");c(this)[f?"show":"hide"]()}):this.animate(K("toggle",3),a,b);return this},fadeTo:function(a,b,d){return this.filter(":hidden").css("opacity",0).show().end().animate({opacity:b},a,d)},animate:function(a,b,d,f){var e=c.speed(b,d,f);if(c.isEmptyObject(a))return this.each(e.complete);return this[e.queue===false?"each":"queue"](function(){var i=c.extend({},e),j,n=this.nodeType===1&&c(this).is(":hidden"), -o=this;for(j in a){var m=j.replace(ha,ia);if(j!==m){a[m]=a[j];delete a[j];j=m}if(a[j]==="hide"&&n||a[j]==="show"&&!n)return i.complete.call(this);if((j==="height"||j==="width")&&this.style){i.display=c.css(this,"display");i.overflow=this.style.overflow}if(c.isArray(a[j])){(i.specialEasing=i.specialEasing||{})[j]=a[j][1];a[j]=a[j][0]}}if(i.overflow!=null)this.style.overflow="hidden";i.curAnim=c.extend({},a);c.each(a,function(s,x){var A=new c.fx(o,i,s);if(wb.test(x))A[x==="toggle"?n?"show":"hide":x](a); -else{var B=xb.exec(x),C=A.cur(true)||0;if(B){x=parseFloat(B[2]);var E=B[3]||"px";if(E!=="px"){o.style[s]=(x||1)+E;C=(x||1)/A.cur(true)*C;o.style[s]=C+E}if(B[1])x=(B[1]==="-="?-1:1)*x+C;A.custom(C,x,E)}else A.custom(C,x,"")}});return true})},stop:function(a,b){var d=c.timers;a&&this.queue([]);this.each(function(){for(var f=d.length-1;f>=0;f--)if(d[f].elem===this){b&&d[f](true);d.splice(f,1)}});b||this.dequeue();return this}});c.each({slideDown:K("show",1),slideUp:K("hide",1),slideToggle:K("toggle", -1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(a,b){c.fn[a]=function(d,f){return this.animate(b,d,f)}});c.extend({speed:function(a,b,d){var f=a&&typeof a==="object"?a:{complete:d||!d&&b||c.isFunction(a)&&a,duration:a,easing:d&&b||b&&!c.isFunction(b)&&b};f.duration=c.fx.off?0:typeof f.duration==="number"?f.duration:c.fx.speeds[f.duration]||c.fx.speeds._default;f.old=f.complete;f.complete=function(){f.queue!==false&&c(this).dequeue();c.isFunction(f.old)&&f.old.call(this)};return f},easing:{linear:function(a, -b,d,f){return d+f*a},swing:function(a,b,d,f){return(-Math.cos(a*Math.PI)/2+0.5)*f+d}},timers:[],fx:function(a,b,d){this.options=b;this.elem=a;this.prop=d;if(!b.orig)b.orig={}}});c.fx.prototype={update:function(){this.options.step&&this.options.step.call(this.elem,this.now,this);(c.fx.step[this.prop]||c.fx.step._default)(this);if((this.prop==="height"||this.prop==="width")&&this.elem.style)this.elem.style.display="block"},cur:function(a){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]== -null))return this.elem[this.prop];return(a=parseFloat(c.css(this.elem,this.prop,a)))&&a>-10000?a:parseFloat(c.curCSS(this.elem,this.prop))||0},custom:function(a,b,d){function f(i){return e.step(i)}this.startTime=J();this.start=a;this.end=b;this.unit=d||this.unit||"px";this.now=this.start;this.pos=this.state=0;var e=this;f.elem=this.elem;if(f()&&c.timers.push(f)&&!W)W=setInterval(c.fx.tick,13)},show:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.show=true;this.custom(this.prop=== -"width"||this.prop==="height"?1:0,this.cur());c(this.elem).show()},hide:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(a){var b=J(),d=true;if(a||b>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;for(var f in this.options.curAnim)if(this.options.curAnim[f]!==true)d=false;if(d){if(this.options.display!=null){this.elem.style.overflow= -this.options.overflow;a=c.data(this.elem,"olddisplay");this.elem.style.display=a?a:this.options.display;if(c.css(this.elem,"display")==="none")this.elem.style.display="block"}this.options.hide&&c(this.elem).hide();if(this.options.hide||this.options.show)for(var e in this.options.curAnim)c.style(this.elem,e,this.options.orig[e]);this.options.complete.call(this.elem)}return false}else{e=b-this.startTime;this.state=e/this.options.duration;a=this.options.easing||(c.easing.swing?"swing":"linear");this.pos= -c.easing[this.options.specialEasing&&this.options.specialEasing[this.prop]||a](this.state,e,0,1,this.options.duration);this.now=this.start+(this.end-this.start)*this.pos;this.update()}return true}};c.extend(c.fx,{tick:function(){for(var a=c.timers,b=0;b<a.length;b++)a[b]()||a.splice(b--,1);a.length||c.fx.stop()},stop:function(){clearInterval(W);W=null},speeds:{slow:600,fast:200,_default:400},step:{opacity:function(a){c.style(a.elem,"opacity",a.now)},_default:function(a){if(a.elem.style&&a.elem.style[a.prop]!= -null)a.elem.style[a.prop]=(a.prop==="width"||a.prop==="height"?Math.max(0,a.now):a.now)+a.unit;else a.elem[a.prop]=a.now}}});if(c.expr&&c.expr.filters)c.expr.filters.animated=function(a){return c.grep(c.timers,function(b){return a===b.elem}).length};c.fn.offset="getBoundingClientRect"in r.documentElement?function(a){var b=this[0];if(a)return this.each(function(e){c.offset.setOffset(this,a,e)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);var d=b.getBoundingClientRect(), -f=b.ownerDocument;b=f.body;f=f.documentElement;return{top:d.top+(self.pageYOffset||c.support.boxModel&&f.scrollTop||b.scrollTop)-(f.clientTop||b.clientTop||0),left:d.left+(self.pageXOffset||c.support.boxModel&&f.scrollLeft||b.scrollLeft)-(f.clientLeft||b.clientLeft||0)}}:function(a){var b=this[0];if(a)return this.each(function(s){c.offset.setOffset(this,a,s)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);c.offset.initialize();var d=b.offsetParent,f= -b,e=b.ownerDocument,i,j=e.documentElement,n=e.body;f=(e=e.defaultView)?e.getComputedStyle(b,null):b.currentStyle;for(var o=b.offsetTop,m=b.offsetLeft;(b=b.parentNode)&&b!==n&&b!==j;){if(c.offset.supportsFixedPosition&&f.position==="fixed")break;i=e?e.getComputedStyle(b,null):b.currentStyle;o-=b.scrollTop;m-=b.scrollLeft;if(b===d){o+=b.offsetTop;m+=b.offsetLeft;if(c.offset.doesNotAddBorder&&!(c.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(b.nodeName))){o+=parseFloat(i.borderTopWidth)|| -0;m+=parseFloat(i.borderLeftWidth)||0}f=d;d=b.offsetParent}if(c.offset.subtractsBorderForOverflowNotVisible&&i.overflow!=="visible"){o+=parseFloat(i.borderTopWidth)||0;m+=parseFloat(i.borderLeftWidth)||0}f=i}if(f.position==="relative"||f.position==="static"){o+=n.offsetTop;m+=n.offsetLeft}if(c.offset.supportsFixedPosition&&f.position==="fixed"){o+=Math.max(j.scrollTop,n.scrollTop);m+=Math.max(j.scrollLeft,n.scrollLeft)}return{top:o,left:m}};c.offset={initialize:function(){var a=r.body,b=r.createElement("div"), -d,f,e,i=parseFloat(c.curCSS(a,"marginTop",true))||0;c.extend(b.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"});b.innerHTML="<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>";a.insertBefore(b,a.firstChild); -d=b.firstChild;f=d.firstChild;e=d.nextSibling.firstChild.firstChild;this.doesNotAddBorder=f.offsetTop!==5;this.doesAddBorderForTableAndCells=e.offsetTop===5;f.style.position="fixed";f.style.top="20px";this.supportsFixedPosition=f.offsetTop===20||f.offsetTop===15;f.style.position=f.style.top="";d.style.overflow="hidden";d.style.position="relative";this.subtractsBorderForOverflowNotVisible=f.offsetTop===-5;this.doesNotIncludeMarginInBodyOffset=a.offsetTop!==i;a.removeChild(b);c.offset.initialize=c.noop}, -bodyOffset:function(a){var b=a.offsetTop,d=a.offsetLeft;c.offset.initialize();if(c.offset.doesNotIncludeMarginInBodyOffset){b+=parseFloat(c.curCSS(a,"marginTop",true))||0;d+=parseFloat(c.curCSS(a,"marginLeft",true))||0}return{top:b,left:d}},setOffset:function(a,b,d){if(/static/.test(c.curCSS(a,"position")))a.style.position="relative";var f=c(a),e=f.offset(),i=parseInt(c.curCSS(a,"top",true),10)||0,j=parseInt(c.curCSS(a,"left",true),10)||0;if(c.isFunction(b))b=b.call(a,d,e);d={top:b.top-e.top+i,left:b.left- -e.left+j};"using"in b?b.using.call(a,d):f.css(d)}};c.fn.extend({position:function(){if(!this[0])return null;var a=this[0],b=this.offsetParent(),d=this.offset(),f=/^body|html$/i.test(b[0].nodeName)?{top:0,left:0}:b.offset();d.top-=parseFloat(c.curCSS(a,"marginTop",true))||0;d.left-=parseFloat(c.curCSS(a,"marginLeft",true))||0;f.top+=parseFloat(c.curCSS(b[0],"borderTopWidth",true))||0;f.left+=parseFloat(c.curCSS(b[0],"borderLeftWidth",true))||0;return{top:d.top-f.top,left:d.left-f.left}},offsetParent:function(){return this.map(function(){for(var a= -this.offsetParent||r.body;a&&!/^body|html$/i.test(a.nodeName)&&c.css(a,"position")==="static";)a=a.offsetParent;return a})}});c.each(["Left","Top"],function(a,b){var d="scroll"+b;c.fn[d]=function(f){var e=this[0],i;if(!e)return null;if(f!==v)return this.each(function(){if(i=ua(this))i.scrollTo(!a?f:c(i).scrollLeft(),a?f:c(i).scrollTop());else this[d]=f});else return(i=ua(e))?"pageXOffset"in i?i[a?"pageYOffset":"pageXOffset"]:c.support.boxModel&&i.document.documentElement[d]||i.document.body[d]:e[d]}}); -c.each(["Height","Width"],function(a,b){var d=b.toLowerCase();c.fn["inner"+b]=function(){return this[0]?c.css(this[0],d,false,"padding"):null};c.fn["outer"+b]=function(f){return this[0]?c.css(this[0],d,false,f?"margin":"border"):null};c.fn[d]=function(f){var e=this[0];if(!e)return f==null?null:this;if(c.isFunction(f))return this.each(function(i){var j=c(this);j[d](f.call(this,i,j[d]()))});return"scrollTo"in e&&e.document?e.document.compatMode==="CSS1Compat"&&e.document.documentElement["client"+b]|| -e.document.body["client"+b]:e.nodeType===9?Math.max(e.documentElement["client"+b],e.body["scroll"+b],e.documentElement["scroll"+b],e.body["offset"+b],e.documentElement["offset"+b]):f===v?c.css(e,d):this.css(d,typeof f==="string"?f:f+"px")}});z.jQuery=z.$=c})(window); +(function( window, undefined ) { + +// Define a local copy of jQuery +var jQuery = function( selector, context ) { +		// The jQuery object is actually just the init constructor 'enhanced' +		return new jQuery.fn.init( selector, context ); +	}, + +	// Map over jQuery in case of overwrite +	_jQuery = window.jQuery, + +	// Map over the $ in case of overwrite +	_$ = window.$, + +	// Use the correct document accordingly with window argument (sandbox) +	document = window.document, + +	// A central reference to the root jQuery(document) +	rootjQuery, + +	// A simple way to check for HTML strings or ID strings +	// (both of which we optimize for) +	quickExpr = /^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/, + +	// Is it a simple selector +	isSimple = /^.[^:#\[\.,]*$/, + +	// Check if a string has a non-whitespace character in it +	rnotwhite = /\S/, + +	// Used for trimming whitespace +	rtrim = /^(\s|\u00A0)+|(\s|\u00A0)+$/g, + +	// Match a standalone tag +	rsingleTag = /^<(\w+)\s*\/?>(?:<\/\1>)?$/, + +	// Keep a UserAgent string for use with jQuery.browser +	userAgent = navigator.userAgent, + +	// For matching the engine and version of the browser +	browserMatch, +	 +	// Has the ready events already been bound? +	readyBound = false, +	 +	// The functions to execute on DOM ready +	readyList = [], + +	// The ready event handler +	DOMContentLoaded, + +	// Save a reference to some core methods +	toString = Object.prototype.toString, +	hasOwnProperty = Object.prototype.hasOwnProperty, +	push = Array.prototype.push, +	slice = Array.prototype.slice, +	indexOf = Array.prototype.indexOf; + +jQuery.fn = jQuery.prototype = { +	init: function( selector, context ) { +		var match, elem, ret, doc; + +		// Handle $(""), $(null), or $(undefined) +		if ( !selector ) { +			return this; +		} + +		// Handle $(DOMElement) +		if ( selector.nodeType ) { +			this.context = this[0] = selector; +			this.length = 1; +			return this; +		} + +		// Handle HTML strings +		if ( typeof selector === "string" ) { +			// Are we dealing with HTML string or an ID? +			match = quickExpr.exec( selector ); + +			// Verify a match, and that no context was specified for #id +			if ( match && (match[1] || !context) ) { + +				// HANDLE: $(html) -> $(array) +				if ( match[1] ) { +					doc = (context ? context.ownerDocument || context : document); + +					// If a single string is passed in and it's a single tag +					// just do a createElement and skip the rest +					ret = rsingleTag.exec( selector ); + +					if ( ret ) { +						if ( jQuery.isPlainObject( context ) ) { +							selector = [ document.createElement( ret[1] ) ]; +							jQuery.fn.attr.call( selector, context, true ); + +						} else { +							selector = [ doc.createElement( ret[1] ) ]; +						} + +					} else { +						ret = buildFragment( [ match[1] ], [ doc ] ); +						selector = (ret.cacheable ? ret.fragment.cloneNode(true) : ret.fragment).childNodes; +					} + +				// HANDLE: $("#id") +				} else { +					elem = document.getElementById( match[2] ); + +					if ( elem ) { +						// Handle the case where IE and Opera return items +						// by name instead of ID +						if ( elem.id !== match[2] ) { +							return rootjQuery.find( selector ); +						} + +						// Otherwise, we inject the element directly into the jQuery object +						this.length = 1; +						this[0] = elem; +					} + +					this.context = document; +					this.selector = selector; +					return this; +				} + +			// HANDLE: $("TAG") +			} else if ( !context && /^\w+$/.test( selector ) ) { +				this.selector = selector; +				this.context = document; +				selector = document.getElementsByTagName( selector ); + +			// HANDLE: $(expr, $(...)) +			} else if ( !context || context.jquery ) { +				return (context || rootjQuery).find( selector ); + +			// HANDLE: $(expr, context) +			// (which is just equivalent to: $(context).find(expr) +			} else { +				return jQuery( context ).find( selector ); +			} + +		// HANDLE: $(function) +		// Shortcut for document ready +		} else if ( jQuery.isFunction( selector ) ) { +			return rootjQuery.ready( selector ); +		} + +		if (selector.selector !== undefined) { +			this.selector = selector.selector; +			this.context = selector.context; +		} + +		return jQuery.isArray( selector ) ? +			this.setArray( selector ) : +			jQuery.makeArray( selector, this ); +	}, + +	// Start with an empty selector +	selector: "", + +	// The current version of jQuery being used +	jquery: "1.4.1", + +	// The default length of a jQuery object is 0 +	length: 0, + +	// The number of elements contained in the matched element set +	size: function() { +		return this.length; +	}, + +	toArray: function() { +		return slice.call( this, 0 ); +	}, + +	// Get the Nth element in the matched element set OR +	// Get the whole matched element set as a clean array +	get: function( num ) { +		return num == null ? + +			// Return a 'clean' array +			this.toArray() : + +			// Return just the object +			( num < 0 ? this.slice(num)[ 0 ] : this[ num ] ); +	}, + +	// Take an array of elements and push it onto the stack +	// (returning the new matched element set) +	pushStack: function( elems, name, selector ) { +		// Build a new jQuery matched element set +		var ret = jQuery( elems || null ); + +		// Add the old object onto the stack (as a reference) +		ret.prevObject = this; + +		ret.context = this.context; + +		if ( name === "find" ) { +			ret.selector = this.selector + (this.selector ? " " : "") + selector; +		} else if ( name ) { +			ret.selector = this.selector + "." + name + "(" + selector + ")"; +		} + +		// Return the newly-formed element set +		return ret; +	}, + +	// Force the current matched set of elements to become +	// the specified array of elements (destroying the stack in the process) +	// You should use pushStack() in order to do this, but maintain the stack +	setArray: function( elems ) { +		// Resetting the length to 0, then using the native Array push +		// is a super-fast way to populate an object with array-like properties +		this.length = 0; +		push.apply( this, elems ); + +		return this; +	}, + +	// Execute a callback for every element in the matched set. +	// (You can seed the arguments with an array of args, but this is +	// only used internally.) +	each: function( callback, args ) { +		return jQuery.each( this, callback, args ); +	}, +	 +	ready: function( fn ) { +		// Attach the listeners +		jQuery.bindReady(); + +		// If the DOM is already ready +		if ( jQuery.isReady ) { +			// Execute the function immediately +			fn.call( document, jQuery ); + +		// Otherwise, remember the function for later +		} else if ( readyList ) { +			// Add the function to the wait list +			readyList.push( fn ); +		} + +		return this; +	}, +	 +	eq: function( i ) { +		return i === -1 ? +			this.slice( i ) : +			this.slice( i, +i + 1 ); +	}, + +	first: function() { +		return this.eq( 0 ); +	}, + +	last: function() { +		return this.eq( -1 ); +	}, + +	slice: function() { +		return this.pushStack( slice.apply( this, arguments ), +			"slice", slice.call(arguments).join(",") ); +	}, + +	map: function( callback ) { +		return this.pushStack( jQuery.map(this, function( elem, i ) { +			return callback.call( elem, i, elem ); +		})); +	}, +	 +	end: function() { +		return this.prevObject || jQuery(null); +	}, + +	// For internal use only. +	// Behaves like an Array's method, not like a jQuery method. +	push: push, +	sort: [].sort, +	splice: [].splice +}; + +// Give the init function the jQuery prototype for later instantiation +jQuery.fn.init.prototype = jQuery.fn; + +jQuery.extend = jQuery.fn.extend = function() { +	// copy reference to target object +	var target = arguments[0] || {}, i = 1, length = arguments.length, deep = false, options, name, src, copy; + +	// Handle a deep copy situation +	if ( typeof target === "boolean" ) { +		deep = target; +		target = arguments[1] || {}; +		// skip the boolean and the target +		i = 2; +	} + +	// Handle case when target is a string or something (possible in deep copy) +	if ( typeof target !== "object" && !jQuery.isFunction(target) ) { +		target = {}; +	} + +	// extend jQuery itself if only one argument is passed +	if ( length === i ) { +		target = this; +		--i; +	} + +	for ( ; i < length; i++ ) { +		// Only deal with non-null/undefined values +		if ( (options = arguments[ i ]) != null ) { +			// Extend the base object +			for ( name in options ) { +				src = target[ name ]; +				copy = options[ name ]; + +				// Prevent never-ending loop +				if ( target === copy ) { +					continue; +				} + +				// Recurse if we're merging object literal values or arrays +				if ( deep && copy && ( jQuery.isPlainObject(copy) || jQuery.isArray(copy) ) ) { +					var clone = src && ( jQuery.isPlainObject(src) || jQuery.isArray(src) ) ? src +						: jQuery.isArray(copy) ? [] : {}; + +					// Never move original objects, clone them +					target[ name ] = jQuery.extend( deep, clone, copy ); + +				// Don't bring in undefined values +				} else if ( copy !== undefined ) { +					target[ name ] = copy; +				} +			} +		} +	} + +	// Return the modified object +	return target; +}; + +jQuery.extend({ +	noConflict: function( deep ) { +		window.$ = _$; + +		if ( deep ) { +			window.jQuery = _jQuery; +		} + +		return jQuery; +	}, +	 +	// Is the DOM ready to be used? Set to true once it occurs. +	isReady: false, +	 +	// Handle when the DOM is ready +	ready: function() { +		// Make sure that the DOM is not already loaded +		if ( !jQuery.isReady ) { +			// Make sure body exists, at least, in case IE gets a little overzealous (ticket #5443). +			if ( !document.body ) { +				return setTimeout( jQuery.ready, 13 ); +			} + +			// Remember that the DOM is ready +			jQuery.isReady = true; + +			// If there are functions bound, to execute +			if ( readyList ) { +				// Execute all of them +				var fn, i = 0; +				while ( (fn = readyList[ i++ ]) ) { +					fn.call( document, jQuery ); +				} + +				// Reset the list of functions +				readyList = null; +			} + +			// Trigger any bound ready events +			if ( jQuery.fn.triggerHandler ) { +				jQuery( document ).triggerHandler( "ready" ); +			} +		} +	}, +	 +	bindReady: function() { +		if ( readyBound ) { +			return; +		} + +		readyBound = true; + +		// Catch cases where $(document).ready() is called after the +		// browser event has already occurred. +		if ( document.readyState === "complete" ) { +			return jQuery.ready(); +		} + +		// Mozilla, Opera and webkit nightlies currently support this event +		if ( document.addEventListener ) { +			// Use the handy event callback +			document.addEventListener( "DOMContentLoaded", DOMContentLoaded, false ); +			 +			// A fallback to window.onload, that will always work +			window.addEventListener( "load", jQuery.ready, false ); + +		// If IE event model is used +		} else if ( document.attachEvent ) { +			// ensure firing before onload, +			// maybe late but safe also for iframes +			document.attachEvent("onreadystatechange", DOMContentLoaded); +			 +			// A fallback to window.onload, that will always work +			window.attachEvent( "onload", jQuery.ready ); + +			// If IE and not a frame +			// continually check to see if the document is ready +			var toplevel = false; + +			try { +				toplevel = window.frameElement == null; +			} catch(e) {} + +			if ( document.documentElement.doScroll && toplevel ) { +				doScrollCheck(); +			} +		} +	}, + +	// See test/unit/core.js for details concerning isFunction. +	// Since version 1.3, DOM methods and functions like alert +	// aren't supported. They return false on IE (#2968). +	isFunction: function( obj ) { +		return toString.call(obj) === "[object Function]"; +	}, + +	isArray: function( obj ) { +		return toString.call(obj) === "[object Array]"; +	}, + +	isPlainObject: function( obj ) { +		// Must be an Object. +		// Because of IE, we also have to check the presence of the constructor property. +		// Make sure that DOM nodes and window objects don't pass through, as well +		if ( !obj || toString.call(obj) !== "[object Object]" || obj.nodeType || obj.setInterval ) { +			return false; +		} +		 +		// Not own constructor property must be Object +		if ( obj.constructor +			&& !hasOwnProperty.call(obj, "constructor") +			&& !hasOwnProperty.call(obj.constructor.prototype, "isPrototypeOf") ) { +			return false; +		} +		 +		// Own properties are enumerated firstly, so to speed up, +		// if last one is own, then all properties are own. +	 +		var key; +		for ( key in obj ) {} +		 +		return key === undefined || hasOwnProperty.call( obj, key ); +	}, + +	isEmptyObject: function( obj ) { +		for ( var name in obj ) { +			return false; +		} +		return true; +	}, +	 +	error: function( msg ) { +		throw msg; +	}, +	 +	parseJSON: function( data ) { +		if ( typeof data !== "string" || !data ) { +			return null; +		} +		 +		// Make sure the incoming data is actual JSON +		// Logic borrowed from http://json.org/json2.js +		if ( /^[\],:{}\s]*$/.test(data.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, "@") +			.replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, "]") +			.replace(/(?:^|:|,)(?:\s*\[)+/g, "")) ) { + +			// Try to use the native JSON parser first +			return window.JSON && window.JSON.parse ? +				window.JSON.parse( data ) : +				(new Function("return " + data))(); + +		} else { +			jQuery.error( "Invalid JSON: " + data ); +		} +	}, + +	noop: function() {}, + +	// Evalulates a script in a global context +	globalEval: function( data ) { +		if ( data && rnotwhite.test(data) ) { +			// Inspired by code by Andrea Giammarchi +			// http://webreflection.blogspot.com/2007/08/global-scope-evaluation-and-dom.html +			var head = document.getElementsByTagName("head")[0] || document.documentElement, +				script = document.createElement("script"); + +			script.type = "text/javascript"; + +			if ( jQuery.support.scriptEval ) { +				script.appendChild( document.createTextNode( data ) ); +			} else { +				script.text = data; +			} + +			// Use insertBefore instead of appendChild to circumvent an IE6 bug. +			// This arises when a base node is used (#2709). +			head.insertBefore( script, head.firstChild ); +			head.removeChild( script ); +		} +	}, + +	nodeName: function( elem, name ) { +		return elem.nodeName && elem.nodeName.toUpperCase() === name.toUpperCase(); +	}, + +	// args is for internal usage only +	each: function( object, callback, args ) { +		var name, i = 0, +			length = object.length, +			isObj = length === undefined || jQuery.isFunction(object); + +		if ( args ) { +			if ( isObj ) { +				for ( name in object ) { +					if ( callback.apply( object[ name ], args ) === false ) { +						break; +					} +				} +			} else { +				for ( ; i < length; ) { +					if ( callback.apply( object[ i++ ], args ) === false ) { +						break; +					} +				} +			} + +		// A special, fast, case for the most common use of each +		} else { +			if ( isObj ) { +				for ( name in object ) { +					if ( callback.call( object[ name ], name, object[ name ] ) === false ) { +						break; +					} +				} +			} else { +				for ( var value = object[0]; +					i < length && callback.call( value, i, value ) !== false; value = object[++i] ) {} +			} +		} + +		return object; +	}, + +	trim: function( text ) { +		return (text || "").replace( rtrim, "" ); +	}, + +	// results is for internal usage only +	makeArray: function( array, results ) { +		var ret = results || []; + +		if ( array != null ) { +			// The window, strings (and functions) also have 'length' +			// The extra typeof function check is to prevent crashes +			// in Safari 2 (See: #3039) +			if ( array.length == null || typeof array === "string" || jQuery.isFunction(array) || (typeof array !== "function" && array.setInterval) ) { +				push.call( ret, array ); +			} else { +				jQuery.merge( ret, array ); +			} +		} + +		return ret; +	}, + +	inArray: function( elem, array ) { +		if ( array.indexOf ) { +			return array.indexOf( elem ); +		} + +		for ( var i = 0, length = array.length; i < length; i++ ) { +			if ( array[ i ] === elem ) { +				return i; +			} +		} + +		return -1; +	}, + +	merge: function( first, second ) { +		var i = first.length, j = 0; + +		if ( typeof second.length === "number" ) { +			for ( var l = second.length; j < l; j++ ) { +				first[ i++ ] = second[ j ]; +			} +		} else { +			while ( second[j] !== undefined ) { +				first[ i++ ] = second[ j++ ]; +			} +		} + +		first.length = i; + +		return first; +	}, + +	grep: function( elems, callback, inv ) { +		var ret = []; + +		// Go through the array, only saving the items +		// that pass the validator function +		for ( var i = 0, length = elems.length; i < length; i++ ) { +			if ( !inv !== !callback( elems[ i ], i ) ) { +				ret.push( elems[ i ] ); +			} +		} + +		return ret; +	}, + +	// arg is for internal usage only +	map: function( elems, callback, arg ) { +		var ret = [], value; + +		// Go through the array, translating each of the items to their +		// new value (or values). +		for ( var i = 0, length = elems.length; i < length; i++ ) { +			value = callback( elems[ i ], i, arg ); + +			if ( value != null ) { +				ret[ ret.length ] = value; +			} +		} + +		return ret.concat.apply( [], ret ); +	}, + +	// A global GUID counter for objects +	guid: 1, + +	proxy: function( fn, proxy, thisObject ) { +		if ( arguments.length === 2 ) { +			if ( typeof proxy === "string" ) { +				thisObject = fn; +				fn = thisObject[ proxy ]; +				proxy = undefined; + +			} else if ( proxy && !jQuery.isFunction( proxy ) ) { +				thisObject = proxy; +				proxy = undefined; +			} +		} + +		if ( !proxy && fn ) { +			proxy = function() { +				return fn.apply( thisObject || this, arguments ); +			}; +		} + +		// Set the guid of unique handler to the same of original handler, so it can be removed +		if ( fn ) { +			proxy.guid = fn.guid = fn.guid || proxy.guid || jQuery.guid++; +		} + +		// So proxy can be declared as an argument +		return proxy; +	}, + +	// Use of jQuery.browser is frowned upon. +	// More details: http://docs.jquery.com/Utilities/jQuery.browser +	uaMatch: function( ua ) { +		ua = ua.toLowerCase(); + +		var match = /(webkit)[ \/]([\w.]+)/.exec( ua ) || +			/(opera)(?:.*version)?[ \/]([\w.]+)/.exec( ua ) || +			/(msie) ([\w.]+)/.exec( ua ) || +			!/compatible/.test( ua ) && /(mozilla)(?:.*? rv:([\w.]+))?/.exec( ua ) || +		  	[]; + +		return { browser: match[1] || "", version: match[2] || "0" }; +	}, + +	browser: {} +}); + +browserMatch = jQuery.uaMatch( userAgent ); +if ( browserMatch.browser ) { +	jQuery.browser[ browserMatch.browser ] = true; +	jQuery.browser.version = browserMatch.version; +} + +// Deprecated, use jQuery.browser.webkit instead +if ( jQuery.browser.webkit ) { +	jQuery.browser.safari = true; +} + +if ( indexOf ) { +	jQuery.inArray = function( elem, array ) { +		return indexOf.call( array, elem ); +	}; +} + +// All jQuery objects should point back to these +rootjQuery = jQuery(document); + +// Cleanup functions for the document ready method +if ( document.addEventListener ) { +	DOMContentLoaded = function() { +		document.removeEventListener( "DOMContentLoaded", DOMContentLoaded, false ); +		jQuery.ready(); +	}; + +} else if ( document.attachEvent ) { +	DOMContentLoaded = function() { +		// Make sure body exists, at least, in case IE gets a little overzealous (ticket #5443). +		if ( document.readyState === "complete" ) { +			document.detachEvent( "onreadystatechange", DOMContentLoaded ); +			jQuery.ready(); +		} +	}; +} + +// The DOM ready check for Internet Explorer +function doScrollCheck() { +	if ( jQuery.isReady ) { +		return; +	} + +	try { +		// If IE is used, use the trick by Diego Perini +		// http://javascript.nwbox.com/IEContentLoaded/ +		document.documentElement.doScroll("left"); +	} catch( error ) { +		setTimeout( doScrollCheck, 1 ); +		return; +	} + +	// and execute any waiting functions +	jQuery.ready(); +} + +function evalScript( i, elem ) { +	if ( elem.src ) { +		jQuery.ajax({ +			url: elem.src, +			async: false, +			dataType: "script" +		}); +	} else { +		jQuery.globalEval( elem.text || elem.textContent || elem.innerHTML || "" ); +	} + +	if ( elem.parentNode ) { +		elem.parentNode.removeChild( elem ); +	} +} + +// Mutifunctional method to get and set values to a collection +// The value/s can be optionally by executed if its a function +function access( elems, key, value, exec, fn, pass ) { +	var length = elems.length; +	 +	// Setting many attributes +	if ( typeof key === "object" ) { +		for ( var k in key ) { +			access( elems, k, key[k], exec, fn, value ); +		} +		return elems; +	} +	 +	// Setting one attribute +	if ( value !== undefined ) { +		// Optionally, function values get executed if exec is true +		exec = !pass && exec && jQuery.isFunction(value); +		 +		for ( var i = 0; i < length; i++ ) { +			fn( elems[i], key, exec ? value.call( elems[i], i, fn( elems[i], key ) ) : value, pass ); +		} +		 +		return elems; +	} +	 +	// Getting an attribute +	return length ? fn( elems[0], key ) : null; +} + +function now() { +	return (new Date).getTime(); +} +(function() { + +	jQuery.support = {}; + +	var root = document.documentElement, +		script = document.createElement("script"), +		div = document.createElement("div"), +		id = "script" + now(); + +	div.style.display = "none"; +	div.innerHTML = "   <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>"; + +	var all = div.getElementsByTagName("*"), +		a = div.getElementsByTagName("a")[0]; + +	// Can't get basic test support +	if ( !all || !all.length || !a ) { +		return; +	} + +	jQuery.support = { +		// IE strips leading whitespace when .innerHTML is used +		leadingWhitespace: div.firstChild.nodeType === 3, + +		// Make sure that tbody elements aren't automatically inserted +		// IE will insert them into empty tables +		tbody: !div.getElementsByTagName("tbody").length, + +		// Make sure that link elements get serialized correctly by innerHTML +		// This requires a wrapper element in IE +		htmlSerialize: !!div.getElementsByTagName("link").length, + +		// Get the style information from getAttribute +		// (IE uses .cssText insted) +		style: /red/.test( a.getAttribute("style") ), + +		// Make sure that URLs aren't manipulated +		// (IE normalizes it by default) +		hrefNormalized: a.getAttribute("href") === "/a", + +		// Make sure that element opacity exists +		// (IE uses filter instead) +		// Use a regex to work around a WebKit issue. See #5145 +		opacity: /^0.55$/.test( a.style.opacity ), + +		// Verify style float existence +		// (IE uses styleFloat instead of cssFloat) +		cssFloat: !!a.style.cssFloat, + +		// Make sure that if no value is specified for a checkbox +		// that it defaults to "on". +		// (WebKit defaults to "" instead) +		checkOn: div.getElementsByTagName("input")[0].value === "on", + +		// Make sure that a selected-by-default option has a working selected property. +		// (WebKit defaults to false instead of true, IE too, if it's in an optgroup) +		optSelected: document.createElement("select").appendChild( document.createElement("option") ).selected, + +		// Will be defined later +		checkClone: false, +		scriptEval: false, +		noCloneEvent: true, +		boxModel: null +	}; + +	script.type = "text/javascript"; +	try { +		script.appendChild( document.createTextNode( "window." + id + "=1;" ) ); +	} catch(e) {} + +	root.insertBefore( script, root.firstChild ); + +	// Make sure that the execution of code works by injecting a script +	// tag with appendChild/createTextNode +	// (IE doesn't support this, fails, and uses .text instead) +	if ( window[ id ] ) { +		jQuery.support.scriptEval = true; +		delete window[ id ]; +	} + +	root.removeChild( script ); + +	if ( div.attachEvent && div.fireEvent ) { +		div.attachEvent("onclick", function click() { +			// Cloning a node shouldn't copy over any +			// bound event handlers (IE does this) +			jQuery.support.noCloneEvent = false; +			div.detachEvent("onclick", click); +		}); +		div.cloneNode(true).fireEvent("onclick"); +	} + +	div = document.createElement("div"); +	div.innerHTML = "<input type='radio' name='radiotest' checked='checked'/>"; + +	var fragment = document.createDocumentFragment(); +	fragment.appendChild( div.firstChild ); + +	// WebKit doesn't clone checked state correctly in fragments +	jQuery.support.checkClone = fragment.cloneNode(true).cloneNode(true).lastChild.checked; + +	// Figure out if the W3C box model works as expected +	// document.body must exist before we can do this +	jQuery(function() { +		var div = document.createElement("div"); +		div.style.width = div.style.paddingLeft = "1px"; + +		document.body.appendChild( div ); +		jQuery.boxModel = jQuery.support.boxModel = div.offsetWidth === 2; +		document.body.removeChild( div ).style.display = 'none'; +		div = null; +	}); + +	// Technique from Juriy Zaytsev +	// http://thinkweb2.com/projects/prototype/detecting-event-support-without-browser-sniffing/ +	var eventSupported = function( eventName ) {  +		var el = document.createElement("div");  +		eventName = "on" + eventName;  + +		var isSupported = (eventName in el);  +		if ( !isSupported ) {  +			el.setAttribute(eventName, "return;");  +			isSupported = typeof el[eventName] === "function";  +		}  +		el = null;  + +		return isSupported;  +	}; +	 +	jQuery.support.submitBubbles = eventSupported("submit"); +	jQuery.support.changeBubbles = eventSupported("change"); + +	// release memory in IE +	root = script = div = all = a = null; +})(); + +jQuery.props = { +	"for": "htmlFor", +	"class": "className", +	readonly: "readOnly", +	maxlength: "maxLength", +	cellspacing: "cellSpacing", +	rowspan: "rowSpan", +	colspan: "colSpan", +	tabindex: "tabIndex", +	usemap: "useMap", +	frameborder: "frameBorder" +}; +var expando = "jQuery" + now(), uuid = 0, windowData = {}; +var emptyObject = {}; + +jQuery.extend({ +	cache: {}, +	 +	expando:expando, + +	// The following elements throw uncatchable exceptions if you +	// attempt to add expando properties to them. +	noData: { +		"embed": true, +		"object": true, +		"applet": true +	}, + +	data: function( elem, name, data ) { +		if ( elem.nodeName && jQuery.noData[elem.nodeName.toLowerCase()] ) { +			return; +		} + +		elem = elem == window ? +			windowData : +			elem; + +		var id = elem[ expando ], cache = jQuery.cache, thisCache; + +		// Handle the case where there's no name immediately +		if ( !name && !id ) { +			return null; +		} + +		// Compute a unique ID for the element +		if ( !id ) {  +			id = ++uuid; +		} + +		// Avoid generating a new cache unless none exists and we +		// want to manipulate it. +		if ( typeof name === "object" ) { +			elem[ expando ] = id; +			thisCache = cache[ id ] = jQuery.extend(true, {}, name); +		} else if ( cache[ id ] ) { +			thisCache = cache[ id ]; +		} else if ( typeof data === "undefined" ) { +			thisCache = emptyObject; +		} else { +			thisCache = cache[ id ] = {}; +		} + +		// Prevent overriding the named cache with undefined values +		if ( data !== undefined ) { +			elem[ expando ] = id; +			thisCache[ name ] = data; +		} + +		return typeof name === "string" ? thisCache[ name ] : thisCache; +	}, + +	removeData: function( elem, name ) { +		if ( elem.nodeName && jQuery.noData[elem.nodeName.toLowerCase()] ) { +			return; +		} + +		elem = elem == window ? +			windowData : +			elem; + +		var id = elem[ expando ], cache = jQuery.cache, thisCache = cache[ id ]; + +		// If we want to remove a specific section of the element's data +		if ( name ) { +			if ( thisCache ) { +				// Remove the section of cache data +				delete thisCache[ name ]; + +				// If we've removed all the data, remove the element's cache +				if ( jQuery.isEmptyObject(thisCache) ) { +					jQuery.removeData( elem ); +				} +			} + +		// Otherwise, we want to remove all of the element's data +		} else { +			// Clean up the element expando +			try { +				delete elem[ expando ]; +			} catch( e ) { +				// IE has trouble directly removing the expando +				// but it's ok with using removeAttribute +				if ( elem.removeAttribute ) { +					elem.removeAttribute( expando ); +				} +			} + +			// Completely remove the data cache +			delete cache[ id ]; +		} +	} +}); + +jQuery.fn.extend({ +	data: function( key, value ) { +		if ( typeof key === "undefined" && this.length ) { +			return jQuery.data( this[0] ); + +		} else if ( typeof key === "object" ) { +			return this.each(function() { +				jQuery.data( this, key ); +			}); +		} + +		var parts = key.split("."); +		parts[1] = parts[1] ? "." + parts[1] : ""; + +		if ( value === undefined ) { +			var data = this.triggerHandler("getData" + parts[1] + "!", [parts[0]]); + +			if ( data === undefined && this.length ) { +				data = jQuery.data( this[0], key ); +			} +			return data === undefined && parts[1] ? +				this.data( parts[0] ) : +				data; +		} else { +			return this.trigger("setData" + parts[1] + "!", [parts[0], value]).each(function() { +				jQuery.data( this, key, value ); +			}); +		} +	}, + +	removeData: function( key ) { +		return this.each(function() { +			jQuery.removeData( this, key ); +		}); +	} +}); +jQuery.extend({ +	queue: function( elem, type, data ) { +		if ( !elem ) { +			return; +		} + +		type = (type || "fx") + "queue"; +		var q = jQuery.data( elem, type ); + +		// Speed up dequeue by getting out quickly if this is just a lookup +		if ( !data ) { +			return q || []; +		} + +		if ( !q || jQuery.isArray(data) ) { +			q = jQuery.data( elem, type, jQuery.makeArray(data) ); + +		} else { +			q.push( data ); +		} + +		return q; +	}, + +	dequeue: function( elem, type ) { +		type = type || "fx"; + +		var queue = jQuery.queue( elem, type ), fn = queue.shift(); + +		// If the fx queue is dequeued, always remove the progress sentinel +		if ( fn === "inprogress" ) { +			fn = queue.shift(); +		} + +		if ( fn ) { +			// Add a progress sentinel to prevent the fx queue from being +			// automatically dequeued +			if ( type === "fx" ) { +				queue.unshift("inprogress"); +			} + +			fn.call(elem, function() { +				jQuery.dequeue(elem, type); +			}); +		} +	} +}); + +jQuery.fn.extend({ +	queue: function( type, data ) { +		if ( typeof type !== "string" ) { +			data = type; +			type = "fx"; +		} + +		if ( data === undefined ) { +			return jQuery.queue( this[0], type ); +		} +		return this.each(function( i, elem ) { +			var queue = jQuery.queue( this, type, data ); + +			if ( type === "fx" && queue[0] !== "inprogress" ) { +				jQuery.dequeue( this, type ); +			} +		}); +	}, +	dequeue: function( type ) { +		return this.each(function() { +			jQuery.dequeue( this, type ); +		}); +	}, + +	// Based off of the plugin by Clint Helfers, with permission. +	// http://blindsignals.com/index.php/2009/07/jquery-delay/ +	delay: function( time, type ) { +		time = jQuery.fx ? jQuery.fx.speeds[time] || time : time; +		type = type || "fx"; + +		return this.queue( type, function() { +			var elem = this; +			setTimeout(function() { +				jQuery.dequeue( elem, type ); +			}, time ); +		}); +	}, + +	clearQueue: function( type ) { +		return this.queue( type || "fx", [] ); +	} +}); +var rclass = /[\n\t]/g, +	rspace = /\s+/, +	rreturn = /\r/g, +	rspecialurl = /href|src|style/, +	rtype = /(button|input)/i, +	rfocusable = /(button|input|object|select|textarea)/i, +	rclickable = /^(a|area)$/i, +	rradiocheck = /radio|checkbox/; + +jQuery.fn.extend({ +	attr: function( name, value ) { +		return access( this, name, value, true, jQuery.attr ); +	}, + +	removeAttr: function( name, fn ) { +		return this.each(function(){ +			jQuery.attr( this, name, "" ); +			if ( this.nodeType === 1 ) { +				this.removeAttribute( name ); +			} +		}); +	}, + +	addClass: function( value ) { +		if ( jQuery.isFunction(value) ) { +			return this.each(function(i) { +				var self = jQuery(this); +				self.addClass( value.call(this, i, self.attr("class")) ); +			}); +		} + +		if ( value && typeof value === "string" ) { +			var classNames = (value || "").split( rspace ); + +			for ( var i = 0, l = this.length; i < l; i++ ) { +				var elem = this[i]; + +				if ( elem.nodeType === 1 ) { +					if ( !elem.className ) { +						elem.className = value; + +					} else { +						var className = " " + elem.className + " "; +						for ( var c = 0, cl = classNames.length; c < cl; c++ ) { +							if ( className.indexOf( " " + classNames[c] + " " ) < 0 ) { +								elem.className += " " + classNames[c]; +							} +						} +					} +				} +			} +		} + +		return this; +	}, + +	removeClass: function( value ) { +		if ( jQuery.isFunction(value) ) { +			return this.each(function(i) { +				var self = jQuery(this); +				self.removeClass( value.call(this, i, self.attr("class")) ); +			}); +		} + +		if ( (value && typeof value === "string") || value === undefined ) { +			var classNames = (value || "").split(rspace); + +			for ( var i = 0, l = this.length; i < l; i++ ) { +				var elem = this[i]; + +				if ( elem.nodeType === 1 && elem.className ) { +					if ( value ) { +						var className = (" " + elem.className + " ").replace(rclass, " "); +						for ( var c = 0, cl = classNames.length; c < cl; c++ ) { +							className = className.replace(" " + classNames[c] + " ", " "); +						} +						elem.className = className.substring(1, className.length - 1); + +					} else { +						elem.className = ""; +					} +				} +			} +		} + +		return this; +	}, + +	toggleClass: function( value, stateVal ) { +		var type = typeof value, isBool = typeof stateVal === "boolean"; + +		if ( jQuery.isFunction( value ) ) { +			return this.each(function(i) { +				var self = jQuery(this); +				self.toggleClass( value.call(this, i, self.attr("class"), stateVal), stateVal ); +			}); +		} + +		return this.each(function() { +			if ( type === "string" ) { +				// toggle individual class names +				var className, i = 0, self = jQuery(this), +					state = stateVal, +					classNames = value.split( rspace ); + +				while ( (className = classNames[ i++ ]) ) { +					// check each className given, space seperated list +					state = isBool ? state : !self.hasClass( className ); +					self[ state ? "addClass" : "removeClass" ]( className ); +				} + +			} else if ( type === "undefined" || type === "boolean" ) { +				if ( this.className ) { +					// store className if set +					jQuery.data( this, "__className__", this.className ); +				} + +				// toggle whole className +				this.className = this.className || value === false ? "" : jQuery.data( this, "__className__" ) || ""; +			} +		}); +	}, + +	hasClass: function( selector ) { +		var className = " " + selector + " "; +		for ( var i = 0, l = this.length; i < l; i++ ) { +			if ( (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) > -1 ) { +				return true; +			} +		} + +		return false; +	}, + +	val: function( value ) { +		if ( value === undefined ) { +			var elem = this[0]; + +			if ( elem ) { +				if ( jQuery.nodeName( elem, "option" ) ) { +					return (elem.attributes.value || {}).specified ? elem.value : elem.text; +				} + +				// We need to handle select boxes special +				if ( jQuery.nodeName( elem, "select" ) ) { +					var index = elem.selectedIndex, +						values = [], +						options = elem.options, +						one = elem.type === "select-one"; + +					// Nothing was selected +					if ( index < 0 ) { +						return null; +					} + +					// Loop through all the selected options +					for ( var i = one ? index : 0, max = one ? index + 1 : options.length; i < max; i++ ) { +						var option = options[ i ]; + +						if ( option.selected ) { +							// Get the specifc value for the option +							value = jQuery(option).val(); + +							// We don't need an array for one selects +							if ( one ) { +								return value; +							} + +							// Multi-Selects return an array +							values.push( value ); +						} +					} + +					return values; +				} + +				// Handle the case where in Webkit "" is returned instead of "on" if a value isn't specified +				if ( rradiocheck.test( elem.type ) && !jQuery.support.checkOn ) { +					return elem.getAttribute("value") === null ? "on" : elem.value; +				} +				 + +				// Everything else, we just grab the value +				return (elem.value || "").replace(rreturn, ""); + +			} + +			return undefined; +		} + +		var isFunction = jQuery.isFunction(value); + +		return this.each(function(i) { +			var self = jQuery(this), val = value; + +			if ( this.nodeType !== 1 ) { +				return; +			} + +			if ( isFunction ) { +				val = value.call(this, i, self.val()); +			} + +			// Typecast each time if the value is a Function and the appended +			// value is therefore different each time. +			if ( typeof val === "number" ) { +				val += ""; +			} + +			if ( jQuery.isArray(val) && rradiocheck.test( this.type ) ) { +				this.checked = jQuery.inArray( self.val(), val ) >= 0; + +			} else if ( jQuery.nodeName( this, "select" ) ) { +				var values = jQuery.makeArray(val); + +				jQuery( "option", this ).each(function() { +					this.selected = jQuery.inArray( jQuery(this).val(), values ) >= 0; +				}); + +				if ( !values.length ) { +					this.selectedIndex = -1; +				} + +			} else { +				this.value = val; +			} +		}); +	} +}); + +jQuery.extend({ +	attrFn: { +		val: true, +		css: true, +		html: true, +		text: true, +		data: true, +		width: true, +		height: true, +		offset: true +	}, +		 +	attr: function( elem, name, value, pass ) { +		// don't set attributes on text and comment nodes +		if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 ) { +			return undefined; +		} + +		if ( pass && name in jQuery.attrFn ) { +			return jQuery(elem)[name](value); +		} + +		var notxml = elem.nodeType !== 1 || !jQuery.isXMLDoc( elem ), +			// Whether we are setting (or getting) +			set = value !== undefined; + +		// Try to normalize/fix the name +		name = notxml && jQuery.props[ name ] || name; + +		// Only do all the following if this is a node (faster for style) +		if ( elem.nodeType === 1 ) { +			// These attributes require special treatment +			var special = rspecialurl.test( name ); + +			// Safari mis-reports the default selected property of an option +			// Accessing the parent's selectedIndex property fixes it +			if ( name === "selected" && !jQuery.support.optSelected ) { +				var parent = elem.parentNode; +				if ( parent ) { +					parent.selectedIndex; +	 +					// Make sure that it also works with optgroups, see #5701 +					if ( parent.parentNode ) { +						parent.parentNode.selectedIndex; +					} +				} +			} + +			// If applicable, access the attribute via the DOM 0 way +			if ( name in elem && notxml && !special ) { +				if ( set ) { +					// We can't allow the type property to be changed (since it causes problems in IE) +					if ( name === "type" && rtype.test( elem.nodeName ) && elem.parentNode ) { +						jQuery.error( "type property can't be changed" ); +					} + +					elem[ name ] = value; +				} + +				// browsers index elements by id/name on forms, give priority to attributes. +				if ( jQuery.nodeName( elem, "form" ) && elem.getAttributeNode(name) ) { +					return elem.getAttributeNode( name ).nodeValue; +				} + +				// elem.tabIndex doesn't always return the correct value when it hasn't been explicitly set +				// http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ +				if ( name === "tabIndex" ) { +					var attributeNode = elem.getAttributeNode( "tabIndex" ); + +					return attributeNode && attributeNode.specified ? +						attributeNode.value : +						rfocusable.test( elem.nodeName ) || rclickable.test( elem.nodeName ) && elem.href ? +							0 : +							undefined; +				} + +				return elem[ name ]; +			} + +			if ( !jQuery.support.style && notxml && name === "style" ) { +				if ( set ) { +					elem.style.cssText = "" + value; +				} + +				return elem.style.cssText; +			} + +			if ( set ) { +				// convert the value to a string (all browsers do this but IE) see #1070 +				elem.setAttribute( name, "" + value ); +			} + +			var attr = !jQuery.support.hrefNormalized && notxml && special ? +					// Some attributes require a special call on IE +					elem.getAttribute( name, 2 ) : +					elem.getAttribute( name ); + +			// Non-existent attributes return null, we normalize to undefined +			return attr === null ? undefined : attr; +		} + +		// elem is actually elem.style ... set the style +		// Using attr for specific style information is now deprecated. Use style insead. +		return jQuery.style( elem, name, value ); +	} +}); +var fcleanup = function( nm ) { +	return nm.replace(/[^\w\s\.\|`]/g, function( ch ) { +		return "\\" + ch; +	}); +}; + +/* + * A number of helper functions used for managing events. + * Many of the ideas behind this code originated from + * Dean Edwards' addEvent library. + */ +jQuery.event = { + +	// Bind an event to an element +	// Original by Dean Edwards +	add: function( elem, types, handler, data ) { +		if ( elem.nodeType === 3 || elem.nodeType === 8 ) { +			return; +		} + +		// For whatever reason, IE has trouble passing the window object +		// around, causing it to be cloned in the process +		if ( elem.setInterval && ( elem !== window && !elem.frameElement ) ) { +			elem = window; +		} + +		// Make sure that the function being executed has a unique ID +		if ( !handler.guid ) { +			handler.guid = jQuery.guid++; +		} + +		// if data is passed, bind to handler +		if ( data !== undefined ) { +			// Create temporary function pointer to original handler +			var fn = handler; + +			// Create unique handler function, wrapped around original handler +			handler = jQuery.proxy( fn ); + +			// Store data in unique handler +			handler.data = data; +		} + +		// Init the element's event structure +		var events = jQuery.data( elem, "events" ) || jQuery.data( elem, "events", {} ), +			handle = jQuery.data( elem, "handle" ), eventHandle; + +		if ( !handle ) { +			eventHandle = function() { +				// Handle the second event of a trigger and when +				// an event is called after a page has unloaded +				return typeof jQuery !== "undefined" && !jQuery.event.triggered ? +					jQuery.event.handle.apply( eventHandle.elem, arguments ) : +					undefined; +			}; + +			handle = jQuery.data( elem, "handle", eventHandle ); +		} + +		// If no handle is found then we must be trying to bind to one of the +		// banned noData elements +		if ( !handle ) { +			return; +		} + +		// Add elem as a property of the handle function +		// This is to prevent a memory leak with non-native +		// event in IE. +		handle.elem = elem; + +		// Handle multiple events separated by a space +		// jQuery(...).bind("mouseover mouseout", fn); +		types = types.split( /\s+/ ); + +		var type, i = 0; + +		while ( (type = types[ i++ ]) ) { +			// Namespaced event handlers +			var namespaces = type.split("."); +			type = namespaces.shift(); + +			if ( i > 1 ) { +				handler = jQuery.proxy( handler ); + +				if ( data !== undefined ) { +					handler.data = data; +				} +			} + +			handler.type = namespaces.slice(0).sort().join("."); + +			// Get the current list of functions bound to this event +			var handlers = events[ type ], +				special = this.special[ type ] || {}; + +			// Init the event handler queue +			if ( !handlers ) { +				handlers = events[ type ] = {}; + +				// Check for a special event handler +				// Only use addEventListener/attachEvent if the special +				// events handler returns false +				if ( !special.setup || special.setup.call( elem, data, namespaces, handler) === false ) { +					// Bind the global event handler to the element +					if ( elem.addEventListener ) { +						elem.addEventListener( type, handle, false ); +					} else if ( elem.attachEvent ) { +						elem.attachEvent( "on" + type, handle ); +					} +				} +			} +			 +			if ( special.add ) {  +				var modifiedHandler = special.add.call( elem, handler, data, namespaces, handlers );  +				if ( modifiedHandler && jQuery.isFunction( modifiedHandler ) ) {  +					modifiedHandler.guid = modifiedHandler.guid || handler.guid;  +					modifiedHandler.data = modifiedHandler.data || handler.data;  +					modifiedHandler.type = modifiedHandler.type || handler.type;  +					handler = modifiedHandler;  +				}  +			}  +			 +			// Add the function to the element's handler list +			handlers[ handler.guid ] = handler; + +			// Keep track of which events have been used, for global triggering +			this.global[ type ] = true; +		} + +		// Nullify elem to prevent memory leaks in IE +		elem = null; +	}, + +	global: {}, + +	// Detach an event or set of events from an element +	remove: function( elem, types, handler ) { +		// don't do events on text and comment nodes +		if ( elem.nodeType === 3 || elem.nodeType === 8 ) { +			return; +		} + +		var events = jQuery.data( elem, "events" ), ret, type, fn; + +		if ( events ) { +			// Unbind all events for the element +			if ( types === undefined || (typeof types === "string" && types.charAt(0) === ".") ) { +				for ( type in events ) { +					this.remove( elem, type + (types || "") ); +				} +			} else { +				// types is actually an event object here +				if ( types.type ) { +					handler = types.handler; +					types = types.type; +				} + +				// Handle multiple events separated by a space +				// jQuery(...).unbind("mouseover mouseout", fn); +				types = types.split(/\s+/); +				var i = 0; +				while ( (type = types[ i++ ]) ) { +					// Namespaced event handlers +					var namespaces = type.split("."); +					type = namespaces.shift(); +					var all = !namespaces.length, +						cleaned = jQuery.map( namespaces.slice(0).sort(), fcleanup ), +						namespace = new RegExp("(^|\\.)" + cleaned.join("\\.(?:.*\\.)?") + "(\\.|$)"), +						special = this.special[ type ] || {}; + +					if ( events[ type ] ) { +						// remove the given handler for the given type +						if ( handler ) { +							fn = events[ type ][ handler.guid ]; +							delete events[ type ][ handler.guid ]; + +						// remove all handlers for the given type +						} else { +							for ( var handle in events[ type ] ) { +								// Handle the removal of namespaced events +								if ( all || namespace.test( events[ type ][ handle ].type ) ) { +									delete events[ type ][ handle ]; +								} +							} +						} + +						if ( special.remove ) { +							special.remove.call( elem, namespaces, fn); +						} + +						// remove generic event handler if no more handlers exist +						for ( ret in events[ type ] ) { +							break; +						} +						if ( !ret ) { +							if ( !special.teardown || special.teardown.call( elem, namespaces ) === false ) { +								if ( elem.removeEventListener ) { +									elem.removeEventListener( type, jQuery.data( elem, "handle" ), false ); +								} else if ( elem.detachEvent ) { +									elem.detachEvent( "on" + type, jQuery.data( elem, "handle" ) ); +								} +							} +							ret = null; +							delete events[ type ]; +						} +					} +				} +			} + +			// Remove the expando if it's no longer used +			for ( ret in events ) { +				break; +			} +			if ( !ret ) { +				var handle = jQuery.data( elem, "handle" ); +				if ( handle ) { +					handle.elem = null; +				} +				jQuery.removeData( elem, "events" ); +				jQuery.removeData( elem, "handle" ); +			} +		} +	}, + +	// bubbling is internal +	trigger: function( event, data, elem /*, bubbling */ ) { +		// Event object or event type +		var type = event.type || event, +			bubbling = arguments[3]; + +		if ( !bubbling ) { +			event = typeof event === "object" ? +				// jQuery.Event object +				event[expando] ? event : +				// Object literal +				jQuery.extend( jQuery.Event(type), event ) : +				// Just the event type (string) +				jQuery.Event(type); + +			if ( type.indexOf("!") >= 0 ) { +				event.type = type = type.slice(0, -1); +				event.exclusive = true; +			} + +			// Handle a global trigger +			if ( !elem ) { +				// Don't bubble custom events when global (to avoid too much overhead) +				event.stopPropagation(); + +				// Only trigger if we've ever bound an event for it +				if ( this.global[ type ] ) { +					jQuery.each( jQuery.cache, function() { +						if ( this.events && this.events[type] ) { +							jQuery.event.trigger( event, data, this.handle.elem ); +						} +					}); +				} +			} + +			// Handle triggering a single element + +			// don't do events on text and comment nodes +			if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 ) { +				return undefined; +			} + +			// Clean up in case it is reused +			event.result = undefined; +			event.target = elem; + +			// Clone the incoming data, if any +			data = jQuery.makeArray( data ); +			data.unshift( event ); +		} + +		event.currentTarget = elem; + +		// Trigger the event, it is assumed that "handle" is a function +		var handle = jQuery.data( elem, "handle" ); +		if ( handle ) { +			handle.apply( elem, data ); +		} + +		var parent = elem.parentNode || elem.ownerDocument; + +		// Trigger an inline bound script +		try { +			if ( !(elem && elem.nodeName && jQuery.noData[elem.nodeName.toLowerCase()]) ) { +				if ( elem[ "on" + type ] && elem[ "on" + type ].apply( elem, data ) === false ) { +					event.result = false; +				} +			} + +		// prevent IE from throwing an error for some elements with some event types, see #3533 +		} catch (e) {} + +		if ( !event.isPropagationStopped() && parent ) { +			jQuery.event.trigger( event, data, parent, true ); + +		} else if ( !event.isDefaultPrevented() ) { +			var target = event.target, old, +				isClick = jQuery.nodeName(target, "a") && type === "click"; + +			if ( !isClick && !(target && target.nodeName && jQuery.noData[target.nodeName.toLowerCase()]) ) { +				try { +					if ( target[ type ] ) { +						// Make sure that we don't accidentally re-trigger the onFOO events +						old = target[ "on" + type ]; + +						if ( old ) { +							target[ "on" + type ] = null; +						} + +						this.triggered = true; +						target[ type ](); +					} + +				// prevent IE from throwing an error for some elements with some event types, see #3533 +				} catch (e) {} + +				if ( old ) { +					target[ "on" + type ] = old; +				} + +				this.triggered = false; +			} +		} +	}, + +	handle: function( event ) { +		// returned undefined or false +		var all, handlers; + +		event = arguments[0] = jQuery.event.fix( event || window.event ); +		event.currentTarget = this; + +		// Namespaced event handlers +		var namespaces = event.type.split("."); +		event.type = namespaces.shift(); + +		// Cache this now, all = true means, any handler +		all = !namespaces.length && !event.exclusive; + +		var namespace = new RegExp("(^|\\.)" + namespaces.slice(0).sort().join("\\.(?:.*\\.)?") + "(\\.|$)"); + +		handlers = ( jQuery.data(this, "events") || {} )[ event.type ]; + +		for ( var j in handlers ) { +			var handler = handlers[ j ]; + +			// Filter the functions by class +			if ( all || namespace.test(handler.type) ) { +				// Pass in a reference to the handler function itself +				// So that we can later remove it +				event.handler = handler; +				event.data = handler.data; + +				var ret = handler.apply( this, arguments ); + +				if ( ret !== undefined ) { +					event.result = ret; +					if ( ret === false ) { +						event.preventDefault(); +						event.stopPropagation(); +					} +				} + +				if ( event.isImmediatePropagationStopped() ) { +					break; +				} + +			} +		} + +		return event.result; +	}, + +	props: "altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "), + +	fix: function( event ) { +		if ( event[ expando ] ) { +			return event; +		} + +		// store a copy of the original event object +		// and "clone" to set read-only properties +		var originalEvent = event; +		event = jQuery.Event( originalEvent ); + +		for ( var i = this.props.length, prop; i; ) { +			prop = this.props[ --i ]; +			event[ prop ] = originalEvent[ prop ]; +		} + +		// Fix target property, if necessary +		if ( !event.target ) { +			event.target = event.srcElement || document; // Fixes #1925 where srcElement might not be defined either +		} + +		// check if target is a textnode (safari) +		if ( event.target.nodeType === 3 ) { +			event.target = event.target.parentNode; +		} + +		// Add relatedTarget, if necessary +		if ( !event.relatedTarget && event.fromElement ) { +			event.relatedTarget = event.fromElement === event.target ? event.toElement : event.fromElement; +		} + +		// Calculate pageX/Y if missing and clientX/Y available +		if ( event.pageX == null && event.clientX != null ) { +			var doc = document.documentElement, body = document.body; +			event.pageX = event.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0); +			event.pageY = event.clientY + (doc && doc.scrollTop  || body && body.scrollTop  || 0) - (doc && doc.clientTop  || body && body.clientTop  || 0); +		} + +		// Add which for key events +		if ( !event.which && ((event.charCode || event.charCode === 0) ? event.charCode : event.keyCode) ) { +			event.which = event.charCode || event.keyCode; +		} + +		// Add metaKey to non-Mac browsers (use ctrl for PC's and Meta for Macs) +		if ( !event.metaKey && event.ctrlKey ) { +			event.metaKey = event.ctrlKey; +		} + +		// Add which for click: 1 === left; 2 === middle; 3 === right +		// Note: button is not normalized, so don't use it +		if ( !event.which && event.button !== undefined ) { +			event.which = (event.button & 1 ? 1 : ( event.button & 2 ? 3 : ( event.button & 4 ? 2 : 0 ) )); +		} + +		return event; +	}, + +	// Deprecated, use jQuery.guid instead +	guid: 1E8, + +	// Deprecated, use jQuery.proxy instead +	proxy: jQuery.proxy, + +	special: { +		ready: { +			// Make sure the ready event is setup +			setup: jQuery.bindReady, +			teardown: jQuery.noop +		}, + +		live: { +			add: function( proxy, data, namespaces, live ) { +				jQuery.extend( proxy, data || {} ); + +				proxy.guid += data.selector + data.live;  +				data.liveProxy = proxy; + +				jQuery.event.add( this, data.live, liveHandler, data );  +				 +			}, + +			remove: function( namespaces ) { +				if ( namespaces.length ) { +					var remove = 0, name = new RegExp("(^|\\.)" + namespaces[0] + "(\\.|$)"); + +					jQuery.each( (jQuery.data(this, "events").live || {}), function() { +						if ( name.test(this.type) ) { +							remove++; +						} +					}); + +					if ( remove < 1 ) { +						jQuery.event.remove( this, namespaces[0], liveHandler ); +					} +				} +			}, +			special: {} +		}, +		beforeunload: { +			setup: function( data, namespaces, fn ) { +				// We only want to do this special case on windows +				if ( this.setInterval ) { +					this.onbeforeunload = fn; +				} + +				return false; +			}, +			teardown: function( namespaces, fn ) { +				if ( this.onbeforeunload === fn ) { +					this.onbeforeunload = null; +				} +			} +		} +	} +}; + +jQuery.Event = function( src ) { +	// Allow instantiation without the 'new' keyword +	if ( !this.preventDefault ) { +		return new jQuery.Event( src ); +	} + +	// Event object +	if ( src && src.type ) { +		this.originalEvent = src; +		this.type = src.type; +	// Event type +	} else { +		this.type = src; +	} + +	// timeStamp is buggy for some events on Firefox(#3843) +	// So we won't rely on the native value +	this.timeStamp = now(); + +	// Mark it as fixed +	this[ expando ] = true; +}; + +function returnFalse() { +	return false; +} +function returnTrue() { +	return true; +} + +// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding +// http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html +jQuery.Event.prototype = { +	preventDefault: function() { +		this.isDefaultPrevented = returnTrue; + +		var e = this.originalEvent; +		if ( !e ) { +			return; +		} +		 +		// if preventDefault exists run it on the original event +		if ( e.preventDefault ) { +			e.preventDefault(); +		} +		// otherwise set the returnValue property of the original event to false (IE) +		e.returnValue = false; +	}, +	stopPropagation: function() { +		this.isPropagationStopped = returnTrue; + +		var e = this.originalEvent; +		if ( !e ) { +			return; +		} +		// if stopPropagation exists run it on the original event +		if ( e.stopPropagation ) { +			e.stopPropagation(); +		} +		// otherwise set the cancelBubble property of the original event to true (IE) +		e.cancelBubble = true; +	}, +	stopImmediatePropagation: function() { +		this.isImmediatePropagationStopped = returnTrue; +		this.stopPropagation(); +	}, +	isDefaultPrevented: returnFalse, +	isPropagationStopped: returnFalse, +	isImmediatePropagationStopped: returnFalse +}; + +// Checks if an event happened on an element within another element +// Used in jQuery.event.special.mouseenter and mouseleave handlers +var withinElement = function( event ) { +	// Check if mouse(over|out) are still within the same parent element +	var parent = event.relatedTarget; + +	// Traverse up the tree +	while ( parent && parent !== this ) { +		// Firefox sometimes assigns relatedTarget a XUL element +		// which we cannot access the parentNode property of +		try { +			parent = parent.parentNode; + +		// assuming we've left the element since we most likely mousedover a xul element +		} catch(e) { +			break; +		} +	} + +	if ( parent !== this ) { +		// set the correct event type +		event.type = event.data; + +		// handle event if we actually just moused on to a non sub-element +		jQuery.event.handle.apply( this, arguments ); +	} + +}, + +// In case of event delegation, we only need to rename the event.type, +// liveHandler will take care of the rest. +delegate = function( event ) { +	event.type = event.data; +	jQuery.event.handle.apply( this, arguments ); +}; + +// Create mouseenter and mouseleave events +jQuery.each({ +	mouseenter: "mouseover", +	mouseleave: "mouseout" +}, function( orig, fix ) { +	jQuery.event.special[ orig ] = { +		setup: function( data ) { +			jQuery.event.add( this, fix, data && data.selector ? delegate : withinElement, orig ); +		}, +		teardown: function( data ) { +			jQuery.event.remove( this, fix, data && data.selector ? delegate : withinElement ); +		} +	}; +}); + +// submit delegation +if ( !jQuery.support.submitBubbles ) { + +jQuery.event.special.submit = { +	setup: function( data, namespaces, fn ) { +		if ( this.nodeName.toLowerCase() !== "form" ) { +			jQuery.event.add(this, "click.specialSubmit." + fn.guid, function( e ) { +				var elem = e.target, type = elem.type; + +				if ( (type === "submit" || type === "image") && jQuery( elem ).closest("form").length ) { +					return trigger( "submit", this, arguments ); +				} +			}); +	  +			jQuery.event.add(this, "keypress.specialSubmit." + fn.guid, function( e ) { +				var elem = e.target, type = elem.type; + +				if ( (type === "text" || type === "password") && jQuery( elem ).closest("form").length && e.keyCode === 13 ) { +					return trigger( "submit", this, arguments ); +				} +			}); + +		} else { +			return false; +		} +	}, + +	remove: function( namespaces, fn ) { +		jQuery.event.remove( this, "click.specialSubmit" + (fn ? "."+fn.guid : "") ); +		jQuery.event.remove( this, "keypress.specialSubmit" + (fn ? "."+fn.guid : "") ); +	} +}; + +} + +// change delegation, happens here so we have bind. +if ( !jQuery.support.changeBubbles ) { + +var formElems = /textarea|input|select/i; + +function getVal( elem ) { +	var type = elem.type, val = elem.value; + +	if ( type === "radio" || type === "checkbox" ) { +		val = elem.checked; + +	} else if ( type === "select-multiple" ) { +		val = elem.selectedIndex > -1 ? +			jQuery.map( elem.options, function( elem ) { +				return elem.selected; +			}).join("-") : +			""; + +	} else if ( elem.nodeName.toLowerCase() === "select" ) { +		val = elem.selectedIndex; +	} + +	return val; +} + +function testChange( e ) { +		var elem = e.target, data, val; + +		if ( !formElems.test( elem.nodeName ) || elem.readOnly ) { +			return; +		} + +		data = jQuery.data( elem, "_change_data" ); +		val = getVal(elem); + +		// the current data will be also retrieved by beforeactivate +		if ( e.type !== "focusout" || elem.type !== "radio" ) { +			jQuery.data( elem, "_change_data", val ); +		} +		 +		if ( data === undefined || val === data ) { +			return; +		} + +		if ( data != null || val ) { +			e.type = "change"; +			return jQuery.event.trigger( e, arguments[1], elem ); +		} +} + +jQuery.event.special.change = { +	filters: { +		focusout: testChange,  + +		click: function( e ) { +			var elem = e.target, type = elem.type; + +			if ( type === "radio" || type === "checkbox" || elem.nodeName.toLowerCase() === "select" ) { +				return testChange.call( this, e ); +			} +		}, + +		// Change has to be called before submit +		// Keydown will be called before keypress, which is used in submit-event delegation +		keydown: function( e ) { +			var elem = e.target, type = elem.type; + +			if ( (e.keyCode === 13 && elem.nodeName.toLowerCase() !== "textarea") || +				(e.keyCode === 32 && (type === "checkbox" || type === "radio")) || +				type === "select-multiple" ) { +				return testChange.call( this, e ); +			} +		}, + +		// Beforeactivate happens also before the previous element is blurred +		// with this event you can't trigger a change event, but you can store +		// information/focus[in] is not needed anymore +		beforeactivate: function( e ) { +			var elem = e.target; + +			if ( elem.nodeName.toLowerCase() === "input" && elem.type === "radio" ) { +				jQuery.data( elem, "_change_data", getVal(elem) ); +			} +		} +	}, +	setup: function( data, namespaces, fn ) { +		for ( var type in changeFilters ) { +			jQuery.event.add( this, type + ".specialChange." + fn.guid, changeFilters[type] ); +		} + +		return formElems.test( this.nodeName ); +	}, +	remove: function( namespaces, fn ) { +		for ( var type in changeFilters ) { +			jQuery.event.remove( this, type + ".specialChange" + (fn ? "."+fn.guid : ""), changeFilters[type] ); +		} + +		return formElems.test( this.nodeName ); +	} +}; + +var changeFilters = jQuery.event.special.change.filters; + +} + +function trigger( type, elem, args ) { +	args[0].type = type; +	return jQuery.event.handle.apply( elem, args ); +} + +// Create "bubbling" focus and blur events +if ( document.addEventListener ) { +	jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { +		jQuery.event.special[ fix ] = { +			setup: function() { +				this.addEventListener( orig, handler, true ); +			},  +			teardown: function() {  +				this.removeEventListener( orig, handler, true ); +			} +		}; + +		function handler( e ) {  +			e = jQuery.event.fix( e ); +			e.type = fix; +			return jQuery.event.handle.call( this, e ); +		} +	}); +} + +jQuery.each(["bind", "one"], function( i, name ) { +	jQuery.fn[ name ] = function( type, data, fn ) { +		// Handle object literals +		if ( typeof type === "object" ) { +			for ( var key in type ) { +				this[ name ](key, data, type[key], fn); +			} +			return this; +		} +		 +		if ( jQuery.isFunction( data ) ) { +			fn = data; +			data = undefined; +		} + +		var handler = name === "one" ? jQuery.proxy( fn, function( event ) { +			jQuery( this ).unbind( event, handler ); +			return fn.apply( this, arguments ); +		}) : fn; + +		return type === "unload" && name !== "one" ? +			this.one( type, data, fn ) : +			this.each(function() { +				jQuery.event.add( this, type, handler, data ); +			}); +	}; +}); + +jQuery.fn.extend({ +	unbind: function( type, fn ) { +		// Handle object literals +		if ( typeof type === "object" && !type.preventDefault ) { +			for ( var key in type ) { +				this.unbind(key, type[key]); +			} +			return this; +		} + +		return this.each(function() { +			jQuery.event.remove( this, type, fn ); +		}); +	}, +	trigger: function( type, data ) { +		return this.each(function() { +			jQuery.event.trigger( type, data, this ); +		}); +	}, + +	triggerHandler: function( type, data ) { +		if ( this[0] ) { +			var event = jQuery.Event( type ); +			event.preventDefault(); +			event.stopPropagation(); +			jQuery.event.trigger( event, data, this[0] ); +			return event.result; +		} +	}, + +	toggle: function( fn ) { +		// Save reference to arguments for access in closure +		var args = arguments, i = 1; + +		// link all the functions, so any of them can unbind this click handler +		while ( i < args.length ) { +			jQuery.proxy( fn, args[ i++ ] ); +		} + +		return this.click( jQuery.proxy( fn, function( event ) { +			// Figure out which function to execute +			var lastToggle = ( jQuery.data( this, "lastToggle" + fn.guid ) || 0 ) % i; +			jQuery.data( this, "lastToggle" + fn.guid, lastToggle + 1 ); + +			// Make sure that clicks stop +			event.preventDefault(); + +			// and execute the function +			return args[ lastToggle ].apply( this, arguments ) || false; +		})); +	}, + +	hover: function( fnOver, fnOut ) { +		return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); +	} +}); + +jQuery.each(["live", "die"], function( i, name ) { +	jQuery.fn[ name ] = function( types, data, fn ) { +		var type, i = 0; + +		if ( jQuery.isFunction( data ) ) { +			fn = data; +			data = undefined; +		} + +		types = (types || "").split( /\s+/ ); + +		while ( (type = types[ i++ ]) != null ) { +			type = type === "focus" ? "focusin" : // focus --> focusin +					type === "blur" ? "focusout" : // blur --> focusout +					type === "hover" ? types.push("mouseleave") && "mouseenter" : // hover support +					type; +			 +			if ( name === "live" ) { +				// bind live handler +				jQuery( this.context ).bind( liveConvert( type, this.selector ), { +					data: data, selector: this.selector, live: type +				}, fn ); + +			} else { +				// unbind live handler +				jQuery( this.context ).unbind( liveConvert( type, this.selector ), fn ? { guid: fn.guid + this.selector + type } : null ); +			} +		} +		 +		return this; +	} +}); + +function liveHandler( event ) { +	var stop, elems = [], selectors = [], args = arguments, +		related, match, fn, elem, j, i, l, data, +		live = jQuery.extend({}, jQuery.data( this, "events" ).live); + +	// Make sure we avoid non-left-click bubbling in Firefox (#3861) +	if ( event.button && event.type === "click" ) { +		return; +	} + +	for ( j in live ) { +		fn = live[j]; +		if ( fn.live === event.type || +				fn.altLive && jQuery.inArray(event.type, fn.altLive) > -1 ) { + +			data = fn.data; +			if ( !(data.beforeFilter && data.beforeFilter[event.type] &&  +					!data.beforeFilter[event.type](event)) ) { +				selectors.push( fn.selector ); +			} +		} else { +			delete live[j]; +		} +	} + +	match = jQuery( event.target ).closest( selectors, event.currentTarget ); + +	for ( i = 0, l = match.length; i < l; i++ ) { +		for ( j in live ) { +			fn = live[j]; +			elem = match[i].elem; +			related = null; + +			if ( match[i].selector === fn.selector ) { +				// Those two events require additional checking +				if ( fn.live === "mouseenter" || fn.live === "mouseleave" ) { +					related = jQuery( event.relatedTarget ).closest( fn.selector )[0]; +				} + +				if ( !related || related !== elem ) { +					elems.push({ elem: elem, fn: fn }); +				} +			} +		} +	} + +	for ( i = 0, l = elems.length; i < l; i++ ) { +		match = elems[i]; +		event.currentTarget = match.elem; +		event.data = match.fn.data; +		if ( match.fn.apply( match.elem, args ) === false ) { +			stop = false; +			break; +		} +	} + +	return stop; +} + +function liveConvert( type, selector ) { +	return "live." + (type ? type + "." : "") + selector.replace(/\./g, "`").replace(/ /g, "&"); +} + +jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblclick " + +	"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + +	"change select submit keydown keypress keyup error").split(" "), function( i, name ) { + +	// Handle event binding +	jQuery.fn[ name ] = function( fn ) { +		return fn ? this.bind( name, fn ) : this.trigger( name ); +	}; + +	if ( jQuery.attrFn ) { +		jQuery.attrFn[ name ] = true; +	} +}); + +// Prevent memory leaks in IE +// Window isn't included so as not to unbind existing unload events +// More info: +//  - http://isaacschlueter.com/2006/10/msie-memory-leaks/ +if ( window.attachEvent && !window.addEventListener ) { +	window.attachEvent("onunload", function() { +		for ( var id in jQuery.cache ) { +			if ( jQuery.cache[ id ].handle ) { +				// Try/Catch is to handle iframes being unloaded, see #4280 +				try { +					jQuery.event.remove( jQuery.cache[ id ].handle.elem ); +				} catch(e) {} +			} +		} +	}); +} +/*! + * Sizzle CSS Selector Engine - v1.0 + *  Copyright 2009, The Dojo Foundation + *  Released under the MIT, BSD, and GPL Licenses. + *  More information: http://sizzlejs.com/ + */ +(function(){ + +var chunker = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g, +	done = 0, +	toString = Object.prototype.toString, +	hasDuplicate = false, +	baseHasDuplicate = true; + +// Here we check if the JavaScript engine is using some sort of +// optimization where it does not always call our comparision +// function. If that is the case, discard the hasDuplicate value. +//   Thus far that includes Google Chrome. +[0, 0].sort(function(){ +	baseHasDuplicate = false; +	return 0; +}); + +var Sizzle = function(selector, context, results, seed) { +	results = results || []; +	var origContext = context = context || document; + +	if ( context.nodeType !== 1 && context.nodeType !== 9 ) { +		return []; +	} +	 +	if ( !selector || typeof selector !== "string" ) { +		return results; +	} + +	var parts = [], m, set, checkSet, extra, prune = true, contextXML = isXML(context), +		soFar = selector; +	 +	// Reset the position of the chunker regexp (start from head) +	while ( (chunker.exec(""), m = chunker.exec(soFar)) !== null ) { +		soFar = m[3]; +		 +		parts.push( m[1] ); +		 +		if ( m[2] ) { +			extra = m[3]; +			break; +		} +	} + +	if ( parts.length > 1 && origPOS.exec( selector ) ) { +		if ( parts.length === 2 && Expr.relative[ parts[0] ] ) { +			set = posProcess( parts[0] + parts[1], context ); +		} else { +			set = Expr.relative[ parts[0] ] ? +				[ context ] : +				Sizzle( parts.shift(), context ); + +			while ( parts.length ) { +				selector = parts.shift(); + +				if ( Expr.relative[ selector ] ) { +					selector += parts.shift(); +				} +				 +				set = posProcess( selector, set ); +			} +		} +	} else { +		// Take a shortcut and set the context if the root selector is an ID +		// (but not if it'll be faster if the inner selector is an ID) +		if ( !seed && parts.length > 1 && context.nodeType === 9 && !contextXML && +				Expr.match.ID.test(parts[0]) && !Expr.match.ID.test(parts[parts.length - 1]) ) { +			var ret = Sizzle.find( parts.shift(), context, contextXML ); +			context = ret.expr ? Sizzle.filter( ret.expr, ret.set )[0] : ret.set[0]; +		} + +		if ( context ) { +			var ret = seed ? +				{ expr: parts.pop(), set: makeArray(seed) } : +				Sizzle.find( parts.pop(), parts.length === 1 && (parts[0] === "~" || parts[0] === "+") && context.parentNode ? context.parentNode : context, contextXML ); +			set = ret.expr ? Sizzle.filter( ret.expr, ret.set ) : ret.set; + +			if ( parts.length > 0 ) { +				checkSet = makeArray(set); +			} else { +				prune = false; +			} + +			while ( parts.length ) { +				var cur = parts.pop(), pop = cur; + +				if ( !Expr.relative[ cur ] ) { +					cur = ""; +				} else { +					pop = parts.pop(); +				} + +				if ( pop == null ) { +					pop = context; +				} + +				Expr.relative[ cur ]( checkSet, pop, contextXML ); +			} +		} else { +			checkSet = parts = []; +		} +	} + +	if ( !checkSet ) { +		checkSet = set; +	} + +	if ( !checkSet ) { +		Sizzle.error( cur || selector ); +	} + +	if ( toString.call(checkSet) === "[object Array]" ) { +		if ( !prune ) { +			results.push.apply( results, checkSet ); +		} else if ( context && context.nodeType === 1 ) { +			for ( var i = 0; checkSet[i] != null; i++ ) { +				if ( checkSet[i] && (checkSet[i] === true || checkSet[i].nodeType === 1 && contains(context, checkSet[i])) ) { +					results.push( set[i] ); +				} +			} +		} else { +			for ( var i = 0; checkSet[i] != null; i++ ) { +				if ( checkSet[i] && checkSet[i].nodeType === 1 ) { +					results.push( set[i] ); +				} +			} +		} +	} else { +		makeArray( checkSet, results ); +	} + +	if ( extra ) { +		Sizzle( extra, origContext, results, seed ); +		Sizzle.uniqueSort( results ); +	} + +	return results; +}; + +Sizzle.uniqueSort = function(results){ +	if ( sortOrder ) { +		hasDuplicate = baseHasDuplicate; +		results.sort(sortOrder); + +		if ( hasDuplicate ) { +			for ( var i = 1; i < results.length; i++ ) { +				if ( results[i] === results[i-1] ) { +					results.splice(i--, 1); +				} +			} +		} +	} + +	return results; +}; + +Sizzle.matches = function(expr, set){ +	return Sizzle(expr, null, null, set); +}; + +Sizzle.find = function(expr, context, isXML){ +	var set, match; + +	if ( !expr ) { +		return []; +	} + +	for ( var i = 0, l = Expr.order.length; i < l; i++ ) { +		var type = Expr.order[i], match; +		 +		if ( (match = Expr.leftMatch[ type ].exec( expr )) ) { +			var left = match[1]; +			match.splice(1,1); + +			if ( left.substr( left.length - 1 ) !== "\\" ) { +				match[1] = (match[1] || "").replace(/\\/g, ""); +				set = Expr.find[ type ]( match, context, isXML ); +				if ( set != null ) { +					expr = expr.replace( Expr.match[ type ], "" ); +					break; +				} +			} +		} +	} + +	if ( !set ) { +		set = context.getElementsByTagName("*"); +	} + +	return {set: set, expr: expr}; +}; + +Sizzle.filter = function(expr, set, inplace, not){ +	var old = expr, result = [], curLoop = set, match, anyFound, +		isXMLFilter = set && set[0] && isXML(set[0]); + +	while ( expr && set.length ) { +		for ( var type in Expr.filter ) { +			if ( (match = Expr.leftMatch[ type ].exec( expr )) != null && match[2] ) { +				var filter = Expr.filter[ type ], found, item, left = match[1]; +				anyFound = false; + +				match.splice(1,1); + +				if ( left.substr( left.length - 1 ) === "\\" ) { +					continue; +				} + +				if ( curLoop === result ) { +					result = []; +				} + +				if ( Expr.preFilter[ type ] ) { +					match = Expr.preFilter[ type ]( match, curLoop, inplace, result, not, isXMLFilter ); + +					if ( !match ) { +						anyFound = found = true; +					} else if ( match === true ) { +						continue; +					} +				} + +				if ( match ) { +					for ( var i = 0; (item = curLoop[i]) != null; i++ ) { +						if ( item ) { +							found = filter( item, match, i, curLoop ); +							var pass = not ^ !!found; + +							if ( inplace && found != null ) { +								if ( pass ) { +									anyFound = true; +								} else { +									curLoop[i] = false; +								} +							} else if ( pass ) { +								result.push( item ); +								anyFound = true; +							} +						} +					} +				} + +				if ( found !== undefined ) { +					if ( !inplace ) { +						curLoop = result; +					} + +					expr = expr.replace( Expr.match[ type ], "" ); + +					if ( !anyFound ) { +						return []; +					} + +					break; +				} +			} +		} + +		// Improper expression +		if ( expr === old ) { +			if ( anyFound == null ) { +				Sizzle.error( expr ); +			} else { +				break; +			} +		} + +		old = expr; +	} + +	return curLoop; +}; + +Sizzle.error = function( msg ) { +	throw "Syntax error, unrecognized expression: " + msg; +}; + +var Expr = Sizzle.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\))?/ +	}, +	leftMatch: {}, +	attrMap: { +		"class": "className", +		"for": "htmlFor" +	}, +	attrHandle: { +		href: function(elem){ +			return elem.getAttribute("href"); +		} +	}, +	relative: { +		"+": function(checkSet, part){ +			var isPartStr = typeof part === "string", +				isTag = isPartStr && !/\W/.test(part), +				isPartStrNotTag = isPartStr && !isTag; + +			if ( isTag ) { +				part = part.toLowerCase(); +			} + +			for ( var i = 0, l = checkSet.length, elem; i < l; i++ ) { +				if ( (elem = checkSet[i]) ) { +					while ( (elem = elem.previousSibling) && elem.nodeType !== 1 ) {} + +					checkSet[i] = isPartStrNotTag || elem && elem.nodeName.toLowerCase() === part ? +						elem || false : +						elem === part; +				} +			} + +			if ( isPartStrNotTag ) { +				Sizzle.filter( part, checkSet, true ); +			} +		}, +		">": function(checkSet, part){ +			var isPartStr = typeof part === "string"; + +			if ( isPartStr && !/\W/.test(part) ) { +				part = part.toLowerCase(); + +				for ( var i = 0, l = checkSet.length; i < l; i++ ) { +					var elem = checkSet[i]; +					if ( elem ) { +						var parent = elem.parentNode; +						checkSet[i] = parent.nodeName.toLowerCase() === part ? parent : false; +					} +				} +			} else { +				for ( var i = 0, l = checkSet.length; i < l; i++ ) { +					var elem = checkSet[i]; +					if ( elem ) { +						checkSet[i] = isPartStr ? +							elem.parentNode : +							elem.parentNode === part; +					} +				} + +				if ( isPartStr ) { +					Sizzle.filter( part, checkSet, true ); +				} +			} +		}, +		"": function(checkSet, part, isXML){ +			var doneName = done++, checkFn = dirCheck; + +			if ( typeof part === "string" && !/\W/.test(part) ) { +				var nodeCheck = part = part.toLowerCase(); +				checkFn = dirNodeCheck; +			} + +			checkFn("parentNode", part, doneName, checkSet, nodeCheck, isXML); +		}, +		"~": function(checkSet, part, isXML){ +			var doneName = done++, checkFn = dirCheck; + +			if ( typeof part === "string" && !/\W/.test(part) ) { +				var nodeCheck = part = part.toLowerCase(); +				checkFn = dirNodeCheck; +			} + +			checkFn("previousSibling", part, doneName, checkSet, nodeCheck, isXML); +		} +	}, +	find: { +		ID: function(match, context, isXML){ +			if ( typeof context.getElementById !== "undefined" && !isXML ) { +				var m = context.getElementById(match[1]); +				return m ? [m] : []; +			} +		}, +		NAME: function(match, context){ +			if ( typeof context.getElementsByName !== "undefined" ) { +				var ret = [], results = context.getElementsByName(match[1]); + +				for ( var i = 0, l = results.length; i < l; i++ ) { +					if ( results[i].getAttribute("name") === match[1] ) { +						ret.push( results[i] ); +					} +				} + +				return ret.length === 0 ? null : ret; +			} +		}, +		TAG: function(match, context){ +			return context.getElementsByTagName(match[1]); +		} +	}, +	preFilter: { +		CLASS: function(match, curLoop, inplace, result, not, isXML){ +			match = " " + match[1].replace(/\\/g, "") + " "; + +			if ( isXML ) { +				return match; +			} + +			for ( var i = 0, elem; (elem = curLoop[i]) != null; i++ ) { +				if ( elem ) { +					if ( not ^ (elem.className && (" " + elem.className + " ").replace(/[\t\n]/g, " ").indexOf(match) >= 0) ) { +						if ( !inplace ) { +							result.push( elem ); +						} +					} else if ( inplace ) { +						curLoop[i] = false; +					} +				} +			} + +			return false; +		}, +		ID: function(match){ +			return match[1].replace(/\\/g, ""); +		}, +		TAG: function(match, curLoop){ +			return match[1].toLowerCase(); +		}, +		CHILD: function(match){ +			if ( match[1] === "nth" ) { +				// parse equations like 'even', 'odd', '5', '2n', '3n+2', '4n-1', '-n+6' +				var test = /(-?)(\d*)n((?:\+|-)?\d*)/.exec( +					match[2] === "even" && "2n" || match[2] === "odd" && "2n+1" || +					!/\D/.test( match[2] ) && "0n+" + match[2] || match[2]); + +				// calculate the numbers (first)n+(last) including if they are negative +				match[2] = (test[1] + (test[2] || 1)) - 0; +				match[3] = test[3] - 0; +			} + +			// TODO: Move to normal caching system +			match[0] = done++; + +			return match; +		}, +		ATTR: function(match, curLoop, inplace, result, not, isXML){ +			var name = match[1].replace(/\\/g, ""); +			 +			if ( !isXML && Expr.attrMap[name] ) { +				match[1] = Expr.attrMap[name]; +			} + +			if ( match[2] === "~=" ) { +				match[4] = " " + match[4] + " "; +			} + +			return match; +		}, +		PSEUDO: function(match, curLoop, inplace, result, not){ +			if ( match[1] === "not" ) { +				// If we're dealing with a complex expression, or a simple one +				if ( ( chunker.exec(match[3]) || "" ).length > 1 || /^\w/.test(match[3]) ) { +					match[3] = Sizzle(match[3], null, null, curLoop); +				} else { +					var ret = Sizzle.filter(match[3], curLoop, inplace, true ^ not); +					if ( !inplace ) { +						result.push.apply( result, ret ); +					} +					return false; +				} +			} else if ( Expr.match.POS.test( match[0] ) || Expr.match.CHILD.test( match[0] ) ) { +				return true; +			} +			 +			return match; +		}, +		POS: function(match){ +			match.unshift( true ); +			return match; +		} +	}, +	filters: { +		enabled: function(elem){ +			return elem.disabled === false && elem.type !== "hidden"; +		}, +		disabled: function(elem){ +			return elem.disabled === true; +		}, +		checked: function(elem){ +			return elem.checked === true; +		}, +		selected: function(elem){ +			// Accessing this property makes selected-by-default +			// options in Safari work properly +			elem.parentNode.selectedIndex; +			return elem.selected === true; +		}, +		parent: function(elem){ +			return !!elem.firstChild; +		}, +		empty: function(elem){ +			return !elem.firstChild; +		}, +		has: function(elem, i, match){ +			return !!Sizzle( match[3], elem ).length; +		}, +		header: function(elem){ +			return /h\d/i.test( elem.nodeName ); +		}, +		text: function(elem){ +			return "text" === elem.type; +		}, +		radio: function(elem){ +			return "radio" === elem.type; +		}, +		checkbox: function(elem){ +			return "checkbox" === elem.type; +		}, +		file: function(elem){ +			return "file" === elem.type; +		}, +		password: function(elem){ +			return "password" === elem.type; +		}, +		submit: function(elem){ +			return "submit" === elem.type; +		}, +		image: function(elem){ +			return "image" === elem.type; +		}, +		reset: function(elem){ +			return "reset" === elem.type; +		}, +		button: function(elem){ +			return "button" === elem.type || elem.nodeName.toLowerCase() === "button"; +		}, +		input: function(elem){ +			return /input|select|textarea|button/i.test(elem.nodeName); +		} +	}, +	setFilters: { +		first: function(elem, i){ +			return i === 0; +		}, +		last: function(elem, i, match, array){ +			return i === array.length - 1; +		}, +		even: function(elem, i){ +			return i % 2 === 0; +		}, +		odd: function(elem, i){ +			return i % 2 === 1; +		}, +		lt: function(elem, i, match){ +			return i < match[3] - 0; +		}, +		gt: function(elem, i, match){ +			return i > match[3] - 0; +		}, +		nth: function(elem, i, match){ +			return match[3] - 0 === i; +		}, +		eq: function(elem, i, match){ +			return match[3] - 0 === i; +		} +	}, +	filter: { +		PSEUDO: function(elem, match, i, array){ +			var name = match[1], filter = Expr.filters[ name ]; + +			if ( filter ) { +				return filter( elem, i, match, array ); +			} else if ( name === "contains" ) { +				return (elem.textContent || elem.innerText || getText([ elem ]) || "").indexOf(match[3]) >= 0; +			} else if ( name === "not" ) { +				var not = match[3]; + +				for ( var i = 0, l = not.length; i < l; i++ ) { +					if ( not[i] === elem ) { +						return false; +					} +				} + +				return true; +			} else { +				Sizzle.error( "Syntax error, unrecognized expression: " + name ); +			} +		}, +		CHILD: function(elem, match){ +			var type = match[1], node = elem; +			switch (type) { +				case 'only': +				case 'first': +					while ( (node = node.previousSibling) )	 { +						if ( node.nodeType === 1 ) {  +							return false;  +						} +					} +					if ( type === "first" ) {  +						return true;  +					} +					node = elem; +				case 'last': +					while ( (node = node.nextSibling) )	 { +						if ( node.nodeType === 1 ) {  +							return false;  +						} +					} +					return true; +				case 'nth': +					var first = match[2], last = match[3]; + +					if ( first === 1 && last === 0 ) { +						return true; +					} +					 +					var doneName = match[0], +						parent = elem.parentNode; +	 +					if ( parent && (parent.sizcache !== doneName || !elem.nodeIndex) ) { +						var count = 0; +						for ( node = parent.firstChild; node; node = node.nextSibling ) { +							if ( node.nodeType === 1 ) { +								node.nodeIndex = ++count; +							} +						}  +						parent.sizcache = doneName; +					} +					 +					var diff = elem.nodeIndex - last; +					if ( first === 0 ) { +						return diff === 0; +					} else { +						return ( diff % first === 0 && diff / first >= 0 ); +					} +			} +		}, +		ID: function(elem, match){ +			return elem.nodeType === 1 && elem.getAttribute("id") === match; +		}, +		TAG: function(elem, match){ +			return (match === "*" && elem.nodeType === 1) || elem.nodeName.toLowerCase() === match; +		}, +		CLASS: function(elem, match){ +			return (" " + (elem.className || elem.getAttribute("class")) + " ") +				.indexOf( match ) > -1; +		}, +		ATTR: function(elem, match){ +			var name = match[1], +				result = Expr.attrHandle[ name ] ? +					Expr.attrHandle[ name ]( elem ) : +					elem[ name ] != null ? +						elem[ name ] : +						elem.getAttribute( name ), +				value = result + "", +				type = match[2], +				check = match[4]; + +			return result == null ? +				type === "!=" : +				type === "=" ? +				value === check : +				type === "*=" ? +				value.indexOf(check) >= 0 : +				type === "~=" ? +				(" " + value + " ").indexOf(check) >= 0 : +				!check ? +				value && result !== false : +				type === "!=" ? +				value !== check : +				type === "^=" ? +				value.indexOf(check) === 0 : +				type === "$=" ? +				value.substr(value.length - check.length) === check : +				type === "|=" ? +				value === check || value.substr(0, check.length + 1) === check + "-" : +				false; +		}, +		POS: function(elem, match, i, array){ +			var name = match[2], filter = Expr.setFilters[ name ]; + +			if ( filter ) { +				return filter( elem, i, match, array ); +			} +		} +	} +}; + +var origPOS = Expr.match.POS; + +for ( var type in Expr.match ) { +	Expr.match[ type ] = new RegExp( Expr.match[ type ].source + /(?![^\[]*\])(?![^\(]*\))/.source ); +	Expr.leftMatch[ type ] = new RegExp( /(^(?:.|\r|\n)*?)/.source + Expr.match[ type ].source.replace(/\\(\d+)/g, function(all, num){ +		return "\\" + (num - 0 + 1); +	})); +} + +var makeArray = function(array, results) { +	array = Array.prototype.slice.call( array, 0 ); + +	if ( results ) { +		results.push.apply( results, array ); +		return results; +	} +	 +	return array; +}; + +// Perform a simple check to determine if the browser is capable of +// converting a NodeList to an array using builtin methods. +try { +	Array.prototype.slice.call( document.documentElement.childNodes, 0 ); + +// Provide a fallback method if it does not work +} catch(e){ +	makeArray = function(array, results) { +		var ret = results || []; + +		if ( toString.call(array) === "[object Array]" ) { +			Array.prototype.push.apply( ret, array ); +		} else { +			if ( typeof array.length === "number" ) { +				for ( var i = 0, l = array.length; i < l; i++ ) { +					ret.push( array[i] ); +				} +			} else { +				for ( var i = 0; array[i]; i++ ) { +					ret.push( array[i] ); +				} +			} +		} + +		return ret; +	}; +} + +var sortOrder; + +if ( document.documentElement.compareDocumentPosition ) { +	sortOrder = function( a, b ) { +		if ( !a.compareDocumentPosition || !b.compareDocumentPosition ) { +			if ( a == b ) { +				hasDuplicate = true; +			} +			return a.compareDocumentPosition ? -1 : 1; +		} + +		var ret = a.compareDocumentPosition(b) & 4 ? -1 : a === b ? 0 : 1; +		if ( ret === 0 ) { +			hasDuplicate = true; +		} +		return ret; +	}; +} else if ( "sourceIndex" in document.documentElement ) { +	sortOrder = function( a, b ) { +		if ( !a.sourceIndex || !b.sourceIndex ) { +			if ( a == b ) { +				hasDuplicate = true; +			} +			return a.sourceIndex ? -1 : 1; +		} + +		var ret = a.sourceIndex - b.sourceIndex; +		if ( ret === 0 ) { +			hasDuplicate = true; +		} +		return ret; +	}; +} else if ( document.createRange ) { +	sortOrder = function( a, b ) { +		if ( !a.ownerDocument || !b.ownerDocument ) { +			if ( a == b ) { +				hasDuplicate = true; +			} +			return a.ownerDocument ? -1 : 1; +		} + +		var aRange = a.ownerDocument.createRange(), bRange = b.ownerDocument.createRange(); +		aRange.setStart(a, 0); +		aRange.setEnd(a, 0); +		bRange.setStart(b, 0); +		bRange.setEnd(b, 0); +		var ret = aRange.compareBoundaryPoints(Range.START_TO_END, bRange); +		if ( ret === 0 ) { +			hasDuplicate = true; +		} +		return ret; +	}; +} + +// Utility function for retreiving the text value of an array of DOM nodes +function getText( elems ) { +	var ret = "", elem; + +	for ( var i = 0; elems[i]; i++ ) { +		elem = elems[i]; + +		// Get the text from text nodes and CDATA nodes +		if ( elem.nodeType === 3 || elem.nodeType === 4 ) { +			ret += elem.nodeValue; + +		// Traverse everything else, except comment nodes +		} else if ( elem.nodeType !== 8 ) { +			ret += getText( elem.childNodes ); +		} +	} + +	return ret; +} + +// Check to see if the browser returns elements by name when +// querying by getElementById (and provide a workaround) +(function(){ +	// We're going to inject a fake input element with a specified name +	var form = document.createElement("div"), +		id = "script" + (new Date).getTime(); +	form.innerHTML = "<a name='" + id + "'/>"; + +	// Inject it into the root element, check its status, and remove it quickly +	var root = document.documentElement; +	root.insertBefore( form, root.firstChild ); + +	// The workaround has to do additional checks after a getElementById +	// Which slows things down for other browsers (hence the branching) +	if ( document.getElementById( id ) ) { +		Expr.find.ID = function(match, context, isXML){ +			if ( typeof context.getElementById !== "undefined" && !isXML ) { +				var m = context.getElementById(match[1]); +				return m ? m.id === match[1] || typeof m.getAttributeNode !== "undefined" && m.getAttributeNode("id").nodeValue === match[1] ? [m] : undefined : []; +			} +		}; + +		Expr.filter.ID = function(elem, match){ +			var node = typeof elem.getAttributeNode !== "undefined" && elem.getAttributeNode("id"); +			return elem.nodeType === 1 && node && node.nodeValue === match; +		}; +	} + +	root.removeChild( form ); +	root = form = null; // release memory in IE +})(); + +(function(){ +	// Check to see if the browser returns only elements +	// when doing getElementsByTagName("*") + +	// Create a fake element +	var div = document.createElement("div"); +	div.appendChild( document.createComment("") ); + +	// Make sure no comments are found +	if ( div.getElementsByTagName("*").length > 0 ) { +		Expr.find.TAG = function(match, context){ +			var results = context.getElementsByTagName(match[1]); + +			// Filter out possible comments +			if ( match[1] === "*" ) { +				var tmp = []; + +				for ( var i = 0; results[i]; i++ ) { +					if ( results[i].nodeType === 1 ) { +						tmp.push( results[i] ); +					} +				} + +				results = tmp; +			} + +			return results; +		}; +	} + +	// Check to see if an attribute returns normalized href attributes +	div.innerHTML = "<a href='#'></a>"; +	if ( div.firstChild && typeof div.firstChild.getAttribute !== "undefined" && +			div.firstChild.getAttribute("href") !== "#" ) { +		Expr.attrHandle.href = function(elem){ +			return elem.getAttribute("href", 2); +		}; +	} + +	div = null; // release memory in IE +})(); + +if ( document.querySelectorAll ) { +	(function(){ +		var oldSizzle = Sizzle, div = document.createElement("div"); +		div.innerHTML = "<p class='TEST'></p>"; + +		// Safari can't handle uppercase or unicode characters when +		// in quirks mode. +		if ( div.querySelectorAll && div.querySelectorAll(".TEST").length === 0 ) { +			return; +		} +	 +		Sizzle = function(query, context, extra, seed){ +			context = context || document; + +			// Only use querySelectorAll on non-XML documents +			// (ID selectors don't work in non-HTML documents) +			if ( !seed && context.nodeType === 9 && !isXML(context) ) { +				try { +					return makeArray( context.querySelectorAll(query), extra ); +				} catch(e){} +			} +		 +			return oldSizzle(query, context, extra, seed); +		}; + +		for ( var prop in oldSizzle ) { +			Sizzle[ prop ] = oldSizzle[ prop ]; +		} + +		div = null; // release memory in IE +	})(); +} + +(function(){ +	var div = document.createElement("div"); + +	div.innerHTML = "<div class='test e'></div><div class='test'></div>"; + +	// Opera can't find a second classname (in 9.6) +	// Also, make sure that getElementsByClassName actually exists +	if ( !div.getElementsByClassName || div.getElementsByClassName("e").length === 0 ) { +		return; +	} + +	// Safari caches class attributes, doesn't catch changes (in 3.2) +	div.lastChild.className = "e"; + +	if ( div.getElementsByClassName("e").length === 1 ) { +		return; +	} +	 +	Expr.order.splice(1, 0, "CLASS"); +	Expr.find.CLASS = function(match, context, isXML) { +		if ( typeof context.getElementsByClassName !== "undefined" && !isXML ) { +			return context.getElementsByClassName(match[1]); +		} +	}; + +	div = null; // release memory in IE +})(); + +function dirNodeCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) { +	for ( var i = 0, l = checkSet.length; i < l; i++ ) { +		var elem = checkSet[i]; +		if ( elem ) { +			elem = elem[dir]; +			var match = false; + +			while ( elem ) { +				if ( elem.sizcache === doneName ) { +					match = checkSet[elem.sizset]; +					break; +				} + +				if ( elem.nodeType === 1 && !isXML ){ +					elem.sizcache = doneName; +					elem.sizset = i; +				} + +				if ( elem.nodeName.toLowerCase() === cur ) { +					match = elem; +					break; +				} + +				elem = elem[dir]; +			} + +			checkSet[i] = match; +		} +	} +} + +function dirCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) { +	for ( var i = 0, l = checkSet.length; i < l; i++ ) { +		var elem = checkSet[i]; +		if ( elem ) { +			elem = elem[dir]; +			var match = false; + +			while ( elem ) { +				if ( elem.sizcache === doneName ) { +					match = checkSet[elem.sizset]; +					break; +				} + +				if ( elem.nodeType === 1 ) { +					if ( !isXML ) { +						elem.sizcache = doneName; +						elem.sizset = i; +					} +					if ( typeof cur !== "string" ) { +						if ( elem === cur ) { +							match = true; +							break; +						} + +					} else if ( Sizzle.filter( cur, [elem] ).length > 0 ) { +						match = elem; +						break; +					} +				} + +				elem = elem[dir]; +			} + +			checkSet[i] = match; +		} +	} +} + +var contains = document.compareDocumentPosition ? function(a, b){ +	return a.compareDocumentPosition(b) & 16; +} : function(a, b){ +	return a !== b && (a.contains ? a.contains(b) : true); +}; + +var isXML = function(elem){ +	// documentElement is verified for cases where it doesn't yet exist +	// (such as loading iframes in IE - #4833)  +	var documentElement = (elem ? elem.ownerDocument || elem : 0).documentElement; +	return documentElement ? documentElement.nodeName !== "HTML" : false; +}; + +var posProcess = function(selector, context){ +	var tmpSet = [], later = "", match, +		root = context.nodeType ? [context] : context; + +	// Position selectors must be done after the filter +	// And so must :not(positional) so we move all PSEUDOs to the end +	while ( (match = Expr.match.PSEUDO.exec( selector )) ) { +		later += match[0]; +		selector = selector.replace( Expr.match.PSEUDO, "" ); +	} + +	selector = Expr.relative[selector] ? selector + "*" : selector; + +	for ( var i = 0, l = root.length; i < l; i++ ) { +		Sizzle( selector, root[i], tmpSet ); +	} + +	return Sizzle.filter( later, tmpSet ); +}; + +// EXPOSE +jQuery.find = Sizzle; +jQuery.expr = Sizzle.selectors; +jQuery.expr[":"] = jQuery.expr.filters; +jQuery.unique = Sizzle.uniqueSort; +jQuery.getText = getText; +jQuery.isXMLDoc = isXML; +jQuery.contains = contains; + +return; + +window.Sizzle = Sizzle; + +})(); +var runtil = /Until$/, +	rparentsprev = /^(?:parents|prevUntil|prevAll)/, +	// Note: This RegExp should be improved, or likely pulled from Sizzle +	rmultiselector = /,/, +	slice = Array.prototype.slice; + +// Implement the identical functionality for filter and not +var winnow = function( elements, qualifier, keep ) { +	if ( jQuery.isFunction( qualifier ) ) { +		return jQuery.grep(elements, function( elem, i ) { +			return !!qualifier.call( elem, i, elem ) === keep; +		}); + +	} else if ( qualifier.nodeType ) { +		return jQuery.grep(elements, function( elem, i ) { +			return (elem === qualifier) === keep; +		}); + +	} else if ( typeof qualifier === "string" ) { +		var filtered = jQuery.grep(elements, function( elem ) { +			return elem.nodeType === 1; +		}); + +		if ( isSimple.test( qualifier ) ) { +			return jQuery.filter(qualifier, filtered, !keep); +		} else { +			qualifier = jQuery.filter( qualifier, filtered ); +		} +	} + +	return jQuery.grep(elements, function( elem, i ) { +		return (jQuery.inArray( elem, qualifier ) >= 0) === keep; +	}); +}; + +jQuery.fn.extend({ +	find: function( selector ) { +		var ret = this.pushStack( "", "find", selector ), length = 0; + +		for ( var i = 0, l = this.length; i < l; i++ ) { +			length = ret.length; +			jQuery.find( selector, this[i], ret ); + +			if ( i > 0 ) { +				// Make sure that the results are unique +				for ( var n = length; n < ret.length; n++ ) { +					for ( var r = 0; r < length; r++ ) { +						if ( ret[r] === ret[n] ) { +							ret.splice(n--, 1); +							break; +						} +					} +				} +			} +		} + +		return ret; +	}, + +	has: function( target ) { +		var targets = jQuery( target ); +		return this.filter(function() { +			for ( var i = 0, l = targets.length; i < l; i++ ) { +				if ( jQuery.contains( this, targets[i] ) ) { +					return true; +				} +			} +		}); +	}, + +	not: function( selector ) { +		return this.pushStack( winnow(this, selector, false), "not", selector); +	}, + +	filter: function( selector ) { +		return this.pushStack( winnow(this, selector, true), "filter", selector ); +	}, +	 +	is: function( selector ) { +		return !!selector && jQuery.filter( selector, this ).length > 0; +	}, + +	closest: function( selectors, context ) { +		if ( jQuery.isArray( selectors ) ) { +			var ret = [], cur = this[0], match, matches = {}, selector; + +			if ( cur && selectors.length ) { +				for ( var i = 0, l = selectors.length; i < l; i++ ) { +					selector = selectors[i]; + +					if ( !matches[selector] ) { +						matches[selector] = jQuery.expr.match.POS.test( selector ) ?  +							jQuery( selector, context || this.context ) : +							selector; +					} +				} + +				while ( cur && cur.ownerDocument && cur !== context ) { +					for ( selector in matches ) { +						match = matches[selector]; + +						if ( match.jquery ? match.index(cur) > -1 : jQuery(cur).is(match) ) { +							ret.push({ selector: selector, elem: cur }); +							delete matches[selector]; +						} +					} +					cur = cur.parentNode; +				} +			} + +			return ret; +		} + +		var pos = jQuery.expr.match.POS.test( selectors ) ?  +			jQuery( selectors, context || this.context ) : null; + +		return this.map(function( i, cur ) { +			while ( cur && cur.ownerDocument && cur !== context ) { +				if ( pos ? pos.index(cur) > -1 : jQuery(cur).is(selectors) ) { +					return cur; +				} +				cur = cur.parentNode; +			} +			return null; +		}); +	}, +	 +	// Determine the position of an element within +	// the matched set of elements +	index: function( elem ) { +		if ( !elem || typeof elem === "string" ) { +			return jQuery.inArray( this[0], +				// If it receives a string, the selector is used +				// If it receives nothing, the siblings are used +				elem ? jQuery( elem ) : this.parent().children() ); +		} +		// Locate the position of the desired element +		return jQuery.inArray( +			// If it receives a jQuery object, the first element is used +			elem.jquery ? elem[0] : elem, this ); +	}, + +	add: function( selector, context ) { +		var set = typeof selector === "string" ? +				jQuery( selector, context || this.context ) : +				jQuery.makeArray( selector ), +			all = jQuery.merge( this.get(), set ); + +		return this.pushStack( isDisconnected( set[0] ) || isDisconnected( all[0] ) ? +			all : +			jQuery.unique( all ) ); +	}, + +	andSelf: function() { +		return this.add( this.prevObject ); +	} +}); + +// A painfully simple check to see if an element is disconnected +// from a document (should be improved, where feasible). +function isDisconnected( node ) { +	return !node || !node.parentNode || node.parentNode.nodeType === 11; +} + +jQuery.each({ +	parent: function( elem ) { +		var parent = elem.parentNode; +		return parent && parent.nodeType !== 11 ? parent : null; +	}, +	parents: function( elem ) { +		return jQuery.dir( elem, "parentNode" ); +	}, +	parentsUntil: function( elem, i, until ) { +		return jQuery.dir( elem, "parentNode", until ); +	}, +	next: function( elem ) { +		return jQuery.nth( elem, 2, "nextSibling" ); +	}, +	prev: function( elem ) { +		return jQuery.nth( elem, 2, "previousSibling" ); +	}, +	nextAll: function( elem ) { +		return jQuery.dir( elem, "nextSibling" ); +	}, +	prevAll: function( elem ) { +		return jQuery.dir( elem, "previousSibling" ); +	}, +	nextUntil: function( elem, i, until ) { +		return jQuery.dir( elem, "nextSibling", until ); +	}, +	prevUntil: function( elem, i, until ) { +		return jQuery.dir( elem, "previousSibling", until ); +	}, +	siblings: function( elem ) { +		return jQuery.sibling( elem.parentNode.firstChild, elem ); +	}, +	children: function( elem ) { +		return jQuery.sibling( elem.firstChild ); +	}, +	contents: function( elem ) { +		return jQuery.nodeName( elem, "iframe" ) ? +			elem.contentDocument || elem.contentWindow.document : +			jQuery.makeArray( elem.childNodes ); +	} +}, function( name, fn ) { +	jQuery.fn[ name ] = function( until, selector ) { +		var ret = jQuery.map( this, fn, until ); +		 +		if ( !runtil.test( name ) ) { +			selector = until; +		} + +		if ( selector && typeof selector === "string" ) { +			ret = jQuery.filter( selector, ret ); +		} + +		ret = this.length > 1 ? jQuery.unique( ret ) : ret; + +		if ( (this.length > 1 || rmultiselector.test( selector )) && rparentsprev.test( name ) ) { +			ret = ret.reverse(); +		} + +		return this.pushStack( ret, name, slice.call(arguments).join(",") ); +	}; +}); + +jQuery.extend({ +	filter: function( expr, elems, not ) { +		if ( not ) { +			expr = ":not(" + expr + ")"; +		} + +		return jQuery.find.matches(expr, elems); +	}, +	 +	dir: function( elem, dir, until ) { +		var matched = [], cur = elem[dir]; +		while ( cur && cur.nodeType !== 9 && (until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until )) ) { +			if ( cur.nodeType === 1 ) { +				matched.push( cur ); +			} +			cur = cur[dir]; +		} +		return matched; +	}, + +	nth: function( cur, result, dir, elem ) { +		result = result || 1; +		var num = 0; + +		for ( ; cur; cur = cur[dir] ) { +			if ( cur.nodeType === 1 && ++num === result ) { +				break; +			} +		} + +		return cur; +	}, + +	sibling: function( n, elem ) { +		var r = []; + +		for ( ; n; n = n.nextSibling ) { +			if ( n.nodeType === 1 && n !== elem ) { +				r.push( n ); +			} +		} + +		return r; +	} +}); +var rinlinejQuery = / jQuery\d+="(?:\d+|null)"/g, +	rleadingWhitespace = /^\s+/, +	rxhtmlTag = /(<([\w:]+)[^>]*?)\/>/g, +	rselfClosing = /^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i, +	rtagName = /<([\w:]+)/, +	rtbody = /<tbody/i, +	rhtml = /<|&\w+;/, +	rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i,  // checked="checked" or checked (html5) +	fcloseTag = function( all, front, tag ) { +		return rselfClosing.test( tag ) ? +			all : +			front + "></" + tag + ">"; +	}, +	wrapMap = { +		option: [ 1, "<select multiple='multiple'>", "</select>" ], +		legend: [ 1, "<fieldset>", "</fieldset>" ], +		thead: [ 1, "<table>", "</table>" ], +		tr: [ 2, "<table><tbody>", "</tbody></table>" ], +		td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ], +		col: [ 2, "<table><tbody></tbody><colgroup>", "</colgroup></table>" ], +		area: [ 1, "<map>", "</map>" ], +		_default: [ 0, "", "" ] +	}; + +wrapMap.optgroup = wrapMap.option; +wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; +wrapMap.th = wrapMap.td; + +// IE can't serialize <link> and <script> tags normally +if ( !jQuery.support.htmlSerialize ) { +	wrapMap._default = [ 1, "div<div>", "</div>" ]; +} + +jQuery.fn.extend({ +	text: function( text ) { +		if ( jQuery.isFunction(text) ) { +			return this.each(function(i) { +				var self = jQuery(this); +				self.text( text.call(this, i, self.text()) ); +			}); +		} + +		if ( typeof text !== "object" && text !== undefined ) { +			return this.empty().append( (this[0] && this[0].ownerDocument || document).createTextNode( text ) ); +		} + +		return jQuery.getText( this ); +	}, + +	wrapAll: function( html ) { +		if ( jQuery.isFunction( html ) ) { +			return this.each(function(i) { +				jQuery(this).wrapAll( html.call(this, i) ); +			}); +		} + +		if ( this[0] ) { +			// The elements to wrap the target around +			var wrap = jQuery( html, this[0].ownerDocument ).eq(0).clone(true); + +			if ( this[0].parentNode ) { +				wrap.insertBefore( this[0] ); +			} + +			wrap.map(function() { +				var elem = this; + +				while ( elem.firstChild && elem.firstChild.nodeType === 1 ) { +					elem = elem.firstChild; +				} + +				return elem; +			}).append(this); +		} + +		return this; +	}, + +	wrapInner: function( html ) { +		if ( jQuery.isFunction( html ) ) { +			return this.each(function(i) { +				jQuery(this).wrapInner( html.call(this, i) ); +			}); +		} + +		return this.each(function() { +			var self = jQuery( this ), contents = self.contents(); + +			if ( contents.length ) { +				contents.wrapAll( html ); + +			} else { +				self.append( html ); +			} +		}); +	}, + +	wrap: function( html ) { +		return this.each(function() { +			jQuery( this ).wrapAll( html ); +		}); +	}, + +	unwrap: function() { +		return this.parent().each(function() { +			if ( !jQuery.nodeName( this, "body" ) ) { +				jQuery( this ).replaceWith( this.childNodes ); +			} +		}).end(); +	}, + +	append: function() { +		return this.domManip(arguments, true, function( elem ) { +			if ( this.nodeType === 1 ) { +				this.appendChild( elem ); +			} +		}); +	}, + +	prepend: function() { +		return this.domManip(arguments, true, function( elem ) { +			if ( this.nodeType === 1 ) { +				this.insertBefore( elem, this.firstChild ); +			} +		}); +	}, + +	before: function() { +		if ( this[0] && this[0].parentNode ) { +			return this.domManip(arguments, false, function( elem ) { +				this.parentNode.insertBefore( elem, this ); +			}); +		} else if ( arguments.length ) { +			var set = jQuery(arguments[0]); +			set.push.apply( set, this.toArray() ); +			return this.pushStack( set, "before", arguments ); +		} +	}, + +	after: function() { +		if ( this[0] && this[0].parentNode ) { +			return this.domManip(arguments, false, function( elem ) { +				this.parentNode.insertBefore( elem, this.nextSibling ); +			}); +		} else if ( arguments.length ) { +			var set = this.pushStack( this, "after", arguments ); +			set.push.apply( set, jQuery(arguments[0]).toArray() ); +			return set; +		} +	}, + +	clone: function( events ) { +		// Do the clone +		var ret = this.map(function() { +			if ( !jQuery.support.noCloneEvent && !jQuery.isXMLDoc(this) ) { +				// IE copies events bound via attachEvent when +				// using cloneNode. Calling detachEvent on the +				// clone will also remove the events from the orignal +				// In order to get around this, we use innerHTML. +				// Unfortunately, this means some modifications to +				// attributes in IE that are actually only stored +				// as properties will not be copied (such as the +				// the name attribute on an input). +				var html = this.outerHTML, ownerDocument = this.ownerDocument; +				if ( !html ) { +					var div = ownerDocument.createElement("div"); +					div.appendChild( this.cloneNode(true) ); +					html = div.innerHTML; +				} + +				return jQuery.clean([html.replace(rinlinejQuery, "") +					.replace(rleadingWhitespace, "")], ownerDocument)[0]; +			} else { +				return this.cloneNode(true); +			} +		}); + +		// Copy the events from the original to the clone +		if ( events === true ) { +			cloneCopyEvent( this, ret ); +			cloneCopyEvent( this.find("*"), ret.find("*") ); +		} + +		// Return the cloned set +		return ret; +	}, + +	html: function( value ) { +		if ( value === undefined ) { +			return this[0] && this[0].nodeType === 1 ? +				this[0].innerHTML.replace(rinlinejQuery, "") : +				null; + +		// See if we can take a shortcut and just use innerHTML +		} else if ( typeof value === "string" && !/<script/i.test( value ) && +			(jQuery.support.leadingWhitespace || !rleadingWhitespace.test( value )) && +			!wrapMap[ (rtagName.exec( value ) || ["", ""])[1].toLowerCase() ] ) { + +			value = value.replace(rxhtmlTag, fcloseTag); + +			try { +				for ( var i = 0, l = this.length; i < l; i++ ) { +					// Remove element nodes and prevent memory leaks +					if ( this[i].nodeType === 1 ) { +						jQuery.cleanData( this[i].getElementsByTagName("*") ); +						this[i].innerHTML = value; +					} +				} + +			// If using innerHTML throws an exception, use the fallback method +			} catch(e) { +				this.empty().append( value ); +			} + +		} else if ( jQuery.isFunction( value ) ) { +			this.each(function(i){ +				var self = jQuery(this), old = self.html(); +				self.empty().append(function(){ +					return value.call( this, i, old ); +				}); +			}); + +		} else { +			this.empty().append( value ); +		} + +		return this; +	}, + +	replaceWith: function( value ) { +		if ( this[0] && this[0].parentNode ) { +			// Make sure that the elements are removed from the DOM before they are inserted +			// this can help fix replacing a parent with child elements +			if ( !jQuery.isFunction( value ) ) { +				value = jQuery( value ).detach(); + +			} else { +				return this.each(function(i) { +					var self = jQuery(this), old = self.html(); +					self.replaceWith( value.call( this, i, old ) ); +				}); +			} + +			return this.each(function() { +				var next = this.nextSibling, parent = this.parentNode; + +				jQuery(this).remove(); + +				if ( next ) { +					jQuery(next).before( value ); +				} else { +					jQuery(parent).append( value ); +				} +			}); +		} else { +			return this.pushStack( jQuery(jQuery.isFunction(value) ? value() : value), "replaceWith", value ); +		} +	}, + +	detach: function( selector ) { +		return this.remove( selector, true ); +	}, + +	domManip: function( args, table, callback ) { +		var results, first, value = args[0], scripts = []; + +		// We can't cloneNode fragments that contain checked, in WebKit +		if ( !jQuery.support.checkClone && arguments.length === 3 && typeof value === "string" && rchecked.test( value ) ) { +			return this.each(function() { +				jQuery(this).domManip( args, table, callback, true ); +			}); +		} + +		if ( jQuery.isFunction(value) ) { +			return this.each(function(i) { +				var self = jQuery(this); +				args[0] = value.call(this, i, table ? self.html() : undefined); +				self.domManip( args, table, callback ); +			}); +		} + +		if ( this[0] ) { +			// If we're in a fragment, just use that instead of building a new one +			if ( args[0] && args[0].parentNode && args[0].parentNode.nodeType === 11 ) { +				results = { fragment: args[0].parentNode }; +			} else { +				results = buildFragment( args, this, scripts ); +			} + +			first = results.fragment.firstChild; + +			if ( first ) { +				table = table && jQuery.nodeName( first, "tr" ); + +				for ( var i = 0, l = this.length; i < l; i++ ) { +					callback.call( +						table ? +							root(this[i], first) : +							this[i], +						results.cacheable || this.length > 1 || i > 0 ? +							results.fragment.cloneNode(true) : +							results.fragment +					); +				} +			} + +			if ( scripts ) { +				jQuery.each( scripts, evalScript ); +			} +		} + +		return this; + +		function root( elem, cur ) { +			return jQuery.nodeName(elem, "table") ? +				(elem.getElementsByTagName("tbody")[0] || +				elem.appendChild(elem.ownerDocument.createElement("tbody"))) : +				elem; +		} +	} +}); + +function cloneCopyEvent(orig, ret) { +	var i = 0; + +	ret.each(function() { +		if ( this.nodeName !== (orig[i] && orig[i].nodeName) ) { +			return; +		} + +		var oldData = jQuery.data( orig[i++] ), curData = jQuery.data( this, oldData ), events = oldData && oldData.events; + +		if ( events ) { +			delete curData.handle; +			curData.events = {}; + +			for ( var type in events ) { +				for ( var handler in events[ type ] ) { +					jQuery.event.add( this, type, events[ type ][ handler ], events[ type ][ handler ].data ); +				} +			} +		} +	}); +} + +function buildFragment( args, nodes, scripts ) { +	var fragment, cacheable, cacheresults, doc; + +	// webkit does not clone 'checked' attribute of radio inputs on cloneNode, so don't cache if string has a checked +	if ( args.length === 1 && typeof args[0] === "string" && args[0].length < 512 && args[0].indexOf("<option") < 0 && (jQuery.support.checkClone || !rchecked.test( args[0] )) ) { +		cacheable = true; +		cacheresults = jQuery.fragments[ args[0] ]; +		if ( cacheresults ) { +			if ( cacheresults !== 1 ) { +				fragment = cacheresults; +			} +		} +	} + +	if ( !fragment ) { +		doc = (nodes && nodes[0] ? nodes[0].ownerDocument || nodes[0] : document); +		fragment = doc.createDocumentFragment(); +		jQuery.clean( args, doc, fragment, scripts ); +	} + +	if ( cacheable ) { +		jQuery.fragments[ args[0] ] = cacheresults ? fragment : 1; +	} + +	return { fragment: fragment, cacheable: cacheable }; +} + +jQuery.fragments = {}; + +jQuery.each({ +	appendTo: "append", +	prependTo: "prepend", +	insertBefore: "before", +	insertAfter: "after", +	replaceAll: "replaceWith" +}, function( name, original ) { +	jQuery.fn[ name ] = function( selector ) { +		var ret = [], insert = jQuery( selector ); + +		for ( var i = 0, l = insert.length; i < l; i++ ) { +			var elems = (i > 0 ? this.clone(true) : this).get(); +			jQuery.fn[ original ].apply( jQuery(insert[i]), elems ); +			ret = ret.concat( elems ); +		} +		return this.pushStack( ret, name, insert.selector ); +	}; +}); + +jQuery.each({ +	// keepData is for internal use only--do not document +	remove: function( selector, keepData ) { +		if ( !selector || jQuery.filter( selector, [ this ] ).length ) { +			if ( !keepData && this.nodeType === 1 ) { +				jQuery.cleanData( this.getElementsByTagName("*") ); +				jQuery.cleanData( [ this ] ); +			} + +			if ( this.parentNode ) { +				 this.parentNode.removeChild( this ); +			} +		} +	}, + +	empty: function() { +		// Remove element nodes and prevent memory leaks +		if ( this.nodeType === 1 ) { +			jQuery.cleanData( this.getElementsByTagName("*") ); +		} + +		// Remove any remaining nodes +		while ( this.firstChild ) { +			this.removeChild( this.firstChild ); +		} +	} +}, function( name, fn ) { +	jQuery.fn[ name ] = function() { +		return this.each( fn, arguments ); +	}; +}); + +jQuery.extend({ +	clean: function( elems, context, fragment, scripts ) { +		context = context || document; + +		// !context.createElement fails in IE with an error but returns typeof 'object' +		if ( typeof context.createElement === "undefined" ) { +			context = context.ownerDocument || context[0] && context[0].ownerDocument || document; +		} + +		var ret = []; + +		jQuery.each(elems, function( i, elem ) { +			if ( typeof elem === "number" ) { +				elem += ""; +			} + +			if ( !elem ) { +				return; +			} + +			// Convert html string into DOM nodes +			if ( typeof elem === "string" && !rhtml.test( elem ) ) { +				elem = context.createTextNode( elem ); + +			} else if ( typeof elem === "string" ) { +				// Fix "XHTML"-style tags in all browsers +				elem = elem.replace(rxhtmlTag, fcloseTag); + +				// Trim whitespace, otherwise indexOf won't work as expected +				var tag = (rtagName.exec( elem ) || ["", ""])[1].toLowerCase(), +					wrap = wrapMap[ tag ] || wrapMap._default, +					depth = wrap[0], +					div = context.createElement("div"); + +				// Go to html and back, then peel off extra wrappers +				div.innerHTML = wrap[1] + elem + wrap[2]; + +				// Move to the right depth +				while ( depth-- ) { +					div = div.lastChild; +				} + +				// Remove IE's autoinserted <tbody> from table fragments +				if ( !jQuery.support.tbody ) { + +					// String was a <table>, *may* have spurious <tbody> +					var hasBody = rtbody.test(elem), +						tbody = tag === "table" && !hasBody ? +							div.firstChild && div.firstChild.childNodes : + +							// String was a bare <thead> or <tfoot> +							wrap[1] === "<table>" && !hasBody ? +								div.childNodes : +								[]; + +					for ( var j = tbody.length - 1; j >= 0 ; --j ) { +						if ( jQuery.nodeName( tbody[ j ], "tbody" ) && !tbody[ j ].childNodes.length ) { +							tbody[ j ].parentNode.removeChild( tbody[ j ] ); +						} +					} + +				} + +				// IE completely kills leading whitespace when innerHTML is used +				if ( !jQuery.support.leadingWhitespace && rleadingWhitespace.test( elem ) ) { +					div.insertBefore( context.createTextNode( rleadingWhitespace.exec(elem)[0] ), div.firstChild ); +				} + +				elem = jQuery.makeArray( div.childNodes ); +			} + +			if ( elem.nodeType ) { +				ret.push( elem ); +			} else { +				ret = jQuery.merge( ret, elem ); +			} + +		}); + +		if ( fragment ) { +			for ( var i = 0; ret[i]; i++ ) { +				if ( scripts && jQuery.nodeName( ret[i], "script" ) && (!ret[i].type || ret[i].type.toLowerCase() === "text/javascript") ) { +					scripts.push( ret[i].parentNode ? ret[i].parentNode.removeChild( ret[i] ) : ret[i] ); +				} else { +					if ( ret[i].nodeType === 1 ) { +						ret.splice.apply( ret, [i + 1, 0].concat(jQuery.makeArray(ret[i].getElementsByTagName("script"))) ); +					} +					fragment.appendChild( ret[i] ); +				} +			} +		} + +		return ret; +	}, +	 +	cleanData: function( elems ) { +		for ( var i = 0, elem, id; (elem = elems[i]) != null; i++ ) { +			jQuery.event.remove( elem ); +			jQuery.removeData( elem ); +		} +	} +}); +// exclude the following css properties to add px +var rexclude = /z-?index|font-?weight|opacity|zoom|line-?height/i, +	ralpha = /alpha\([^)]*\)/, +	ropacity = /opacity=([^)]*)/, +	rfloat = /float/i, +	rdashAlpha = /-([a-z])/ig, +	rupper = /([A-Z])/g, +	rnumpx = /^-?\d+(?:px)?$/i, +	rnum = /^-?\d/, + +	cssShow = { position: "absolute", visibility: "hidden", display:"block" }, +	cssWidth = [ "Left", "Right" ], +	cssHeight = [ "Top", "Bottom" ], + +	// cache check for defaultView.getComputedStyle +	getComputedStyle = document.defaultView && document.defaultView.getComputedStyle, +	// normalize float css property +	styleFloat = jQuery.support.cssFloat ? "cssFloat" : "styleFloat", +	fcamelCase = function( all, letter ) { +		return letter.toUpperCase(); +	}; + +jQuery.fn.css = function( name, value ) { +	return access( this, name, value, true, function( elem, name, value ) { +		if ( value === undefined ) { +			return jQuery.curCSS( elem, name ); +		} +		 +		if ( typeof value === "number" && !rexclude.test(name) ) { +			value += "px"; +		} + +		jQuery.style( elem, name, value ); +	}); +}; + +jQuery.extend({ +	style: function( elem, name, value ) { +		// don't set styles on text and comment nodes +		if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 ) { +			return undefined; +		} + +		// ignore negative width and height values #1599 +		if ( (name === "width" || name === "height") && parseFloat(value) < 0 ) { +			value = undefined; +		} + +		var style = elem.style || elem, set = value !== undefined; + +		// IE uses filters for opacity +		if ( !jQuery.support.opacity && name === "opacity" ) { +			if ( set ) { +				// IE has trouble with opacity if it does not have layout +				// Force it by setting the zoom level +				style.zoom = 1; + +				// Set the alpha filter to set the opacity +				var opacity = parseInt( value, 10 ) + "" === "NaN" ? "" : "alpha(opacity=" + value * 100 + ")"; +				var filter = style.filter || jQuery.curCSS( elem, "filter" ) || ""; +				style.filter = ralpha.test(filter) ? filter.replace(ralpha, opacity) : opacity; +			} + +			return style.filter && style.filter.indexOf("opacity=") >= 0 ? +				(parseFloat( ropacity.exec(style.filter)[1] ) / 100) + "": +				""; +		} + +		// Make sure we're using the right name for getting the float value +		if ( rfloat.test( name ) ) { +			name = styleFloat; +		} + +		name = name.replace(rdashAlpha, fcamelCase); + +		if ( set ) { +			style[ name ] = value; +		} + +		return style[ name ]; +	}, + +	css: function( elem, name, force, extra ) { +		if ( name === "width" || name === "height" ) { +			var val, props = cssShow, which = name === "width" ? cssWidth : cssHeight; + +			function getWH() { +				val = name === "width" ? elem.offsetWidth : elem.offsetHeight; + +				if ( extra === "border" ) { +					return; +				} + +				jQuery.each( which, function() { +					if ( !extra ) { +						val -= parseFloat(jQuery.curCSS( elem, "padding" + this, true)) || 0; +					} + +					if ( extra === "margin" ) { +						val += parseFloat(jQuery.curCSS( elem, "margin" + this, true)) || 0; +					} else { +						val -= parseFloat(jQuery.curCSS( elem, "border" + this + "Width", true)) || 0; +					} +				}); +			} + +			if ( elem.offsetWidth !== 0 ) { +				getWH(); +			} else { +				jQuery.swap( elem, props, getWH ); +			} + +			return Math.max(0, Math.round(val)); +		} + +		return jQuery.curCSS( elem, name, force ); +	}, + +	curCSS: function( elem, name, force ) { +		var ret, style = elem.style, filter; + +		// IE uses filters for opacity +		if ( !jQuery.support.opacity && name === "opacity" && elem.currentStyle ) { +			ret = ropacity.test(elem.currentStyle.filter || "") ? +				(parseFloat(RegExp.$1) / 100) + "" : +				""; + +			return ret === "" ? +				"1" : +				ret; +		} + +		// Make sure we're using the right name for getting the float value +		if ( rfloat.test( name ) ) { +			name = styleFloat; +		} + +		if ( !force && style && style[ name ] ) { +			ret = style[ name ]; + +		} else if ( getComputedStyle ) { + +			// Only "float" is needed here +			if ( rfloat.test( name ) ) { +				name = "float"; +			} + +			name = name.replace( rupper, "-$1" ).toLowerCase(); + +			var defaultView = elem.ownerDocument.defaultView; + +			if ( !defaultView ) { +				return null; +			} + +			var computedStyle = defaultView.getComputedStyle( elem, null ); + +			if ( computedStyle ) { +				ret = computedStyle.getPropertyValue( name ); +			} + +			// We should always get a number back from opacity +			if ( name === "opacity" && ret === "" ) { +				ret = "1"; +			} + +		} else if ( elem.currentStyle ) { +			var camelCase = name.replace(rdashAlpha, fcamelCase); + +			ret = elem.currentStyle[ name ] || elem.currentStyle[ camelCase ]; + +			// From the awesome hack by Dean Edwards +			// http://erik.eae.net/archives/2007/07/27/18.54.15/#comment-102291 + +			// If we're not dealing with a regular pixel number +			// but a number that has a weird ending, we need to convert it to pixels +			if ( !rnumpx.test( ret ) && rnum.test( ret ) ) { +				// Remember the original values +				var left = style.left, rsLeft = elem.runtimeStyle.left; + +				// Put in the new values to get a computed value out +				elem.runtimeStyle.left = elem.currentStyle.left; +				style.left = camelCase === "fontSize" ? "1em" : (ret || 0); +				ret = style.pixelLeft + "px"; + +				// Revert the changed values +				style.left = left; +				elem.runtimeStyle.left = rsLeft; +			} +		} + +		return ret; +	}, + +	// A method for quickly swapping in/out CSS properties to get correct calculations +	swap: function( elem, options, callback ) { +		var old = {}; + +		// Remember the old values, and insert the new ones +		for ( var name in options ) { +			old[ name ] = elem.style[ name ]; +			elem.style[ name ] = options[ name ]; +		} + +		callback.call( elem ); + +		// Revert the old values +		for ( var name in options ) { +			elem.style[ name ] = old[ name ]; +		} +	} +}); + +if ( jQuery.expr && jQuery.expr.filters ) { +	jQuery.expr.filters.hidden = function( elem ) { +		var width = elem.offsetWidth, height = elem.offsetHeight, +			skip = elem.nodeName.toLowerCase() === "tr"; + +		return width === 0 && height === 0 && !skip ? +			true : +			width > 0 && height > 0 && !skip ? +				false : +				jQuery.curCSS(elem, "display") === "none"; +	}; + +	jQuery.expr.filters.visible = function( elem ) { +		return !jQuery.expr.filters.hidden( elem ); +	}; +} +var jsc = now(), +	rscript = /<script(.|\s)*?\/script>/gi, +	rselectTextarea = /select|textarea/i, +	rinput = /color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i, +	jsre = /=\?(&|$)/, +	rquery = /\?/, +	rts = /(\?|&)_=.*?(&|$)/, +	rurl = /^(\w+:)?\/\/([^\/?#]+)/, +	r20 = /%20/g; + +jQuery.fn.extend({ +	// Keep a copy of the old load +	_load: jQuery.fn.load, + +	load: function( url, params, callback ) { +		if ( typeof url !== "string" ) { +			return this._load( url ); + +		// Don't do a request if no elements are being requested +		} else if ( !this.length ) { +			return this; +		} + +		var off = url.indexOf(" "); +		if ( off >= 0 ) { +			var selector = url.slice(off, url.length); +			url = url.slice(0, off); +		} + +		// Default to a GET request +		var type = "GET"; + +		// If the second parameter was provided +		if ( params ) { +			// If it's a function +			if ( jQuery.isFunction( params ) ) { +				// We assume that it's the callback +				callback = params; +				params = null; + +			// Otherwise, build a param string +			} else if ( typeof params === "object" ) { +				params = jQuery.param( params, jQuery.ajaxSettings.traditional ); +				type = "POST"; +			} +		} + +		var self = this; + +		// Request the remote document +		jQuery.ajax({ +			url: url, +			type: type, +			dataType: "html", +			data: params, +			complete: function( res, status ) { +				// If successful, inject the HTML into all the matched elements +				if ( status === "success" || status === "notmodified" ) { +					// See if a selector was specified +					self.html( selector ? +						// Create a dummy div to hold the results +						jQuery("<div />") +							// inject the contents of the document in, removing the scripts +							// to avoid any 'Permission Denied' errors in IE +							.append(res.responseText.replace(rscript, "")) + +							// Locate the specified elements +							.find(selector) : + +						// If not, just inject the full result +						res.responseText ); +				} + +				if ( callback ) { +					self.each( callback, [res.responseText, status, res] ); +				} +			} +		}); + +		return this; +	}, + +	serialize: function() { +		return jQuery.param(this.serializeArray()); +	}, +	serializeArray: function() { +		return this.map(function() { +			return this.elements ? jQuery.makeArray(this.elements) : this; +		}) +		.filter(function() { +			return this.name && !this.disabled && +				(this.checked || rselectTextarea.test(this.nodeName) || +					rinput.test(this.type)); +		}) +		.map(function( i, elem ) { +			var val = jQuery(this).val(); + +			return val == null ? +				null : +				jQuery.isArray(val) ? +					jQuery.map( val, function( val, i ) { +						return { name: elem.name, value: val }; +					}) : +					{ name: elem.name, value: val }; +		}).get(); +	} +}); + +// Attach a bunch of functions for handling common AJAX events +jQuery.each( "ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "), function( i, o ) { +	jQuery.fn[o] = function( f ) { +		return this.bind(o, f); +	}; +}); + +jQuery.extend({ + +	get: function( url, data, callback, type ) { +		// shift arguments if data argument was omited +		if ( jQuery.isFunction( data ) ) { +			type = type || callback; +			callback = data; +			data = null; +		} + +		return jQuery.ajax({ +			type: "GET", +			url: url, +			data: data, +			success: callback, +			dataType: type +		}); +	}, + +	getScript: function( url, callback ) { +		return jQuery.get(url, null, callback, "script"); +	}, + +	getJSON: function( url, data, callback ) { +		return jQuery.get(url, data, callback, "json"); +	}, + +	post: function( url, data, callback, type ) { +		// shift arguments if data argument was omited +		if ( jQuery.isFunction( data ) ) { +			type = type || callback; +			callback = data; +			data = {}; +		} + +		return jQuery.ajax({ +			type: "POST", +			url: url, +			data: data, +			success: callback, +			dataType: type +		}); +	}, + +	ajaxSetup: function( settings ) { +		jQuery.extend( jQuery.ajaxSettings, settings ); +	}, + +	ajaxSettings: { +		url: location.href, +		global: true, +		type: "GET", +		contentType: "application/x-www-form-urlencoded", +		processData: true, +		async: true, +		/* +		timeout: 0, +		data: null, +		username: null, +		password: null, +		traditional: false, +		*/ +		// Create the request object; Microsoft failed to properly +		// implement the XMLHttpRequest in IE7 (can't request local files), +		// so we use the ActiveXObject when it is available +		// This function can be overriden by calling jQuery.ajaxSetup +		xhr: window.XMLHttpRequest && (window.location.protocol !== "file:" || !window.ActiveXObject) ? +			function() { +				return new window.XMLHttpRequest(); +			} : +			function() { +				try { +					return new window.ActiveXObject("Microsoft.XMLHTTP"); +				} catch(e) {} +			}, +		accepts: { +			xml: "application/xml, text/xml", +			html: "text/html", +			script: "text/javascript, application/javascript", +			json: "application/json, text/javascript", +			text: "text/plain", +			_default: "*/*" +		} +	}, + +	// Last-Modified header cache for next request +	lastModified: {}, +	etag: {}, + +	ajax: function( origSettings ) { +		var s = jQuery.extend(true, {}, jQuery.ajaxSettings, origSettings); +		 +		var jsonp, status, data, +			callbackContext = origSettings && origSettings.context || s, +			type = s.type.toUpperCase(); + +		// convert data if not already a string +		if ( s.data && s.processData && typeof s.data !== "string" ) { +			s.data = jQuery.param( s.data, s.traditional ); +		} + +		// Handle JSONP Parameter Callbacks +		if ( s.dataType === "jsonp" ) { +			if ( type === "GET" ) { +				if ( !jsre.test( s.url ) ) { +					s.url += (rquery.test( s.url ) ? "&" : "?") + (s.jsonp || "callback") + "=?"; +				} +			} else if ( !s.data || !jsre.test(s.data) ) { +				s.data = (s.data ? s.data + "&" : "") + (s.jsonp || "callback") + "=?"; +			} +			s.dataType = "json"; +		} + +		// Build temporary JSONP function +		if ( s.dataType === "json" && (s.data && jsre.test(s.data) || jsre.test(s.url)) ) { +			jsonp = s.jsonpCallback || ("jsonp" + jsc++); + +			// Replace the =? sequence both in the query string and the data +			if ( s.data ) { +				s.data = (s.data + "").replace(jsre, "=" + jsonp + "$1"); +			} + +			s.url = s.url.replace(jsre, "=" + jsonp + "$1"); + +			// We need to make sure +			// that a JSONP style response is executed properly +			s.dataType = "script"; + +			// Handle JSONP-style loading +			window[ jsonp ] = window[ jsonp ] || function( tmp ) { +				data = tmp; +				success(); +				complete(); +				// Garbage collect +				window[ jsonp ] = undefined; + +				try { +					delete window[ jsonp ]; +				} catch(e) {} + +				if ( head ) { +					head.removeChild( script ); +				} +			}; +		} + +		if ( s.dataType === "script" && s.cache === null ) { +			s.cache = false; +		} + +		if ( s.cache === false && type === "GET" ) { +			var ts = now(); + +			// try replacing _= if it is there +			var ret = s.url.replace(rts, "$1_=" + ts + "$2"); + +			// if nothing was replaced, add timestamp to the end +			s.url = ret + ((ret === s.url) ? (rquery.test(s.url) ? "&" : "?") + "_=" + ts : ""); +		} + +		// If data is available, append data to url for get requests +		if ( s.data && type === "GET" ) { +			s.url += (rquery.test(s.url) ? "&" : "?") + s.data; +		} + +		// Watch for a new set of requests +		if ( s.global && ! jQuery.active++ ) { +			jQuery.event.trigger( "ajaxStart" ); +		} + +		// Matches an absolute URL, and saves the domain +		var parts = rurl.exec( s.url ), +			remote = parts && (parts[1] && parts[1] !== location.protocol || parts[2] !== location.host); + +		// If we're requesting a remote document +		// and trying to load JSON or Script with a GET +		if ( s.dataType === "script" && type === "GET" && remote ) { +			var head = document.getElementsByTagName("head")[0] || document.documentElement; +			var script = document.createElement("script"); +			script.src = s.url; +			if ( s.scriptCharset ) { +				script.charset = s.scriptCharset; +			} + +			// Handle Script loading +			if ( !jsonp ) { +				var done = false; + +				// Attach handlers for all browsers +				script.onload = script.onreadystatechange = function() { +					if ( !done && (!this.readyState || +							this.readyState === "loaded" || this.readyState === "complete") ) { +						done = true; +						success(); +						complete(); + +						// Handle memory leak in IE +						script.onload = script.onreadystatechange = null; +						if ( head && script.parentNode ) { +							head.removeChild( script ); +						} +					} +				}; +			} + +			// Use insertBefore instead of appendChild  to circumvent an IE6 bug. +			// This arises when a base node is used (#2709 and #4378). +			head.insertBefore( script, head.firstChild ); + +			// We handle everything using the script element injection +			return undefined; +		} + +		var requestDone = false; + +		// Create the request object +		var xhr = s.xhr(); + +		if ( !xhr ) { +			return; +		} + +		// Open the socket +		// Passing null username, generates a login popup on Opera (#2865) +		if ( s.username ) { +			xhr.open(type, s.url, s.async, s.username, s.password); +		} else { +			xhr.open(type, s.url, s.async); +		} + +		// Need an extra try/catch for cross domain requests in Firefox 3 +		try { +			// Set the correct header, if data is being sent +			if ( s.data || origSettings && origSettings.contentType ) { +				xhr.setRequestHeader("Content-Type", s.contentType); +			} + +			// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. +			if ( s.ifModified ) { +				if ( jQuery.lastModified[s.url] ) { +					xhr.setRequestHeader("If-Modified-Since", jQuery.lastModified[s.url]); +				} + +				if ( jQuery.etag[s.url] ) { +					xhr.setRequestHeader("If-None-Match", jQuery.etag[s.url]); +				} +			} + +			// Set header so the called script knows that it's an XMLHttpRequest +			// Only send the header if it's not a remote XHR +			if ( !remote ) { +				xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest"); +			} + +			// Set the Accepts header for the server, depending on the dataType +			xhr.setRequestHeader("Accept", s.dataType && s.accepts[ s.dataType ] ? +				s.accepts[ s.dataType ] + ", */*" : +				s.accepts._default ); +		} catch(e) {} + +		// Allow custom headers/mimetypes and early abort +		if ( s.beforeSend && s.beforeSend.call(callbackContext, xhr, s) === false ) { +			// Handle the global AJAX counter +			if ( s.global && ! --jQuery.active ) { +				jQuery.event.trigger( "ajaxStop" ); +			} + +			// close opended socket +			xhr.abort(); +			return false; +		} + +		if ( s.global ) { +			trigger("ajaxSend", [xhr, s]); +		} + +		// Wait for a response to come back +		var onreadystatechange = xhr.onreadystatechange = function( isTimeout ) { +			// The request was aborted +			if ( !xhr || xhr.readyState === 0 || isTimeout === "abort" ) { +				// Opera doesn't call onreadystatechange before this point +				// so we simulate the call +				if ( !requestDone ) { +					complete(); +				} + +				requestDone = true; +				if ( xhr ) { +					xhr.onreadystatechange = jQuery.noop; +				} + +			// The transfer is complete and the data is available, or the request timed out +			} else if ( !requestDone && xhr && (xhr.readyState === 4 || isTimeout === "timeout") ) { +				requestDone = true; +				xhr.onreadystatechange = jQuery.noop; + +				status = isTimeout === "timeout" ? +					"timeout" : +					!jQuery.httpSuccess( xhr ) ? +						"error" : +						s.ifModified && jQuery.httpNotModified( xhr, s.url ) ? +							"notmodified" : +							"success"; + +				var errMsg; + +				if ( status === "success" ) { +					// Watch for, and catch, XML document parse errors +					try { +						// process the data (runs the xml through httpData regardless of callback) +						data = jQuery.httpData( xhr, s.dataType, s ); +					} catch(err) { +						status = "parsererror"; +						errMsg = err; +					} +				} + +				// Make sure that the request was successful or notmodified +				if ( status === "success" || status === "notmodified" ) { +					// JSONP handles its own success callback +					if ( !jsonp ) { +						success(); +					} +				} else { +					jQuery.handleError(s, xhr, status, errMsg); +				} + +				// Fire the complete handlers +				complete(); + +				if ( isTimeout === "timeout" ) { +					xhr.abort(); +				} + +				// Stop memory leaks +				if ( s.async ) { +					xhr = null; +				} +			} +		}; + +		// Override the abort handler, if we can (IE doesn't allow it, but that's OK) +		// Opera doesn't fire onreadystatechange at all on abort +		try { +			var oldAbort = xhr.abort; +			xhr.abort = function() { +				if ( xhr ) { +					oldAbort.call( xhr ); +				} + +				onreadystatechange( "abort" ); +			}; +		} catch(e) { } + +		// Timeout checker +		if ( s.async && s.timeout > 0 ) { +			setTimeout(function() { +				// Check to see if the request is still happening +				if ( xhr && !requestDone ) { +					onreadystatechange( "timeout" ); +				} +			}, s.timeout); +		} + +		// Send the data +		try { +			xhr.send( type === "POST" || type === "PUT" || type === "DELETE" ? s.data : null ); +		} catch(e) { +			jQuery.handleError(s, xhr, null, e); +			// Fire the complete handlers +			complete(); +		} + +		// firefox 1.5 doesn't fire statechange for sync requests +		if ( !s.async ) { +			onreadystatechange(); +		} + +		function success() { +			// If a local callback was specified, fire it and pass it the data +			if ( s.success ) { +				s.success.call( callbackContext, data, status, xhr ); +			} + +			// Fire the global callback +			if ( s.global ) { +				trigger( "ajaxSuccess", [xhr, s] ); +			} +		} + +		function complete() { +			// Process result +			if ( s.complete ) { +				s.complete.call( callbackContext, xhr, status); +			} + +			// The request was completed +			if ( s.global ) { +				trigger( "ajaxComplete", [xhr, s] ); +			} + +			// Handle the global AJAX counter +			if ( s.global && ! --jQuery.active ) { +				jQuery.event.trigger( "ajaxStop" ); +			} +		} +		 +		function trigger(type, args) { +			(s.context ? jQuery(s.context) : jQuery.event).trigger(type, args); +		} + +		// return XMLHttpRequest to allow aborting the request etc. +		return xhr; +	}, + +	handleError: function( s, xhr, status, e ) { +		// If a local callback was specified, fire it +		if ( s.error ) { +			s.error.call( s.context || s, xhr, status, e ); +		} + +		// Fire the global callback +		if ( s.global ) { +			(s.context ? jQuery(s.context) : jQuery.event).trigger( "ajaxError", [xhr, s, e] ); +		} +	}, + +	// Counter for holding the number of active queries +	active: 0, + +	// Determines if an XMLHttpRequest was successful or not +	httpSuccess: function( xhr ) { +		try { +			// IE error sometimes returns 1223 when it should be 204 so treat it as success, see #1450 +			return !xhr.status && location.protocol === "file:" || +				// Opera returns 0 when status is 304 +				( xhr.status >= 200 && xhr.status < 300 ) || +				xhr.status === 304 || xhr.status === 1223 || xhr.status === 0; +		} catch(e) {} + +		return false; +	}, + +	// Determines if an XMLHttpRequest returns NotModified +	httpNotModified: function( xhr, url ) { +		var lastModified = xhr.getResponseHeader("Last-Modified"), +			etag = xhr.getResponseHeader("Etag"); + +		if ( lastModified ) { +			jQuery.lastModified[url] = lastModified; +		} + +		if ( etag ) { +			jQuery.etag[url] = etag; +		} + +		// Opera returns 0 when status is 304 +		return xhr.status === 304 || xhr.status === 0; +	}, + +	httpData: function( xhr, type, s ) { +		var ct = xhr.getResponseHeader("content-type") || "", +			xml = type === "xml" || !type && ct.indexOf("xml") >= 0, +			data = xml ? xhr.responseXML : xhr.responseText; + +		if ( xml && data.documentElement.nodeName === "parsererror" ) { +			jQuery.error( "parsererror" ); +		} + +		// Allow a pre-filtering function to sanitize the response +		// s is checked to keep backwards compatibility +		if ( s && s.dataFilter ) { +			data = s.dataFilter( data, type ); +		} + +		// The filter can actually parse the response +		if ( typeof data === "string" ) { +			// Get the JavaScript object, if JSON is used. +			if ( type === "json" || !type && ct.indexOf("json") >= 0 ) { +				data = jQuery.parseJSON( data ); + +			// If the type is "script", eval it in global context +			} else if ( type === "script" || !type && ct.indexOf("javascript") >= 0 ) { +				jQuery.globalEval( data ); +			} +		} + +		return data; +	}, + +	// Serialize an array of form elements or a set of +	// key/values into a query string +	param: function( a, traditional ) { +		var s = []; +		 +		// Set traditional to true for jQuery <= 1.3.2 behavior. +		if ( traditional === undefined ) { +			traditional = jQuery.ajaxSettings.traditional; +		} +		 +		// If an array was passed in, assume that it is an array of form elements. +		if ( jQuery.isArray(a) || a.jquery ) { +			// Serialize the form elements +			jQuery.each( a, function() { +				add( this.name, this.value ); +			}); +			 +		} else { +			// If traditional, encode the "old" way (the way 1.3.2 or older +			// did it), otherwise encode params recursively. +			for ( var prefix in a ) { +				buildParams( prefix, a[prefix] ); +			} +		} + +		// Return the resulting serialization +		return s.join("&").replace(r20, "+"); + +		function buildParams( prefix, obj ) { +			if ( jQuery.isArray(obj) ) { +				// Serialize array item. +				jQuery.each( obj, function( i, v ) { +					if ( traditional ) { +						// Treat each array item as a scalar. +						add( prefix, v ); +					} else { +						// If array item is non-scalar (array or object), encode its +						// numeric index to resolve deserialization ambiguity issues. +						// Note that rack (as of 1.0.0) can't currently deserialize +						// nested arrays properly, and attempting to do so may cause +						// a server error. Possible fixes are to modify rack's +						// deserialization algorithm or to provide an option or flag +						// to force array serialization to be shallow. +						buildParams( prefix + "[" + ( typeof v === "object" || jQuery.isArray(v) ? i : "" ) + "]", v ); +					} +				}); +					 +			} else if ( !traditional && obj != null && typeof obj === "object" ) { +				// Serialize object item. +				jQuery.each( obj, function( k, v ) { +					buildParams( prefix + "[" + k + "]", v ); +				}); +					 +			} else { +				// Serialize scalar item. +				add( prefix, obj ); +			} +		} + +		function add( key, value ) { +			// If value is a function, invoke it and return its value +			value = jQuery.isFunction(value) ? value() : value; +			s[ s.length ] = encodeURIComponent(key) + "=" + encodeURIComponent(value); +		} +	} +}); +var elemdisplay = {}, +	rfxtypes = /toggle|show|hide/, +	rfxnum = /^([+-]=)?([\d+-.]+)(.*)$/, +	timerId, +	fxAttrs = [ +		// height animations +		[ "height", "marginTop", "marginBottom", "paddingTop", "paddingBottom" ], +		// width animations +		[ "width", "marginLeft", "marginRight", "paddingLeft", "paddingRight" ], +		// opacity animations +		[ "opacity" ] +	]; + +jQuery.fn.extend({ +	show: function( speed, callback ) { +		if ( speed || speed === 0) { +			return this.animate( genFx("show", 3), speed, callback); + +		} else { +			for ( var i = 0, l = this.length; i < l; i++ ) { +				var old = jQuery.data(this[i], "olddisplay"); + +				this[i].style.display = old || ""; + +				if ( jQuery.css(this[i], "display") === "none" ) { +					var nodeName = this[i].nodeName, display; + +					if ( elemdisplay[ nodeName ] ) { +						display = elemdisplay[ nodeName ]; + +					} else { +						var elem = jQuery("<" + nodeName + " />").appendTo("body"); + +						display = elem.css("display"); + +						if ( display === "none" ) { +							display = "block"; +						} + +						elem.remove(); + +						elemdisplay[ nodeName ] = display; +					} + +					jQuery.data(this[i], "olddisplay", display); +				} +			} + +			// Set the display of the elements in a second loop +			// to avoid the constant reflow +			for ( var j = 0, k = this.length; j < k; j++ ) { +				this[j].style.display = jQuery.data(this[j], "olddisplay") || ""; +			} + +			return this; +		} +	}, + +	hide: function( speed, callback ) { +		if ( speed || speed === 0 ) { +			return this.animate( genFx("hide", 3), speed, callback); + +		} else { +			for ( var i = 0, l = this.length; i < l; i++ ) { +				var old = jQuery.data(this[i], "olddisplay"); +				if ( !old && old !== "none" ) { +					jQuery.data(this[i], "olddisplay", jQuery.css(this[i], "display")); +				} +			} + +			// Set the display of the elements in a second loop +			// to avoid the constant reflow +			for ( var j = 0, k = this.length; j < k; j++ ) { +				this[j].style.display = "none"; +			} + +			return this; +		} +	}, + +	// Save the old toggle function +	_toggle: jQuery.fn.toggle, + +	toggle: function( fn, fn2 ) { +		var bool = typeof fn === "boolean"; + +		if ( jQuery.isFunction(fn) && jQuery.isFunction(fn2) ) { +			this._toggle.apply( this, arguments ); + +		} else if ( fn == null || bool ) { +			this.each(function() { +				var state = bool ? fn : jQuery(this).is(":hidden"); +				jQuery(this)[ state ? "show" : "hide" ](); +			}); + +		} else { +			this.animate(genFx("toggle", 3), fn, fn2); +		} + +		return this; +	}, + +	fadeTo: function( speed, to, callback ) { +		return this.filter(":hidden").css("opacity", 0).show().end() +					.animate({opacity: to}, speed, callback); +	}, + +	animate: function( prop, speed, easing, callback ) { +		var optall = jQuery.speed(speed, easing, callback); + +		if ( jQuery.isEmptyObject( prop ) ) { +			return this.each( optall.complete ); +		} + +		return this[ optall.queue === false ? "each" : "queue" ](function() { +			var opt = jQuery.extend({}, optall), p, +				hidden = this.nodeType === 1 && jQuery(this).is(":hidden"), +				self = this; + +			for ( p in prop ) { +				var name = p.replace(rdashAlpha, fcamelCase); + +				if ( p !== name ) { +					prop[ name ] = prop[ p ]; +					delete prop[ p ]; +					p = name; +				} + +				if ( prop[p] === "hide" && hidden || prop[p] === "show" && !hidden ) { +					return opt.complete.call(this); +				} + +				if ( ( p === "height" || p === "width" ) && this.style ) { +					// Store display property +					opt.display = jQuery.css(this, "display"); + +					// Make sure that nothing sneaks out +					opt.overflow = this.style.overflow; +				} + +				if ( jQuery.isArray( prop[p] ) ) { +					// Create (if needed) and add to specialEasing +					(opt.specialEasing = opt.specialEasing || {})[p] = prop[p][1]; +					prop[p] = prop[p][0]; +				} +			} + +			if ( opt.overflow != null ) { +				this.style.overflow = "hidden"; +			} + +			opt.curAnim = jQuery.extend({}, prop); + +			jQuery.each( prop, function( name, val ) { +				var e = new jQuery.fx( self, opt, name ); + +				if ( rfxtypes.test(val) ) { +					e[ val === "toggle" ? hidden ? "show" : "hide" : val ]( prop ); + +				} else { +					var parts = rfxnum.exec(val), +						start = e.cur(true) || 0; + +					if ( parts ) { +						var end = parseFloat( parts[2] ), +							unit = parts[3] || "px"; + +						// We need to compute starting value +						if ( unit !== "px" ) { +							self.style[ name ] = (end || 1) + unit; +							start = ((end || 1) / e.cur(true)) * start; +							self.style[ name ] = start + unit; +						} + +						// If a +=/-= token was provided, we're doing a relative animation +						if ( parts[1] ) { +							end = ((parts[1] === "-=" ? -1 : 1) * end) + start; +						} + +						e.custom( start, end, unit ); + +					} else { +						e.custom( start, val, "" ); +					} +				} +			}); + +			// For JS strict compliance +			return true; +		}); +	}, + +	stop: function( clearQueue, gotoEnd ) { +		var timers = jQuery.timers; + +		if ( clearQueue ) { +			this.queue([]); +		} + +		this.each(function() { +			// go in reverse order so anything added to the queue during the loop is ignored +			for ( var i = timers.length - 1; i >= 0; i-- ) { +				if ( timers[i].elem === this ) { +					if (gotoEnd) { +						// force the next step to be the last +						timers[i](true); +					} + +					timers.splice(i, 1); +				} +			} +		}); + +		// start the next in the queue if the last step wasn't forced +		if ( !gotoEnd ) { +			this.dequeue(); +		} + +		return this; +	} + +}); + +// Generate shortcuts for custom animations +jQuery.each({ +	slideDown: genFx("show", 1), +	slideUp: genFx("hide", 1), +	slideToggle: genFx("toggle", 1), +	fadeIn: { opacity: "show" }, +	fadeOut: { opacity: "hide" } +}, function( name, props ) { +	jQuery.fn[ name ] = function( speed, callback ) { +		return this.animate( props, speed, callback ); +	}; +}); + +jQuery.extend({ +	speed: function( speed, easing, fn ) { +		var opt = speed && typeof speed === "object" ? speed : { +			complete: fn || !fn && easing || +				jQuery.isFunction( speed ) && speed, +			duration: speed, +			easing: fn && easing || easing && !jQuery.isFunction(easing) && easing +		}; + +		opt.duration = jQuery.fx.off ? 0 : typeof opt.duration === "number" ? opt.duration : +			jQuery.fx.speeds[opt.duration] || jQuery.fx.speeds._default; + +		// Queueing +		opt.old = opt.complete; +		opt.complete = function() { +			if ( opt.queue !== false ) { +				jQuery(this).dequeue(); +			} +			if ( jQuery.isFunction( opt.old ) ) { +				opt.old.call( this ); +			} +		}; + +		return opt; +	}, + +	easing: { +		linear: function( p, n, firstNum, diff ) { +			return firstNum + diff * p; +		}, +		swing: function( p, n, firstNum, diff ) { +			return ((-Math.cos(p*Math.PI)/2) + 0.5) * diff + firstNum; +		} +	}, + +	timers: [], + +	fx: function( elem, options, prop ) { +		this.options = options; +		this.elem = elem; +		this.prop = prop; + +		if ( !options.orig ) { +			options.orig = {}; +		} +	} + +}); + +jQuery.fx.prototype = { +	// Simple function for setting a style value +	update: function() { +		if ( this.options.step ) { +			this.options.step.call( this.elem, this.now, this ); +		} + +		(jQuery.fx.step[this.prop] || jQuery.fx.step._default)( this ); + +		// Set display property to block for height/width animations +		if ( ( this.prop === "height" || this.prop === "width" ) && this.elem.style ) { +			this.elem.style.display = "block"; +		} +	}, + +	// Get the current size +	cur: function( force ) { +		if ( this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null) ) { +			return this.elem[ this.prop ]; +		} + +		var r = parseFloat(jQuery.css(this.elem, this.prop, force)); +		return r && r > -10000 ? r : parseFloat(jQuery.curCSS(this.elem, this.prop)) || 0; +	}, + +	// Start an animation from one number to another +	custom: function( from, to, unit ) { +		this.startTime = now(); +		this.start = from; +		this.end = to; +		this.unit = unit || this.unit || "px"; +		this.now = this.start; +		this.pos = this.state = 0; + +		var self = this; +		function t( gotoEnd ) { +			return self.step(gotoEnd); +		} + +		t.elem = this.elem; + +		if ( t() && jQuery.timers.push(t) && !timerId ) { +			timerId = setInterval(jQuery.fx.tick, 13); +		} +	}, + +	// Simple 'show' function +	show: function() { +		// Remember where we started, so that we can go back to it later +		this.options.orig[this.prop] = jQuery.style( this.elem, this.prop ); +		this.options.show = true; + +		// Begin the animation +		// Make sure that we start at a small width/height to avoid any +		// flash of content +		this.custom(this.prop === "width" || this.prop === "height" ? 1 : 0, this.cur()); + +		// Start by showing the element +		jQuery( this.elem ).show(); +	}, + +	// Simple 'hide' function +	hide: function() { +		// Remember where we started, so that we can go back to it later +		this.options.orig[this.prop] = jQuery.style( this.elem, this.prop ); +		this.options.hide = true; + +		// Begin the animation +		this.custom(this.cur(), 0); +	}, + +	// Each step of an animation +	step: function( gotoEnd ) { +		var t = now(), done = true; + +		if ( gotoEnd || t >= this.options.duration + this.startTime ) { +			this.now = this.end; +			this.pos = this.state = 1; +			this.update(); + +			this.options.curAnim[ this.prop ] = true; + +			for ( var i in this.options.curAnim ) { +				if ( this.options.curAnim[i] !== true ) { +					done = false; +				} +			} + +			if ( done ) { +				if ( this.options.display != null ) { +					// Reset the overflow +					this.elem.style.overflow = this.options.overflow; + +					// Reset the display +					var old = jQuery.data(this.elem, "olddisplay"); +					this.elem.style.display = old ? old : this.options.display; + +					if ( jQuery.css(this.elem, "display") === "none" ) { +						this.elem.style.display = "block"; +					} +				} + +				// Hide the element if the "hide" operation was done +				if ( this.options.hide ) { +					jQuery(this.elem).hide(); +				} + +				// Reset the properties, if the item has been hidden or shown +				if ( this.options.hide || this.options.show ) { +					for ( var p in this.options.curAnim ) { +						jQuery.style(this.elem, p, this.options.orig[p]); +					} +				} + +				// Execute the complete function +				this.options.complete.call( this.elem ); +			} + +			return false; + +		} else { +			var n = t - this.startTime; +			this.state = n / this.options.duration; + +			// Perform the easing function, defaults to swing +			var specialEasing = this.options.specialEasing && this.options.specialEasing[this.prop]; +			var defaultEasing = this.options.easing || (jQuery.easing.swing ? "swing" : "linear"); +			this.pos = jQuery.easing[specialEasing || defaultEasing](this.state, n, 0, 1, this.options.duration); +			this.now = this.start + ((this.end - this.start) * this.pos); + +			// Perform the next step of the animation +			this.update(); +		} + +		return true; +	} +}; + +jQuery.extend( jQuery.fx, { +	tick: function() { +		var timers = jQuery.timers; + +		for ( var i = 0; i < timers.length; i++ ) { +			if ( !timers[i]() ) { +				timers.splice(i--, 1); +			} +		} + +		if ( !timers.length ) { +			jQuery.fx.stop(); +		} +	}, +		 +	stop: function() { +		clearInterval( timerId ); +		timerId = null; +	}, +	 +	speeds: { +		slow: 600, + 		fast: 200, + 		// Default speed + 		_default: 400 +	}, + +	step: { +		opacity: function( fx ) { +			jQuery.style(fx.elem, "opacity", fx.now); +		}, + +		_default: function( fx ) { +			if ( fx.elem.style && fx.elem.style[ fx.prop ] != null ) { +				fx.elem.style[ fx.prop ] = (fx.prop === "width" || fx.prop === "height" ? Math.max(0, fx.now) : fx.now) + fx.unit; +			} else { +				fx.elem[ fx.prop ] = fx.now; +			} +		} +	} +}); + +if ( jQuery.expr && jQuery.expr.filters ) { +	jQuery.expr.filters.animated = function( elem ) { +		return jQuery.grep(jQuery.timers, function( fn ) { +			return elem === fn.elem; +		}).length; +	}; +} + +function genFx( type, num ) { +	var obj = {}; + +	jQuery.each( fxAttrs.concat.apply([], fxAttrs.slice(0,num)), function() { +		obj[ this ] = type; +	}); + +	return obj; +} +if ( "getBoundingClientRect" in document.documentElement ) { +	jQuery.fn.offset = function( options ) { +		var elem = this[0]; + +		if ( options ) {  +			return this.each(function( i ) { +				jQuery.offset.setOffset( this, options, i ); +			}); +		} + +		if ( !elem || !elem.ownerDocument ) { +			return null; +		} + +		if ( elem === elem.ownerDocument.body ) { +			return jQuery.offset.bodyOffset( elem ); +		} + +		var box = elem.getBoundingClientRect(), doc = elem.ownerDocument, body = doc.body, docElem = doc.documentElement, +			clientTop = docElem.clientTop || body.clientTop || 0, clientLeft = docElem.clientLeft || body.clientLeft || 0, +			top  = box.top  + (self.pageYOffset || jQuery.support.boxModel && docElem.scrollTop  || body.scrollTop ) - clientTop, +			left = box.left + (self.pageXOffset || jQuery.support.boxModel && docElem.scrollLeft || body.scrollLeft) - clientLeft; + +		return { top: top, left: left }; +	}; + +} else { +	jQuery.fn.offset = function( options ) { +		var elem = this[0]; + +		if ( options ) {  +			return this.each(function( i ) { +				jQuery.offset.setOffset( this, options, i ); +			}); +		} + +		if ( !elem || !elem.ownerDocument ) { +			return null; +		} + +		if ( elem === elem.ownerDocument.body ) { +			return jQuery.offset.bodyOffset( elem ); +		} + +		jQuery.offset.initialize(); + +		var offsetParent = elem.offsetParent, prevOffsetParent = elem, +			doc = elem.ownerDocument, computedStyle, docElem = doc.documentElement, +			body = doc.body, defaultView = doc.defaultView, +			prevComputedStyle = defaultView ? defaultView.getComputedStyle( elem, null ) : elem.currentStyle, +			top = elem.offsetTop, left = elem.offsetLeft; + +		while ( (elem = elem.parentNode) && elem !== body && elem !== docElem ) { +			if ( jQuery.offset.supportsFixedPosition && prevComputedStyle.position === "fixed" ) { +				break; +			} + +			computedStyle = defaultView ? defaultView.getComputedStyle(elem, null) : elem.currentStyle; +			top  -= elem.scrollTop; +			left -= elem.scrollLeft; + +			if ( elem === offsetParent ) { +				top  += elem.offsetTop; +				left += elem.offsetLeft; + +				if ( jQuery.offset.doesNotAddBorder && !(jQuery.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i.test(elem.nodeName)) ) { +					top  += parseFloat( computedStyle.borderTopWidth  ) || 0; +					left += parseFloat( computedStyle.borderLeftWidth ) || 0; +				} + +				prevOffsetParent = offsetParent, offsetParent = elem.offsetParent; +			} + +			if ( jQuery.offset.subtractsBorderForOverflowNotVisible && computedStyle.overflow !== "visible" ) { +				top  += parseFloat( computedStyle.borderTopWidth  ) || 0; +				left += parseFloat( computedStyle.borderLeftWidth ) || 0; +			} + +			prevComputedStyle = computedStyle; +		} + +		if ( prevComputedStyle.position === "relative" || prevComputedStyle.position === "static" ) { +			top  += body.offsetTop; +			left += body.offsetLeft; +		} + +		if ( jQuery.offset.supportsFixedPosition && prevComputedStyle.position === "fixed" ) { +			top  += Math.max( docElem.scrollTop, body.scrollTop ); +			left += Math.max( docElem.scrollLeft, body.scrollLeft ); +		} + +		return { top: top, left: left }; +	}; +} + +jQuery.offset = { +	initialize: function() { +		var body = document.body, container = document.createElement("div"), innerDiv, checkDiv, table, td, bodyMarginTop = parseFloat( jQuery.curCSS(body, "marginTop", true) ) || 0, +			html = "<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>"; + +		jQuery.extend( container.style, { position: "absolute", top: 0, left: 0, margin: 0, border: 0, width: "1px", height: "1px", visibility: "hidden" } ); + +		container.innerHTML = html; +		body.insertBefore( container, body.firstChild ); +		innerDiv = container.firstChild; +		checkDiv = innerDiv.firstChild; +		td = innerDiv.nextSibling.firstChild.firstChild; + +		this.doesNotAddBorder = (checkDiv.offsetTop !== 5); +		this.doesAddBorderForTableAndCells = (td.offsetTop === 5); + +		checkDiv.style.position = "fixed", checkDiv.style.top = "20px"; +		// safari subtracts parent border width here which is 5px +		this.supportsFixedPosition = (checkDiv.offsetTop === 20 || checkDiv.offsetTop === 15); +		checkDiv.style.position = checkDiv.style.top = ""; + +		innerDiv.style.overflow = "hidden", innerDiv.style.position = "relative"; +		this.subtractsBorderForOverflowNotVisible = (checkDiv.offsetTop === -5); + +		this.doesNotIncludeMarginInBodyOffset = (body.offsetTop !== bodyMarginTop); + +		body.removeChild( container ); +		body = container = innerDiv = checkDiv = table = td = null; +		jQuery.offset.initialize = jQuery.noop; +	}, + +	bodyOffset: function( body ) { +		var top = body.offsetTop, left = body.offsetLeft; + +		jQuery.offset.initialize(); + +		if ( jQuery.offset.doesNotIncludeMarginInBodyOffset ) { +			top  += parseFloat( jQuery.curCSS(body, "marginTop",  true) ) || 0; +			left += parseFloat( jQuery.curCSS(body, "marginLeft", true) ) || 0; +		} + +		return { top: top, left: left }; +	}, +	 +	setOffset: function( elem, options, i ) { +		// set position first, in-case top/left are set even on static elem +		if ( /static/.test( jQuery.curCSS( elem, "position" ) ) ) { +			elem.style.position = "relative"; +		} +		var curElem   = jQuery( elem ), +			curOffset = curElem.offset(), +			curTop    = parseInt( jQuery.curCSS( elem, "top",  true ), 10 ) || 0, +			curLeft   = parseInt( jQuery.curCSS( elem, "left", true ), 10 ) || 0; + +		if ( jQuery.isFunction( options ) ) { +			options = options.call( elem, i, curOffset ); +		} + +		var props = { +			top:  (options.top  - curOffset.top)  + curTop, +			left: (options.left - curOffset.left) + curLeft +		}; +		 +		if ( "using" in options ) { +			options.using.call( elem, props ); +		} else { +			curElem.css( props ); +		} +	} +}; + + +jQuery.fn.extend({ +	position: function() { +		if ( !this[0] ) { +			return null; +		} + +		var elem = this[0], + +		// Get *real* offsetParent +		offsetParent = this.offsetParent(), + +		// Get correct offsets +		offset       = this.offset(), +		parentOffset = /^body|html$/i.test(offsetParent[0].nodeName) ? { top: 0, left: 0 } : offsetParent.offset(); + +		// Subtract element margins +		// note: when an element has margin: auto the offsetLeft and marginLeft +		// are the same in Safari causing offset.left to incorrectly be 0 +		offset.top  -= parseFloat( jQuery.curCSS(elem, "marginTop",  true) ) || 0; +		offset.left -= parseFloat( jQuery.curCSS(elem, "marginLeft", true) ) || 0; + +		// Add offsetParent borders +		parentOffset.top  += parseFloat( jQuery.curCSS(offsetParent[0], "borderTopWidth",  true) ) || 0; +		parentOffset.left += parseFloat( jQuery.curCSS(offsetParent[0], "borderLeftWidth", true) ) || 0; + +		// Subtract the two offsets +		return { +			top:  offset.top  - parentOffset.top, +			left: offset.left - parentOffset.left +		}; +	}, + +	offsetParent: function() { +		return this.map(function() { +			var offsetParent = this.offsetParent || document.body; +			while ( offsetParent && (!/^body|html$/i.test(offsetParent.nodeName) && jQuery.css(offsetParent, "position") === "static") ) { +				offsetParent = offsetParent.offsetParent; +			} +			return offsetParent; +		}); +	} +}); + + +// Create scrollLeft and scrollTop methods +jQuery.each( ["Left", "Top"], function( i, name ) { +	var method = "scroll" + name; + +	jQuery.fn[ method ] = function(val) { +		var elem = this[0], win; +		 +		if ( !elem ) { +			return null; +		} + +		if ( val !== undefined ) { +			// Set the scroll offset +			return this.each(function() { +				win = getWindow( this ); + +				if ( win ) { +					win.scrollTo( +						!i ? val : jQuery(win).scrollLeft(), +						 i ? val : jQuery(win).scrollTop() +					); + +				} else { +					this[ method ] = val; +				} +			}); +		} else { +			win = getWindow( elem ); + +			// Return the scroll offset +			return win ? ("pageXOffset" in win) ? win[ i ? "pageYOffset" : "pageXOffset" ] : +				jQuery.support.boxModel && win.document.documentElement[ method ] || +					win.document.body[ method ] : +				elem[ method ]; +		} +	}; +}); + +function getWindow( elem ) { +	return ("scrollTo" in elem && elem.document) ? +		elem : +		elem.nodeType === 9 ? +			elem.defaultView || elem.parentWindow : +			false; +} +// Create innerHeight, innerWidth, outerHeight and outerWidth methods +jQuery.each([ "Height", "Width" ], function( i, name ) { + +	var type = name.toLowerCase(); + +	// innerHeight and innerWidth +	jQuery.fn["inner" + name] = function() { +		return this[0] ? +			jQuery.css( this[0], type, false, "padding" ) : +			null; +	}; + +	// outerHeight and outerWidth +	jQuery.fn["outer" + name] = function( margin ) { +		return this[0] ? +			jQuery.css( this[0], type, false, margin ? "margin" : "border" ) : +			null; +	}; + +	jQuery.fn[ type ] = function( size ) { +		// Get window width or height +		var elem = this[0]; +		if ( !elem ) { +			return size == null ? null : this; +		} +		 +		if ( jQuery.isFunction( size ) ) { +			return this.each(function( i ) { +				var self = jQuery( this ); +				self[ type ]( size.call( this, i, self[ type ]() ) ); +			}); +		} + +		return ("scrollTo" in elem && elem.document) ? // does it walk and quack like a window? +			// Everyone else use document.documentElement or document.body depending on Quirks vs Standards mode +			elem.document.compatMode === "CSS1Compat" && elem.document.documentElement[ "client" + name ] || +			elem.document.body[ "client" + name ] : + +			// Get document width or height +			(elem.nodeType === 9) ? // is it a document +				// Either scroll[Width/Height] or offset[Width/Height], whichever is greater +				Math.max( +					elem.documentElement["client" + name], +					elem.body["scroll" + name], elem.documentElement["scroll" + name], +					elem.body["offset" + name], elem.documentElement["offset" + name] +				) : + +				// Get or set width or height on the element +				size === undefined ? +					// Get width or height on the element +					jQuery.css( elem, type ) : + +					// Set the width or height on the element (default to pixels if value is unitless) +					this.css( type, typeof size === "string" ? size : size + "px" ); +	}; + +}); +// Expose jQuery to the global object +window.jQuery = window.$ = jQuery; + +})(window);
\ No newline at end of file diff --git a/debug_toolbar/media/debug_toolbar/js/toolbar.js b/debug_toolbar/media/debug_toolbar/js/toolbar.js index 33970f8..c763fd2 100644 --- a/debug_toolbar/media/debug_toolbar/js/toolbar.js +++ b/debug_toolbar/media/debug_toolbar/js/toolbar.js @@ -1,24 +1,13 @@ -(function(window, document, version, callback) { -	var j, d; -	var loaded = false; -	if (!(j = window.jQuery) || version > j.fn.jquery || callback(j)) { -		var script = document.createElement("script"); -		script.type = "text/javascript"; -		script.src = DEBUG_TOOLBAR_MEDIA_URL + "js/jquery.js"; -		script.onload = script.onreadystatechange = function() { -			if (!loaded && (!(d = this.readyState) || d == "loaded" || d == "complete")) { -				callback((j = window.jQuery).noConflict(1), loaded = true); -				j(script).remove(); -			} -		}; -		document.documentElement.childNodes[0].appendChild(script) -	} -})(window, document, "1.3", function($, jquery_loaded) { - -	$.cookie = function(name, value, options) { if (typeof value != 'undefined') { options = options || {}; if (value === null) { value = ''; options.expires = -1; } var expires = ''; if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) { var date; if (typeof options.expires == 'number') { date = new Date(); date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000)); } else { date = options.expires; } expires = '; expires=' + date.toUTCString(); } var path = options.path ? '; path=' + (options.path) : ''; var domain = options.domain ? '; domain=' + (options.domain) : ''; var secure = options.secure ? '; secure' : ''; document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join(''); } else { var cookieValue = null; if (document.cookie && document.cookie != '') { var cookies = document.cookie.split(';'); for (var i = 0; i < cookies.length; i++) { var cookie = $.trim(cookies[i]); if (cookie.substring(0, name.length + 1) == (name + '=')) { cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); break; } } } return cookieValue; } }; -	$('head').append('<link rel="stylesheet" href="'+DEBUG_TOOLBAR_MEDIA_URL+'css/toolbar.min.css" type="text/css" />'); +window.djdt = (function(window, document, jQuery) { +	jQuery.cookie = function(name, value, options) { if (typeof value != 'undefined') { options = options || {}; if (value === null) { value = ''; options.expires = -1; } var expires = ''; if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) { var date; if (typeof options.expires == 'number') { date = new Date(); date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000)); } else { date = options.expires; } expires = '; expires=' + date.toUTCString(); } var path = options.path ? '; path=' + (options.path) : ''; var domain = options.domain ? '; domain=' + (options.domain) : ''; var secure = options.secure ? '; secure' : ''; document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join(''); } else { var cookieValue = null; if (document.cookie && document.cookie != '') { var cookies = document.cookie.split(';'); for (var i = 0; i < cookies.length; i++) { var cookie = $.trim(cookies[i]); if (cookie.substring(0, name.length + 1) == (name + '=')) { cookieValue = decodeURIComponent(cookie.substring(name.length + 1)); break; } } } return cookieValue; } }; +	var $ = jQuery;  	var COOKIE_NAME = 'djdt';  	var djdt = { +		jQuery: jQuery, +		events: { +			ready: [] +		}, +		isReady: false,  		init: function() {  			$('#djDebug').show();  			var current = null; @@ -44,7 +33,11 @@  				return false;  			});  			$('#djDebug a.remoteCall').click(function() { -				$('#djDebugWindow').load(this.href, {}, function() { +				$('#djDebugWindow').load(this.href, function(response, status, xhr) { +					if (status == "error") { +						var message = '<div class="djDebugPanelTitle"><a class="djDebugClose djDebugBack" href="">Back</a><h3>'+xhr.status+': '+xhr.statusText+'</h3></div>'; +						$('#djDebugWindow').html(message); +					}  					$('#djDebugWindow a.djDebugBack').click(function() {  						$(this).parent().parent().hide();  						return false; @@ -54,13 +47,52 @@  				return false;  			});  			$('#djDebugTemplatePanel a.djTemplateShowContext').click(function() { -				djdt.toggle_arrow($(this).children('.toggleArrow')) +				djdt.toggle_arrow($(this).children('.toggleArrow'));  				djdt.toggle_content($(this).parent().next());  				return false;  			}); -			$('#djDebugSQLPanel a.djSQLShowStacktrace').click(function() { -				djdt.toggle_content($('.djSQLHideStacktraceDiv', $(this).parents('tr'))); -				return false; +			$('#djDebug a.djToggleSwitch').click(function(e) { +				e.preventDefault(); +				var btn = $(this); +				var id = btn.attr('data-toggle-id'); +				var open_me = btn.text() == btn.attr('data-toggle-open'); +				if (id == '' || !id) { +					return; +				} +				 +				$(this).parents('.djDebugPanelContent').find('.djToggleDetails_' + id).each(function(){ +					var $this = $(this); +					if (open_me) { +						$this.addClass('djSelected'); +						$this.removeClass('djUnselected'); +						btn.text(btn.attr('data-toggle-close')); +						$this.find('.djToggleSwitch').text(btn.text()); +					} else { +						$this.removeClass('djSelected'); +						$this.addClass('djUnselected'); +						btn.text(btn.attr('data-toggle-open')); +						$this.find('.djToggleSwitch').text(btn.text()); +					} +				}); +				return; +			}); +			function getSubcalls(row) { +			  id = row.attr('id'); +			  return $('.djDebugProfileRow[id^="'+id+'_"]'); +			} +			function getDirectSubcalls(row) { +			  subcalls = getSubcalls(row); +			  depth = parseInt(row.attr('depth')) + 1; +			  return subcalls.filter('[depth='+depth+']'); +			} +			$('.djDebugProfileRow .djDebugProfileToggle').click(function(){ +			  row = $(this).closest('.djDebugProfileRow') +			  subcalls = getSubcalls(row); +			  if (subcalls.css('display')=='none') { +			    getDirectSubcalls(row).show(); +			  } else { +			    subcalls.hide(); +			  }  			});  			$('#djHideToolBarButton').click(function() {  				djdt.hide_toolbar(true); @@ -92,6 +124,15 @@  			} else {  				djdt.show_toolbar(false);  			} +			$('#djDebug .djDebugHoverable').hover(function(){ +				$(this).addClass('djDebugHover'); +			}, function(){ +			    $(this).removeClass('djDebugHover'); +			}); +			djdt.isReady = true; +			$.each(djdt.events.ready, function(_, callback){ +			    callback(djdt); +			});  		},  		toggle_content: function(elem) {  			if (elem.is(':visible')) { @@ -144,10 +185,17 @@  			var uarr = String.fromCharCode(0x25b6);  			var darr = String.fromCharCode(0x25bc);  			elem.html(elem.html() == uarr ? darr : uarr); +		}, +		ready: function(callback){ +			if (djdt.isReady) { +				callback(djdt); +			} else { +				djdt.events.ready.push(callback); +			}  		}  	};  	$(document).ready(function() {  		djdt.init();  	}); -}); - +	return djdt; +}(window, document, jQuery.noConflict())); diff --git a/debug_toolbar/media/debug_toolbar/js/toolbar.min.js b/debug_toolbar/media/debug_toolbar/js/toolbar.min.js index 81b3f85..b72b0b5 100644 --- a/debug_toolbar/media/debug_toolbar/js/toolbar.min.js +++ b/debug_toolbar/media/debug_toolbar/js/toolbar.min.js @@ -1 +1,23 @@ -(function(g,a,b,i){var f,h;var e=false;if(!(f=g.jQuery)||b>f.fn.jquery||i(f)){var c=a.createElement("script");c.type="text/javascript";c.src=DEBUG_TOOLBAR_MEDIA_URL+"js/jquery.js";c.onload=c.onreadystatechange=function(){if(!e&&(!(h=this.readyState)||h=="loaded"||h=="complete")){i((f=g.jQuery).noConflict(1),e=true);f(c).remove()}};a.documentElement.childNodes[0].appendChild(c)}})(window,document,"1.3",function(b,a){b.cookie=function(f,n,q){if(typeof n!="undefined"){q=q||{};if(n===null){n="";q.expires=-1}var j="";if(q.expires&&(typeof q.expires=="number"||q.expires.toUTCString)){var k;if(typeof q.expires=="number"){k=new Date();k.setTime(k.getTime()+(q.expires*24*60*60*1000))}else{k=q.expires}j="; expires="+k.toUTCString()}var p=q.path?"; path="+(q.path):"";var l=q.domain?"; domain="+(q.domain):"";var e=q.secure?"; secure":"";document.cookie=[f,"=",encodeURIComponent(n),j,p,l,e].join("")}else{var h=null;if(document.cookie&&document.cookie!=""){var o=document.cookie.split(";");for(var m=0;m<o.length;m++){var g=b.trim(o[m]);if(g.substring(0,f.length+1)==(f+"=")){h=decodeURIComponent(g.substring(f.length+1));break}}}return h}};b("head").append('<link rel="stylesheet" href="'+DEBUG_TOOLBAR_MEDIA_URL+'css/toolbar.min.css" type="text/css" />');var d="djdt";var c={init:function(){b("#djDebug").show();var e=null;b("#djDebugPanelList li a").click(function(){if(!this.className){return false}e=b("#djDebug #"+this.className);if(e.is(":visible")){b(document).trigger("close.djDebug");b(this).parent().removeClass("active")}else{b(".panelContent").hide();e.show();b("#djDebugToolbar li").removeClass("active");b(this).parent().addClass("active")}return false});b("#djDebug a.djDebugClose").click(function(){b(document).trigger("close.djDebug");b("#djDebugToolbar li").removeClass("active");return false});b("#djDebug a.remoteCall").click(function(){b("#djDebugWindow").load(this.href,{},function(){b("#djDebugWindow a.djDebugBack").click(function(){b(this).parent().parent().hide();return false})});b("#djDebugWindow").show();return false});b("#djDebugTemplatePanel a.djTemplateShowContext").click(function(){c.toggle_arrow(b(this).children(".toggleArrow"));c.toggle_content(b(this).parent().next());return false});b("#djDebugSQLPanel a.djSQLShowStacktrace").click(function(){c.toggle_content(b(".djSQLHideStacktraceDiv",b(this).parents("tr")));return false});b("#djHideToolBarButton").click(function(){c.hide_toolbar(true);return false});b("#djShowToolBarButton").click(function(){c.show_toolbar();return false});b(document).bind("close.djDebug",function(){if(b("#djDebugWindow").is(":visible")){b("#djDebugWindow").hide();return}if(b(".panelContent").is(":visible")){b(".panelContent").hide();return}if(b("#djDebugToolbar").is(":visible")){c.hide_toolbar(true);return}});if(b.cookie(d)){c.hide_toolbar(false)}else{c.show_toolbar(false)}},toggle_content:function(e){if(e.is(":visible")){e.hide()}else{e.show()}},close:function(){b(document).trigger("close.djDebug");return false},hide_toolbar:function(e){b("#djDebugWindow").hide();b(".panelContent").hide();b("#djDebugToolbar li").removeClass("active");b("#djDebugToolbar").hide("fast");b("#djDebugToolbarHandle").show();b(document).unbind("keydown.djDebug");if(e){b.cookie(d,"hide",{path:"/",expires:10})}},show_toolbar:function(e){b(document).bind("keydown.djDebug",function(f){if(f.keyCode==27){c.close()}});b("#djDebugToolbarHandle").hide();if(e){b("#djDebugToolbar").show("fast")}else{b("#djDebugToolbar").show()}b.cookie(d,null,{path:"/",expires:-1})},toggle_arrow:function(f){var e=String.fromCharCode(9654);var g=String.fromCharCode(9660);f.html(f.html()==e?g:e)}};b(document).ready(function(){c.init()})});
\ No newline at end of file +/* + * jQuery JavaScript Library v1.4.1 + * http://jquery.com/ + * + * Copyright 2010, John Resig + * Dual licensed under the MIT or GPL Version 2 licenses. + * http://jquery.org/license + * + * Includes Sizzle.js + * http://sizzlejs.com/ + * Copyright 2010, The Dojo Foundation + * Released under the MIT, BSD, and GPL Licenses. + * + * Date: Mon Jan 25 19:43:33 2010 -0500 + */ +(function(aI,B){var a=function(aU,aV){return new a.fn.init(aU,aV)},n=aI.jQuery,Q=aI.$,aa=aI.document,W,O=/^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/,aS=/^.[^:#\[\.,]*$/,au=/\S/,L=/^(\s|\u00A0)+|(\s|\u00A0)+$/g,e=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,b=navigator.userAgent,u,I=false,ac=[],aC,aq=Object.prototype.toString,an=Object.prototype.hasOwnProperty,g=Array.prototype.push,D=Array.prototype.slice,s=Array.prototype.indexOf;a.fn=a.prototype={init:function(aU,aX){var aW,aY,aV,aZ;if(!aU){return this}if(aU.nodeType){this.context=this[0]=aU;this.length=1;return this}if(typeof aU==="string"){aW=O.exec(aU);if(aW&&(aW[1]||!aX)){if(aW[1]){aZ=(aX?aX.ownerDocument||aX:aa);aV=e.exec(aU);if(aV){if(a.isPlainObject(aX)){aU=[aa.createElement(aV[1])];a.fn.attr.call(aU,aX,true)}else{aU=[aZ.createElement(aV[1])]}}else{aV=H([aW[1]],[aZ]);aU=(aV.cacheable?aV.fragment.cloneNode(true):aV.fragment).childNodes}}else{aY=aa.getElementById(aW[2]);if(aY){if(aY.id!==aW[2]){return W.find(aU)}this.length=1;this[0]=aY}this.context=aa;this.selector=aU;return this}}else{if(!aX&&/^\w+$/.test(aU)){this.selector=aU;this.context=aa;aU=aa.getElementsByTagName(aU)}else{if(!aX||aX.jquery){return(aX||W).find(aU)}else{return a(aX).find(aU)}}}}else{if(a.isFunction(aU)){return W.ready(aU)}}if(aU.selector!==B){this.selector=aU.selector;this.context=aU.context}return a.isArray(aU)?this.setArray(aU):a.makeArray(aU,this)},selector:"",jquery:"1.4.1",length:0,size:function(){return this.length},toArray:function(){return D.call(this,0)},get:function(aU){return aU==null?this.toArray():(aU<0?this.slice(aU)[0]:this[aU])},pushStack:function(aV,aX,aU){var aW=a(aV||null);aW.prevObject=this;aW.context=this.context;if(aX==="find"){aW.selector=this.selector+(this.selector?" ":"")+aU}else{if(aX){aW.selector=this.selector+"."+aX+"("+aU+")"}}return aW},setArray:function(aU){this.length=0;g.apply(this,aU);return this},each:function(aV,aU){return a.each(this,aV,aU)},ready:function(aU){a.bindReady();if(a.isReady){aU.call(aa,a)}else{if(ac){ac.push(aU)}}return this},eq:function(aU){return aU===-1?this.slice(aU):this.slice(aU,+aU+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(D.apply(this,arguments),"slice",D.call(arguments).join(","))},map:function(aU){return this.pushStack(a.map(this,function(aW,aV){return aU.call(aW,aV,aW)}))},end:function(){return this.prevObject||a(null)},push:g,sort:[].sort,splice:[].splice};a.fn.init.prototype=a.fn;a.extend=a.fn.extend=function(){var aZ=arguments[0]||{},aY=1,aX=arguments.length,a1=false,a2,aW,aU,aV;if(typeof aZ==="boolean"){a1=aZ;aZ=arguments[1]||{};aY=2}if(typeof aZ!=="object"&&!a.isFunction(aZ)){aZ={}}if(aX===aY){aZ=this;--aY}for(;aY<aX;aY++){if((a2=arguments[aY])!=null){for(aW in a2){aU=aZ[aW];aV=a2[aW];if(aZ===aV){continue}if(a1&&aV&&(a.isPlainObject(aV)||a.isArray(aV))){var a0=aU&&(a.isPlainObject(aU)||a.isArray(aU))?aU:a.isArray(aV)?[]:{};aZ[aW]=a.extend(a1,a0,aV)}else{if(aV!==B){aZ[aW]=aV}}}}}return aZ};a.extend({noConflict:function(aU){aI.$=Q;if(aU){aI.jQuery=n}return a},isReady:false,ready:function(){if(!a.isReady){if(!aa.body){return setTimeout(a.ready,13)}a.isReady=true;if(ac){var aV,aU=0;while((aV=ac[aU++])){aV.call(aa,a)}ac=null}if(a.fn.triggerHandler){a(aa).triggerHandler("ready")}}},bindReady:function(){if(I){return}I=true;if(aa.readyState==="complete"){return a.ready()}if(aa.addEventListener){aa.addEventListener("DOMContentLoaded",aC,false);aI.addEventListener("load",a.ready,false)}else{if(aa.attachEvent){aa.attachEvent("onreadystatechange",aC);aI.attachEvent("onload",a.ready);var aU=false;try{aU=aI.frameElement==null}catch(aV){}if(aa.documentElement.doScroll&&aU){w()}}}},isFunction:function(aU){return aq.call(aU)==="[object Function]"},isArray:function(aU){return aq.call(aU)==="[object Array]"},isPlainObject:function(aV){if(!aV||aq.call(aV)!=="[object Object]"||aV.nodeType||aV.setInterval){return false}if(aV.constructor&&!an.call(aV,"constructor")&&!an.call(aV.constructor.prototype,"isPrototypeOf")){return false}var aU;for(aU in aV){}return aU===B||an.call(aV,aU)},isEmptyObject:function(aV){for(var aU in aV){return false}return true},error:function(aU){throw aU},parseJSON:function(aU){if(typeof aU!=="string"||!aU){return null}if(/^[\],:{}\s]*$/.test(aU.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,"@").replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,"]").replace(/(?:^|:|,)(?:\s*\[)+/g,""))){return aI.JSON&&aI.JSON.parse?aI.JSON.parse(aU):(new Function("return "+aU))()}else{a.error("Invalid JSON: "+aU)}},noop:function(){},globalEval:function(aW){if(aW&&au.test(aW)){var aV=aa.getElementsByTagName("head")[0]||aa.documentElement,aU=aa.createElement("script");aU.type="text/javascript";if(a.support.scriptEval){aU.appendChild(aa.createTextNode(aW))}else{aU.text=aW}aV.insertBefore(aU,aV.firstChild);aV.removeChild(aU)}},nodeName:function(aV,aU){return aV.nodeName&&aV.nodeName.toUpperCase()===aU.toUpperCase()},each:function(aX,a1,aW){var aV,aY=0,aZ=aX.length,aU=aZ===B||a.isFunction(aX);if(aW){if(aU){for(aV in aX){if(a1.apply(aX[aV],aW)===false){break}}}else{for(;aY<aZ;){if(a1.apply(aX[aY++],aW)===false){break}}}}else{if(aU){for(aV in aX){if(a1.call(aX[aV],aV,aX[aV])===false){break}}}else{for(var a0=aX[0];aY<aZ&&a1.call(a0,aY,a0)!==false;a0=aX[++aY]){}}}return aX},trim:function(aU){return(aU||"").replace(L,"")},makeArray:function(aW,aV){var aU=aV||[];if(aW!=null){if(aW.length==null||typeof aW==="string"||a.isFunction(aW)||(typeof aW!=="function"&&aW.setInterval)){g.call(aU,aW)}else{a.merge(aU,aW)}}return aU},inArray:function(aW,aX){if(aX.indexOf){return aX.indexOf(aW)}for(var aU=0,aV=aX.length;aU<aV;aU++){if(aX[aU]===aW){return aU}}return -1},merge:function(aY,aW){var aX=aY.length,aV=0;if(typeof aW.length==="number"){for(var aU=aW.length;aV<aU;aV++){aY[aX++]=aW[aV]}}else{while(aW[aV]!==B){aY[aX++]=aW[aV++]}}aY.length=aX;return aY},grep:function(aV,aZ,aU){var aW=[];for(var aX=0,aY=aV.length;aX<aY;aX++){if(!aU!==!aZ(aV[aX],aX)){aW.push(aV[aX])}}return aW},map:function(aV,a0,aU){var aW=[],aZ;for(var aX=0,aY=aV.length;aX<aY;aX++){aZ=a0(aV[aX],aX,aU);if(aZ!=null){aW[aW.length]=aZ}}return aW.concat.apply([],aW)},guid:1,proxy:function(aW,aV,aU){if(arguments.length===2){if(typeof aV==="string"){aU=aW;aW=aU[aV];aV=B}else{if(aV&&!a.isFunction(aV)){aU=aV;aV=B}}}if(!aV&&aW){aV=function(){return aW.apply(aU||this,arguments)}}if(aW){aV.guid=aW.guid=aW.guid||aV.guid||a.guid++}return aV},uaMatch:function(aV){aV=aV.toLowerCase();var aU=/(webkit)[ \/]([\w.]+)/.exec(aV)||/(opera)(?:.*version)?[ \/]([\w.]+)/.exec(aV)||/(msie) ([\w.]+)/.exec(aV)||!/compatible/.test(aV)&&/(mozilla)(?:.*? rv:([\w.]+))?/.exec(aV)||[];return{browser:aU[1]||"",version:aU[2]||"0"}},browser:{}});u=a.uaMatch(b);if(u.browser){a.browser[u.browser]=true;a.browser.version=u.version}if(a.browser.webkit){a.browser.safari=true}if(s){a.inArray=function(aU,aV){return s.call(aV,aU)}}W=a(aa);if(aa.addEventListener){aC=function(){aa.removeEventListener("DOMContentLoaded",aC,false);a.ready()}}else{if(aa.attachEvent){aC=function(){if(aa.readyState==="complete"){aa.detachEvent("onreadystatechange",aC);a.ready()}}}}function w(){if(a.isReady){return}try{aa.documentElement.doScroll("left")}catch(aU){setTimeout(w,1);return}a.ready()}function aR(aU,aV){if(aV.src){a.ajax({url:aV.src,async:false,dataType:"script"})}else{a.globalEval(aV.text||aV.textContent||aV.innerHTML||"")}if(aV.parentNode){aV.parentNode.removeChild(aV)}}function al(aU,a2,a0,aW,aZ,a1){var aV=aU.length;if(typeof a2==="object"){for(var aX in a2){al(aU,aX,a2[aX],aW,aZ,a0)}return aU}if(a0!==B){aW=!a1&&aW&&a.isFunction(a0);for(var aY=0;aY<aV;aY++){aZ(aU[aY],a2,aW?a0.call(aU[aY],aY,aZ(aU[aY],a2)):a0,a1)}return aU}return aV?aZ(aU[0],a2):null}function aL(){return(new Date).getTime()}(function(){a.support={};var a0=aa.documentElement,aZ=aa.createElement("script"),aU=aa.createElement("div"),aV="script"+aL();aU.style.display="none";aU.innerHTML="   <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>";var a2=aU.getElementsByTagName("*"),a1=aU.getElementsByTagName("a")[0];if(!a2||!a2.length||!a1){return}a.support={leadingWhitespace:aU.firstChild.nodeType===3,tbody:!aU.getElementsByTagName("tbody").length,htmlSerialize:!!aU.getElementsByTagName("link").length,style:/red/.test(a1.getAttribute("style")),hrefNormalized:a1.getAttribute("href")==="/a",opacity:/^0.55$/.test(a1.style.opacity),cssFloat:!!a1.style.cssFloat,checkOn:aU.getElementsByTagName("input")[0].value==="on",optSelected:aa.createElement("select").appendChild(aa.createElement("option")).selected,checkClone:false,scriptEval:false,noCloneEvent:true,boxModel:null};aZ.type="text/javascript";try{aZ.appendChild(aa.createTextNode("window."+aV+"=1;"))}catch(aX){}a0.insertBefore(aZ,a0.firstChild);if(aI[aV]){a.support.scriptEval=true;delete aI[aV]}a0.removeChild(aZ);if(aU.attachEvent&&aU.fireEvent){aU.attachEvent("onclick",function a3(){a.support.noCloneEvent=false;aU.detachEvent("onclick",a3)});aU.cloneNode(true).fireEvent("onclick")}aU=aa.createElement("div");aU.innerHTML="<input type='radio' name='radiotest' checked='checked'/>";var aW=aa.createDocumentFragment();aW.appendChild(aU.firstChild);a.support.checkClone=aW.cloneNode(true).cloneNode(true).lastChild.checked;a(function(){var a4=aa.createElement("div");a4.style.width=a4.style.paddingLeft="1px";aa.body.appendChild(a4);a.boxModel=a.support.boxModel=a4.offsetWidth===2;aa.body.removeChild(a4).style.display="none";a4=null});var aY=function(a4){var a6=aa.createElement("div");a4="on"+a4;var a5=(a4 in a6);if(!a5){a6.setAttribute(a4,"return;");a5=typeof a6[a4]==="function"}a6=null;return a5};a.support.submitBubbles=aY("submit");a.support.changeBubbles=aY("change");a0=aZ=aU=a2=a1=null})();a.props={"for":"htmlFor","class":"className",readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",colspan:"colSpan",tabindex:"tabIndex",usemap:"useMap",frameborder:"frameBorder"};var aE="jQuery"+aL(),aD=0,aP={};var K={};a.extend({cache:{},expando:aE,noData:{embed:true,object:true,applet:true},data:function(aW,aV,aY){if(aW.nodeName&&a.noData[aW.nodeName.toLowerCase()]){return}aW=aW==aI?aP:aW;var aZ=aW[aE],aU=a.cache,aX;if(!aV&&!aZ){return null}if(!aZ){aZ=++aD}if(typeof aV==="object"){aW[aE]=aZ;aX=aU[aZ]=a.extend(true,{},aV)}else{if(aU[aZ]){aX=aU[aZ]}else{if(typeof aY==="undefined"){aX=K}else{aX=aU[aZ]={}}}}if(aY!==B){aW[aE]=aZ;aX[aV]=aY}return typeof aV==="string"?aX[aV]:aX},removeData:function(aW,aV){if(aW.nodeName&&a.noData[aW.nodeName.toLowerCase()]){return}aW=aW==aI?aP:aW;var aZ=aW[aE],aU=a.cache,aX=aU[aZ];if(aV){if(aX){delete aX[aV];if(a.isEmptyObject(aX)){a.removeData(aW)}}}else{try{delete aW[aE]}catch(aY){if(aW.removeAttribute){aW.removeAttribute(aE)}}delete aU[aZ]}}});a.fn.extend({data:function(aU,aW){if(typeof aU==="undefined"&&this.length){return a.data(this[0])}else{if(typeof aU==="object"){return this.each(function(){a.data(this,aU)})}}var aX=aU.split(".");aX[1]=aX[1]?"."+aX[1]:"";if(aW===B){var aV=this.triggerHandler("getData"+aX[1]+"!",[aX[0]]);if(aV===B&&this.length){aV=a.data(this[0],aU)}return aV===B&&aX[1]?this.data(aX[0]):aV}else{return this.trigger("setData"+aX[1]+"!",[aX[0],aW]).each(function(){a.data(this,aU,aW)})}},removeData:function(aU){return this.each(function(){a.removeData(this,aU)})}});a.extend({queue:function(aV,aU,aX){if(!aV){return}aU=(aU||"fx")+"queue";var aW=a.data(aV,aU);if(!aX){return aW||[]}if(!aW||a.isArray(aX)){aW=a.data(aV,aU,a.makeArray(aX))}else{aW.push(aX)}return aW},dequeue:function(aX,aW){aW=aW||"fx";var aU=a.queue(aX,aW),aV=aU.shift();if(aV==="inprogress"){aV=aU.shift()}if(aV){if(aW==="fx"){aU.unshift("inprogress")}aV.call(aX,function(){a.dequeue(aX,aW)})}}});a.fn.extend({queue:function(aU,aV){if(typeof aU!=="string"){aV=aU;aU="fx"}if(aV===B){return a.queue(this[0],aU)}return this.each(function(aX,aY){var aW=a.queue(this,aU,aV);if(aU==="fx"&&aW[0]!=="inprogress"){a.dequeue(this,aU)}})},dequeue:function(aU){return this.each(function(){a.dequeue(this,aU)})},delay:function(aV,aU){aV=a.fx?a.fx.speeds[aV]||aV:aV;aU=aU||"fx";return this.queue(aU,function(){var aW=this;setTimeout(function(){a.dequeue(aW,aU)},aV)})},clearQueue:function(aU){return this.queue(aU||"fx",[])}});var am=/[\n\t]/g,R=/\s+/,at=/\r/g,aM=/href|src|style/,d=/(button|input)/i,y=/(button|input|object|select|textarea)/i,j=/^(a|area)$/i,G=/radio|checkbox/;a.fn.extend({attr:function(aU,aV){return al(this,aU,aV,true,a.attr)},removeAttr:function(aU,aV){return this.each(function(){a.attr(this,aU,"");if(this.nodeType===1){this.removeAttribute(aU)}})},addClass:function(aZ){if(a.isFunction(aZ)){return this.each(function(a3){var a2=a(this);a2.addClass(aZ.call(this,a3,a2.attr("class")))})}if(aZ&&typeof aZ==="string"){var a0=(aZ||"").split(R);for(var aW=0,aV=this.length;aW<aV;aW++){var aY=this[aW];if(aY.nodeType===1){if(!aY.className){aY.className=aZ}else{var aX=" "+aY.className+" ";for(var a1=0,aU=a0.length;a1<aU;a1++){if(aX.indexOf(" "+a0[a1]+" ")<0){aY.className+=" "+a0[a1]}}}}}}return this},removeClass:function(aZ){if(a.isFunction(aZ)){return this.each(function(a3){var a2=a(this);a2.removeClass(aZ.call(this,a3,a2.attr("class")))})}if((aZ&&typeof aZ==="string")||aZ===B){var a0=(aZ||"").split(R);for(var aW=0,aV=this.length;aW<aV;aW++){var aY=this[aW];if(aY.nodeType===1&&aY.className){if(aZ){var aX=(" "+aY.className+" ").replace(am," ");for(var a1=0,aU=a0.length;a1<aU;a1++){aX=aX.replace(" "+a0[a1]+" "," ")}aY.className=aX.substring(1,aX.length-1)}else{aY.className=""}}}}return this},toggleClass:function(aX,aV){var aW=typeof aX,aU=typeof aV==="boolean";if(a.isFunction(aX)){return this.each(function(aZ){var aY=a(this);aY.toggleClass(aX.call(this,aZ,aY.attr("class"),aV),aV)})}return this.each(function(){if(aW==="string"){var a0,aZ=0,aY=a(this),a1=aV,a2=aX.split(R);while((a0=a2[aZ++])){a1=aU?a1:!aY.hasClass(a0);aY[a1?"addClass":"removeClass"](a0)}}else{if(aW==="undefined"||aW==="boolean"){if(this.className){a.data(this,"__className__",this.className)}this.className=this.className||aX===false?"":a.data(this,"__className__")||""}}})},hasClass:function(aU){var aX=" "+aU+" ";for(var aW=0,aV=this.length;aW<aV;aW++){if((" "+this[aW].className+" ").replace(am," ").indexOf(aX)>-1){return true}}return false},val:function(a1){if(a1===B){var aV=this[0];if(aV){if(a.nodeName(aV,"option")){return(aV.attributes.value||{}).specified?aV.value:aV.text}if(a.nodeName(aV,"select")){var aZ=aV.selectedIndex,a2=[],a3=aV.options,aY=aV.type==="select-one";if(aZ<0){return null}for(var aW=aY?aZ:0,a0=aY?aZ+1:a3.length;aW<a0;aW++){var aX=a3[aW];if(aX.selected){a1=a(aX).val();if(aY){return a1}a2.push(a1)}}return a2}if(G.test(aV.type)&&!a.support.checkOn){return aV.getAttribute("value")===null?"on":aV.value}return(aV.value||"").replace(at,"")}return B}var aU=a.isFunction(a1);return this.each(function(a6){var a5=a(this),a7=a1;if(this.nodeType!==1){return}if(aU){a7=a1.call(this,a6,a5.val())}if(typeof a7==="number"){a7+=""}if(a.isArray(a7)&&G.test(this.type)){this.checked=a.inArray(a5.val(),a7)>=0}else{if(a.nodeName(this,"select")){var a4=a.makeArray(a7);a("option",this).each(function(){this.selected=a.inArray(a(this).val(),a4)>=0});if(!a4.length){this.selectedIndex=-1}}else{this.value=a7}}})}});a.extend({attrFn:{val:true,css:true,html:true,text:true,data:true,width:true,height:true,offset:true},attr:function(aV,aU,a0,a3){if(!aV||aV.nodeType===3||aV.nodeType===8){return B}if(a3&&aU in a.attrFn){return a(aV)[aU](a0)}var aW=aV.nodeType!==1||!a.isXMLDoc(aV),aZ=a0!==B;aU=aW&&a.props[aU]||aU;if(aV.nodeType===1){var aY=aM.test(aU);if(aU==="selected"&&!a.support.optSelected){var a1=aV.parentNode;if(a1){a1.selectedIndex;if(a1.parentNode){a1.parentNode.selectedIndex}}}if(aU in aV&&aW&&!aY){if(aZ){if(aU==="type"&&d.test(aV.nodeName)&&aV.parentNode){a.error("type property can't be changed")}aV[aU]=a0}if(a.nodeName(aV,"form")&&aV.getAttributeNode(aU)){return aV.getAttributeNode(aU).nodeValue}if(aU==="tabIndex"){var a2=aV.getAttributeNode("tabIndex");return a2&&a2.specified?a2.value:y.test(aV.nodeName)||j.test(aV.nodeName)&&aV.href?0:B}return aV[aU]}if(!a.support.style&&aW&&aU==="style"){if(aZ){aV.style.cssText=""+a0}return aV.style.cssText}if(aZ){aV.setAttribute(aU,""+a0)}var aX=!a.support.hrefNormalized&&aW&&aY?aV.getAttribute(aU,2):aV.getAttribute(aU);return aX===null?B:aX}return a.style(aV,aU,a0)}});var z=function(aU){return aU.replace(/[^\w\s\.\|`]/g,function(aV){return"\\"+aV})};a.event={add:function(aW,a1,a6,aY){if(aW.nodeType===3||aW.nodeType===8){return}if(aW.setInterval&&(aW!==aI&&!aW.frameElement)){aW=aI}if(!a6.guid){a6.guid=a.guid++}if(aY!==B){var a4=a6;a6=a.proxy(a4);a6.data=aY}var a7=a.data(aW,"events")||a.data(aW,"events",{}),a0=a.data(aW,"handle"),aZ;if(!a0){aZ=function(){return typeof a!=="undefined"&&!a.event.triggered?a.event.handle.apply(aZ.elem,arguments):B};a0=a.data(aW,"handle",aZ)}if(!a0){return}a0.elem=aW;a1=a1.split(/\s+/);var a3,aX=0;while((a3=a1[aX++])){var aU=a3.split(".");a3=aU.shift();if(aX>1){a6=a.proxy(a6);if(aY!==B){a6.data=aY}}a6.type=aU.slice(0).sort().join(".");var aV=a7[a3],a2=this.special[a3]||{};if(!aV){aV=a7[a3]={};if(!a2.setup||a2.setup.call(aW,aY,aU,a6)===false){if(aW.addEventListener){aW.addEventListener(a3,a0,false)}else{if(aW.attachEvent){aW.attachEvent("on"+a3,a0)}}}}if(a2.add){var a5=a2.add.call(aW,a6,aY,aU,aV);if(a5&&a.isFunction(a5)){a5.guid=a5.guid||a6.guid;a5.data=a5.data||a6.data;a5.type=a5.type||a6.type;a6=a5}}aV[a6.guid]=a6;this.global[a3]=true}aW=null},global:{},remove:function(aW,a0,a6){if(aW.nodeType===3||aW.nodeType===8){return}var a7=a.data(aW,"events"),a1,a3,a4;if(a7){if(a0===B||(typeof a0==="string"&&a0.charAt(0)===".")){for(a3 in a7){this.remove(aW,a3+(a0||""))}}else{if(a0.type){a6=a0.handler;a0=a0.type}a0=a0.split(/\s+/);var aY=0;while((a3=a0[aY++])){var aU=a3.split(".");a3=aU.shift();var a5=!aU.length,aV=a.map(aU.slice(0).sort(),z),aX=new RegExp("(^|\\.)"+aV.join("\\.(?:.*\\.)?")+"(\\.|$)"),a2=this.special[a3]||{};if(a7[a3]){if(a6){a4=a7[a3][a6.guid];delete a7[a3][a6.guid]}else{for(var aZ in a7[a3]){if(a5||aX.test(a7[a3][aZ].type)){delete a7[a3][aZ]}}}if(a2.remove){a2.remove.call(aW,aU,a4)}for(a1 in a7[a3]){break}if(!a1){if(!a2.teardown||a2.teardown.call(aW,aU)===false){if(aW.removeEventListener){aW.removeEventListener(a3,a.data(aW,"handle"),false)}else{if(aW.detachEvent){aW.detachEvent("on"+a3,a.data(aW,"handle"))}}}a1=null;delete a7[a3]}}}}for(a1 in a7){break}if(!a1){var aZ=a.data(aW,"handle");if(aZ){aZ.elem=null}a.removeData(aW,"events");a.removeData(aW,"handle")}}},trigger:function(aU,aY,aW){var a2=aU.type||aU,aX=arguments[3];if(!aX){aU=typeof aU==="object"?aU[aE]?aU:a.extend(a.Event(a2),aU):a.Event(a2);if(a2.indexOf("!")>=0){aU.type=a2=a2.slice(0,-1);aU.exclusive=true}if(!aW){aU.stopPropagation();if(this.global[a2]){a.each(a.cache,function(){if(this.events&&this.events[a2]){a.event.trigger(aU,aY,this.handle.elem)}})}}if(!aW||aW.nodeType===3||aW.nodeType===8){return B}aU.result=B;aU.target=aW;aY=a.makeArray(aY);aY.unshift(aU)}aU.currentTarget=aW;var aZ=a.data(aW,"handle");if(aZ){aZ.apply(aW,aY)}var a3=aW.parentNode||aW.ownerDocument;try{if(!(aW&&aW.nodeName&&a.noData[aW.nodeName.toLowerCase()])){if(aW["on"+a2]&&aW["on"+a2].apply(aW,aY)===false){aU.result=false}}}catch(a1){}if(!aU.isPropagationStopped()&&a3){a.event.trigger(aU,aY,a3,true)}else{if(!aU.isDefaultPrevented()){var a0=aU.target,aV,a4=a.nodeName(a0,"a")&&a2==="click";if(!a4&&!(a0&&a0.nodeName&&a.noData[a0.nodeName.toLowerCase()])){try{if(a0[a2]){aV=a0["on"+a2];if(aV){a0["on"+a2]=null}this.triggered=true;a0[a2]()}}catch(a1){}if(aV){a0["on"+a2]=aV}this.triggered=false}}}},handle:function(a0){var aZ,aU;a0=arguments[0]=a.event.fix(a0||aI.event);a0.currentTarget=this;var a1=a0.type.split(".");a0.type=a1.shift();aZ=!a1.length&&!a0.exclusive;var aY=new RegExp("(^|\\.)"+a1.slice(0).sort().join("\\.(?:.*\\.)?")+"(\\.|$)");aU=(a.data(this,"events")||{})[a0.type];for(var aW in aU){var aX=aU[aW];if(aZ||aY.test(aX.type)){a0.handler=aX;a0.data=aX.data;var aV=aX.apply(this,arguments);if(aV!==B){a0.result=aV;if(aV===false){a0.preventDefault();a0.stopPropagation()}}if(a0.isImmediatePropagationStopped()){break}}}return a0.result},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(aX){if(aX[aE]){return aX}var aV=aX;aX=a.Event(aV);for(var aW=this.props.length,aZ;aW;){aZ=this.props[--aW];aX[aZ]=aV[aZ]}if(!aX.target){aX.target=aX.srcElement||aa}if(aX.target.nodeType===3){aX.target=aX.target.parentNode}if(!aX.relatedTarget&&aX.fromElement){aX.relatedTarget=aX.fromElement===aX.target?aX.toElement:aX.fromElement}if(aX.pageX==null&&aX.clientX!=null){var aY=aa.documentElement,aU=aa.body;aX.pageX=aX.clientX+(aY&&aY.scrollLeft||aU&&aU.scrollLeft||0)-(aY&&aY.clientLeft||aU&&aU.clientLeft||0);aX.pageY=aX.clientY+(aY&&aY.scrollTop||aU&&aU.scrollTop||0)-(aY&&aY.clientTop||aU&&aU.clientTop||0)}if(!aX.which&&((aX.charCode||aX.charCode===0)?aX.charCode:aX.keyCode)){aX.which=aX.charCode||aX.keyCode}if(!aX.metaKey&&aX.ctrlKey){aX.metaKey=aX.ctrlKey}if(!aX.which&&aX.button!==B){aX.which=(aX.button&1?1:(aX.button&2?3:(aX.button&4?2:0)))}return aX},guid:100000000,proxy:a.proxy,special:{ready:{setup:a.bindReady,teardown:a.noop},live:{add:function(aU,aX,aW,aV){a.extend(aU,aX||{});aU.guid+=aX.selector+aX.live;aX.liveProxy=aU;a.event.add(this,aX.live,U,aX)},remove:function(aW){if(aW.length){var aU=0,aV=new RegExp("(^|\\.)"+aW[0]+"(\\.|$)");a.each((a.data(this,"events").live||{}),function(){if(aV.test(this.type)){aU++}});if(aU<1){a.event.remove(this,aW[0],U)}}},special:{}},beforeunload:{setup:function(aW,aV,aU){if(this.setInterval){this.onbeforeunload=aU}return false},teardown:function(aV,aU){if(this.onbeforeunload===aU){this.onbeforeunload=null}}}}};a.Event=function(aU){if(!this.preventDefault){return new a.Event(aU)}if(aU&&aU.type){this.originalEvent=aU;this.type=aU.type}else{this.type=aU}this.timeStamp=aL();this[aE]=true};function aN(){return false}function f(){return true}a.Event.prototype={preventDefault:function(){this.isDefaultPrevented=f;var aU=this.originalEvent;if(!aU){return}if(aU.preventDefault){aU.preventDefault()}aU.returnValue=false},stopPropagation:function(){this.isPropagationStopped=f;var aU=this.originalEvent;if(!aU){return}if(aU.stopPropagation){aU.stopPropagation()}aU.cancelBubble=true},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=f;this.stopPropagation()},isDefaultPrevented:aN,isPropagationStopped:aN,isImmediatePropagationStopped:aN};var P=function(aV){var aU=aV.relatedTarget;while(aU&&aU!==this){try{aU=aU.parentNode}catch(aW){break}}if(aU!==this){aV.type=aV.data;a.event.handle.apply(this,arguments)}},av=function(aU){aU.type=aU.data;a.event.handle.apply(this,arguments)};a.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(aV,aU){a.event.special[aV]={setup:function(aW){a.event.add(this,aU,aW&&aW.selector?av:P,aV)},teardown:function(aW){a.event.remove(this,aU,aW&&aW.selector?av:P)}}});if(!a.support.submitBubbles){a.event.special.submit={setup:function(aW,aV,aU){if(this.nodeName.toLowerCase()!=="form"){a.event.add(this,"click.specialSubmit."+aU.guid,function(aZ){var aY=aZ.target,aX=aY.type;if((aX==="submit"||aX==="image")&&a(aY).closest("form").length){return ax("submit",this,arguments)}});a.event.add(this,"keypress.specialSubmit."+aU.guid,function(aZ){var aY=aZ.target,aX=aY.type;if((aX==="text"||aX==="password")&&a(aY).closest("form").length&&aZ.keyCode===13){return ax("submit",this,arguments)}})}else{return false}},remove:function(aV,aU){a.event.remove(this,"click.specialSubmit"+(aU?"."+aU.guid:""));a.event.remove(this,"keypress.specialSubmit"+(aU?"."+aU.guid:""))}}}if(!a.support.changeBubbles){var ao=/textarea|input|select/i;function i(aV){var aU=aV.type,aW=aV.value;if(aU==="radio"||aU==="checkbox"){aW=aV.checked}else{if(aU==="select-multiple"){aW=aV.selectedIndex>-1?a.map(aV.options,function(aX){return aX.selected}).join("-"):""}else{if(aV.nodeName.toLowerCase()==="select"){aW=aV.selectedIndex}}}return aW}function N(aW){var aU=aW.target,aV,aX;if(!ao.test(aU.nodeName)||aU.readOnly){return}aV=a.data(aU,"_change_data");aX=i(aU);if(aW.type!=="focusout"||aU.type!=="radio"){a.data(aU,"_change_data",aX)}if(aV===B||aX===aV){return}if(aV!=null||aX){aW.type="change";return a.event.trigger(aW,arguments[1],aU)}}a.event.special.change={filters:{focusout:N,click:function(aW){var aV=aW.target,aU=aV.type;if(aU==="radio"||aU==="checkbox"||aV.nodeName.toLowerCase()==="select"){return N.call(this,aW)}},keydown:function(aW){var aV=aW.target,aU=aV.type;if((aW.keyCode===13&&aV.nodeName.toLowerCase()!=="textarea")||(aW.keyCode===32&&(aU==="checkbox"||aU==="radio"))||aU==="select-multiple"){return N.call(this,aW)}},beforeactivate:function(aV){var aU=aV.target;if(aU.nodeName.toLowerCase()==="input"&&aU.type==="radio"){a.data(aU,"_change_data",i(aU))}}},setup:function(aX,aW,aV){for(var aU in aO){a.event.add(this,aU+".specialChange."+aV.guid,aO[aU])}return ao.test(this.nodeName)},remove:function(aW,aV){for(var aU in aO){a.event.remove(this,aU+".specialChange"+(aV?"."+aV.guid:""),aO[aU])}return ao.test(this.nodeName)}};var aO=a.event.special.change.filters}function ax(aV,aW,aU){aU[0].type=aV;return a.event.handle.apply(aW,aU)}if(aa.addEventListener){a.each({focus:"focusin",blur:"focusout"},function(aW,aU){a.event.special[aU]={setup:function(){this.addEventListener(aW,aV,true)},teardown:function(){this.removeEventListener(aW,aV,true)}};function aV(aX){aX=a.event.fix(aX);aX.type=aU;return a.event.handle.call(this,aX)}})}a.each(["bind","one"],function(aV,aU){a.fn[aU]=function(aZ,a0,aY){if(typeof aZ==="object"){for(var aW in aZ){this[aU](aW,a0,aZ[aW],aY)}return this}if(a.isFunction(a0)){aY=a0;a0=B}var aX=aU==="one"?a.proxy(aY,function(a1){a(this).unbind(a1,aX);return aY.apply(this,arguments)}):aY;return aZ==="unload"&&aU!=="one"?this.one(aZ,a0,aY):this.each(function(){a.event.add(this,aZ,aX,a0)})}});a.fn.extend({unbind:function(aW,aV){if(typeof aW==="object"&&!aW.preventDefault){for(var aU in aW){this.unbind(aU,aW[aU])}return this}return this.each(function(){a.event.remove(this,aW,aV)})},trigger:function(aU,aV){return this.each(function(){a.event.trigger(aU,aV,this)})},triggerHandler:function(aU,aW){if(this[0]){var aV=a.Event(aU);aV.preventDefault();aV.stopPropagation();a.event.trigger(aV,aW,this[0]);return aV.result}},toggle:function(aW){var aU=arguments,aV=1;while(aV<aU.length){a.proxy(aW,aU[aV++])}return this.click(a.proxy(aW,function(aX){var aY=(a.data(this,"lastToggle"+aW.guid)||0)%aV;a.data(this,"lastToggle"+aW.guid,aY+1);aX.preventDefault();return aU[aY].apply(this,arguments)||false}))},hover:function(aU,aV){return this.mouseenter(aU).mouseleave(aV||aU)}});a.each(["live","die"],function(aV,aU){a.fn[aU]=function(aX,a0,aZ){var aY,aW=0;if(a.isFunction(a0)){aZ=a0;a0=B}aX=(aX||"").split(/\s+/);while((aY=aX[aW++])!=null){aY=aY==="focus"?"focusin":aY==="blur"?"focusout":aY==="hover"?aX.push("mouseleave")&&"mouseenter":aY;if(aU==="live"){a(this.context).bind(m(aY,this.selector),{data:a0,selector:this.selector,live:aY},aZ)}else{a(this.context).unbind(m(aY,this.selector),aZ?{guid:aZ.guid+this.selector+aY}:null)}}return this}});function U(aU){var a5,aV=[],a7=[],a3=arguments,a6,a2,a4,aX,aZ,a1,aY,a0,aW=a.extend({},a.data(this,"events").live);if(aU.button&&aU.type==="click"){return}for(aZ in aW){a4=aW[aZ];if(a4.live===aU.type||a4.altLive&&a.inArray(aU.type,a4.altLive)>-1){a0=a4.data;if(!(a0.beforeFilter&&a0.beforeFilter[aU.type]&&!a0.beforeFilter[aU.type](aU))){a7.push(a4.selector)}}else{delete aW[aZ]}}a2=a(aU.target).closest(a7,aU.currentTarget);for(a1=0,aY=a2.length;a1<aY;a1++){for(aZ in aW){a4=aW[aZ];aX=a2[a1].elem;a6=null;if(a2[a1].selector===a4.selector){if(a4.live==="mouseenter"||a4.live==="mouseleave"){a6=a(aU.relatedTarget).closest(a4.selector)[0]}if(!a6||a6!==aX){aV.push({elem:aX,fn:a4})}}}}for(a1=0,aY=aV.length;a1<aY;a1++){a2=aV[a1];aU.currentTarget=a2.elem;aU.data=a2.fn.data;if(a2.fn.apply(a2.elem,a3)===false){a5=false;break}}return a5}function m(aV,aU){return"live."+(aV?aV+".":"")+aU.replace(/\./g,"`").replace(/ /g,"&")}a.each(("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error").split(" "),function(aV,aU){a.fn[aU]=function(aW){return aW?this.bind(aU,aW):this.trigger(aU)};if(a.attrFn){a.attrFn[aU]=true}});if(aI.attachEvent&&!aI.addEventListener){aI.attachEvent("onunload",function(){for(var aV in a.cache){if(a.cache[aV].handle){try{a.event.remove(a.cache[aV].handle.elem)}catch(aU){}}}}); +/* + * Sizzle CSS Selector Engine - v1.0 + *  Copyright 2009, The Dojo Foundation + *  Released under the MIT, BSD, and GPL Licenses. + *  More information: http://sizzlejs.com/ + */ +}(function(){var a5=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,a6=0,a8=Object.prototype.toString,a0=false,aZ=true;[0,0].sort(function(){aZ=false;return 0});var aW=function(bh,bc,bk,bl){bk=bk||[];var bn=bc=bc||aa;if(bc.nodeType!==1&&bc.nodeType!==9){return[]}if(!bh||typeof bh!=="string"){return bk}var bi=[],be,bp,bs,bd,bg=true,bf=aX(bc),bm=bh;while((a5.exec(""),be=a5.exec(bm))!==null){bm=be[3];bi.push(be[1]);if(be[2]){bd=be[3];break}}if(bi.length>1&&a1.exec(bh)){if(bi.length===2&&a2.relative[bi[0]]){bp=a9(bi[0]+bi[1],bc)}else{bp=a2.relative[bi[0]]?[bc]:aW(bi.shift(),bc);while(bi.length){bh=bi.shift();if(a2.relative[bh]){bh+=bi.shift()}bp=a9(bh,bp)}}}else{if(!bl&&bi.length>1&&bc.nodeType===9&&!bf&&a2.match.ID.test(bi[0])&&!a2.match.ID.test(bi[bi.length-1])){var bo=aW.find(bi.shift(),bc,bf);bc=bo.expr?aW.filter(bo.expr,bo.set)[0]:bo.set[0]}if(bc){var bo=bl?{expr:bi.pop(),set:a4(bl)}:aW.find(bi.pop(),bi.length===1&&(bi[0]==="~"||bi[0]==="+")&&bc.parentNode?bc.parentNode:bc,bf);bp=bo.expr?aW.filter(bo.expr,bo.set):bo.set;if(bi.length>0){bs=a4(bp)}else{bg=false}while(bi.length){var br=bi.pop(),bq=br;if(!a2.relative[br]){br=""}else{bq=bi.pop()}if(bq==null){bq=bc}a2.relative[br](bs,bq,bf)}}else{bs=bi=[]}}if(!bs){bs=bp}if(!bs){aW.error(br||bh)}if(a8.call(bs)==="[object Array]"){if(!bg){bk.push.apply(bk,bs)}else{if(bc&&bc.nodeType===1){for(var bj=0;bs[bj]!=null;bj++){if(bs[bj]&&(bs[bj]===true||bs[bj].nodeType===1&&a3(bc,bs[bj]))){bk.push(bp[bj])}}}else{for(var bj=0;bs[bj]!=null;bj++){if(bs[bj]&&bs[bj].nodeType===1){bk.push(bp[bj])}}}}}else{a4(bs,bk)}if(bd){aW(bd,bn,bk,bl);aW.uniqueSort(bk)}return bk};aW.uniqueSort=function(bd){if(a7){a0=aZ;bd.sort(a7);if(a0){for(var bc=1;bc<bd.length;bc++){if(bd[bc]===bd[bc-1]){bd.splice(bc--,1)}}}}return bd};aW.matches=function(bc,bd){return aW(bc,null,null,bd)};aW.find=function(bj,bc,bk){var bi,bg;if(!bj){return[]}for(var bf=0,be=a2.order.length;bf<be;bf++){var bh=a2.order[bf],bg;if((bg=a2.leftMatch[bh].exec(bj))){var bd=bg[1];bg.splice(1,1);if(bd.substr(bd.length-1)!=="\\"){bg[1]=(bg[1]||"").replace(/\\/g,"");bi=a2.find[bh](bg,bc,bk);if(bi!=null){bj=bj.replace(a2.match[bh],"");break}}}}if(!bi){bi=bc.getElementsByTagName("*")}return{set:bi,expr:bj}};aW.filter=function(bn,bm,bq,bg){var be=bn,bs=[],bk=bm,bi,bc,bj=bm&&bm[0]&&aX(bm[0]);while(bn&&bm.length){for(var bl in a2.filter){if((bi=a2.leftMatch[bl].exec(bn))!=null&&bi[2]){var bd=a2.filter[bl],br,bp,bf=bi[1];bc=false;bi.splice(1,1);if(bf.substr(bf.length-1)==="\\"){continue}if(bk===bs){bs=[]}if(a2.preFilter[bl]){bi=a2.preFilter[bl](bi,bk,bq,bs,bg,bj);if(!bi){bc=br=true}else{if(bi===true){continue}}}if(bi){for(var bh=0;(bp=bk[bh])!=null;bh++){if(bp){br=bd(bp,bi,bh,bk);var bo=bg^!!br;if(bq&&br!=null){if(bo){bc=true}else{bk[bh]=false}}else{if(bo){bs.push(bp);bc=true}}}}}if(br!==B){if(!bq){bk=bs}bn=bn.replace(a2.match[bl],"");if(!bc){return[]}break}}}if(bn===be){if(bc==null){aW.error(bn)}else{break}}be=bn}return bk};aW.error=function(bc){throw"Syntax error, unrecognized expression: "+bc};var a2=aW.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\))?/},leftMatch:{},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(bc){return bc.getAttribute("href")}},relative:{"+":function(bi,bd){var bf=typeof bd==="string",bh=bf&&!/\W/.test(bd),bj=bf&&!bh;if(bh){bd=bd.toLowerCase()}for(var be=0,bc=bi.length,bg;be<bc;be++){if((bg=bi[be])){while((bg=bg.previousSibling)&&bg.nodeType!==1){}bi[be]=bj||bg&&bg.nodeName.toLowerCase()===bd?bg||false:bg===bd}}if(bj){aW.filter(bd,bi,true)}},">":function(bi,bd){var bg=typeof bd==="string";if(bg&&!/\W/.test(bd)){bd=bd.toLowerCase();for(var be=0,bc=bi.length;be<bc;be++){var bh=bi[be];if(bh){var bf=bh.parentNode;bi[be]=bf.nodeName.toLowerCase()===bd?bf:false}}}else{for(var be=0,bc=bi.length;be<bc;be++){var bh=bi[be];if(bh){bi[be]=bg?bh.parentNode:bh.parentNode===bd}}if(bg){aW.filter(bd,bi,true)}}},"":function(bf,bd,bh){var be=a6++,bc=ba;if(typeof bd==="string"&&!/\W/.test(bd)){var bg=bd=bd.toLowerCase();bc=aU}bc("parentNode",bd,be,bf,bg,bh)},"~":function(bf,bd,bh){var be=a6++,bc=ba;if(typeof bd==="string"&&!/\W/.test(bd)){var bg=bd=bd.toLowerCase();bc=aU}bc("previousSibling",bd,be,bf,bg,bh)}},find:{ID:function(bd,be,bf){if(typeof be.getElementById!=="undefined"&&!bf){var bc=be.getElementById(bd[1]);return bc?[bc]:[]}},NAME:function(be,bh){if(typeof bh.getElementsByName!=="undefined"){var bd=[],bg=bh.getElementsByName(be[1]);for(var bf=0,bc=bg.length;bf<bc;bf++){if(bg[bf].getAttribute("name")===be[1]){bd.push(bg[bf])}}return bd.length===0?null:bd}},TAG:function(bc,bd){return bd.getElementsByTagName(bc[1])}},preFilter:{CLASS:function(bf,bd,be,bc,bi,bj){bf=" "+bf[1].replace(/\\/g,"")+" ";if(bj){return bf}for(var bg=0,bh;(bh=bd[bg])!=null;bg++){if(bh){if(bi^(bh.className&&(" "+bh.className+" ").replace(/[\t\n]/g," ").indexOf(bf)>=0)){if(!be){bc.push(bh)}}else{if(be){bd[bg]=false}}}}return false},ID:function(bc){return bc[1].replace(/\\/g,"")},TAG:function(bd,bc){return bd[1].toLowerCase()},CHILD:function(bc){if(bc[1]==="nth"){var bd=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(bc[2]==="even"&&"2n"||bc[2]==="odd"&&"2n+1"||!/\D/.test(bc[2])&&"0n+"+bc[2]||bc[2]);bc[2]=(bd[1]+(bd[2]||1))-0;bc[3]=bd[3]-0}bc[0]=a6++;return bc},ATTR:function(bg,bd,be,bc,bh,bi){var bf=bg[1].replace(/\\/g,"");if(!bi&&a2.attrMap[bf]){bg[1]=a2.attrMap[bf]}if(bg[2]==="~="){bg[4]=" "+bg[4]+" "}return bg},PSEUDO:function(bg,bd,be,bc,bh){if(bg[1]==="not"){if((a5.exec(bg[3])||"").length>1||/^\w/.test(bg[3])){bg[3]=aW(bg[3],null,null,bd)}else{var bf=aW.filter(bg[3],bd,be,true^bh);if(!be){bc.push.apply(bc,bf)}return false}}else{if(a2.match.POS.test(bg[0])||a2.match.CHILD.test(bg[0])){return true}}return bg},POS:function(bc){bc.unshift(true);return bc}},filters:{enabled:function(bc){return bc.disabled===false&&bc.type!=="hidden"},disabled:function(bc){return bc.disabled===true},checked:function(bc){return bc.checked===true},selected:function(bc){bc.parentNode.selectedIndex;return bc.selected===true},parent:function(bc){return !!bc.firstChild},empty:function(bc){return !bc.firstChild},has:function(be,bd,bc){return !!aW(bc[3],be).length},header:function(bc){return/h\d/i.test(bc.nodeName)},text:function(bc){return"text"===bc.type},radio:function(bc){return"radio"===bc.type},checkbox:function(bc){return"checkbox"===bc.type},file:function(bc){return"file"===bc.type},password:function(bc){return"password"===bc.type},submit:function(bc){return"submit"===bc.type},image:function(bc){return"image"===bc.type},reset:function(bc){return"reset"===bc.type},button:function(bc){return"button"===bc.type||bc.nodeName.toLowerCase()==="button"},input:function(bc){return/input|select|textarea|button/i.test(bc.nodeName)}},setFilters:{first:function(bd,bc){return bc===0},last:function(be,bd,bc,bf){return bd===bf.length-1},even:function(bd,bc){return bc%2===0},odd:function(bd,bc){return bc%2===1},lt:function(be,bd,bc){return bd<bc[3]-0},gt:function(be,bd,bc){return bd>bc[3]-0},nth:function(be,bd,bc){return bc[3]-0===bd},eq:function(be,bd,bc){return bc[3]-0===bd}},filter:{PSEUDO:function(bi,be,bf,bj){var bd=be[1],bg=a2.filters[bd];if(bg){return bg(bi,bf,be,bj)}else{if(bd==="contains"){return(bi.textContent||bi.innerText||aV([bi])||"").indexOf(be[3])>=0}else{if(bd==="not"){var bh=be[3];for(var bf=0,bc=bh.length;bf<bc;bf++){if(bh[bf]===bi){return false}}return true}else{aW.error("Syntax error, unrecognized expression: "+bd)}}}},CHILD:function(bc,bf){var bi=bf[1],bd=bc;switch(bi){case"only":case"first":while((bd=bd.previousSibling)){if(bd.nodeType===1){return false}}if(bi==="first"){return true}bd=bc;case"last":while((bd=bd.nextSibling)){if(bd.nodeType===1){return false}}return true;case"nth":var be=bf[2],bl=bf[3];if(be===1&&bl===0){return true}var bh=bf[0],bk=bc.parentNode;if(bk&&(bk.sizcache!==bh||!bc.nodeIndex)){var bg=0;for(bd=bk.firstChild;bd;bd=bd.nextSibling){if(bd.nodeType===1){bd.nodeIndex=++bg}}bk.sizcache=bh}var bj=bc.nodeIndex-bl;if(be===0){return bj===0}else{return(bj%be===0&&bj/be>=0)}}},ID:function(bd,bc){return bd.nodeType===1&&bd.getAttribute("id")===bc},TAG:function(bd,bc){return(bc==="*"&&bd.nodeType===1)||bd.nodeName.toLowerCase()===bc},CLASS:function(bd,bc){return(" "+(bd.className||bd.getAttribute("class"))+" ").indexOf(bc)>-1},ATTR:function(bh,bf){var be=bf[1],bc=a2.attrHandle[be]?a2.attrHandle[be](bh):bh[be]!=null?bh[be]:bh.getAttribute(be),bi=bc+"",bg=bf[2],bd=bf[4];return bc==null?bg==="!=":bg==="="?bi===bd:bg==="*="?bi.indexOf(bd)>=0:bg==="~="?(" "+bi+" ").indexOf(bd)>=0:!bd?bi&&bc!==false:bg==="!="?bi!==bd:bg==="^="?bi.indexOf(bd)===0:bg==="$="?bi.substr(bi.length-bd.length)===bd:bg==="|="?bi===bd||bi.substr(0,bd.length+1)===bd+"-":false},POS:function(bg,bd,be,bh){var bc=bd[2],bf=a2.setFilters[bc];if(bf){return bf(bg,be,bd,bh)}}}};var a1=a2.match.POS;for(var aY in a2.match){a2.match[aY]=new RegExp(a2.match[aY].source+/(?![^\[]*\])(?![^\(]*\))/.source);a2.leftMatch[aY]=new RegExp(/(^(?:.|\r|\n)*?)/.source+a2.match[aY].source.replace(/\\(\d+)/g,function(bd,bc){return"\\"+(bc-0+1)}))}var a4=function(bd,bc){bd=Array.prototype.slice.call(bd,0);if(bc){bc.push.apply(bc,bd);return bc}return bd};try{Array.prototype.slice.call(aa.documentElement.childNodes,0)}catch(bb){a4=function(bg,bf){var bd=bf||[];if(a8.call(bg)==="[object Array]"){Array.prototype.push.apply(bd,bg)}else{if(typeof bg.length==="number"){for(var be=0,bc=bg.length;be<bc;be++){bd.push(bg[be])}}else{for(var be=0;bg[be];be++){bd.push(bg[be])}}}return bd}}var a7;if(aa.documentElement.compareDocumentPosition){a7=function(bd,bc){if(!bd.compareDocumentPosition||!bc.compareDocumentPosition){if(bd==bc){a0=true}return bd.compareDocumentPosition?-1:1}var be=bd.compareDocumentPosition(bc)&4?-1:bd===bc?0:1;if(be===0){a0=true}return be}}else{if("sourceIndex" in aa.documentElement){a7=function(bd,bc){if(!bd.sourceIndex||!bc.sourceIndex){if(bd==bc){a0=true}return bd.sourceIndex?-1:1}var be=bd.sourceIndex-bc.sourceIndex;if(be===0){a0=true}return be}}else{if(aa.createRange){a7=function(bf,bd){if(!bf.ownerDocument||!bd.ownerDocument){if(bf==bd){a0=true}return bf.ownerDocument?-1:1}var be=bf.ownerDocument.createRange(),bc=bd.ownerDocument.createRange();be.setStart(bf,0);be.setEnd(bf,0);bc.setStart(bd,0);bc.setEnd(bd,0);var bg=be.compareBoundaryPoints(Range.START_TO_END,bc);if(bg===0){a0=true}return bg}}}}function aV(bc){var bd="",bf;for(var be=0;bc[be];be++){bf=bc[be];if(bf.nodeType===3||bf.nodeType===4){bd+=bf.nodeValue}else{if(bf.nodeType!==8){bd+=aV(bf.childNodes)}}}return bd}(function(){var bd=aa.createElement("div"),be="script"+(new Date).getTime();bd.innerHTML="<a name='"+be+"'/>";var bc=aa.documentElement;bc.insertBefore(bd,bc.firstChild);if(aa.getElementById(be)){a2.find.ID=function(bg,bh,bi){if(typeof bh.getElementById!=="undefined"&&!bi){var bf=bh.getElementById(bg[1]);return bf?bf.id===bg[1]||typeof bf.getAttributeNode!=="undefined"&&bf.getAttributeNode("id").nodeValue===bg[1]?[bf]:B:[]}};a2.filter.ID=function(bh,bf){var bg=typeof bh.getAttributeNode!=="undefined"&&bh.getAttributeNode("id");return bh.nodeType===1&&bg&&bg.nodeValue===bf}}bc.removeChild(bd);bc=bd=null})();(function(){var bc=aa.createElement("div");bc.appendChild(aa.createComment(""));if(bc.getElementsByTagName("*").length>0){a2.find.TAG=function(bd,bh){var bg=bh.getElementsByTagName(bd[1]);if(bd[1]==="*"){var bf=[];for(var be=0;bg[be];be++){if(bg[be].nodeType===1){bf.push(bg[be])}}bg=bf}return bg}}bc.innerHTML="<a href='#'></a>";if(bc.firstChild&&typeof bc.firstChild.getAttribute!=="undefined"&&bc.firstChild.getAttribute("href")!=="#"){a2.attrHandle.href=function(bd){return bd.getAttribute("href",2)}}bc=null})();if(aa.querySelectorAll){(function(){var bc=aW,be=aa.createElement("div");be.innerHTML="<p class='TEST'></p>";if(be.querySelectorAll&&be.querySelectorAll(".TEST").length===0){return}aW=function(bi,bh,bf,bg){bh=bh||aa;if(!bg&&bh.nodeType===9&&!aX(bh)){try{return a4(bh.querySelectorAll(bi),bf)}catch(bj){}}return bc(bi,bh,bf,bg)};for(var bd in bc){aW[bd]=bc[bd]}be=null})()}(function(){var bc=aa.createElement("div");bc.innerHTML="<div class='test e'></div><div class='test'></div>";if(!bc.getElementsByClassName||bc.getElementsByClassName("e").length===0){return}bc.lastChild.className="e";if(bc.getElementsByClassName("e").length===1){return}a2.order.splice(1,0,"CLASS");a2.find.CLASS=function(bd,be,bf){if(typeof be.getElementsByClassName!=="undefined"&&!bf){return be.getElementsByClassName(bd[1])}};bc=null})();function aU(bd,bi,bh,bl,bj,bk){for(var bf=0,be=bl.length;bf<be;bf++){var bc=bl[bf];if(bc){bc=bc[bd];var bg=false;while(bc){if(bc.sizcache===bh){bg=bl[bc.sizset];break}if(bc.nodeType===1&&!bk){bc.sizcache=bh;bc.sizset=bf}if(bc.nodeName.toLowerCase()===bi){bg=bc;break}bc=bc[bd]}bl[bf]=bg}}}function ba(bd,bi,bh,bl,bj,bk){for(var bf=0,be=bl.length;bf<be;bf++){var bc=bl[bf];if(bc){bc=bc[bd];var bg=false;while(bc){if(bc.sizcache===bh){bg=bl[bc.sizset];break}if(bc.nodeType===1){if(!bk){bc.sizcache=bh;bc.sizset=bf}if(typeof bi!=="string"){if(bc===bi){bg=true;break}}else{if(aW.filter(bi,[bc]).length>0){bg=bc;break}}}bc=bc[bd]}bl[bf]=bg}}}var a3=aa.compareDocumentPosition?function(bd,bc){return bd.compareDocumentPosition(bc)&16}:function(bd,bc){return bd!==bc&&(bd.contains?bd.contains(bc):true)};var aX=function(bc){var bd=(bc?bc.ownerDocument||bc:0).documentElement;return bd?bd.nodeName!=="HTML":false};var a9=function(bc,bj){var bf=[],bg="",bh,be=bj.nodeType?[bj]:bj;while((bh=a2.match.PSEUDO.exec(bc))){bg+=bh[0];bc=bc.replace(a2.match.PSEUDO,"")}bc=a2.relative[bc]?bc+"*":bc;for(var bi=0,bd=be.length;bi<bd;bi++){aW(bc,be[bi],bf)}return aW.filter(bg,bf)};a.find=aW;a.expr=aW.selectors;a.expr[":"]=a.expr.filters;a.unique=aW.uniqueSort;a.getText=aV;a.isXMLDoc=aX;a.contains=a3;return;aI.Sizzle=aW})();var M=/Until$/,X=/^(?:parents|prevUntil|prevAll)/,aH=/,/,D=Array.prototype.slice;var ag=function(aX,aW,aU){if(a.isFunction(aW)){return a.grep(aX,function(aZ,aY){return !!aW.call(aZ,aY,aZ)===aU})}else{if(aW.nodeType){return a.grep(aX,function(aZ,aY){return(aZ===aW)===aU})}else{if(typeof aW==="string"){var aV=a.grep(aX,function(aY){return aY.nodeType===1});if(aS.test(aW)){return a.filter(aW,aV,!aU)}else{aW=a.filter(aW,aV)}}}}return a.grep(aX,function(aZ,aY){return(a.inArray(aZ,aW)>=0)===aU})};a.fn.extend({find:function(aU){var aW=this.pushStack("","find",aU),aZ=0;for(var aX=0,aV=this.length;aX<aV;aX++){aZ=aW.length;a.find(aU,this[aX],aW);if(aX>0){for(var a0=aZ;a0<aW.length;a0++){for(var aY=0;aY<aZ;aY++){if(aW[aY]===aW[a0]){aW.splice(a0--,1);break}}}}}return aW},has:function(aV){var aU=a(aV);return this.filter(function(){for(var aX=0,aW=aU.length;aX<aW;aX++){if(a.contains(this,aU[aX])){return true}}})},not:function(aU){return this.pushStack(ag(this,aU,false),"not",aU)},filter:function(aU){return this.pushStack(ag(this,aU,true),"filter",aU)},is:function(aU){return !!aU&&a.filter(aU,this).length>0},closest:function(a3,aU){if(a.isArray(a3)){var a0=[],a2=this[0],aZ,aY={},aW;if(a2&&a3.length){for(var aX=0,aV=a3.length;aX<aV;aX++){aW=a3[aX];if(!aY[aW]){aY[aW]=a.expr.match.POS.test(aW)?a(aW,aU||this.context):aW}}while(a2&&a2.ownerDocument&&a2!==aU){for(aW in aY){aZ=aY[aW];if(aZ.jquery?aZ.index(a2)>-1:a(a2).is(aZ)){a0.push({selector:aW,elem:a2});delete aY[aW]}}a2=a2.parentNode}}return a0}var a1=a.expr.match.POS.test(a3)?a(a3,aU||this.context):null;return this.map(function(a4,a5){while(a5&&a5.ownerDocument&&a5!==aU){if(a1?a1.index(a5)>-1:a(a5).is(a3)){return a5}a5=a5.parentNode}return null})},index:function(aU){if(!aU||typeof aU==="string"){return a.inArray(this[0],aU?a(aU):this.parent().children())}return a.inArray(aU.jquery?aU[0]:aU,this)},add:function(aU,aV){var aX=typeof aU==="string"?a(aU,aV||this.context):a.makeArray(aU),aW=a.merge(this.get(),aX);return this.pushStack(x(aX[0])||x(aW[0])?aW:a.unique(aW))},andSelf:function(){return this.add(this.prevObject)}});function x(aU){return !aU||!aU.parentNode||aU.parentNode.nodeType===11}a.each({parent:function(aV){var aU=aV.parentNode;return aU&&aU.nodeType!==11?aU:null},parents:function(aU){return a.dir(aU,"parentNode")},parentsUntil:function(aV,aU,aW){return a.dir(aV,"parentNode",aW)},next:function(aU){return a.nth(aU,2,"nextSibling")},prev:function(aU){return a.nth(aU,2,"previousSibling")},nextAll:function(aU){return a.dir(aU,"nextSibling")},prevAll:function(aU){return a.dir(aU,"previousSibling")},nextUntil:function(aV,aU,aW){return a.dir(aV,"nextSibling",aW)},prevUntil:function(aV,aU,aW){return a.dir(aV,"previousSibling",aW)},siblings:function(aU){return a.sibling(aU.parentNode.firstChild,aU)},children:function(aU){return a.sibling(aU.firstChild)},contents:function(aU){return a.nodeName(aU,"iframe")?aU.contentDocument||aU.contentWindow.document:a.makeArray(aU.childNodes)}},function(aU,aV){a.fn[aU]=function(aY,aW){var aX=a.map(this,aV,aY);if(!M.test(aU)){aW=aY}if(aW&&typeof aW==="string"){aX=a.filter(aW,aX)}aX=this.length>1?a.unique(aX):aX;if((this.length>1||aH.test(aW))&&X.test(aU)){aX=aX.reverse()}return this.pushStack(aX,aU,D.call(arguments).join(","))}});a.extend({filter:function(aW,aU,aV){if(aV){aW=":not("+aW+")"}return a.find.matches(aW,aU)},dir:function(aW,aV,aY){var aU=[],aX=aW[aV];while(aX&&aX.nodeType!==9&&(aY===B||aX.nodeType!==1||!a(aX).is(aY))){if(aX.nodeType===1){aU.push(aX)}aX=aX[aV]}return aU},nth:function(aY,aU,aW,aX){aU=aU||1;var aV=0;for(;aY;aY=aY[aW]){if(aY.nodeType===1&&++aV===aU){break}}return aY},sibling:function(aW,aV){var aU=[];for(;aW;aW=aW.nextSibling){if(aW.nodeType===1&&aW!==aV){aU.push(aW)}}return aU}});var S=/ jQuery\d+="(?:\d+|null)"/g,Y=/^\s+/,F=/(<([\w:]+)[^>]*?)\/>/g,aj=/^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i,c=/<([\w:]+)/,t=/<tbody/i,J=/<|&\w+;/,l=/checked\s*(?:[^=]|=\s*.checked.)/i,p=function(aV,aW,aU){return aj.test(aU)?aV:aW+"></"+aU+">"},ab={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],area:[1,"<map>","</map>"],_default:[0,"",""]};ab.optgroup=ab.option;ab.tbody=ab.tfoot=ab.colgroup=ab.caption=ab.thead;ab.th=ab.td;if(!a.support.htmlSerialize){ab._default=[1,"div<div>","</div>"]}a.fn.extend({text:function(aU){if(a.isFunction(aU)){return this.each(function(aW){var aV=a(this);aV.text(aU.call(this,aW,aV.text()))})}if(typeof aU!=="object"&&aU!==B){return this.empty().append((this[0]&&this[0].ownerDocument||aa).createTextNode(aU))}return a.getText(this)},wrapAll:function(aU){if(a.isFunction(aU)){return this.each(function(aW){a(this).wrapAll(aU.call(this,aW))})}if(this[0]){var aV=a(aU,this[0].ownerDocument).eq(0).clone(true);if(this[0].parentNode){aV.insertBefore(this[0])}aV.map(function(){var aW=this;while(aW.firstChild&&aW.firstChild.nodeType===1){aW=aW.firstChild}return aW}).append(this)}return this},wrapInner:function(aU){if(a.isFunction(aU)){return this.each(function(aV){a(this).wrapInner(aU.call(this,aV))})}return this.each(function(){var aV=a(this),aW=aV.contents();if(aW.length){aW.wrapAll(aU)}else{aV.append(aU)}})},wrap:function(aU){return this.each(function(){a(this).wrapAll(aU)})},unwrap:function(){return this.parent().each(function(){if(!a.nodeName(this,"body")){a(this).replaceWith(this.childNodes)}}).end()},append:function(){return this.domManip(arguments,true,function(aU){if(this.nodeType===1){this.appendChild(aU)}})},prepend:function(){return this.domManip(arguments,true,function(aU){if(this.nodeType===1){this.insertBefore(aU,this.firstChild)}})},before:function(){if(this[0]&&this[0].parentNode){return this.domManip(arguments,false,function(aV){this.parentNode.insertBefore(aV,this)})}else{if(arguments.length){var aU=a(arguments[0]);aU.push.apply(aU,this.toArray());return this.pushStack(aU,"before",arguments)}}},after:function(){if(this[0]&&this[0].parentNode){return this.domManip(arguments,false,function(aV){this.parentNode.insertBefore(aV,this.nextSibling)})}else{if(arguments.length){var aU=this.pushStack(this,"after",arguments);aU.push.apply(aU,a(arguments[0]).toArray());return aU}}},clone:function(aV){var aU=this.map(function(){if(!a.support.noCloneEvent&&!a.isXMLDoc(this)){var aX=this.outerHTML,aW=this.ownerDocument;if(!aX){var aY=aW.createElement("div");aY.appendChild(this.cloneNode(true));aX=aY.innerHTML}return a.clean([aX.replace(S,"").replace(Y,"")],aW)[0]}else{return this.cloneNode(true)}});if(aV===true){q(this,aU);q(this.find("*"),aU.find("*"))}return aU},html:function(aW){if(aW===B){return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(S,""):null}else{if(typeof aW==="string"&&!/<script/i.test(aW)&&(a.support.leadingWhitespace||!Y.test(aW))&&!ab[(c.exec(aW)||["",""])[1].toLowerCase()]){aW=aW.replace(F,p);try{for(var aV=0,aU=this.length;aV<aU;aV++){if(this[aV].nodeType===1){a.cleanData(this[aV].getElementsByTagName("*"));this[aV].innerHTML=aW}}}catch(aX){this.empty().append(aW)}}else{if(a.isFunction(aW)){this.each(function(a0){var aZ=a(this),aY=aZ.html();aZ.empty().append(function(){return aW.call(this,a0,aY)})})}else{this.empty().append(aW)}}}return this},replaceWith:function(aU){if(this[0]&&this[0].parentNode){if(!a.isFunction(aU)){aU=a(aU).detach()}else{return this.each(function(aX){var aW=a(this),aV=aW.html();aW.replaceWith(aU.call(this,aX,aV))})}return this.each(function(){var aW=this.nextSibling,aV=this.parentNode;a(this).remove();if(aW){a(aW).before(aU)}else{a(aV).append(aU)}})}else{return this.pushStack(a(a.isFunction(aU)?aU():aU),"replaceWith",aU)}},detach:function(aU){return this.remove(aU,true)},domManip:function(aZ,a3,a2){var aW,aY,a1=aZ[0],aV=[];if(!a.support.checkClone&&arguments.length===3&&typeof a1==="string"&&l.test(a1)){return this.each(function(){a(this).domManip(aZ,a3,a2,true)})}if(a.isFunction(a1)){return this.each(function(a5){var a4=a(this);aZ[0]=a1.call(this,a5,a3?a4.html():B);a4.domManip(aZ,a3,a2)})}if(this[0]){if(aZ[0]&&aZ[0].parentNode&&aZ[0].parentNode.nodeType===11){aW={fragment:aZ[0].parentNode}}else{aW=H(aZ,this,aV)}aY=aW.fragment.firstChild;if(aY){a3=a3&&a.nodeName(aY,"tr");for(var aX=0,aU=this.length;aX<aU;aX++){a2.call(a3?a0(this[aX],aY):this[aX],aW.cacheable||this.length>1||aX>0?aW.fragment.cloneNode(true):aW.fragment)}}if(aV){a.each(aV,aR)}}return this;function a0(a4,a5){return a.nodeName(a4,"table")?(a4.getElementsByTagName("tbody")[0]||a4.appendChild(a4.ownerDocument.createElement("tbody"))):a4}}});function q(aW,aU){var aV=0;aU.each(function(){if(this.nodeName!==(aW[aV]&&aW[aV].nodeName)){return}var a1=a.data(aW[aV++]),a0=a.data(this,a1),aX=a1&&a1.events;if(aX){delete a0.handle;a0.events={};for(var aZ in aX){for(var aY in aX[aZ]){a.event.add(this,aZ,aX[aZ][aY],aX[aZ][aY].data)}}}})}function H(aZ,aX,aV){var aY,aU,aW,a0;if(aZ.length===1&&typeof aZ[0]==="string"&&aZ[0].length<512&&aZ[0].indexOf("<option")<0&&(a.support.checkClone||!l.test(aZ[0]))){aU=true;aW=a.fragments[aZ[0]];if(aW){if(aW!==1){aY=aW}}}if(!aY){a0=(aX&&aX[0]?aX[0].ownerDocument||aX[0]:aa);aY=a0.createDocumentFragment();a.clean(aZ,a0,aY,aV)}if(aU){a.fragments[aZ[0]]=aW?aY:1}return{fragment:aY,cacheable:aU}}a.fragments={};a.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(aU,aV){a.fn[aU]=function(aW){var aZ=[],a1=a(aW);for(var a0=0,aX=a1.length;a0<aX;a0++){var aY=(a0>0?this.clone(true):this).get();a.fn[aV].apply(a(a1[a0]),aY);aZ=aZ.concat(aY)}return this.pushStack(aZ,aU,a1.selector)}});a.each({remove:function(aU,aV){if(!aU||a.filter(aU,[this]).length){if(!aV&&this.nodeType===1){a.cleanData(this.getElementsByTagName("*"));a.cleanData([this])}if(this.parentNode){this.parentNode.removeChild(this)}}},empty:function(){if(this.nodeType===1){a.cleanData(this.getElementsByTagName("*"))}while(this.firstChild){this.removeChild(this.firstChild)}}},function(aU,aV){a.fn[aU]=function(){return this.each(aV,arguments)}});a.extend({clean:function(aV,aZ,aX,aU){aZ=aZ||aa;if(typeof aZ.createElement==="undefined"){aZ=aZ.ownerDocument||aZ[0]&&aZ[0].ownerDocument||aa}var aW=[];a.each(aV,function(a6,a3){if(typeof a3==="number"){a3+=""}if(!a3){return}if(typeof a3==="string"&&!J.test(a3)){a3=aZ.createTextNode(a3)}else{if(typeof a3==="string"){a3=a3.replace(F,p);var a8=(c.exec(a3)||["",""])[1].toLowerCase(),a2=ab[a8]||ab._default,a5=a2[0],a0=aZ.createElement("div");a0.innerHTML=a2[1]+a3+a2[2];while(a5--){a0=a0.lastChild}if(!a.support.tbody){var a1=t.test(a3),a7=a8==="table"&&!a1?a0.firstChild&&a0.firstChild.childNodes:a2[1]==="<table>"&&!a1?a0.childNodes:[];for(var a4=a7.length-1;a4>=0;--a4){if(a.nodeName(a7[a4],"tbody")&&!a7[a4].childNodes.length){a7[a4].parentNode.removeChild(a7[a4])}}}if(!a.support.leadingWhitespace&&Y.test(a3)){a0.insertBefore(aZ.createTextNode(Y.exec(a3)[0]),a0.firstChild)}a3=a.makeArray(a0.childNodes)}}if(a3.nodeType){aW.push(a3)}else{aW=a.merge(aW,a3)}});if(aX){for(var aY=0;aW[aY];aY++){if(aU&&a.nodeName(aW[aY],"script")&&(!aW[aY].type||aW[aY].type.toLowerCase()==="text/javascript")){aU.push(aW[aY].parentNode?aW[aY].parentNode.removeChild(aW[aY]):aW[aY])}else{if(aW[aY].nodeType===1){aW.splice.apply(aW,[aY+1,0].concat(a.makeArray(aW[aY].getElementsByTagName("script"))))}aX.appendChild(aW[aY])}}}return aW},cleanData:function(aU){for(var aV=0,aW,aX;(aW=aU[aV])!=null;aV++){a.event.remove(aW);a.removeData(aW)}}});var ap=/z-?index|font-?weight|opacity|zoom|line-?height/i,T=/alpha\([^)]*\)/,Z=/opacity=([^)]*)/,af=/float/i,aw=/-([a-z])/ig,v=/([A-Z])/g,aK=/^-?\d+(?:px)?$/i,aQ=/^-?\d/,aG={position:"absolute",visibility:"hidden",display:"block"},V=["Left","Right"],aA=["Top","Bottom"],ai=aa.defaultView&&aa.defaultView.getComputedStyle,aJ=a.support.cssFloat?"cssFloat":"styleFloat",k=function(aU,aV){return aV.toUpperCase()};a.fn.css=function(aU,aV){return al(this,aU,aV,true,function(aX,aW,aY){if(aY===B){return a.curCSS(aX,aW)}if(typeof aY==="number"&&!ap.test(aW)){aY+="px"}a.style(aX,aW,aY)})};a.extend({style:function(aY,aV,aZ){if(!aY||aY.nodeType===3||aY.nodeType===8){return B}if((aV==="width"||aV==="height")&&parseFloat(aZ)<0){aZ=B}var aX=aY.style||aY,a0=aZ!==B;if(!a.support.opacity&&aV==="opacity"){if(a0){aX.zoom=1;var aU=parseInt(aZ,10)+""==="NaN"?"":"alpha(opacity="+aZ*100+")";var aW=aX.filter||a.curCSS(aY,"filter")||"";aX.filter=T.test(aW)?aW.replace(T,aU):aU}return aX.filter&&aX.filter.indexOf("opacity=")>=0?(parseFloat(Z.exec(aX.filter)[1])/100)+"":""}if(af.test(aV)){aV=aJ}aV=aV.replace(aw,k);if(a0){aX[aV]=aZ}return aX[aV]},css:function(aX,aV,aZ,aU){if(aV==="width"||aV==="height"){var a1,aW=aG,a0=aV==="width"?V:aA;function aY(){a1=aV==="width"?aX.offsetWidth:aX.offsetHeight;if(aU==="border"){return}a.each(a0,function(){if(!aU){a1-=parseFloat(a.curCSS(aX,"padding"+this,true))||0}if(aU==="margin"){a1+=parseFloat(a.curCSS(aX,"margin"+this,true))||0}else{a1-=parseFloat(a.curCSS(aX,"border"+this+"Width",true))||0}})}if(aX.offsetWidth!==0){aY()}else{a.swap(aX,aW,aY)}return Math.max(0,Math.round(a1))}return a.curCSS(aX,aV,aZ)},curCSS:function(a0,aV,aW){var a3,aU=a0.style,aX;if(!a.support.opacity&&aV==="opacity"&&a0.currentStyle){a3=Z.test(a0.currentStyle.filter||"")?(parseFloat(RegExp.$1)/100)+"":"";return a3===""?"1":a3}if(af.test(aV)){aV=aJ}if(!aW&&aU&&aU[aV]){a3=aU[aV]}else{if(ai){if(af.test(aV)){aV="float"}aV=aV.replace(v,"-$1").toLowerCase();var a2=a0.ownerDocument.defaultView;if(!a2){return null}var a4=a2.getComputedStyle(a0,null);if(a4){a3=a4.getPropertyValue(aV)}if(aV==="opacity"&&a3===""){a3="1"}}else{if(a0.currentStyle){var aZ=aV.replace(aw,k);a3=a0.currentStyle[aV]||a0.currentStyle[aZ];if(!aK.test(a3)&&aQ.test(a3)){var aY=aU.left,a1=a0.runtimeStyle.left;a0.runtimeStyle.left=a0.currentStyle.left;aU.left=aZ==="fontSize"?"1em":(a3||0);a3=aU.pixelLeft+"px";aU.left=aY;a0.runtimeStyle.left=a1}}}}return a3},swap:function(aX,aW,aY){var aU={};for(var aV in aW){aU[aV]=aX.style[aV];aX.style[aV]=aW[aV]}aY.call(aX);for(var aV in aW){aX.style[aV]=aU[aV]}}});if(a.expr&&a.expr.filters){a.expr.filters.hidden=function(aX){var aV=aX.offsetWidth,aU=aX.offsetHeight,aW=aX.nodeName.toLowerCase()==="tr";return aV===0&&aU===0&&!aW?true:aV>0&&aU>0&&!aW?false:a.curCSS(aX,"display")==="none"};a.expr.filters.visible=function(aU){return !a.expr.filters.hidden(aU)}}var ae=aL(),aF=/<script(.|\s)*?\/script>/gi,o=/select|textarea/i,ay=/color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i,r=/=\?(&|$)/,C=/\?/,aT=/(\?|&)_=.*?(&|$)/,A=/^(\w+:)?\/\/([^\/?#]+)/,h=/%20/g;a.fn.extend({_load:a.fn.load,load:function(aW,aZ,a0){if(typeof aW!=="string"){return this._load(aW)}else{if(!this.length){return this}}var aY=aW.indexOf(" ");if(aY>=0){var aU=aW.slice(aY,aW.length);aW=aW.slice(0,aY)}var aX="GET";if(aZ){if(a.isFunction(aZ)){a0=aZ;aZ=null}else{if(typeof aZ==="object"){aZ=a.param(aZ,a.ajaxSettings.traditional);aX="POST"}}}var aV=this;a.ajax({url:aW,type:aX,dataType:"html",data:aZ,complete:function(a2,a1){if(a1==="success"||a1==="notmodified"){aV.html(aU?a("<div />").append(a2.responseText.replace(aF,"")).find(aU):a2.responseText)}if(a0){aV.each(a0,[a2.responseText,a1,a2])}}});return this},serialize:function(){return a.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?a.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||o.test(this.nodeName)||ay.test(this.type))}).map(function(aU,aV){var aW=a(this).val();return aW==null?null:a.isArray(aW)?a.map(aW,function(aY,aX){return{name:aV.name,value:aY}}):{name:aV.name,value:aW}}).get()}});a.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(aU,aV){a.fn[aV]=function(aW){return this.bind(aV,aW)}});a.extend({get:function(aU,aW,aX,aV){if(a.isFunction(aW)){aV=aV||aX;aX=aW;aW=null}return a.ajax({type:"GET",url:aU,data:aW,success:aX,dataType:aV})},getScript:function(aU,aV){return a.get(aU,null,aV,"script")},getJSON:function(aU,aV,aW){return a.get(aU,aV,aW,"json")},post:function(aU,aW,aX,aV){if(a.isFunction(aW)){aV=aV||aX;aX=aW;aW={}}return a.ajax({type:"POST",url:aU,data:aW,success:aX,dataType:aV})},ajaxSetup:function(aU){a.extend(a.ajaxSettings,aU)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:aI.XMLHttpRequest&&(aI.location.protocol!=="file:"||!aI.ActiveXObject)?function(){return new aI.XMLHttpRequest()}:function(){try{return new aI.ActiveXObject("Microsoft.XMLHTTP")}catch(aU){}},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},etag:{},ajax:function(a9){var a4=a.extend(true,{},a.ajaxSettings,a9);var be,a8,bd,bf=a9&&a9.context||a4,aW=a4.type.toUpperCase();if(a4.data&&a4.processData&&typeof a4.data!=="string"){a4.data=a.param(a4.data,a4.traditional)}if(a4.dataType==="jsonp"){if(aW==="GET"){if(!r.test(a4.url)){a4.url+=(C.test(a4.url)?"&":"?")+(a4.jsonp||"callback")+"=?"}}else{if(!a4.data||!r.test(a4.data)){a4.data=(a4.data?a4.data+"&":"")+(a4.jsonp||"callback")+"=?"}}a4.dataType="json"}if(a4.dataType==="json"&&(a4.data&&r.test(a4.data)||r.test(a4.url))){be=a4.jsonpCallback||("jsonp"+ae++);if(a4.data){a4.data=(a4.data+"").replace(r,"="+be+"$1")}a4.url=a4.url.replace(r,"="+be+"$1");a4.dataType="script";aI[be]=aI[be]||function(bg){bd=bg;aZ();a2();aI[be]=B;try{delete aI[be]}catch(bh){}if(aX){aX.removeChild(bb)}}}if(a4.dataType==="script"&&a4.cache===null){a4.cache=false}if(a4.cache===false&&aW==="GET"){var aU=aL();var bc=a4.url.replace(aT,"$1_="+aU+"$2");a4.url=bc+((bc===a4.url)?(C.test(a4.url)?"&":"?")+"_="+aU:"")}if(a4.data&&aW==="GET"){a4.url+=(C.test(a4.url)?"&":"?")+a4.data}if(a4.global&&!a.active++){a.event.trigger("ajaxStart")}var a7=A.exec(a4.url),aY=a7&&(a7[1]&&a7[1]!==location.protocol||a7[2]!==location.host);if(a4.dataType==="script"&&aW==="GET"&&aY){var aX=aa.getElementsByTagName("head")[0]||aa.documentElement;var bb=aa.createElement("script");bb.src=a4.url;if(a4.scriptCharset){bb.charset=a4.scriptCharset}if(!be){var a6=false;bb.onload=bb.onreadystatechange=function(){if(!a6&&(!this.readyState||this.readyState==="loaded"||this.readyState==="complete")){a6=true;aZ();a2();bb.onload=bb.onreadystatechange=null;if(aX&&bb.parentNode){aX.removeChild(bb)}}}}aX.insertBefore(bb,aX.firstChild);return B}var a1=false;var a0=a4.xhr();if(!a0){return}if(a4.username){a0.open(aW,a4.url,a4.async,a4.username,a4.password)}else{a0.open(aW,a4.url,a4.async)}try{if(a4.data||a9&&a9.contentType){a0.setRequestHeader("Content-Type",a4.contentType)}if(a4.ifModified){if(a.lastModified[a4.url]){a0.setRequestHeader("If-Modified-Since",a.lastModified[a4.url])}if(a.etag[a4.url]){a0.setRequestHeader("If-None-Match",a.etag[a4.url])}}if(!aY){a0.setRequestHeader("X-Requested-With","XMLHttpRequest")}a0.setRequestHeader("Accept",a4.dataType&&a4.accepts[a4.dataType]?a4.accepts[a4.dataType]+", */*":a4.accepts._default)}catch(ba){}if(a4.beforeSend&&a4.beforeSend.call(bf,a0,a4)===false){if(a4.global&&!--a.active){a.event.trigger("ajaxStop")}a0.abort();return false}if(a4.global){a5("ajaxSend",[a0,a4])}var a3=a0.onreadystatechange=function(bg){if(!a0||a0.readyState===0||bg==="abort"){if(!a1){a2()}a1=true;if(a0){a0.onreadystatechange=a.noop}}else{if(!a1&&a0&&(a0.readyState===4||bg==="timeout")){a1=true;a0.onreadystatechange=a.noop;a8=bg==="timeout"?"timeout":!a.httpSuccess(a0)?"error":a4.ifModified&&a.httpNotModified(a0,a4.url)?"notmodified":"success";var bi;if(a8==="success"){try{bd=a.httpData(a0,a4.dataType,a4)}catch(bh){a8="parsererror";bi=bh}}if(a8==="success"||a8==="notmodified"){if(!be){aZ()}}else{a.handleError(a4,a0,a8,bi)}a2();if(bg==="timeout"){a0.abort()}if(a4.async){a0=null}}}};try{var aV=a0.abort;a0.abort=function(){if(a0){aV.call(a0)}a3("abort")}}catch(ba){}if(a4.async&&a4.timeout>0){setTimeout(function(){if(a0&&!a1){a3("timeout")}},a4.timeout)}try{a0.send(aW==="POST"||aW==="PUT"||aW==="DELETE"?a4.data:null)}catch(ba){a.handleError(a4,a0,null,ba);a2()}if(!a4.async){a3()}function aZ(){if(a4.success){a4.success.call(bf,bd,a8,a0)}if(a4.global){a5("ajaxSuccess",[a0,a4])}}function a2(){if(a4.complete){a4.complete.call(bf,a0,a8)}if(a4.global){a5("ajaxComplete",[a0,a4])}if(a4.global&&!--a.active){a.event.trigger("ajaxStop")}}function a5(bh,bg){(a4.context?a(a4.context):a.event).trigger(bh,bg)}return a0},handleError:function(aV,aX,aU,aW){if(aV.error){aV.error.call(aV.context||aV,aX,aU,aW)}if(aV.global){(aV.context?a(aV.context):a.event).trigger("ajaxError",[aX,aV,aW])}},active:0,httpSuccess:function(aV){try{return !aV.status&&location.protocol==="file:"||(aV.status>=200&&aV.status<300)||aV.status===304||aV.status===1223||aV.status===0}catch(aU){}return false},httpNotModified:function(aX,aU){var aW=aX.getResponseHeader("Last-Modified"),aV=aX.getResponseHeader("Etag");if(aW){a.lastModified[aU]=aW}if(aV){a.etag[aU]=aV}return aX.status===304||aX.status===0},httpData:function(aZ,aX,aW){var aV=aZ.getResponseHeader("content-type")||"",aU=aX==="xml"||!aX&&aV.indexOf("xml")>=0,aY=aU?aZ.responseXML:aZ.responseText;if(aU&&aY.documentElement.nodeName==="parsererror"){a.error("parsererror")}if(aW&&aW.dataFilter){aY=aW.dataFilter(aY,aX)}if(typeof aY==="string"){if(aX==="json"||!aX&&aV.indexOf("json")>=0){aY=a.parseJSON(aY)}else{if(aX==="script"||!aX&&aV.indexOf("javascript")>=0){a.globalEval(aY)}}}return aY},param:function(aU,aX){var aV=[];if(aX===B){aX=a.ajaxSettings.traditional}if(a.isArray(aU)||aU.jquery){a.each(aU,function(){aZ(this.name,this.value)})}else{for(var aY in aU){aW(aY,aU[aY])}}return aV.join("&").replace(h,"+");function aW(a0,a1){if(a.isArray(a1)){a.each(a1,function(a3,a2){if(aX){aZ(a0,a2)}else{aW(a0+"["+(typeof a2==="object"||a.isArray(a2)?a3:"")+"]",a2)}})}else{if(!aX&&a1!=null&&typeof a1==="object"){a.each(a1,function(a3,a2){aW(a0+"["+a3+"]",a2)})}else{aZ(a0,a1)}}}function aZ(a0,a1){a1=a.isFunction(a1)?a1():a1;aV[aV.length]=encodeURIComponent(a0)+"="+encodeURIComponent(a1)}}});var E={},ad=/toggle|show|hide/,ar=/^([+-]=)?([\d+-.]+)(.*)$/,aB,ah=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];a.fn.extend({show:function(aV,a3){if(aV||aV===0){return this.animate(az("show",3),aV,a3)}else{for(var a0=0,aX=this.length;a0<aX;a0++){var aU=a.data(this[a0],"olddisplay");this[a0].style.display=aU||"";if(a.css(this[a0],"display")==="none"){var a2=this[a0].nodeName,a1;if(E[a2]){a1=E[a2]}else{var aW=a("<"+a2+" />").appendTo("body");a1=aW.css("display");if(a1==="none"){a1="block"}aW.remove();E[a2]=a1}a.data(this[a0],"olddisplay",a1)}}for(var aZ=0,aY=this.length;aZ<aY;aZ++){this[aZ].style.display=a.data(this[aZ],"olddisplay")||""}return this}},hide:function(aZ,a0){if(aZ||aZ===0){return this.animate(az("hide",3),aZ,a0)}else{for(var aY=0,aV=this.length;aY<aV;aY++){var aU=a.data(this[aY],"olddisplay");if(!aU&&aU!=="none"){a.data(this[aY],"olddisplay",a.css(this[aY],"display"))}}for(var aX=0,aW=this.length;aX<aW;aX++){this[aX].style.display="none"}return this}},_toggle:a.fn.toggle,toggle:function(aW,aV){var aU=typeof aW==="boolean";if(a.isFunction(aW)&&a.isFunction(aV)){this._toggle.apply(this,arguments)}else{if(aW==null||aU){this.each(function(){var aX=aU?aW:a(this).is(":hidden");a(this)[aX?"show":"hide"]()})}else{this.animate(az("toggle",3),aW,aV)}}return this},fadeTo:function(aU,aW,aV){return this.filter(":hidden").css("opacity",0).show().end().animate({opacity:aW},aU,aV)},animate:function(aY,aV,aX,aW){var aU=a.speed(aV,aX,aW);if(a.isEmptyObject(aY)){return this.each(aU.complete)}return this[aU.queue===false?"each":"queue"](function(){var a1=a.extend({},aU),a3,a2=this.nodeType===1&&a(this).is(":hidden"),aZ=this;for(a3 in aY){var a0=a3.replace(aw,k);if(a3!==a0){aY[a0]=aY[a3];delete aY[a3];a3=a0}if(aY[a3]==="hide"&&a2||aY[a3]==="show"&&!a2){return a1.complete.call(this)}if((a3==="height"||a3==="width")&&this.style){a1.display=a.css(this,"display");a1.overflow=this.style.overflow}if(a.isArray(aY[a3])){(a1.specialEasing=a1.specialEasing||{})[a3]=aY[a3][1];aY[a3]=aY[a3][0]}}if(a1.overflow!=null){this.style.overflow="hidden"}a1.curAnim=a.extend({},aY);a.each(aY,function(a5,a9){var a8=new a.fx(aZ,a1,a5);if(ad.test(a9)){a8[a9==="toggle"?a2?"show":"hide":a9](aY)}else{var a7=ar.exec(a9),ba=a8.cur(true)||0;if(a7){var a4=parseFloat(a7[2]),a6=a7[3]||"px";if(a6!=="px"){aZ.style[a5]=(a4||1)+a6;ba=((a4||1)/a8.cur(true))*ba;aZ.style[a5]=ba+a6}if(a7[1]){a4=((a7[1]==="-="?-1:1)*a4)+ba}a8.custom(ba,a4,a6)}else{a8.custom(ba,a9,"")}}});return true})},stop:function(aV,aU){var aW=a.timers;if(aV){this.queue([])}this.each(function(){for(var aX=aW.length-1;aX>=0;aX--){if(aW[aX].elem===this){if(aU){aW[aX](true)}aW.splice(aX,1)}}});if(!aU){this.dequeue()}return this}});a.each({slideDown:az("show",1),slideUp:az("hide",1),slideToggle:az("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(aU,aV){a.fn[aU]=function(aW,aX){return this.animate(aV,aW,aX)}});a.extend({speed:function(aW,aX,aV){var aU=aW&&typeof aW==="object"?aW:{complete:aV||!aV&&aX||a.isFunction(aW)&&aW,duration:aW,easing:aV&&aX||aX&&!a.isFunction(aX)&&aX};aU.duration=a.fx.off?0:typeof aU.duration==="number"?aU.duration:a.fx.speeds[aU.duration]||a.fx.speeds._default;aU.old=aU.complete;aU.complete=function(){if(aU.queue!==false){a(this).dequeue()}if(a.isFunction(aU.old)){aU.old.call(this)}};return aU},easing:{linear:function(aW,aX,aU,aV){return aU+aV*aW},swing:function(aW,aX,aU,aV){return((-Math.cos(aW*Math.PI)/2)+0.5)*aV+aU}},timers:[],fx:function(aV,aU,aW){this.options=aU;this.elem=aV;this.prop=aW;if(!aU.orig){aU.orig={}}}});a.fx.prototype={update:function(){if(this.options.step){this.options.step.call(this.elem,this.now,this)}(a.fx.step[this.prop]||a.fx.step._default)(this);if((this.prop==="height"||this.prop==="width")&&this.elem.style){this.elem.style.display="block"}},cur:function(aV){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null)){return this.elem[this.prop]}var aU=parseFloat(a.css(this.elem,this.prop,aV));return aU&&aU>-10000?aU:parseFloat(a.curCSS(this.elem,this.prop))||0},custom:function(aY,aX,aW){this.startTime=aL();this.start=aY;this.end=aX;this.unit=aW||this.unit||"px";this.now=this.start;this.pos=this.state=0;var aU=this;function aV(aZ){return aU.step(aZ)}aV.elem=this.elem;if(aV()&&a.timers.push(aV)&&!aB){aB=setInterval(a.fx.tick,13)}},show:function(){this.options.orig[this.prop]=a.style(this.elem,this.prop);this.options.show=true;this.custom(this.prop==="width"||this.prop==="height"?1:0,this.cur());a(this.elem).show()},hide:function(){this.options.orig[this.prop]=a.style(this.elem,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(aX){var a2=aL(),aY=true;if(aX||a2>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;for(var aZ in this.options.curAnim){if(this.options.curAnim[aZ]!==true){aY=false}}if(aY){if(this.options.display!=null){this.elem.style.overflow=this.options.overflow;var aW=a.data(this.elem,"olddisplay");this.elem.style.display=aW?aW:this.options.display;if(a.css(this.elem,"display")==="none"){this.elem.style.display="block"}}if(this.options.hide){a(this.elem).hide()}if(this.options.hide||this.options.show){for(var aU in this.options.curAnim){a.style(this.elem,aU,this.options.orig[aU])}}this.options.complete.call(this.elem)}return false}else{var aV=a2-this.startTime;this.state=aV/this.options.duration;var a0=this.options.specialEasing&&this.options.specialEasing[this.prop];var a1=this.options.easing||(a.easing.swing?"swing":"linear");this.pos=a.easing[a0||a1](this.state,aV,0,1,this.options.duration);this.now=this.start+((this.end-this.start)*this.pos);this.update()}return true}};a.extend(a.fx,{tick:function(){var aV=a.timers;for(var aU=0;aU<aV.length;aU++){if(!aV[aU]()){aV.splice(aU--,1)}}if(!aV.length){a.fx.stop()}},stop:function(){clearInterval(aB);aB=null},speeds:{slow:600,fast:200,_default:400},step:{opacity:function(aU){a.style(aU.elem,"opacity",aU.now)},_default:function(aU){if(aU.elem.style&&aU.elem.style[aU.prop]!=null){aU.elem.style[aU.prop]=(aU.prop==="width"||aU.prop==="height"?Math.max(0,aU.now):aU.now)+aU.unit}else{aU.elem[aU.prop]=aU.now}}}});if(a.expr&&a.expr.filters){a.expr.filters.animated=function(aU){return a.grep(a.timers,function(aV){return aU===aV.elem}).length}}function az(aV,aU){var aW={};a.each(ah.concat.apply([],ah.slice(0,aU)),function(){aW[this]=aV});return aW}if("getBoundingClientRect" in aa.documentElement){a.fn.offset=function(a3){var aW=this[0];if(a3){return this.each(function(a4){a.offset.setOffset(this,a3,a4)})}if(!aW||!aW.ownerDocument){return null}if(aW===aW.ownerDocument.body){return a.offset.bodyOffset(aW)}var aY=aW.getBoundingClientRect(),a2=aW.ownerDocument,aZ=a2.body,aU=a2.documentElement,aX=aU.clientTop||aZ.clientTop||0,a0=aU.clientLeft||aZ.clientLeft||0,a1=aY.top+(self.pageYOffset||a.support.boxModel&&aU.scrollTop||aZ.scrollTop)-aX,aV=aY.left+(self.pageXOffset||a.support.boxModel&&aU.scrollLeft||aZ.scrollLeft)-a0;return{top:a1,left:aV}}}else{a.fn.offset=function(a5){var aZ=this[0];if(a5){return this.each(function(a6){a.offset.setOffset(this,a5,a6)})}if(!aZ||!aZ.ownerDocument){return null}if(aZ===aZ.ownerDocument.body){return a.offset.bodyOffset(aZ)}a.offset.initialize();var aW=aZ.offsetParent,aV=aZ,a4=aZ.ownerDocument,a2,aX=a4.documentElement,a0=a4.body,a1=a4.defaultView,aU=a1?a1.getComputedStyle(aZ,null):aZ.currentStyle,a3=aZ.offsetTop,aY=aZ.offsetLeft;while((aZ=aZ.parentNode)&&aZ!==a0&&aZ!==aX){if(a.offset.supportsFixedPosition&&aU.position==="fixed"){break}a2=a1?a1.getComputedStyle(aZ,null):aZ.currentStyle;a3-=aZ.scrollTop;aY-=aZ.scrollLeft;if(aZ===aW){a3+=aZ.offsetTop;aY+=aZ.offsetLeft;if(a.offset.doesNotAddBorder&&!(a.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(aZ.nodeName))){a3+=parseFloat(a2.borderTopWidth)||0;aY+=parseFloat(a2.borderLeftWidth)||0}aV=aW,aW=aZ.offsetParent}if(a.offset.subtractsBorderForOverflowNotVisible&&a2.overflow!=="visible"){a3+=parseFloat(a2.borderTopWidth)||0;aY+=parseFloat(a2.borderLeftWidth)||0}aU=a2}if(aU.position==="relative"||aU.position==="static"){a3+=a0.offsetTop;aY+=a0.offsetLeft}if(a.offset.supportsFixedPosition&&aU.position==="fixed"){a3+=Math.max(aX.scrollTop,a0.scrollTop);aY+=Math.max(aX.scrollLeft,a0.scrollLeft)}return{top:a3,left:aY}}}a.offset={initialize:function(){var aU=aa.body,aV=aa.createElement("div"),aY,a0,aZ,a1,aW=parseFloat(a.curCSS(aU,"marginTop",true))||0,aX="<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>";a.extend(aV.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"});aV.innerHTML=aX;aU.insertBefore(aV,aU.firstChild);aY=aV.firstChild;a0=aY.firstChild;a1=aY.nextSibling.firstChild.firstChild;this.doesNotAddBorder=(a0.offsetTop!==5);this.doesAddBorderForTableAndCells=(a1.offsetTop===5);a0.style.position="fixed",a0.style.top="20px";this.supportsFixedPosition=(a0.offsetTop===20||a0.offsetTop===15);a0.style.position=a0.style.top="";aY.style.overflow="hidden",aY.style.position="relative";this.subtractsBorderForOverflowNotVisible=(a0.offsetTop===-5);this.doesNotIncludeMarginInBodyOffset=(aU.offsetTop!==aW);aU.removeChild(aV);aU=aV=aY=a0=aZ=a1=null;a.offset.initialize=a.noop},bodyOffset:function(aU){var aW=aU.offsetTop,aV=aU.offsetLeft;a.offset.initialize();if(a.offset.doesNotIncludeMarginInBodyOffset){aW+=parseFloat(a.curCSS(aU,"marginTop",true))||0;aV+=parseFloat(a.curCSS(aU,"marginLeft",true))||0}return{top:aW,left:aV}},setOffset:function(aZ,aV,aW){if(/static/.test(a.curCSS(aZ,"position"))){aZ.style.position="relative"}var aY=a(aZ),a1=aY.offset(),aU=parseInt(a.curCSS(aZ,"top",true),10)||0,a0=parseInt(a.curCSS(aZ,"left",true),10)||0;if(a.isFunction(aV)){aV=aV.call(aZ,aW,a1)}var aX={top:(aV.top-a1.top)+aU,left:(aV.left-a1.left)+a0};if("using" in aV){aV.using.call(aZ,aX)}else{aY.css(aX)}}};a.fn.extend({position:function(){if(!this[0]){return null}var aW=this[0],aV=this.offsetParent(),aX=this.offset(),aU=/^body|html$/i.test(aV[0].nodeName)?{top:0,left:0}:aV.offset();aX.top-=parseFloat(a.curCSS(aW,"marginTop",true))||0;aX.left-=parseFloat(a.curCSS(aW,"marginLeft",true))||0;aU.top+=parseFloat(a.curCSS(aV[0],"borderTopWidth",true))||0;aU.left+=parseFloat(a.curCSS(aV[0],"borderLeftWidth",true))||0;return{top:aX.top-aU.top,left:aX.left-aU.left}},offsetParent:function(){return this.map(function(){var aU=this.offsetParent||aa.body;while(aU&&(!/^body|html$/i.test(aU.nodeName)&&a.css(aU,"position")==="static")){aU=aU.offsetParent}return aU})}});a.each(["Left","Top"],function(aV,aU){var aW="scroll"+aU;a.fn[aW]=function(aZ){var aX=this[0],aY;if(!aX){return null}if(aZ!==B){return this.each(function(){aY=ak(this);if(aY){aY.scrollTo(!aV?aZ:a(aY).scrollLeft(),aV?aZ:a(aY).scrollTop())}else{this[aW]=aZ}})}else{aY=ak(aX);return aY?("pageXOffset" in aY)?aY[aV?"pageYOffset":"pageXOffset"]:a.support.boxModel&&aY.document.documentElement[aW]||aY.document.body[aW]:aX[aW]}}});function ak(aU){return("scrollTo" in aU&&aU.document)?aU:aU.nodeType===9?aU.defaultView||aU.parentWindow:false}a.each(["Height","Width"],function(aV,aU){var aW=aU.toLowerCase();a.fn["inner"+aU]=function(){return this[0]?a.css(this[0],aW,false,"padding"):null};a.fn["outer"+aU]=function(aX){return this[0]?a.css(this[0],aW,false,aX?"margin":"border"):null};a.fn[aW]=function(aX){var aY=this[0];if(!aY){return aX==null?null:this}if(a.isFunction(aX)){return this.each(function(a0){var aZ=a(this);aZ[aW](aX.call(this,a0,aZ[aW]()))})}return("scrollTo" in aY&&aY.document)?aY.document.compatMode==="CSS1Compat"&&aY.document.documentElement["client"+aU]||aY.document.body["client"+aU]:(aY.nodeType===9)?Math.max(aY.documentElement["client"+aU],aY.body["scroll"+aU],aY.documentElement["scroll"+aU],aY.body["offset"+aU],aY.documentElement["offset"+aU]):aX===B?a.css(aY,aW):this.css(aW,typeof aX==="string"?aX:aX+"px")}});aI.jQuery=aI.$=a})(window);window.djdt=(function(b,a,e){e.cookie=function(h,p,s){if(typeof p!="undefined"){s=s||{};if(p===null){p="";s.expires=-1}var l="";if(s.expires&&(typeof s.expires=="number"||s.expires.toUTCString)){var m;if(typeof s.expires=="number"){m=new Date();m.setTime(m.getTime()+(s.expires*24*60*60*1000))}else{m=s.expires}l="; expires="+m.toUTCString()}var r=s.path?"; path="+(s.path):"";var n=s.domain?"; domain="+(s.domain):"";var g=s.secure?"; secure":"";a.cookie=[h,"=",encodeURIComponent(p),l,r,n,g].join("")}else{var k=null;if(a.cookie&&a.cookie!=""){var q=a.cookie.split(";");for(var o=0;o<q.length;o++){var j=c.trim(q[o]);if(j.substring(0,h.length+1)==(h+"=")){k=decodeURIComponent(j.substring(h.length+1));break}}}return k}};var c=e;var f="djdt";var d={jQuery:e,events:{ready:[]},isReady:false,init:function(){c("#djDebug").show();var i=null;c("#djDebugPanelList li a").click(function(){if(!this.className){return false}i=c("#djDebug #"+this.className);if(i.is(":visible")){c(a).trigger("close.djDebug");c(this).parent().removeClass("active")}else{c(".panelContent").hide();i.show();c("#djDebugToolbar li").removeClass("active");c(this).parent().addClass("active")}return false});c("#djDebug a.djDebugClose").click(function(){c(a).trigger("close.djDebug");c("#djDebugToolbar li").removeClass("active");return false});c("#djDebug a.remoteCall").click(function(){c("#djDebugWindow").load(this.href,function(k,j,m){if(j=="error"){var l='<div class="djDebugPanelTitle"><a class="djDebugClose djDebugBack" href="">Back</a><h3>'+m.status+": "+m.statusText+"</h3></div>";c("#djDebugWindow").html(l)}c("#djDebugWindow a.djDebugBack").click(function(){c(this).parent().parent().hide();return false})});c("#djDebugWindow").show();return false});c("#djDebugTemplatePanel a.djTemplateShowContext").click(function(){d.toggle_arrow(c(this).children(".toggleArrow"));d.toggle_content(c(this).parent().next());return false});c("#djDebug a.djToggleSwitch").click(function(l){l.preventDefault();var j=c(this);var m=j.attr("data-toggle-id");var k=j.text()==j.attr("data-toggle-open");if(m==""||!m){return}c(this).parents(".djDebugPanelContent").find(".djToggleDetails_"+m).each(function(){var n=c(this);if(k){n.addClass("djSelected");n.removeClass("djUnselected");j.text(j.attr("data-toggle-close"));n.find(".djToggleSwitch").text(j.text())}else{n.removeClass("djSelected");n.addClass("djUnselected");j.text(j.attr("data-toggle-open"));n.find(".djToggleSwitch").text(j.text())}});return});function g(j){id=j.attr("id");return c('.djDebugProfileRow[id^="'+id+'_"]')}function h(j){subcalls=g(j);depth=parseInt(j.attr("depth"))+1;return subcalls.filter("[depth="+depth+"]")}c(".djDebugProfileRow .djDebugProfileToggle").click(function(){row=c(this).closest(".djDebugProfileRow");subcalls=g(row);if(subcalls.css("display")=="none"){h(row).show()}else{subcalls.hide()}});c("#djHideToolBarButton").click(function(){d.hide_toolbar(true);return false});c("#djShowToolBarButton").click(function(){d.show_toolbar();return false});c(a).bind("close.djDebug",function(){if(c("#djDebugWindow").is(":visible")){c("#djDebugWindow").hide();return}if(c(".panelContent").is(":visible")){c(".panelContent").hide();return}if(c("#djDebugToolbar").is(":visible")){d.hide_toolbar(true);return}});if(c.cookie(f)){d.hide_toolbar(false)}else{d.show_toolbar(false)}c("#djDebug .djDebugHoverable").hover(function(){c(this).addClass("djDebugHover")},function(){c(this).removeClass("djDebugHover")});d.isReady=true;c.each(d.events.ready,function(j,k){k(d)})},toggle_content:function(g){if(g.is(":visible")){g.hide()}else{g.show()}},close:function(){c(a).trigger("close.djDebug");return false},hide_toolbar:function(g){c("#djDebugWindow").hide();c(".panelContent").hide();c("#djDebugToolbar li").removeClass("active");c("#djDebugToolbar").hide("fast");c("#djDebugToolbarHandle").show();c(a).unbind("keydown.djDebug");if(g){c.cookie(f,"hide",{path:"/",expires:10})}},show_toolbar:function(g){c(a).bind("keydown.djDebug",function(h){if(h.keyCode==27){d.close()}});c("#djDebugToolbarHandle").hide();if(g){c("#djDebugToolbar").show("fast")}else{c("#djDebugToolbar").show()}c.cookie(f,null,{path:"/",expires:-1})},toggle_arrow:function(h){var g=String.fromCharCode(9654);var i=String.fromCharCode(9660);h.html(h.html()==g?i:g)},ready:function(g){if(d.isReady){g(d)}else{d.events.ready.push(g)}}};c(a).ready(function(){d.init()});return d}(window,document,jQuery.noConflict()));
\ No newline at end of file diff --git a/debug_toolbar/middleware.py b/debug_toolbar/middleware.py index 0931389..b4619da 100644 --- a/debug_toolbar/middleware.py +++ b/debug_toolbar/middleware.py @@ -1,7 +1,7 @@  """  Debug Toolbar middleware  """ -import os +import thread  from django.conf import settings  from django.http import HttpResponseRedirect @@ -31,8 +31,13 @@ class DebugToolbarMiddleware(object):      Middleware to set up Debug Toolbar on incoming request and render toolbar      on outgoing response.      """ +    debug_toolbars = {} +     +    @classmethod +    def get_current(cls): +        return cls.debug_toolbars.get(thread.get_ident()) +      def __init__(self): -        self.debug_toolbars = {}          self.override_url = True          # Set method to use to decide to show toolbar @@ -60,33 +65,42 @@ class DebugToolbarMiddleware(object):          if not remote_addr in settings.INTERNAL_IPS \              or (request.is_ajax() and \                  not debug_toolbar.urls._PREFIX in request.path) \ -                    or not settings.DEBUG: +                    or not (settings.DEBUG or getattr(settings, 'TEST', False)):              return False          return True      def process_request(self, request):          if self.show_toolbar(request):              if self.override_url: -                original_urlconf = getattr(request, 'urlconf', settings.ROOT_URLCONF) +                original_urlconf = __import__(getattr(request, 'urlconf', settings.ROOT_URLCONF), {}, {}, ['*'])                  debug_toolbar.urls.urlpatterns += patterns('',                      ('', include(original_urlconf)),                  ) +                if hasattr(original_urlconf, 'handler404'): +                    debug_toolbar.urls.handler404 = original_urlconf.handler404 +                if hasattr(original_urlconf, 'handler500'): +                    debug_toolbar.urls.handler500 = original_urlconf.handler500                  self.override_url = False              request.urlconf = 'debug_toolbar.urls' -            self.debug_toolbars[request] = DebugToolbar(request) -            for panel in self.debug_toolbars[request].panels: +            toolbar = DebugToolbar(request) +            for panel in toolbar.panels:                  panel.process_request(request) +            self.__class__.debug_toolbars[thread.get_ident()] = toolbar      def process_view(self, request, view_func, view_args, view_kwargs): -        if request in self.debug_toolbars: -            for panel in self.debug_toolbars[request].panels: -                panel.process_view(request, view_func, view_args, view_kwargs) +        toolbar = self.__class__.debug_toolbars.get(thread.get_ident()) +        if not toolbar: +            return +        for panel in toolbar.panels: +            panel.process_view(request, view_func, view_args, view_kwargs)      def process_response(self, request, response): -        if request not in self.debug_toolbars: +        ident = thread.get_ident() +        toolbar = self.__class__.debug_toolbars.get(ident) +        if not toolbar:              return response -        if self.debug_toolbars[request].config['INTERCEPT_REDIRECTS']: +        if toolbar.config['INTERCEPT_REDIRECTS']:              if isinstance(response, HttpResponseRedirect):                  redirect_to = response.get('Location', None)                  if redirect_to: @@ -96,15 +110,15 @@ class DebugToolbarMiddleware(object):                          {'redirect_to': redirect_to}                      )                      response.cookies = cookies -        if response.status_code == 200: -            for panel in self.debug_toolbars[request].panels: +        if response.status_code == 200 and 'gzip' not in response.get('Content-Encoding', '') and \ +           response.get('Content-Type', '').split(';')[0] in _HTML_TYPES: +            for panel in toolbar.panels:                  panel.process_response(request, response) -            if response.get('Content-Type', None) and response['Content-Type'].split(';')[0] in _HTML_TYPES: -                response.content = replace_insensitive( -                    smart_unicode(response.content),  -                    self.tag, -                    smart_unicode(self.debug_toolbars[request].render_toolbar() + self.tag)) +            response.content = replace_insensitive( +                smart_unicode(response.content),  +                self.tag, +                smart_unicode(toolbar.render_toolbar() + self.tag))              if response.get('Content-Length', None):                  response['Content-Length'] = len(response.content) -        del self.debug_toolbars[request] +        del self.__class__.debug_toolbars[ident]          return response diff --git a/debug_toolbar/panels/logger.py b/debug_toolbar/panels/logger.py index 620102e..5e82a13 100644 --- a/debug_toolbar/panels/logger.py +++ b/debug_toolbar/panels/logger.py @@ -8,16 +8,21 @@ from django.template.loader import render_to_string  from django.utils.translation import ugettext_lazy as _  from debug_toolbar.panels import DebugPanel -class ThreadTrackingHandler(logging.Handler): + +class LogCollector(object):      def __init__(self):          if threading is None:              raise NotImplementedError("threading module is not available, \                  the logging panel cannot be used without it") -        logging.Handler.__init__(self)          self.records = {} # a dictionary that maps threads to log records -    def emit(self, record): -        self.get_records().append(record) +    def add_record(self, record, thread=None): +        # Avoid logging SQL queries since they are already in the SQL panel +        # TODO: Make this check whether SQL panel is enabled +        if record.get('channel', '') == 'django.db.backends': +            return + +        self.get_records(thread).append(record)      def get_records(self, thread=None):          """ @@ -36,20 +41,67 @@ class ThreadTrackingHandler(logging.Handler):          if thread in self.records:              del self.records[thread] -handler = ThreadTrackingHandler() + +class ThreadTrackingHandler(logging.Handler): +    def __init__(self, collector): +        logging.Handler.__init__(self) +        self.collector = collector + +    def emit(self, record): +        record = { +            'message': record.getMessage(), +            'time': datetime.datetime.fromtimestamp(record.created), +            'level': record.levelname, +            'file': record.pathname, +            'line': record.lineno, +            'channel': record.name, +        } +        self.collector.add_record(record) + + +collector = LogCollector() +logging_handler = ThreadTrackingHandler(collector)  logging.root.setLevel(logging.NOTSET) -logging.root.addHandler(handler) +logging.root.addHandler(logging_handler)  # register with logging + +try: +    import logbook +    logbook_supported = True +except ImportError: +    # logbook support is optional, so fail silently +    logbook_supported = False + +if logbook_supported: +    class LogbookThreadTrackingHandler(logbook.handlers.Handler): +        def __init__(self, collector): +            logbook.handlers.Handler.__init__(self, bubble=True) +            self.collector = collector + +        def emit(self, record): +            record = { +                'message': record.message, +                'time': record.time, +                'level': record.level_name, +                'file': record.filename, +                'line': record.lineno, +                'channel': record.channel, +            } +            self.collector.add_record(record) + + +    logbook_handler = LogbookThreadTrackingHandler(collector) +    logbook_handler.push_application()        # register with logbook  class LoggingPanel(DebugPanel):      name = 'Logging'      has_content = True      def process_request(self, request): -        handler.clear_records() +        collector.clear_records()      def get_and_delete(self): -        records = handler.get_records() -        handler.clear_records() +        records = collector.get_records() +        collector.clear_records()          return records      def nav_title(self): @@ -57,7 +109,7 @@ class LoggingPanel(DebugPanel):      def nav_subtitle(self):          # FIXME l10n: use ngettext -        return "%s message%s" % (len(handler.get_records()), (len(handler.get_records()) == 1) and '' or 's') +        return "%s message%s" % (len(collector.get_records()), (len(collector.get_records()) == 1) and '' or 's')      def title(self):          return _('Log Messages') @@ -66,16 +118,7 @@ class LoggingPanel(DebugPanel):          return ''      def content(self): -        records = [] -        for record in self.get_and_delete(): -            records.append({ -                'message': record.getMessage(), -                'time': datetime.datetime.fromtimestamp(record.created), -                'level': record.levelname, -                'file': record.pathname, -                'line': record.lineno, -            }) - +        records = self.get_and_delete()          context = self.context.copy()          context.update({'records': records}) diff --git a/debug_toolbar/panels/profiling.py b/debug_toolbar/panels/profiling.py new file mode 100644 index 0000000..68aafb7 --- /dev/null +++ b/debug_toolbar/panels/profiling.py @@ -0,0 +1,169 @@ +from __future__ import division + +from django.template.loader import render_to_string +from django.utils.translation import ugettext_lazy as _ +from django.utils.safestring import mark_safe +from debug_toolbar.panels import DebugPanel + +import cProfile +from pstats import Stats +from colorsys import hsv_to_rgb + +class DjangoDebugToolbarStats(Stats): +    __root = None +     +    def get_root_func(self): +        if self.__root is None: +            for func, (cc, nc, tt, ct, callers) in self.stats.iteritems(): +                if len(callers) == 0: +                    self.__root = func +                    break +        return self.__root +     +    def print_call_tree_node(self, function, depth, max_depth, cum_filter=0.1): +        self.print_line(function, depth=depth) +        if depth < max_depth: +            for called in self.all_callees[function].keys(): +                if self.stats[called][3] >= cum_filter: +                    self.print_call_tree_node(called, depth+1, max_depth, cum_filter=cum_filter) + +class FunctionCall(object): +    def __init__(self, statobj, func, depth=0, stats=None, id=0, parent_ids=[], hsv=(0,0.5,1)): +        self.statobj = statobj +        self.func = func +        if stats: +            self.stats = stats +        else: +            self.stats = statobj.stats[func][:4] +        self.depth = depth +        self.id = id +        self.parent_ids = parent_ids +        self.hsv = hsv +     +    def parent_classes(self): +        return self.parent_classes +     +    def background(self): +        r,g,b = hsv_to_rgb(*self.hsv) +        return 'rgb(%f%%,%f%%,%f%%)' %(r*100, g*100, b*100) +     +    def func_std_string(self): # match what old profile produced +        func_name = self.func +        if func_name[:2] == ('~', 0): +            # special case for built-in functions +            name = func_name[2] +            if name.startswith('<') and name.endswith('>'): +                return '{%s}' % name[1:-1] +            else: +                return name +        else: +            file_name, line_num, method = self.func +            idx = file_name.find('/site-packages/') +            if idx > -1: +                file_name=file_name[idx+14:] +             +            file_path, file_name = file_name.rsplit('/', 1) +             +            return mark_safe('<span class="path">{0}/</span><span class="file">{1}</span> in <span class="func">{3}</span>(<span class="lineno">{2}</span>)'.format( +                file_path, +                file_name, +                line_num, +                method, +            )) +     +    def subfuncs(self): +        i=0 +        h,s,v = self.hsv +        count = len(self.statobj.all_callees[self.func]) +        for func, stats in self.statobj.all_callees[self.func].iteritems(): +            i += 1 +            h1 = h + (i/count)/(self.depth+1) +            if stats[3] == 0: +                s1 = 0 +            else: +                s1 = s*(stats[3]/self.stats[3]) +            yield FunctionCall(self.statobj, +                               func,  +                               self.depth+1,  +                               stats=stats, +                               id=str(self.id) + '_' + str(i), +                               parent_ids=self.parent_ids + [self.id], +                               hsv=(h1,s1,1)) +     +    def count(self): +        return self.stats[1] +     +    def tottime(self): +        return self.stats[2] +     +    def cumtime(self): +        cc, nc, tt, ct = self.stats +        return self.stats[3] +     +    def tottime_per_call(self): +        cc, nc, tt, ct = self.stats + +        if nc == 0: +            return 0 + +        return tt/nc +     +    def cumtime_per_call(self): +        cc, nc, tt, ct = self.stats + +        if cc == 0: +            return 0 + +        return ct/cc + +    def indent(self): +        return 16 * self.depth + +class ProfilingDebugPanel(DebugPanel): +    """ +    Panel that displays the Django version. +    """ +    name = 'Profiling' +    has_content = True + +    def nav_title(self): +        return _('Profiling') + +    def url(self): +        return '' +     +    def title(self): +        return _('Profiling') + +    def process_view(self, request, view_func, view_args, view_kwargs): +        self.profiler = cProfile.Profile() +        args = (request,) + view_args +        return self.profiler.runcall(view_func, *args, **view_kwargs) + +    def process_response(self, request, response): +        self.profiler.create_stats() +        self.stats = DjangoDebugToolbarStats(self.profiler) +        return response + +    def add_node(self, func_list, func, max_depth, cum_time=0.1): +        func_list.append(func) +        func.has_subfuncs = False +        if func.depth < max_depth: +            for subfunc in func.subfuncs(): +                if subfunc.stats[3] >= cum_time: +                    func.has_subfuncs = True +                    self.add_node(func_list, subfunc, max_depth, cum_time=cum_time) +     +    def content(self): +         +        self.stats.calc_callees() +        root = FunctionCall(self.stats, self.stats.get_root_func(), depth=0) +         +        func_list = [] +        self.add_node(func_list, root, 10, root.stats[3]/8) +        context = self.context.copy() +        context.update({ +            'func_list': func_list, +        }) + +        return render_to_string('debug_toolbar/panels/profiling.html', context) diff --git a/debug_toolbar/panels/sql.py b/debug_toolbar/panels/sql.py index e1e9bdf..ff63b6f 100644 --- a/debug_toolbar/panels/sql.py +++ b/debug_toolbar/panels/sql.py @@ -1,133 +1,60 @@ -from datetime import datetime -import os -import sys -import SocketServer -import traceback - -import django -from django.conf import settings -from django.db import connection -from django.db.backends import util -from django.views.debug import linebreak_iter -from django.template import Node +import re +import uuid + +from django.db.backends import BaseDatabaseWrapper  from django.template.loader import render_to_string -from django.utils import simplejson -from django.utils.encoding import force_unicode -from django.utils.hashcompat import sha_constructor -from django.utils.translation import ugettext_lazy as _ +from django.utils.html import escape +from django.utils.safestring import mark_safe +from django.utils.translation import ugettext_lazy as _, ungettext_lazy as __ +from debug_toolbar.utils.compat.db import connections +from debug_toolbar.middleware import DebugToolbarMiddleware  from debug_toolbar.panels import DebugPanel  from debug_toolbar.utils import sqlparse - -# Figure out some paths -django_path = os.path.realpath(os.path.dirname(django.__file__)) -socketserver_path = os.path.realpath(os.path.dirname(SocketServer.__file__)) - -# TODO:This should be set in the toolbar loader as a default and panels should -# get a copy of the toolbar object with access to its config dictionary -SQL_WARNING_THRESHOLD = getattr(settings, 'DEBUG_TOOLBAR_CONFIG', {}) \ -                            .get('SQL_WARNING_THRESHOLD', 500) - -def tidy_stacktrace(strace): -    """ -    Clean up stacktrace and remove all entries that: -    1. Are part of Django (except contrib apps) -    2. Are part of SocketServer (used by Django's dev server) -    3. Are the last entry (which is part of our stacktracing code) -    """ -    trace = [] -    for s in strace[:-1]: -        s_path = os.path.realpath(s[0]) -        if getattr(settings, 'DEBUG_TOOLBAR_CONFIG', {}).get('HIDE_DJANGO_SQL', True) \ -            and django_path in s_path and not 'django/contrib' in s_path: -            continue -        if socketserver_path in s_path: -            continue -        trace.append((s[0], s[1], s[2], s[3])) -    return trace - -def get_template_info(source, context_lines=3): -    line = 0 -    upto = 0 -    source_lines = [] -    before = during = after = "" - -    origin, (start, end) = source -    template_source = origin.reload() - -    for num, next in enumerate(linebreak_iter(template_source)): -        if start >= upto and end <= next: -            line = num -            before = template_source[upto:start] -            during = template_source[start:end] -            after = template_source[end:next] -        source_lines.append((num, template_source[upto:next])) -        upto = next - -    top = max(1, line - context_lines) -    bottom = min(len(source_lines), line + 1 + context_lines) - -    context = [] -    for num, content in source_lines[top:bottom]: -        context.append({ -            'num': num, -            'content': content, -            'highlight': (num == line), -        }) - -    return { -        'name': origin.name, -        'context': context, -    } - -class DatabaseStatTracker(util.CursorDebugWrapper): -    """ -    Replacement for CursorDebugWrapper which stores additional information -    in `connection.queries`. -    """ -    def execute(self, sql, params=()): -        start = datetime.now() -        try: -            return self.cursor.execute(sql, params) -        finally: -            stop = datetime.now() -            duration = ms_from_timedelta(stop - start) -            stacktrace = tidy_stacktrace(traceback.extract_stack()) -            _params = '' -            try: -                _params = simplejson.dumps([force_unicode(x, strings_only=True) for x in params]) -            except TypeError: -                pass # object not JSON serializable - -            template_info = None -            cur_frame = sys._getframe().f_back -            try: -                while cur_frame is not None: -                    if cur_frame.f_code.co_name == 'render': -                        node = cur_frame.f_locals['self'] -                        if isinstance(node, Node): -                            template_info = get_template_info(node.source) -                            break -                    cur_frame = cur_frame.f_back -            except: -                pass -            del cur_frame - -            # We keep `sql` to maintain backwards compatibility -            self.db.queries.append({ -                'sql': self.db.ops.last_executed_query(self.cursor, sql, params), -                'duration': duration, -                'raw_sql': sql, -                'params': _params, -                'hash': sha_constructor(settings.SECRET_KEY + sql + _params).hexdigest(), -                'stacktrace': stacktrace, -                'start_time': start, -                'stop_time': stop, -                'is_slow': (duration > SQL_WARNING_THRESHOLD), -                'is_select': sql.lower().strip().startswith('select'), -                'template_info': template_info, -            }) -util.CursorDebugWrapper = DatabaseStatTracker +from debug_toolbar.utils.tracking.db import CursorWrapper +from debug_toolbar.utils.tracking import replace_call + +# Inject our tracking cursor +@replace_call(BaseDatabaseWrapper.cursor) +def cursor(func, self): +    result = func(self) + +    djdt = DebugToolbarMiddleware.get_current() +    if not djdt: +        return result +    logger = djdt.get_panel(SQLDebugPanel) +     +    return CursorWrapper(result, self, logger=logger) + +def get_isolation_level_display(engine, level): +    if engine == 'psycopg2': +        import psycopg2.extensions +        choices = { +            psycopg2.extensions.ISOLATION_LEVEL_AUTOCOMMIT: 'Autocommit', +            psycopg2.extensions.ISOLATION_LEVEL_READ_UNCOMMITTED: 'Read uncommitted', +            psycopg2.extensions.ISOLATION_LEVEL_READ_COMMITTED: 'Read committed', +            psycopg2.extensions.ISOLATION_LEVEL_REPEATABLE_READ: 'Repeatable read', +            psycopg2.extensions.ISOLATION_LEVEL_SERIALIZABLE: 'Serializable', +        } +    else: +        raise ValueError(engine) +     +    return choices.get(level) + +def get_transaction_status_display(engine, level): +    if engine == 'psycopg2': +        import psycopg2.extensions +        choices = { +            psycopg2.extensions.TRANSACTION_STATUS_IDLE: 'Idle', +            psycopg2.extensions.TRANSACTION_STATUS_ACTIVE: 'Active', +            psycopg2.extensions.TRANSACTION_STATUS_INTRANS: 'In transaction', +            psycopg2.extensions.TRANSACTION_STATUS_INERROR: 'In error', +            psycopg2.extensions.TRANSACTION_STATUS_UNKNOWN: 'Unknown', +        } +    else: +        raise ValueError(engine) +     +    return choices.get(level)  class SQLDebugPanel(DebugPanel):      """ @@ -139,56 +66,148 @@ class SQLDebugPanel(DebugPanel):      def __init__(self, *args, **kwargs):          super(self.__class__, self).__init__(*args, **kwargs) -        self._offset = len(connection.queries) +        self._offset = dict((k, len(connections[k].queries)) for k in connections)          self._sql_time = 0 +        self._num_queries = 0          self._queries = [] +        self._databases = {} +        self._transaction_status = {} +        self._transaction_ids = {} +     +    def get_transaction_id(self, alias): +        conn = connections[alias].connection +        if not conn: +            return None + +        engine = conn.__class__.__module__.split('.', 1)[0] +        if engine == 'psycopg2': +            cur_status = conn.get_transaction_status() +        else: +            raise ValueError(engine) + +        last_status = self._transaction_status.get(alias) +        self._transaction_status[alias] = cur_status + +        if not cur_status: +            # No available state +            return None + +        if cur_status != last_status: +            if cur_status: +                self._transaction_ids[alias] = uuid.uuid4().hex +            else: +                self._transaction_ids[alias] = None +         +        return self._transaction_ids[alias] +     +    def record(self, alias, **kwargs): +        self._queries.append((alias, kwargs)) +        if alias not in self._databases: +            self._databases[alias] = { +                'time_spent': kwargs['duration'], +                'num_queries': 1, +            } +        else: +            self._databases[alias]['time_spent'] += kwargs['duration'] +            self._databases[alias]['num_queries'] += 1 +        self._sql_time += kwargs['duration'] +        self._num_queries += 1      def nav_title(self):          return _('SQL')      def nav_subtitle(self): -        self._queries = connection.queries[self._offset:] -        self._sql_time = sum([q['duration'] for q in self._queries]) -        num_queries = len(self._queries)          # TODO l10n: use ngettext          return "%d %s in %.2fms" % ( -            num_queries, -            (num_queries == 1) and 'query' or 'queries', +            self._num_queries, +            (self._num_queries == 1) and 'query' or 'queries',              self._sql_time          )      def title(self): -        return _('SQL Queries') +        count = len(self._databases) +         +        return __('SQL Queries from %(count)d connection', 'SQL Queries from %(count)d connections', count) % dict( +            count=count, +        )      def url(self):          return ''      def content(self): -        width_ratio_tally = 0 -        for query in self._queries: -            query['sql'] = reformat_sql(query['sql']) -            try: -                query['width_ratio'] = (query['duration'] / self._sql_time) * 100 -            except ZeroDivisionError: -                query['width_ratio'] = 0 -            query['start_offset'] = width_ratio_tally -            width_ratio_tally += query['width_ratio'] - +        if self._queries: +            width_ratio_tally = 0 +            colors = [ +                (256, 0, 0), # red +                (0, 256, 0), # blue +                (0, 0, 256), # green +            ] +            factor = int(256.0/(len(self._databases)*2.5)) +            for n, db in enumerate(self._databases.itervalues()): +                rgb = [0, 0, 0] +                color = n % 3 +                rgb[color] = 256 - n/3*factor +                nn = color +                # XXX: pretty sure this is horrible after so many aliases +                while rgb[color] < factor: +                    nc = min(256 - rgb[color], 256) +                    rgb[color] += nc +                    nn += 1 +                    if nn > 2: +                        nn = 0 +                    rgb[nn] = nc +                db['rgb_color'] = rgb +         +            trans_ids = {} +            trans_id = None +            i = 0 +            for alias, query in self._queries: +                trans_id = query.get('trans_id') +                last_trans_id = trans_ids.get(alias) +                 +                if trans_id != last_trans_id: +                    if last_trans_id: +                        self._queries[i-1][1]['ends_trans'] = True +                    trans_ids[alias] = trans_id +                    if trans_id: +                        query['starts_trans'] = True +                if trans_id: +                    query['in_trans'] = True +                 +                query['alias'] = alias +                if 'iso_level' in query: +                    query['iso_level'] = get_isolation_level_display(query['engine'], query['iso_level']) +                if 'trans_status' in query: +                    query['trans_status'] = get_transaction_status_display(query['engine'], query['trans_status']) +                query['sql'] = reformat_sql(query['sql']) +                query['rgb_color'] = self._databases[alias]['rgb_color'] +                try: +                    query['width_ratio'] = (query['duration'] / self._sql_time) * 100 +                except ZeroDivisionError: +                    query['width_ratio'] = 0 +                query['start_offset'] = width_ratio_tally +                query['end_offset'] = query['width_ratio'] + query['start_offset'] +                width_ratio_tally += query['width_ratio'] +             +                stacktrace = [] +                for frame in query['stacktrace']: +                    params = map(escape, frame[0].rsplit('/', 1) + list(frame[1:])) +                    stacktrace.append('<span class="path">{0}/</span><span class="file">{1}</span> in <span class="func">{3}</span>(<span class="lineno">{2}</span>)\n  <span class="code">{4}</span>"'.format(*params)) +                query['stacktrace'] = mark_safe('\n'.join(stacktrace)) +                i += 1 + +            if trans_id: +                self._queries[i-1][1]['ends_trans'] = True +                  context = self.context.copy()          context.update({ -            'queries': self._queries, +            'databases': sorted(self._databases.items(), key=lambda x: -x[1]['time_spent']), +            'queries': [q for a, q in self._queries],              'sql_time': self._sql_time, -            'is_mysql': settings.DATABASE_ENGINE == 'mysql',          })          return render_to_string('debug_toolbar/panels/sql.html', context) -def ms_from_timedelta(td): -    """ -    Given a timedelta object, returns a float representing milliseconds -    """ -    return (td.seconds * 1000) + (td.microseconds / 1000.0) -  class BoldKeywordFilter(sqlparse.filters.Filter):      """sqlparse filter to bold SQL keywords"""      def process(self, stack, stream): @@ -197,12 +216,15 @@ class BoldKeywordFilter(sqlparse.filters.Filter):              is_keyword = token_type in sqlparse.tokens.Keyword              if is_keyword:                  yield sqlparse.tokens.Text, '<strong>' -            yield token_type, django.utils.html.escape(value) +            yield token_type, escape(value)              if is_keyword:                  yield sqlparse.tokens.Text, '</strong>' +def swap_fields(sql): +    return re.sub('SELECT</strong> (.*) <strong>FROM', 'SELECT</strong> <span class="djDebugCollapse">\g<1></span> <strong>FROM', sql) +  def reformat_sql(sql):      stack = sqlparse.engine.FilterStack()      stack.preprocess.append(BoldKeywordFilter()) # add our custom filter      stack.postprocess.append(sqlparse.filters.SerializerUnicode()) # tokens -> strings -    return ''.join(stack.run(sql)) +    return swap_fields(''.join(stack.run(sql))) diff --git a/debug_toolbar/panels/template.py b/debug_toolbar/panels/template.py index d9cd071..44b8b3e 100644 --- a/debug_toolbar/panels/template.py +++ b/debug_toolbar/panels/template.py @@ -3,8 +3,6 @@ from pprint import pformat  from django import http  from django.conf import settings -from django.core.signals import request_started -from django.dispatch import Signal  from django.template.context import get_standard_processors  from django.template.loader import render_to_string  from django.test.signals import template_rendered @@ -56,7 +54,7 @@ class TemplateDebugPanel(DebugPanel):      def title(self):          num_templates = len([t for t in self.templates -            if not t['template'].name.startswith('debug_toolbar/')]) +            if not (t['template'].name and t['template'].name.startswith('debug_toolbar/'))])          return _('Templates (%(num_templates)s rendered)') % {'num_templates': num_templates}      def url(self): @@ -78,7 +76,7 @@ class TemplateDebugPanel(DebugPanel):              # Clean up some info about templates              template = template_data.get('template', None)              # Skip templates that we are generating through the debug toolbar. -            if template.name.startswith('debug_toolbar/'): +            if template.name and template.name.startswith('debug_toolbar/'):                  continue              if template.origin and template.origin.name:                  template.origin_name = template.origin.name diff --git a/debug_toolbar/runtests.py b/debug_toolbar/runtests.py new file mode 100644 index 0000000..f16882a --- /dev/null +++ b/debug_toolbar/runtests.py @@ -0,0 +1,47 @@ +#!/usr/bin/env python +import sys +from os.path import dirname, abspath + +from django.conf import settings + +if not settings.configured: +    settings.configure( +        DATABASE_ENGINE='sqlite3', +        # HACK: this fixes our threaded runserver remote tests +        # DATABASE_NAME='test_sentry', +        # TEST_DATABASE_NAME='test_sentry', +        INSTALLED_APPS=[ +            'django.contrib.auth', +            'django.contrib.admin', +            'django.contrib.contenttypes', +            'django.contrib.sessions', +            'django.contrib.sites', + +            'debug_toolbar', +             +            'debug_toolbar.tests', +        ], +        ROOT_URLCONF='', +        DEBUG=False, +        SITE_ID=1, +    ) +    import djcelery +    djcelery.setup_loader() + +from django.test.simple import run_tests + +def runtests(*test_args): +    if 'south' in settings.INSTALLED_APPS: +        from south.management.commands import patch_for_test_db_setup +        patch_for_test_db_setup() + +    if not test_args: +        test_args = ['debug_toolbar'] +    parent = dirname(abspath(__file__)) +    sys.path.insert(0, parent) +    failures = run_tests(test_args, verbosity=1, interactive=True) +    sys.exit(failures) + + +if __name__ == '__main__': +    runtests(*sys.argv[1:])
\ No newline at end of file diff --git a/debug_toolbar/templates/debug_toolbar/base.html b/debug_toolbar/templates/debug_toolbar/base.html index 0fe64ca..d039ade 100644 --- a/debug_toolbar/templates/debug_toolbar/base.html +++ b/debug_toolbar/templates/debug_toolbar/base.html @@ -1,11 +1,9 @@  {% load i18n %} -<style type="text/css">@media print { #djDebug {display:none;}}</style> -<script type="text/javascript"> -// <![CDATA[ -var DEBUG_TOOLBAR_MEDIA_URL = "{{ DEBUG_TOOLBAR_MEDIA_URL }}"; -// ]]> -</script> -<script type="text/javascript" src="{{ DEBUG_TOOLBAR_MEDIA_URL }}js/toolbar.min.js"></script> +<style type="text/css"> +@media print { #djDebug {display:none;}} +{{ css }} +</style> +<script type="text/javascript">{{ js }}</script>  <div id="djDebug" style="display:none;">  	<div style="display:none;" id="djDebugToolbar">  		<ul id="djDebugPanelList"> @@ -15,7 +13,7 @@ var DEBUG_TOOLBAR_MEDIA_URL = "{{ DEBUG_TOOLBAR_MEDIA_URL }}";  			<li id="djDebugButton">DEBUG</li>  			{% endif %}  			{% for panel in panels %} -				<li> +				<li class="djDebugPanelButton">  					{% if panel.has_content %}  						<a href="{{ panel.url|default:"#" }}" title="{{ panel.title }}" class="{{ panel.dom_id }}">  					{% else %} diff --git a/debug_toolbar/templates/debug_toolbar/panels/logger.html b/debug_toolbar/templates/debug_toolbar/panels/logger.html index 5e8b652..c41749e 100644 --- a/debug_toolbar/templates/debug_toolbar/panels/logger.html +++ b/debug_toolbar/templates/debug_toolbar/panels/logger.html @@ -5,6 +5,7 @@  			<tr>  				<th>{% trans "Level" %}</th>  				<th>{% trans "Time" %}</th> +				<th>{% trans "Channel" %}</th>  				<th>{% trans "Message" %}</th>  				<th>{% trans "Location" %}</th>  			</tr> @@ -14,6 +15,7 @@  				<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}">  					<td>{{ record.level }}</td>  					<td>{{ record.time|date:"h:i:s m/d/Y" }}</td> +					<td>{{ record.channel|default:"-" }}</td>  					<td>{{ record.message }}</td>  					<td>{{ record.file }}:{{ record.line }}</td>  				</tr> diff --git a/debug_toolbar/templates/debug_toolbar/panels/profiling.html b/debug_toolbar/templates/debug_toolbar/panels/profiling.html new file mode 100644 index 0000000..ebc91cc --- /dev/null +++ b/debug_toolbar/templates/debug_toolbar/panels/profiling.html @@ -0,0 +1,36 @@ +{% load i18n %} + +<table width="100%"> +	<thead> +		<tr> +			<th>{% trans "Call" %}</th> +			<th>{% trans "TotTime" %}</th> +			<th>{% trans "Per" %}</th> +			<th>{% trans "CumTime" %}</th> +			<th>{% trans "Per" %}</th> +			<th>{% trans "Count" %}</th> +		</tr> +	</thead> +	<tbody> +		{% for call in func_list %} +			<!--  style="background:{{ call.background }}" --> +			<tr id="{{ call.id }}" class="djDebugProfileRow{% for parent_id in call.parent_ids %} djToggleDetails_{{ parent_id }}{% endfor %}" depth="{{ call.depth }}"> +				<td> +					<div style="padding-left: {{ call.indent }}px;"> +						{% if call.has_subfuncs %} +							<a class="djProfileToggleDetails djToggleSwitch" data-toggle-id="{{ call.id }}" data-toggle-open="+" data-toggle-close="-" href="javascript:void(0)">-</a> +						{% else %} +							<span class="djNoToggleSwitch"></span> +						{% endif %} +						<span class="stack">{{ call.func_std_string }}</span> +					</div> +				</td> +				<td>{{ call.tottime|floatformat:3 }}</td> +				<td>{{ call.tottime_per_call|floatformat:3 }}</td> +				<td>{{ call.cumtime|floatformat:3 }}</td> +				<td>{{ call.cumtime_per_call|floatformat:3 }}</td> +				<td>{{ call.count }}</td> +			</tr> +		{% endfor %} +	</tbody> +</table> diff --git a/debug_toolbar/templates/debug_toolbar/panels/sql.html b/debug_toolbar/templates/debug_toolbar/panels/sql.html index 9ed87ca..f904e15 100644 --- a/debug_toolbar/templates/debug_toolbar/panels/sql.html +++ b/debug_toolbar/templates/debug_toolbar/panels/sql.html @@ -1,69 +1,87 @@  {% load i18n %} -<table> -	<thead> -		<tr> -			<th>{% trans "Time" %} (ms)</th> -			<th>{% trans "Action" %}</th> -			<th>{% trans 'Stacktrace' %}</th> -			<th>{% trans 'Query' %}</th> -		</tr> -	</thead> -	<tbody> -		{% for query in queries %} -			<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> -				<td>{{ query.duration|floatformat:"2" }}</td> -				<td> -				{% if query.params %} -					{% if query.is_select %} -						<a class="remoteCall" href="/__debug__/sql_select/?sql={{ query.raw_sql|urlencode }}&params={{ query.params|urlencode }}&duration={{ query.duration|floatformat:"2"|urlencode }}&hash={{ query.hash }}">SELECT</a><br /> -						<a class="remoteCall" href="/__debug__/sql_explain/?sql={{ query.raw_sql|urlencode }}&params={{ query.params|urlencode }}&duration={{ query.duration|floatformat:"2"|urlencode }}&hash={{ query.hash }}">EXPLAIN</a><br /> -						{% if is_mysql %} -							<a class="remoteCall" href="/__debug__/sql_profile/?sql={{ query.raw_sql|urlencode }}&params={{ query.params|urlencode }}&duration={{ query.duration|floatformat:"2"|urlencode }}&hash={{ query.hash }}">PROFILE</a><br /> +<div class="clearfix"> +	<ul class="stats"> +		{% for alias, info in databases %} +			<li> +				<strong class="label"><span style="background-color: rgb({{ info.rgb_color|join:", " }})" class="color"> </span> {{ alias }}</strong> +				<span class="info">{{ info.time_spent|floatformat:"2" }} ms ({% blocktrans count info.num_queries as num %}{{ num }} query{% plural %}{{ num }} queries{% endblocktrans %})</span> +			</li> +		{% endfor %} +	</ul> +</div> + +{% if queries %} +	<table> +		<thead> +			<tr> +				<th class="color"> </th> +				<th class="query" colspan="2">{% trans 'Query' %}</th> +				<th class="timeline">{% trans 'Timeline' %}</th> +				<th class="time">{% trans 'Time (ms)' %}</th> +				<th class="actions">{% trans "Action" %}</th> +			</tr> +		</thead> +		<tbody> +			{% for query in queries %} +				<tr class="djDebugHoverable {% cycle 'djDebugOdd' 'djDebugEven' %}{% if query.is_slow %} djDebugRowWarning{% endif %}{% if query.starts_trans %} djDebugStartTransaction{% endif %}{% if query.ends_trans %} djDebugEndTransaction{% endif %}{% if query.in_trans %} djDebugInTransaction{% endif %}" id="sqlMain_{{ forloop.counter }}"> +					<td class="color"><span style="background-color: rgb({{ query.rgb_color|join:", " }});"> </span></td> +					<td class="toggle"> +						<a class="djToggleSwitch" data-toggle-id="{{ forloop.counter }}" data-toggle-open="+" data-toggle-close="-" href="javascript:void(0)">+</a> +					</td> +					<td class="query"> +						<div class="djDebugSqlWrap"> +							<div class="djDebugSql">{{ query.sql|safe }}</div> +						</div> +					</td> +					<td class="timeline"> +						<div class="djDebugTimeline"><div class="djDebugLineChart{% if query.is_slow %} djDebugLineChartWarning{% endif %}" style="left:{{ query.start_offset }}%;"><strong style="width:{{ query.width_ratio }}%;">{{ query.width_ratio }}%</strong></div></div> +					</td> +					<td class="time"> +						{{ query.duration|floatformat:"2" }} +					</td> +					<td class="actions"> +					{% if query.params %} +						{% if query.is_select %} +							<a class="remoteCall" href="/__debug__/sql_select/?sql={{ query.raw_sql|urlencode }}&params={{ query.params|urlencode }}&duration={{ query.duration|floatformat:"2"|urlencode }}&hash={{ query.hash }}">Sel</a> +							<a class="remoteCall" href="/__debug__/sql_explain/?sql={{ query.raw_sql|urlencode }}&params={{ query.params|urlencode }}&duration={{ query.duration|floatformat:"2"|urlencode }}&hash={{ query.hash }}">Expl</a> +							{% ifequal query.engine 'mysql' %} +								<a class="remoteCall" href="/__debug__/sql_profile/?sql={{ query.raw_sql|urlencode }}&params={{ query.params|urlencode }}&duration={{ query.duration|floatformat:"2"|urlencode }}&hash={{ query.hash }}">Prof</a> +							{% endifequal %}  						{% endif %}  					{% endif %} -				{% endif %} -				</td> -				<td> -					{% if query.stacktrace %} -					<div class="djSQLShowStacktraceDiv"><a class="djSQLShowStacktrace" href="#">Toggle Stacktrace</a></div> -					{% endif %} -				</td> -				<td class="syntax"> -					<div class="djDebugSqlWrap"> -						<div class="djDebugSql">{{ query.sql|safe }}</div> -						{% if query.stacktrace %} -						<div class="djSQLHideStacktraceDiv" style="display:none;"> -							<table> -								<tr> -									<th>{% trans "Line" %}</th> -									<th>{% trans "Method" %}</th> -									<th>{% trans "File" %}</th> -								</tr> -								{% for file, line, method in query.stacktrace %} +					</td> +				</tr> +				<tr class="djUnselected djDebugHoverable {% cycle 'djDebugOdd' 'djDebugEven' %}{% if query.is_slow %} djDebugRowWarning{% endif %} djToggleDetails_{{ forloop.counter }}" id="sqlDetails_{{ forloop.counter }}"> +					<td colspan="2"></td> +					<td colspan="4"> +						<div class="djSQLDetailsDiv"> +							<p><strong>Connection:</strong> {{ query.alias }}</p> +							{% if query.iso_level %} +								<p><strong>Isolation Level:</strong> {{ query.iso_level }}</p> +							{% endif %} +							{% if query.trans_status %} +								<p><strong>Transaction Status:</strong> {{ query.trans_status }}</p> +							{% endif %} +							{% if query.stacktrace %} +								<pre class="stack">{{ query.stacktrace }}</pre> +							{% endif %} +							{% if query.template_info %} +								<table> +									{% for line in query.template_info.context %}  									<tr> -										<td>{{ line }}</td> -										<td><code>{{ method|escape }}</code></td> -										<td><code>{{ file|escape }}</code></td> +										<td>{{ line.num }}</td> +										<td><code style="font-family: monospace;{% if line.highlight %}background-color: lightgrey{% endif %}">{{ line.content }}</code></td>  									</tr> -								{% endfor %} -							</table> -							{% if query.template_info %} -							<table> -								{% for line in query.template_info.context %} -								<tr> -									<td>{{ line.num }}</td> -									<td><code style="font-family: monospace;{% if line.highlight %}background-color: lightgrey{% endif %}">{{ line.content }}</code></td> -								</tr> -								{% endfor %} -							</table> -							<p><strong>{{ query.template_info.name|default:"(unknown)" }}</strong></p> +									{% endfor %} +								</table> +								<p><strong>{{ query.template_info.name|default:"(unknown)" }}</strong></p>  							{% endif %}  						</div> -						{% endif %} -            <span class="djDebugLineChart{% if query.is_slow %} djDebugLineChartWarning{% endif %}" style="width:{{ query.width_ratio }}%; left:{{ query.start_offset }}%;"></span> -					</div> -				</td> -			</tr> -		{% endfor %} -	</tbody> -</table> +					</td> +				</tr> +			{% endfor %} +		</tbody> +	</table> +{% else %} +	<p>No SQL queries were recorded during this request.</p> +{% endif %} diff --git a/debug_toolbar/tests/__init__.py b/debug_toolbar/tests/__init__.py new file mode 100644 index 0000000..f853b10 --- /dev/null +++ b/debug_toolbar/tests/__init__.py @@ -0,0 +1 @@ +from tests import *
\ No newline at end of file diff --git a/debug_toolbar/tests/templates/404.html b/debug_toolbar/tests/templates/404.html new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/debug_toolbar/tests/templates/404.html diff --git a/debug_toolbar/tests/tests.py b/debug_toolbar/tests/tests.py new file mode 100644 index 0000000..fe1904a --- /dev/null +++ b/debug_toolbar/tests/tests.py @@ -0,0 +1,174 @@ +from debug_toolbar.middleware import DebugToolbarMiddleware +from debug_toolbar.panels.sql import SQLDebugPanel +from debug_toolbar.toolbar.loader import DebugToolbar +from debug_toolbar.utils.tracking import pre_dispatch, post_dispatch, callbacks + +from django.contrib.auth.models import User +from django.test import TestCase + +from dingus import Dingus +import thread + +class BaseTestCase(TestCase): +    def setUp(self): +        request = Dingus('request') +        toolbar = DebugToolbar(request) +        DebugToolbarMiddleware.debug_toolbars[thread.get_ident()] = toolbar +        self.toolbar = toolbar + +class DebugToolbarTestCase(BaseTestCase): +    urls = 'debug_toolbar.tests.urls' +     +    def test_middleware(self): +        resp = self.client.get('/execute_sql/') +        self.assertEquals(resp.status_code, 200) + +class SQLPanelTestCase(BaseTestCase): +    def test_recording(self): +        panel = self.toolbar.get_panel(SQLDebugPanel) +        self.assertEquals(len(panel._queries), 0) +         +        list(User.objects.all()) +         +        # ensure query was logged +        self.assertEquals(len(panel._queries), 1) +        query = panel._queries[0] +        self.assertEquals(query[0], 'default') +        self.assertTrue('sql' in query[1]) +        self.assertTrue('duration' in query[1]) +        self.assertTrue('stacktrace' in query[1]) + +def module_func(*args, **kwargs): +    """Used by dispatch tests""" +    return 'blah' + +class TrackingTestCase(BaseTestCase): +    @classmethod +    def class_method(cls, *args, **kwargs): +        return 'blah' + +    def class_func(self, *args, **kwargs): +        """Used by dispatch tests""" +        return 'blah' +     +    def test_pre_hook(self): +        foo = {} +         +        @pre_dispatch(module_func) +        def test(**kwargs): +            foo.update(kwargs) +             +        self.assertTrue(hasattr(module_func, '__wrapped__')) +        self.assertEquals(len(callbacks['before']), 1) +         +        module_func('hi', foo='bar') +         +        self.assertTrue('sender' in foo, foo) +        # best we can do +        self.assertEquals(foo['sender'].__name__, 'module_func') +        self.assertTrue('start' in foo, foo) +        self.assertTrue(foo['start'] > 0) +        self.assertTrue('stop' not in foo, foo) +        self.assertTrue('args' in foo, foo) +        self.assertTrue(len(foo['args']), 1) +        self.assertEquals(foo['args'][0], 'hi') +        self.assertTrue('kwargs' in foo, foo) +        self.assertTrue(len(foo['kwargs']), 1) +        self.assertTrue('foo' in foo['kwargs']) +        self.assertEquals(foo['kwargs']['foo'], 'bar') +     +        callbacks['before'] = {} +     +        @pre_dispatch(TrackingTestCase.class_func) +        def test(**kwargs): +            foo.update(kwargs) +     +        self.assertTrue(hasattr(TrackingTestCase.class_func, '__wrapped__')) +        self.assertEquals(len(callbacks['before']), 1) + +        self.class_func('hello', foo='bar') + +        self.assertTrue('sender' in foo, foo) +        # best we can do +        self.assertEquals(foo['sender'].__name__, 'class_func') +        self.assertTrue('start' in foo, foo) +        self.assertTrue(foo['start'] > 0) +        self.assertTrue('stop' not in foo, foo) +        self.assertTrue('args' in foo, foo) +        self.assertTrue(len(foo['args']), 2) +        self.assertEquals(foo['args'][1], 'hello') +        self.assertTrue('kwargs' in foo, foo) +        self.assertTrue(len(foo['kwargs']), 1) +        self.assertTrue('foo' in foo['kwargs']) +        self.assertEquals(foo['kwargs']['foo'], 'bar') + +        # callbacks['before'] = {} +        #      +        #         @pre_dispatch(TrackingTestCase.class_method) +        #         def test(**kwargs): +        #             foo.update(kwargs) +        #      +        #         self.assertTrue(hasattr(TrackingTestCase.class_method, '__wrapped__')) +        #         self.assertEquals(len(callbacks['before']), 1) +        #  +        #         TrackingTestCase.class_method() +        #  +        #         self.assertTrue('sender' in foo, foo) +        #         # best we can do +        #         self.assertEquals(foo['sender'].__name__, 'class_method') +        #         self.assertTrue('start' in foo, foo) +        #         self.assertTrue('stop' not in foo, foo) +        #         self.assertTrue('args' in foo, foo) + +    def test_post_hook(self): +        foo = {} +         +        @post_dispatch(module_func) +        def test(**kwargs): +            foo.update(kwargs) +             +        self.assertTrue(hasattr(module_func, '__wrapped__')) +        self.assertEquals(len(callbacks['after']), 1) +         +        module_func('hi', foo='bar') +         +        self.assertTrue('sender' in foo, foo) +        # best we can do +        self.assertEquals(foo['sender'].__name__, 'module_func') +        self.assertTrue('start' in foo, foo) +        self.assertTrue(foo['start'] > 0) +        self.assertTrue('stop' in foo, foo) +        self.assertTrue(foo['stop'] > foo['start']) +        self.assertTrue('args' in foo, foo) +        self.assertTrue(len(foo['args']), 1) +        self.assertEquals(foo['args'][0], 'hi') +        self.assertTrue('kwargs' in foo, foo) +        self.assertTrue(len(foo['kwargs']), 1) +        self.assertTrue('foo' in foo['kwargs']) +        self.assertEquals(foo['kwargs']['foo'], 'bar') +     +        callbacks['after'] = {} +     +        @post_dispatch(TrackingTestCase.class_func) +        def test(**kwargs): +            foo.update(kwargs) +     +        self.assertTrue(hasattr(TrackingTestCase.class_func, '__wrapped__')) +        self.assertEquals(len(callbacks['after']), 1) + +        self.class_func('hello', foo='bar') + +        self.assertTrue('sender' in foo, foo) +        # best we can do +        self.assertEquals(foo['sender'].__name__, 'class_func') +        self.assertTrue('start' in foo, foo) +        self.assertTrue(foo['start'] > 0) +        self.assertTrue('stop' in foo, foo) +        self.assertTrue(foo['stop'] > foo['start']) +        self.assertTrue('args' in foo, foo) +        self.assertTrue(len(foo['args']), 2) +        self.assertEquals(foo['args'][1], 'hello') +        self.assertTrue('kwargs' in foo, foo) +        self.assertTrue(len(foo['kwargs']), 1) +        self.assertTrue('foo' in foo['kwargs']) +        self.assertEquals(foo['kwargs']['foo'], 'bar')
\ No newline at end of file diff --git a/debug_toolbar/tests/urls.py b/debug_toolbar/tests/urls.py new file mode 100644 index 0000000..7c99b03 --- /dev/null +++ b/debug_toolbar/tests/urls.py @@ -0,0 +1,14 @@ +""" +URLpatterns for the debug toolbar.  + +These should not be loaded explicitly; the debug toolbar middleware will patch +this into the urlconf for the request. +""" +from django.conf.urls.defaults import * +from django.contrib import admin + +admin.autodiscover() + +urlpatterns = patterns('', +    url(r'^execute_sql/$', 'debug_toolbar.tests.views.execute_sql'), +) diff --git a/debug_toolbar/tests/views.py b/debug_toolbar/tests/views.py new file mode 100644 index 0000000..f989dcd --- /dev/null +++ b/debug_toolbar/tests/views.py @@ -0,0 +1,7 @@ +from django.contrib.auth.models import User +from django.http import HttpResponse + +def execute_sql(request): +    list(User.objects.all()) +     +    return HttpResponse()
\ No newline at end of file diff --git a/debug_toolbar/toolbar/loader.py b/debug_toolbar/toolbar/loader.py index 4b53d2f..3501c69 100644 --- a/debug_toolbar/toolbar/loader.py +++ b/debug_toolbar/toolbar/loader.py @@ -1,14 +1,18 @@  """  The main DebugToolbar class that loads and renders the Toolbar.  """ +import os.path, os +  from django.conf import settings  from django.template.loader import render_to_string +from django.utils.datastructures import SortedDict +from django.utils.safestring import mark_safe  class DebugToolbar(object):      def __init__(self, request):          self.request = request -        self.panels = [] +        self._panels = SortedDict()          base_url = self.request.META.get('SCRIPT_NAME', '')          self.config = {              'INTERCEPT_REDIRECTS': True, @@ -34,6 +38,13 @@ class DebugToolbar(object):              'debug_toolbar.panels.logger.LoggingPanel',          )          self.load_panels() +     +    def _get_panels(self): +        return self._panels.values() +    panels = property(_get_panels) + +    def get_panel(self, cls): +        return self._panels[cls]      def load_panels(self):          """ @@ -66,13 +77,19 @@ class DebugToolbar(object):              except:                  raise # Bubble up problem loading panel -            self.panels.append(panel_instance) +            self._panels[panel_class] = panel_instance      def render_toolbar(self):          """          Renders the overall Toolbar with panels inside.          """ +        media_path = os.path.join(os.path.dirname(__file__), os.pardir, 'media', 'debug_toolbar') +                  context = self.template_context.copy() -        context.update({ 'panels': self.panels, }) +        context.update({ +            'panels': self.panels, +            'js': mark_safe(open(os.path.join(media_path, 'js', 'toolbar.min.js'), 'r').read()), +            'css': mark_safe(open(os.path.join(media_path, 'css', 'toolbar.min.css'), 'r').read()), +        })          return render_to_string('debug_toolbar/base.html', context) diff --git a/debug_toolbar/utils/__init__.py b/debug_toolbar/utils/__init__.py index e69de29..61bb717 100644 --- a/debug_toolbar/utils/__init__.py +++ b/debug_toolbar/utils/__init__.py @@ -0,0 +1,68 @@ +import os.path +import django +import SocketServer + +from django.conf import settings +from django.views.debug import linebreak_iter + +# Figure out some paths +django_path = os.path.realpath(os.path.dirname(django.__file__)) +socketserver_path = os.path.realpath(os.path.dirname(SocketServer.__file__)) + +def ms_from_timedelta(td): +    """ +    Given a timedelta object, returns a float representing milliseconds +    """ +    return (td.seconds * 1000) + (td.microseconds / 1000.0) + +def tidy_stacktrace(strace): +    """ +    Clean up stacktrace and remove all entries that: +    1. Are part of Django (except contrib apps) +    2. Are part of SocketServer (used by Django's dev server) +    3. Are the last entry (which is part of our stacktracing code) +    """ +    trace = [] +    for s in strace[:-1]: +        s_path = os.path.realpath(s[0]) +        if getattr(settings, 'DEBUG_TOOLBAR_CONFIG', {}).get('HIDE_DJANGO_SQL', True) \ +            and django_path in s_path and not 'django/contrib' in s_path: +            continue +        if socketserver_path in s_path: +            continue +        trace.append((s[0], s[1], s[2], s[3])) +    return trace + +def get_template_info(source, context_lines=3): +    line = 0 +    upto = 0 +    source_lines = [] +    before = during = after = "" + +    origin, (start, end) = source +    template_source = origin.reload() + +    for num, next in enumerate(linebreak_iter(template_source)): +        if start >= upto and end <= next: +            line = num +            before = template_source[upto:start] +            during = template_source[start:end] +            after = template_source[end:next] +        source_lines.append((num, template_source[upto:next])) +        upto = next + +    top = max(1, line - context_lines) +    bottom = min(len(source_lines), line + 1 + context_lines) + +    context = [] +    for num, content in source_lines[top:bottom]: +        context.append({ +            'num': num, +            'content': content, +            'highlight': (num == line), +        }) + +    return { +        'name': origin.name, +        'context': context, +    }
\ No newline at end of file diff --git a/debug_toolbar/utils/compat/__init__.py b/debug_toolbar/utils/compat/__init__.py new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/debug_toolbar/utils/compat/__init__.py diff --git a/debug_toolbar/utils/compat/db.py b/debug_toolbar/utils/compat/db.py new file mode 100644 index 0000000..4273d9e --- /dev/null +++ b/debug_toolbar/utils/compat/db.py @@ -0,0 +1,13 @@ +from django.conf import settings +try: +    from django.db import connections +    dbconf = settings.DATABASES +except ImportError: +    # Compat with < Django 1.2 +    from django.db import connection +    connections = {'default': connection} +    dbconf = { +        'default': { +            'ENGINE': settings.DATABASE_ENGINE, +        } +    }
\ No newline at end of file diff --git a/debug_toolbar/utils/tracking/__init__.py b/debug_toolbar/utils/tracking/__init__.py new file mode 100644 index 0000000..db8ff18 --- /dev/null +++ b/debug_toolbar/utils/tracking/__init__.py @@ -0,0 +1,90 @@ +import logging +import time +import types + +def post_dispatch(func): +    def wrapped(callback): +        register_hook(func, 'after', callback) +        return callback +    return wrapped + +def pre_dispatch(func): +    def wrapped(callback): +        register_hook(func, 'before', callback) +        return callback +    return wrapped + +def replace_call(func): +    def inner(callback): +        def wrapped(*args, **kwargs): +            return callback(func, *args, **kwargs) + +        actual = getattr(func, '__wrapped__', func) +        wrapped.__wrapped__ = actual +        wrapped.__doc__ = getattr(actual, '__doc__', None) +        wrapped.__name__ = actual.__name__ + +        _replace_function(func, wrapped) +        return wrapped +    return inner + +def fire_hook(hook, sender, **kwargs): +    try: +        for callback in callbacks[hook].get(id(sender), []): +            callback(sender=sender, **kwargs) +    except Exception, e: +        # Log the exception, dont mess w/ the underlying function +        logging.exception(e) + +def _replace_function(func, wrapped): +    if isinstance(func, types.FunctionType): +        if func.__module__ == '__builtin__': +            # oh shit +            __builtins__[func] = wrapped +        else: +            module = __import__(func.__module__, {}, {}, [func.__module__], 0) +            setattr(module, func.__name__, wrapped) +    elif getattr(func, 'im_self', None): +        # TODO: classmethods +        raise NotImplementedError +    elif hasattr(func, 'im_class'): +        # for unbound methods +        setattr(func.im_class, func.__name__, wrapped) +    else: +        raise NotImplementedError + +callbacks = { +    'before': {}, +    'after': {}, +} + +def register_hook(func, hook, callback): +    """ +    def myhook(sender, args, kwargs): +        print func, "executed +        print "args:", args +        print "kwargs:", kwargs +    register_hook(BaseDatabaseWrapper.cursor, 'before', myhook) +    """ + +    assert hook in ('before', 'after') + +    def wrapped(*args, **kwargs): +        start = time.time() +        fire_hook('before', sender=wrapped.__wrapped__, args=args, kwargs=kwargs, +                  start=start) +        result = wrapped.__wrapped__(*args, **kwargs) +        stop = time.time() +        fire_hook('after', sender=wrapped.__wrapped__, args=args, kwargs=kwargs, +                  result=result, start=start, stop=stop) +    actual = getattr(func, '__wrapped__', func) +    wrapped.__wrapped__ = actual +    wrapped.__doc__ = getattr(actual, '__doc__', None) +    wrapped.__name__ = actual.__name__ +     +    id_ = id(actual) +    if id_ not in callbacks[hook]: +        callbacks[hook][id_] = [] +    callbacks[hook][id_].append(callback) + +    _replace_function(func, wrapped)
\ No newline at end of file diff --git a/debug_toolbar/utils/tracking/db.py b/debug_toolbar/utils/tracking/db.py new file mode 100644 index 0000000..87f4550 --- /dev/null +++ b/debug_toolbar/utils/tracking/db.py @@ -0,0 +1,105 @@ +import sys +import traceback + +from datetime import datetime + +from django.conf import settings +from django.template import Node +from django.utils import simplejson +from django.utils.encoding import force_unicode +from django.utils.hashcompat import sha_constructor + +from debug_toolbar.utils import ms_from_timedelta, tidy_stacktrace, get_template_info +from debug_toolbar.utils.compat.db import connections +# TODO:This should be set in the toolbar loader as a default and panels should +# get a copy of the toolbar object with access to its config dictionary +SQL_WARNING_THRESHOLD = getattr(settings, 'DEBUG_TOOLBAR_CONFIG', {}) \ +                            .get('SQL_WARNING_THRESHOLD', 500) + +class CursorWrapper(object): +    """ +    Wraps a cursor and logs queries. +    """ +     +    def __init__(self, cursor, db, logger): +        self.cursor = cursor +        # Instance of a BaseDatabaseWrapper subclass +        self.db = db +        # logger must implement a ``record`` method +        self.logger = logger + +    def execute(self, sql, params=()): +        start = datetime.now() +        try: +            return self.cursor.execute(sql, params) +        finally: +            stop = datetime.now() +            duration = ms_from_timedelta(stop - start) +            stacktrace = tidy_stacktrace(traceback.extract_stack()) +            _params = '' +            try: +                _params = simplejson.dumps([force_unicode(x, strings_only=True) for x in params]) +            except TypeError: +                pass # object not JSON serializable + +            template_info = None +            cur_frame = sys._getframe().f_back +            try: +                while cur_frame is not None: +                    if cur_frame.f_code.co_name == 'render': +                        node = cur_frame.f_locals['self'] +                        if isinstance(node, Node): +                            template_info = get_template_info(node.source) +                            break +                    cur_frame = cur_frame.f_back +            except: +                pass +            del cur_frame + +            alias = getattr(self, 'alias', 'default') +            conn = connections[alias].connection +            # HACK: avoid imports +            if conn: +                engine = conn.__class__.__module__.split('.', 1)[0] +            else: +                engine = 'unknown' + +            params = { +                'engine': engine, +                'alias': alias, +                'sql': self.db.ops.last_executed_query(self.cursor, sql, params), +                'duration': duration, +                'raw_sql': sql, +                'params': _params, +                'hash': sha_constructor(settings.SECRET_KEY + sql + _params).hexdigest(), +                'stacktrace': stacktrace, +                'start_time': start, +                'stop_time': stop, +                'is_slow': (duration > SQL_WARNING_THRESHOLD), +                'is_select': sql.lower().strip().startswith('select'), +                'template_info': template_info, +            } + +            if engine == 'psycopg2': +                params.update({ +                    'trans_id': self.logger.get_transaction_id(alias), +                    'trans_status': conn.get_transaction_status(), +                    'iso_level': conn.isolation_level, +                    'encoding': conn.encoding, +                }) +                 +             +            # We keep `sql` to maintain backwards compatibility +            self.logger.record(**params) + +    def executemany(self, sql, param_list): +        return self.cursor.executemany(sql, param_list) + +    def __getattr__(self, attr): +        if attr in self.__dict__: +            return self.__dict__[attr] +        else: +            return getattr(self.cursor, attr) + +    def __iter__(self): +        return iter(self.cursor)
\ No newline at end of file diff --git a/example/example.db b/example/example.dbBinary files differ index f78b987..6eb3916 100644 --- a/example/example.db +++ b/example/example.db diff --git a/example/settings.py b/example/settings.py index 06e153d..11b0117 100644 --- a/example/settings.py +++ b/example/settings.py @@ -32,3 +32,16 @@ TEMPLATE_CONTEXT_PROCESSORS = (  )  TEMPLATE_DEBUG = DEBUG  TEMPLATE_DIRS = (os.path.join(PROJECT_PATH, 'templates')) +DEBUG_TOOLBAR_PANELS = ( +    'debug_toolbar.panels.version.VersionDebugPanel', +    'debug_toolbar.panels.timer.TimerDebugPanel', +    'debug_toolbar.panels.settings_vars.SettingsVarsDebugPanel', +    'debug_toolbar.panels.headers.HeaderDebugPanel', +    'debug_toolbar.panels.profiling.ProfilingDebugPanel', +    'debug_toolbar.panels.request_vars.RequestVarsDebugPanel', +    'debug_toolbar.panels.sql.SQLDebugPanel', +    'debug_toolbar.panels.template.TemplateDebugPanel', +    #'debug_toolbar.panels.cache.CacheDebugPanel', +    'debug_toolbar.panels.signals.SignalDebugPanel', +    'debug_toolbar.panels.logger.LoggingPanel', +)
\ No newline at end of file @@ -8,10 +8,15 @@ setup(      # Get more strings from http://www.python.org/pypi?:action=list_classifiers      author='Rob Hudson',      author_email='rob@cogit8.org', -    url='http://robhudson.github.com/django-debug-toolbar/', -    download_url='http://github.com/robhudson/django-debug-toolbar/downloads', +    url='https://github.com/django-debug-toolbar/django-debug-toolbar', +    download_url='https://github.com/django-debug-toolbar/django-debug-toolbar/downloads',      license='BSD',      packages=find_packages(exclude=['ez_setup']), +    tests_require=[ +        'django', +        'dingus', +    ], +    test_suite='debug_toolbar.runtests.runtests',      include_package_data=True,      zip_safe=False, # because we're including media that Django needs      classifiers=[ | 
