aboutsummaryrefslogtreecommitdiffstats
path: root/97suifang-front/assets/plugins
diff options
context:
space:
mode:
Diffstat (limited to '97suifang-front/assets/plugins')
-rw-r--r--97suifang-front/assets/plugins/datepicker/datepicker.css383
-rw-r--r--97suifang-front/assets/plugins/datepicker/datepicker.js5257
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/calendar.gifbin0 -> 269 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/calendar.pngbin0 -> 261 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_f6f6f6_1x400.pngbin0 -> 104 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_fdf5ce_1x400.pngbin0 -> 125 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_65_ffffff_1x400.pngbin0 -> 105 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-bg_gloss-wave_35_f6a828_500x100.pngbin0 -> 3762 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_100_eeeeee_1x100.pngbin0 -> 90 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_75_ffe45c_1x100.pngbin0 -> 129 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-icons_ef8c08_256x240.pngbin0 -> 4369 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/images/ui-icons_ffffff_256x240.pngbin0 -> 4369 bytes
-rw-r--r--97suifang-front/assets/plugins/datepicker/language-zh-CN.js23
-rw-r--r--97suifang-front/assets/plugins/highcharts/highcharts-more.js50
-rw-r--r--97suifang-front/assets/plugins/highcharts/highcharts.js277
-rw-r--r--97suifang-front/assets/plugins/thickbox/images/loadingAnimation.gifbin0 -> 7347 bytes
-rw-r--r--97suifang-front/assets/plugins/thickbox/thickbox.css135
-rw-r--r--97suifang-front/assets/plugins/thickbox/thickbox.js286
18 files changed, 6411 insertions, 0 deletions
diff --git a/97suifang-front/assets/plugins/datepicker/datepicker.css b/97suifang-front/assets/plugins/datepicker/datepicker.css
new file mode 100644
index 0000000..5732386
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/datepicker.css
@@ -0,0 +1,383 @@
+/*
+ * jQuery UI CSS Framework 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Theming/API
+ */
+
+/* Layout helpers
+----------------------------------*/
+.ui-helper-hidden { display: none; }
+.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); }
+.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
+.ui-helper-clearfix:before, .ui-helper-clearfix:after { content: ""; display: table; }
+.ui-helper-clearfix:after { clear: both; }
+.ui-helper-clearfix { zoom: 1; }
+.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
+
+
+/* Interaction Cues
+----------------------------------*/
+.ui-state-disabled { cursor: default !important; }
+
+
+/* Icons
+----------------------------------*/
+
+/* states and images */
+.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
+
+
+/* Misc visuals
+----------------------------------*/
+
+/* Overlays */
+.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
+
+
+/*
+ * jQuery UI CSS Framework 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Theming/API
+ *
+ * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Trebuchet%20MS,%20Tahoma,%20Verdana,%20Arial,%20sans-serif&fwDefault=bold&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=f6a828&bgTextureHeader=12_gloss_wave.png&bgImgOpacityHeader=35&borderColorHeader=e78f08&fcHeader=ffffff&iconColorHeader=ffffff&bgColorContent=eeeeee&bgTextureContent=03_highlight_soft.png&bgImgOpacityContent=100&borderColorContent=dddddd&fcContent=333333&iconColorContent=222222&bgColorDefault=f6f6f6&bgTextureDefault=02_glass.png&bgImgOpacityDefault=100&borderColorDefault=cccccc&fcDefault=1c94c4&iconColorDefault=ef8c08&bgColorHover=fdf5ce&bgTextureHover=02_glass.png&bgImgOpacityHover=100&borderColorHover=fbcb09&fcHover=c77405&iconColorHover=ef8c08&bgColorActive=ffffff&bgTextureActive=02_glass.png&bgImgOpacityActive=65&borderColorActive=fbd850&fcActive=eb8f00&iconColorActive=ef8c08&bgColorHighlight=ffe45c&bgTextureHighlight=03_highlight_soft.png&bgImgOpacityHighlight=75&borderColorHighlight=fed22f&fcHighlight=363636&iconColorHighlight=228ef1&bgColorError=b81900&bgTextureError=08_diagonals_thick.png&bgImgOpacityError=18&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffd27a&bgColorOverlay=666666&bgTextureOverlay=08_diagonals_thick.png&bgImgOpacityOverlay=20&opacityOverlay=50&bgColorShadow=000000&bgTextureShadow=01_flat.png&bgImgOpacityShadow=10&opacityShadow=20&thicknessShadow=5px&offsetTopShadow=-5px&offsetLeftShadow=-5px&cornerRadiusShadow=5px
+ */
+
+
+/* Component containers
+----------------------------------*/
+.ui-widget { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1.1em; }
+.ui-widget .ui-widget { font-size: 1em; }
+.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Trebuchet MS, Tahoma, Verdana, Arial, sans-serif; font-size: 1em; }
+.ui-widget-content { border: 1px solid #dddddd; background: #eeeeee url(images/ui-bg_highlight-soft_100_eeeeee_1x100.png) 50% top repeat-x; color: #333333; }
+.ui-widget-content a { color: #333333; }
+.ui-widget-header { border: 1px solid #e78f08; background: #f6a828 url(images/ui-bg_gloss-wave_35_f6a828_500x100.png) 50% 50% repeat-x; color: #ffffff; font-weight: bold; }
+.ui-widget-header a { color: #ffffff; }
+
+/* Interaction states
+----------------------------------*/
+.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #cccccc; background: #f6f6f6 url(images/ui-bg_glass_100_f6f6f6_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #1c94c4; }
+.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #1c94c4; text-decoration: none; }
+.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #fbcb09; background: #fdf5ce url(images/ui-bg_glass_100_fdf5ce_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #c77405; }
+.ui-state-hover a, .ui-state-hover a:hover { color: #c77405; text-decoration: none; }
+.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #fbd850; background: #ffffff url(images/ui-bg_glass_65_ffffff_1x400.png) 50% 50% repeat-x; font-weight: bold; color: #eb8f00; }
+.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #eb8f00; text-decoration: none; }
+.ui-widget :active { outline: none; }
+
+/* Interaction Cues
+----------------------------------*/
+.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fed22f; background: #ffe45c url(images/ui-bg_highlight-soft_75_ffe45c_1x100.png) 50% top repeat-x; color: #363636; }
+.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; }
+.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #b81900 url(images/ui-bg_diagonals-thick_18_b81900_40x40.png) 50% 50% repeat; color: #ffffff; }
+.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #ffffff; }
+.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #ffffff; }
+.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
+.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
+.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
+
+/* Icons
+----------------------------------*/
+
+/* states and images */
+.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png); }
+.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); }
+.ui-widget-header .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); }
+.ui-state-default .ui-icon { background-image: url(images/ui-icons_ef8c08_256x240.png); }
+.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); }
+.ui-state-active .ui-icon {background-image: url(images/ui-icons_ef8c08_256x240.png); }
+.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_228ef1_256x240.png); }
+.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_ffd27a_256x240.png); }
+
+/* positioning */
+.ui-icon-carat-1-n { background-position: 0 0; }
+.ui-icon-carat-1-ne { background-position: -16px 0; }
+.ui-icon-carat-1-e { background-position: -32px 0; }
+.ui-icon-carat-1-se { background-position: -48px 0; }
+.ui-icon-carat-1-s { background-position: -64px 0; }
+.ui-icon-carat-1-sw { background-position: -80px 0; }
+.ui-icon-carat-1-w { background-position: -96px 0; }
+.ui-icon-carat-1-nw { background-position: -112px 0; }
+.ui-icon-carat-2-n-s { background-position: -128px 0; }
+.ui-icon-carat-2-e-w { background-position: -144px 0; }
+.ui-icon-triangle-1-n { background-position: 0 -16px; }
+.ui-icon-triangle-1-ne { background-position: -16px -16px; }
+.ui-icon-triangle-1-e { background-position: -32px -16px; }
+.ui-icon-triangle-1-se { background-position: -48px -16px; }
+.ui-icon-triangle-1-s { background-position: -64px -16px; }
+.ui-icon-triangle-1-sw { background-position: -80px -16px; }
+.ui-icon-triangle-1-w { background-position: -96px -16px; }
+.ui-icon-triangle-1-nw { background-position: -112px -16px; }
+.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
+.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
+.ui-icon-arrow-1-n { background-position: 0 -32px; }
+.ui-icon-arrow-1-ne { background-position: -16px -32px; }
+.ui-icon-arrow-1-e { background-position: -32px -32px; }
+.ui-icon-arrow-1-se { background-position: -48px -32px; }
+.ui-icon-arrow-1-s { background-position: -64px -32px; }
+.ui-icon-arrow-1-sw { background-position: -80px -32px; }
+.ui-icon-arrow-1-w { background-position: -96px -32px; }
+.ui-icon-arrow-1-nw { background-position: -112px -32px; }
+.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
+.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
+.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
+.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
+.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
+.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
+.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
+.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
+.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
+.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
+.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
+.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
+.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
+.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
+.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
+.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
+.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
+.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
+.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
+.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
+.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
+.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
+.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
+.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
+.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
+.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
+.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
+.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
+.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
+.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
+.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
+.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
+.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
+.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
+.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
+.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
+.ui-icon-arrow-4 { background-position: 0 -80px; }
+.ui-icon-arrow-4-diag { background-position: -16px -80px; }
+.ui-icon-extlink { background-position: -32px -80px; }
+.ui-icon-newwin { background-position: -48px -80px; }
+.ui-icon-refresh { background-position: -64px -80px; }
+.ui-icon-shuffle { background-position: -80px -80px; }
+.ui-icon-transfer-e-w { background-position: -96px -80px; }
+.ui-icon-transferthick-e-w { background-position: -112px -80px; }
+.ui-icon-folder-collapsed { background-position: 0 -96px; }
+.ui-icon-folder-open { background-position: -16px -96px; }
+.ui-icon-document { background-position: -32px -96px; }
+.ui-icon-document-b { background-position: -48px -96px; }
+.ui-icon-note { background-position: -64px -96px; }
+.ui-icon-mail-closed { background-position: -80px -96px; }
+.ui-icon-mail-open { background-position: -96px -96px; }
+.ui-icon-suitcase { background-position: -112px -96px; }
+.ui-icon-comment { background-position: -128px -96px; }
+.ui-icon-person { background-position: -144px -96px; }
+.ui-icon-print { background-position: -160px -96px; }
+.ui-icon-trash { background-position: -176px -96px; }
+.ui-icon-locked { background-position: -192px -96px; }
+.ui-icon-unlocked { background-position: -208px -96px; }
+.ui-icon-bookmark { background-position: -224px -96px; }
+.ui-icon-tag { background-position: -240px -96px; }
+.ui-icon-home { background-position: 0 -112px; }
+.ui-icon-flag { background-position: -16px -112px; }
+.ui-icon-calendar { background-position: -32px -112px; }
+.ui-icon-cart { background-position: -48px -112px; }
+.ui-icon-pencil { background-position: -64px -112px; }
+.ui-icon-clock { background-position: -80px -112px; }
+.ui-icon-disk { background-position: -96px -112px; }
+.ui-icon-calculator { background-position: -112px -112px; }
+.ui-icon-zoomin { background-position: -128px -112px; }
+.ui-icon-zoomout { background-position: -144px -112px; }
+.ui-icon-search { background-position: -160px -112px; }
+.ui-icon-wrench { background-position: -176px -112px; }
+.ui-icon-gear { background-position: -192px -112px; }
+.ui-icon-heart { background-position: -208px -112px; }
+.ui-icon-star { background-position: -224px -112px; }
+.ui-icon-link { background-position: -240px -112px; }
+.ui-icon-cancel { background-position: 0 -128px; }
+.ui-icon-plus { background-position: -16px -128px; }
+.ui-icon-plusthick { background-position: -32px -128px; }
+.ui-icon-minus { background-position: -48px -128px; }
+.ui-icon-minusthick { background-position: -64px -128px; }
+.ui-icon-close { background-position: -80px -128px; }
+.ui-icon-closethick { background-position: -96px -128px; }
+.ui-icon-key { background-position: -112px -128px; }
+.ui-icon-lightbulb { background-position: -128px -128px; }
+.ui-icon-scissors { background-position: -144px -128px; }
+.ui-icon-clipboard { background-position: -160px -128px; }
+.ui-icon-copy { background-position: -176px -128px; }
+.ui-icon-contact { background-position: -192px -128px; }
+.ui-icon-image { background-position: -208px -128px; }
+.ui-icon-video { background-position: -224px -128px; }
+.ui-icon-script { background-position: -240px -128px; }
+.ui-icon-alert { background-position: 0 -144px; }
+.ui-icon-info { background-position: -16px -144px; }
+.ui-icon-notice { background-position: -32px -144px; }
+.ui-icon-help { background-position: -48px -144px; }
+.ui-icon-check { background-position: -64px -144px; }
+.ui-icon-bullet { background-position: -80px -144px; }
+.ui-icon-radio-off { background-position: -96px -144px; }
+.ui-icon-radio-on { background-position: -112px -144px; }
+.ui-icon-pin-w { background-position: -128px -144px; }
+.ui-icon-pin-s { background-position: -144px -144px; }
+.ui-icon-play { background-position: 0 -160px; }
+.ui-icon-pause { background-position: -16px -160px; }
+.ui-icon-seek-next { background-position: -32px -160px; }
+.ui-icon-seek-prev { background-position: -48px -160px; }
+.ui-icon-seek-end { background-position: -64px -160px; }
+.ui-icon-seek-start { background-position: -80px -160px; }
+/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
+.ui-icon-seek-first { background-position: -80px -160px; }
+.ui-icon-stop { background-position: -96px -160px; }
+.ui-icon-eject { background-position: -112px -160px; }
+.ui-icon-volume-off { background-position: -128px -160px; }
+.ui-icon-volume-on { background-position: -144px -160px; }
+.ui-icon-power { background-position: 0 -176px; }
+.ui-icon-signal-diag { background-position: -16px -176px; }
+.ui-icon-signal { background-position: -32px -176px; }
+.ui-icon-battery-0 { background-position: -48px -176px; }
+.ui-icon-battery-1 { background-position: -64px -176px; }
+.ui-icon-battery-2 { background-position: -80px -176px; }
+.ui-icon-battery-3 { background-position: -96px -176px; }
+.ui-icon-circle-plus { background-position: 0 -192px; }
+.ui-icon-circle-minus { background-position: -16px -192px; }
+.ui-icon-circle-close { background-position: -32px -192px; }
+.ui-icon-circle-triangle-e { background-position: -48px -192px; }
+.ui-icon-circle-triangle-s { background-position: -64px -192px; }
+.ui-icon-circle-triangle-w { background-position: -80px -192px; }
+.ui-icon-circle-triangle-n { background-position: -96px -192px; }
+.ui-icon-circle-arrow-e { background-position: -112px -192px; }
+.ui-icon-circle-arrow-s { background-position: -128px -192px; }
+.ui-icon-circle-arrow-w { background-position: -144px -192px; }
+.ui-icon-circle-arrow-n { background-position: -160px -192px; }
+.ui-icon-circle-zoomin { background-position: -176px -192px; }
+.ui-icon-circle-zoomout { background-position: -192px -192px; }
+.ui-icon-circle-check { background-position: -208px -192px; }
+.ui-icon-circlesmall-plus { background-position: 0 -208px; }
+.ui-icon-circlesmall-minus { background-position: -16px -208px; }
+.ui-icon-circlesmall-close { background-position: -32px -208px; }
+.ui-icon-squaresmall-plus { background-position: -48px -208px; }
+.ui-icon-squaresmall-minus { background-position: -64px -208px; }
+.ui-icon-squaresmall-close { background-position: -80px -208px; }
+.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
+.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
+.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
+.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
+.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
+.ui-icon-grip-diagonal-se { background-position: -80px -224px; }
+
+
+/* Misc visuals
+----------------------------------*/
+
+/* Corner radius */
+.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; -khtml-border-top-left-radius: 4px; border-top-left-radius: 4px; }
+.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; -khtml-border-top-right-radius: 4px; border-top-right-radius: 4px; }
+.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; -khtml-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; }
+.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; -khtml-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; }
+
+/* Overlays */
+.ui-widget-overlay { background: #666666 url(images/ui-bg_diagonals-thick_20_666666_40x40.png) 50% 50% repeat; opacity: .50;filter:Alpha(Opacity=50); }
+.ui-widget-shadow { margin: -5px 0 0 -5px; padding: 5px; background: #000000 url(images/ui-bg_flat_10_000000_40x100.png) 50% 50% repeat-x; opacity: .20;filter:Alpha(Opacity=20); -moz-border-radius: 5px; -khtml-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; }/*
+ * jQuery UI Resizable 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Resizable#theming
+ */
+.ui-resizable { position: relative;}
+.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; }
+.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
+.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
+.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
+.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
+.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
+.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
+.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
+.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
+.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/*
+ * jQuery UI Selectable 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Selectable#theming
+ */
+.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
+/*
+ * jQuery UI Datepicker 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Datepicker#theming
+ */
+.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
+.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
+.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
+.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
+.ui-datepicker .ui-datepicker-prev { left:2px; }
+.ui-datepicker .ui-datepicker-next { right:2px; }
+.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
+.ui-datepicker .ui-datepicker-next-hover { right:1px; }
+.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; }
+.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
+.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
+.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
+.ui-datepicker select.ui-datepicker-month,
+.ui-datepicker select.ui-datepicker-year { width: 49%;}
+.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
+.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; }
+.ui-datepicker td { border: 0; padding: 1px; }
+.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
+.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
+.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
+.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
+
+/* with multiple calendars */
+.ui-datepicker.ui-datepicker-multi { width:auto; }
+.ui-datepicker-multi .ui-datepicker-group { float:left; }
+.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
+.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
+.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
+.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
+.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
+.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
+.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
+.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }
+
+/* RTL support */
+.ui-datepicker-rtl { direction: rtl; }
+.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
+.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
+.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
+.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
+.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
+.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
+.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
+.ui-datepicker-rtl .ui-datepicker-group { float:right; }
+.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
+.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
+
+/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
+.ui-datepicker-cover {
+ display: none; /*sorry for IE5*/
+ display/**/: block; /*sorry for IE5*/
+ position: absolute; /*must have*/
+ z-index: -1; /*must have*/
+ filter: mask(); /*must have*/
+ top: -4px; /*must have*/
+ left: -4px; /*must have*/
+ width: 200px; /*must have*/
+ height: 200px; /*must have*/
+} \ No newline at end of file
diff --git a/97suifang-front/assets/plugins/datepicker/datepicker.js b/97suifang-front/assets/plugins/datepicker/datepicker.js
new file mode 100644
index 0000000..5c4ed85
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/datepicker.js
@@ -0,0 +1,5257 @@
+/*!
+ * jQuery UI 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI
+ */
+(function(a, b) {
+ function d(b) {
+ return ! a(b).parents().andSelf().filter(function() {
+ return a.curCSS(this, "visibility") === "hidden" || a.expr.filters.hidden(this)
+ }).length
+ }
+ function c(b, c) {
+ var e = b.nodeName.toLowerCase();
+ if ("area" === e) {
+ var f = b.parentNode,
+ g = f.name,
+ h;
+ if (!b.href || !g || f.nodeName.toLowerCase() !== "map") return ! 1;
+ h = a("img[usemap=#" + g + "]")[0];
+ return !! h && d(h)
+ }
+ return (/input|select|textarea|button|object/.test(e) ? !b.disabled: "a" == e ? b.href || c: c) && d(b)
+ }
+ a.ui = a.ui || {};
+ a.ui.version || (a.extend(a.ui, {
+ version: "1.8.18",
+ keyCode: {
+ ALT: 18,
+ BACKSPACE: 8,
+ CAPS_LOCK: 20,
+ COMMA: 188,
+ COMMAND: 91,
+ COMMAND_LEFT: 91,
+ COMMAND_RIGHT: 93,
+ CONTROL: 17,
+ DELETE: 46,
+ DOWN: 40,
+ END: 35,
+ ENTER: 13,
+ ESCAPE: 27,
+ HOME: 36,
+ INSERT: 45,
+ LEFT: 37,
+ MENU: 93,
+ NUMPAD_ADD: 107,
+ NUMPAD_DECIMAL: 110,
+ NUMPAD_DIVIDE: 111,
+ NUMPAD_ENTER: 108,
+ NUMPAD_MULTIPLY: 106,
+ NUMPAD_SUBTRACT: 109,
+ PAGE_DOWN: 34,
+ PAGE_UP: 33,
+ PERIOD: 190,
+ RIGHT: 39,
+ SHIFT: 16,
+ SPACE: 32,
+ TAB: 9,
+ UP: 38,
+ WINDOWS: 91
+ }
+ }), a.fn.extend({
+ propAttr: a.fn.prop || a.fn.attr,
+ _focus: a.fn.focus,
+ focus: function(b, c) {
+ return typeof b == "number" ? this.each(function() {
+ var d = this;
+ setTimeout(function() {
+ a(d).focus(),
+ c && c.call(d)
+ },
+ b)
+ }) : this._focus.apply(this, arguments)
+ },
+ scrollParent: function() {
+ var b;
+ a.browser.msie && /(static|relative)/.test(this.css("position")) || /absolute/.test(this.css("position")) ? b = this.parents().filter(function() {
+ return /(relative|absolute|fixed)/.test(a.curCSS(this, "position", 1)) && /(auto|scroll)/.test(a.curCSS(this, "overflow", 1) + a.curCSS(this, "overflow-y", 1) + a.curCSS(this, "overflow-x", 1))
+ }).eq(0) : b = this.parents().filter(function() {
+ return /(auto|scroll)/.test(a.curCSS(this, "overflow", 1) + a.curCSS(this, "overflow-y", 1) + a.curCSS(this, "overflow-x", 1))
+ }).eq(0);
+ return /fixed/.test(this.css("position")) || !b.length ? a(document) : b
+ },
+ zIndex: function(c) {
+ if (c !== b) return this.css("zIndex", c);
+ if (this.length) {
+ var d = a(this[0]),
+ e,
+ f;
+ while (d.length && d[0] !== document) {
+ e = d.css("position");
+ if (e === "absolute" || e === "relative" || e === "fixed") {
+ f = parseInt(d.css("zIndex"), 10);
+ if (!isNaN(f) && f !== 0) return f
+ }
+ d = d.parent()
+ }
+ }
+ return 0
+ },
+ disableSelection: function() {
+ return this.bind((a.support.selectstart ? "selectstart": "mousedown") + ".ui-disableSelection",
+ function(a) {
+ a.preventDefault()
+ })
+ },
+ enableSelection: function() {
+ return this.unbind(".ui-disableSelection")
+ }
+ }), a.each(["Width", "Height"],
+ function(c, d) {
+ function h(b, c, d, f) {
+ a.each(e,
+ function() {
+ c -= parseFloat(a.curCSS(b, "padding" + this, !0)) || 0,
+ d && (c -= parseFloat(a.curCSS(b, "border" + this + "Width", !0)) || 0),
+ f && (c -= parseFloat(a.curCSS(b, "margin" + this, !0)) || 0)
+ });
+ return c
+ }
+ var e = d === "Width" ? ["Left", "Right"] : ["Top", "Bottom"],
+ f = d.toLowerCase(),
+ g = {
+ innerWidth: a.fn.innerWidth,
+ innerHeight: a.fn.innerHeight,
+ outerWidth: a.fn.outerWidth,
+ outerHeight: a.fn.outerHeight
+ };
+ a.fn["inner" + d] = function(c) {
+ if (c === b) return g["inner" + d].call(this);
+ return this.each(function() {
+ a(this).css(f, h(this, c) + "px")
+ })
+ },
+ a.fn["outer" + d] = function(b, c) {
+ if (typeof b != "number") return g["outer" + d].call(this, b);
+ return this.each(function() {
+ a(this).css(f, h(this, b, !0, c) + "px")
+ })
+ }
+ }), a.extend(a.expr[":"], {
+ data: function(b, c, d) {
+ return !! a.data(b, d[3])
+ },
+ focusable: function(b) {
+ return c(b, !isNaN(a.attr(b, "tabindex")))
+ },
+ tabbable: function(b) {
+ var d = a.attr(b, "tabindex"),
+ e = isNaN(d);
+ return (e || d >= 0) && c(b, !e)
+ }
+ }), a(function() {
+ var b = document.body,
+ c = b.appendChild(c = document.createElement("div"));
+ c.offsetHeight,
+ a.extend(c.style, {
+ minHeight: "100px",
+ height: "auto",
+ padding: 0,
+ borderWidth: 0
+ }),
+ a.support.minHeight = c.offsetHeight === 100,
+ a.support.selectstart = "onselectstart" in c,
+ b.removeChild(c).style.display = "none"
+ }), a.extend(a.ui, {
+ plugin: {
+ add: function(b, c, d) {
+ var e = a.ui[b].prototype;
+ for (var f in d) e.plugins[f] = e.plugins[f] || [],
+ e.plugins[f].push([c, d[f]])
+ },
+ call: function(a, b, c) {
+ var d = a.plugins[b];
+ if ( !! d && !!a.element[0].parentNode) for (var e = 0; e < d.length; e++) a.options[d[e][0]] && d[e][1].apply(a.element, c)
+ }
+ },
+ contains: function(a, b) {
+ return document.compareDocumentPosition ? a.compareDocumentPosition(b) & 16 : a !== b && a.contains(b)
+ },
+ hasScroll: function(b, c) {
+ if (a(b).css("overflow") === "hidden") return ! 1;
+ var d = c && c === "left" ? "scrollLeft": "scrollTop",
+ e = !1;
+ if (b[d] > 0) return ! 0;
+ b[d] = 1,
+ e = b[d] > 0,
+ b[d] = 0;
+ return e
+ },
+ isOverAxis: function(a, b, c) {
+ return a > b && a < b + c
+ },
+ isOver: function(b, c, d, e, f, g) {
+ return a.ui.isOverAxis(b, d, f) && a.ui.isOverAxis(c, e, g)
+ }
+ }))
+})(jQuery);
+/*!
+ * jQuery UI Widget 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Widget
+ */
+(function(a, b) {
+ if (a.cleanData) {
+ var c = a.cleanData;
+ a.cleanData = function(b) {
+ for (var d = 0,
+ e; (e = b[d]) != null; d++) try {
+ a(e).triggerHandler("remove")
+ } catch(f) {}
+ c(b)
+ }
+ } else {
+ var d = a.fn.remove;
+ a.fn.remove = function(b, c) {
+ return this.each(function() {
+ c || (!b || a.filter(b, [this]).length) && a("*", this).add([this]).each(function() {
+ try {
+ a(this).triggerHandler("remove")
+ } catch(b) {}
+ });
+ return d.call(a(this), b, c)
+ })
+ }
+ }
+ a.widget = function(b, c, d) {
+ var e = b.split(".")[0],
+ f;
+ b = b.split(".")[1],
+ f = e + "-" + b,
+ d || (d = c, c = a.Widget),
+ a.expr[":"][f] = function(c) {
+ return !! a.data(c, b)
+ },
+ a[e] = a[e] || {},
+ a[e][b] = function(a, b) {
+ arguments.length && this._createWidget(a, b)
+ };
+ var g = new c;
+ g.options = a.extend(!0, {},
+ g.options),
+ a[e][b].prototype = a.extend(!0, g, {
+ namespace: e,
+ widgetName: b,
+ widgetEventPrefix: a[e][b].prototype.widgetEventPrefix || b,
+ widgetBaseClass: f
+ },
+ d),
+ a.widget.bridge(b, a[e][b])
+ },
+ a.widget.bridge = function(c, d) {
+ a.fn[c] = function(e) {
+ var f = typeof e == "string",
+ g = Array.prototype.slice.call(arguments, 1),
+ h = this;
+ e = !f && g.length ? a.extend.apply(null, [!0, e].concat(g)) : e;
+ if (f && e.charAt(0) === "_") return h;
+ f ? this.each(function() {
+ var d = a.data(this, c),
+ f = d && a.isFunction(d[e]) ? d[e].apply(d, g) : d;
+ if (f !== d && f !== b) {
+ h = f;
+ return ! 1
+ }
+ }) : this.each(function() {
+ var b = a.data(this, c);
+ b ? b.option(e || {})._init() : a.data(this, c, new d(e, this))
+ });
+ return h
+ }
+ },
+ a.Widget = function(a, b) {
+ arguments.length && this._createWidget(a, b)
+ },
+ a.Widget.prototype = {
+ widgetName: "widget",
+ widgetEventPrefix: "",
+ options: {
+ disabled: !1
+ },
+ _createWidget: function(b, c) {
+ a.data(c, this.widgetName, this),
+ this.element = a(c),
+ this.options = a.extend(!0, {},
+ this.options, this._getCreateOptions(), b);
+ var d = this;
+ this.element.bind("remove." + this.widgetName,
+ function() {
+ d.destroy()
+ }),
+ this._create(),
+ this._trigger("create"),
+ this._init()
+ },
+ _getCreateOptions: function() {
+ return a.metadata && a.metadata.get(this.element[0])[this.widgetName]
+ },
+ _create: function() {},
+ _init: function() {},
+ destroy: function() {
+ this.element.unbind("." + this.widgetName).removeData(this.widgetName),
+ this.widget().unbind("." + this.widgetName).removeAttr("aria-disabled").removeClass(this.widgetBaseClass + "-disabled " + "ui-state-disabled")
+ },
+ widget: function() {
+ return this.element
+ },
+ option: function(c, d) {
+ var e = c;
+ if (arguments.length === 0) return a.extend({},
+ this.options);
+ if (typeof c == "string") {
+ if (d === b) return this.options[c];
+ e = {},
+ e[c] = d
+ }
+ this._setOptions(e);
+ return this
+ },
+ _setOptions: function(b) {
+ var c = this;
+ a.each(b,
+ function(a, b) {
+ c._setOption(a, b)
+ });
+ return this
+ },
+ _setOption: function(a, b) {
+ this.options[a] = b,
+ a === "disabled" && this.widget()[b ? "addClass": "removeClass"](this.widgetBaseClass + "-disabled" + " " + "ui-state-disabled").attr("aria-disabled", b);
+ return this
+ },
+ enable: function() {
+ return this._setOption("disabled", !1)
+ },
+ disable: function() {
+ return this._setOption("disabled", !0)
+ },
+ _trigger: function(b, c, d) {
+ var e, f, g = this.options[b];
+ d = d || {},
+ c = a.Event(c),
+ c.type = (b === this.widgetEventPrefix ? b: this.widgetEventPrefix + b).toLowerCase(),
+ c.target = this.element[0],
+ f = c.originalEvent;
+ if (f) for (e in f) e in c || (c[e] = f[e]);
+ this.element.trigger(c, d);
+ return ! (a.isFunction(g) && g.call(this.element[0], c, d) === !1 || c.isDefaultPrevented())
+ }
+ }
+})(jQuery);
+/*!
+ * jQuery UI Mouse 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Mouse
+ *
+ * Depends:
+ * jquery.ui.widget.js
+ */
+(function(a, b) {
+ var c = !1;
+ a(document).mouseup(function(a) {
+ c = !1
+ }),
+ a.widget("ui.mouse", {
+ options: {
+ cancel: ":input,option",
+ distance: 1,
+ delay: 0
+ },
+ _mouseInit: function() {
+ var b = this;
+ this.element.bind("mousedown." + this.widgetName,
+ function(a) {
+ return b._mouseDown(a)
+ }).bind("click." + this.widgetName,
+ function(c) {
+ if (!0 === a.data(c.target, b.widgetName + ".preventClickEvent")) {
+ a.removeData(c.target, b.widgetName + ".preventClickEvent"),
+ c.stopImmediatePropagation();
+ return ! 1
+ }
+ }),
+ this.started = !1
+ },
+ _mouseDestroy: function() {
+ this.element.unbind("." + this.widgetName)
+ },
+ _mouseDown: function(b) {
+ if (!c) {
+ this._mouseStarted && this._mouseUp(b),
+ this._mouseDownEvent = b;
+ var d = this,
+ e = b.which == 1,
+ f = typeof this.options.cancel == "string" && b.target.nodeName ? a(b.target).closest(this.options.cancel).length: !1;
+ if (!e || f || !this._mouseCapture(b)) return ! 0;
+ this.mouseDelayMet = !this.options.delay,
+ this.mouseDelayMet || (this._mouseDelayTimer = setTimeout(function() {
+ d.mouseDelayMet = !0
+ },
+ this.options.delay));
+ if (this._mouseDistanceMet(b) && this._mouseDelayMet(b)) {
+ this._mouseStarted = this._mouseStart(b) !== !1;
+ if (!this._mouseStarted) {
+ b.preventDefault();
+ return ! 0
+ }
+ } ! 0 === a.data(b.target, this.widgetName + ".preventClickEvent") && a.removeData(b.target, this.widgetName + ".preventClickEvent"),
+ this._mouseMoveDelegate = function(a) {
+ return d._mouseMove(a)
+ },
+ this._mouseUpDelegate = function(a) {
+ return d._mouseUp(a)
+ },
+ a(document).bind("mousemove." + this.widgetName, this._mouseMoveDelegate).bind("mouseup." + this.widgetName, this._mouseUpDelegate),
+ b.preventDefault(),
+ c = !0;
+ return ! 0
+ }
+ },
+ _mouseMove: function(b) {
+ if (a.browser.msie && !(document.documentMode >= 9) && !b.button) return this._mouseUp(b);
+ if (this._mouseStarted) {
+ this._mouseDrag(b);
+ return b.preventDefault()
+ }
+ this._mouseDistanceMet(b) && this._mouseDelayMet(b) && (this._mouseStarted = this._mouseStart(this._mouseDownEvent, b) !== !1, this._mouseStarted ? this._mouseDrag(b) : this._mouseUp(b));
+ return ! this._mouseStarted
+ },
+ _mouseUp: function(b) {
+ a(document).unbind("mousemove." + this.widgetName, this._mouseMoveDelegate).unbind("mouseup." + this.widgetName, this._mouseUpDelegate),
+ this._mouseStarted && (this._mouseStarted = !1, b.target == this._mouseDownEvent.target && a.data(b.target, this.widgetName + ".preventClickEvent", !0), this._mouseStop(b));
+ return ! 1
+ },
+ _mouseDistanceMet: function(a) {
+ return Math.max(Math.abs(this._mouseDownEvent.pageX - a.pageX), Math.abs(this._mouseDownEvent.pageY - a.pageY)) >= this.options.distance
+ },
+ _mouseDelayMet: function(a) {
+ return this.mouseDelayMet
+ },
+ _mouseStart: function(a) {},
+ _mouseDrag: function(a) {},
+ _mouseStop: function(a) {},
+ _mouseCapture: function(a) {
+ return ! 0
+ }
+ })
+})(jQuery);
+/*
+ * jQuery UI Position 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Position
+ */
+(function(a, b) {
+ a.ui = a.ui || {};
+ var c = /left|center|right/,
+ d = /top|center|bottom/,
+ e = "center",
+ f = {},
+ g = a.fn.position,
+ h = a.fn.offset;
+ a.fn.position = function(b) {
+ if (!b || !b.of) return g.apply(this, arguments);
+ b = a.extend({},
+ b);
+ var h = a(b.of),
+ i = h[0],
+ j = (b.collision || "flip").split(" "),
+ k = b.offset ? b.offset.split(" ") : [0, 0],
+ l,
+ m,
+ n;
+ i.nodeType === 9 ? (l = h.width(), m = h.height(), n = {
+ top: 0,
+ left: 0
+ }) : i.setTimeout ? (l = h.width(), m = h.height(), n = {
+ top: h.scrollTop(),
+ left: h.scrollLeft()
+ }) : i.preventDefault ? (b.at = "left top", l = m = 0, n = {
+ top: b.of.pageY,
+ left: b.of.pageX
+ }) : (l = h.outerWidth(), m = h.outerHeight(), n = h.offset()),
+ a.each(["my", "at"],
+ function() {
+ var a = (b[this] || "").split(" ");
+ a.length === 1 && (a = c.test(a[0]) ? a.concat([e]) : d.test(a[0]) ? [e].concat(a) : [e, e]),
+ a[0] = c.test(a[0]) ? a[0] : e,
+ a[1] = d.test(a[1]) ? a[1] : e,
+ b[this] = a
+ }),
+ j.length === 1 && (j[1] = j[0]),
+ k[0] = parseInt(k[0], 10) || 0,
+ k.length === 1 && (k[1] = k[0]),
+ k[1] = parseInt(k[1], 10) || 0,
+ b.at[0] === "right" ? n.left += l: b.at[0] === e && (n.left += l / 2),
+ b.at[1] === "bottom" ? n.top += m: b.at[1] === e && (n.top += m / 2),
+ n.left += k[0],
+ n.top += k[1];
+ return this.each(function() {
+ var c = a(this),
+ d = c.outerWidth(),
+ g = c.outerHeight(),
+ h = parseInt(a.curCSS(this, "marginLeft", !0)) || 0,
+ i = parseInt(a.curCSS(this, "marginTop", !0)) || 0,
+ o = d + h + (parseInt(a.curCSS(this, "marginRight", !0)) || 0),
+ p = g + i + (parseInt(a.curCSS(this, "marginBottom", !0)) || 0),
+ q = a.extend({},
+ n),
+ r;
+ b.my[0] === "right" ? q.left -= d: b.my[0] === e && (q.left -= d / 2),
+ b.my[1] === "bottom" ? q.top -= g: b.my[1] === e && (q.top -= g / 2),
+ f.fractions || (q.left = Math.round(q.left), q.top = Math.round(q.top)),
+ r = {
+ left: q.left - h,
+ top: q.top - i
+ },
+ a.each(["left", "top"],
+ function(c, e) {
+ a.ui.position[j[c]] && a.ui.position[j[c]][e](q, {
+ targetWidth: l,
+ targetHeight: m,
+ elemWidth: d,
+ elemHeight: g,
+ collisionPosition: r,
+ collisionWidth: o,
+ collisionHeight: p,
+ offset: k,
+ my: b.my,
+ at: b.at
+ })
+ }),
+ a.fn.bgiframe && c.bgiframe(),
+ c.offset(a.extend(q, {
+ using: b.using
+ }))
+ })
+ },
+ a.ui.position = {
+ fit: {
+ left: function(b, c) {
+ var d = a(window),
+ e = c.collisionPosition.left + c.collisionWidth - d.width() - d.scrollLeft();
+ b.left = e > 0 ? b.left - e: Math.max(b.left - c.collisionPosition.left, b.left)
+ },
+ top: function(b, c) {
+ var d = a(window),
+ e = c.collisionPosition.top + c.collisionHeight - d.height() - d.scrollTop();
+ b.top = e > 0 ? b.top - e: Math.max(b.top - c.collisionPosition.top, b.top)
+ }
+ },
+ flip: {
+ left: function(b, c) {
+ if (c.at[0] !== e) {
+ var d = a(window),
+ f = c.collisionPosition.left + c.collisionWidth - d.width() - d.scrollLeft(),
+ g = c.my[0] === "left" ? -c.elemWidth: c.my[0] === "right" ? c.elemWidth: 0,
+ h = c.at[0] === "left" ? c.targetWidth: -c.targetWidth,
+ i = -2 * c.offset[0];
+ b.left += c.collisionPosition.left < 0 ? g + h + i: f > 0 ? g + h + i: 0
+ }
+ },
+ top: function(b, c) {
+ if (c.at[1] !== e) {
+ var d = a(window),
+ f = c.collisionPosition.top + c.collisionHeight - d.height() - d.scrollTop(),
+ g = c.my[1] === "top" ? -c.elemHeight: c.my[1] === "bottom" ? c.elemHeight: 0,
+ h = c.at[1] === "top" ? c.targetHeight: -c.targetHeight,
+ i = -2 * c.offset[1];
+ b.top += c.collisionPosition.top < 0 ? g + h + i: f > 0 ? g + h + i: 0
+ }
+ }
+ }
+ },
+ a.offset.setOffset || (a.offset.setOffset = function(b, c) { / static / .test(a.curCSS(b, "position")) && (b.style.position = "relative");
+ var d = a(b),
+ e = d.offset(),
+ f = parseInt(a.curCSS(b, "top", !0), 10) || 0,
+ g = parseInt(a.curCSS(b, "left", !0), 10) || 0,
+ h = {
+ top: c.top - e.top + f,
+ left: c.left - e.left + g
+ };
+ "using" in c ? c.using.call(b, h) : d.css(h)
+ },
+ a.fn.offset = function(b) {
+ var c = this[0];
+ if (!c || !c.ownerDocument) return null;
+ if (b) return this.each(function() {
+ a.offset.setOffset(this, b)
+ });
+ return h.call(this)
+ }),
+ function() {
+ var b = document.getElementsByTagName("body")[0],
+ c = document.createElement("div"),
+ d,
+ e,
+ g,
+ h,
+ i;
+ d = document.createElement(b ? "div": "body"),
+ g = {
+ visibility: "hidden",
+ width: 0,
+ height: 0,
+ border: 0,
+ margin: 0,
+ background: "none"
+ },
+ b && a.extend(g, {
+ position: "absolute",
+ left: "-1000px",
+ top: "-1000px"
+ });
+ for (var j in g) d.style[j] = g[j];
+ d.appendChild(c),
+ e = b || document.documentElement,
+ e.insertBefore(d, e.firstChild),
+ c.style.cssText = "position: absolute; left: 10.7432222px; top: 10.432325px; height: 30px; width: 201px;",
+ h = a(c).offset(function(a, b) {
+ return b
+ }).offset(),
+ d.innerHTML = "",
+ e.removeChild(d),
+ i = h.top + h.left + (b ? 2e3: 0),
+ f.fractions = i > 21 && i < 22
+ } ()
+})(jQuery);
+/*
+ * jQuery UI Draggable 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Draggables
+ *
+ * Depends:
+ * jquery.ui.core.js
+ * jquery.ui.mouse.js
+ * jquery.ui.widget.js
+ */
+(function(a, b) {
+ a.widget("ui.draggable", a.ui.mouse, {
+ widgetEventPrefix: "drag",
+ options: {
+ addClasses: !0,
+ appendTo: "parent",
+ axis: !1,
+
+ connectToSortable: !1,
+ containment: !1,
+ cursor: "auto",
+ cursorAt: !1,
+ grid: !1,
+ handle: !1,
+ helper: "original",
+ iframeFix: !1,
+ opacity: !1,
+ refreshPositions: !1,
+ revert: !1,
+ revertDuration: 500,
+ scope: "default",
+ scroll: !0,
+ scrollSensitivity: 20,
+ scrollSpeed: 20,
+ snap: !1,
+ snapMode: "both",
+ snapTolerance: 20,
+ stack: !1,
+ zIndex: !1
+ },
+ _create: function() {
+ this.options.helper == "original" && !/^(?:r|a|f)/.test(this.element.css("position")) && (this.element[0].style.position = "relative"),
+ this.options.addClasses && this.element.addClass("ui-draggable"),
+ this.options.disabled && this.element.addClass("ui-draggable-disabled"),
+ this._mouseInit()
+ },
+ destroy: function() {
+ if ( !! this.element.data("draggable")) {
+ this.element.removeData("draggable").unbind(".draggable").removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled"),
+ this._mouseDestroy();
+ return this
+ }
+ },
+ _mouseCapture: function(b) {
+ var c = this.options;
+ if (this.helper || c.disabled || a(b.target).is(".ui-resizable-handle")) return ! 1;
+ this.handle = this._getHandle(b);
+ if (!this.handle) return ! 1;
+ c.iframeFix && a(c.iframeFix === !0 ? "iframe": c.iframeFix).each(function() {
+ a('<div class="ui-draggable-iframeFix" style="background: #fff;"></div>').css({
+ width: this.offsetWidth + "px",
+ height: this.offsetHeight + "px",
+ position: "absolute",
+ opacity: "0.001",
+ zIndex: 1e3
+ }).css(a(this).offset()).appendTo("body")
+ });
+ return ! 0
+ },
+ _mouseStart: function(b) {
+ var c = this.options;
+ this.helper = this._createHelper(b),
+ this._cacheHelperProportions(),
+ a.ui.ddmanager && (a.ui.ddmanager.current = this),
+ this._cacheMargins(),
+ this.cssPosition = this.helper.css("position"),
+ this.scrollParent = this.helper.scrollParent(),
+ this.offset = this.positionAbs = this.element.offset(),
+ this.offset = {
+ top: this.offset.top - this.margins.top,
+ left: this.offset.left - this.margins.left
+ },
+ a.extend(this.offset, {
+ click: {
+ left: b.pageX - this.offset.left,
+ top: b.pageY - this.offset.top
+ },
+ parent: this._getParentOffset(),
+ relative: this._getRelativeOffset()
+ }),
+ this.originalPosition = this.position = this._generatePosition(b),
+ this.originalPageX = b.pageX,
+ this.originalPageY = b.pageY,
+ c.cursorAt && this._adjustOffsetFromHelper(c.cursorAt),
+ c.containment && this._setContainment();
+ if (this._trigger("start", b) === !1) {
+ this._clear();
+ return ! 1
+ }
+ this._cacheHelperProportions(),
+ a.ui.ddmanager && !c.dropBehaviour && a.ui.ddmanager.prepareOffsets(this, b),
+ this.helper.addClass("ui-draggable-dragging"),
+ this._mouseDrag(b, !0),
+ a.ui.ddmanager && a.ui.ddmanager.dragStart(this, b);
+ return ! 0
+ },
+ _mouseDrag: function(b, c) {
+ this.position = this._generatePosition(b),
+ this.positionAbs = this._convertPositionTo("absolute");
+ if (!c) {
+ var d = this._uiHash();
+ if (this._trigger("drag", b, d) === !1) {
+ this._mouseUp({});
+ return ! 1
+ }
+ this.position = d.position
+ }
+ if (!this.options.axis || this.options.axis != "y") this.helper[0].style.left = this.position.left + "px";
+ if (!this.options.axis || this.options.axis != "x") this.helper[0].style.top = this.position.top + "px";
+ a.ui.ddmanager && a.ui.ddmanager.drag(this, b);
+ return ! 1
+ },
+ _mouseStop: function(b) {
+ var c = !1;
+ a.ui.ddmanager && !this.options.dropBehaviour && (c = a.ui.ddmanager.drop(this, b)),
+ this.dropped && (c = this.dropped, this.dropped = !1);
+ if ((!this.element[0] || !this.element[0].parentNode) && this.options.helper == "original") return ! 1;
+ if (this.options.revert == "invalid" && !c || this.options.revert == "valid" && c || this.options.revert === !0 || a.isFunction(this.options.revert) && this.options.revert.call(this.element, c)) {
+ var d = this;
+ a(this.helper).animate(this.originalPosition, parseInt(this.options.revertDuration, 10),
+ function() {
+ d._trigger("stop", b) !== !1 && d._clear()
+ })
+ } else this._trigger("stop", b) !== !1 && this._clear();
+ return ! 1
+ },
+ _mouseUp: function(b) {
+ this.options.iframeFix === !0 && a("div.ui-draggable-iframeFix").each(function() {
+ this.parentNode.removeChild(this)
+ }),
+ a.ui.ddmanager && a.ui.ddmanager.dragStop(this, b);
+ return a.ui.mouse.prototype._mouseUp.call(this, b)
+ },
+ cancel: function() {
+ this.helper.is(".ui-draggable-dragging") ? this._mouseUp({}) : this._clear();
+ return this
+ },
+ _getHandle: function(b) {
+ var c = !this.options.handle || !a(this.options.handle, this.element).length ? !0 : !1;
+ a(this.options.handle, this.element).find("*").andSelf().each(function() {
+ this == b.target && (c = !0)
+ });
+ return c
+ },
+ _createHelper: function(b) {
+ var c = this.options,
+ d = a.isFunction(c.helper) ? a(c.helper.apply(this.element[0], [b])) : c.helper == "clone" ? this.element.clone().removeAttr("id") : this.element;
+ d.parents("body").length || d.appendTo(c.appendTo == "parent" ? this.element[0].parentNode: c.appendTo),
+ d[0] != this.element[0] && !/(fixed|absolute)/.test(d.css("position")) && d.css("position", "absolute");
+ return d
+ },
+ _adjustOffsetFromHelper: function(b) {
+ typeof b == "string" && (b = b.split(" ")),
+ a.isArray(b) && (b = {
+ left: +b[0],
+ top: +b[1] || 0
+ }),
+ "left" in b && (this.offset.click.left = b.left + this.margins.left),
+ "right" in b && (this.offset.click.left = this.helperProportions.width - b.right + this.margins.left),
+ "top" in b && (this.offset.click.top = b.top + this.margins.top),
+ "bottom" in b && (this.offset.click.top = this.helperProportions.height - b.bottom + this.margins.top)
+ },
+ _getParentOffset: function() {
+ this.offsetParent = this.helper.offsetParent();
+ var b = this.offsetParent.offset();
+ this.cssPosition == "absolute" && this.scrollParent[0] != document && a.ui.contains(this.scrollParent[0], this.offsetParent[0]) && (b.left += this.scrollParent.scrollLeft(), b.top += this.scrollParent.scrollTop());
+ if (this.offsetParent[0] == document.body || this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() == "html" && a.browser.msie) b = {
+ top: 0,
+ left: 0
+ };
+ return {
+ top: b.top + (parseInt(this.offsetParent.css("borderTopWidth"), 10) || 0),
+ left: b.left + (parseInt(this.offsetParent.css("borderLeftWidth"), 10) || 0)
+ }
+ },
+ _getRelativeOffset: function() {
+ if (this.cssPosition == "relative") {
+ var a = this.element.position();
+ return {
+ top: a.top - (parseInt(this.helper.css("top"), 10) || 0) + this.scrollParent.scrollTop(),
+ left: a.left - (parseInt(this.helper.css("left"), 10) || 0) + this.scrollParent.scrollLeft()
+ }
+ }
+ return {
+ top: 0,
+ left: 0
+ }
+ },
+ _cacheMargins: function() {
+ this.margins = {
+ left: parseInt(this.element.css("marginLeft"), 10) || 0,
+ top: parseInt(this.element.css("marginTop"), 10) || 0,
+ right: parseInt(this.element.css("marginRight"), 10) || 0,
+ bottom: parseInt(this.element.css("marginBottom"), 10) || 0
+ }
+ },
+ _cacheHelperProportions: function() {
+ this.helperProportions = {
+ width: this.helper.outerWidth(),
+ height: this.helper.outerHeight()
+ }
+ },
+ _setContainment: function() {
+ var b = this.options;
+ b.containment == "parent" && (b.containment = this.helper[0].parentNode);
+ if (b.containment == "document" || b.containment == "window") this.containment = [b.containment == "document" ? 0 : a(window).scrollLeft() - this.offset.relative.left - this.offset.parent.left, b.containment == "document" ? 0 : a(window).scrollTop() - this.offset.relative.top - this.offset.parent.top, (b.containment == "document" ? 0 : a(window).scrollLeft()) + a(b.containment == "document" ? document: window).width() - this.helperProportions.width - this.margins.left, (b.containment == "document" ? 0 : a(window).scrollTop()) + (a(b.containment == "document" ? document: window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top];
+ if (!/^(document|window|parent)$/.test(b.containment) && b.containment.constructor != Array) {
+ var c = a(b.containment),
+ d = c[0];
+ if (!d) return;
+ var e = c.offset(),
+ f = a(d).css("overflow") != "hidden";
+ this.containment = [(parseInt(a(d).css("borderLeftWidth"), 10) || 0) + (parseInt(a(d).css("paddingLeft"), 10) || 0), (parseInt(a(d).css("borderTopWidth"), 10) || 0) + (parseInt(a(d).css("paddingTop"), 10) || 0), (f ? Math.max(d.scrollWidth, d.offsetWidth) : d.offsetWidth) - (parseInt(a(d).css("borderLeftWidth"), 10) || 0) - (parseInt(a(d).css("paddingRight"), 10) || 0) - this.helperProportions.width - this.margins.left - this.margins.right, (f ? Math.max(d.scrollHeight, d.offsetHeight) : d.offsetHeight) - (parseInt(a(d).css("borderTopWidth"), 10) || 0) - (parseInt(a(d).css("paddingBottom"), 10) || 0) - this.helperProportions.height - this.margins.top - this.margins.bottom],
+ this.relative_container = c
+ } else b.containment.constructor == Array && (this.containment = b.containment)
+ },
+ _convertPositionTo: function(b, c) {
+ c || (c = this.position);
+ var d = b == "absolute" ? 1 : -1,
+ e = this.options,
+ f = this.cssPosition == "absolute" && (this.scrollParent[0] == document || !a.ui.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent: this.scrollParent,
+ g = /(html|body)/i.test(f[0].tagName);
+ return {
+ top: c.top + this.offset.relative.top * d + this.offset.parent.top * d - (a.browser.safari && a.browser.version < 526 && this.cssPosition == "fixed" ? 0 : (this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : g ? 0 : f.scrollTop()) * d),
+ left: c.left + this.offset.relative.left * d + this.offset.parent.left * d - (a.browser.safari && a.browser.version < 526 && this.cssPosition == "fixed" ? 0 : (this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : g ? 0 : f.scrollLeft()) * d)
+ }
+ },
+ _generatePosition: function(b) {
+ var c = this.options,
+ d = this.cssPosition == "absolute" && (this.scrollParent[0] == document || !a.ui.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent: this.scrollParent,
+ e = /(html|body)/i.test(d[0].tagName),
+ f = b.pageX,
+ g = b.pageY;
+ if (this.originalPosition) {
+ var h;
+ if (this.containment) {
+ if (this.relative_container) {
+ var i = this.relative_container.offset();
+ h = [this.containment[0] + i.left, this.containment[1] + i.top, this.containment[2] + i.left, this.containment[3] + i.top]
+ } else h = this.containment;
+ b.pageX - this.offset.click.left < h[0] && (f = h[0] + this.offset.click.left),
+ b.pageY - this.offset.click.top < h[1] && (g = h[1] + this.offset.click.top),
+ b.pageX - this.offset.click.left > h[2] && (f = h[2] + this.offset.click.left),
+ b.pageY - this.offset.click.top > h[3] && (g = h[3] + this.offset.click.top)
+ }
+ if (c.grid) {
+ var j = c.grid[1] ? this.originalPageY + Math.round((g - this.originalPageY) / c.grid[1]) * c.grid[1] : this.originalPageY;
+ g = h ? j - this.offset.click.top < h[1] || j - this.offset.click.top > h[3] ? j - this.offset.click.top < h[1] ? j + c.grid[1] : j - c.grid[1] : j: j;
+ var k = c.grid[0] ? this.originalPageX + Math.round((f - this.originalPageX) / c.grid[0]) * c.grid[0] : this.originalPageX;
+ f = h ? k - this.offset.click.left < h[0] || k - this.offset.click.left > h[2] ? k - this.offset.click.left < h[0] ? k + c.grid[0] : k - c.grid[0] : k: k
+ }
+ }
+ return {
+ top: g - this.offset.click.top - this.offset.relative.top - this.offset.parent.top + (a.browser.safari && a.browser.version < 526 && this.cssPosition == "fixed" ? 0 : this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : e ? 0 : d.scrollTop()),
+ left: f - this.offset.click.left - this.offset.relative.left - this.offset.parent.left + (a.browser.safari && a.browser.version < 526 && this.cssPosition == "fixed" ? 0 : this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : e ? 0 : d.scrollLeft())
+ }
+ },
+ _clear: function() {
+ this.helper.removeClass("ui-draggable-dragging"),
+ this.helper[0] != this.element[0] && !this.cancelHelperRemoval && this.helper.remove(),
+ this.helper = null,
+ this.cancelHelperRemoval = !1
+ },
+ _trigger: function(b, c, d) {
+ d = d || this._uiHash(),
+ a.ui.plugin.call(this, b, [c, d]),
+ b == "drag" && (this.positionAbs = this._convertPositionTo("absolute"));
+ return a.Widget.prototype._trigger.call(this, b, c, d)
+ },
+ plugins: {},
+ _uiHash: function(a) {
+ return {
+ helper: this.helper,
+ position: this.position,
+ originalPosition: this.originalPosition,
+ offset: this.positionAbs
+ }
+ }
+ }),
+ a.extend(a.ui.draggable, {
+ version: "1.8.18"
+ }),
+ a.ui.plugin.add("draggable", "connectToSortable", {
+ start: function(b, c) {
+ var d = a(this).data("draggable"),
+ e = d.options,
+ f = a.extend({},
+ c, {
+ item: d.element
+ });
+ d.sortables = [],
+ a(e.connectToSortable).each(function() {
+ var c = a.data(this, "sortable");
+ c && !c.options.disabled && (d.sortables.push({
+ instance: c,
+ shouldRevert: c.options.revert
+ }), c.refreshPositions(), c._trigger("activate", b, f))
+ })
+ },
+ stop: function(b, c) {
+ var d = a(this).data("draggable"),
+ e = a.extend({},
+ c, {
+ item: d.element
+ });
+ a.each(d.sortables,
+ function() {
+ this.instance.isOver ? (this.instance.isOver = 0, d.cancelHelperRemoval = !0, this.instance.cancelHelperRemoval = !1, this.shouldRevert && (this.instance.options.revert = !0), this.instance._mouseStop(b), this.instance.options.helper = this.instance.options._helper, d.options.helper == "original" && this.instance.currentItem.css({
+ top: "auto",
+ left: "auto"
+ })) : (this.instance.cancelHelperRemoval = !1, this.instance._trigger("deactivate", b, e))
+ })
+ },
+ drag: function(b, c) {
+ var d = a(this).data("draggable"),
+ e = this,
+ f = function(b) {
+ var c = this.offset.click.top,
+ d = this.offset.click.left,
+ e = this.positionAbs.top,
+ f = this.positionAbs.left,
+ g = b.height,
+ h = b.width,
+ i = b.top,
+ j = b.left;
+ return a.ui.isOver(e + c, f + d, i, j, g, h)
+ };
+ a.each(d.sortables,
+ function(f) {
+ this.instance.positionAbs = d.positionAbs,
+ this.instance.helperProportions = d.helperProportions,
+ this.instance.offset.click = d.offset.click,
+ this.instance._intersectsWith(this.instance.containerCache) ? (this.instance.isOver || (this.instance.isOver = 1, this.instance.currentItem = a(e).clone().removeAttr("id").appendTo(this.instance.element).data("sortable-item", !0), this.instance.options._helper = this.instance.options.helper, this.instance.options.helper = function() {
+ return c.helper[0]
+ },
+ b.target = this.instance.currentItem[0], this.instance._mouseCapture(b, !0), this.instance._mouseStart(b, !0, !0), this.instance.offset.click.top = d.offset.click.top, this.instance.offset.click.left = d.offset.click.left, this.instance.offset.parent.left -= d.offset.parent.left - this.instance.offset.parent.left, this.instance.offset.parent.top -= d.offset.parent.top - this.instance.offset.parent.top, d._trigger("toSortable", b), d.dropped = this.instance.element, d.currentItem = d.element, this.instance.fromOutside = d), this.instance.currentItem && this.instance._mouseDrag(b)) : this.instance.isOver && (this.instance.isOver = 0, this.instance.cancelHelperRemoval = !0, this.instance.options.revert = !1, this.instance._trigger("out", b, this.instance._uiHash(this.instance)), this.instance._mouseStop(b, !0), this.instance.options.helper = this.instance.options._helper, this.instance.currentItem.remove(), this.instance.placeholder && this.instance.placeholder.remove(), d._trigger("fromSortable", b), d.dropped = !1)
+ })
+ }
+ }),
+ a.ui.plugin.add("draggable", "cursor", {
+ start: function(b, c) {
+ var d = a("body"),
+ e = a(this).data("draggable").options;
+ d.css("cursor") && (e._cursor = d.css("cursor")),
+ d.css("cursor", e.cursor)
+ },
+ stop: function(b, c) {
+ var d = a(this).data("draggable").options;
+ d._cursor && a("body").css("cursor", d._cursor)
+ }
+ }),
+ a.ui.plugin.add("draggable", "opacity", {
+ start: function(b, c) {
+ var d = a(c.helper),
+ e = a(this).data("draggable").options;
+ d.css("opacity") && (e._opacity = d.css("opacity")),
+ d.css("opacity", e.opacity)
+ },
+ stop: function(b, c) {
+ var d = a(this).data("draggable").options;
+ d._opacity && a(c.helper).css("opacity", d._opacity)
+ }
+ }),
+ a.ui.plugin.add("draggable", "scroll", {
+ start: function(b, c) {
+ var d = a(this).data("draggable");
+ d.scrollParent[0] != document && d.scrollParent[0].tagName != "HTML" && (d.overflowOffset = d.scrollParent.offset())
+ },
+ drag: function(b, c) {
+ var d = a(this).data("draggable"),
+ e = d.options,
+ f = !1;
+ if (d.scrollParent[0] != document && d.scrollParent[0].tagName != "HTML") {
+ if (!e.axis || e.axis != "x") d.overflowOffset.top + d.scrollParent[0].offsetHeight - b.pageY < e.scrollSensitivity ? d.scrollParent[0].scrollTop = f = d.scrollParent[0].scrollTop + e.scrollSpeed: b.pageY - d.overflowOffset.top < e.scrollSensitivity && (d.scrollParent[0].scrollTop = f = d.scrollParent[0].scrollTop - e.scrollSpeed);
+ if (!e.axis || e.axis != "y") d.overflowOffset.left + d.scrollParent[0].offsetWidth - b.pageX < e.scrollSensitivity ? d.scrollParent[0].scrollLeft = f = d.scrollParent[0].scrollLeft + e.scrollSpeed: b.pageX - d.overflowOffset.left < e.scrollSensitivity && (d.scrollParent[0].scrollLeft = f = d.scrollParent[0].scrollLeft - e.scrollSpeed)
+ } else {
+ if (!e.axis || e.axis != "x") b.pageY - a(document).scrollTop() < e.scrollSensitivity ? f = a(document).scrollTop(a(document).scrollTop() - e.scrollSpeed) : a(window).height() - (b.pageY - a(document).scrollTop()) < e.scrollSensitivity && (f = a(document).scrollTop(a(document).scrollTop() + e.scrollSpeed));
+ if (!e.axis || e.axis != "y") b.pageX - a(document).scrollLeft() < e.scrollSensitivity ? f = a(document).scrollLeft(a(document).scrollLeft() - e.scrollSpeed) : a(window).width() - (b.pageX - a(document).scrollLeft()) < e.scrollSensitivity && (f = a(document).scrollLeft(a(document).scrollLeft() + e.scrollSpeed))
+ }
+ f !== !1 && a.ui.ddmanager && !e.dropBehaviour && a.ui.ddmanager.prepareOffsets(d, b)
+ }
+ }),
+ a.ui.plugin.add("draggable", "snap", {
+ start: function(b, c) {
+ var d = a(this).data("draggable"),
+ e = d.options;
+ d.snapElements = [],
+ a(e.snap.constructor != String ? e.snap.items || ":data(draggable)": e.snap).each(function() {
+ var b = a(this),
+ c = b.offset();
+ this != d.element[0] && d.snapElements.push({
+ item: this,
+ width: b.outerWidth(),
+ height: b.outerHeight(),
+ top: c.top,
+ left: c.left
+ })
+ })
+ },
+ drag: function(b, c) {
+ var d = a(this).data("draggable"),
+ e = d.options,
+ f = e.snapTolerance,
+ g = c.offset.left,
+ h = g + d.helperProportions.width,
+ i = c.offset.top,
+ j = i + d.helperProportions.height;
+ for (var k = d.snapElements.length - 1; k >= 0; k--) {
+ var l = d.snapElements[k].left,
+ m = l + d.snapElements[k].width,
+ n = d.snapElements[k].top,
+ o = n + d.snapElements[k].height;
+ if (! (l - f < g && g < m + f && n - f < i && i < o + f || l - f < g && g < m + f && n - f < j && j < o + f || l - f < h && h < m + f && n - f < i && i < o + f || l - f < h && h < m + f && n - f < j && j < o + f)) {
+ d.snapElements[k].snapping && d.options.snap.release && d.options.snap.release.call(d.element, b, a.extend(d._uiHash(), {
+ snapItem: d.snapElements[k].item
+ })),
+ d.snapElements[k].snapping = !1;
+ continue
+ }
+ if (e.snapMode != "inner") {
+ var p = Math.abs(n - j) <= f,
+ q = Math.abs(o - i) <= f,
+ r = Math.abs(l - h) <= f,
+ s = Math.abs(m - g) <= f;
+ p && (c.position.top = d._convertPositionTo("relative", {
+ top: n - d.helperProportions.height,
+ left: 0
+ }).top - d.margins.top),
+ q && (c.position.top = d._convertPositionTo("relative", {
+ top: o,
+ left: 0
+ }).top - d.margins.top),
+ r && (c.position.left = d._convertPositionTo("relative", {
+ top: 0,
+ left: l - d.helperProportions.width
+ }).left - d.margins.left),
+ s && (c.position.left = d._convertPositionTo("relative", {
+ top: 0,
+ left: m
+ }).left - d.margins.left)
+ }
+ var t = p || q || r || s;
+ if (e.snapMode != "outer") {
+ var p = Math.abs(n - i) <= f,
+ q = Math.abs(o - j) <= f,
+ r = Math.abs(l - g) <= f,
+ s = Math.abs(m - h) <= f;
+ p && (c.position.top = d._convertPositionTo("relative", {
+ top: n,
+ left: 0
+ }).top - d.margins.top),
+ q && (c.position.top = d._convertPositionTo("relative", {
+ top: o - d.helperProportions.height,
+ left: 0
+ }).top - d.margins.top),
+ r && (c.position.left = d._convertPositionTo("relative", {
+ top: 0,
+ left: l
+ }).left - d.margins.left),
+ s && (c.position.left = d._convertPositionTo("relative", {
+ top: 0,
+ left: m - d.helperProportions.width
+ }).left - d.margins.left)
+ } ! d.snapElements[k].snapping && (p || q || r || s || t) && d.options.snap.snap && d.options.snap.snap.call(d.element, b, a.extend(d._uiHash(), {
+ snapItem: d.snapElements[k].item
+ })),
+ d.snapElements[k].snapping = p || q || r || s || t
+ }
+ }
+ }),
+ a.ui.plugin.add("draggable", "stack", {
+ start: function(b, c) {
+ var d = a(this).data("draggable").options,
+ e = a.makeArray(a(d.stack)).sort(function(b, c) {
+ return (parseInt(a(b).css("zIndex"), 10) || 0) - (parseInt(a(c).css("zIndex"), 10) || 0)
+ });
+ if ( !! e.length) {
+ var f = parseInt(e[0].style.zIndex) || 0;
+ a(e).each(function(a) {
+ this.style.zIndex = f + a
+ }),
+ this[0].style.zIndex = f + e.length
+ }
+ }
+ }),
+ a.ui.plugin.add("draggable", "zIndex", {
+ start: function(b, c) {
+ var d = a(c.helper),
+ e = a(this).data("draggable").options;
+ d.css("zIndex") && (e._zIndex = d.css("zIndex")),
+ d.css("zIndex", e.zIndex)
+ },
+ stop: function(b, c) {
+ var d = a(this).data("draggable").options;
+ d._zIndex && a(c.helper).css("zIndex", d._zIndex)
+ }
+ })
+})(jQuery);
+/*
+ * jQuery UI Droppable 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Droppables
+ *
+ * Depends:
+ * jquery.ui.core.js
+ * jquery.ui.widget.js
+ * jquery.ui.mouse.js
+ * jquery.ui.draggable.js
+ */
+(function(a, b) {
+ a.widget("ui.droppable", {
+ widgetEventPrefix: "drop",
+ options: {
+ accept: "*",
+ activeClass: !1,
+ addClasses: !0,
+ greedy: !1,
+ hoverClass: !1,
+ scope: "default",
+ tolerance: "intersect"
+ },
+ _create: function() {
+ var b = this.options,
+ c = b.accept;
+ this.isover = 0,
+ this.isout = 1,
+ this.accept = a.isFunction(c) ? c: function(a) {
+ return a.is(c)
+ },
+ this.proportions = {
+ width: this.element[0].offsetWidth,
+ height: this.element[0].offsetHeight
+ },
+ a.ui.ddmanager.droppables[b.scope] = a.ui.ddmanager.droppables[b.scope] || [],
+ a.ui.ddmanager.droppables[b.scope].push(this),
+ b.addClasses && this.element.addClass("ui-droppable")
+ },
+ destroy: function() {
+ var b = a.ui.ddmanager.droppables[this.options.scope];
+ for (var c = 0; c < b.length; c++) b[c] == this && b.splice(c, 1);
+ this.element.removeClass("ui-droppable ui-droppable-disabled").removeData("droppable").unbind(".droppable");
+ return this
+ },
+ _setOption: function(b, c) {
+ b == "accept" && (this.accept = a.isFunction(c) ? c: function(a) {
+ return a.is(c)
+ }),
+ a.Widget.prototype._setOption.apply(this, arguments)
+ },
+ _activate: function(b) {
+ var c = a.ui.ddmanager.current;
+ this.options.activeClass && this.element.addClass(this.options.activeClass),
+ c && this._trigger("activate", b, this.ui(c))
+ },
+ _deactivate: function(b) {
+ var c = a.ui.ddmanager.current;
+ this.options.activeClass && this.element.removeClass(this.options.activeClass),
+ c && this._trigger("deactivate", b, this.ui(c))
+ },
+ _over: function(b) {
+ var c = a.ui.ddmanager.current; !! c && (c.currentItem || c.element)[0] != this.element[0] && this.accept.call(this.element[0], c.currentItem || c.element) && (this.options.hoverClass && this.element.addClass(this.options.hoverClass), this._trigger("over", b, this.ui(c)))
+ },
+ _out: function(b) {
+ var c = a.ui.ddmanager.current; !! c && (c.currentItem || c.element)[0] != this.element[0] && this.accept.call(this.element[0], c.currentItem || c.element) && (this.options.hoverClass && this.element.removeClass(this.options.hoverClass), this._trigger("out", b, this.ui(c)))
+ },
+ _drop: function(b, c) {
+ var d = c || a.ui.ddmanager.current;
+ if (!d || (d.currentItem || d.element)[0] == this.element[0]) return ! 1;
+ var e = !1;
+ this.element.find(":data(droppable)").not(".ui-draggable-dragging").each(function() {
+ var b = a.data(this, "droppable");
+ if (b.options.greedy && !b.options.disabled && b.options.scope == d.options.scope && b.accept.call(b.element[0], d.currentItem || d.element) && a.ui.intersect(d, a.extend(b, {
+ offset: b.element.offset()
+ }), b.options.tolerance)) {
+ e = !0;
+ return ! 1
+ }
+ });
+ if (e) return ! 1;
+ if (this.accept.call(this.element[0], d.currentItem || d.element)) {
+ this.options.activeClass && this.element.removeClass(this.options.activeClass),
+ this.options.hoverClass && this.element.removeClass(this.options.hoverClass),
+ this._trigger("drop", b, this.ui(d));
+ return this.element
+ }
+ return ! 1
+ },
+ ui: function(a) {
+ return {
+ draggable: a.currentItem || a.element,
+ helper: a.helper,
+ position: a.position,
+ offset: a.positionAbs
+ }
+ }
+ }),
+ a.extend(a.ui.droppable, {
+ version: "1.8.18"
+ }),
+ a.ui.intersect = function(b, c, d) {
+ if (!c.offset) return ! 1;
+ var e = (b.positionAbs || b.position.absolute).left,
+ f = e + b.helperProportions.width,
+ g = (b.positionAbs || b.position.absolute).top,
+ h = g + b.helperProportions.height,
+ i = c.offset.left,
+ j = i + c.proportions.width,
+ k = c.offset.top,
+ l = k + c.proportions.height;
+ switch (d) {
+ case "fit":
+ return i <= e && f <= j && k <= g && h <= l;
+ case "intersect":
+ return i < e + b.helperProportions.width / 2 && f - b.helperProportions.width / 2 < j && k < g + b.helperProportions.height / 2 && h - b.helperProportions.height / 2 < l;
+ case "pointer":
+ var m = (b.positionAbs || b.position.absolute).left + (b.clickOffset || b.offset.click).left,
+ n = (b.positionAbs || b.position.absolute).top + (b.clickOffset || b.offset.click).top,
+ o = a.ui.isOver(n, m, k, i, c.proportions.height, c.proportions.width);
+ return o;
+ case "touch":
+ return (g >= k && g <= l || h >= k && h <= l || g < k && h > l) && (e >= i && e <= j || f >= i && f <= j || e < i && f > j);
+ default:
+ return ! 1
+ }
+ },
+ a.ui.ddmanager = {
+ current: null,
+ droppables: {
+ "default": []
+ },
+ prepareOffsets: function(b, c) {
+ var d = a.ui.ddmanager.droppables[b.options.scope] || [],
+ e = c ? c.type: null,
+ f = (b.currentItem || b.element).find(":data(droppable)").andSelf();
+ droppablesLoop: for (var g = 0; g < d.length; g++) {
+ if (d[g].options.disabled || b && !d[g].accept.call(d[g].element[0], b.currentItem || b.element)) continue;
+ for (var h = 0; h < f.length; h++) if (f[h] == d[g].element[0]) {
+ d[g].proportions.height = 0;
+ continue droppablesLoop
+ }
+ d[g].visible = d[g].element.css("display") != "none";
+ if (!d[g].visible) continue;
+ e == "mousedown" && d[g]._activate.call(d[g], c),
+ d[g].offset = d[g].element.offset(),
+ d[g].proportions = {
+ width: d[g].element[0].offsetWidth,
+ height: d[g].element[0].offsetHeight
+ }
+ }
+ },
+ drop: function(b, c) {
+ var d = !1;
+ a.each(a.ui.ddmanager.droppables[b.options.scope] || [],
+ function() { ! this.options || (!this.options.disabled && this.visible && a.ui.intersect(b, this, this.options.tolerance) && (d = this._drop.call(this, c) || d), !this.options.disabled && this.visible && this.accept.call(this.element[0], b.currentItem || b.element) && (this.isout = 1, this.isover = 0, this._deactivate.call(this, c)))
+ });
+ return d
+ },
+ dragStart: function(b, c) {
+ b.element.parents(":not(body,html)").bind("scroll.droppable",
+ function() {
+ b.options.refreshPositions || a.ui.ddmanager.prepareOffsets(b, c)
+ })
+ },
+ drag: function(b, c) {
+ b.options.refreshPositions && a.ui.ddmanager.prepareOffsets(b, c),
+ a.each(a.ui.ddmanager.droppables[b.options.scope] || [],
+ function() {
+ if (! (this.options.disabled || this.greedyChild || !this.visible)) {
+ var d = a.ui.intersect(b, this, this.options.tolerance),
+ e = !d && this.isover == 1 ? "isout": d && this.isover == 0 ? "isover": null;
+ if (!e) return;
+ var f;
+ if (this.options.greedy) {
+ var g = this.element.parents(":data(droppable):eq(0)");
+ g.length && (f = a.data(g[0], "droppable"), f.greedyChild = e == "isover" ? 1 : 0)
+ }
+ f && e == "isover" && (f.isover = 0, f.isout = 1, f._out.call(f, c)),
+ this[e] = 1,
+ this[e == "isout" ? "isover": "isout"] = 0,
+ this[e == "isover" ? "_over": "_out"].call(this, c),
+ f && e == "isout" && (f.isout = 0, f.isover = 1, f._over.call(f, c))
+ }
+ })
+ },
+ dragStop: function(b, c) {
+ b.element.parents(":not(body,html)").unbind("scroll.droppable"),
+ b.options.refreshPositions || a.ui.ddmanager.prepareOffsets(b, c)
+ }
+ }
+})(jQuery);
+/*
+ * jQuery UI Resizable 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Resizables
+ *
+ * Depends:
+ * jquery.ui.core.js
+ * jquery.ui.mouse.js
+ * jquery.ui.widget.js
+ */
+(function(a, b) {
+ a.widget("ui.resizable", a.ui.mouse, {
+ widgetEventPrefix: "resize",
+ options: {
+ alsoResize: !1,
+ animate: !1,
+ animateDuration: "slow",
+ animateEasing: "swing",
+ aspectRatio: !1,
+ autoHide: !1,
+ containment: !1,
+ ghost: !1,
+ grid: !1,
+ handles: "e,s,se",
+ helper: !1,
+ maxHeight: null,
+ maxWidth: null,
+ minHeight: 10,
+ minWidth: 10,
+ zIndex: 1e3
+ },
+ _create: function() {
+ var b = this,
+ c = this.options;
+ this.element.addClass("ui-resizable"),
+ a.extend(this, {
+ _aspectRatio: !!c.aspectRatio,
+ aspectRatio: c.aspectRatio,
+ originalElement: this.element,
+ _proportionallyResizeElements: [],
+ _helper: c.helper || c.ghost || c.animate ? c.helper || "ui-resizable-helper": null
+ }),
+ this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i) && (this.element.wrap(a('<div class="ui-wrapper" style="overflow: hidden;"></div>').css({
+ position: this.element.css("position"),
+ width: this.element.outerWidth(),
+ height: this.element.outerHeight(),
+ top: this.element.css("top"),
+ left: this.element.css("left")
+ })), this.element = this.element.parent().data("resizable", this.element.data("resizable")), this.elementIsWrapper = !0, this.element.css({
+ marginLeft: this.originalElement.css("marginLeft"),
+ marginTop: this.originalElement.css("marginTop"),
+ marginRight: this.originalElement.css("marginRight"),
+ marginBottom: this.originalElement.css("marginBottom")
+ }), this.originalElement.css({
+ marginLeft: 0,
+ marginTop: 0,
+ marginRight: 0,
+ marginBottom: 0
+ }), this.originalResizeStyle = this.originalElement.css("resize"), this.originalElement.css("resize", "none"), this._proportionallyResizeElements.push(this.originalElement.css({
+ position: "static",
+ zoom: 1,
+ display: "block"
+ })), this.originalElement.css({
+ margin: this.originalElement.css("margin")
+ }), this._proportionallyResize()),
+ this.handles = c.handles || (a(".ui-resizable-handle", this.element).length ? {
+ n: ".ui-resizable-n",
+ e: ".ui-resizable-e",
+ s: ".ui-resizable-s",
+ w: ".ui-resizable-w",
+ se: ".ui-resizable-se",
+ sw: ".ui-resizable-sw",
+ ne: ".ui-resizable-ne",
+ nw: ".ui-resizable-nw"
+ }: "e,s,se");
+ if (this.handles.constructor == String) {
+ this.handles == "all" && (this.handles = "n,e,s,w,se,sw,ne,nw");
+ var d = this.handles.split(",");
+ this.handles = {};
+ for (var e = 0; e < d.length; e++) {
+ var f = a.trim(d[e]),
+ g = "ui-resizable-" + f,
+ h = a('<div class="ui-resizable-handle ' + g + '"></div>');
+ /sw|se|ne|nw/.test(f) && h.css({
+ zIndex: ++c.zIndex
+ }),
+ "se" == f && h.addClass("ui-icon ui-icon-gripsmall-diagonal-se"),
+ this.handles[f] = ".ui-resizable-" + f,
+ this.element.append(h)
+ }
+ }
+ this._renderAxis = function(b) {
+ b = b || this.element;
+ for (var c in this.handles) {
+ this.handles[c].constructor == String && (this.handles[c] = a(this.handles[c], this.element).show());
+ if (this.elementIsWrapper && this.originalElement[0].nodeName.match(/textarea|input|select|button/i)) {
+ var d = a(this.handles[c], this.element),
+ e = 0;
+ e = /sw|ne|nw|se|n|s/.test(c) ? d.outerHeight() : d.outerWidth();
+ var f = ["padding", /ne|nw|n/.test(c) ? "Top": /se|sw|s/.test(c) ? "Bottom": /^e$/.test(c) ? "Right": "Left"].join("");
+ b.css(f, e),
+ this._proportionallyResize()
+ }
+ if (!a(this.handles[c]).length) continue
+ }
+ },
+ this._renderAxis(this.element),
+ this._handles = a(".ui-resizable-handle", this.element).disableSelection(),
+ this._handles.mouseover(function() {
+ if (!b.resizing) {
+ if (this.className) var a = this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i);
+ b.axis = a && a[1] ? a[1] : "se"
+ }
+ }),
+ c.autoHide && (this._handles.hide(), a(this.element).addClass("ui-resizable-autohide").hover(function() {
+ c.disabled || (a(this).removeClass("ui-resizable-autohide"), b._handles.show())
+ },
+ function() {
+ c.disabled || b.resizing || (a(this).addClass("ui-resizable-autohide"), b._handles.hide())
+ })),
+ this._mouseInit()
+ },
+ destroy: function() {
+ this._mouseDestroy();
+ var b = function(b) {
+ a(b).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").unbind(".resizable").find(".ui-resizable-handle").remove()
+ };
+ if (this.elementIsWrapper) {
+ b(this.element);
+ var c = this.element;
+ c.after(this.originalElement.css({
+ position: c.css("position"),
+ width: c.outerWidth(),
+ height: c.outerHeight(),
+ top: c.css("top"),
+ left: c.css("left")
+ })).remove()
+ }
+ this.originalElement.css("resize", this.originalResizeStyle),
+ b(this.originalElement);
+ return this
+ },
+ _mouseCapture: function(b) {
+ var c = !1;
+ for (var d in this.handles) a(this.handles[d])[0] == b.target && (c = !0);
+ return ! this.options.disabled && c
+ },
+ _mouseStart: function(b) {
+ var d = this.options,
+ e = this.element.position(),
+ f = this.element;
+ this.resizing = !0,
+ this.documentScroll = {
+ top: a(document).scrollTop(),
+ left: a(document).scrollLeft()
+ },
+ (f.is(".ui-draggable") || /absolute/.test(f.css("position"))) && f.css({
+ position: "absolute",
+ top: e.top,
+ left: e.left
+ }),
+ this._renderProxy();
+ var g = c(this.helper.css("left")),
+ h = c(this.helper.css("top"));
+ d.containment && (g += a(d.containment).scrollLeft() || 0, h += a(d.containment).scrollTop() || 0),
+ this.offset = this.helper.offset(),
+ this.position = {
+ left: g,
+ top: h
+ },
+ this.size = this._helper ? {
+ width: f.outerWidth(),
+ height: f.outerHeight()
+ }: {
+ width: f.width(),
+ height: f.height()
+ },
+ this.originalSize = this._helper ? {
+ width: f.outerWidth(),
+ height: f.outerHeight()
+ }: {
+ width: f.width(),
+ height: f.height()
+ },
+ this.originalPosition = {
+ left: g,
+ top: h
+ },
+ this.sizeDiff = {
+ width: f.outerWidth() - f.width(),
+ height: f.outerHeight() - f.height()
+ },
+ this.originalMousePosition = {
+ left: b.pageX,
+ top: b.pageY
+ },
+ this.aspectRatio = typeof d.aspectRatio == "number" ? d.aspectRatio: this.originalSize.width / this.originalSize.height || 1;
+ var i = a(".ui-resizable-" + this.axis).css("cursor");
+ a("body").css("cursor", i == "auto" ? this.axis + "-resize": i),
+ f.addClass("ui-resizable-resizing"),
+ this._propagate("start", b);
+ return ! 0
+ },
+ _mouseDrag: function(b) {
+ var c = this.helper,
+ d = this.options,
+ e = {},
+ f = this,
+ g = this.originalMousePosition,
+ h = this.axis,
+ i = b.pageX - g.left || 0,
+ j = b.pageY - g.top || 0,
+ k = this._change[h];
+ if (!k) return ! 1;
+ var l = k.apply(this, [b, i, j]),
+ m = a.browser.msie && a.browser.version < 7,
+ n = this.sizeDiff;
+ this._updateVirtualBoundaries(b.shiftKey);
+ if (this._aspectRatio || b.shiftKey) l = this._updateRatio(l, b);
+ l = this._respectSize(l, b),
+ this._propagate("resize", b),
+ c.css({
+ top: this.position.top + "px",
+ left: this.position.left + "px",
+ width: this.size.width + "px",
+ height: this.size.height + "px"
+ }),
+ !this._helper && this._proportionallyResizeElements.length && this._proportionallyResize(),
+ this._updateCache(l),
+ this._trigger("resize", b, this.ui());
+ return ! 1
+ },
+ _mouseStop: function(b) {
+ this.resizing = !1;
+ var c = this.options,
+ d = this;
+ if (this._helper) {
+ var e = this._proportionallyResizeElements,
+ f = e.length && /textarea/i.test(e[0].nodeName),
+ g = f && a.ui.hasScroll(e[0], "left") ? 0 : d.sizeDiff.height,
+ h = f ? 0 : d.sizeDiff.width,
+ i = {
+ width: d.helper.width() - h,
+ height: d.helper.height() - g
+ },
+ j = parseInt(d.element.css("left"), 10) + (d.position.left - d.originalPosition.left) || null,
+ k = parseInt(d.element.css("top"), 10) + (d.position.top - d.originalPosition.top) || null;
+ c.animate || this.element.css(a.extend(i, {
+ top: k,
+ left: j
+ })),
+ d.helper.height(d.size.height),
+ d.helper.width(d.size.width),
+ this._helper && !c.animate && this._proportionallyResize()
+ }
+ a("body").css("cursor", "auto"),
+ this.element.removeClass("ui-resizable-resizing"),
+ this._propagate("stop", b),
+ this._helper && this.helper.remove();
+ return ! 1
+ },
+ _updateVirtualBoundaries: function(a) {
+ var b = this.options,
+ c, e, f, g, h;
+ h = {
+ minWidth: d(b.minWidth) ? b.minWidth: 0,
+ maxWidth: d(b.maxWidth) ? b.maxWidth: Infinity,
+ minHeight: d(b.minHeight) ? b.minHeight: 0,
+ maxHeight: d(b.maxHeight) ? b.maxHeight: Infinity
+ };
+ if (this._aspectRatio || a) c = h.minHeight * this.aspectRatio,
+ f = h.minWidth / this.aspectRatio,
+ e = h.maxHeight * this.aspectRatio,
+ g = h.maxWidth / this.aspectRatio,
+ c > h.minWidth && (h.minWidth = c),
+ f > h.minHeight && (h.minHeight = f),
+ e < h.maxWidth && (h.maxWidth = e),
+ g < h.maxHeight && (h.maxHeight = g);
+ this._vBoundaries = h
+ },
+ _updateCache: function(a) {
+ var b = this.options;
+ this.offset = this.helper.offset(),
+ d(a.left) && (this.position.left = a.left),
+ d(a.top) && (this.position.top = a.top),
+ d(a.height) && (this.size.height = a.height),
+ d(a.width) && (this.size.width = a.width)
+ },
+ _updateRatio: function(a, b) {
+ var c = this.options,
+ e = this.position,
+ f = this.size,
+ g = this.axis;
+ d(a.height) ? a.width = a.height * this.aspectRatio: d(a.width) && (a.height = a.width / this.aspectRatio),
+ g == "sw" && (a.left = e.left + (f.width - a.width), a.top = null),
+ g == "nw" && (a.top = e.top + (f.height - a.height), a.left = e.left + (f.width - a.width));
+ return a
+ },
+ _respectSize: function(a, b) {
+ var c = this.helper,
+ e = this._vBoundaries,
+ f = this._aspectRatio || b.shiftKey,
+ g = this.axis,
+ h = d(a.width) && e.maxWidth && e.maxWidth < a.width,
+ i = d(a.height) && e.maxHeight && e.maxHeight < a.height,
+ j = d(a.width) && e.minWidth && e.minWidth > a.width,
+ k = d(a.height) && e.minHeight && e.minHeight > a.height;
+ j && (a.width = e.minWidth),
+ k && (a.height = e.minHeight),
+ h && (a.width = e.maxWidth),
+ i && (a.height = e.maxHeight);
+ var l = this.originalPosition.left + this.originalSize.width,
+ m = this.position.top + this.size.height,
+ n = /sw|nw|w/.test(g),
+ o = /nw|ne|n/.test(g);
+ j && n && (a.left = l - e.minWidth),
+ h && n && (a.left = l - e.maxWidth),
+ k && o && (a.top = m - e.minHeight),
+ i && o && (a.top = m - e.maxHeight);
+ var p = !a.width && !a.height;
+ p && !a.left && a.top ? a.top = null: p && !a.top && a.left && (a.left = null);
+ return a
+ },
+ _proportionallyResize: function() {
+ var b = this.options;
+ if ( !! this._proportionallyResizeElements.length) {
+ var c = this.helper || this.element;
+ for (var d = 0; d < this._proportionallyResizeElements.length; d++) {
+ var e = this._proportionallyResizeElements[d];
+ if (!this.borderDif) {
+ var f = [e.css("borderTopWidth"), e.css("borderRightWidth"), e.css("borderBottomWidth"), e.css("borderLeftWidth")],
+ g = [e.css("paddingTop"), e.css("paddingRight"), e.css("paddingBottom"), e.css("paddingLeft")];
+ this.borderDif = a.map(f,
+ function(a, b) {
+ var c = parseInt(a, 10) || 0,
+ d = parseInt(g[b], 10) || 0;
+ return c + d
+ })
+ }
+ if (a.browser.msie && ( !! a(c).is(":hidden") || !!a(c).parents(":hidden").length)) continue;
+ e.css({
+ height: c.height() - this.borderDif[0] - this.borderDif[2] || 0,
+ width: c.width() - this.borderDif[1] - this.borderDif[3] || 0
+ })
+ }
+ }
+ },
+ _renderProxy: function() {
+ var b = this.element,
+ c = this.options;
+ this.elementOffset = b.offset();
+ if (this._helper) {
+ this.helper = this.helper || a('<div style="overflow:hidden;"></div>');
+ var d = a.browser.msie && a.browser.version < 7,
+ e = d ? 1 : 0,
+ f = d ? 2 : -1;
+ this.helper.addClass(this._helper).css({
+ width: this.element.outerWidth() + f,
+ height: this.element.outerHeight() + f,
+ position: "absolute",
+ left: this.elementOffset.left - e + "px",
+ top: this.elementOffset.top - e + "px",
+ zIndex: ++c.zIndex
+ }),
+ this.helper.appendTo("body").disableSelection()
+ } else this.helper = this.element
+ },
+ _change: {
+ e: function(a, b, c) {
+ return {
+ width: this.originalSize.width + b
+ }
+ },
+ w: function(a, b, c) {
+ var d = this.options,
+ e = this.originalSize,
+ f = this.originalPosition;
+ return {
+ left: f.left + b,
+ width: e.width - b
+ }
+ },
+ n: function(a, b, c) {
+ var d = this.options,
+ e = this.originalSize,
+ f = this.originalPosition;
+ return {
+ top: f.top + c,
+ height: e.height - c
+ }
+ },
+ s: function(a, b, c) {
+ return {
+ height: this.originalSize.height + c
+ }
+ },
+ se: function(b, c, d) {
+ return a.extend(this._change.s.apply(this, arguments), this._change.e.apply(this, [b, c, d]))
+ },
+ sw: function(b, c, d) {
+ return a.extend(this._change.s.apply(this, arguments), this._change.w.apply(this, [b, c, d]))
+ },
+ ne: function(b, c, d) {
+ return a.extend(this._change.n.apply(this, arguments), this._change.e.apply(this, [b, c, d]))
+ },
+ nw: function(b, c, d) {
+ return a.extend(this._change.n.apply(this, arguments), this._change.w.apply(this, [b, c, d]))
+ }
+ },
+ _propagate: function(b, c) {
+ a.ui.plugin.call(this, b, [c, this.ui()]),
+ b != "resize" && this._trigger(b, c, this.ui())
+ },
+ plugins: {},
+ ui: function() {
+ return {
+ originalElement: this.originalElement,
+ element: this.element,
+ helper: this.helper,
+ position: this.position,
+ size: this.size,
+ originalSize: this.originalSize,
+ originalPosition: this.originalPosition
+ }
+ }
+ }),
+ a.extend(a.ui.resizable, {
+ version: "1.8.18"
+ }),
+ a.ui.plugin.add("resizable", "alsoResize", {
+ start: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options,
+ f = function(b) {
+ a(b).each(function() {
+ var b = a(this);
+ b.data("resizable-alsoresize", {
+ width: parseInt(b.width(), 10),
+ height: parseInt(b.height(), 10),
+ left: parseInt(b.css("left"), 10),
+ top: parseInt(b.css("top"), 10)
+ })
+ })
+ };
+ typeof e.alsoResize == "object" && !e.alsoResize.parentNode ? e.alsoResize.length ? (e.alsoResize = e.alsoResize[0], f(e.alsoResize)) : a.each(e.alsoResize,
+ function(a) {
+ f(a)
+ }) : f(e.alsoResize)
+ },
+ resize: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options,
+ f = d.originalSize,
+ g = d.originalPosition,
+ h = {
+ height: d.size.height - f.height || 0,
+ width: d.size.width - f.width || 0,
+ top: d.position.top - g.top || 0,
+ left: d.position.left - g.left || 0
+ },
+ i = function(b, d) {
+ a(b).each(function() {
+ var b = a(this),
+ e = a(this).data("resizable-alsoresize"),
+ f = {},
+ g = d && d.length ? d: b.parents(c.originalElement[0]).length ? ["width", "height"] : ["width", "height", "top", "left"];
+ a.each(g,
+ function(a, b) {
+ var c = (e[b] || 0) + (h[b] || 0);
+ c && c >= 0 && (f[b] = c || null)
+ }),
+ b.css(f)
+ })
+ };
+ typeof e.alsoResize == "object" && !e.alsoResize.nodeType ? a.each(e.alsoResize,
+ function(a, b) {
+ i(a, b)
+ }) : i(e.alsoResize)
+ },
+ stop: function(b, c) {
+ a(this).removeData("resizable-alsoresize")
+ }
+ }),
+ a.ui.plugin.add("resizable", "animate", {
+ stop: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options,
+ f = d._proportionallyResizeElements,
+ g = f.length && /textarea/i.test(f[0].nodeName),
+ h = g && a.ui.hasScroll(f[0], "left") ? 0 : d.sizeDiff.height,
+ i = g ? 0 : d.sizeDiff.width,
+ j = {
+ width: d.size.width - i,
+ height: d.size.height - h
+ },
+ k = parseInt(d.element.css("left"), 10) + (d.position.left - d.originalPosition.left) || null,
+ l = parseInt(d.element.css("top"), 10) + (d.position.top - d.originalPosition.top) || null;
+ d.element.animate(a.extend(j, l && k ? {
+ top: l,
+ left: k
+ }: {}), {
+ duration: e.animateDuration,
+ easing: e.animateEasing,
+ step: function() {
+ var c = {
+ width: parseInt(d.element.css("width"), 10),
+ height: parseInt(d.element.css("height"), 10),
+ top: parseInt(d.element.css("top"), 10),
+ left: parseInt(d.element.css("left"), 10)
+ };
+ f && f.length && a(f[0]).css({
+ width: c.width,
+ height: c.height
+ }),
+ d._updateCache(c),
+ d._propagate("resize", b)
+ }
+ })
+ }
+ }),
+ a.ui.plugin.add("resizable", "containment", {
+ start: function(b, d) {
+ var e = a(this).data("resizable"),
+ f = e.options,
+ g = e.element,
+ h = f.containment,
+ i = h instanceof a ? h.get(0) : /parent/.test(h) ? g.parent().get(0) : h;
+ if ( !! i) {
+ e.containerElement = a(i);
+ if (/document/.test(h) || h == document) e.containerOffset = {
+ left: 0,
+ top: 0
+ },
+ e.containerPosition = {
+ left: 0,
+ top: 0
+ },
+ e.parentData = {
+ element: a(document),
+ left: 0,
+ top: 0,
+ width: a(document).width(),
+ height: a(document).height() || document.body.parentNode.scrollHeight
+ };
+ else {
+ var j = a(i),
+ k = [];
+ a(["Top", "Right", "Left", "Bottom"]).each(function(a, b) {
+ k[a] = c(j.css("padding" + b))
+ }),
+ e.containerOffset = j.offset(),
+ e.containerPosition = j.position(),
+ e.containerSize = {
+ height: j.innerHeight() - k[3],
+ width: j.innerWidth() - k[1]
+ };
+ var l = e.containerOffset,
+ m = e.containerSize.height,
+ n = e.containerSize.width,
+ o = a.ui.hasScroll(i, "left") ? i.scrollWidth: n,
+ p = a.ui.hasScroll(i) ? i.scrollHeight: m;
+ e.parentData = {
+ element: i,
+ left: l.left,
+ top: l.top,
+ width: o,
+ height: p
+ }
+ }
+ }
+ },
+ resize: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options,
+ f = d.containerSize,
+ g = d.containerOffset,
+ h = d.size,
+ i = d.position,
+ j = d._aspectRatio || b.shiftKey,
+ k = {
+ top: 0,
+ left: 0
+ },
+ l = d.containerElement;
+ l[0] != document && /static/.test(l.css("position")) && (k = g),
+ i.left < (d._helper ? g.left: 0) && (d.size.width = d.size.width + (d._helper ? d.position.left - g.left: d.position.left - k.left), j && (d.size.height = d.size.width / e.aspectRatio), d.position.left = e.helper ? g.left: 0),
+ i.top < (d._helper ? g.top: 0) && (d.size.height = d.size.height + (d._helper ? d.position.top - g.top: d.position.top), j && (d.size.width = d.size.height * e.aspectRatio), d.position.top = d._helper ? g.top: 0),
+ d.offset.left = d.parentData.left + d.position.left,
+ d.offset.top = d.parentData.top + d.position.top;
+ var m = Math.abs((d._helper ? d.offset.left - k.left: d.offset.left - k.left) + d.sizeDiff.width),
+ n = Math.abs((d._helper ? d.offset.top - k.top: d.offset.top - g.top) + d.sizeDiff.height),
+ o = d.containerElement.get(0) == d.element.parent().get(0),
+ p = /relative|absolute/.test(d.containerElement.css("position"));
+ o && p && (m -= d.parentData.left),
+ m + d.size.width >= d.parentData.width && (d.size.width = d.parentData.width - m, j && (d.size.height = d.size.width / d.aspectRatio)),
+ n + d.size.height >= d.parentData.height && (d.size.height = d.parentData.height - n, j && (d.size.width = d.size.height * d.aspectRatio))
+ },
+ stop: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options,
+ f = d.position,
+ g = d.containerOffset,
+ h = d.containerPosition,
+ i = d.containerElement,
+ j = a(d.helper),
+ k = j.offset(),
+ l = j.outerWidth() - d.sizeDiff.width,
+ m = j.outerHeight() - d.sizeDiff.height;
+ d._helper && !e.animate && /relative/.test(i.css("position")) && a(this).css({
+ left: k.left - h.left - g.left,
+ width: l,
+ height: m
+ }),
+ d._helper && !e.animate && /static/.test(i.css("position")) && a(this).css({
+ left: k.left - h.left - g.left,
+ width: l,
+ height: m
+ })
+ }
+ }),
+ a.ui.plugin.add("resizable", "ghost", {
+ start: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options,
+ f = d.size;
+ d.ghost = d.originalElement.clone(),
+ d.ghost.css({
+ opacity: .25,
+ display: "block",
+ position: "relative",
+ height: f.height,
+ width: f.width,
+ margin: 0,
+ left: 0,
+ top: 0
+ }).addClass("ui-resizable-ghost").addClass(typeof e.ghost == "string" ? e.ghost: ""),
+ d.ghost.appendTo(d.helper)
+ },
+ resize: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options;
+ d.ghost && d.ghost.css({
+ position: "relative",
+ height: d.size.height,
+ width: d.size.width
+ })
+ },
+ stop: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options;
+ d.ghost && d.helper && d.helper.get(0).removeChild(d.ghost.get(0))
+ }
+ }),
+ a.ui.plugin.add("resizable", "grid", {
+ resize: function(b, c) {
+ var d = a(this).data("resizable"),
+ e = d.options,
+ f = d.size,
+ g = d.originalSize,
+ h = d.originalPosition,
+ i = d.axis,
+ j = e._aspectRatio || b.shiftKey;
+ e.grid = typeof e.grid == "number" ? [e.grid, e.grid] : e.grid;
+ var k = Math.round((f.width - g.width) / (e.grid[0] || 1)) * (e.grid[0] || 1),
+ l = Math.round((f.height - g.height) / (e.grid[1] || 1)) * (e.grid[1] || 1);
+ /^(se|s|e)$/.test(i) ? (d.size.width = g.width + k, d.size.height = g.height + l) : /^(ne)$/.test(i) ? (d.size.width = g.width + k, d.size.height = g.height + l, d.position.top = h.top - l) : /^(sw)$/.test(i) ? (d.size.width = g.width + k, d.size.height = g.height + l, d.position.left = h.left - k) : (d.size.width = g.width + k, d.size.height = g.height + l, d.position.top = h.top - l, d.position.left = h.left - k)
+ }
+ });
+ var c = function(a) {
+ return parseInt(a, 10) || 0
+ },
+ d = function(a) {
+ return ! isNaN(parseInt(a, 10))
+ }
+})(jQuery);
+/*
+ * jQuery UI Selectable 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Selectables
+ *
+ * Depends:
+ * jquery.ui.core.js
+ * jquery.ui.mouse.js
+ * jquery.ui.widget.js
+ */
+(function(a, b) {
+ a.widget("ui.selectable", a.ui.mouse, {
+ options: {
+ appendTo: "body",
+ autoRefresh: !0,
+ distance: 0,
+ filter: "*",
+ tolerance: "touch"
+ },
+ _create: function() {
+ var b = this;
+ this.element.addClass("ui-selectable"),
+ this.dragged = !1;
+ var c;
+ this.refresh = function() {
+ c = a(b.options.filter, b.element[0]),
+ c.addClass("ui-selectee"),
+ c.each(function() {
+ var b = a(this),
+ c = b.offset();
+ a.data(this, "selectable-item", {
+ element: this,
+ $element: b,
+ left: c.left,
+ top: c.top,
+ right: c.left + b.outerWidth(),
+ bottom: c.top + b.outerHeight(),
+ startselected: !1,
+ selected: b.hasClass("ui-selected"),
+ selecting: b.hasClass("ui-selecting"),
+ unselecting: b.hasClass("ui-unselecting")
+ })
+ })
+ },
+ this.refresh(),
+ this.selectees = c.addClass("ui-selectee"),
+ this._mouseInit(),
+ this.helper = a("<div class='ui-selectable-helper'></div>")
+ },
+ destroy: function() {
+ this.selectees.removeClass("ui-selectee").removeData("selectable-item"),
+ this.element.removeClass("ui-selectable ui-selectable-disabled").removeData("selectable").unbind(".selectable"),
+ this._mouseDestroy();
+ return this
+ },
+ _mouseStart: function(b) {
+ var c = this;
+ this.opos = [b.pageX, b.pageY];
+ if (!this.options.disabled) {
+ var d = this.options;
+ this.selectees = a(d.filter, this.element[0]),
+ this._trigger("start", b),
+ a(d.appendTo).append(this.helper),
+ this.helper.css({
+ left: b.clientX,
+ top: b.clientY,
+ width: 0,
+ height: 0
+ }),
+ d.autoRefresh && this.refresh(),
+ this.selectees.filter(".ui-selected").each(function() {
+ var d = a.data(this, "selectable-item");
+ d.startselected = !0,
+ !b.metaKey && !b.ctrlKey && (d.$element.removeClass("ui-selected"), d.selected = !1, d.$element.addClass("ui-unselecting"), d.unselecting = !0, c._trigger("unselecting", b, {
+ unselecting: d.element
+ }))
+ }),
+ a(b.target).parents().andSelf().each(function() {
+ var d = a.data(this, "selectable-item");
+ if (d) {
+ var e = !b.metaKey && !b.ctrlKey || !d.$element.hasClass("ui-selected");
+ d.$element.removeClass(e ? "ui-unselecting": "ui-selected").addClass(e ? "ui-selecting": "ui-unselecting"),
+ d.unselecting = !e,
+ d.selecting = e,
+ d.selected = e,
+ e ? c._trigger("selecting", b, {
+ selecting: d.element
+ }) : c._trigger("unselecting", b, {
+ unselecting: d.element
+ });
+ return ! 1
+ }
+ })
+ }
+ },
+ _mouseDrag: function(b) {
+ var c = this;
+ this.dragged = !0;
+ if (!this.options.disabled) {
+ var d = this.options,
+ e = this.opos[0],
+ f = this.opos[1],
+ g = b.pageX,
+ h = b.pageY;
+ if (e > g) {
+ var i = g;
+ g = e,
+ e = i
+ }
+ if (f > h) {
+ var i = h;
+ h = f,
+ f = i
+ }
+ this.helper.css({
+ left: e,
+ top: f,
+ width: g - e,
+ height: h - f
+ }),
+ this.selectees.each(function() {
+ var i = a.data(this, "selectable-item");
+ if ( !! i && i.element != c.element[0]) {
+ var j = !1;
+ d.tolerance == "touch" ? j = !(i.left > g || i.right < e || i.top > h || i.bottom < f) : d.tolerance == "fit" && (j = i.left > e && i.right < g && i.top > f && i.bottom < h),
+ j ? (i.selected && (i.$element.removeClass("ui-selected"), i.selected = !1), i.unselecting && (i.$element.removeClass("ui-unselecting"), i.unselecting = !1), i.selecting || (i.$element.addClass("ui-selecting"), i.selecting = !0, c._trigger("selecting", b, {
+ selecting: i.element
+ }))) : (i.selecting && ((b.metaKey || b.ctrlKey) && i.startselected ? (i.$element.removeClass("ui-selecting"), i.selecting = !1, i.$element.addClass("ui-selected"), i.selected = !0) : (i.$element.removeClass("ui-selecting"), i.selecting = !1, i.startselected && (i.$element.addClass("ui-unselecting"), i.unselecting = !0), c._trigger("unselecting", b, {
+ unselecting: i.element
+ }))), i.selected && !b.metaKey && !b.ctrlKey && !i.startselected && (i.$element.removeClass("ui-selected"), i.selected = !1, i.$element.addClass("ui-unselecting"), i.unselecting = !0, c._trigger("unselecting", b, {
+ unselecting: i.element
+ })))
+ }
+ });
+ return ! 1
+ }
+ },
+ _mouseStop: function(b) {
+ var c = this;
+ this.dragged = !1;
+ var d = this.options;
+ a(".ui-unselecting", this.element[0]).each(function() {
+ var d = a.data(this, "selectable-item");
+ d.$element.removeClass("ui-unselecting"),
+ d.unselecting = !1,
+ d.startselected = !1,
+ c._trigger("unselected", b, {
+ unselected: d.element
+ })
+ }),
+ a(".ui-selecting", this.element[0]).each(function() {
+ var d = a.data(this, "selectable-item");
+ d.$element.removeClass("ui-selecting").addClass("ui-selected"),
+ d.selecting = !1,
+ d.selected = !0,
+ d.startselected = !0,
+ c._trigger("selected", b, {
+ selected: d.element
+ })
+ }),
+ this._trigger("stop", b),
+ this.helper.remove();
+ return ! 1
+ }
+ }),
+ a.extend(a.ui.selectable, {
+ version: "1.8.18"
+ })
+})(jQuery);
+/*
+ * jQuery UI Sortable 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Sortables
+ *
+ * Depends:
+ * jquery.ui.core.js
+ * jquery.ui.mouse.js
+ * jquery.ui.widget.js
+ */
+(function(a, b) {
+ a.widget("ui.sortable", a.ui.mouse, {
+ widgetEventPrefix: "sort",
+ ready: !1,
+ options: {
+ appendTo: "parent",
+ axis: !1,
+ connectWith: !1,
+ containment: !1,
+ cursor: "auto",
+ cursorAt: !1,
+ dropOnEmpty: !0,
+ forcePlaceholderSize: !1,
+ forceHelperSize: !1,
+ grid: !1,
+ handle: !1,
+ helper: "original",
+ items: "> *",
+ opacity: !1,
+ placeholder: !1,
+ revert: !1,
+ scroll: !0,
+ scrollSensitivity: 20,
+ scrollSpeed: 20,
+ scope: "default",
+ tolerance: "intersect",
+ zIndex: 1e3
+ },
+ _create: function() {
+ var a = this.options;
+ this.containerCache = {},
+ this.element.addClass("ui-sortable"),
+ this.refresh(),
+ this.floating = this.items.length ? a.axis === "x" || /left|right/.test(this.items[0].item.css("float")) || /inline|table-cell/.test(this.items[0].item.css("display")) : !1,
+ this.offset = this.element.offset(),
+ this._mouseInit(),
+ this.ready = !0
+ },
+ destroy: function() {
+ a.Widget.prototype.destroy.call(this),
+ this.element.removeClass("ui-sortable ui-sortable-disabled"),
+ this._mouseDestroy();
+ for (var b = this.items.length - 1; b >= 0; b--) this.items[b].item.removeData(this.widgetName + "-item");
+ return this
+ },
+ _setOption: function(b, c) {
+ b === "disabled" ? (this.options[b] = c, this.widget()[c ? "addClass": "removeClass"]("ui-sortable-disabled")) : a.Widget.prototype._setOption.apply(this, arguments)
+ },
+ _mouseCapture: function(b, c) {
+ var d = this;
+ if (this.reverting) return ! 1;
+ if (this.options.disabled || this.options.type == "static") return ! 1;
+ this._refreshItems(b);
+ var e = null,
+ f = this,
+ g = a(b.target).parents().each(function() {
+ if (a.data(this, d.widgetName + "-item") == f) {
+ e = a(this);
+ return ! 1
+ }
+ });
+ a.data(b.target, d.widgetName + "-item") == f && (e = a(b.target));
+ if (!e) return ! 1;
+ if (this.options.handle && !c) {
+ var h = !1;
+ a(this.options.handle, e).find("*").andSelf().each(function() {
+ this == b.target && (h = !0)
+ });
+ if (!h) return ! 1
+ }
+ this.currentItem = e,
+
+ this._removeCurrentsFromItems();
+ return ! 0
+ },
+ _mouseStart: function(b, c, d) {
+ var e = this.options,
+ f = this;
+ this.currentContainer = this,
+ this.refreshPositions(),
+ this.helper = this._createHelper(b),
+ this._cacheHelperProportions(),
+ this._cacheMargins(),
+ this.scrollParent = this.helper.scrollParent(),
+ this.offset = this.currentItem.offset(),
+ this.offset = {
+ top: this.offset.top - this.margins.top,
+ left: this.offset.left - this.margins.left
+ },
+ this.helper.css("position", "absolute"),
+ this.cssPosition = this.helper.css("position"),
+ a.extend(this.offset, {
+ click: {
+ left: b.pageX - this.offset.left,
+ top: b.pageY - this.offset.top
+ },
+ parent: this._getParentOffset(),
+ relative: this._getRelativeOffset()
+ }),
+ this.originalPosition = this._generatePosition(b),
+ this.originalPageX = b.pageX,
+ this.originalPageY = b.pageY,
+ e.cursorAt && this._adjustOffsetFromHelper(e.cursorAt),
+ this.domPosition = {
+ prev: this.currentItem.prev()[0],
+ parent: this.currentItem.parent()[0]
+ },
+ this.helper[0] != this.currentItem[0] && this.currentItem.hide(),
+ this._createPlaceholder(),
+ e.containment && this._setContainment(),
+ e.cursor && (a("body").css("cursor") && (this._storedCursor = a("body").css("cursor")), a("body").css("cursor", e.cursor)),
+ e.opacity && (this.helper.css("opacity") && (this._storedOpacity = this.helper.css("opacity")), this.helper.css("opacity", e.opacity)),
+ e.zIndex && (this.helper.css("zIndex") && (this._storedZIndex = this.helper.css("zIndex")), this.helper.css("zIndex", e.zIndex)),
+ this.scrollParent[0] != document && this.scrollParent[0].tagName != "HTML" && (this.overflowOffset = this.scrollParent.offset()),
+ this._trigger("start", b, this._uiHash()),
+ this._preserveHelperProportions || this._cacheHelperProportions();
+ if (!d) for (var g = this.containers.length - 1; g >= 0; g--) this.containers[g]._trigger("activate", b, f._uiHash(this));
+ a.ui.ddmanager && (a.ui.ddmanager.current = this),
+ a.ui.ddmanager && !e.dropBehaviour && a.ui.ddmanager.prepareOffsets(this, b),
+ this.dragging = !0,
+ this.helper.addClass("ui-sortable-helper"),
+ this._mouseDrag(b);
+ return ! 0
+ },
+ _mouseDrag: function(b) {
+ this.position = this._generatePosition(b),
+ this.positionAbs = this._convertPositionTo("absolute"),
+ this.lastPositionAbs || (this.lastPositionAbs = this.positionAbs);
+ if (this.options.scroll) {
+ var c = this.options,
+ d = !1;
+ this.scrollParent[0] != document && this.scrollParent[0].tagName != "HTML" ? (this.overflowOffset.top + this.scrollParent[0].offsetHeight - b.pageY < c.scrollSensitivity ? this.scrollParent[0].scrollTop = d = this.scrollParent[0].scrollTop + c.scrollSpeed: b.pageY - this.overflowOffset.top < c.scrollSensitivity && (this.scrollParent[0].scrollTop = d = this.scrollParent[0].scrollTop - c.scrollSpeed), this.overflowOffset.left + this.scrollParent[0].offsetWidth - b.pageX < c.scrollSensitivity ? this.scrollParent[0].scrollLeft = d = this.scrollParent[0].scrollLeft + c.scrollSpeed: b.pageX - this.overflowOffset.left < c.scrollSensitivity && (this.scrollParent[0].scrollLeft = d = this.scrollParent[0].scrollLeft - c.scrollSpeed)) : (b.pageY - a(document).scrollTop() < c.scrollSensitivity ? d = a(document).scrollTop(a(document).scrollTop() - c.scrollSpeed) : a(window).height() - (b.pageY - a(document).scrollTop()) < c.scrollSensitivity && (d = a(document).scrollTop(a(document).scrollTop() + c.scrollSpeed)), b.pageX - a(document).scrollLeft() < c.scrollSensitivity ? d = a(document).scrollLeft(a(document).scrollLeft() - c.scrollSpeed) : a(window).width() - (b.pageX - a(document).scrollLeft()) < c.scrollSensitivity && (d = a(document).scrollLeft(a(document).scrollLeft() + c.scrollSpeed))),
+ d !== !1 && a.ui.ddmanager && !c.dropBehaviour && a.ui.ddmanager.prepareOffsets(this, b)
+ }
+ this.positionAbs = this._convertPositionTo("absolute");
+ if (!this.options.axis || this.options.axis != "y") this.helper[0].style.left = this.position.left + "px";
+ if (!this.options.axis || this.options.axis != "x") this.helper[0].style.top = this.position.top + "px";
+ for (var e = this.items.length - 1; e >= 0; e--) {
+ var f = this.items[e],
+ g = f.item[0],
+ h = this._intersectsWithPointer(f);
+ if (!h) continue;
+ if (g != this.currentItem[0] && this.placeholder[h == 1 ? "next": "prev"]()[0] != g && !a.ui.contains(this.placeholder[0], g) && (this.options.type == "semi-dynamic" ? !a.ui.contains(this.element[0], g) : !0)) {
+ this.direction = h == 1 ? "down": "up";
+ if (this.options.tolerance == "pointer" || this._intersectsWithSides(f)) this._rearrange(b, f);
+ else break;
+ this._trigger("change", b, this._uiHash());
+ break
+ }
+ }
+ this._contactContainers(b),
+ a.ui.ddmanager && a.ui.ddmanager.drag(this, b),
+ this._trigger("sort", b, this._uiHash()),
+ this.lastPositionAbs = this.positionAbs;
+ return ! 1
+ },
+ _mouseStop: function(b, c) {
+ if ( !! b) {
+ a.ui.ddmanager && !this.options.dropBehaviour && a.ui.ddmanager.drop(this, b);
+ if (this.options.revert) {
+ var d = this,
+ e = d.placeholder.offset();
+ d.reverting = !0,
+ a(this.helper).animate({
+ left: e.left - this.offset.parent.left - d.margins.left + (this.offsetParent[0] == document.body ? 0 : this.offsetParent[0].scrollLeft),
+ top: e.top - this.offset.parent.top - d.margins.top + (this.offsetParent[0] == document.body ? 0 : this.offsetParent[0].scrollTop)
+ },
+ parseInt(this.options.revert, 10) || 500,
+ function() {
+ d._clear(b)
+ })
+ } else this._clear(b, c);
+ return ! 1
+ }
+ },
+ cancel: function() {
+ var b = this;
+ if (this.dragging) {
+ this._mouseUp({
+ target: null
+ }),
+ this.options.helper == "original" ? this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper") : this.currentItem.show();
+ for (var c = this.containers.length - 1; c >= 0; c--) this.containers[c]._trigger("deactivate", null, b._uiHash(this)),
+ this.containers[c].containerCache.over && (this.containers[c]._trigger("out", null, b._uiHash(this)), this.containers[c].containerCache.over = 0)
+ }
+ this.placeholder && (this.placeholder[0].parentNode && this.placeholder[0].parentNode.removeChild(this.placeholder[0]), this.options.helper != "original" && this.helper && this.helper[0].parentNode && this.helper.remove(), a.extend(this, {
+ helper: null,
+ dragging: !1,
+ reverting: !1,
+ _noFinalSort: null
+ }), this.domPosition.prev ? a(this.domPosition.prev).after(this.currentItem) : a(this.domPosition.parent).prepend(this.currentItem));
+ return this
+ },
+ serialize: function(b) {
+ var c = this._getItemsAsjQuery(b && b.connected),
+ d = [];
+ b = b || {},
+ a(c).each(function() {
+ var c = (a(b.item || this).attr(b.attribute || "id") || "").match(b.expression || /(.+)[-=_](.+)/);
+ c && d.push((b.key || c[1] + "[]") + "=" + (b.key && b.expression ? c[1] : c[2]))
+ }),
+ !d.length && b.key && d.push(b.key + "=");
+ return d.join("&")
+ },
+ toArray: function(b) {
+ var c = this._getItemsAsjQuery(b && b.connected),
+ d = [];
+ b = b || {},
+ c.each(function() {
+ d.push(a(b.item || this).attr(b.attribute || "id") || "")
+ });
+ return d
+ },
+ _intersectsWith: function(a) {
+ var b = this.positionAbs.left,
+ c = b + this.helperProportions.width,
+ d = this.positionAbs.top,
+ e = d + this.helperProportions.height,
+ f = a.left,
+ g = f + a.width,
+ h = a.top,
+ i = h + a.height,
+ j = this.offset.click.top,
+ k = this.offset.click.left,
+ l = d + j > h && d + j < i && b + k > f && b + k < g;
+ return this.options.tolerance == "pointer" || this.options.forcePointerForContainers || this.options.tolerance != "pointer" && this.helperProportions[this.floating ? "width": "height"] > a[this.floating ? "width": "height"] ? l: f < b + this.helperProportions.width / 2 && c - this.helperProportions.width / 2 < g && h < d + this.helperProportions.height / 2 && e - this.helperProportions.height / 2 < i
+ },
+ _intersectsWithPointer: function(b) {
+ var c = a.ui.isOverAxis(this.positionAbs.top + this.offset.click.top, b.top, b.height),
+ d = a.ui.isOverAxis(this.positionAbs.left + this.offset.click.left, b.left, b.width),
+ e = c && d,
+ f = this._getDragVerticalDirection(),
+ g = this._getDragHorizontalDirection();
+ if (!e) return ! 1;
+ return this.floating ? g && g == "right" || f == "down" ? 2 : 1 : f && (f == "down" ? 2 : 1)
+ },
+ _intersectsWithSides: function(b) {
+ var c = a.ui.isOverAxis(this.positionAbs.top + this.offset.click.top, b.top + b.height / 2, b.height),
+ d = a.ui.isOverAxis(this.positionAbs.left + this.offset.click.left, b.left + b.width / 2, b.width),
+ e = this._getDragVerticalDirection(),
+ f = this._getDragHorizontalDirection();
+ return this.floating && f ? f == "right" && d || f == "left" && !d: e && (e == "down" && c || e == "up" && !c)
+ },
+ _getDragVerticalDirection: function() {
+ var a = this.positionAbs.top - this.lastPositionAbs.top;
+ return a != 0 && (a > 0 ? "down": "up")
+ },
+ _getDragHorizontalDirection: function() {
+ var a = this.positionAbs.left - this.lastPositionAbs.left;
+ return a != 0 && (a > 0 ? "right": "left")
+ },
+ refresh: function(a) {
+ this._refreshItems(a),
+ this.refreshPositions();
+ return this
+ },
+ _connectWith: function() {
+ var a = this.options;
+ return a.connectWith.constructor == String ? [a.connectWith] : a.connectWith
+ },
+ _getItemsAsjQuery: function(b) {
+ var c = this,
+ d = [],
+ e = [],
+ f = this._connectWith();
+ if (f && b) for (var g = f.length - 1; g >= 0; g--) {
+ var h = a(f[g]);
+ for (var i = h.length - 1; i >= 0; i--) {
+ var j = a.data(h[i], this.widgetName);
+ j && j != this && !j.options.disabled && e.push([a.isFunction(j.options.items) ? j.options.items.call(j.element) : a(j.options.items, j.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), j])
+ }
+ }
+ e.push([a.isFunction(this.options.items) ? this.options.items.call(this.element, null, {
+ options: this.options,
+ item: this.currentItem
+ }) : a(this.options.items, this.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), this]);
+ for (var g = e.length - 1; g >= 0; g--) e[g][0].each(function() {
+ d.push(this)
+ });
+ return a(d)
+ },
+ _removeCurrentsFromItems: function() {
+ var a = this.currentItem.find(":data(" + this.widgetName + "-item)");
+ for (var b = 0; b < this.items.length; b++) for (var c = 0; c < a.length; c++) a[c] == this.items[b].item[0] && this.items.splice(b, 1)
+ },
+ _refreshItems: function(b) {
+ this.items = [],
+ this.containers = [this];
+ var c = this.items,
+ d = this,
+ e = [[a.isFunction(this.options.items) ? this.options.items.call(this.element[0], b, {
+ item: this.currentItem
+ }) : a(this.options.items, this.element), this]],
+ f = this._connectWith();
+ if (f && this.ready) for (var g = f.length - 1; g >= 0; g--) {
+ var h = a(f[g]);
+ for (var i = h.length - 1; i >= 0; i--) {
+ var j = a.data(h[i], this.widgetName);
+ j && j != this && !j.options.disabled && (e.push([a.isFunction(j.options.items) ? j.options.items.call(j.element[0], b, {
+ item: this.currentItem
+ }) : a(j.options.items, j.element), j]), this.containers.push(j))
+ }
+ }
+ for (var g = e.length - 1; g >= 0; g--) {
+ var k = e[g][1],
+ l = e[g][0];
+ for (var i = 0,
+ m = l.length; i < m; i++) {
+ var n = a(l[i]);
+ n.data(this.widgetName + "-item", k),
+ c.push({
+ item: n,
+ instance: k,
+ width: 0,
+ height: 0,
+ left: 0,
+ top: 0
+ })
+ }
+ }
+ },
+ refreshPositions: function(b) {
+ this.offsetParent && this.helper && (this.offset.parent = this._getParentOffset());
+ for (var c = this.items.length - 1; c >= 0; c--) {
+ var d = this.items[c];
+ if (d.instance != this.currentContainer && this.currentContainer && d.item[0] != this.currentItem[0]) continue;
+ var e = this.options.toleranceElement ? a(this.options.toleranceElement, d.item) : d.item;
+ b || (d.width = e.outerWidth(), d.height = e.outerHeight());
+ var f = e.offset();
+ d.left = f.left,
+ d.top = f.top
+ }
+ if (this.options.custom && this.options.custom.refreshContainers) this.options.custom.refreshContainers.call(this);
+ else for (var c = this.containers.length - 1; c >= 0; c--) {
+ var f = this.containers[c].element.offset();
+ this.containers[c].containerCache.left = f.left,
+ this.containers[c].containerCache.top = f.top,
+ this.containers[c].containerCache.width = this.containers[c].element.outerWidth(),
+ this.containers[c].containerCache.height = this.containers[c].element.outerHeight()
+ }
+ return this
+ },
+ _createPlaceholder: function(b) {
+ var c = b || this,
+ d = c.options;
+ if (!d.placeholder || d.placeholder.constructor == String) {
+ var e = d.placeholder;
+ d.placeholder = {
+ element: function() {
+ var b = a(document.createElement(c.currentItem[0].nodeName)).addClass(e || c.currentItem[0].className + " ui-sortable-placeholder").removeClass("ui-sortable-helper")[0];
+ e || (b.style.visibility = "hidden");
+ return b
+ },
+ update: function(a, b) {
+ if (!e || !!d.forcePlaceholderSize) b.height() || b.height(c.currentItem.innerHeight() - parseInt(c.currentItem.css("paddingTop") || 0, 10) - parseInt(c.currentItem.css("paddingBottom") || 0, 10)),
+ b.width() || b.width(c.currentItem.innerWidth() - parseInt(c.currentItem.css("paddingLeft") || 0, 10) - parseInt(c.currentItem.css("paddingRight") || 0, 10))
+ }
+ }
+ }
+ c.placeholder = a(d.placeholder.element.call(c.element, c.currentItem)),
+ c.currentItem.after(c.placeholder),
+ d.placeholder.update(c, c.placeholder)
+ },
+ _contactContainers: function(b) {
+ var c = null,
+ d = null;
+ for (var e = this.containers.length - 1; e >= 0; e--) {
+ if (a.ui.contains(this.currentItem[0], this.containers[e].element[0])) continue;
+ if (this._intersectsWith(this.containers[e].containerCache)) {
+ if (c && a.ui.contains(this.containers[e].element[0], c.element[0])) continue;
+ c = this.containers[e],
+ d = e
+ } else this.containers[e].containerCache.over && (this.containers[e]._trigger("out", b, this._uiHash(this)), this.containers[e].containerCache.over = 0)
+ }
+ if ( !! c) if (this.containers.length === 1) this.containers[d]._trigger("over", b, this._uiHash(this)),
+ this.containers[d].containerCache.over = 1;
+ else if (this.currentContainer != this.containers[d]) {
+ var f = 1e4,
+ g = null,
+ h = this.positionAbs[this.containers[d].floating ? "left": "top"];
+ for (var i = this.items.length - 1; i >= 0; i--) {
+ if (!a.ui.contains(this.containers[d].element[0], this.items[i].item[0])) continue;
+ var j = this.items[i][this.containers[d].floating ? "left": "top"];
+ Math.abs(j - h) < f && (f = Math.abs(j - h), g = this.items[i])
+ }
+ if (!g && !this.options.dropOnEmpty) return;
+ this.currentContainer = this.containers[d],
+ g ? this._rearrange(b, g, null, !0) : this._rearrange(b, null, this.containers[d].element, !0),
+ this._trigger("change", b, this._uiHash()),
+ this.containers[d]._trigger("change", b, this._uiHash(this)),
+ this.options.placeholder.update(this.currentContainer, this.placeholder),
+ this.containers[d]._trigger("over", b, this._uiHash(this)),
+ this.containers[d].containerCache.over = 1
+ }
+ },
+ _createHelper: function(b) {
+ var c = this.options,
+ d = a.isFunction(c.helper) ? a(c.helper.apply(this.element[0], [b, this.currentItem])) : c.helper == "clone" ? this.currentItem.clone() : this.currentItem;
+ d.parents("body").length || a(c.appendTo != "parent" ? c.appendTo: this.currentItem[0].parentNode)[0].appendChild(d[0]),
+ d[0] == this.currentItem[0] && (this._storedCSS = {
+ width: this.currentItem[0].style.width,
+ height: this.currentItem[0].style.height,
+ position: this.currentItem.css("position"),
+ top: this.currentItem.css("top"),
+ left: this.currentItem.css("left")
+ }),
+ (d[0].style.width == "" || c.forceHelperSize) && d.width(this.currentItem.width()),
+ (d[0].style.height == "" || c.forceHelperSize) && d.height(this.currentItem.height());
+ return d
+ },
+ _adjustOffsetFromHelper: function(b) {
+ typeof b == "string" && (b = b.split(" ")),
+ a.isArray(b) && (b = {
+ left: +b[0],
+ top: +b[1] || 0
+ }),
+ "left" in b && (this.offset.click.left = b.left + this.margins.left),
+ "right" in b && (this.offset.click.left = this.helperProportions.width - b.right + this.margins.left),
+ "top" in b && (this.offset.click.top = b.top + this.margins.top),
+ "bottom" in b && (this.offset.click.top = this.helperProportions.height - b.bottom + this.margins.top)
+ },
+ _getParentOffset: function() {
+ this.offsetParent = this.helper.offsetParent();
+ var b = this.offsetParent.offset();
+ this.cssPosition == "absolute" && this.scrollParent[0] != document && a.ui.contains(this.scrollParent[0], this.offsetParent[0]) && (b.left += this.scrollParent.scrollLeft(), b.top += this.scrollParent.scrollTop());
+ if (this.offsetParent[0] == document.body || this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() == "html" && a.browser.msie) b = {
+ top: 0,
+ left: 0
+ };
+ return {
+ top: b.top + (parseInt(this.offsetParent.css("borderTopWidth"), 10) || 0),
+ left: b.left + (parseInt(this.offsetParent.css("borderLeftWidth"), 10) || 0)
+ }
+ },
+ _getRelativeOffset: function() {
+ if (this.cssPosition == "relative") {
+ var a = this.currentItem.position();
+ return {
+ top: a.top - (parseInt(this.helper.css("top"), 10) || 0) + this.scrollParent.scrollTop(),
+ left: a.left - (parseInt(this.helper.css("left"), 10) || 0) + this.scrollParent.scrollLeft()
+ }
+ }
+ return {
+ top: 0,
+ left: 0
+ }
+ },
+ _cacheMargins: function() {
+ this.margins = {
+ left: parseInt(this.currentItem.css("marginLeft"), 10) || 0,
+ top: parseInt(this.currentItem.css("marginTop"), 10) || 0
+ }
+ },
+ _cacheHelperProportions: function() {
+ this.helperProportions = {
+ width: this.helper.outerWidth(),
+ height: this.helper.outerHeight()
+ }
+ },
+ _setContainment: function() {
+ var b = this.options;
+ b.containment == "parent" && (b.containment = this.helper[0].parentNode);
+ if (b.containment == "document" || b.containment == "window") this.containment = [0 - this.offset.relative.left - this.offset.parent.left, 0 - this.offset.relative.top - this.offset.parent.top, a(b.containment == "document" ? document: window).width() - this.helperProportions.width - this.margins.left, (a(b.containment == "document" ? document: window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top];
+ if (!/^(document|window|parent)$/.test(b.containment)) {
+ var c = a(b.containment)[0],
+ d = a(b.containment).offset(),
+ e = a(c).css("overflow") != "hidden";
+ this.containment = [d.left + (parseInt(a(c).css("borderLeftWidth"), 10) || 0) + (parseInt(a(c).css("paddingLeft"), 10) || 0) - this.margins.left, d.top + (parseInt(a(c).css("borderTopWidth"), 10) || 0) + (parseInt(a(c).css("paddingTop"), 10) || 0) - this.margins.top, d.left + (e ? Math.max(c.scrollWidth, c.offsetWidth) : c.offsetWidth) - (parseInt(a(c).css("borderLeftWidth"), 10) || 0) - (parseInt(a(c).css("paddingRight"), 10) || 0) - this.helperProportions.width - this.margins.left, d.top + (e ? Math.max(c.scrollHeight, c.offsetHeight) : c.offsetHeight) - (parseInt(a(c).css("borderTopWidth"), 10) || 0) - (parseInt(a(c).css("paddingBottom"), 10) || 0) - this.helperProportions.height - this.margins.top]
+ }
+ },
+ _convertPositionTo: function(b, c) {
+ c || (c = this.position);
+ var d = b == "absolute" ? 1 : -1,
+ e = this.options,
+ f = this.cssPosition == "absolute" && (this.scrollParent[0] == document || !a.ui.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent: this.scrollParent,
+ g = /(html|body)/i.test(f[0].tagName);
+ return {
+ top: c.top + this.offset.relative.top * d + this.offset.parent.top * d - (a.browser.safari && this.cssPosition == "fixed" ? 0 : (this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : g ? 0 : f.scrollTop()) * d),
+ left: c.left + this.offset.relative.left * d + this.offset.parent.left * d - (a.browser.safari && this.cssPosition == "fixed" ? 0 : (this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : g ? 0 : f.scrollLeft()) * d)
+ }
+ },
+ _generatePosition: function(b) {
+ var c = this.options,
+ d = this.cssPosition == "absolute" && (this.scrollParent[0] == document || !a.ui.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent: this.scrollParent,
+ e = /(html|body)/i.test(d[0].tagName);
+ this.cssPosition == "relative" && (this.scrollParent[0] == document || this.scrollParent[0] == this.offsetParent[0]) && (this.offset.relative = this._getRelativeOffset());
+ var f = b.pageX,
+ g = b.pageY;
+ if (this.originalPosition) {
+ this.containment && (b.pageX - this.offset.click.left < this.containment[0] && (f = this.containment[0] + this.offset.click.left), b.pageY - this.offset.click.top < this.containment[1] && (g = this.containment[1] + this.offset.click.top), b.pageX - this.offset.click.left > this.containment[2] && (f = this.containment[2] + this.offset.click.left), b.pageY - this.offset.click.top > this.containment[3] && (g = this.containment[3] + this.offset.click.top));
+ if (c.grid) {
+ var h = this.originalPageY + Math.round((g - this.originalPageY) / c.grid[1]) * c.grid[1];
+ g = this.containment ? h - this.offset.click.top < this.containment[1] || h - this.offset.click.top > this.containment[3] ? h - this.offset.click.top < this.containment[1] ? h + c.grid[1] : h - c.grid[1] : h: h;
+ var i = this.originalPageX + Math.round((f - this.originalPageX) / c.grid[0]) * c.grid[0];
+ f = this.containment ? i - this.offset.click.left < this.containment[0] || i - this.offset.click.left > this.containment[2] ? i - this.offset.click.left < this.containment[0] ? i + c.grid[0] : i - c.grid[0] : i: i
+ }
+ }
+ return {
+ top: g - this.offset.click.top - this.offset.relative.top - this.offset.parent.top + (a.browser.safari && this.cssPosition == "fixed" ? 0 : this.cssPosition == "fixed" ? -this.scrollParent.scrollTop() : e ? 0 : d.scrollTop()),
+ left: f - this.offset.click.left - this.offset.relative.left - this.offset.parent.left + (a.browser.safari && this.cssPosition == "fixed" ? 0 : this.cssPosition == "fixed" ? -this.scrollParent.scrollLeft() : e ? 0 : d.scrollLeft())
+ }
+ },
+ _rearrange: function(a, b, c, d) {
+ c ? c[0].appendChild(this.placeholder[0]) : b.item[0].parentNode.insertBefore(this.placeholder[0], this.direction == "down" ? b.item[0] : b.item[0].nextSibling),
+ this.counter = this.counter ? ++this.counter: 1;
+ var e = this,
+ f = this.counter;
+ window.setTimeout(function() {
+ f == e.counter && e.refreshPositions(!d)
+ },
+ 0)
+ },
+ _clear: function(b, c) {
+ this.reverting = !1;
+ var d = [],
+ e = this; ! this._noFinalSort && this.currentItem.parent().length && this.placeholder.before(this.currentItem),
+ this._noFinalSort = null;
+ if (this.helper[0] == this.currentItem[0]) {
+ for (var f in this._storedCSS) if (this._storedCSS[f] == "auto" || this._storedCSS[f] == "static") this._storedCSS[f] = "";
+ this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper")
+ } else this.currentItem.show();
+ this.fromOutside && !c && d.push(function(a) {
+ this._trigger("receive", a, this._uiHash(this.fromOutside))
+ }),
+ (this.fromOutside || this.domPosition.prev != this.currentItem.prev().not(".ui-sortable-helper")[0] || this.domPosition.parent != this.currentItem.parent()[0]) && !c && d.push(function(a) {
+ this._trigger("update", a, this._uiHash())
+ });
+ if (!a.ui.contains(this.element[0], this.currentItem[0])) {
+ c || d.push(function(a) {
+ this._trigger("remove", a, this._uiHash())
+ });
+ for (var f = this.containers.length - 1; f >= 0; f--) a.ui.contains(this.containers[f].element[0], this.currentItem[0]) && !c && (d.push(function(a) {
+ return function(b) {
+ a._trigger("receive", b, this._uiHash(this))
+ }
+ }.call(this, this.containers[f])), d.push(function(a) {
+ return function(b) {
+ a._trigger("update", b, this._uiHash(this))
+ }
+ }.call(this, this.containers[f])))
+ }
+ for (var f = this.containers.length - 1; f >= 0; f--) c || d.push(function(a) {
+ return function(b) {
+ a._trigger("deactivate", b, this._uiHash(this))
+ }
+ }.call(this, this.containers[f])),
+ this.containers[f].containerCache.over && (d.push(function(a) {
+ return function(b) {
+ a._trigger("out", b, this._uiHash(this))
+ }
+ }.call(this, this.containers[f])), this.containers[f].containerCache.over = 0);
+ this._storedCursor && a("body").css("cursor", this._storedCursor),
+ this._storedOpacity && this.helper.css("opacity", this._storedOpacity),
+ this._storedZIndex && this.helper.css("zIndex", this._storedZIndex == "auto" ? "": this._storedZIndex),
+ this.dragging = !1;
+ if (this.cancelHelperRemoval) {
+ if (!c) {
+ this._trigger("beforeStop", b, this._uiHash());
+ for (var f = 0; f < d.length; f++) d[f].call(this, b);
+ this._trigger("stop", b, this._uiHash())
+ }
+ return ! 1
+ }
+ c || this._trigger("beforeStop", b, this._uiHash()),
+ this.placeholder[0].parentNode.removeChild(this.placeholder[0]),
+ this.helper[0] != this.currentItem[0] && this.helper.remove(),
+ this.helper = null;
+ if (!c) {
+ for (var f = 0; f < d.length; f++) d[f].call(this, b);
+ this._trigger("stop", b, this._uiHash())
+ }
+ this.fromOutside = !1;
+ return ! 0
+ },
+ _trigger: function() {
+ a.Widget.prototype._trigger.apply(this, arguments) === !1 && this.cancel()
+ },
+ _uiHash: function(b) {
+ var c = b || this;
+ return {
+ helper: c.helper,
+ placeholder: c.placeholder || a([]),
+ position: c.position,
+ originalPosition: c.originalPosition,
+ offset: c.positionAbs,
+ item: c.currentItem,
+ sender: b ? b.element: null
+ }
+ }
+ }),
+ a.extend(a.ui.sortable, {
+ version: "1.8.18"
+ })
+})(jQuery);
+/*
+ * jQuery UI Datepicker 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Datepicker
+ *
+ * Depends:
+ * jquery.ui.core.js
+ */
+(function($, undefined) {
+ function isArray(a) {
+ return a && ($.browser.safari && typeof a == "object" && a.length || a.constructor && a.constructor.toString().match(/\Array\(\)/))
+ }
+ function extendRemove(a, b) {
+ $.extend(a, b);
+ for (var c in b) if (b[c] == null || b[c] == undefined) a[c] = b[c];
+ return a
+ }
+ function bindHover(a) {
+ var b = "button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a";
+ return a.bind("mouseout",
+ function(a) {
+ var c = $(a.target).closest(b); ! c.length || c.removeClass("ui-state-hover ui-datepicker-prev-hover ui-datepicker-next-hover")
+ }).bind("mouseover",
+ function(c) {
+ var d = $(c.target).closest(b); ! $.datepicker._isDisabledDatepicker(instActive.inline ? a.parent()[0] : instActive.input[0]) && !!d.length && (d.parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover"), d.addClass("ui-state-hover"), d.hasClass("ui-datepicker-prev") && d.addClass("ui-datepicker-prev-hover"), d.hasClass("ui-datepicker-next") && d.addClass("ui-datepicker-next-hover"))
+ })
+ }
+ function Datepicker() {
+ this.debug = !1,
+ this._curInst = null,
+ this._keyEvent = !1,
+ this._disabledInputs = [],
+ this._datepickerShowing = !1,
+ this._inDialog = !1,
+ this._mainDivId = "ui-datepicker-div",
+ this._inlineClass = "ui-datepicker-inline",
+ this._appendClass = "ui-datepicker-append",
+ this._triggerClass = "ui-datepicker-trigger",
+ this._dialogClass = "ui-datepicker-dialog",
+ this._disableClass = "ui-datepicker-disabled",
+ this._unselectableClass = "ui-datepicker-unselectable",
+ this._currentClass = "ui-datepicker-current-day",
+ this._dayOverClass = "ui-datepicker-days-cell-over",
+ this.regional = [],
+ this.regional[""] = {
+ closeText: "Done",
+ prevText: "Prev",
+ nextText: "Next",
+ currentText: "Today",
+ monthNames: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
+ monthNamesShort: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
+ dayNames: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],
+ dayNamesShort: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
+ dayNamesMin: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"],
+ weekHeader: "Wk",
+ dateFormat: "mm/dd/yy",
+ firstDay: 0,
+ isRTL: !1,
+ showMonthAfterYear: !1,
+ yearSuffix: ""
+ },
+ this._defaults = {
+ showOn: "focus",
+ showAnim: "fadeIn",
+ showOptions: {},
+ defaultDate: null,
+ appendText: "",
+ buttonText: "...",
+ buttonImage: "",
+ buttonImageOnly: !1,
+ hideIfNoPrevNext: !1,
+ navigationAsDateFormat: !1,
+ gotoCurrent: !1,
+ changeMonth: !1,
+ changeYear: !1,
+ yearRange: "c-10:c+10",
+ showOtherMonths: !1,
+ selectOtherMonths: !1,
+ showWeek: !1,
+ calculateWeek: this.iso8601Week,
+ shortYearCutoff: "+10",
+ minDate: null,
+ maxDate: null,
+ duration: "fast",
+ beforeShowDay: null,
+ beforeShow: null,
+ onSelect: null,
+ onChangeMonthYear: null,
+ onClose: null,
+ numberOfMonths: 1,
+ showCurrentAtPos: 0,
+ stepMonths: 1,
+ stepBigMonths: 12,
+ altField: "",
+ altFormat: "",
+ constrainInput: !0,
+ showButtonPanel: !1,
+ autoSize: !1,
+ disabled: !1
+ },
+ $.extend(this._defaults, this.regional[""]),
+ this.dpDiv = bindHover($('<div id="' + this._mainDivId + '" class="ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>'))
+ }
+ $.extend($.ui, {
+ datepicker: {
+ version: "1.8.18"
+ }
+ });
+ var PROP_NAME = "datepicker",
+ dpuuid = (new Date).getTime(),
+ instActive;
+ $.extend(Datepicker.prototype, {
+ markerClassName: "hasDatepicker",
+ maxRows: 4,
+ log: function() {
+ this.debug && console.log.apply("", arguments)
+ },
+ _widgetDatepicker: function() {
+ return this.dpDiv
+ },
+ setDefaults: function(a) {
+ extendRemove(this._defaults, a || {});
+ return this
+ },
+ _attachDatepicker: function(target, settings) {
+ var inlineSettings = null;
+ for (var attrName in this._defaults) {
+ var attrValue = target.getAttribute("date:" + attrName);
+ if (attrValue) {
+ inlineSettings = inlineSettings || {};
+ try {
+ inlineSettings[attrName] = eval(attrValue)
+ } catch(err) {
+ inlineSettings[attrName] = attrValue
+ }
+ }
+ }
+ var nodeName = target.nodeName.toLowerCase(),
+ inline = nodeName == "div" || nodeName == "span";
+ target.id || (this.uuid += 1, target.id = "dp" + this.uuid);
+ var inst = this._newInst($(target), inline);
+ inst.settings = $.extend({},
+ settings || {},
+ inlineSettings || {}),
+ nodeName == "input" ? this._connectDatepicker(target, inst) : inline && this._inlineDatepicker(target, inst)
+ },
+ _newInst: function(a, b) {
+ var c = a[0].id.replace(/([^A-Za-z0-9_-])/g, "\\\\$1");
+ return {
+ id: c,
+ input: a,
+ selectedDay: 0,
+ selectedMonth: 0,
+ selectedYear: 0,
+ drawMonth: 0,
+ drawYear: 0,
+ inline: b,
+ dpDiv: b ? bindHover($('<div class="' + this._inlineClass + ' ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>')) : this.dpDiv
+ }
+ },
+ _connectDatepicker: function(a, b) {
+ var c = $(a);
+ b.append = $([]),
+ b.trigger = $([]);
+ c.hasClass(this.markerClassName) || (this._attachments(c, b), c.addClass(this.markerClassName).keydown(this._doKeyDown).keypress(this._doKeyPress).keyup(this._doKeyUp).bind("setData.datepicker",
+ function(a, c, d) {
+ b.settings[c] = d
+ }).bind("getData.datepicker",
+ function(a, c) {
+ return this._get(b, c)
+ }), this._autoSize(b), $.data(a, PROP_NAME, b), b.settings.disabled && this._disableDatepicker(a))
+ },
+ _attachments: function(a, b) {
+ var c = this._get(b, "appendText"),
+ d = this._get(b, "isRTL");
+ b.append && b.append.remove(),
+ c && (b.append = $('<span class="' + this._appendClass + '">' + c + "</span>"), a[d ? "before": "after"](b.append)),
+ a.unbind("focus", this._showDatepicker),
+ b.trigger && b.trigger.remove();
+ var e = this._get(b, "showOn"); (e == "focus" || e == "both") && a.focus(this._showDatepicker);
+ if (e == "button" || e == "both") {
+ var f = this._get(b, "buttonText"),
+ g = this._get(b, "buttonImage");
+ b.trigger = $(this._get(b, "buttonImageOnly") ? $("<img/>").addClass(this._triggerClass).attr({
+ src: g,
+ alt: f,
+ title: f
+ }) : $('<button type="button"></button>').addClass(this._triggerClass).html(g == "" ? f: $("<img/>").attr({
+ src: g,
+ alt: f,
+ title: f
+ }))),
+ a[d ? "before": "after"](b.trigger),
+ b.trigger.click(function() {
+ $.datepicker._datepickerShowing && $.datepicker._lastInput == a[0] ? $.datepicker._hideDatepicker() : $.datepicker._datepickerShowing && $.datepicker._lastInput != a[0] ? ($.datepicker._hideDatepicker(), $.datepicker._showDatepicker(a[0])) : $.datepicker._showDatepicker(a[0]);
+ return ! 1
+ })
+ }
+ },
+ _autoSize: function(a) {
+ if (this._get(a, "autoSize") && !a.inline) {
+ var b = new Date(2009, 11, 20),
+ c = this._get(a, "dateFormat");
+ if (c.match(/[DM]/)) {
+ var d = function(a) {
+ var b = 0,
+ c = 0;
+ for (var d = 0; d < a.length; d++) a[d].length > b && (b = a[d].length, c = d);
+ return c
+ };
+ b.setMonth(d(this._get(a, c.match(/MM/) ? "monthNames": "monthNamesShort"))),
+ b.setDate(d(this._get(a, c.match(/DD/) ? "dayNames": "dayNamesShort")) + 20 - b.getDay())
+ }
+ a.input.attr("size", this._formatDate(a, b).length)
+ }
+ },
+ _inlineDatepicker: function(a, b) {
+ var c = $(a);
+ c.hasClass(this.markerClassName) || (c.addClass(this.markerClassName).append(b.dpDiv).bind("setData.datepicker",
+ function(a, c, d) {
+ b.settings[c] = d
+ }).bind("getData.datepicker",
+ function(a, c) {
+ return this._get(b, c)
+ }), $.data(a, PROP_NAME, b), this._setDate(b, this._getDefaultDate(b), !0), this._updateDatepicker(b), this._updateAlternate(b), b.settings.disabled && this._disableDatepicker(a), b.dpDiv.css("display", "block"))
+ },
+ _dialogDatepicker: function(a, b, c, d, e) {
+ var f = this._dialogInst;
+ if (!f) {
+ this.uuid += 1;
+ var g = "dp" + this.uuid;
+ this._dialogInput = $('<input type="text" id="' + g + '" style="position: absolute; top: -100px; width: 0px; z-index: -10;"/>'),
+ this._dialogInput.keydown(this._doKeyDown),
+ $("body").append(this._dialogInput),
+ f = this._dialogInst = this._newInst(this._dialogInput, !1),
+ f.settings = {},
+ $.data(this._dialogInput[0], PROP_NAME, f)
+ }
+ extendRemove(f.settings, d || {}),
+ b = b && b.constructor == Date ? this._formatDate(f, b) : b,
+ this._dialogInput.val(b),
+ this._pos = e ? e.length ? e: [e.pageX, e.pageY] : null;
+ if (!this._pos) {
+ var h = document.documentElement.clientWidth,
+ i = document.documentElement.clientHeight,
+ j = document.documentElement.scrollLeft || document.body.scrollLeft,
+ k = document.documentElement.scrollTop || document.body.scrollTop;
+ this._pos = [h / 2 - 100 + j, i / 2 - 150 + k]
+ }
+ this._dialogInput.css("left", this._pos[0] + 20 + "px").css("top", this._pos[1] + "px"),
+ f.settings.onSelect = c,
+ this._inDialog = !0,
+ this.dpDiv.addClass(this._dialogClass),
+ this._showDatepicker(this._dialogInput[0]),
+ $.blockUI && $.blockUI(this.dpDiv),
+ $.data(this._dialogInput[0], PROP_NAME, f);
+ return this
+ },
+ _destroyDatepicker: function(a) {
+ var b = $(a),
+ c = $.data(a, PROP_NAME);
+ if ( !! b.hasClass(this.markerClassName)) {
+ var d = a.nodeName.toLowerCase();
+ $.removeData(a, PROP_NAME),
+ d == "input" ? (c.append.remove(), c.trigger.remove(), b.removeClass(this.markerClassName).unbind("focus", this._showDatepicker).unbind("keydown", this._doKeyDown).unbind("keypress", this._doKeyPress).unbind("keyup", this._doKeyUp)) : (d == "div" || d == "span") && b.removeClass(this.markerClassName).empty()
+ }
+ },
+ _enableDatepicker: function(a) {
+ var b = $(a),
+ c = $.data(a, PROP_NAME);
+ if ( !! b.hasClass(this.markerClassName)) {
+ var d = a.nodeName.toLowerCase();
+ if (d == "input") a.disabled = !1,
+ c.trigger.filter("button").each(function() {
+ this.disabled = !1
+ }).end().filter("img").css({
+ opacity: "1.0",
+ cursor: ""
+ });
+ else if (d == "div" || d == "span") {
+ var e = b.children("." + this._inlineClass);
+ e.children().removeClass("ui-state-disabled"),
+ e.find("select.ui-datepicker-month, select.ui-datepicker-year").removeAttr("disabled")
+ }
+ this._disabledInputs = $.map(this._disabledInputs,
+ function(b) {
+ return b == a ? null: b
+ })
+ }
+ },
+ _disableDatepicker: function(a) {
+ var b = $(a),
+ c = $.data(a, PROP_NAME);
+ if ( !! b.hasClass(this.markerClassName)) {
+ var d = a.nodeName.toLowerCase();
+ if (d == "input") a.disabled = !0,
+ c.trigger.filter("button").each(function() {
+ this.disabled = !0
+ }).end().filter("img").css({
+ opacity: "0.5",
+ cursor: "default"
+ });
+ else if (d == "div" || d == "span") {
+ var e = b.children("." + this._inlineClass);
+ e.children().addClass("ui-state-disabled"),
+ e.find("select.ui-datepicker-month, select.ui-datepicker-year").attr("disabled", "disabled")
+ }
+ this._disabledInputs = $.map(this._disabledInputs,
+ function(b) {
+ return b == a ? null: b
+ }),
+ this._disabledInputs[this._disabledInputs.length] = a
+ }
+ },
+ _isDisabledDatepicker: function(a) {
+ if (!a) return ! 1;
+ for (var b = 0; b < this._disabledInputs.length; b++) if (this._disabledInputs[b] == a) return ! 0;
+ return ! 1
+ },
+ _getInst: function(a) {
+ try {
+ return $.data(a, PROP_NAME)
+ } catch(b) {
+ throw "Missing instance data for this datepicker"
+ }
+ },
+ _optionDatepicker: function(a, b, c) {
+ var d = this._getInst(a);
+ if (arguments.length == 2 && typeof b == "string") return b == "defaults" ? $.extend({},
+ $.datepicker._defaults) : d ? b == "all" ? $.extend({},
+ d.settings) : this._get(d, b) : null;
+ var e = b || {};
+ typeof b == "string" && (e = {},
+ e[b] = c);
+ if (d) {
+ this._curInst == d && this._hideDatepicker();
+ var f = this._getDateDatepicker(a, !0),
+ g = this._getMinMaxDate(d, "min"),
+ h = this._getMinMaxDate(d, "max");
+ extendRemove(d.settings, e),
+ g !== null && e.dateFormat !== undefined && e.minDate === undefined && (d.settings.minDate = this._formatDate(d, g)),
+ h !== null && e.dateFormat !== undefined && e.maxDate === undefined && (d.settings.maxDate = this._formatDate(d, h)),
+ this._attachments($(a), d),
+ this._autoSize(d),
+ this._setDate(d, f),
+ this._updateAlternate(d),
+ this._updateDatepicker(d)
+ }
+ },
+ _changeDatepicker: function(a, b, c) {
+ this._optionDatepicker(a, b, c)
+ },
+ _refreshDatepicker: function(a) {
+ var b = this._getInst(a);
+ b && this._updateDatepicker(b)
+ },
+ _setDateDatepicker: function(a, b) {
+ var c = this._getInst(a);
+ c && (this._setDate(c, b), this._updateDatepicker(c), this._updateAlternate(c))
+ },
+ _getDateDatepicker: function(a, b) {
+ var c = this._getInst(a);
+ c && !c.inline && this._setDateFromField(c, b);
+ return c ? this._getDate(c) : null
+ },
+ _doKeyDown: function(a) {
+ var b = $.datepicker._getInst(a.target),
+ c = !0,
+ d = b.dpDiv.is(".ui-datepicker-rtl");
+ b._keyEvent = !0;
+ if ($.datepicker._datepickerShowing) switch (a.keyCode) {
+ case 9:
+ $.datepicker._hideDatepicker(),
+ c = !1;
+ break;
+ case 13:
+ var e = $("td." + $.datepicker._dayOverClass + ":not(." + $.datepicker._currentClass + ")", b.dpDiv);
+ e[0] && $.datepicker._selectDay(a.target, b.selectedMonth, b.selectedYear, e[0]);
+ var f = $.datepicker._get(b, "onSelect");
+ if (f) {
+ var g = $.datepicker._formatDate(b);
+ f.apply(b.input ? b.input[0] : null, [g, b])
+ } else $.datepicker._hideDatepicker();
+ return ! 1;
+ case 27:
+ $.datepicker._hideDatepicker();
+ break;
+ case 33:
+ $.datepicker._adjustDate(a.target, a.ctrlKey ? -$.datepicker._get(b, "stepBigMonths") : -$.datepicker._get(b, "stepMonths"), "M");
+ break;
+ case 34:
+ $.datepicker._adjustDate(a.target, a.ctrlKey ? +$.datepicker._get(b, "stepBigMonths") : +$.datepicker._get(b, "stepMonths"), "M");
+ break;
+ case 35:
+ (a.ctrlKey || a.metaKey) && $.datepicker._clearDate(a.target),
+ c = a.ctrlKey || a.metaKey;
+ break;
+ case 36:
+ (a.ctrlKey || a.metaKey) && $.datepicker._gotoToday(a.target),
+ c = a.ctrlKey || a.metaKey;
+ break;
+ case 37:
+ (a.ctrlKey || a.metaKey) && $.datepicker._adjustDate(a.target, d ? 1 : -1, "D"),
+ c = a.ctrlKey || a.metaKey,
+ a.originalEvent.altKey && $.datepicker._adjustDate(a.target, a.ctrlKey ? -$.datepicker._get(b, "stepBigMonths") : -$.datepicker._get(b, "stepMonths"), "M");
+ break;
+ case 38:
+ (a.ctrlKey || a.metaKey) && $.datepicker._adjustDate(a.target, -7, "D"),
+ c = a.ctrlKey || a.metaKey;
+ break;
+ case 39:
+ (a.ctrlKey || a.metaKey) && $.datepicker._adjustDate(a.target, d ? -1 : 1, "D"),
+ c = a.ctrlKey || a.metaKey,
+ a.originalEvent.altKey && $.datepicker._adjustDate(a.target, a.ctrlKey ? +$.datepicker._get(b, "stepBigMonths") : +$.datepicker._get(b, "stepMonths"), "M");
+ break;
+ case 40:
+ (a.ctrlKey || a.metaKey) && $.datepicker._adjustDate(a.target, 7, "D"),
+ c = a.ctrlKey || a.metaKey;
+ break;
+ default:
+ c = !1
+ } else a.keyCode == 36 && a.ctrlKey ? $.datepicker._showDatepicker(this) : c = !1;
+ c && (a.preventDefault(), a.stopPropagation())
+ },
+ _doKeyPress: function(a) {
+ var b = $.datepicker._getInst(a.target);
+ if ($.datepicker._get(b, "constrainInput")) {
+ var c = $.datepicker._possibleChars($.datepicker._get(b, "dateFormat")),
+ d = String.fromCharCode(a.charCode == undefined ? a.keyCode: a.charCode);
+ return a.ctrlKey || a.metaKey || d < " " || !c || c.indexOf(d) > -1
+ }
+ },
+ _doKeyUp: function(a) {
+ var b = $.datepicker._getInst(a.target);
+ if (b.input.val() != b.lastVal) try {
+ var c = $.datepicker.parseDate($.datepicker._get(b, "dateFormat"), b.input ? b.input.val() : null, $.datepicker._getFormatConfig(b));
+ c && ($.datepicker._setDateFromField(b), $.datepicker._updateAlternate(b), $.datepicker._updateDatepicker(b))
+ } catch(a) {
+ $.datepicker.log(a)
+ }
+ return ! 0
+ },
+ _showDatepicker: function(a) {
+ a = a.target || a,
+ a.nodeName.toLowerCase() != "input" && (a = $("input", a.parentNode)[0]);
+ if (!$.datepicker._isDisabledDatepicker(a) && $.datepicker._lastInput != a) {
+ var b = $.datepicker._getInst(a);
+ $.datepicker._curInst && $.datepicker._curInst != b && ($.datepicker._curInst.dpDiv.stop(!0, !0), b && $.datepicker._datepickerShowing && $.datepicker._hideDatepicker($.datepicker._curInst.input[0]));
+ var c = $.datepicker._get(b, "beforeShow"),
+ d = c ? c.apply(a, [a, b]) : {};
+ if (d === !1) return;
+ extendRemove(b.settings, d),
+ b.lastVal = null,
+ $.datepicker._lastInput = a,
+ $.datepicker._setDateFromField(b),
+ $.datepicker._inDialog && (a.value = ""),
+ $.datepicker._pos || ($.datepicker._pos = $.datepicker._findPos(a), $.datepicker._pos[1] += a.offsetHeight);
+ var e = !1;
+ $(a).parents().each(function() {
+ e |= $(this).css("position") == "fixed";
+ return ! e
+ }),
+ e && $.browser.opera && ($.datepicker._pos[0] -= document.documentElement.scrollLeft, $.datepicker._pos[1] -= document.documentElement.scrollTop);
+ var f = {
+ left: $.datepicker._pos[0],
+ top: $.datepicker._pos[1]
+ };
+ $.datepicker._pos = null,
+ b.dpDiv.empty(),
+ b.dpDiv.css({
+ position: "absolute",
+ display: "block",
+ top: "-1000px"
+ }),
+ $.datepicker._updateDatepicker(b),
+ f = $.datepicker._checkOffset(b, f, e),
+ b.dpDiv.css({
+ position: $.datepicker._inDialog && $.blockUI ? "static": e ? "fixed": "absolute",
+ display: "none",
+ left: f.left + "px",
+ top: f.top + "px"
+ });
+ if (!b.inline) {
+ var g = $.datepicker._get(b, "showAnim"),
+ h = $.datepicker._get(b, "duration"),
+ i = function() {
+ var a = b.dpDiv.find("iframe.ui-datepicker-cover");
+ if ( !! a.length) {
+ var c = $.datepicker._getBorders(b.dpDiv);
+ a.css({
+ left: -c[0],
+ top: -c[1],
+ width: b.dpDiv.outerWidth(),
+ height: b.dpDiv.outerHeight()
+ })
+ }
+ };
+ b.dpDiv.zIndex($(a).zIndex() + 1),
+ $.datepicker._datepickerShowing = !0,
+ $.effects && $.effects[g] ? b.dpDiv.show(g, $.datepicker._get(b, "showOptions"), h, i) : b.dpDiv[g || "show"](g ? h: null, i),
+ (!g || !h) && i(),
+ b.input.is(":visible") && !b.input.is(":disabled") && b.input.focus(),
+ $.datepicker._curInst = b
+ }
+ }
+ },
+ _updateDatepicker: function(a) {
+ var b = this;
+ b.maxRows = 4;
+ var c = $.datepicker._getBorders(a.dpDiv);
+ instActive = a,
+ a.dpDiv.empty().append(this._generateHTML(a));
+ var d = a.dpDiv.find("iframe.ui-datepicker-cover"); ! d.length || d.css({
+ left: -c[0],
+ top: -c[1],
+ width: a.dpDiv.outerWidth(),
+ height: a.dpDiv.outerHeight()
+ }),
+ a.dpDiv.find("." + this._dayOverClass + " a").mouseover();
+ var e = this._getNumberOfMonths(a),
+ f = e[1],
+ g = 17;
+ a.dpDiv.removeClass("ui-datepicker-multi-2 ui-datepicker-multi-3 ui-datepicker-multi-4").width(""),
+ f > 1 && a.dpDiv.addClass("ui-datepicker-multi-" + f).css("width", g * f + "em"),
+ a.dpDiv[(e[0] != 1 || e[1] != 1 ? "add": "remove") + "Class"]("ui-datepicker-multi"),
+ a.dpDiv[(this._get(a, "isRTL") ? "add": "remove") + "Class"]("ui-datepicker-rtl"),
+ a == $.datepicker._curInst && $.datepicker._datepickerShowing && a.input && a.input.is(":visible") && !a.input.is(":disabled") && a.input[0] != document.activeElement && a.input.focus();
+ if (a.yearshtml) {
+ var h = a.yearshtml;
+ setTimeout(function() {
+ h === a.yearshtml && a.yearshtml && a.dpDiv.find("select.ui-datepicker-year:first").replaceWith(a.yearshtml),
+ h = a.yearshtml = null
+ },
+ 0)
+ }
+ },
+ _getBorders: function(a) {
+ var b = function(a) {
+ return {
+ thin: 1,
+ medium: 2,
+ thick: 3
+ } [a] || a
+ };
+ return [parseFloat(b(a.css("border-left-width"))), parseFloat(b(a.css("border-top-width")))]
+ },
+ _checkOffset: function(a, b, c) {
+ var d = a.dpDiv.outerWidth(),
+ e = a.dpDiv.outerHeight(),
+ f = a.input ? a.input.outerWidth() : 0,
+ g = a.input ? a.input.outerHeight() : 0,
+ h = document.documentElement.clientWidth + $(document).scrollLeft(),
+ i = document.documentElement.clientHeight + $(document).scrollTop();
+ b.left -= this._get(a, "isRTL") ? d - f: 0,
+ b.left -= c && b.left == a.input.offset().left ? $(document).scrollLeft() : 0,
+ b.top -= c && b.top == a.input.offset().top + g ? $(document).scrollTop() : 0,
+ b.left -= Math.min(b.left, b.left + d > h && h > d ? Math.abs(b.left + d - h) : 0),
+ b.top -= Math.min(b.top, b.top + e > i && i > e ? Math.abs(e + g) : 0);
+ return b
+ },
+ _findPos: function(a) {
+ var b = this._getInst(a),
+ c = this._get(b, "isRTL");
+ while (a && (a.type == "hidden" || a.nodeType != 1 || $.expr.filters.hidden(a))) a = a[c ? "previousSibling": "nextSibling"];
+ var d = $(a).offset();
+ return [d.left, d.top]
+ },
+ _hideDatepicker: function(a) {
+ var b = this._curInst;
+ if (! (!b || a && b != $.data(a, PROP_NAME)) && this._datepickerShowing) {
+ var c = this._get(b, "showAnim"),
+ d = this._get(b, "duration"),
+ e = this,
+ f = function() {
+ $.datepicker._tidyDialog(b),
+ e._curInst = null
+ };
+ $.effects && $.effects[c] ? b.dpDiv.hide(c, $.datepicker._get(b, "showOptions"), d, f) : b.dpDiv[c == "slideDown" ? "slideUp": c == "fadeIn" ? "fadeOut": "hide"](c ? d: null, f),
+ c || f(),
+ this._datepickerShowing = !1;
+ var g = this._get(b, "onClose");
+ g && g.apply(b.input ? b.input[0] : null, [b.input ? b.input.val() : "", b]),
+ this._lastInput = null,
+ this._inDialog && (this._dialogInput.css({
+ position: "absolute",
+ left: "0",
+ top: "-100px"
+ }), $.blockUI && ($.unblockUI(), $("body").append(this.dpDiv))),
+ this._inDialog = !1
+ }
+ },
+ _tidyDialog: function(a) {
+ a.dpDiv.removeClass(this._dialogClass).unbind(".ui-datepicker-calendar")
+ },
+ _checkExternalClick: function(a) {
+ if ( !! $.datepicker._curInst) {
+ var b = $(a.target),
+ c = $.datepicker._getInst(b[0]); (b[0].id != $.datepicker._mainDivId && b.parents("#" + $.datepicker._mainDivId).length == 0 && !b.hasClass($.datepicker.markerClassName) && !b.closest("." + $.datepicker._triggerClass).length && $.datepicker._datepickerShowing && (!$.datepicker._inDialog || !$.blockUI) || b.hasClass($.datepicker.markerClassName) && $.datepicker._curInst != c) && $.datepicker._hideDatepicker()
+ }
+ },
+ _adjustDate: function(a, b, c) {
+ var d = $(a),
+ e = this._getInst(d[0]);
+ this._isDisabledDatepicker(d[0]) || (this._adjustInstDate(e, b + (c == "M" ? this._get(e, "showCurrentAtPos") : 0), c), this._updateDatepicker(e))
+ },
+ _gotoToday: function(a) {
+ var b = $(a),
+ c = this._getInst(b[0]);
+ if (this._get(c, "gotoCurrent") && c.currentDay) c.selectedDay = c.currentDay,
+ c.drawMonth = c.selectedMonth = c.currentMonth,
+ c.drawYear = c.selectedYear = c.currentYear;
+ else {
+ var d = new Date;
+ c.selectedDay = d.getDate(),
+ c.drawMonth = c.selectedMonth = d.getMonth(),
+ c.drawYear = c.selectedYear = d.getFullYear()
+ }
+ this._notifyChange(c),
+ this._adjustDate(b)
+ },
+ _selectMonthYear: function(a, b, c) {
+ var d = $(a),
+ e = this._getInst(d[0]);
+ e["selected" + (c == "M" ? "Month": "Year")] = e["draw" + (c == "M" ? "Month": "Year")] = parseInt(b.options[b.selectedIndex].value, 10),
+ this._notifyChange(e),
+ this._adjustDate(d)
+ },
+ _selectDay: function(a, b, c, d) {
+ var e = $(a);
+ if (!$(d).hasClass(this._unselectableClass) && !this._isDisabledDatepicker(e[0])) {
+ var f = this._getInst(e[0]);
+ f.selectedDay = f.currentDay = $("a", d).html(),
+ f.selectedMonth = f.currentMonth = b,
+ f.selectedYear = f.currentYear = c,
+ this._selectDate(a, this._formatDate(f, f.currentDay, f.currentMonth, f.currentYear))
+ }
+ },
+ _clearDate: function(a) {
+ var b = $(a),
+ c = this._getInst(b[0]);
+ this._selectDate(b, "")
+ },
+ _selectDate: function(a, b) {
+ var c = $(a),
+ d = this._getInst(c[0]);
+ b = b != null ? b: this._formatDate(d),
+ d.input && d.input.val(b),
+ this._updateAlternate(d);
+ var e = this._get(d, "onSelect");
+ e ? e.apply(d.input ? d.input[0] : null, [b, d]) : d.input && d.input.trigger("change"),
+ d.inline ? this._updateDatepicker(d) : (this._hideDatepicker(), this._lastInput = d.input[0], typeof d.input[0] != "object" && d.input.focus(), this._lastInput = null)
+ },
+ _updateAlternate: function(a) {
+ var b = this._get(a, "altField");
+ if (b) {
+ var c = this._get(a, "altFormat") || this._get(a, "dateFormat"),
+ d = this._getDate(a),
+ e = this.formatDate(c, d, this._getFormatConfig(a));
+ $(b).each(function() {
+ $(this).val(e)
+ })
+ }
+ },
+ noWeekends: function(a) {
+ var b = a.getDay();
+ return [b > 0 && b < 6, ""]
+ },
+ iso8601Week: function(a) {
+ var b = new Date(a.getTime());
+ b.setDate(b.getDate() + 4 - (b.getDay() || 7));
+ var c = b.getTime();
+ b.setMonth(0),
+ b.setDate(1);
+ return Math.floor(Math.round((c - b) / 864e5) / 7) + 1
+ },
+ parseDate: function(a, b, c) {
+ if (a == null || b == null) throw "Invalid arguments";
+ b = typeof b == "object" ? b.toString() : b + "";
+ if (b == "") return null;
+ var d = (c ? c.shortYearCutoff: null) || this._defaults.shortYearCutoff;
+ d = typeof d != "string" ? d: (new Date).getFullYear() % 100 + parseInt(d, 10);
+ var e = (c ? c.dayNamesShort: null) || this._defaults.dayNamesShort,
+ f = (c ? c.dayNames: null) || this._defaults.dayNames,
+ g = (c ? c.monthNamesShort: null) || this._defaults.monthNamesShort,
+ h = (c ? c.monthNames: null) || this._defaults.monthNames,
+ i = -1,
+ j = -1,
+ k = -1,
+ l = -1,
+ m = !1,
+ n = function(b) {
+ var c = s + 1 < a.length && a.charAt(s + 1) == b;
+ c && s++;
+ return c
+ },
+ o = function(a) {
+ var c = n(a),
+ d = a == "@" ? 14 : a == "!" ? 20 : a == "y" && c ? 4 : a == "o" ? 3 : 2,
+ e = new RegExp("^\\d{1," + d + "}"),
+ f = b.substring(r).match(e);
+ if (!f) throw "Missing number at position " + r;
+ r += f[0].length;
+ return parseInt(f[0], 10)
+ },
+ p = function(a, c, d) {
+ var e = $.map(n(a) ? d: c,
+ function(a, b) {
+ return [[b, a]]
+ }).sort(function(a, b) {
+ return - (a[1].length - b[1].length)
+ }),
+ f = -1;
+ $.each(e,
+ function(a, c) {
+ var d = c[1];
+ if (b.substr(r, d.length).toLowerCase() == d.toLowerCase()) {
+ f = c[0],
+ r += d.length;
+ return ! 1
+ }
+ });
+ if (f != -1) return f + 1;
+ throw "Unknown name at position " + r
+ },
+ q = function() {
+ if (b.charAt(r) != a.charAt(s)) throw "Unexpected literal at position " + r;
+ r++
+ },
+ r = 0;
+ for (var s = 0; s < a.length; s++) if (m) a.charAt(s) == "'" && !n("'") ? m = !1 : q();
+ else switch (a.charAt(s)) {
+ case "d":
+ k = o("d");
+ break;
+ case "D":
+ p("D", e, f);
+ break;
+ case "o":
+ l = o("o");
+ break;
+ case "m":
+ j = o("m");
+ break;
+ case "M":
+ j = p("M", g, h);
+ break;
+ case "y":
+ i = o("y");
+ break;
+ case "@":
+ var t = new Date(o("@"));
+ i = t.getFullYear(),
+ j = t.getMonth() + 1,
+ k = t.getDate();
+ break;
+ case "!":
+ var t = new Date((o("!") - this._ticksTo1970) / 1e4);
+ i = t.getFullYear(),
+ j = t.getMonth() + 1,
+ k = t.getDate();
+ break;
+ case "'":
+ n("'") ? q() : m = !0;
+ break;
+ default:
+ q()
+ }
+ if (r < b.length) throw "Extra/unparsed characters found in date: " + b.substring(r);
+ i == -1 ? i = (new Date).getFullYear() : i < 100 && (i += (new Date).getFullYear() - (new Date).getFullYear() % 100 + (i <= d ? 0 : -100));
+ if (l > -1) {
+ j = 1,
+ k = l;
+ for (;;) {
+ var u = this._getDaysInMonth(i, j - 1);
+ if (k <= u) break;
+ j++,
+ k -= u
+ }
+ }
+ var t = this._daylightSavingAdjust(new Date(i, j - 1, k));
+ if (t.getFullYear() != i || t.getMonth() + 1 != j || t.getDate() != k) throw "Invalid date";
+ return t
+ },
+ ATOM: "yy-mm-dd",
+ COOKIE: "D, dd M yy",
+ ISO_8601: "yy-mm-dd",
+ RFC_822: "D, d M y",
+ RFC_850: "DD, dd-M-y",
+ RFC_1036: "D, d M y",
+ RFC_1123: "D, d M yy",
+ RFC_2822: "D, d M yy",
+ RSS: "D, d M y",
+ TICKS: "!",
+ TIMESTAMP: "@",
+ W3C: "yy-mm-dd",
+ _ticksTo1970: (718685 + Math.floor(492.5) - Math.floor(19.7) + Math.floor(4.925)) * 24 * 60 * 60 * 1e7,
+ formatDate: function(a, b, c) {
+ if (!b) return "";
+ var d = (c ? c.dayNamesShort: null) || this._defaults.dayNamesShort,
+ e = (c ? c.dayNames: null) || this._defaults.dayNames,
+ f = (c ? c.monthNamesShort: null) || this._defaults.monthNamesShort,
+ g = (c ? c.monthNames: null) || this._defaults.monthNames,
+ h = function(b) {
+ var c = m + 1 < a.length && a.charAt(m + 1) == b;
+ c && m++;
+ return c
+ },
+ i = function(a, b, c) {
+ var d = "" + b;
+ if (h(a)) while (d.length < c) d = "0" + d;
+ return d
+ },
+ j = function(a, b, c, d) {
+ return h(a) ? d[b] : c[b]
+ },
+ k = "",
+ l = !1;
+ if (b) for (var m = 0; m < a.length; m++) if (l) a.charAt(m) == "'" && !h("'") ? l = !1 : k += a.charAt(m);
+ else switch (a.charAt(m)) {
+ case "d":
+ k += i("d", b.getDate(), 2);
+ break;
+ case "D":
+ k += j("D", b.getDay(), d, e);
+ break;
+ case "o":
+ k += i("o", Math.round(((new Date(b.getFullYear(), b.getMonth(), b.getDate())).getTime() - (new Date(b.getFullYear(), 0, 0)).getTime()) / 864e5), 3);
+ break;
+ case "m":
+ k += i("m", b.getMonth() + 1, 2);
+ break;
+ case "M":
+ k += j("M", b.getMonth(), f, g);
+ break;
+ case "y":
+ k += h("y") ? b.getFullYear() : (b.getYear() % 100 < 10 ? "0": "") + b.getYear() % 100;
+ break;
+ case "@":
+ k += b.getTime();
+ break;
+ case "!":
+ k += b.getTime() * 1e4 + this._ticksTo1970;
+ break;
+ case "'":
+ h("'") ? k += "'": l = !0;
+ break;
+ default:
+ k += a.charAt(m)
+ }
+ return k
+ },
+ _possibleChars: function(a) {
+ var b = "",
+ c = !1,
+ d = function(b) {
+ var c = e + 1 < a.length && a.charAt(e + 1) == b;
+ c && e++;
+ return c
+ };
+ for (var e = 0; e < a.length; e++) if (c) a.charAt(e) == "'" && !d("'") ? c = !1 : b += a.charAt(e);
+ else switch (a.charAt(e)) {
+ case "d":
+ case "m":
+ case "y":
+ case "@":
+ b += "0123456789";
+ break;
+ case "D":
+ case "M":
+ return null;
+ case "'":
+ d("'") ? b += "'": c = !0;
+ break;
+ default:
+ b += a.charAt(e)
+ }
+ return b
+ },
+ _get: function(a, b) {
+ return a.settings[b] !== undefined ? a.settings[b] : this._defaults[b]
+ },
+ _setDateFromField: function(a, b) {
+ if (a.input.val() != a.lastVal) {
+ var c = this._get(a, "dateFormat"),
+ d = a.lastVal = a.input ? a.input.val() : null,
+ e,
+ f;
+ e = f = this._getDefaultDate(a);
+ var g = this._getFormatConfig(a);
+ try {
+ e = this.parseDate(c, d, g) || f
+ } catch(h) {
+ this.log(h),
+ d = b ? "": d
+ }
+ a.selectedDay = e.getDate(),
+ a.drawMonth = a.selectedMonth = e.getMonth(),
+ a.drawYear = a.selectedYear = e.getFullYear(),
+ a.currentDay = d ? e.getDate() : 0,
+ a.currentMonth = d ? e.getMonth() : 0,
+ a.currentYear = d ? e.getFullYear() : 0,
+ this._adjustInstDate(a)
+ }
+ },
+ _getDefaultDate: function(a) {
+ return this._restrictMinMax(a, this._determineDate(a, this._get(a, "defaultDate"), new Date))
+ },
+ _determineDate: function(a, b, c) {
+ var d = function(a) {
+ var b = new Date;
+ b.setDate(b.getDate() + a);
+ return b
+ },
+ e = function(b) {
+ try {
+ return $.datepicker.parseDate($.datepicker._get(a, "dateFormat"), b, $.datepicker._getFormatConfig(a))
+ } catch(c) {}
+ var d = (b.toLowerCase().match(/^c/) ? $.datepicker._getDate(a) : null) || new Date,
+ e = d.getFullYear(),
+ f = d.getMonth(),
+ g = d.getDate(),
+ h = /([+-]?[0-9]+)\s*(d|D|w|W|m|M|y|Y)?/g,
+ i = h.exec(b);
+ while (i) {
+ switch (i[2] || "d") {
+ case "d":
+ case "D":
+ g += parseInt(i[1], 10);
+ break;
+ case "w":
+ case "W":
+ g += parseInt(i[1], 10) * 7;
+ break;
+ case "m":
+ case "M":
+ f += parseInt(i[1], 10),
+ g = Math.min(g, $.datepicker._getDaysInMonth(e, f));
+ break;
+ case "y":
+ case "Y":
+ e += parseInt(i[1], 10),
+ g = Math.min(g, $.datepicker._getDaysInMonth(e, f))
+ }
+ i = h.exec(b)
+ }
+ return new Date(e, f, g)
+ },
+ f = b == null || b === "" ? c: typeof b == "string" ? e(b) : typeof b == "number" ? isNaN(b) ? c: d(b) : new Date(b.getTime());
+ f = f && f.toString() == "Invalid Date" ? c: f,
+ f && (f.setHours(0), f.setMinutes(0), f.setSeconds(0), f.setMilliseconds(0));
+ return this._daylightSavingAdjust(f)
+ },
+ _daylightSavingAdjust: function(a) {
+ if (!a) return null;
+ a.setHours(a.getHours() > 12 ? a.getHours() + 2 : 0);
+ return a
+ },
+ _setDate: function(a, b, c) {
+ var d = !b,
+ e = a.selectedMonth,
+ f = a.selectedYear,
+ g = this._restrictMinMax(a, this._determineDate(a, b, new Date));
+ a.selectedDay = a.currentDay = g.getDate(),
+ a.drawMonth = a.selectedMonth = a.currentMonth = g.getMonth(),
+ a.drawYear = a.selectedYear = a.currentYear = g.getFullYear(),
+ (e != a.selectedMonth || f != a.selectedYear) && !c && this._notifyChange(a),
+ this._adjustInstDate(a),
+ a.input && a.input.val(d ? "": this._formatDate(a))
+ },
+ _getDate: function(a) {
+ var b = !a.currentYear || a.input && a.input.val() == "" ? null: this._daylightSavingAdjust(new Date(a.currentYear, a.currentMonth, a.currentDay));
+ return b
+ },
+ _generateHTML: function(a) {
+ var b = new Date;
+ b = this._daylightSavingAdjust(new Date(b.getFullYear(), b.getMonth(), b.getDate()));
+ var c = this._get(a, "isRTL"),
+ d = this._get(a, "showButtonPanel"),
+ e = this._get(a, "hideIfNoPrevNext"),
+ f = this._get(a, "navigationAsDateFormat"),
+ g = this._getNumberOfMonths(a),
+ h = this._get(a, "showCurrentAtPos"),
+ i = this._get(a, "stepMonths"),
+ j = g[0] != 1 || g[1] != 1,
+ k = this._daylightSavingAdjust(a.currentDay ? new Date(a.currentYear, a.currentMonth, a.currentDay) : new Date(9999, 9, 9)),
+ l = this._getMinMaxDate(a, "min"),
+ m = this._getMinMaxDate(a, "max"),
+ n = a.drawMonth - h,
+ o = a.drawYear;
+ n < 0 && (n += 12, o--);
+ if (m) {
+ var p = this._daylightSavingAdjust(new Date(m.getFullYear(), m.getMonth() - g[0] * g[1] + 1, m.getDate()));
+ p = l && p < l ? l: p;
+ while (this._daylightSavingAdjust(new Date(o, n, 1)) > p) n--,
+ n < 0 && (n = 11, o--)
+ }
+ a.drawMonth = n,
+ a.drawYear = o;
+ var q = this._get(a, "prevText");
+ q = f ? this.formatDate(q, this._daylightSavingAdjust(new Date(o, n - i, 1)), this._getFormatConfig(a)) : q;
+ var r = this._canAdjustMonth(a, -1, o, n) ? '<a class="ui-datepicker-prev ui-corner-all" onclick="DP_jQuery_' + dpuuid + ".datepicker._adjustDate('#" + a.id + "', -" + i + ", 'M');\"" + ' title="' + q + '"><span class="ui-icon ui-icon-circle-triangle-' + (c ? "e": "w") + '">' + q + "</span></a>": e ? "": '<a class="ui-datepicker-prev ui-corner-all ui-state-disabled" title="' + q + '"><span class="ui-icon ui-icon-circle-triangle-' + (c ? "e": "w") + '">' + q + "</span></a>",
+ s = this._get(a, "nextText");
+ s = f ? this.formatDate(s, this._daylightSavingAdjust(new Date(o, n + i, 1)), this._getFormatConfig(a)) : s;
+ var t = this._canAdjustMonth(a, 1, o, n) ? '<a class="ui-datepicker-next ui-corner-all" onclick="DP_jQuery_' + dpuuid + ".datepicker._adjustDate('#" + a.id + "', +" + i + ", 'M');\"" + ' title="' + s + '"><span class="ui-icon ui-icon-circle-triangle-' + (c ? "w": "e") + '">' + s + "</span></a>": e ? "": '<a class="ui-datepicker-next ui-corner-all ui-state-disabled" title="' + s + '"><span class="ui-icon ui-icon-circle-triangle-' + (c ? "w": "e") + '">' + s + "</span></a>",
+ u = this._get(a, "currentText"),
+ v = this._get(a, "gotoCurrent") && a.currentDay ? k: b;
+ u = f ? this.formatDate(u, v, this._getFormatConfig(a)) : u;
+ var w = a.inline ? "": '<button type="button" class="ui-datepicker-close ui-state-default ui-priority-primary ui-corner-all" onclick="DP_jQuery_' + dpuuid + '.datepicker._hideDatepicker();">' + this._get(a, "closeText") + "</button>",
+ x = d ? '<div class="ui-datepicker-buttonpane ui-widget-content">' + (c ? w: "") + (this._isInRange(a, v) ? '<button type="button" class="ui-datepicker-current ui-state-default ui-priority-secondary ui-corner-all" onclick="DP_jQuery_' + dpuuid + ".datepicker._gotoToday('#" + a.id + "');\"" + ">" + u + "</button>": "") + (c ? "": w) + "</div>": "",
+ y = parseInt(this._get(a, "firstDay"), 10);
+ y = isNaN(y) ? 0 : y;
+ var z = this._get(a, "showWeek"),
+ A = this._get(a, "dayNames"),
+ B = this._get(a, "dayNamesShort"),
+ C = this._get(a, "dayNamesMin"),
+ D = this._get(a, "monthNames"),
+ E = this._get(a, "monthNamesShort"),
+ F = this._get(a, "beforeShowDay"),
+ G = this._get(a, "showOtherMonths"),
+ H = this._get(a, "selectOtherMonths"),
+ I = this._get(a, "calculateWeek") || this.iso8601Week,
+ J = this._getDefaultDate(a),
+ K = "";
+ for (var L = 0; L < g[0]; L++) {
+ var M = "";
+ this.maxRows = 4;
+ for (var N = 0; N < g[1]; N++) {
+ var O = this._daylightSavingAdjust(new Date(o, n, a.selectedDay)),
+ P = " ui-corner-all",
+ Q = "";
+ if (j) {
+ Q += '<div class="ui-datepicker-group';
+ if (g[1] > 1) switch (N) {
+ case 0:
+ Q += " ui-datepicker-group-first",
+ P = " ui-corner-" + (c ? "right": "left");
+ break;
+ case g[1] - 1 : Q += " ui-datepicker-group-last",
+ P = " ui-corner-" + (c ? "left": "right");
+ break;
+ default:
+ Q += " ui-datepicker-group-middle",
+ P = ""
+ }
+ Q += '">'
+ }
+ Q += '<div class="ui-datepicker-header ui-widget-header ui-helper-clearfix' + P + '">' + (/all|left/.test(P) && L == 0 ? c ? t: r: "") + (/all|right/.test(P) && L == 0 ? c ? r: t: "") + this._generateMonthYearHeader(a, n, o, l, m, L > 0 || N > 0, D, E) + '</div><table class="ui-datepicker-calendar"><thead>' + "<tr>";
+ var R = z ? '<th class="ui-datepicker-week-col">' + this._get(a, "weekHeader") + "</th>": "";
+ for (var S = 0; S < 7; S++) {
+ var T = (S + y) % 7;
+ R += "<th" + ((S + y + 6) % 7 >= 5 ? ' class="ui-datepicker-week-end"': "") + ">" + '<span title="' + A[T] + '">' + C[T] + "</span></th>"
+ }
+ Q += R + "</tr></thead><tbody>";
+ var U = this._getDaysInMonth(o, n);
+ o == a.selectedYear && n == a.selectedMonth && (a.selectedDay = Math.min(a.selectedDay, U));
+ var V = (this._getFirstDayOfMonth(o, n) - y + 7) % 7,
+ W = Math.ceil((V + U) / 7),
+ X = j ? this.maxRows > W ? this.maxRows: W: W;
+ this.maxRows = X;
+ var Y = this._daylightSavingAdjust(new Date(o, n, 1 - V));
+ for (var Z = 0; Z < X; Z++) {
+ Q += "<tr>";
+ var _ = z ? '<td class="ui-datepicker-week-col">' + this._get(a, "calculateWeek")(Y) + "</td>": "";
+ for (var S = 0; S < 7; S++) {
+ var ba = F ? F.apply(a.input ? a.input[0] : null, [Y]) : [!0, ""],
+ bb = Y.getMonth() != n,
+ bc = bb && !H || !ba[0] || l && Y < l || m && Y > m;
+ _ += '<td class="' + ((S + y + 6) % 7 >= 5 ? " ui-datepicker-week-end": "") + (bb ? " ui-datepicker-other-month": "") + (Y.getTime() == O.getTime() && n == a.selectedMonth && a._keyEvent || J.getTime() == Y.getTime() && J.getTime() == O.getTime() ? " " + this._dayOverClass: "") + (bc ? " " + this._unselectableClass + " ui-state-disabled": "") + (bb && !G ? "": " " + ba[1] + (Y.getTime() == k.getTime() ? " " + this._currentClass: "") + (Y.getTime() == b.getTime() ? " ui-datepicker-today": "")) + '"' + ((!bb || G) && ba[2] ? ' title="' + ba[2] + '"': "") + (bc ? "": ' onclick="DP_jQuery_' + dpuuid + ".datepicker._selectDay('#" + a.id + "'," + Y.getMonth() + "," + Y.getFullYear() + ', this);return false;"') + ">" + (bb && !G ? "&#xa0;": bc ? '<span class="ui-state-default">' + Y.getDate() + "</span>": '<a class="ui-state-default' + (Y.getTime() == b.getTime() ? " ui-state-highlight": "") + (Y.getTime() == k.getTime() ? " ui-state-active": "") + (bb ? " ui-priority-secondary": "") + '" href="#">' + Y.getDate() + "</a>") + "</td>",
+ Y.setDate(Y.getDate() + 1),
+ Y = this._daylightSavingAdjust(Y)
+ }
+ Q += _ + "</tr>"
+ }
+ n++,
+ n > 11 && (n = 0, o++),
+ Q += "</tbody></table>" + (j ? "</div>" + (g[0] > 0 && N == g[1] - 1 ? '<div class="ui-datepicker-row-break"></div>': "") : ""),
+ M += Q
+ }
+ K += M
+ }
+ K += x + ($.browser.msie && parseInt($.browser.version, 10) < 7 && !a.inline ? '<iframe src="javascript:false;" class="ui-datepicker-cover" frameborder="0"></iframe>': ""),
+ a._keyEvent = !1;
+ return K
+ },
+ _generateMonthYearHeader: function(a, b, c, d, e, f, g, h) {
+ var i = this._get(a, "changeMonth"),
+ j = this._get(a, "changeYear"),
+ k = this._get(a, "showMonthAfterYear"),
+ l = '<div class="ui-datepicker-title">',
+ m = "";
+ if (f || !i) m += '<span class="ui-datepicker-month">' + g[b] + "</span>";
+ else {
+ var n = d && d.getFullYear() == c,
+ o = e && e.getFullYear() == c;
+ m += '<select class="ui-datepicker-month" onchange="DP_jQuery_' + dpuuid + ".datepicker._selectMonthYear('#" + a.id + "', this, 'M');\" " + ">";
+ for (var p = 0; p < 12; p++)(!n || p >= d.getMonth()) && (!o || p <= e.getMonth()) && (m += '<option value="' + p + '"' + (p == b ? ' selected="selected"': "") + ">" + h[p] + "</option>");
+ m += "</select>"
+ }
+ k || (l += m + (f || !i || !j ? "&#xa0;": ""));
+ if (!a.yearshtml) {
+ a.yearshtml = "";
+ if (f || !j) l += '<span class="ui-datepicker-year">' + c + "</span>";
+ else {
+ var q = this._get(a, "yearRange").split(":"),
+ r = (new Date).getFullYear(),
+ s = function(a) {
+ var b = a.match(/c[+-].*/) ? c + parseInt(a.substring(1), 10) : a.match(/[+-].*/) ? r + parseInt(a, 10) : parseInt(a, 10);
+ return isNaN(b) ? r: b
+ },
+ t = s(q[0]),
+ u = Math.max(t, s(q[1] || ""));
+ t = d ? Math.max(t, d.getFullYear()) : t,
+ u = e ? Math.min(u, e.getFullYear()) : u,
+ a.yearshtml += '<select class="ui-datepicker-year" onchange="DP_jQuery_' + dpuuid + ".datepicker._selectMonthYear('#" + a.id + "', this, 'Y');\" " + ">";
+ for (; t <= u; t++) a.yearshtml += '<option value="' + t + '"' + (t == c ? ' selected="selected"': "") + ">" + t + "</option>";
+ a.yearshtml += "</select>",
+ l += a.yearshtml,
+ a.yearshtml = null
+ }
+ }
+ l += this._get(a, "yearSuffix"),
+ k && (l += (f || !i || !j ? "&#xa0;": "") + m),
+ l += "</div>";
+ return l
+ },
+ _adjustInstDate: function(a, b, c) {
+ var d = a.drawYear + (c == "Y" ? b: 0),
+ e = a.drawMonth + (c == "M" ? b: 0),
+ f = Math.min(a.selectedDay, this._getDaysInMonth(d, e)) + (c == "D" ? b: 0),
+ g = this._restrictMinMax(a, this._daylightSavingAdjust(new Date(d, e, f)));
+ a.selectedDay = g.getDate(),
+ a.drawMonth = a.selectedMonth = g.getMonth(),
+ a.drawYear = a.selectedYear = g.getFullYear(),
+ (c == "M" || c == "Y") && this._notifyChange(a)
+ },
+ _restrictMinMax: function(a, b) {
+ var c = this._getMinMaxDate(a, "min"),
+ d = this._getMinMaxDate(a, "max"),
+ e = c && b < c ? c: b;
+ e = d && e > d ? d: e;
+ return e
+ },
+ _notifyChange: function(a) {
+ var b = this._get(a, "onChangeMonthYear");
+ b && b.apply(a.input ? a.input[0] : null, [a.selectedYear, a.selectedMonth + 1, a])
+ },
+ _getNumberOfMonths: function(a) {
+ var b = this._get(a, "numberOfMonths");
+ return b == null ? [1, 1] : typeof b == "number" ? [1, b] : b
+ },
+ _getMinMaxDate: function(a, b) {
+ return this._determineDate(a, this._get(a, b + "Date"), null)
+ },
+ _getDaysInMonth: function(a, b) {
+ return 32 - this._daylightSavingAdjust(new Date(a, b, 32)).getDate()
+ },
+ _getFirstDayOfMonth: function(a, b) {
+ return (new Date(a, b, 1)).getDay()
+ },
+ _canAdjustMonth: function(a, b, c, d) {
+ var e = this._getNumberOfMonths(a),
+ f = this._daylightSavingAdjust(new Date(c, d + (b < 0 ? b: e[0] * e[1]), 1));
+ b < 0 && f.setDate(this._getDaysInMonth(f.getFullYear(), f.getMonth()));
+ return this._isInRange(a, f)
+ },
+ _isInRange: function(a, b) {
+ var c = this._getMinMaxDate(a, "min"),
+ d = this._getMinMaxDate(a, "max");
+ return (!c || b.getTime() >= c.getTime()) && (!d || b.getTime() <= d.getTime())
+ },
+ _getFormatConfig: function(a) {
+ var b = this._get(a, "shortYearCutoff");
+ b = typeof b != "string" ? b: (new Date).getFullYear() % 100 + parseInt(b, 10);
+ return {
+ shortYearCutoff: b,
+ dayNamesShort: this._get(a, "dayNamesShort"),
+ dayNames: this._get(a, "dayNames"),
+ monthNamesShort: this._get(a, "monthNamesShort"),
+ monthNames: this._get(a, "monthNames")
+ }
+ },
+ _formatDate: function(a, b, c, d) {
+ b || (a.currentDay = a.selectedDay, a.currentMonth = a.selectedMonth, a.currentYear = a.selectedYear);
+ var e = b ? typeof b == "object" ? b: this._daylightSavingAdjust(new Date(d, c, b)) : this._daylightSavingAdjust(new Date(a.currentYear, a.currentMonth, a.currentDay));
+ return this.formatDate(this._get(a, "dateFormat"), e, this._getFormatConfig(a))
+ }
+ }),
+ $.fn.datepicker = function(a) {
+ if (!this.length) return this;
+ $.datepicker.initialized || ($(document).mousedown($.datepicker._checkExternalClick).find("body").append($.datepicker.dpDiv), $.datepicker.initialized = !0);
+ var b = Array.prototype.slice.call(arguments, 1);
+ if (typeof a == "string" && (a == "isDisabled" || a == "getDate" || a == "widget")) return $.datepicker["_" + a + "Datepicker"].apply($.datepicker, [this[0]].concat(b));
+ if (a == "option" && arguments.length == 2 && typeof arguments[1] == "string") return $.datepicker["_" + a + "Datepicker"].apply($.datepicker, [this[0]].concat(b));
+ return this.each(function() {
+ typeof a == "string" ? $.datepicker["_" + a + "Datepicker"].apply($.datepicker, [this].concat(b)) : $.datepicker._attachDatepicker(this, a)
+ })
+ },
+ $.datepicker = new Datepicker,
+ $.datepicker.initialized = !1,
+ $.datepicker.uuid = (new Date).getTime(),
+ $.datepicker.version = "1.8.18",
+ window["DP_jQuery_" + dpuuid] = $
+})(jQuery);
+/*
+ * jQuery UI Effects 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/
+ */
+jQuery.effects ||
+function(a, b) {
+ function l(b) {
+ if (!b || typeof b == "number" || a.fx.speeds[b]) return ! 0;
+ if (typeof b == "string" && !a.effects[b]) return ! 0;
+ return ! 1
+ }
+ function k(b, c, d, e) {
+ typeof b == "object" && (e = c, d = null, c = b, b = c.effect),
+ a.isFunction(c) && (e = c, d = null, c = {});
+ if (typeof c == "number" || a.fx.speeds[c]) e = d,
+ d = c,
+ c = {};
+ a.isFunction(d) && (e = d, d = null),
+ c = c || {},
+ d = d || c.duration,
+ d = a.fx.off ? 0 : typeof d == "number" ? d: d in a.fx.speeds ? a.fx.speeds[d] : a.fx.speeds._default,
+ e = e || c.complete;
+ return [b, c, d, e]
+ }
+ function j(a, b) {
+ var c = {
+ _: 0
+ },
+ d;
+ for (d in b) a[d] != b[d] && (c[d] = b[d]);
+ return c
+ }
+ function i(b) {
+ var c, d;
+ for (c in b) d = b[c],
+ (d == null || a.isFunction(d) || c in g || /scrollbar/.test(c) || !/color/i.test(c) && isNaN(parseFloat(d))) && delete b[c];
+ return b
+ }
+ function h() {
+ var a = document.defaultView ? document.defaultView.getComputedStyle(this, null) : this.currentStyle,
+ b = {},
+ c,
+ d;
+ if (a && a.length && a[0] && a[a[0]]) {
+ var e = a.length;
+ while (e--) c = a[e],
+ typeof a[c] == "string" && (d = c.replace(/\-(\w)/g,
+ function(a, b) {
+ return b.toUpperCase()
+ }), b[d] = a[c])
+ } else for (c in a) typeof a[c] == "string" && (b[c] = a[c]);
+ return b
+ }
+ function d(b, d) {
+ var e;
+ do {
+ e = a.curCSS(b, d);
+ if (e != "" && e != "transparent" || a.nodeName(b, "body")) break;
+ d = "backgroundColor"
+ } while ( b = b . parentNode );
+ return c(e)
+ }
+ function c(b) {
+ var c;
+ if (b && b.constructor == Array && b.length == 3) return b;
+ if (c = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(b)) return [parseInt(c[1], 10), parseInt(c[2], 10), parseInt(c[3], 10)];
+ if (c = /rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(b)) return [parseFloat(c[1]) * 2.55, parseFloat(c[2]) * 2.55, parseFloat(c[3]) * 2.55];
+ if (c = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(b)) return [parseInt(c[1], 16), parseInt(c[2], 16), parseInt(c[3], 16)];
+ if (c = /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(b)) return [parseInt(c[1] + c[1], 16), parseInt(c[2] + c[2], 16), parseInt(c[3] + c[3], 16)];
+ if (c = /rgba\(0, 0, 0, 0\)/.exec(b)) return e.transparent;
+ return e[a.trim(b).toLowerCase()]
+ }
+ a.effects = {},
+ a.each(["backgroundColor", "borderBottomColor", "borderLeftColor", "borderRightColor", "borderTopColor", "borderColor", "color", "outlineColor"],
+ function(b, e) {
+ a.fx.step[e] = function(a) {
+ a.colorInit || (a.start = d(a.elem, e), a.end = c(a.end), a.colorInit = !0),
+ a.elem.style[e] = "rgb(" + Math.max(Math.min(parseInt(a.pos * (a.end[0] - a.start[0]) + a.start[0], 10), 255), 0) + "," + Math.max(Math.min(parseInt(a.pos * (a.end[1] - a.start[1]) + a.start[1], 10), 255), 0) + "," + Math.max(Math.min(parseInt(a.pos * (a.end[2] - a.start[2]) + a.start[2], 10), 255), 0) + ")"
+ }
+ });
+ var e = {
+ aqua: [0, 255, 255],
+ azure: [240, 255, 255],
+ beige: [245, 245, 220],
+ black: [0, 0, 0],
+ blue: [0, 0, 255],
+ brown: [165, 42, 42],
+ cyan: [0, 255, 255],
+ darkblue: [0, 0, 139],
+ darkcyan: [0, 139, 139],
+ darkgrey: [169, 169, 169],
+ darkgreen: [0, 100, 0],
+ darkkhaki: [189, 183, 107],
+ darkmagenta: [139, 0, 139],
+ darkolivegreen: [85, 107, 47],
+ darkorange: [255, 140, 0],
+ darkorchid: [153, 50, 204],
+ darkred: [139, 0, 0],
+ darksalmon: [233, 150, 122],
+ darkviolet: [148, 0, 211],
+ fuchsia: [255, 0, 255],
+ gold: [255, 215, 0],
+ green: [0, 128, 0],
+ indigo: [75, 0, 130],
+ khaki: [240, 230, 140],
+ lightblue: [173, 216, 230],
+ lightcyan: [224, 255, 255],
+ lightgreen: [144, 238, 144],
+ lightgrey: [211, 211, 211],
+ lightpink: [255, 182, 193],
+ lightyellow: [255, 255, 224],
+ lime: [0, 255, 0],
+ magenta: [255, 0, 255],
+ maroon: [128, 0, 0],
+ navy: [0, 0, 128],
+ olive: [128, 128, 0],
+ orange: [255, 165, 0],
+ pink: [255, 192, 203],
+ purple: [128, 0, 128],
+ violet: [128, 0, 128],
+ red: [255, 0, 0],
+ silver: [192, 192, 192],
+ white: [255, 255, 255],
+ yellow: [255, 255, 0],
+ transparent: [255, 255, 255]
+ },
+ f = ["add", "remove", "toggle"],
+ g = {
+ border: 1,
+ borderBottom: 1,
+ borderColor: 1,
+ borderLeft: 1,
+ borderRight: 1,
+ borderTop: 1,
+ borderWidth: 1,
+ margin: 1,
+ padding: 1
+ };
+ a.effects.animateClass = function(b, c, d, e) {
+ a.isFunction(d) && (e = d, d = null);
+ return this.queue(function() {
+ var g = a(this),
+ k = g.attr("style") || " ",
+ l = i(h.call(this)),
+ m,
+ n = g.attr("class");
+ a.each(f,
+ function(a, c) {
+ b[c] && g[c + "Class"](b[c])
+ }),
+ m = i(h.call(this)),
+ g.attr("class", n),
+ g.animate(j(l, m), {
+ queue: !1,
+ duration: c,
+ easing: d,
+ complete: function() {
+ a.each(f,
+ function(a, c) {
+ b[c] && g[c + "Class"](b[c])
+ }),
+ typeof g.attr("style") == "object" ? (g.attr("style").cssText = "", g.attr("style").cssText = k) : g.attr("style", k),
+ e && e.apply(this, arguments),
+ a.dequeue(this)
+ }
+ })
+ })
+ },
+ a.fn.extend({
+ _addClass: a.fn.addClass,
+ addClass: function(b, c, d, e) {
+ return c ? a.effects.animateClass.apply(this, [{
+ add: b
+ },
+ c, d, e]) : this._addClass(b)
+ },
+ _removeClass: a.fn.removeClass,
+ removeClass: function(b, c, d, e) {
+ return c ? a.effects.animateClass.apply(this, [{
+ remove: b
+ },
+ c, d, e]) : this._removeClass(b)
+ },
+ _toggleClass: a.fn.toggleClass,
+ toggleClass: function(c, d, e, f, g) {
+ return typeof d == "boolean" || d === b ? e ? a.effects.animateClass.apply(this, [d ? {
+ add: c
+ }: {
+ remove: c
+ },
+ e, f, g]) : this._toggleClass(c, d) : a.effects.animateClass.apply(this, [{
+ toggle: c
+ },
+ d, e, f])
+ },
+ switchClass: function(b, c, d, e, f) {
+ return a.effects.animateClass.apply(this, [{
+ add: c,
+ remove: b
+ },
+ d, e, f])
+ }
+ }),
+ a.extend(a.effects, {
+ version: "1.8.18",
+ save: function(a, b) {
+ for (var c = 0; c < b.length; c++) b[c] !== null && a.data("ec.storage." + b[c], a[0].style[b[c]])
+ },
+ restore: function(a, b) {
+ for (var c = 0; c < b.length; c++) b[c] !== null && a.css(b[c], a.data("ec.storage." + b[c]))
+ },
+ setMode: function(a, b) {
+ b == "toggle" && (b = a.is(":hidden") ? "show": "hide");
+ return b
+ },
+ getBaseline: function(a, b) {
+ var c, d;
+ switch (a[0]) {
+ case "top":
+ c = 0;
+ break;
+ case "middle":
+ c = .5;
+ break;
+ case "bottom":
+ c = 1;
+ break;
+ default:
+ c = a[0] / b.height
+ }
+ switch (a[1]) {
+ case "left":
+ d = 0;
+ break;
+ case "center":
+ d = .5;
+ break;
+ case "right":
+ d = 1;
+ break;
+ default:
+ d = a[1] / b.width
+ }
+ return {
+ x: d,
+ y: c
+ }
+ },
+ createWrapper: function(b) {
+ if (b.parent().is(".ui-effects-wrapper")) return b.parent();
+ var c = {
+ width: b.outerWidth(!0),
+ height: b.outerHeight(!0),
+ "float": b.css("float")
+ },
+ d = a("<div></div>").addClass("ui-effects-wrapper").css({
+ fontSize: "100%",
+ background: "transparent",
+ border: "none",
+ margin: 0,
+ padding: 0
+ }),
+ e = document.activeElement;
+ b.wrap(d),
+ (b[0] === e || a.contains(b[0], e)) && a(e).focus(),
+ d = b.parent(),
+ b.css("position") == "static" ? (d.css({
+ position: "relative"
+ }), b.css({
+ position: "relative"
+ })) : (a.extend(c, {
+ position: b.css("position"),
+ zIndex: b.css("z-index")
+ }), a.each(["top", "left", "bottom", "right"],
+ function(a, d) {
+ c[d] = b.css(d),
+ isNaN(parseInt(c[d], 10)) && (c[d] = "auto")
+ }), b.css({
+ position: "relative",
+ top: 0,
+ left: 0,
+ right: "auto",
+ bottom: "auto"
+ }));
+ return d.css(c).show()
+ },
+ removeWrapper: function(b) {
+ var c, d = document.activeElement;
+ if (b.parent().is(".ui-effects-wrapper")) {
+ c = b.parent().replaceWith(b),
+ (b[0] === d || a.contains(b[0], d)) && a(d).focus();
+ return c
+ }
+ return b
+ },
+ setTransition: function(b, c, d, e) {
+ e = e || {},
+ a.each(c,
+ function(a, c) {
+ unit = b.cssUnit(c),
+ unit[0] > 0 && (e[c] = unit[0] * d + unit[1])
+ });
+ return e
+ }
+ }),
+ a.fn.extend({
+ effect: function(b, c, d, e) {
+ var f = k.apply(this, arguments),
+ g = {
+ options: f[1],
+ duration: f[2],
+ callback: f[3]
+ },
+ h = g.options.mode,
+ i = a.effects[b];
+ if (a.fx.off || !i) return h ? this[h](g.duration, g.callback) : this.each(function() {
+ g.callback && g.callback.call(this)
+ });
+ return i.call(this, g)
+ },
+ _show: a.fn.show,
+ show: function(a) {
+ if (l(a)) return this._show.apply(this, arguments);
+ var b = k.apply(this, arguments);
+ b[1].mode = "show";
+ return this.effect.apply(this, b)
+ },
+ _hide: a.fn.hide,
+ hide: function(a) {
+ if (l(a)) return this._hide.apply(this, arguments);
+ var b = k.apply(this, arguments);
+ b[1].mode = "hide";
+ return this.effect.apply(this, b)
+ },
+ __toggle: a.fn.toggle,
+ toggle: function(b) {
+ if (l(b) || typeof b == "boolean" || a.isFunction(b)) return this.__toggle.apply(this, arguments);
+ var c = k.apply(this, arguments);
+ c[1].mode = "toggle";
+ return this.effect.apply(this, c)
+ },
+ cssUnit: function(b) {
+ var c = this.css(b),
+ d = [];
+ a.each(["em", "px", "%", "pt"],
+ function(a, b) {
+ c.indexOf(b) > 0 && (d = [parseFloat(c), b])
+ });
+ return d
+ }
+ }),
+ a.easing.jswing = a.easing.swing,
+ a.extend(a.easing, {
+ def: "easeOutQuad",
+ swing: function(b, c, d, e, f) {
+ return a.easing[a.easing.def](b, c, d, e, f)
+ },
+ easeInQuad: function(a, b, c, d, e) {
+ return d * (b /= e) * b + c
+ },
+ easeOutQuad: function(a, b, c, d, e) {
+ return - d * (b /= e) * (b - 2) + c
+ },
+ easeInOutQuad: function(a, b, c, d, e) {
+ if ((b /= e / 2) < 1) return d / 2 * b * b + c;
+ return - d / 2 * (--b * (b - 2) - 1) + c
+ },
+ easeInCubic: function(a, b, c, d, e) {
+ return d * (b /= e) * b * b + c
+ },
+ easeOutCubic: function(a, b, c, d, e) {
+ return d * ((b = b / e - 1) * b * b + 1) + c
+ },
+ easeInOutCubic: function(a, b, c, d, e) {
+ if ((b /= e / 2) < 1) return d / 2 * b * b * b + c;
+ return d / 2 * ((b -= 2) * b * b + 2) + c
+ },
+ easeInQuart: function(a, b, c, d, e) {
+ return d * (b /= e) * b * b * b + c
+ },
+ easeOutQuart: function(a, b, c, d, e) {
+ return - d * ((b = b / e - 1) * b * b * b - 1) + c
+ },
+ easeInOutQuart: function(a, b, c, d, e) {
+ if ((b /= e / 2) < 1) return d / 2 * b * b * b * b + c;
+ return - d / 2 * ((b -= 2) * b * b * b - 2) + c
+ },
+ easeInQuint: function(a, b, c, d, e) {
+ return d * (b /= e) * b * b * b * b + c
+ },
+ easeOutQuint: function(a, b, c, d, e) {
+ return d * ((b = b / e - 1) * b * b * b * b + 1) + c
+ },
+ easeInOutQuint: function(a, b, c, d, e) {
+ if ((b /= e / 2) < 1) return d / 2 * b * b * b * b * b + c;
+ return d / 2 * ((b -= 2) * b * b * b * b + 2) + c
+ },
+ easeInSine: function(a, b, c, d, e) {
+ return - d * Math.cos(b / e * (Math.PI / 2)) + d + c
+ },
+ easeOutSine: function(a, b, c, d, e) {
+ return d * Math.sin(b / e * (Math.PI / 2)) + c
+ },
+ easeInOutSine: function(a, b, c, d, e) {
+ return - d / 2 * (Math.cos(Math.PI * b / e) - 1) + c
+ },
+ easeInExpo: function(a, b, c, d, e) {
+ return b == 0 ? c: d * Math.pow(2, 10 * (b / e - 1)) + c
+ },
+ easeOutExpo: function(a, b, c, d, e) {
+ return b == e ? c + d: d * ( - Math.pow(2, -10 * b / e) + 1) + c
+ },
+ easeInOutExpo: function(a, b, c, d, e) {
+ if (b == 0) return c;
+ if (b == e) return c + d;
+ if ((b /= e / 2) < 1) return d / 2 * Math.pow(2, 10 * (b - 1)) + c;
+ return d / 2 * ( - Math.pow(2, -10 * --b) + 2) + c
+ },
+ easeInCirc: function(a, b, c, d, e) {
+ return - d * (Math.sqrt(1 - (b /= e) * b) - 1) + c
+ },
+ easeOutCirc: function(a, b, c, d, e) {
+ return d * Math.sqrt(1 - (b = b / e - 1) * b) + c
+ },
+ easeInOutCirc: function(a, b, c, d, e) {
+ if ((b /= e / 2) < 1) return - d / 2 * (Math.sqrt(1 - b * b) - 1) + c;
+ return d / 2 * (Math.sqrt(1 - (b -= 2) * b) + 1) + c
+ },
+ easeInElastic: function(a, b, c, d, e) {
+ var f = 1.70158,
+ g = 0,
+ h = d;
+ if (b == 0) return c;
+ if ((b /= e) == 1) return c + d;
+ g || (g = e * .3);
+ if (h < Math.abs(d)) {
+ h = d;
+ var f = g / 4
+ } else var f = g / (2 * Math.PI) * Math.asin(d / h);
+ return - (h * Math.pow(2, 10 * (b -= 1)) * Math.sin((b * e - f) * 2 * Math.PI / g)) + c
+ },
+ easeOutElastic: function(a, b, c, d, e) {
+ var f = 1.70158,
+ g = 0,
+ h = d;
+ if (b == 0) return c;
+ if ((b /= e) == 1) return c + d;
+ g || (g = e * .3);
+ if (h < Math.abs(d)) {
+ h = d;
+ var f = g / 4
+ } else var f = g / (2 * Math.PI) * Math.asin(d / h);
+ return h * Math.pow(2, -10 * b) * Math.sin((b * e - f) * 2 * Math.PI / g) + d + c
+ },
+ easeInOutElastic: function(a, b, c, d, e) {
+ var f = 1.70158,
+ g = 0,
+ h = d;
+ if (b == 0) return c;
+ if ((b /= e / 2) == 2) return c + d;
+ g || (g = e * .3 * 1.5);
+ if (h < Math.abs(d)) {
+ h = d;
+ var f = g / 4
+ } else var f = g / (2 * Math.PI) * Math.asin(d / h);
+ if (b < 1) return - 0.5 * h * Math.pow(2, 10 * (b -= 1)) * Math.sin((b * e - f) * 2 * Math.PI / g) + c;
+ return h * Math.pow(2, -10 * (b -= 1)) * Math.sin((b * e - f) * 2 * Math.PI / g) * .5 + d + c
+ },
+ easeInBack: function(a, c, d, e, f, g) {
+ g == b && (g = 1.70158);
+ return e * (c /= f) * c * ((g + 1) * c - g) + d
+ },
+ easeOutBack: function(a, c, d, e, f, g) {
+ g == b && (g = 1.70158);
+ return e * ((c = c / f - 1) * c * ((g + 1) * c + g) + 1) + d
+ },
+ easeInOutBack: function(a, c, d, e, f, g) {
+ g == b && (g = 1.70158);
+ if ((c /= f / 2) < 1) return e / 2 * c * c * (((g *= 1.525) + 1) * c - g) + d;
+ return e / 2 * ((c -= 2) * c * (((g *= 1.525) + 1) * c + g) + 2) + d
+ },
+ easeInBounce: function(b, c, d, e, f) {
+ return e - a.easing.easeOutBounce(b, f - c, 0, e, f) + d
+ },
+ easeOutBounce: function(a, b, c, d, e) {
+ return (b /= e) < 1 / 2.75 ? d * 7.5625 * b * b + c: b < 2 / 2.75 ? d * (7.5625 * (b -= 1.5 / 2.75) * b + .75) + c: b < 2.5 / 2.75 ? d * (7.5625 * (b -= 2.25 / 2.75) * b + .9375) + c: d * (7.5625 * (b -= 2.625 / 2.75) * b + .984375) + c
+ },
+ easeInOutBounce: function(b, c, d, e, f) {
+ if (c < f / 2) return a.easing.easeInBounce(b, c * 2, 0, e, f) * .5 + d;
+ return a.easing.easeOutBounce(b, c * 2 - f, 0, e, f) * .5 + e * .5 + d
+ }
+ })
+} (jQuery);
+/*
+ * jQuery UI Effects Blind 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Blind
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.blind = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right"],
+ e = a.effects.setMode(c, b.options.mode || "hide"),
+ f = b.options.direction || "vertical";
+ a.effects.save(c, d),
+ c.show();
+ var g = a.effects.createWrapper(c).css({
+ overflow: "hidden"
+ }),
+ h = f == "vertical" ? "height": "width",
+ i = f == "vertical" ? g.height() : g.width();
+ e == "show" && g.css(h, 0);
+ var j = {};
+ j[h] = e == "show" ? i: 0,
+ g.animate(j, b.duration, b.options.easing,
+ function() {
+ e == "hide" && c.hide(),
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(c[0], arguments),
+ c.dequeue()
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Bounce 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Bounce
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.bounce = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right"],
+ e = a.effects.setMode(c, b.options.mode || "effect"),
+ f = b.options.direction || "up",
+ g = b.options.distance || 20,
+ h = b.options.times || 5,
+ i = b.duration || 250;
+ /show|hide/.test(e) && d.push("opacity"),
+ a.effects.save(c, d),
+ c.show(),
+ a.effects.createWrapper(c);
+ var j = f == "up" || f == "down" ? "top": "left",
+ k = f == "up" || f == "left" ? "pos": "neg",
+ g = b.options.distance || (j == "top" ? c.outerHeight({
+ margin: !0
+ }) / 3 : c.outerWidth({
+ margin: !0
+ }) / 3);
+ e == "show" && c.css("opacity", 0).css(j, k == "pos" ? -g: g),
+ e == "hide" && (g = g / (h * 2)),
+ e != "hide" && h--;
+ if (e == "show") {
+ var l = {
+ opacity: 1
+ };
+ l[j] = (k == "pos" ? "+=": "-=") + g,
+ c.animate(l, i / 2, b.options.easing),
+ g = g / 2,
+ h--
+ }
+ for (var m = 0; m < h; m++) {
+ var n = {},
+ p = {};
+ n[j] = (k == "pos" ? "-=": "+=") + g,
+ p[j] = (k == "pos" ? "+=": "-=") + g,
+ c.animate(n, i / 2, b.options.easing).animate(p, i / 2, b.options.easing),
+ g = e == "hide" ? g * 2 : g / 2
+ }
+ if (e == "hide") {
+ var l = {
+ opacity: 0
+ };
+ l[j] = (k == "pos" ? "-=": "+=") + g,
+ c.animate(l, i / 2, b.options.easing,
+ function() {
+ c.hide(),
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(this, arguments)
+ })
+ } else {
+ var n = {},
+ p = {};
+ n[j] = (k == "pos" ? "-=": "+=") + g,
+ p[j] = (k == "pos" ? "+=": "-=") + g,
+ c.animate(n, i / 2, b.options.easing).animate(p, i / 2, b.options.easing,
+ function() {
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(this, arguments)
+ })
+ }
+ c.queue("fx",
+ function() {
+ c.dequeue()
+ }),
+ c.dequeue()
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Clip 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Clip
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.clip = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right", "height", "width"],
+ e = a.effects.setMode(c, b.options.mode || "hide"),
+ f = b.options.direction || "vertical";
+ a.effects.save(c, d),
+ c.show();
+ var g = a.effects.createWrapper(c).css({
+ overflow: "hidden"
+ }),
+ h = c[0].tagName == "IMG" ? g: c,
+ i = {
+ size: f == "vertical" ? "height": "width",
+ position: f == "vertical" ? "top": "left"
+ },
+ j = f == "vertical" ? h.height() : h.width();
+ e == "show" && (h.css(i.size, 0), h.css(i.position, j / 2));
+ var k = {};
+ k[i.size] = e == "show" ? j: 0,
+ k[i.position] = e == "show" ? 0 : j / 2,
+ h.animate(k, {
+ queue: !1,
+ duration: b.duration,
+ easing: b.options.easing,
+ complete: function() {
+ e == "hide" && c.hide(),
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(c[0], arguments),
+ c.dequeue()
+ }
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Drop 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Drop
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.drop = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right", "opacity"],
+ e = a.effects.setMode(c, b.options.mode || "hide"),
+ f = b.options.direction || "left";
+ a.effects.save(c, d),
+ c.show(),
+ a.effects.createWrapper(c);
+ var g = f == "up" || f == "down" ? "top": "left",
+ h = f == "up" || f == "left" ? "pos": "neg",
+ i = b.options.distance || (g == "top" ? c.outerHeight({
+ margin: !0
+ }) / 2 : c.outerWidth({
+ margin: !0
+ }) / 2);
+ e == "show" && c.css("opacity", 0).css(g, h == "pos" ? -i: i);
+ var j = {
+ opacity: e == "show" ? 1 : 0
+ };
+ j[g] = (e == "show" ? h == "pos" ? "+=": "-=": h == "pos" ? "-=": "+=") + i,
+ c.animate(j, {
+ queue: !1,
+ duration: b.duration,
+ easing: b.options.easing,
+ complete: function() {
+ e == "hide" && c.hide(),
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(this, arguments),
+ c.dequeue()
+ }
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Explode 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Explode
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.explode = function(b) {
+ return this.queue(function() {
+ var c = b.options.pieces ? Math.round(Math.sqrt(b.options.pieces)) : 3,
+ d = b.options.pieces ? Math.round(Math.sqrt(b.options.pieces)) : 3;
+ b.options.mode = b.options.mode == "toggle" ? a(this).is(":visible") ? "hide": "show": b.options.mode;
+ var e = a(this).show().css("visibility", "hidden"),
+ f = e.offset();
+ f.top -= parseInt(e.css("marginTop"), 10) || 0,
+ f.left -= parseInt(e.css("marginLeft"), 10) || 0;
+ var g = e.outerWidth(!0),
+ h = e.outerHeight(!0);
+ for (var i = 0; i < c; i++) for (var j = 0; j < d; j++) e.clone().appendTo("body").wrap("<div></div>").css({
+ position: "absolute",
+ visibility: "visible",
+ left: -j * (g / d),
+ top: -i * (h / c)
+ }).parent().addClass("ui-effects-explode").css({
+ position: "absolute",
+ overflow: "hidden",
+ width: g / d,
+ height: h / c,
+ left: f.left + j * (g / d) + (b.options.mode == "show" ? (j - Math.floor(d / 2)) * (g / d) : 0),
+ top: f.top + i * (h / c) + (b.options.mode == "show" ? (i - Math.floor(c / 2)) * (h / c) : 0),
+ opacity: b.options.mode == "show" ? 0 : 1
+ }).animate({
+ left: f.left + j * (g / d) + (b.options.mode == "show" ? 0 : (j - Math.floor(d / 2)) * (g / d)),
+ top: f.top + i * (h / c) + (b.options.mode == "show" ? 0 : (i - Math.floor(c / 2)) * (h / c)),
+ opacity: b.options.mode == "show" ? 1 : 0
+ },
+ b.duration || 500);
+ setTimeout(function() {
+ b.options.mode == "show" ? e.css({
+ visibility: "visible"
+ }) : e.css({
+ visibility: "visible"
+ }).hide(),
+ b.callback && b.callback.apply(e[0]),
+ e.dequeue(),
+ a("div.ui-effects-explode").remove()
+ },
+ b.duration || 500)
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Fade 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Fade
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.fade = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = a.effects.setMode(c, b.options.mode || "hide");
+ c.animate({
+ opacity: d
+ },
+ {
+ queue: !1,
+ duration: b.duration,
+ easing: b.options.easing,
+ complete: function() {
+ b.callback && b.callback.apply(this, arguments),
+ c.dequeue()
+ }
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Fold 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Fold
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.fold = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right"],
+ e = a.effects.setMode(c, b.options.mode || "hide"),
+ f = b.options.size || 15,
+ g = !!b.options.horizFirst,
+ h = b.duration ? b.duration / 2 : a.fx.speeds._default / 2;
+ a.effects.save(c, d),
+ c.show();
+ var i = a.effects.createWrapper(c).css({
+ overflow: "hidden"
+ }),
+ j = e == "show" != g,
+ k = j ? ["width", "height"] : ["height", "width"],
+ l = j ? [i.width(), i.height()] : [i.height(), i.width()],
+ m = /([0-9]+)%/.exec(f);
+ m && (f = parseInt(m[1], 10) / 100 * l[e == "hide" ? 0 : 1]),
+ e == "show" && i.css(g ? {
+ height: 0,
+ width: f
+ }: {
+ height: f,
+ width: 0
+ });
+ var n = {},
+ p = {};
+ n[k[0]] = e == "show" ? l[0] : f,
+ p[k[1]] = e == "show" ? l[1] : 0,
+ i.animate(n, h, b.options.easing).animate(p, h, b.options.easing,
+ function() {
+ e == "hide" && c.hide(),
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(c[0], arguments),
+ c.dequeue()
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Highlight 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Highlight
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.highlight = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["backgroundImage", "backgroundColor", "opacity"],
+ e = a.effects.setMode(c, b.options.mode || "show"),
+ f = {
+ backgroundColor: c.css("backgroundColor")
+ };
+ e == "hide" && (f.opacity = 0),
+ a.effects.save(c, d),
+ c.show().css({
+ backgroundImage: "none",
+ backgroundColor: b.options.color || "#ffff99"
+ }).animate(f, {
+ queue: !1,
+ duration: b.duration,
+ easing: b.options.easing,
+ complete: function() {
+ e == "hide" && c.hide(),
+ a.effects.restore(c, d),
+ e == "show" && !a.support.opacity && this.style.removeAttribute("filter"),
+ b.callback && b.callback.apply(this, arguments),
+ c.dequeue()
+ }
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Pulsate 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Pulsate
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.pulsate = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = a.effects.setMode(c, b.options.mode || "show");
+ times = (b.options.times || 5) * 2 - 1,
+ duration = b.duration ? b.duration / 2 : a.fx.speeds._default / 2,
+ isVisible = c.is(":visible"),
+ animateTo = 0,
+ isVisible || (c.css("opacity", 0).show(), animateTo = 1),
+ (d == "hide" && isVisible || d == "show" && !isVisible) && times--;
+ for (var e = 0; e < times; e++) c.animate({
+ opacity: animateTo
+ },
+ duration, b.options.easing),
+ animateTo = (animateTo + 1) % 2;
+ c.animate({
+ opacity: animateTo
+ },
+ duration, b.options.easing,
+ function() {
+ animateTo == 0 && c.hide(),
+ b.callback && b.callback.apply(this, arguments)
+ }),
+ c.queue("fx",
+ function() {
+ c.dequeue()
+ }).dequeue()
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Scale 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Scale
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.puff = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = a.effects.setMode(c, b.options.mode || "hide"),
+ e = parseInt(b.options.percent, 10) || 150,
+ f = e / 100,
+ g = {
+ height: c.height(),
+ width: c.width()
+ };
+ a.extend(b.options, {
+ fade: !0,
+ mode: d,
+ percent: d == "hide" ? e: 100,
+ from: d == "hide" ? g: {
+ height: g.height * f,
+ width: g.width * f
+ }
+ }),
+ c.effect("scale", b.options, b.duration, b.callback),
+ c.dequeue()
+ })
+ },
+ a.effects.scale = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = a.extend(!0, {},
+ b.options),
+ e = a.effects.setMode(c, b.options.mode || "effect"),
+ f = parseInt(b.options.percent, 10) || (parseInt(b.options.percent, 10) == 0 ? 0 : e == "hide" ? 0 : 100),
+ g = b.options.direction || "both",
+ h = b.options.origin;
+ e != "effect" && (d.origin = h || ["middle", "center"], d.restore = !0);
+ var i = {
+ height: c.height(),
+ width: c.width()
+ };
+ c.from = b.options.from || (e == "show" ? {
+ height: 0,
+ width: 0
+ }: i);
+ var j = {
+ y: g != "horizontal" ? f / 100 : 1,
+ x: g != "vertical" ? f / 100 : 1
+ };
+ c.to = {
+ height: i.height * j.y,
+ width: i.width * j.x
+ },
+ b.options.fade && (e == "show" && (c.from.opacity = 0, c.to.opacity = 1), e == "hide" && (c.from.opacity = 1, c.to.opacity = 0)),
+ d.from = c.from,
+ d.to = c.to,
+ d.mode = e,
+ c.effect("size", d, b.duration, b.callback),
+ c.dequeue()
+ })
+ },
+ a.effects.size = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right", "width", "height", "overflow", "opacity"],
+ e = ["position", "top", "bottom", "left", "right", "overflow", "opacity"],
+ f = ["width", "height", "overflow"],
+ g = ["fontSize"],
+ h = ["borderTopWidth", "borderBottomWidth", "paddingTop", "paddingBottom"],
+ i = ["borderLeftWidth", "borderRightWidth", "paddingLeft", "paddingRight"],
+ j = a.effects.setMode(c, b.options.mode || "effect"),
+ k = b.options.restore || !1,
+ l = b.options.scale || "both",
+ m = b.options.origin,
+ n = {
+ height: c.height(),
+ width: c.width()
+ };
+ c.from = b.options.from || n,
+ c.to = b.options.to || n;
+ if (m) {
+ var p = a.effects.getBaseline(m, n);
+ c.from.top = (n.height - c.from.height) * p.y,
+ c.from.left = (n.width - c.from.width) * p.x,
+ c.to.top = (n.height - c.to.height) * p.y,
+ c.to.left = (n.width - c.to.width) * p.x
+ }
+ var q = {
+ from: {
+ y: c.from.height / n.height,
+ x: c.from.width / n.width
+ },
+ to: {
+ y: c.to.height / n.height,
+ x: c.to.width / n.width
+ }
+ };
+ if (l == "box" || l == "both") q.from.y != q.to.y && (d = d.concat(h), c.from = a.effects.setTransition(c, h, q.from.y, c.from), c.to = a.effects.setTransition(c, h, q.to.y, c.to)),
+ q.from.x != q.to.x && (d = d.concat(i), c.from = a.effects.setTransition(c, i, q.from.x, c.from), c.to = a.effects.setTransition(c, i, q.to.x, c.to)); (l == "content" || l == "both") && q.from.y != q.to.y && (d = d.concat(g), c.from = a.effects.setTransition(c, g, q.from.y, c.from), c.to = a.effects.setTransition(c, g, q.to.y, c.to)),
+ a.effects.save(c, k ? d: e),
+ c.show(),
+ a.effects.createWrapper(c),
+ c.css("overflow", "hidden").css(c.from);
+ if (l == "content" || l == "both") h = h.concat(["marginTop", "marginBottom"]).concat(g),
+ i = i.concat(["marginLeft", "marginRight"]),
+ f = d.concat(h).concat(i),
+ c.find("*[width]").each(function() {
+ child = a(this),
+ k && a.effects.save(child, f);
+ var c = {
+ height: child.height(),
+ width: child.width()
+ };
+ child.from = {
+ height: c.height * q.from.y,
+ width: c.width * q.from.x
+ },
+ child.to = {
+ height: c.height * q.to.y,
+ width: c.width * q.to.x
+ },
+ q.from.y != q.to.y && (child.from = a.effects.setTransition(child, h, q.from.y, child.from), child.to = a.effects.setTransition(child, h, q.to.y, child.to)),
+ q.from.x != q.to.x && (child.from = a.effects.setTransition(child, i, q.from.x, child.from), child.to = a.effects.setTransition(child, i, q.to.x, child.to)),
+ child.css(child.from),
+ child.animate(child.to, b.duration, b.options.easing,
+ function() {
+ k && a.effects.restore(child, f)
+ })
+ });
+ c.animate(c.to, {
+ queue: !1,
+ duration: b.duration,
+ easing: b.options.easing,
+ complete: function() {
+ c.to.opacity === 0 && c.css("opacity", c.from.opacity),
+ j == "hide" && c.hide(),
+ a.effects.restore(c, k ? d: e),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(this, arguments),
+ c.dequeue()
+ }
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Shake 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Shake
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.shake = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right"],
+ e = a.effects.setMode(c, b.options.mode || "effect"),
+ f = b.options.direction || "left",
+ g = b.options.distance || 20,
+ h = b.options.times || 3,
+ i = b.duration || b.options.duration || 140;
+ a.effects.save(c, d),
+ c.show(),
+ a.effects.createWrapper(c);
+ var j = f == "up" || f == "down" ? "top": "left",
+ k = f == "up" || f == "left" ? "pos": "neg",
+ l = {},
+ m = {},
+ n = {};
+ l[j] = (k == "pos" ? "-=": "+=") + g,
+ m[j] = (k == "pos" ? "+=": "-=") + g * 2,
+ n[j] = (k == "pos" ? "-=": "+=") + g * 2,
+ c.animate(l, i, b.options.easing);
+ for (var p = 1; p < h; p++) c.animate(m, i, b.options.easing).animate(n, i, b.options.easing);
+ c.animate(m, i, b.options.easing).animate(l, i / 2, b.options.easing,
+ function() {
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(this, arguments)
+ }),
+ c.queue("fx",
+ function() {
+ c.dequeue()
+ }),
+ c.dequeue()
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Slide 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Slide
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.slide = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = ["position", "top", "bottom", "left", "right"],
+ e = a.effects.setMode(c, b.options.mode || "show"),
+ f = b.options.direction || "left";
+ a.effects.save(c, d),
+ c.show(),
+ a.effects.createWrapper(c).css({
+ overflow: "hidden"
+ });
+ var g = f == "up" || f == "down" ? "top": "left",
+ h = f == "up" || f == "left" ? "pos": "neg",
+ i = b.options.distance || (g == "top" ? c.outerHeight({
+ margin: !0
+ }) : c.outerWidth({
+ margin: !0
+ }));
+ e == "show" && c.css(g, h == "pos" ? isNaN(i) ? "-" + i: -i: i);
+ var j = {};
+ j[g] = (e == "show" ? h == "pos" ? "+=": "-=": h == "pos" ? "-=": "+=") + i,
+ c.animate(j, {
+ queue: !1,
+ duration: b.duration,
+ easing: b.options.easing,
+ complete: function() {
+ e == "hide" && c.hide(),
+ a.effects.restore(c, d),
+ a.effects.removeWrapper(c),
+ b.callback && b.callback.apply(this, arguments),
+ c.dequeue()
+ }
+ })
+ })
+ }
+})(jQuery);
+/*
+ * jQuery UI Effects Transfer 1.8.18
+ *
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * http://docs.jquery.com/UI/Effects/Transfer
+ *
+ * Depends:
+ * jquery.effects.core.js
+ */
+(function(a, b) {
+ a.effects.transfer = function(b) {
+ return this.queue(function() {
+ var c = a(this),
+ d = a(b.options.to),
+ e = d.offset(),
+ f = {
+ top: e.top,
+ left: e.left,
+ height: d.innerHeight(),
+ width: d.innerWidth()
+ },
+ g = c.offset(),
+ h = a('<div class="ui-effects-transfer"></div>').appendTo(document.body).addClass(b.options.className).css({
+ top: g.top,
+ left: g.left,
+ height: c.innerHeight(),
+ width: c.innerWidth(),
+ position: "absolute"
+ }).animate(f, b.duration, b.options.easing,
+ function() {
+ h.remove(),
+ b.callback && b.callback.apply(c[0], arguments),
+ c.dequeue()
+ })
+ })
+ }
+})(jQuery); \ No newline at end of file
diff --git a/97suifang-front/assets/plugins/datepicker/images/calendar.gif b/97suifang-front/assets/plugins/datepicker/images/calendar.gif
new file mode 100644
index 0000000..d0abaa7
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/calendar.gif
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/calendar.png b/97suifang-front/assets/plugins/datepicker/images/calendar.png
new file mode 100644
index 0000000..0245536
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/calendar.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_f6f6f6_1x400.png b/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_f6f6f6_1x400.png
new file mode 100644
index 0000000..9b383f4
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_f6f6f6_1x400.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_fdf5ce_1x400.png b/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_fdf5ce_1x400.png
new file mode 100644
index 0000000..a23baad
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_100_fdf5ce_1x400.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_65_ffffff_1x400.png b/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_65_ffffff_1x400.png
new file mode 100644
index 0000000..42ccba2
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-bg_glass_65_ffffff_1x400.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-bg_gloss-wave_35_f6a828_500x100.png b/97suifang-front/assets/plugins/datepicker/images/ui-bg_gloss-wave_35_f6a828_500x100.png
new file mode 100644
index 0000000..39d5824
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-bg_gloss-wave_35_f6a828_500x100.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_100_eeeeee_1x100.png b/97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_100_eeeeee_1x100.png
new file mode 100644
index 0000000..f127367
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_100_eeeeee_1x100.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_75_ffe45c_1x100.png b/97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_75_ffe45c_1x100.png
new file mode 100644
index 0000000..359397a
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-bg_highlight-soft_75_ffe45c_1x100.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-icons_ef8c08_256x240.png b/97suifang-front/assets/plugins/datepicker/images/ui-icons_ef8c08_256x240.png
new file mode 100644
index 0000000..85e63e9
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-icons_ef8c08_256x240.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/images/ui-icons_ffffff_256x240.png b/97suifang-front/assets/plugins/datepicker/images/ui-icons_ffffff_256x240.png
new file mode 100644
index 0000000..42f8f99
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/images/ui-icons_ffffff_256x240.png
Binary files differ
diff --git a/97suifang-front/assets/plugins/datepicker/language-zh-CN.js b/97suifang-front/assets/plugins/datepicker/language-zh-CN.js
new file mode 100644
index 0000000..96194fa
--- /dev/null
+++ b/97suifang-front/assets/plugins/datepicker/language-zh-CN.js
@@ -0,0 +1,23 @@
+/* Chinese initialisation for the jQuery UI date picker plugin. */
+/* Written by Cloudream (cloudream@gmail.com). */
+jQuery(function($){
+ $.datepicker.regional['zh-CN'] = {
+ closeText: '关闭',
+ prevText: '&#x3c;上月',
+ nextText: '下月&#x3e;',
+ currentText: '今天',
+ monthNames: ['一月','二月','三月','四月','五月','六月',
+ '七月','八月','九月','十月','十一月','十二月'],
+ monthNamesShort: ['一','二','三','四','五','六',
+ '七','八','九','十','十一','十二'],
+ dayNames: ['星期日','星期一','星期二','星期三','星期四','星期五','星期六'],
+ dayNamesShort: ['周日','周一','周二','周三','周四','周五','周六'],
+ dayNamesMin: ['日','一','二','三','四','五','六'],
+ weekHeader: '周',
+ dateFormat: 'yy-mm-dd',
+ firstDay: 1,
+ isRTL: false,
+ showMonthAfterYear: true,
+ yearSuffix: '年'};
+ $.datepicker.setDefaults($.datepicker.regional['zh-CN']);
+}); \ No newline at end of file
diff --git a/97suifang-front/assets/plugins/highcharts/highcharts-more.js b/97suifang-front/assets/plugins/highcharts/highcharts-more.js
new file mode 100644
index 0000000..1ccdd52
--- /dev/null
+++ b/97suifang-front/assets/plugins/highcharts/highcharts-more.js
@@ -0,0 +1,50 @@
+/*
+ Highcharts JS v3.0.4 (2013-08-02)
+
+ (c) 2009-2013 Torstein Hønsi
+
+ License: www.highcharts.com/license
+*/
+(function(l,C){function J(a,b,c){this.init.call(this,a,b,c)}function K(a,b,c){a.call(this,b,c);if(this.chart.polar)this.closeSegment=function(a){var c=this.xAxis.center;a.push("L",c[0],c[1])},this.closedStacks=!0}function L(a,b){var c=this.chart,d=this.options.animation,g=this.group,f=this.markerGroup,e=this.xAxis.center,i=c.plotLeft,o=c.plotTop;if(c.polar){if(c.renderer.isSVG)if(d===!0&&(d={}),b){if(c={translateX:e[0]+i,translateY:e[1]+o,scaleX:0.001,scaleY:0.001},g.attr(c),f)f.attrSetters=g.attrSetters,
+f.attr(c)}else c={translateX:i,translateY:o,scaleX:1,scaleY:1},g.animate(c,d),f&&f.animate(c,d),this.animate=null}else a.call(this,b)}var P=l.arrayMin,Q=l.arrayMax,r=l.each,F=l.extend,p=l.merge,R=l.map,q=l.pick,v=l.pInt,m=l.getOptions().plotOptions,h=l.seriesTypes,x=l.extendClass,M=l.splat,n=l.wrap,N=l.Axis,u=l.Tick,z=l.Series,t=h.column.prototype,s=Math,D=s.round,A=s.floor,S=s.max,w=function(){};F(J.prototype,{init:function(a,b,c){var d=this,g=d.defaultOptions;d.chart=b;if(b.angular)g.background=
+{};d.options=a=p(g,a);(a=a.background)&&r([].concat(M(a)).reverse(),function(a){var b=a.backgroundColor,a=p(d.defaultBackgroundOptions,a);if(b)a.backgroundColor=b;a.color=a.backgroundColor;c.options.plotBands.unshift(a)})},defaultOptions:{center:["50%","50%"],size:"85%",startAngle:0},defaultBackgroundOptions:{shape:"circle",borderWidth:1,borderColor:"silver",backgroundColor:{linearGradient:{x1:0,y1:0,x2:0,y2:1},stops:[[0,"#FFF"],[1,"#DDD"]]},from:Number.MIN_VALUE,innerRadius:0,to:Number.MAX_VALUE,
+outerRadius:"105%"}});var G=N.prototype,u=u.prototype,T={getOffset:w,redraw:function(){this.isDirty=!1},render:function(){this.isDirty=!1},setScale:w,setCategories:w,setTitle:w},O={isRadial:!0,defaultRadialGaugeOptions:{labels:{align:"center",x:0,y:null},minorGridLineWidth:0,minorTickInterval:"auto",minorTickLength:10,minorTickPosition:"inside",minorTickWidth:1,plotBands:[],tickLength:10,tickPosition:"inside",tickWidth:2,title:{rotation:0},zIndex:2},defaultRadialXOptions:{gridLineWidth:1,labels:{align:null,
+distance:15,x:0,y:null},maxPadding:0,minPadding:0,plotBands:[],showLastLabel:!1,tickLength:0},defaultRadialYOptions:{gridLineInterpolation:"circle",labels:{align:"right",x:-3,y:-2},plotBands:[],showLastLabel:!1,title:{x:4,text:null,rotation:90}},setOptions:function(a){this.options=p(this.defaultOptions,this.defaultRadialOptions,a)},getOffset:function(){G.getOffset.call(this);this.chart.axisOffset[this.side]=0;this.center=this.pane.center=h.pie.prototype.getCenter.call(this.pane)},getLinePath:function(a,
+b){var c=this.center,b=q(b,c[2]/2-this.offset);return this.chart.renderer.symbols.arc(this.left+c[0],this.top+c[1],b,b,{start:this.startAngleRad,end:this.endAngleRad,open:!0,innerR:0})},setAxisTranslation:function(){G.setAxisTranslation.call(this);if(this.center&&(this.transA=this.isCircular?(this.endAngleRad-this.startAngleRad)/(this.max-this.min||1):this.center[2]/2/(this.max-this.min||1),this.isXAxis))this.minPixelPadding=this.transA*this.minPointOffset+(this.reversed?(this.endAngleRad-this.startAngleRad)/
+4:0)},beforeSetTickPositions:function(){this.autoConnect&&(this.max+=this.categories&&1||this.pointRange||this.closestPointRange)},setAxisSize:function(){G.setAxisSize.call(this);if(this.center)this.len=this.width=this.height=this.isCircular?this.center[2]*(this.endAngleRad-this.startAngleRad)/2:this.center[2]/2},getPosition:function(a,b){if(!this.isCircular)b=this.translate(a),a=this.min;return this.postTranslate(this.translate(a),q(b,this.center[2]/2)-this.offset)},postTranslate:function(a,b){var c=
+this.chart,d=this.center,a=this.startAngleRad+a;return{x:c.plotLeft+d[0]+Math.cos(a)*b,y:c.plotTop+d[1]+Math.sin(a)*b}},getPlotBandPath:function(a,b,c){var d=this.center,g=this.startAngleRad,f=d[2]/2,e=[q(c.outerRadius,"100%"),c.innerRadius,q(c.thickness,10)],i=/%$/,o,k=this.isCircular;this.options.gridLineInterpolation==="polygon"?d=this.getPlotLinePath(a).concat(this.getPlotLinePath(b,!0)):(k||(e[0]=this.translate(a),e[1]=this.translate(b)),e=R(e,function(a){i.test(a)&&(a=v(a,10)*f/100);return a}),
+c.shape==="circle"||!k?(a=-Math.PI/2,b=Math.PI*1.5,o=!0):(a=g+this.translate(a),b=g+this.translate(b)),d=this.chart.renderer.symbols.arc(this.left+d[0],this.top+d[1],e[0],e[0],{start:a,end:b,innerR:q(e[1],e[0]-e[2]),open:o}));return d},getPlotLinePath:function(a,b){var c=this.center,d=this.chart,g=this.getPosition(a),f,e,i;this.isCircular?i=["M",c[0]+d.plotLeft,c[1]+d.plotTop,"L",g.x,g.y]:this.options.gridLineInterpolation==="circle"?(a=this.translate(a))&&(i=this.getLinePath(0,a)):(f=d.xAxis[0],
+i=[],a=this.translate(a),c=f.tickPositions,f.autoConnect&&(c=c.concat([c[0]])),b&&(c=[].concat(c).reverse()),r(c,function(c,b){e=f.getPosition(c,a);i.push(b?"L":"M",e.x,e.y)}));return i},getTitlePosition:function(){var a=this.center,b=this.chart,c=this.options.title;return{x:b.plotLeft+a[0]+(c.x||0),y:b.plotTop+a[1]-{high:0.5,middle:0.25,low:0}[c.align]*a[2]+(c.y||0)}}};n(G,"init",function(a,b,c){var j;var d=b.angular,g=b.polar,f=c.isX,e=d&&f,i,o;o=b.options;var k=c.pane||0;if(d){if(F(this,e?T:O),
+i=!f)this.defaultRadialOptions=this.defaultRadialGaugeOptions}else if(g)F(this,O),this.defaultRadialOptions=(i=f)?this.defaultRadialXOptions:p(this.defaultYAxisOptions,this.defaultRadialYOptions);a.call(this,b,c);if(!e&&(d||g)){a=this.options;if(!b.panes)b.panes=[];this.pane=(j=b.panes[k]=b.panes[k]||new J(M(o.pane)[k],b,this),k=j);k=k.options;b.inverted=!1;o.chart.zoomType=null;this.startAngleRad=b=(k.startAngle-90)*Math.PI/180;this.endAngleRad=o=(q(k.endAngle,k.startAngle+360)-90)*Math.PI/180;this.offset=
+a.offset||0;if((this.isCircular=i)&&c.max===C&&o-b===2*Math.PI)this.autoConnect=!0}});n(u,"getPosition",function(a,b,c,d,g){var f=this.axis;return f.getPosition?f.getPosition(c):a.call(this,b,c,d,g)});n(u,"getLabelPosition",function(a,b,c,d,g,f,e,i,o){var k=this.axis,j=f.y,h=f.align,l=(k.translate(this.pos)+k.startAngleRad+Math.PI/2)/Math.PI*180%360;k.isRadial?(a=k.getPosition(this.pos,k.center[2]/2+q(f.distance,-25)),f.rotation==="auto"?d.attr({rotation:l}):j===null&&(j=v(d.styles.lineHeight)*0.9-
+d.getBBox().height/2),h===null&&(h=k.isCircular?l>20&&l<160?"left":l>200&&l<340?"right":"center":"center",d.attr({align:h})),a.x+=f.x,a.y+=j):a=a.call(this,b,c,d,g,f,e,i,o);return a});n(u,"getMarkPath",function(a,b,c,d,g,f,e){var i=this.axis;i.isRadial?(a=i.getPosition(this.pos,i.center[2]/2+d),b=["M",b,c,"L",a.x,a.y]):b=a.call(this,b,c,d,g,f,e);return b});m.arearange=p(m.area,{lineWidth:1,marker:null,threshold:null,tooltip:{pointFormat:'<span style="color:{series.color}">{series.name}</span>: <b>{point.low}</b> - <b>{point.high}</b><br/>'},
+trackByArea:!0,dataLabels:{verticalAlign:null,xLow:0,xHigh:0,yLow:0,yHigh:0}});h.arearange=l.extendClass(h.area,{type:"arearange",pointArrayMap:["low","high"],toYData:function(a){return[a.low,a.high]},pointValKey:"low",getSegments:function(){var a=this;r(a.points,function(b){if(!a.options.connectNulls&&(b.low===null||b.high===null))b.y=null;else if(b.low===null&&b.high!==null)b.y=b.high});z.prototype.getSegments.call(this)},translate:function(){var a=this.yAxis;h.area.prototype.translate.apply(this);
+r(this.points,function(b){var c=b.low,d=b.high,g=b.plotY;d===null&&c===null?b.y=null:c===null?(b.plotLow=b.plotY=null,b.plotHigh=a.translate(d,0,1,0,1)):d===null?(b.plotLow=g,b.plotHigh=null):(b.plotLow=g,b.plotHigh=a.translate(d,0,1,0,1))})},getSegmentPath:function(a){var b,c=[],d=a.length,g=z.prototype.getSegmentPath,f,e;e=this.options;var i=e.step;for(b=HighchartsAdapter.grep(a,function(a){return a.plotLow!==null});d--;)f=a[d],f.plotHigh!==null&&c.push({plotX:f.plotX,plotY:f.plotHigh});a=g.call(this,
+b);if(i)i===!0&&(i="left"),e.step={left:"right",center:"center",right:"left"}[i];c=g.call(this,c);e.step=i;e=[].concat(a,c);c[0]="L";this.areaPath=this.areaPath.concat(a,c);return e},drawDataLabels:function(){var a=this.data,b=a.length,c,d=[],g=z.prototype,f=this.options.dataLabels,e,i=this.chart.inverted;if(f.enabled||this._hasPointLabels){for(c=b;c--;)e=a[c],e.y=e.high,e.plotY=e.plotHigh,d[c]=e.dataLabel,e.dataLabel=e.dataLabelUpper,e.below=!1,i?(f.align="left",f.x=f.xHigh):f.y=f.yHigh;g.drawDataLabels.apply(this,
+arguments);for(c=b;c--;)e=a[c],e.dataLabelUpper=e.dataLabel,e.dataLabel=d[c],e.y=e.low,e.plotY=e.plotLow,e.below=!0,i?(f.align="right",f.x=f.xLow):f.y=f.yLow;g.drawDataLabels.apply(this,arguments)}},alignDataLabel:h.column.prototype.alignDataLabel,getSymbol:h.column.prototype.getSymbol,drawPoints:w});m.areasplinerange=p(m.arearange);h.areasplinerange=x(h.arearange,{type:"areasplinerange",getPointSpline:h.spline.prototype.getPointSpline});m.columnrange=p(m.column,m.arearange,{lineWidth:1,pointRange:null});
+h.columnrange=x(h.arearange,{type:"columnrange",translate:function(){var a=this,b=a.yAxis,c;t.translate.apply(a);r(a.points,function(d){var g=d.shapeArgs,f=a.options.minPointLength,e;d.plotHigh=c=b.translate(d.high,0,1,0,1);d.plotLow=d.plotY;e=c;d=d.plotY-c;d<f&&(f-=d,d+=f,e-=f/2);g.height=d;g.y=e})},trackerGroups:["group","dataLabels"],drawGraph:w,pointAttrToOptions:t.pointAttrToOptions,drawPoints:t.drawPoints,drawTracker:t.drawTracker,animate:t.animate,getColumnMetrics:t.getColumnMetrics});m.gauge=
+p(m.line,{dataLabels:{enabled:!0,y:15,borderWidth:1,borderColor:"silver",borderRadius:3,style:{fontWeight:"bold"},verticalAlign:"top",zIndex:2},dial:{},pivot:{},tooltip:{headerFormat:""},showInLegend:!1});u={type:"gauge",pointClass:l.extendClass(l.Point,{setState:function(a){this.state=a}}),angular:!0,drawGraph:w,trackerGroups:["group","dataLabels"],translate:function(){var a=this.yAxis,b=this.options,c=a.center;this.generatePoints();r(this.points,function(d){var g=p(b.dial,d.dial),f=v(q(g.radius,
+80))*c[2]/200,e=v(q(g.baseLength,70))*f/100,i=v(q(g.rearLength,10))*f/100,o=g.baseWidth||3,k=g.topWidth||1,j=a.startAngleRad+a.translate(d.y,null,null,null,!0);b.wrap===!1&&(j=Math.max(a.startAngleRad,Math.min(a.endAngleRad,j)));j=j*180/Math.PI;d.shapeType="path";d.shapeArgs={d:g.path||["M",-i,-o/2,"L",e,-o/2,f,-k/2,f,k/2,e,o/2,-i,o/2,"z"],translateX:c[0],translateY:c[1],rotation:j};d.plotX=c[0];d.plotY=c[1]})},drawPoints:function(){var a=this,b=a.yAxis.center,c=a.pivot,d=a.options,g=d.pivot,f=a.chart.renderer;
+r(a.points,function(c){var b=c.graphic,g=c.shapeArgs,k=g.d,j=p(d.dial,c.dial);b?(b.animate(g),g.d=k):c.graphic=f[c.shapeType](g).attr({stroke:j.borderColor||"none","stroke-width":j.borderWidth||0,fill:j.backgroundColor||"black",rotation:g.rotation}).add(a.group)});c?c.animate({translateX:b[0],translateY:b[1]}):a.pivot=f.circle(0,0,q(g.radius,5)).attr({"stroke-width":g.borderWidth||0,stroke:g.borderColor||"silver",fill:g.backgroundColor||"black"}).translate(b[0],b[1]).add(a.group)},animate:function(a){var b=
+this;if(!a)r(b.points,function(a){var d=a.graphic;d&&(d.attr({rotation:b.yAxis.startAngleRad*180/Math.PI}),d.animate({rotation:a.shapeArgs.rotation},b.options.animation))}),b.animate=null},render:function(){this.group=this.plotGroup("group","series",this.visible?"visible":"hidden",this.options.zIndex,this.chart.seriesGroup);h.pie.prototype.render.call(this);this.group.clip(this.chart.clipRect)},setData:h.pie.prototype.setData,drawTracker:h.column.prototype.drawTracker};h.gauge=l.extendClass(h.line,
+u);m.boxplot=p(m.column,{fillColor:"#FFFFFF",lineWidth:1,medianWidth:2,states:{hover:{brightness:-0.3}},threshold:null,tooltip:{pointFormat:'<span style="color:{series.color};font-weight:bold">{series.name}</span><br/>Maximum: {point.high}<br/>Upper quartile: {point.q3}<br/>Median: {point.median}<br/>Lower quartile: {point.q1}<br/>Minimum: {point.low}<br/>'},whiskerLength:"50%",whiskerWidth:2});h.boxplot=x(h.column,{type:"boxplot",pointArrayMap:["low","q1","median","q3","high"],toYData:function(a){return[a.low,
+a.q1,a.median,a.q3,a.high]},pointValKey:"high",pointAttrToOptions:{fill:"fillColor",stroke:"color","stroke-width":"lineWidth"},drawDataLabels:w,translate:function(){var a=this.yAxis,b=this.pointArrayMap;h.column.prototype.translate.apply(this);r(this.points,function(c){r(b,function(b){c[b]!==null&&(c[b+"Plot"]=a.translate(c[b],0,1,0,1))})})},drawPoints:function(){var a=this,b=a.points,c=a.options,d=a.chart.renderer,g,f,e,i,o,k,j,h,l,m,n,H,p,E,I,t,w,s,v,u,z,y,x=a.doQuartiles!==!1,B=parseInt(a.options.whiskerLength,
+10)/100;r(b,function(b){l=b.graphic;z=b.shapeArgs;n={};E={};t={};y=b.color||a.color;if(b.plotY!==C)if(g=b.pointAttr[b.selected?"selected":""],w=z.width,s=A(z.x),v=s+w,u=D(w/2),f=A(x?b.q1Plot:b.lowPlot),e=A(x?b.q3Plot:b.lowPlot),i=A(b.highPlot),o=A(b.lowPlot),n.stroke=b.stemColor||c.stemColor||y,n["stroke-width"]=q(b.stemWidth,c.stemWidth,c.lineWidth),n.dashstyle=b.stemDashStyle||c.stemDashStyle,E.stroke=b.whiskerColor||c.whiskerColor||y,E["stroke-width"]=q(b.whiskerWidth,c.whiskerWidth,c.lineWidth),
+t.stroke=b.medianColor||c.medianColor||y,t["stroke-width"]=q(b.medianWidth,c.medianWidth,c.lineWidth),j=n["stroke-width"]%2/2,h=s+u+j,m=["M",h,e,"L",h,i,"M",h,f,"L",h,o,"z"],x&&(j=g["stroke-width"]%2/2,h=A(h)+j,f=A(f)+j,e=A(e)+j,s+=j,v+=j,H=["M",s,e,"L",s,f,"L",v,f,"L",v,e,"L",s,e,"z"]),B&&(j=E["stroke-width"]%2/2,i+=j,o+=j,p=["M",h-u*B,i,"L",h+u*B,i,"M",h-u*B,o,"L",h+u*B,o]),j=t["stroke-width"]%2/2,k=D(b.medianPlot)+j,I=["M",s,k,"L",v,k,"z"],l)b.stem.animate({d:m}),B&&b.whiskers.animate({d:p}),x&&
+b.box.animate({d:H}),b.medianShape.animate({d:I});else{b.graphic=l=d.g().add(a.group);b.stem=d.path(m).attr(n).add(l);if(B)b.whiskers=d.path(p).attr(E).add(l);if(x)b.box=d.path(H).attr(g).add(l);b.medianShape=d.path(I).attr(t).add(l)}})}});m.errorbar=p(m.boxplot,{color:"#000000",grouping:!1,linkedTo:":previous",tooltip:{pointFormat:m.arearange.tooltip.pointFormat},whiskerWidth:null});h.errorbar=x(h.boxplot,{type:"errorbar",pointArrayMap:["low","high"],toYData:function(a){return[a.low,a.high]},pointValKey:"high",
+doQuartiles:!1,getColumnMetrics:function(){return this.linkedParent&&this.linkedParent.columnMetrics||h.column.prototype.getColumnMetrics.call(this)}});m.waterfall=p(m.column,{lineWidth:1,lineColor:"#333",dashStyle:"dot",borderColor:"#333"});h.waterfall=x(h.column,{type:"waterfall",upColorProp:"fill",pointArrayMap:["low","y"],pointValKey:"y",init:function(a,b){b.stacking=!0;h.column.prototype.init.call(this,a,b)},translate:function(){var a=this.options,b=this.yAxis,c,d,g,f,e,i,o,k,j;c=a.threshold;
+a=a.borderWidth%2/2;h.column.prototype.translate.apply(this);k=c;g=this.points;for(d=0,c=g.length;d<c;d++){f=g[d];e=f.shapeArgs;i=this.getStack(d);j=i.points[this.index];if(isNaN(f.y))f.y=this.yData[d];o=S(k,k+f.y)+j[0];e.y=b.translate(o,0,1);f.isSum||f.isIntermediateSum?(e.y=b.translate(j[1],0,1),e.height=b.translate(j[0],0,1)-e.y):k+=i.total;e.height<0&&(e.y+=e.height,e.height*=-1);f.plotY=e.y=D(e.y)-a;e.height=D(e.height);f.yBottom=e.y+e.height}},processData:function(a){var b=this.yData,c=this.points,
+d,g=b.length,f=this.options.threshold||0,e,i,h,k,j,l;i=e=h=k=f;for(l=0;l<g;l++)j=b[l],d=c?c[l]:{},j==="sum"||d.isSum?b[l]=i:j==="intermediateSum"||d.isIntermediateSum?(b[l]=e,e=f):(i+=j,e+=j),h=Math.min(i,h),k=Math.max(i,k);z.prototype.processData.call(this,a);this.dataMin=h;this.dataMax=k},toYData:function(a){if(a.isSum)return"sum";else if(a.isIntermediateSum)return"intermediateSum";return a.y},getAttribs:function(){h.column.prototype.getAttribs.apply(this,arguments);var a=this.options,b=a.states,
+c=a.upColor||this.color,a=l.Color(c).brighten(0.1).get(),d=p(this.pointAttr),g=this.upColorProp;d[""][g]=c;d.hover[g]=b.hover.upColor||a;d.select[g]=b.select.upColor||c;r(this.points,function(a){if(a.y>0&&!a.color)a.pointAttr=d,a.color=c})},getGraphPath:function(){var a=this.data,b=a.length,c=D(this.options.lineWidth+this.options.borderWidth)%2/2,d=[],g,f,e;for(e=1;e<b;e++)f=a[e].shapeArgs,g=a[e-1].shapeArgs,f=["M",g.x+g.width,g.y+c,"L",f.x,g.y+c],a[e-1].y<0&&(f[2]+=g.height,f[5]+=g.height),d=d.concat(f);
+return d},getExtremes:w,getStack:function(a){var b=this.yAxis.stacks,c=this.stackKey;this.processedYData[a]<this.options.threshold&&(c="-"+c);return b[c][a]},drawGraph:z.prototype.drawGraph});m.bubble=p(m.scatter,{dataLabels:{inside:!0,style:{color:"white",textShadow:"0px 0px 3px black"},verticalAlign:"middle"},marker:{lineColor:null,lineWidth:1},minSize:8,maxSize:"20%",tooltip:{pointFormat:"({point.x}, {point.y}), Size: {point.z}"},turboThreshold:0,zThreshold:0});h.bubble=x(h.scatter,{type:"bubble",
+pointArrayMap:["y","z"],trackerGroups:["group","dataLabelsGroup"],pointAttrToOptions:{stroke:"lineColor","stroke-width":"lineWidth",fill:"fillColor"},applyOpacity:function(a){var b=this.options.marker,c=q(b.fillOpacity,0.5),a=a||b.fillColor||this.color;c!==1&&(a=l.Color(a).setOpacity(c).get("rgba"));return a},convertAttribs:function(){var a=z.prototype.convertAttribs.apply(this,arguments);a.fill=this.applyOpacity(a.fill);return a},getRadii:function(a,b,c,d){var g,f,e,i=this.zData,h=[];for(f=0,g=i.length;f<
+g;f++)e=b-a,e=e>0?(i[f]-a)/(b-a):0.5,h.push(s.ceil(c+e*(d-c))/2);this.radii=h},animate:function(a){var b=this.options.animation;if(!a)r(this.points,function(a){var d=a.graphic,a=a.shapeArgs;d&&a&&(d.attr("r",1),d.animate({r:a.r},b))}),this.animate=null},translate:function(){var a,b=this.data,c,d,g=this.radii;h.scatter.prototype.translate.call(this);for(a=b.length;a--;)c=b[a],d=g?g[a]:0,c.negative=c.z<(this.options.zThreshold||0),d>=this.minPxSize/2?(c.shapeType="circle",c.shapeArgs={x:c.plotX,y:c.plotY,
+r:d},c.dlBox={x:c.plotX-d,y:c.plotY-d,width:2*d,height:2*d}):c.shapeArgs=c.plotY=c.dlBox=C},drawLegendSymbol:function(a,b){var c=v(a.itemStyle.fontSize)/2;b.legendSymbol=this.chart.renderer.circle(c,a.baseline-c,c).attr({zIndex:3}).add(b.legendGroup);b.legendSymbol.isMarker=!0},drawPoints:h.column.prototype.drawPoints,alignDataLabel:h.column.prototype.alignDataLabel});N.prototype.beforePadding=function(){var a=this,b=this.len,c=this.chart,d=0,g=b,f=this.isXAxis,e=f?"xData":"yData",i=this.min,h={},
+k=s.min(c.plotWidth,c.plotHeight),j=Number.MAX_VALUE,l=-Number.MAX_VALUE,m=this.max-i,n=b/m,p=[];this.tickPositions&&(r(this.series,function(b){var c=b.options;if(b.type==="bubble"&&b.visible&&(a.allowZoomOutside=!0,p.push(b),f))r(["minSize","maxSize"],function(a){var b=c[a],d=/%$/.test(b),b=v(b);h[a]=d?k*b/100:b}),b.minPxSize=h.minSize,b=b.zData,b.length&&(j=s.min(j,s.max(P(b),c.displayNegative===!1?c.zThreshold:-Number.MAX_VALUE)),l=s.max(l,Q(b)))}),r(p,function(a){var b=a[e],c=b.length,k;f&&a.getRadii(j,
+l,h.minSize,h.maxSize);if(m>0)for(;c--;)k=a.radii[c],d=Math.min((b[c]-i)*n-k,d),g=Math.max((b[c]-i)*n+k,g)}),m>0&&q(this.options.min,this.userMin)===C&&q(this.options.max,this.userMax)===C&&(g-=b,n*=(b+d-g)/b,this.min+=d/n,this.max+=g/n))};var y=z.prototype,m=l.Pointer.prototype;y.toXY=function(a){var b,c=this.chart;b=a.plotX;var d=a.plotY;a.rectPlotX=b;a.rectPlotY=d;a.clientX=(b/Math.PI*180+this.xAxis.pane.options.startAngle)%360;b=this.xAxis.postTranslate(a.plotX,this.yAxis.len-d);a.plotX=a.polarPlotX=
+b.x-c.plotLeft;a.plotY=a.polarPlotY=b.y-c.plotTop};y.orderTooltipPoints=function(a){if(this.chart.polar&&(a.sort(function(a,c){return a.clientX-c.clientX}),a[0]))a[0].wrappedClientX=a[0].clientX+360,a.push(a[0])};n(h.area.prototype,"init",K);n(h.areaspline.prototype,"init",K);n(h.spline.prototype,"getPointSpline",function(a,b,c,d){var g,f,e,i,h,k,j;if(this.chart.polar){g=c.plotX;f=c.plotY;a=b[d-1];e=b[d+1];this.connectEnds&&(a||(a=b[b.length-2]),e||(e=b[1]));if(a&&e)i=a.plotX,h=a.plotY,b=e.plotX,
+k=e.plotY,i=(1.5*g+i)/2.5,h=(1.5*f+h)/2.5,e=(1.5*g+b)/2.5,j=(1.5*f+k)/2.5,b=Math.sqrt(Math.pow(i-g,2)+Math.pow(h-f,2)),k=Math.sqrt(Math.pow(e-g,2)+Math.pow(j-f,2)),i=Math.atan2(h-f,i-g),h=Math.atan2(j-f,e-g),j=Math.PI/2+(i+h)/2,Math.abs(i-j)>Math.PI/2&&(j-=Math.PI),i=g+Math.cos(j)*b,h=f+Math.sin(j)*b,e=g+Math.cos(Math.PI+j)*k,j=f+Math.sin(Math.PI+j)*k,c.rightContX=e,c.rightContY=j;d?(c=["C",a.rightContX||a.plotX,a.rightContY||a.plotY,i||g,h||f,g,f],a.rightContX=a.rightContY=null):c=["M",g,f]}else c=
+a.call(this,b,c,d);return c});n(y,"translate",function(a){a.call(this);if(this.chart.polar&&!this.preventPostTranslate)for(var a=this.points,b=a.length;b--;)this.toXY(a[b])});n(y,"getSegmentPath",function(a,b){var c=this.points;if(this.chart.polar&&this.options.connectEnds!==!1&&b[b.length-1]===c[c.length-1]&&c[0].y!==null)this.connectEnds=!0,b=[].concat(b,[c[0]]);return a.call(this,b)});n(y,"animate",L);n(t,"animate",L);n(y,"setTooltipPoints",function(a,b){this.chart.polar&&F(this.xAxis,{tooltipLen:360});
+return a.call(this,b)});n(t,"translate",function(a){var b=this.xAxis,c=this.yAxis.len,d=b.center,g=b.startAngleRad,f=this.chart.renderer,e,h;this.preventPostTranslate=!0;a.call(this);if(b.isRadial){b=this.points;for(h=b.length;h--;)e=b[h],a=e.barX+g,e.shapeType="path",e.shapeArgs={d:f.symbols.arc(d[0],d[1],c-e.plotY,null,{start:a,end:a+e.pointWidth,innerR:c-q(e.yBottom,c)})},this.toXY(e)}});n(t,"alignDataLabel",function(a,b,c,d,g,f){if(this.chart.polar){a=b.rectPlotX/Math.PI*180;if(d.align===null)d.align=
+a>20&&a<160?"left":a>200&&a<340?"right":"center";if(d.verticalAlign===null)d.verticalAlign=a<45||a>315?"bottom":a>135&&a<225?"top":"middle";y.alignDataLabel.call(this,b,c,d,g,f)}else a.call(this,b,c,d,g,f)});n(m,"getIndex",function(a,b){var c,d=this.chart,g;d.polar?(g=d.xAxis[0].center,c=b.chartX-g[0]-d.plotLeft,d=b.chartY-g[1]-d.plotTop,c=180-Math.round(Math.atan2(c,d)/Math.PI*180)):c=a.call(this,b);return c});n(m,"getCoordinates",function(a,b){var c=this.chart,d={xAxis:[],yAxis:[]};c.polar?r(c.axes,
+function(a){var f=a.isXAxis,e=a.center,h=b.chartX-e[0]-c.plotLeft,e=b.chartY-e[1]-c.plotTop;d[f?"xAxis":"yAxis"].push({axis:a,value:a.translate(f?Math.PI-Math.atan2(h,e):Math.sqrt(Math.pow(h,2)+Math.pow(e,2)),!0)})}):d=a.call(this,b);return d})})(Highcharts);
diff --git a/97suifang-front/assets/plugins/highcharts/highcharts.js b/97suifang-front/assets/plugins/highcharts/highcharts.js
new file mode 100644
index 0000000..9f2c8cb
--- /dev/null
+++ b/97suifang-front/assets/plugins/highcharts/highcharts.js
@@ -0,0 +1,277 @@
+/*
+ Highcharts JS v3.0.4 (2013-08-02)
+
+ (c) 2009-2013 Torstein Hønsi
+
+ License: www.highcharts.com/license
+*/
+(function(){function r(a,b){var c;a||(a={});for(c in b)a[c]=b[c];return a}function x(){var a,b=arguments.length,c={},d=function(a,b){var c,h;typeof a!=="object"&&(a={});for(h in b)b.hasOwnProperty(h)&&(c=b[h],a[h]=c&&typeof c==="object"&&Object.prototype.toString.call(c)!=="[object Array]"&&typeof c.nodeType!=="number"?d(a[h]||{},c):b[h]);return a};for(a=0;a<b;a++)c=d(c,arguments[a]);return c}function A(a,b){return parseInt(a,b||10)}function da(a){return typeof a==="string"}function U(a){return typeof a===
+"object"}function Ha(a){return Object.prototype.toString.call(a)==="[object Array]"}function pa(a){return typeof a==="number"}function ma(a){return N.log(a)/N.LN10}function ea(a){return N.pow(10,a)}function fa(a,b){for(var c=a.length;c--;)if(a[c]===b){a.splice(c,1);break}}function t(a){return a!==v&&a!==null}function w(a,b,c){var d,e;if(da(b))t(c)?a.setAttribute(b,c):a&&a.getAttribute&&(e=a.getAttribute(b));else if(t(b)&&U(b))for(d in b)a.setAttribute(d,b[d]);return e}function ha(a){return Ha(a)?
+a:[a]}function p(){var a=arguments,b,c,d=a.length;for(b=0;b<d;b++)if(c=a[b],typeof c!=="undefined"&&c!==null)return c}function M(a,b){if(qa&&b&&b.opacity!==v)b.filter="alpha(opacity="+b.opacity*100+")";r(a.style,b)}function T(a,b,c,d,e){a=z.createElement(a);b&&r(a,b);e&&M(a,{padding:0,border:R,margin:0});c&&M(a,c);d&&d.appendChild(a);return a}function ga(a,b){var c=function(){};c.prototype=new a;r(c.prototype,b);return c}function ya(a,b,c,d){var e=O.lang,a=+a||0,f=b===-1?(a.toString().split(".")[1]||
+"").length:isNaN(b=P(b))?2:b,b=c===void 0?e.decimalPoint:c,d=d===void 0?e.thousandsSep:d,e=a<0?"-":"",c=String(A(a=P(a).toFixed(f))),g=c.length>3?c.length%3:0;return e+(g?c.substr(0,g)+d:"")+c.substr(g).replace(/(\d{3})(?=\d)/g,"$1"+d)+(f?b+P(a-c).toFixed(f).slice(2):"")}function za(a,b){return Array((b||2)+1-String(a).length).join(0)+a}function Bb(a,b,c){var d=a[b];a[b]=function(){var a=Array.prototype.slice.call(arguments);a.unshift(d);return c.apply(this,a)}}function Aa(a,b){for(var c="{",d=!1,
+e,f,g,h,i,j=[];(c=a.indexOf(c))!==-1;){e=a.slice(0,c);if(d){f=e.split(":");g=f.shift().split(".");i=g.length;e=b;for(h=0;h<i;h++)e=e[g[h]];if(f.length)f=f.join(":"),g=/\.([0-9])/,h=O.lang,i=void 0,/f$/.test(f)?(i=(i=f.match(g))?i[1]:-1,e=ya(e,i,h.decimalPoint,f.indexOf(",")>-1?h.thousandsSep:"")):e=Xa(f,e)}j.push(e);a=a.slice(c+1);c=(d=!d)?"}":"{"}j.push(a);return j.join("")}function lb(a){return N.pow(10,S(N.log(a)/N.LN10))}function mb(a,b,c,d){var e,c=p(c,1);e=a/c;b||(b=[1,2,2.5,5,10],d&&d.allowDecimals===
+!1&&(c===1?b=[1,2,5,10]:c<=0.1&&(b=[1/c])));for(d=0;d<b.length;d++)if(a=b[d],e<=(b[d]+(b[d+1]||b[d]))/2)break;a*=c;return a}function Cb(a,b){var c=b||[[Db,[1,2,5,10,20,25,50,100,200,500]],[nb,[1,2,5,10,15,30]],[Ya,[1,2,5,10,15,30]],[Qa,[1,2,3,4,6,8,12]],[ra,[1,2]],[Za,[1,2]],[Ra,[1,2,3,4,6]],[sa,null]],d=c[c.length-1],e=y[d[0]],f=d[1],g;for(g=0;g<c.length;g++)if(d=c[g],e=y[d[0]],f=d[1],c[g+1]&&a<=(e*f[f.length-1]+y[c[g+1][0]])/2)break;e===y[sa]&&a<5*e&&(f=[1,2,5]);e===y[sa]&&a<5*e&&(f=[1,2,5]);c=
+mb(a/e,f,d[0]===sa?lb(a/e):1);return{unitRange:e,count:c,unitName:d[0]}}function Eb(a,b,c,d){var e=[],f={},g=O.global.useUTC,h,i=new Date(b),j=a.unitRange,k=a.count;if(t(b)){j>=y[nb]&&(i.setMilliseconds(0),i.setSeconds(j>=y[Ya]?0:k*S(i.getSeconds()/k)));if(j>=y[Ya])i[Fb](j>=y[Qa]?0:k*S(i[ob]()/k));if(j>=y[Qa])i[Gb](j>=y[ra]?0:k*S(i[pb]()/k));if(j>=y[ra])i[qb](j>=y[Ra]?1:k*S(i[Sa]()/k));j>=y[Ra]&&(i[Hb](j>=y[sa]?0:k*S(i[$a]()/k)),h=i[ab]());j>=y[sa]&&(h-=h%k,i[Ib](h));if(j===y[Za])i[qb](i[Sa]()-i[rb]()+
+p(d,1));b=1;h=i[ab]();for(var d=i.getTime(),l=i[$a](),m=i[Sa](),o=g?0:(864E5+i.getTimezoneOffset()*6E4)%864E5;d<c;)e.push(d),j===y[sa]?d=bb(h+b*k,0):j===y[Ra]?d=bb(h,l+b*k):!g&&(j===y[ra]||j===y[Za])?d=bb(h,l,m+b*k*(j===y[ra]?1:7)):d+=j*k,b++;e.push(d);n(sb(e,function(a){return j<=y[Qa]&&a%y[ra]===o}),function(a){f[a]=ra})}e.info=r(a,{higherRanks:f,totalRange:j*k});return e}function Jb(){this.symbol=this.color=0}function Kb(a,b){var c=a.length,d,e;for(e=0;e<c;e++)a[e].ss_i=e;a.sort(function(a,c){d=
+b(a,c);return d===0?a.ss_i-c.ss_i:d});for(e=0;e<c;e++)delete a[e].ss_i}function Ia(a){for(var b=a.length,c=a[0];b--;)a[b]<c&&(c=a[b]);return c}function ta(a){for(var b=a.length,c=a[0];b--;)a[b]>c&&(c=a[b]);return c}function Ja(a,b){for(var c in a)a[c]&&a[c]!==b&&a[c].destroy&&a[c].destroy(),delete a[c]}function Ta(a){cb||(cb=T(Ba));a&&cb.appendChild(a);cb.innerHTML=""}function ua(a,b){var c="Highcharts error #"+a+": www.highcharts.com/errors/"+a;if(b)throw c;else E.console&&console.log(c)}function ia(a){return parseFloat(a.toPrecision(14))}
+function Ka(a,b){Ca=p(a,b.animation)}function Lb(){var a=O.global.useUTC,b=a?"getUTC":"get",c=a?"setUTC":"set";bb=a?Date.UTC:function(a,b,c,g,h,i){return(new Date(a,b,p(c,1),p(g,0),p(h,0),p(i,0))).getTime()};ob=b+"Minutes";pb=b+"Hours";rb=b+"Day";Sa=b+"Date";$a=b+"Month";ab=b+"FullYear";Fb=c+"Minutes";Gb=c+"Hours";qb=c+"Date";Hb=c+"Month";Ib=c+"FullYear"}function va(){}function La(a,b,c,d){this.axis=a;this.pos=b;this.type=c||"";this.isNew=!0;!c&&!d&&this.addLabel()}function tb(a,b){this.axis=a;if(b)this.options=
+b,this.id=b.id}function Mb(a,b,c,d,e,f){var g=a.chart.inverted;this.axis=a;this.isNegative=c;this.options=b;this.x=d;this.total=0;this.points={};this.stack=e;this.percent=f==="percent";this.alignOptions={align:b.align||(g?c?"left":"right":"center"),verticalAlign:b.verticalAlign||(g?"middle":c?"bottom":"top"),y:p(b.y,g?4:c?14:-6),x:p(b.x,g?c?-6:6:0)};this.textAlign=b.textAlign||(g?c?"right":"left":"center")}function db(){this.init.apply(this,arguments)}function ub(){this.init.apply(this,arguments)}
+function vb(a,b){this.init(a,b)}function wb(a,b){this.init(a,b)}function xb(){this.init.apply(this,arguments)}var v,z=document,E=window,N=Math,s=N.round,S=N.floor,ja=N.ceil,u=N.max,I=N.min,P=N.abs,V=N.cos,ba=N.sin,Ma=N.PI,Ua=Ma*2/360,Da=navigator.userAgent,Nb=E.opera,qa=/msie/i.test(Da)&&!Nb,eb=z.documentMode===8,fb=/AppleWebKit/.test(Da),gb=/Firefox/.test(Da),Ob=/(Mobile|Android|Windows Phone)/.test(Da),wa="http://www.w3.org/2000/svg",Y=!!z.createElementNS&&!!z.createElementNS(wa,"svg").createSVGRect,
+Vb=gb&&parseInt(Da.split("Firefox/")[1],10)<4,Z=!Y&&!qa&&!!z.createElement("canvas").getContext,Va,hb=z.documentElement.ontouchstart!==v,Pb={},yb=0,cb,O,Xa,Ca,zb,y,xa=function(){},Ea=[],Ba="div",R="none",Qb="rgba(192,192,192,"+(Y?1.0E-4:0.002)+")",Db="millisecond",nb="second",Ya="minute",Qa="hour",ra="day",Za="week",Ra="month",sa="year",Rb="stroke-width",bb,ob,pb,rb,Sa,$a,ab,Fb,Gb,qb,Hb,Ib,$={};E.Highcharts=E.Highcharts?ua(16,!0):{};Xa=function(a,b,c){if(!t(b)||isNaN(b))return"Invalid date";var a=
+p(a,"%Y-%m-%d %H:%M:%S"),d=new Date(b),e,f=d[pb](),g=d[rb](),h=d[Sa](),i=d[$a](),j=d[ab](),k=O.lang,l=k.weekdays,d=r({a:l[g].substr(0,3),A:l[g],d:za(h),e:h,b:k.shortMonths[i],B:k.months[i],m:za(i+1),y:j.toString().substr(2,2),Y:j,H:za(f),I:za(f%12||12),l:f%12||12,M:za(d[ob]()),p:f<12?"AM":"PM",P:f<12?"am":"pm",S:za(d.getSeconds()),L:za(s(b%1E3),3)},Highcharts.dateFormats);for(e in d)for(;a.indexOf("%"+e)!==-1;)a=a.replace("%"+e,typeof d[e]==="function"?d[e](b):d[e]);return c?a.substr(0,1).toUpperCase()+
+a.substr(1):a};Jb.prototype={wrapColor:function(a){if(this.color>=a)this.color=0},wrapSymbol:function(a){if(this.symbol>=a)this.symbol=0}};y=function(){for(var a=0,b=arguments,c=b.length,d={};a<c;a++)d[b[a++]]=b[a];return d}(Db,1,nb,1E3,Ya,6E4,Qa,36E5,ra,864E5,Za,6048E5,Ra,26784E5,sa,31556952E3);zb={init:function(a,b,c){var b=b||"",d=a.shift,e=b.indexOf("C")>-1,f=e?7:3,g,b=b.split(" "),c=[].concat(c),h,i,j=function(a){for(g=a.length;g--;)a[g]==="M"&&a.splice(g+1,0,a[g+1],a[g+2],a[g+1],a[g+2])};e&&
+(j(b),j(c));a.isArea&&(h=b.splice(b.length-6,6),i=c.splice(c.length-6,6));if(d<=c.length/f)for(;d--;)c=[].concat(c).splice(0,f).concat(c);a.shift=0;if(b.length)for(a=c.length;b.length<a;)d=[].concat(b).splice(b.length-f,f),e&&(d[f-6]=d[f-2],d[f-5]=d[f-1]),b=b.concat(d);h&&(b=b.concat(h),c=c.concat(i));return[b,c]},step:function(a,b,c,d){var e=[],f=a.length;if(c===1)e=d;else if(f===b.length&&c<1)for(;f--;)d=parseFloat(a[f]),e[f]=isNaN(d)?a[f]:c*parseFloat(b[f]-d)+d;else e=b;return e}};(function(a){E.HighchartsAdapter=
+E.HighchartsAdapter||a&&{init:function(b){var c=a.fx,d=c.step,e,f=a.Tween,g=f&&f.propHooks;e=a.cssHooks.opacity;a.extend(a.easing,{easeOutQuad:function(a,b,c,d,e){return-d*(b/=e)*(b-2)+c}});a.each(["cur","_default","width","height","opacity"],function(a,b){var e=d,k,l;b==="cur"?e=c.prototype:b==="_default"&&f&&(e=g[b],b="set");(k=e[b])&&(e[b]=function(c){c=a?c:this;l=c.elem;return l.attr?l.attr(c.prop,b==="cur"?v:c.now):k.apply(this,arguments)})});Bb(e,"get",function(a,b,c){return b.attr?b.opacity||
+0:a.call(this,b,c)});e=function(a){var c=a.elem,d;if(!a.started)d=b.init(c,c.d,c.toD),a.start=d[0],a.end=d[1],a.started=!0;c.attr("d",b.step(a.start,a.end,a.pos,c.toD))};f?g.d={set:e}:d.d=e;this.each=Array.prototype.forEach?function(a,b){return Array.prototype.forEach.call(a,b)}:function(a,b){for(var c=0,d=a.length;c<d;c++)if(b.call(a[c],a[c],c,a)===!1)return c};a.fn.highcharts=function(){var a="Chart",b=arguments,c,d;da(b[0])&&(a=b[0],b=Array.prototype.slice.call(b,1));c=b[0];if(c!==v)c.chart=c.chart||
+{},c.chart.renderTo=this[0],new Highcharts[a](c,b[1]),d=this;c===v&&(d=Ea[w(this[0],"data-highcharts-chart")]);return d}},getScript:a.getScript,inArray:a.inArray,adapterRun:function(b,c){return a(b)[c]()},grep:a.grep,map:function(a,c){for(var d=[],e=0,f=a.length;e<f;e++)d[e]=c.call(a[e],a[e],e,a);return d},offset:function(b){return a(b).offset()},addEvent:function(b,c,d){a(b).bind(c,d)},removeEvent:function(b,c,d){var e=z.removeEventListener?"removeEventListener":"detachEvent";z[e]&&b&&!b[e]&&(b[e]=
+function(){});a(b).unbind(c,d)},fireEvent:function(b,c,d,e){var f=a.Event(c),g="detached"+c,h;!qa&&d&&(delete d.layerX,delete d.layerY);r(f,d);b[c]&&(b[g]=b[c],b[c]=null);a.each(["preventDefault","stopPropagation"],function(a,b){var c=f[b];f[b]=function(){try{c.call(f)}catch(a){b==="preventDefault"&&(h=!0)}}});a(b).trigger(f);b[g]&&(b[c]=b[g],b[g]=null);e&&!f.isDefaultPrevented()&&!h&&e(f)},washMouseEvent:function(a){var c=a.originalEvent||a;if(c.pageX===v)c.pageX=a.pageX,c.pageY=a.pageY;return c},
+animate:function(b,c,d){var e=a(b);if(!b.style)b.style={};if(c.d)b.toD=c.d,c.d=1;e.stop();e.animate(c,d)},stop:function(b){a(b).stop()}}})(E.jQuery);var W=E.HighchartsAdapter,L=W||{};W&&W.init.call(W,zb);var ib=L.adapterRun,Wb=L.getScript,na=L.inArray,n=L.each,sb=L.grep,Xb=L.offset,Na=L.map,J=L.addEvent,aa=L.removeEvent,C=L.fireEvent,Sb=L.washMouseEvent,Ab=L.animate,Wa=L.stop,L={enabled:!0,x:0,y:15,style:{color:"#666",cursor:"default",fontSize:"11px",lineHeight:"14px"}};O={colors:"#2f7ed8,#0d233a,#8bbc21,#910000,#1aadce,#492970,#f28f43,#77a1e5,#c42525,#a6c96a".split(","),
+symbols:["circle","diamond","square","triangle","triangle-down"],lang:{loading:"Loading...",months:"January,February,March,April,May,June,July,August,September,October,November,December".split(","),shortMonths:"Jan,Feb,Mar,Apr,May,Jun,Jul,Aug,Sep,Oct,Nov,Dec".split(","),weekdays:"Sunday,Monday,Tuesday,Wednesday,Thursday,Friday,Saturday".split(","),decimalPoint:".",numericSymbols:"k,M,G,T,P,E".split(","),resetZoom:"Reset zoom",resetZoomTitle:"Reset zoom level 1:1",thousandsSep:","},global:{useUTC:!0,
+canvasToolsURL:"http://code.highcharts.com/3.0.4/modules/canvas-tools.js",VMLRadialGradientURL:"http://code.highcharts.com/3.0.4/gfx/vml-radial-gradient.png"},chart:{borderColor:"#4572A7",borderRadius:5,defaultSeriesType:"line",ignoreHiddenSeries:!0,spacingTop:10,spacingRight:10,spacingBottom:15,spacingLeft:10,style:{fontFamily:'"Lucida Grande", "Lucida Sans Unicode", Verdana, Arial, Helvetica, sans-serif',fontSize:"12px"},backgroundColor:"#FFFFFF",plotBorderColor:"#C0C0C0",resetZoomButton:{theme:{zIndex:20},
+position:{align:"right",x:-10,y:10}}},title:{text:"Chart title",align:"center",margin:15,style:{color:"#274b6d",fontSize:"16px"}},subtitle:{text:"",align:"center",style:{color:"#4d759e"}},plotOptions:{line:{allowPointSelect:!1,showCheckbox:!1,animation:{duration:1E3},events:{},lineWidth:2,marker:{enabled:!0,lineWidth:0,radius:4,lineColor:"#FFFFFF",states:{hover:{enabled:!0},select:{fillColor:"#FFFFFF",lineColor:"#000000",lineWidth:2}}},point:{events:{}},dataLabels:x(L,{align:"center",enabled:!1,formatter:function(){return this.y===
+null?"":ya(this.y,-1)},verticalAlign:"bottom",y:0}),cropThreshold:300,pointRange:0,showInLegend:!0,states:{hover:{marker:{}},select:{marker:{}}},stickyTracking:!0}},labels:{style:{position:"absolute",color:"#3E576F"}},legend:{enabled:!0,align:"center",layout:"horizontal",labelFormatter:function(){return this.name},borderWidth:1,borderColor:"#909090",borderRadius:5,navigation:{activeColor:"#274b6d",inactiveColor:"#CCC"},shadow:!1,itemStyle:{cursor:"pointer",color:"#274b6d",fontSize:"12px"},itemHoverStyle:{color:"#000"},
+itemHiddenStyle:{color:"#CCC"},itemCheckboxStyle:{position:"absolute",width:"13px",height:"13px"},symbolWidth:16,symbolPadding:5,verticalAlign:"bottom",x:0,y:0,title:{style:{fontWeight:"bold"}}},loading:{labelStyle:{fontWeight:"bold",position:"relative",top:"1em"},style:{position:"absolute",backgroundColor:"white",opacity:0.5,textAlign:"center"}},tooltip:{enabled:!0,animation:Y,backgroundColor:"rgba(255, 255, 255, .85)",borderWidth:1,borderRadius:3,dateTimeLabelFormats:{millisecond:"%A, %b %e, %H:%M:%S.%L",
+second:"%A, %b %e, %H:%M:%S",minute:"%A, %b %e, %H:%M",hour:"%A, %b %e, %H:%M",day:"%A, %b %e, %Y",week:"Week from %A, %b %e, %Y",month:"%B %Y",year:"%Y"},headerFormat:'<span style="font-size: 10px">{point.key}</span><br/>',pointFormat:'<span style="color:{series.color}">{series.name}</span>: <b>{point.y}</b><br/>',shadow:!0,snap:Ob?25:10,style:{color:"#333333",cursor:"default",fontSize:"12px",padding:"8px",whiteSpace:"nowrap"}},credits:{enabled:!0,text:"Highcharts.com",href:"http://www.highcharts.com",
+position:{align:"right",x:-10,verticalAlign:"bottom",y:-5},style:{cursor:"pointer",color:"#909090",fontSize:"9px"}}};var X=O.plotOptions,W=X.line;Lb();var oa=function(a){var b=[],c,d;(function(a){a&&a.stops?d=Na(a.stops,function(a){return oa(a[1])}):(c=/rgba\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]?(?:\.[0-9]+)?)\s*\)/.exec(a))?b=[A(c[1]),A(c[2]),A(c[3]),parseFloat(c[4],10)]:(c=/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(a))?b=[A(c[1],16),A(c[2],16),A(c[3],
+16),1]:(c=/rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(a))&&(b=[A(c[1]),A(c[2]),A(c[3]),1])})(a);return{get:function(c){var f;d?(f=x(a),f.stops=[].concat(f.stops),n(d,function(a,b){f.stops[b]=[f.stops[b][0],a.get(c)]})):f=b&&!isNaN(b[0])?c==="rgb"?"rgb("+b[0]+","+b[1]+","+b[2]+")":c==="a"?b[3]:"rgba("+b.join(",")+")":a;return f},brighten:function(a){if(d)n(d,function(b){b.brighten(a)});else if(pa(a)&&a!==0){var c;for(c=0;c<3;c++)b[c]+=A(a*255),b[c]<0&&(b[c]=0),b[c]>255&&
+(b[c]=255)}return this},rgba:b,setOpacity:function(a){b[3]=a;return this}}};va.prototype={init:function(a,b){this.element=b==="span"?T(b):z.createElementNS(wa,b);this.renderer=a;this.attrSetters={}},opacity:1,animate:function(a,b,c){b=p(b,Ca,!0);Wa(this);if(b){b=x(b);if(c)b.complete=c;Ab(this,a,b)}else this.attr(a),c&&c()},attr:function(a,b){var c,d,e,f,g=this.element,h=g.nodeName.toLowerCase(),i=this.renderer,j,k=this.attrSetters,l=this.shadows,m,o,q=this;da(a)&&t(b)&&(c=a,a={},a[c]=b);if(da(a))c=
+a,h==="circle"?c={x:"cx",y:"cy"}[c]||c:c==="strokeWidth"&&(c="stroke-width"),q=w(g,c)||this[c]||0,c!=="d"&&c!=="visibility"&&(q=parseFloat(q));else{for(c in a)if(j=!1,d=a[c],e=k[c]&&k[c].call(this,d,c),e!==!1){e!==v&&(d=e);if(c==="d")d&&d.join&&(d=d.join(" ")),/(NaN| {2}|^$)/.test(d)&&(d="M 0 0");else if(c==="x"&&h==="text")for(e=0;e<g.childNodes.length;e++)f=g.childNodes[e],w(f,"x")===w(g,"x")&&w(f,"x",d);else if(this.rotation&&(c==="x"||c==="y"))o=!0;else if(c==="fill")d=i.color(d,g,c);else if(h===
+"circle"&&(c==="x"||c==="y"))c={x:"cx",y:"cy"}[c]||c;else if(h==="rect"&&c==="r")w(g,{rx:d,ry:d}),j=!0;else if(c==="translateX"||c==="translateY"||c==="rotation"||c==="verticalAlign"||c==="scaleX"||c==="scaleY")j=o=!0;else if(c==="stroke")d=i.color(d,g,c);else if(c==="dashstyle")if(c="stroke-dasharray",d=d&&d.toLowerCase(),d==="solid")d=R;else{if(d){d=d.replace("shortdashdotdot","3,1,1,1,1,1,").replace("shortdashdot","3,1,1,1").replace("shortdot","1,1,").replace("shortdash","3,1,").replace("longdash",
+"8,3,").replace(/dot/g,"1,3,").replace("dash","4,3,").replace(/,$/,"").split(",");for(e=d.length;e--;)d[e]=A(d[e])*p(a["stroke-width"],this["stroke-width"]);d=d.join(",")}}else if(c==="width")d=A(d);else if(c==="align")c="text-anchor",d={left:"start",center:"middle",right:"end"}[d];else if(c==="title")e=g.getElementsByTagName("title")[0],e||(e=z.createElementNS(wa,"title"),g.appendChild(e)),e.textContent=d;c==="strokeWidth"&&(c="stroke-width");if(c==="stroke-width"||c==="stroke"){this[c]=d;if(this.stroke&&
+this["stroke-width"])w(g,"stroke",this.stroke),w(g,"stroke-width",this["stroke-width"]),this.hasStroke=!0;else if(c==="stroke-width"&&d===0&&this.hasStroke)g.removeAttribute("stroke"),this.hasStroke=!1;j=!0}this.symbolName&&/^(x|y|width|height|r|start|end|innerR|anchorX|anchorY)/.test(c)&&(m||(this.symbolAttr(a),m=!0),j=!0);if(l&&/^(width|height|visibility|x|y|d|transform|cx|cy|r)$/.test(c))for(e=l.length;e--;)w(l[e],c,c==="height"?u(d-(l[e].cutHeight||0),0):d);if((c==="width"||c==="height")&&h===
+"rect"&&d<0)d=0;this[c]=d;c==="text"?(d!==this.textStr&&delete this.bBox,this.textStr=d,this.added&&i.buildText(this)):j||w(g,c,d)}o&&this.updateTransform()}return q},addClass:function(a){var b=this.element,c=w(b,"class")||"";c.indexOf(a)===-1&&w(b,"class",c+" "+a);return this},symbolAttr:function(a){var b=this;n("x,y,r,start,end,width,height,innerR,anchorX,anchorY".split(","),function(c){b[c]=p(a[c],b[c])});b.attr({d:b.renderer.symbols[b.symbolName](b.x,b.y,b.width,b.height,b)})},clip:function(a){return this.attr("clip-path",
+a?"url("+this.renderer.url+"#"+a.id+")":R)},crisp:function(a,b,c,d,e){var f,g={},h={},i,a=a||this.strokeWidth||this.attr&&this.attr("stroke-width")||0;i=s(a)%2/2;h.x=S(b||this.x||0)+i;h.y=S(c||this.y||0)+i;h.width=S((d||this.width||0)-2*i);h.height=S((e||this.height||0)-2*i);h.strokeWidth=a;for(f in h)this[f]!==h[f]&&(this[f]=g[f]=h[f]);return g},css:function(a){var b=this.element,c=a&&a.width&&b.nodeName.toLowerCase()==="text",d,e="",f=function(a,b){return"-"+b.toLowerCase()};if(a&&a.color)a.fill=
+a.color;this.styles=a=r(this.styles,a);Z&&c&&delete a.width;if(qa&&!Y)c&&delete a.width,M(this.element,a);else{for(d in a)e+=d.replace(/([A-Z])/g,f)+":"+a[d]+";";w(b,"style",e)}c&&this.added&&this.renderer.buildText(this);return this},on:function(a,b){var c=this.element;if(hb&&a==="click")c.ontouchstart=function(a){a.preventDefault();b.call(c,a)};c["on"+a]=b;return this},setRadialReference:function(a){this.element.radialReference=a;return this},translate:function(a,b){return this.attr({translateX:a,
+translateY:b})},invert:function(){this.inverted=!0;this.updateTransform();return this},htmlCss:function(a){var b=this.element;if(b=a&&b.tagName==="SPAN"&&a.width)delete a.width,this.textWidth=b,this.updateTransform();this.styles=r(this.styles,a);M(this.element,a);return this},htmlGetBBox:function(){var a=this.element,b=this.bBox;if(!b){if(a.nodeName==="text")a.style.position="absolute";b=this.bBox={x:a.offsetLeft,y:a.offsetTop,width:a.offsetWidth,height:a.offsetHeight}}return b},htmlUpdateTransform:function(){if(this.added){var a=
+this.renderer,b=this.element,c=this.translateX||0,d=this.translateY||0,e=this.x||0,f=this.y||0,g=this.textAlign||"left",h={left:0,center:0.5,right:1}[g],i=g&&g!=="left",j=this.shadows;M(b,{marginLeft:c,marginTop:d});j&&n(j,function(a){M(a,{marginLeft:c+1,marginTop:d+1})});this.inverted&&n(b.childNodes,function(c){a.invertChild(c,b)});if(b.tagName==="SPAN"){var k,l,j=this.rotation,m;k=0;var o=1,q=0,ka;m=A(this.textWidth);var D=this.xCorr||0,F=this.yCorr||0,Tb=[j,g,b.innerHTML,this.textWidth].join(",");
+if(Tb!==this.cTT){t(j)&&(k=j*Ua,o=V(k),q=ba(k),this.setSpanRotation(j,q,o));k=p(this.elemWidth,b.offsetWidth);l=p(this.elemHeight,b.offsetHeight);if(k>m&&/[ \-]/.test(b.textContent||b.innerText))M(b,{width:m+"px",display:"block",whiteSpace:"normal"}),k=m;m=a.fontMetrics(b.style.fontSize).b;D=o<0&&-k;F=q<0&&-l;ka=o*q<0;D+=q*m*(ka?1-h:h);F-=o*m*(j?ka?h:1-h:1);i&&(D-=k*h*(o<0?-1:1),j&&(F-=l*h*(q<0?-1:1)),M(b,{textAlign:g}));this.xCorr=D;this.yCorr=F}M(b,{left:e+D+"px",top:f+F+"px"});if(fb)l=b.offsetHeight;
+this.cTT=Tb}}else this.alignOnAdd=!0},setSpanRotation:function(a){var b={};b[qa?"-ms-transform":fb?"-webkit-transform":gb?"MozTransform":Nb?"-o-transform":""]=b.transform="rotate("+a+"deg)";M(this.element,b)},updateTransform:function(){var a=this.translateX||0,b=this.translateY||0,c=this.scaleX,d=this.scaleY,e=this.inverted,f=this.rotation;e&&(a+=this.attr("width"),b+=this.attr("height"));a=["translate("+a+","+b+")"];e?a.push("rotate(90) scale(-1,1)"):f&&a.push("rotate("+f+" "+(this.x||0)+" "+(this.y||
+0)+")");(t(c)||t(d))&&a.push("scale("+p(c,1)+" "+p(d,1)+")");a.length&&w(this.element,"transform",a.join(" "))},toFront:function(){var a=this.element;a.parentNode.appendChild(a);return this},align:function(a,b,c){var d,e,f,g,h={};e=this.renderer;f=e.alignedObjects;if(a){if(this.alignOptions=a,this.alignByTranslate=b,!c||da(c))this.alignTo=d=c||"renderer",fa(f,this),f.push(this),c=null}else a=this.alignOptions,b=this.alignByTranslate,d=this.alignTo;c=p(c,e[d],e);d=a.align;e=a.verticalAlign;f=(c.x||
+0)+(a.x||0);g=(c.y||0)+(a.y||0);if(d==="right"||d==="center")f+=(c.width-(a.width||0))/{right:1,center:2}[d];h[b?"translateX":"x"]=s(f);if(e==="bottom"||e==="middle")g+=(c.height-(a.height||0))/({bottom:1,middle:2}[e]||1);h[b?"translateY":"y"]=s(g);this[this.placed?"animate":"attr"](h);this.placed=!0;this.alignAttr=h;return this},getBBox:function(){var a=this.bBox,b=this.renderer,c,d=this.rotation;c=this.element;var e=this.styles,f=d*Ua;if(!a){if(c.namespaceURI===wa||b.forExport){try{a=c.getBBox?
+r({},c.getBBox()):{width:c.offsetWidth,height:c.offsetHeight}}catch(g){}if(!a||a.width<0)a={width:0,height:0}}else a=this.htmlGetBBox();if(b.isSVG){b=a.width;c=a.height;if(qa&&e&&e.fontSize==="11px"&&c.toPrecision(3)==="22.7")a.height=c=14;if(d)a.width=P(c*ba(f))+P(b*V(f)),a.height=P(c*V(f))+P(b*ba(f))}this.bBox=a}return a},show:function(){return this.attr({visibility:"visible"})},hide:function(){return this.attr({visibility:"hidden"})},fadeOut:function(a){var b=this;b.animate({opacity:0},{duration:a||
+150,complete:function(){b.hide()}})},add:function(a){var b=this.renderer,c=a||b,d=c.element||b.box,e=d.childNodes,f=this.element,g=w(f,"zIndex"),h;if(a)this.parentGroup=a;this.parentInverted=a&&a.inverted;this.textStr!==void 0&&b.buildText(this);if(g)c.handleZ=!0,g=A(g);if(c.handleZ)for(c=0;c<e.length;c++)if(a=e[c],b=w(a,"zIndex"),a!==f&&(A(b)>g||!t(g)&&t(b))){d.insertBefore(f,a);h=!0;break}h||d.appendChild(f);this.added=!0;C(this,"add");return this},safeRemoveChild:function(a){var b=a.parentNode;
+b&&b.removeChild(a)},destroy:function(){var a=this,b=a.element||{},c=a.shadows,d=a.renderer.isSVG&&b.nodeName==="SPAN"&&b.parentNode,e,f;b.onclick=b.onmouseout=b.onmouseover=b.onmousemove=b.point=null;Wa(a);if(a.clipPath)a.clipPath=a.clipPath.destroy();if(a.stops){for(f=0;f<a.stops.length;f++)a.stops[f]=a.stops[f].destroy();a.stops=null}a.safeRemoveChild(b);for(c&&n(c,function(b){a.safeRemoveChild(b)});d&&d.childNodes.length===0;)b=d.parentNode,a.safeRemoveChild(d),d=b;a.alignTo&&fa(a.renderer.alignedObjects,
+a);for(e in a)delete a[e];return null},shadow:function(a,b,c){var d=[],e,f,g=this.element,h,i,j,k;if(a){i=p(a.width,3);j=(a.opacity||0.15)/i;k=this.parentInverted?"(-1,-1)":"("+p(a.offsetX,1)+", "+p(a.offsetY,1)+")";for(e=1;e<=i;e++){f=g.cloneNode(0);h=i*2+1-2*e;w(f,{isShadow:"true",stroke:a.color||"black","stroke-opacity":j*e,"stroke-width":h,transform:"translate"+k,fill:R});if(c)w(f,"height",u(w(f,"height")-h,0)),f.cutHeight=h;b?b.element.appendChild(f):g.parentNode.insertBefore(f,g);d.push(f)}this.shadows=
+d}return this}};var Fa=function(){this.init.apply(this,arguments)};Fa.prototype={Element:va,init:function(a,b,c,d){var e=location,f,g;f=this.createElement("svg").attr({version:"1.1"});g=f.element;a.appendChild(g);a.innerHTML.indexOf("xmlns")===-1&&w(g,"xmlns",wa);this.isSVG=!0;this.box=g;this.boxWrapper=f;this.alignedObjects=[];this.url=(gb||fb)&&z.getElementsByTagName("base").length?e.href.replace(/#.*?$/,"").replace(/([\('\)])/g,"\\$1").replace(/ /g,"%20"):"";this.createElement("desc").add().element.appendChild(z.createTextNode("Created with Highcharts 3.0.4"));
+this.defs=this.createElement("defs").add();this.forExport=d;this.gradients={};this.setSize(b,c,!1);var h;if(gb&&a.getBoundingClientRect)this.subPixelFix=b=function(){M(a,{left:0,top:0});h=a.getBoundingClientRect();M(a,{left:ja(h.left)-h.left+"px",top:ja(h.top)-h.top+"px"})},b(),J(E,"resize",b)},isHidden:function(){return!this.boxWrapper.getBBox().width},destroy:function(){var a=this.defs;this.box=null;this.boxWrapper=this.boxWrapper.destroy();Ja(this.gradients||{});this.gradients=null;if(a)this.defs=
+a.destroy();this.subPixelFix&&aa(E,"resize",this.subPixelFix);return this.alignedObjects=null},createElement:function(a){var b=new this.Element;b.init(this,a);return b},draw:function(){},buildText:function(a){for(var b=a.element,c=this,d=c.forExport,e=p(a.textStr,"").toString().replace(/<(b|strong)>/g,'<span style="font-weight:bold">').replace(/<(i|em)>/g,'<span style="font-style:italic">').replace(/<a/g,"<span").replace(/<\/(b|strong|i|em|a)>/g,"</span>").split(/<br.*?>/g),f=b.childNodes,g=/style="([^"]+)"/,
+h=/href="(http[^"]+)"/,i=w(b,"x"),j=a.styles,k=j&&j.width&&A(j.width),l=j&&j.lineHeight,m=f.length;m--;)b.removeChild(f[m]);k&&!a.added&&this.box.appendChild(b);e[e.length-1]===""&&e.pop();n(e,function(e,f){var m,p=0,e=e.replace(/<span/g,"|||<span").replace(/<\/span>/g,"</span>|||");m=e.split("|||");n(m,function(e){if(e!==""||m.length===1){var o={},n=z.createElementNS(wa,"tspan"),t;g.test(e)&&(t=e.match(g)[1].replace(/(;| |^)color([ :])/,"$1fill$2"),w(n,"style",t));h.test(e)&&!d&&(w(n,"onclick",'location.href="'+
+e.match(h)[1]+'"'),M(n,{cursor:"pointer"}));e=(e.replace(/<(.|\n)*?>/g,"")||" ").replace(/&lt;/g,"<").replace(/&gt;/g,">");if(e!==" "&&(n.appendChild(z.createTextNode(e)),p?o.dx=0:o.x=i,w(n,o),!p&&f&&(!Y&&d&&M(n,{display:"block"}),w(n,"dy",l||c.fontMetrics(/px$/.test(n.style.fontSize)?n.style.fontSize:j.fontSize).h,fb&&n.offsetHeight)),b.appendChild(n),p++,k))for(var e=e.replace(/([^\^])-/g,"$1- ").split(" "),u,s=[];e.length||s.length;)delete a.bBox,u=a.getBBox().width,o=u>k,!o||e.length===1?(e=s,
+s=[],e.length&&(n=z.createElementNS(wa,"tspan"),w(n,{dy:l||16,x:i}),t&&w(n,"style",t),b.appendChild(n),u>k&&(k=u))):(n.removeChild(n.firstChild),s.unshift(e.pop())),e.length&&n.appendChild(z.createTextNode(e.join(" ").replace(/- /g,"-")))}})})},button:function(a,b,c,d,e,f,g){var h=this.label(a,b,c,null,null,null,null,null,"button"),i=0,j,k,l,m,o,a={x1:0,y1:0,x2:0,y2:1},e=x({"stroke-width":1,stroke:"#CCCCCC",fill:{linearGradient:a,stops:[[0,"#FEFEFE"],[1,"#F6F6F6"]]},r:2,padding:5,style:{color:"black"}},
+e);l=e.style;delete e.style;f=x(e,{stroke:"#68A",fill:{linearGradient:a,stops:[[0,"#FFF"],[1,"#ACF"]]}},f);m=f.style;delete f.style;g=x(e,{stroke:"#68A",fill:{linearGradient:a,stops:[[0,"#9BD"],[1,"#CDF"]]}},g);o=g.style;delete g.style;J(h.element,qa?"mouseover":"mouseenter",function(){h.attr(f).css(m)});J(h.element,qa?"mouseout":"mouseleave",function(){j=[e,f,g][i];k=[l,m,o][i];h.attr(j).css(k)});h.setState=function(a){(i=a)?a===2&&h.attr(g).css(o):h.attr(e).css(l)};return h.on("click",function(){d.call(h)}).attr(e).css(r({cursor:"default"},
+l))},crispLine:function(a,b){a[1]===a[4]&&(a[1]=a[4]=s(a[1])-b%2/2);a[2]===a[5]&&(a[2]=a[5]=s(a[2])+b%2/2);return a},path:function(a){var b={fill:R};Ha(a)?b.d=a:U(a)&&r(b,a);return this.createElement("path").attr(b)},circle:function(a,b,c){a=U(a)?a:{x:a,y:b,r:c};return this.createElement("circle").attr(a)},arc:function(a,b,c,d,e,f){if(U(a))b=a.y,c=a.r,d=a.innerR,e=a.start,f=a.end,a=a.x;a=this.symbol("arc",a||0,b||0,c||0,c||0,{innerR:d||0,start:e||0,end:f||0});a.r=c;return a},rect:function(a,b,c,d,
+e,f){e=U(a)?a.r:e;e=this.createElement("rect").attr({rx:e,ry:e,fill:R});return e.attr(U(a)?a:e.crisp(f,a,b,u(c,0),u(d,0)))},setSize:function(a,b,c){var d=this.alignedObjects,e=d.length;this.width=a;this.height=b;for(this.boxWrapper[p(c,!0)?"animate":"attr"]({width:a,height:b});e--;)d[e].align()},g:function(a){var b=this.createElement("g");return t(a)?b.attr({"class":"highcharts-"+a}):b},image:function(a,b,c,d,e){var f={preserveAspectRatio:R};arguments.length>1&&r(f,{x:b,y:c,width:d,height:e});f=this.createElement("image").attr(f);
+f.element.setAttributeNS?f.element.setAttributeNS("http://www.w3.org/1999/xlink","href",a):f.element.setAttribute("hc-svg-href",a);return f},symbol:function(a,b,c,d,e,f){var g,h=this.symbols[a],h=h&&h(s(b),s(c),d,e,f),i=/^url\((.*?)\)$/,j,k;if(h)g=this.path(h),r(g,{symbolName:a,x:b,y:c,width:d,height:e}),f&&r(g,f);else if(i.test(a))k=function(a,b){a.element&&(a.attr({width:b[0],height:b[1]}),a.alignByTranslate||a.translate(s((d-b[0])/2),s((e-b[1])/2)))},j=a.match(i)[1],a=Pb[j],g=this.image(j).attr({x:b,
+y:c}),g.isImg=!0,a?k(g,a):(g.attr({width:0,height:0}),T("img",{onload:function(){k(g,Pb[j]=[this.width,this.height])},src:j}));return g},symbols:{circle:function(a,b,c,d){var e=0.166*c;return["M",a+c/2,b,"C",a+c+e,b,a+c+e,b+d,a+c/2,b+d,"C",a-e,b+d,a-e,b,a+c/2,b,"Z"]},square:function(a,b,c,d){return["M",a,b,"L",a+c,b,a+c,b+d,a,b+d,"Z"]},triangle:function(a,b,c,d){return["M",a+c/2,b,"L",a+c,b+d,a,b+d,"Z"]},"triangle-down":function(a,b,c,d){return["M",a,b,"L",a+c,b,a+c/2,b+d,"Z"]},diamond:function(a,
+b,c,d){return["M",a+c/2,b,"L",a+c,b+d/2,a+c/2,b+d,a,b+d/2,"Z"]},arc:function(a,b,c,d,e){var f=e.start,c=e.r||c||d,g=e.end-0.001,d=e.innerR,h=e.open,i=V(f),j=ba(f),k=V(g),g=ba(g),e=e.end-f<Ma?0:1;return["M",a+c*i,b+c*j,"A",c,c,0,e,1,a+c*k,b+c*g,h?"M":"L",a+d*k,b+d*g,"A",d,d,0,e,0,a+d*i,b+d*j,h?"":"Z"]}},clipRect:function(a,b,c,d){var e="highcharts-"+yb++,f=this.createElement("clipPath").attr({id:e}).add(this.defs),a=this.rect(a,b,c,d,0).add(f);a.id=e;a.clipPath=f;return a},color:function(a,b,c){var d=
+this,e,f=/^rgba/,g,h,i,j,k,l,m,o=[];a&&a.linearGradient?g="linearGradient":a&&a.radialGradient&&(g="radialGradient");if(g){c=a[g];h=d.gradients;j=a.stops;b=b.radialReference;Ha(c)&&(a[g]=c={x1:c[0],y1:c[1],x2:c[2],y2:c[3],gradientUnits:"userSpaceOnUse"});g==="radialGradient"&&b&&!t(c.gradientUnits)&&(c=x(c,{cx:b[0]-b[2]/2+c.cx*b[2],cy:b[1]-b[2]/2+c.cy*b[2],r:c.r*b[2],gradientUnits:"userSpaceOnUse"}));for(m in c)m!=="id"&&o.push(m,c[m]);for(m in j)o.push(j[m]);o=o.join(",");h[o]?a=h[o].id:(c.id=a=
+"highcharts-"+yb++,h[o]=i=d.createElement(g).attr(c).add(d.defs),i.stops=[],n(j,function(a){f.test(a[1])?(e=oa(a[1]),k=e.get("rgb"),l=e.get("a")):(k=a[1],l=1);a=d.createElement("stop").attr({offset:a[0],"stop-color":k,"stop-opacity":l}).add(i);i.stops.push(a)}));return"url("+d.url+"#"+a+")"}else return f.test(a)?(e=oa(a),w(b,c+"-opacity",e.get("a")),e.get("rgb")):(b.removeAttribute(c+"-opacity"),a)},text:function(a,b,c,d){var e=O.chart.style,f=Z||!Y&&this.forExport;if(d&&!this.forExport)return this.html(a,
+b,c);b=s(p(b,0));c=s(p(c,0));a=this.createElement("text").attr({x:b,y:c,text:a}).css({fontFamily:e.fontFamily,fontSize:e.fontSize});f&&a.css({position:"absolute"});a.x=b;a.y=c;return a},html:function(a,b,c){var d=O.chart.style,e=this.createElement("span"),f=e.attrSetters,g=e.element,h=e.renderer;f.text=function(a){a!==g.innerHTML&&delete this.bBox;g.innerHTML=a;return!1};f.x=f.y=f.align=function(a,b){b==="align"&&(b="textAlign");e[b]=a;e.htmlUpdateTransform();return!1};e.attr({text:a,x:s(b),y:s(c)}).css({position:"absolute",
+whiteSpace:"nowrap",fontFamily:d.fontFamily,fontSize:d.fontSize});e.css=e.htmlCss;if(h.isSVG)e.add=function(a){var b,c=h.box.parentNode,d=[];if(a){if(b=a.div,!b){for(;a;)d.push(a),a=a.parentGroup;n(d.reverse(),function(a){var d;b=a.div=a.div||T(Ba,{className:w(a.element,"class")},{position:"absolute",left:(a.translateX||0)+"px",top:(a.translateY||0)+"px"},b||c);d=b.style;r(a.attrSetters,{translateX:function(a){d.left=a+"px"},translateY:function(a){d.top=a+"px"},visibility:function(a,b){d[b]=a}})})}}else b=
+c;b.appendChild(g);e.added=!0;e.alignOnAdd&&e.htmlUpdateTransform();return e};return e},fontMetrics:function(a){var a=A(a||11),a=a<24?a+4:s(a*1.2),b=s(a*0.8);return{h:a,b:b}},label:function(a,b,c,d,e,f,g,h,i){function j(){var a,b;a=p.element.style;F=(Oa===void 0||Ga===void 0||q.styles.textAlign)&&p.getBBox();q.width=(Oa||F.width||0)+2*ca+jb;q.height=(Ga||F.height||0)+2*ca;w=ca+o.fontMetrics(a&&a.fontSize).b;if(A){if(!D)a=s(-u*ca),b=h?-w:0,q.box=D=d?o.symbol(d,a,b,q.width,q.height):o.rect(a,b,q.width,
+q.height,0,kb[Rb]),D.add(q);D.isImg||D.attr(x({width:q.width,height:q.height},kb));kb=null}}function k(){var a=q.styles,a=a&&a.textAlign,b=jb+ca*(1-u),c;c=h?0:w;if(t(Oa)&&(a==="center"||a==="right"))b+={center:0.5,right:1}[a]*(Oa-F.width);(b!==p.x||c!==p.y)&&p.attr({x:b,y:c});p.x=b;p.y=c}function l(a,b){D?D.attr(a,b):kb[a]=b}function m(){p.add(q);q.attr({text:a,x:b,y:c});D&&t(e)&&q.attr({anchorX:e,anchorY:f})}var o=this,q=o.g(i),p=o.text("",0,0,g).attr({zIndex:1}),D,F,u=0,ca=3,jb=0,Oa,Ga,G,H,B=0,
+kb={},w,g=q.attrSetters,A;J(q,"add",m);g.width=function(a){Oa=a;return!1};g.height=function(a){Ga=a;return!1};g.padding=function(a){t(a)&&a!==ca&&(ca=a,k());return!1};g.paddingLeft=function(a){t(a)&&a!==jb&&(jb=a,k());return!1};g.align=function(a){u={left:0,center:0.5,right:1}[a];return!1};g.text=function(a,b){p.attr(b,a);j();k();return!1};g[Rb]=function(a,b){A=!0;B=a%2/2;l(b,a);return!1};g.stroke=g.fill=g.r=function(a,b){b==="fill"&&(A=!0);l(b,a);return!1};g.anchorX=function(a,b){e=a;l(b,a+B-G);
+return!1};g.anchorY=function(a,b){f=a;l(b,a-H);return!1};g.x=function(a){q.x=a;a-=u*((Oa||F.width)+ca);G=s(a);q.attr("translateX",G);return!1};g.y=function(a){H=q.y=s(a);q.attr("translateY",H);return!1};var z=q.css;return r(q,{css:function(a){if(a){var b={},a=x(a);n("fontSize,fontWeight,fontFamily,color,lineHeight,width,textDecoration".split(","),function(c){a[c]!==v&&(b[c]=a[c],delete a[c])});p.css(b)}return z.call(q,a)},getBBox:function(){return{width:F.width+2*ca,height:F.height+2*ca,x:F.x-ca,
+y:F.y-ca}},shadow:function(a){D&&D.shadow(a);return q},destroy:function(){aa(q,"add",m);aa(q.element,"mouseenter");aa(q.element,"mouseleave");p&&(p=p.destroy());D&&(D=D.destroy());va.prototype.destroy.call(q);q=o=j=k=l=m=null}})}};Va=Fa;var K;if(!Y&&!Z){Highcharts.VMLElement=K={init:function(a,b){var c=["<",b,' filled="f" stroked="f"'],d=["position: ","absolute",";"],e=b===Ba;(b==="shape"||e)&&d.push("left:0;top:0;width:1px;height:1px;");d.push("visibility: ",e?"hidden":"visible");c.push(' style="',
+d.join(""),'"/>');if(b)c=e||b==="span"||b==="img"?c.join(""):a.prepVML(c),this.element=T(c);this.renderer=a;this.attrSetters={}},add:function(a){var b=this.renderer,c=this.element,d=b.box,d=a?a.element||a:d;a&&a.inverted&&b.invertChild(c,d);d.appendChild(c);this.added=!0;this.alignOnAdd&&!this.deferUpdateTransform&&this.updateTransform();C(this,"add");return this},updateTransform:va.prototype.htmlUpdateTransform,setSpanRotation:function(a,b,c){M(this.element,{filter:a?["progid:DXImageTransform.Microsoft.Matrix(M11=",
+c,", M12=",-b,", M21=",b,", M22=",c,", sizingMethod='auto expand')"].join(""):R})},attr:function(a,b){var c,d,e,f=this.element||{},g=f.style,h=f.nodeName,i=this.renderer,j=this.symbolName,k,l=this.shadows,m,o=this.attrSetters,q=this;da(a)&&t(b)&&(c=a,a={},a[c]=b);if(da(a))c=a,q=c==="strokeWidth"||c==="stroke-width"?this.strokeweight:this[c];else for(c in a)if(d=a[c],m=!1,e=o[c]&&o[c].call(this,d,c),e!==!1&&d!==null){e!==v&&(d=e);if(j&&/^(x|y|r|start|end|width|height|innerR|anchorX|anchorY)/.test(c))k||
+(this.symbolAttr(a),k=!0),m=!0;else if(c==="d"){d=d||[];this.d=d.join(" ");e=d.length;m=[];for(var p;e--;)if(pa(d[e]))m[e]=s(d[e]*10)-5;else if(d[e]==="Z")m[e]="x";else if(m[e]=d[e],d.isArc&&(d[e]==="wa"||d[e]==="at"))p=d[e]==="wa"?1:-1,m[e+5]===m[e+7]&&(m[e+7]-=p),m[e+6]===m[e+8]&&(m[e+8]-=p);d=m.join(" ")||"x";f.path=d;if(l)for(e=l.length;e--;)l[e].path=l[e].cutOff?this.cutOffPath(d,l[e].cutOff):d;m=!0}else if(c==="visibility"){if(l)for(e=l.length;e--;)l[e].style[c]=d;h==="DIV"&&(d=d==="hidden"?
+"-999em":0,eb||(g[c]=d?"visible":"hidden"),c="top");g[c]=d;m=!0}else if(c==="zIndex")d&&(g[c]=d),m=!0;else if(na(c,["x","y","width","height"])!==-1)this[c]=d,c==="x"||c==="y"?c={x:"left",y:"top"}[c]:d=u(0,d),this.updateClipping?(this[c]=d,this.updateClipping()):g[c]=d,m=!0;else if(c==="class"&&h==="DIV")f.className=d;else if(c==="stroke")d=i.color(d,f,c),c="strokecolor";else if(c==="stroke-width"||c==="strokeWidth")f.stroked=d?!0:!1,c="strokeweight",this[c]=d,pa(d)&&(d+="px");else if(c==="dashstyle")(f.getElementsByTagName("stroke")[0]||
+T(i.prepVML(["<stroke/>"]),null,null,f))[c]=d||"solid",this.dashstyle=d,m=!0;else if(c==="fill")if(h==="SPAN")g.color=d;else{if(h!=="IMG")f.filled=d!==R?!0:!1,d=i.color(d,f,c,this),c="fillcolor"}else if(c==="opacity")m=!0;else if(h==="shape"&&c==="rotation")this[c]=f.style[c]=d,f.style.left=-s(ba(d*Ua)+1)+"px",f.style.top=s(V(d*Ua))+"px";else if(c==="translateX"||c==="translateY"||c==="rotation")this[c]=d,this.updateTransform(),m=!0;else if(c==="text")this.bBox=null,f.innerHTML=d,m=!0;m||(eb?f[c]=
+d:w(f,c,d))}return q},clip:function(a){var b=this,c;a?(c=a.members,fa(c,b),c.push(b),b.destroyClip=function(){fa(c,b)},a=a.getCSS(b)):(b.destroyClip&&b.destroyClip(),a={clip:eb?"inherit":"rect(auto)"});return b.css(a)},css:va.prototype.htmlCss,safeRemoveChild:function(a){a.parentNode&&Ta(a)},destroy:function(){this.destroyClip&&this.destroyClip();return va.prototype.destroy.apply(this)},on:function(a,b){this.element["on"+a]=function(){var a=E.event;a.target=a.srcElement;b(a)};return this},cutOffPath:function(a,
+b){var c,a=a.split(/[ ,]/);c=a.length;if(c===9||c===11)a[c-4]=a[c-2]=A(a[c-2])-10*b;return a.join(" ")},shadow:function(a,b,c){var d=[],e,f=this.element,g=this.renderer,h,i=f.style,j,k=f.path,l,m,o,q;k&&typeof k.value!=="string"&&(k="x");m=k;if(a){o=p(a.width,3);q=(a.opacity||0.15)/o;for(e=1;e<=3;e++){l=o*2+1-2*e;c&&(m=this.cutOffPath(k.value,l+0.5));j=['<shape isShadow="true" strokeweight="',l,'" filled="false" path="',m,'" coordsize="10 10" style="',f.style.cssText,'" />'];h=T(g.prepVML(j),null,
+{left:A(i.left)+p(a.offsetX,1),top:A(i.top)+p(a.offsetY,1)});if(c)h.cutOff=l+1;j=['<stroke color="',a.color||"black",'" opacity="',q*e,'"/>'];T(g.prepVML(j),null,null,h);b?b.element.appendChild(h):f.parentNode.insertBefore(h,f);d.push(h)}this.shadows=d}return this}};K=ga(va,K);var la={Element:K,isIE8:Da.indexOf("MSIE 8.0")>-1,init:function(a,b,c){var d,e;this.alignedObjects=[];d=this.createElement(Ba);e=d.element;e.style.position="relative";a.appendChild(d.element);this.isVML=!0;this.box=e;this.boxWrapper=
+d;this.setSize(b,c,!1);if(!z.namespaces.hcv)z.namespaces.add("hcv","urn:schemas-microsoft-com:vml"),z.createStyleSheet().cssText="hcv\\:fill, hcv\\:path, hcv\\:shape, hcv\\:stroke{ behavior:url(#default#VML); display: inline-block; } "},isHidden:function(){return!this.box.offsetWidth},clipRect:function(a,b,c,d){var e=this.createElement(),f=U(a);return r(e,{members:[],left:f?a.x:a,top:f?a.y:b,width:f?a.width:c,height:f?a.height:d,getCSS:function(a){var b=a.element,c=b.nodeName,a=a.inverted,d=this.top-
+(c==="shape"?b.offsetTop:0),e=this.left,b=e+this.width,f=d+this.height,d={clip:"rect("+s(a?e:d)+"px,"+s(a?f:b)+"px,"+s(a?b:f)+"px,"+s(a?d:e)+"px)"};!a&&eb&&c==="DIV"&&r(d,{width:b+"px",height:f+"px"});return d},updateClipping:function(){n(e.members,function(a){a.css(e.getCSS(a))})}})},color:function(a,b,c,d){var e=this,f,g=/^rgba/,h,i,j=R;a&&a.linearGradient?i="gradient":a&&a.radialGradient&&(i="pattern");if(i){var k,l,m=a.linearGradient||a.radialGradient,o,q,p,D,F,u="",a=a.stops,t,s=[],v=function(){h=
+['<fill colors="'+s.join(",")+'" opacity="',p,'" o:opacity2="',q,'" type="',i,'" ',u,'focus="100%" method="any" />'];T(e.prepVML(h),null,null,b)};o=a[0];t=a[a.length-1];o[0]>0&&a.unshift([0,o[1]]);t[0]<1&&a.push([1,t[1]]);n(a,function(a,b){g.test(a[1])?(f=oa(a[1]),k=f.get("rgb"),l=f.get("a")):(k=a[1],l=1);s.push(a[0]*100+"% "+k);b?(p=l,D=k):(q=l,F=k)});if(c==="fill")if(i==="gradient")c=m.x1||m[0]||0,a=m.y1||m[1]||0,o=m.x2||m[2]||0,m=m.y2||m[3]||0,u='angle="'+(90-N.atan((m-a)/(o-c))*180/Ma)+'"',v();
+else{var j=m.r,r=j*2,G=j*2,H=m.cx,B=m.cy,x=b.radialReference,w,j=function(){x&&(w=d.getBBox(),H+=(x[0]-w.x)/w.width-0.5,B+=(x[1]-w.y)/w.height-0.5,r*=x[2]/w.width,G*=x[2]/w.height);u='src="'+O.global.VMLRadialGradientURL+'" size="'+r+","+G+'" origin="0.5,0.5" position="'+H+","+B+'" color2="'+F+'" ';v()};d.added?j():J(d,"add",j);j=D}else j=k}else if(g.test(a)&&b.tagName!=="IMG")f=oa(a),h=["<",c,' opacity="',f.get("a"),'"/>'],T(this.prepVML(h),null,null,b),j=f.get("rgb");else{j=b.getElementsByTagName(c);
+if(j.length)j[0].opacity=1,j[0].type="solid";j=a}return j},prepVML:function(a){var b=this.isIE8,a=a.join("");b?(a=a.replace("/>",' xmlns="urn:schemas-microsoft-com:vml" />'),a=a.indexOf('style="')===-1?a.replace("/>",' style="display:inline-block;behavior:url(#default#VML);" />'):a.replace('style="','style="display:inline-block;behavior:url(#default#VML);')):a=a.replace("<","<hcv:");return a},text:Fa.prototype.html,path:function(a){var b={coordsize:"10 10"};Ha(a)?b.d=a:U(a)&&r(b,a);return this.createElement("shape").attr(b)},
+circle:function(a,b,c){var d=this.symbol("circle");if(U(a))c=a.r,b=a.y,a=a.x;d.isCircle=!0;return d.attr({x:a,y:b,width:2*c,height:2*c})},g:function(a){var b;a&&(b={className:"highcharts-"+a,"class":"highcharts-"+a});return this.createElement(Ba).attr(b)},image:function(a,b,c,d,e){var f=this.createElement("img").attr({src:a});arguments.length>1&&f.attr({x:b,y:c,width:d,height:e});return f},rect:function(a,b,c,d,e,f){if(U(a))b=a.y,c=a.width,d=a.height,f=a.strokeWidth,a=a.x;var g=this.symbol("rect");
+g.r=e;return g.attr(g.crisp(f,a,b,u(c,0),u(d,0)))},invertChild:function(a,b){var c=b.style;M(a,{flip:"x",left:A(c.width)-1,top:A(c.height)-1,rotation:-90})},symbols:{arc:function(a,b,c,d,e){var f=e.start,g=e.end,h=e.r||c||d,c=e.innerR,d=V(f),i=ba(f),j=V(g),k=ba(g);if(g-f===0)return["x"];f=["wa",a-h,b-h,a+h,b+h,a+h*d,b+h*i,a+h*j,b+h*k];e.open&&!c&&f.push("e","M",a,b);f.push("at",a-c,b-c,a+c,b+c,a+c*j,b+c*k,a+c*d,b+c*i,"x","e");f.isArc=!0;return f},circle:function(a,b,c,d,e){e&&e.isCircle&&(a-=c/2,
+b-=d/2);return["wa",a,b,a+c,b+d,a+c,b+d/2,a+c,b+d/2,"e"]},rect:function(a,b,c,d,e){var f=a+c,g=b+d,h;!t(e)||!e.r?f=Fa.prototype.symbols.square.apply(0,arguments):(h=I(e.r,c,d),f=["M",a+h,b,"L",f-h,b,"wa",f-2*h,b,f,b+2*h,f-h,b,f,b+h,"L",f,g-h,"wa",f-2*h,g-2*h,f,g,f,g-h,f-h,g,"L",a+h,g,"wa",a,g-2*h,a+2*h,g,a+h,g,a,g-h,"L",a,b+h,"wa",a,b,a+2*h,b+2*h,a,b+h,a+h,b,"x","e"]);return f}}};Highcharts.VMLRenderer=K=function(){this.init.apply(this,arguments)};K.prototype=x(Fa.prototype,la);Va=K}var Ub;if(Z)Highcharts.CanVGRenderer=
+K=function(){wa="http://www.w3.org/1999/xhtml"},K.prototype.symbols={},Ub=function(){function a(){var a=b.length,d;for(d=0;d<a;d++)b[d]();b=[]}var b=[];return{push:function(c,d){b.length===0&&Wb(d,a);b.push(c)}}}(),Va=K;La.prototype={addLabel:function(){var a=this.axis,b=a.options,c=a.chart,d=a.horiz,e=a.categories,f=a.series[0]&&a.series[0].names,g=this.pos,h=b.labels,i=a.tickPositions,d=d&&e&&!h.step&&!h.staggerLines&&!h.rotation&&c.plotWidth/i.length||!d&&(c.optionsMarginLeft||c.chartWidth*0.33),
+j=g===i[0],k=g===i[i.length-1],f=e?p(e[g],f&&f[g],g):g,e=this.label,i=i.info,l;a.isDatetimeAxis&&i&&(l=b.dateTimeLabelFormats[i.higherRanks[g]||i.unitName]);this.isFirst=j;this.isLast=k;b=a.labelFormatter.call({axis:a,chart:c,isFirst:j,isLast:k,dateTimeLabelFormat:l,value:a.isLog?ia(ea(f)):f});g=d&&{width:u(1,s(d-2*(h.padding||10)))+"px"};g=r(g,h.style);if(t(e))e&&e.attr({text:b}).css(g);else{d={align:a.labelAlign};if(pa(h.rotation))d.rotation=h.rotation;this.label=t(b)&&h.enabled?c.renderer.text(b,
+0,0,h.useHTML).attr(d).css(g).add(a.labelGroup):null}},getLabelSize:function(){var a=this.label,b=this.axis;return a?(this.labelBBox=a.getBBox())[b.horiz?"height":"width"]:0},getLabelSides:function(){var a=this.axis,b=this.labelBBox.width,a=b*{left:0,center:0.5,right:1}[a.labelAlign]-a.options.labels.x;return[-a,b-a]},handleOverflow:function(a,b){var c=!0,d=this.axis,e=d.chart,f=this.isFirst,g=this.isLast,h=b.x,i=d.reversed,j=d.tickPositions;if(f||g){var k=this.getLabelSides(),l=k[0],k=k[1],e=e.plotLeft,
+m=e+d.len,j=(d=d.ticks[j[a+(f?1:-1)]])&&d.label.xy&&d.label.xy.x+d.getLabelSides()[f?0:1];f&&!i||g&&i?h+l<e&&(h=e-l,d&&h+k>j&&(c=!1)):h+k>m&&(h=m-k,d&&h+l<j&&(c=!1));b.x=h}return c},getPosition:function(a,b,c,d){var e=this.axis,f=e.chart,g=d&&f.oldChartHeight||f.chartHeight;return{x:a?e.translate(b+c,null,null,d)+e.transB:e.left+e.offset+(e.opposite?(d&&f.oldChartWidth||f.chartWidth)-e.right-e.left:0),y:a?g-e.bottom+e.offset-(e.opposite?e.height:0):g-e.translate(b+c,null,null,d)-e.transB}},getLabelPosition:function(a,
+b,c,d,e,f,g,h){var i=this.axis,j=i.transA,k=i.reversed,l=i.staggerLines,m=i.chart.renderer.fontMetrics(e.style.fontSize).b,o=e.rotation,a=a+e.x-(f&&d?f*j*(k?-1:1):0),b=b+e.y-(f&&!d?f*j*(k?1:-1):0);o&&i.side===2&&(b-=m-m*V(o*Ua));!t(e.y)&&!o&&(b+=m-c.getBBox().height/2);l&&(b+=g/(h||1)%l*(i.labelOffset/l));return{x:a,y:b}},getMarkPath:function(a,b,c,d,e,f){return f.crispLine(["M",a,b,"L",a+(e?0:-c),b+(e?c:0)],d)},render:function(a,b,c){var d=this.axis,e=d.options,f=d.chart.renderer,g=d.horiz,h=this.type,
+i=this.label,j=this.pos,k=e.labels,l=this.gridLine,m=h?h+"Grid":"grid",o=h?h+"Tick":"tick",q=e[m+"LineWidth"],n=e[m+"LineColor"],D=e[m+"LineDashStyle"],F=e[o+"Length"],m=e[o+"Width"]||0,u=e[o+"Color"],t=e[o+"Position"],o=this.mark,s=k.step,r=!0,w=d.tickmarkOffset,G=this.getPosition(g,j,w,b),H=G.x,G=G.y,B=g&&H===d.pos||!g&&G===d.pos+d.len?-1:1,x=d.staggerLines;this.isActive=!0;if(q){j=d.getPlotLinePath(j+w,q*B,b,!0);if(l===v){l={stroke:n,"stroke-width":q};if(D)l.dashstyle=D;if(!h)l.zIndex=1;if(b)l.opacity=
+0;this.gridLine=l=q?f.path(j).attr(l).add(d.gridGroup):null}if(!b&&l&&j)l[this.isNew?"attr":"animate"]({d:j,opacity:c})}if(m&&F)t==="inside"&&(F=-F),d.opposite&&(F=-F),b=this.getMarkPath(H,G,F,m*B,g,f),o?o.animate({d:b,opacity:c}):this.mark=f.path(b).attr({stroke:u,"stroke-width":m,opacity:c}).add(d.axisGroup);if(i&&!isNaN(H))i.xy=G=this.getLabelPosition(H,G,i,g,k,w,a,s),this.isFirst&&!p(e.showFirstLabel,1)||this.isLast&&!p(e.showLastLabel,1)?r=!1:!x&&g&&k.overflow==="justify"&&!this.handleOverflow(a,
+G)&&(r=!1),s&&a%s&&(r=!1),r&&!isNaN(G.y)?(G.opacity=c,i[this.isNew?"attr":"animate"](G),this.isNew=!1):i.attr("y",-9999)},destroy:function(){Ja(this,this.axis)}};tb.prototype={render:function(){var a=this,b=a.axis,c=b.horiz,d=(b.pointRange||0)/2,e=a.options,f=e.label,g=a.label,h=e.width,i=e.to,j=e.from,k=t(j)&&t(i),l=e.value,m=e.dashStyle,o=a.svgElem,q=[],n,D=e.color,F=e.zIndex,s=e.events,r=b.chart.renderer;b.isLog&&(j=ma(j),i=ma(i),l=ma(l));if(h){if(q=b.getPlotLinePath(l,h),d={stroke:D,"stroke-width":h},
+m)d.dashstyle=m}else if(k){if(j=u(j,b.min-d),i=I(i,b.max+d),q=b.getPlotBandPath(j,i,e),d={fill:D},e.borderWidth)d.stroke=e.borderColor,d["stroke-width"]=e.borderWidth}else return;if(t(F))d.zIndex=F;if(o)q?o.animate({d:q},null,o.onGetPath):(o.hide(),o.onGetPath=function(){o.show()});else if(q&&q.length&&(a.svgElem=o=r.path(q).attr(d).add(),s))for(n in e=function(b){o.on(b,function(c){s[b].apply(a,[c])})},s)e(n);if(f&&t(f.text)&&q&&q.length&&b.width>0&&b.height>0){f=x({align:c&&k&&"center",x:c?!k&&
+4:10,verticalAlign:!c&&k&&"middle",y:c?k?16:10:k?6:-4,rotation:c&&!k&&90},f);if(!g)a.label=g=r.text(f.text,0,0,f.useHTML).attr({align:f.textAlign||f.align,rotation:f.rotation,zIndex:F}).css(f.style).add();b=[q[1],q[4],p(q[6],q[1])];q=[q[2],q[5],p(q[7],q[2])];c=Ia(b);k=Ia(q);g.align(f,!1,{x:c,y:k,width:ta(b)-c,height:ta(q)-k});g.show()}else g&&g.hide();return a},destroy:function(){fa(this.axis.plotLinesAndBands,this);delete this.axis;Ja(this)}};Mb.prototype={destroy:function(){Ja(this,this.axis)},
+setTotal:function(a){this.cum=this.total=a},addValue:function(a){this.setTotal(ia(this.total+a))},render:function(a){var b=this.options,c=b.format,c=c?Aa(c,this):b.formatter.call(this);this.label?this.label.attr({text:c,visibility:"hidden"}):this.label=this.axis.chart.renderer.text(c,0,0,b.useHTML).css(b.style).attr({align:this.textAlign,rotation:b.rotation,visibility:"hidden"}).add(a)},cacheExtremes:function(a,b){this.points[a.index]=b},setOffset:function(a,b){var c=this.axis,d=c.chart,e=d.inverted,
+f=this.isNegative,g=c.translate(this.percent?100:this.total,0,0,0,1),c=c.translate(0),c=P(g-c),h=d.xAxis[0].translate(this.x)+a,i=d.plotHeight,f={x:e?f?g:g-c:h,y:e?i-h-b:f?i-g-c:i-g,width:e?c:b,height:e?b:c};if(e=this.label)e.align(this.alignOptions,null,f),f=e.alignAttr,e.attr({visibility:this.options.crop===!1||d.isInsidePlot(f.x,f.y)?Y?"inherit":"visible":"hidden"})}};db.prototype={defaultOptions:{dateTimeLabelFormats:{millisecond:"%H:%M:%S.%L",second:"%H:%M:%S",minute:"%H:%M",hour:"%H:%M",day:"%e. %b",
+week:"%e. %b",month:"%b '%y",year:"%Y"},endOnTick:!1,gridLineColor:"#C0C0C0",labels:L,lineColor:"#C0D0E0",lineWidth:1,minPadding:0.01,maxPadding:0.01,minorGridLineColor:"#E0E0E0",minorGridLineWidth:1,minorTickColor:"#A0A0A0",minorTickLength:2,minorTickPosition:"outside",startOfWeek:1,startOnTick:!1,tickColor:"#C0D0E0",tickLength:5,tickmarkPlacement:"between",tickPixelInterval:100,tickPosition:"outside",tickWidth:1,title:{align:"middle",style:{color:"#4d759e",fontWeight:"bold"}},type:"linear"},defaultYAxisOptions:{endOnTick:!0,
+gridLineWidth:1,tickPixelInterval:72,showLastLabel:!0,labels:{x:-8,y:3},lineWidth:0,maxPadding:0.05,minPadding:0.05,startOnTick:!0,tickWidth:0,title:{rotation:270,text:"Values"},stackLabels:{enabled:!1,formatter:function(){return ya(this.total,-1)},style:L.style}},defaultLeftAxisOptions:{labels:{x:-8,y:null},title:{rotation:270}},defaultRightAxisOptions:{labels:{x:8,y:null},title:{rotation:90}},defaultBottomAxisOptions:{labels:{x:0,y:14},title:{rotation:0}},defaultTopAxisOptions:{labels:{x:0,y:-5},
+title:{rotation:0}},init:function(a,b){var c=b.isX;this.horiz=a.inverted?!c:c;this.xOrY=(this.isXAxis=c)?"x":"y";this.opposite=b.opposite;this.side=this.horiz?this.opposite?0:2:this.opposite?1:3;this.setOptions(b);var d=this.options,e=d.type;this.labelFormatter=d.labels.formatter||this.defaultLabelFormatter;this.userOptions=b;this.minPixelPadding=0;this.chart=a;this.reversed=d.reversed;this.zoomEnabled=d.zoomEnabled!==!1;this.categories=d.categories||e==="category";this.isLog=e==="logarithmic";this.isDatetimeAxis=
+e==="datetime";this.isLinked=t(d.linkedTo);this.tickmarkOffset=this.categories&&d.tickmarkPlacement==="between"?0.5:0;this.ticks={};this.minorTicks={};this.plotLinesAndBands=[];this.alternateBands={};this.len=0;this.minRange=this.userMinRange=d.minRange||d.maxZoom;this.range=d.range;this.offset=d.offset||0;this.stacks={};this.oldStacks={};this.stacksMax={};this._stacksTouched=0;this.min=this.max=null;var f,d=this.options.events;na(this,a.axes)===-1&&(a.axes.push(this),a[c?"xAxis":"yAxis"].push(this));
+this.series=this.series||[];if(a.inverted&&c&&this.reversed===v)this.reversed=!0;this.removePlotLine=this.removePlotBand=this.removePlotBandOrLine;for(f in d)J(this,f,d[f]);if(this.isLog)this.val2lin=ma,this.lin2val=ea},setOptions:function(a){this.options=x(this.defaultOptions,this.isXAxis?{}:this.defaultYAxisOptions,[this.defaultTopAxisOptions,this.defaultRightAxisOptions,this.defaultBottomAxisOptions,this.defaultLeftAxisOptions][this.side],x(O[this.isXAxis?"xAxis":"yAxis"],a))},update:function(a,
+b){var c=this.chart,a=c.options[this.xOrY+"Axis"][this.options.index]=x(this.userOptions,a);this.destroy(!0);this._addedPlotLB=!1;this.init(c,r(a,{events:v}));c.isDirtyBox=!0;p(b,!0)&&c.redraw()},remove:function(a){var b=this.chart,c=this.xOrY+"Axis";n(this.series,function(a){a.remove(!1)});fa(b.axes,this);fa(b[c],this);b.options[c].splice(this.options.index,1);n(b[c],function(a,b){a.options.index=b});this.destroy();b.isDirtyBox=!0;p(a,!0)&&b.redraw()},defaultLabelFormatter:function(){var a=this.axis,
+b=this.value,c=a.categories,d=this.dateTimeLabelFormat,e=O.lang.numericSymbols,f=e&&e.length,g,h=a.options.labels.format,a=a.isLog?b:a.tickInterval;if(h)g=Aa(h,this);else if(c)g=b;else if(d)g=Xa(d,b);else if(f&&a>=1E3)for(;f--&&g===v;)c=Math.pow(1E3,f+1),a>=c&&e[f]!==null&&(g=ya(b/c,-1)+e[f]);g===v&&(g=b>=1E3?ya(b,0):ya(b,-1));return g},getSeriesExtremes:function(){var a=this,b=a.chart;a.hasVisibleSeries=!1;a.dataMin=a.dataMax=null;a.stacksMax={};a.buildStacks();n(a.series,function(c){if(c.visible||
+!b.options.chart.ignoreHiddenSeries){var d=c.options,e;e=d.threshold;a.hasVisibleSeries=!0;a.isLog&&e<=0&&(e=null);if(a.isXAxis){if(e=c.xData,e.length)a.dataMin=I(p(a.dataMin,e[0]),Ia(e)),a.dataMax=u(p(a.dataMax,e[0]),ta(e))}else{d=d.stacking;a.usePercentage=d==="percent";if(a.usePercentage)a.dataMin=0,a.dataMax=99;c.getExtremes();d=c.dataMax;c=c.dataMin;if(!a.usePercentage&&t(c)&&t(d))a.dataMin=I(p(a.dataMin,c),c),a.dataMax=u(p(a.dataMax,d),d);if(t(e))if(a.dataMin>=e)a.dataMin=e,a.ignoreMinPadding=
+!0;else if(a.dataMax<e)a.dataMax=e,a.ignoreMaxPadding=!0}}})},translate:function(a,b,c,d,e,f){var g=this.len,h=1,i=0,j=d?this.oldTransA:this.transA,d=d?this.oldMin:this.min,k=this.minPixelPadding,e=(this.options.ordinal||this.isLog&&e)&&this.lin2val;if(!j)j=this.transA;c&&(h*=-1,i=g);this.reversed&&(h*=-1,i-=h*g);b?(a=a*h+i,a-=k,a=a/j+d,e&&(a=this.lin2val(a))):(e&&(a=this.val2lin(a)),f==="between"&&(f=0.5),a=h*(a-d)*j+i+h*k+(pa(f)?j*f*this.pointRange:0));return a},toPixels:function(a,b){return this.translate(a,
+!1,!this.horiz,null,!0)+(b?0:this.pos)},toValue:function(a,b){return this.translate(a-(b?0:this.pos),!0,!this.horiz,null,!0)},getPlotLinePath:function(a,b,c,d){var e=this.chart,f=this.left,g=this.top,h,i,j,a=this.translate(a,null,null,c),k=c&&e.oldChartHeight||e.chartHeight,l=c&&e.oldChartWidth||e.chartWidth,m;h=this.transB;c=i=s(a+h);h=j=s(k-a-h);if(isNaN(a))m=!0;else if(this.horiz){if(h=g,j=k-this.bottom,c<f||c>f+this.width)m=!0}else if(c=f,i=l-this.right,h<g||h>g+this.height)m=!0;return m&&!d?
+null:e.renderer.crispLine(["M",c,h,"L",i,j],b||0)},getPlotBandPath:function(a,b){var c=this.getPlotLinePath(b),d=this.getPlotLinePath(a);d&&c?d.push(c[4],c[5],c[1],c[2]):d=null;return d},getLinearTickPositions:function(a,b,c){for(var d,b=ia(S(b/a)*a),c=ia(ja(c/a)*a),e=[];b<=c;){e.push(b);b=ia(b+a);if(b===d)break;d=b}return e},getLogTickPositions:function(a,b,c,d){var e=this.options,f=this.len,g=[];if(!d)this._minorAutoInterval=null;if(a>=0.5)a=s(a),g=this.getLinearTickPositions(a,b,c);else if(a>=
+0.08)for(var f=S(b),h,i,j,k,l,e=a>0.3?[1,2,4]:a>0.15?[1,2,4,6,8]:[1,2,3,4,5,6,7,8,9];f<c+1&&!l;f++){i=e.length;for(h=0;h<i&&!l;h++)j=ma(ea(f)*e[h]),j>b&&(!d||k<=c)&&g.push(k),k>c&&(l=!0),k=j}else if(b=ea(b),c=ea(c),a=e[d?"minorTickInterval":"tickInterval"],a=p(a==="auto"?null:a,this._minorAutoInterval,(c-b)*(e.tickPixelInterval/(d?5:1))/((d?f/this.tickPositions.length:f)||1)),a=mb(a,null,lb(a)),g=Na(this.getLinearTickPositions(a,b,c),ma),!d)this._minorAutoInterval=a/5;if(!d)this.tickInterval=a;return g},
+getMinorTickPositions:function(){var a=this.options,b=this.tickPositions,c=this.minorTickInterval,d=[],e;if(this.isLog){e=b.length;for(a=1;a<e;a++)d=d.concat(this.getLogTickPositions(c,b[a-1],b[a],!0))}else if(this.isDatetimeAxis&&a.minorTickInterval==="auto")d=d.concat(Eb(Cb(c),this.min,this.max,a.startOfWeek)),d[0]<this.min&&d.shift();else for(b=this.min+(b[0]-this.min)%c;b<=this.max;b+=c)d.push(b);return d},adjustForMinRange:function(){var a=this.options,b=this.min,c=this.max,d,e=this.dataMax-
+this.dataMin>=this.minRange,f,g,h,i,j;if(this.isXAxis&&this.minRange===v&&!this.isLog)t(a.min)||t(a.max)?this.minRange=null:(n(this.series,function(a){i=a.xData;for(g=j=a.xIncrement?1:i.length-1;g>0;g--)if(h=i[g]-i[g-1],f===v||h<f)f=h}),this.minRange=I(f*5,this.dataMax-this.dataMin));if(c-b<this.minRange){var k=this.minRange;d=(k-c+b)/2;d=[b-d,p(a.min,b-d)];if(e)d[2]=this.dataMin;b=ta(d);c=[b+k,p(a.max,b+k)];if(e)c[2]=this.dataMax;c=Ia(c);c-b<k&&(d[0]=c-k,d[1]=p(a.min,c-k),b=ta(d))}this.min=b;this.max=
+c},setAxisTranslation:function(a){var b=this.max-this.min,c=0,d,e=0,f=0,g=this.linkedParent,h=this.transA;if(this.isXAxis)g?(e=g.minPointOffset,f=g.pointRangePadding):n(this.series,function(a){var g=a.pointRange,h=a.options.pointPlacement,l=a.closestPointRange;g>b&&(g=0);c=u(c,g);e=u(e,da(h)?0:g/2);f=u(f,h==="on"?0:g);!a.noSharedTooltip&&t(l)&&(d=t(d)?I(d,l):l)}),g=this.ordinalSlope&&d?this.ordinalSlope/d:1,this.minPointOffset=e*=g,this.pointRangePadding=f*=g,this.pointRange=I(c,b),this.closestPointRange=
+d;if(a)this.oldTransA=h;this.translationSlope=this.transA=h=this.len/(b+f||1);this.transB=this.horiz?this.left:this.bottom;this.minPixelPadding=h*e},setTickPositions:function(a){var b=this,c=b.chart,d=b.options,e=b.isLog,f=b.isDatetimeAxis,g=b.isXAxis,h=b.isLinked,i=b.options.tickPositioner,j=d.maxPadding,k=d.minPadding,l=d.tickInterval,m=d.minTickInterval,o=d.tickPixelInterval,q=b.categories;h?(b.linkedParent=c[g?"xAxis":"yAxis"][d.linkedTo],c=b.linkedParent.getExtremes(),b.min=p(c.min,c.dataMin),
+b.max=p(c.max,c.dataMax),d.type!==b.linkedParent.options.type&&ua(11,1)):(b.min=p(b.userMin,d.min,b.dataMin),b.max=p(b.userMax,d.max,b.dataMax));if(e)!a&&I(b.min,p(b.dataMin,b.min))<=0&&ua(10,1),b.min=ia(ma(b.min)),b.max=ia(ma(b.max));if(b.range&&(b.userMin=b.min=u(b.min,b.max-b.range),b.userMax=b.max,a))b.range=null;b.beforePadding&&b.beforePadding();b.adjustForMinRange();if(!q&&!b.usePercentage&&!h&&t(b.min)&&t(b.max)&&(c=b.max-b.min)){if(!t(d.min)&&!t(b.userMin)&&k&&(b.dataMin<0||!b.ignoreMinPadding))b.min-=
+c*k;if(!t(d.max)&&!t(b.userMax)&&j&&(b.dataMax>0||!b.ignoreMaxPadding))b.max+=c*j}b.tickInterval=b.min===b.max||b.min===void 0||b.max===void 0?1:h&&!l&&o===b.linkedParent.options.tickPixelInterval?b.linkedParent.tickInterval:p(l,q?1:(b.max-b.min)*o/(b.len||1));g&&!a&&n(b.series,function(a){a.processData(b.min!==b.oldMin||b.max!==b.oldMax)});b.setAxisTranslation(!0);b.beforeSetTickPositions&&b.beforeSetTickPositions();if(b.postProcessTickInterval)b.tickInterval=b.postProcessTickInterval(b.tickInterval);
+if(b.pointRange)b.tickInterval=u(b.pointRange,b.tickInterval);if(!l&&b.tickInterval<m)b.tickInterval=m;if(!f&&!e&&!l)b.tickInterval=mb(b.tickInterval,null,lb(b.tickInterval),d);b.minorTickInterval=d.minorTickInterval==="auto"&&b.tickInterval?b.tickInterval/5:d.minorTickInterval;b.tickPositions=a=d.tickPositions?[].concat(d.tickPositions):i&&i.apply(b,[b.min,b.max]);if(!a)a=f?(b.getNonLinearTimeTicks||Eb)(Cb(b.tickInterval,d.units),b.min,b.max,d.startOfWeek,b.ordinalPositions,b.closestPointRange,!0):
+e?b.getLogTickPositions(b.tickInterval,b.min,b.max):b.getLinearTickPositions(b.tickInterval,b.min,b.max),b.tickPositions=a;if(!h)e=a[0],f=a[a.length-1],h=b.minPointOffset||0,d.startOnTick?b.min=e:b.min-h>e&&a.shift(),d.endOnTick?b.max=f:b.max+h<f&&a.pop(),a.length===1&&(b.min-=0.001,b.max+=0.001)},setMaxTicks:function(){var a=this.chart,b=a.maxTicks||{},c=this.tickPositions,d=this._maxTicksKey=[this.xOrY,this.pos,this.len].join("-");if(!this.isLinked&&!this.isDatetimeAxis&&c&&c.length>(b[d]||0)&&
+this.options.alignTicks!==!1)b[d]=c.length;a.maxTicks=b},adjustTickAmount:function(){var a=this._maxTicksKey,b=this.tickPositions,c=this.chart.maxTicks;if(c&&c[a]&&!this.isDatetimeAxis&&!this.categories&&!this.isLinked&&this.options.alignTicks!==!1){var d=this.tickAmount,e=b.length;this.tickAmount=a=c[a];if(e<a){for(;b.length<a;)b.push(ia(b[b.length-1]+this.tickInterval));this.transA*=(e-1)/(a-1);this.max=b[b.length-1]}if(t(d)&&a!==d)this.isDirty=!0}},setScale:function(){var a=this.stacks,b,c,d,e;
+this.oldMin=this.min;this.oldMax=this.max;this.oldAxisLength=this.len;this.setAxisSize();e=this.len!==this.oldAxisLength;n(this.series,function(a){if(a.isDirtyData||a.isDirty||a.xAxis.isDirty)d=!0});if(e||d||this.isLinked||this.forceRedraw||this.userMin!==this.oldUserMin||this.userMax!==this.oldUserMax){if(!this.isXAxis)for(b in a)for(c in a[b])a[b][c].total=null;this.forceRedraw=!1;this.getSeriesExtremes();this.setTickPositions();this.oldUserMin=this.userMin;this.oldUserMax=this.userMax;if(!this.isDirty)this.isDirty=
+e||this.min!==this.oldMin||this.max!==this.oldMax}else if(!this.isXAxis){if(this.oldStacks)a=this.stacks=this.oldStacks;for(b in a)for(c in a[b])a[b][c].cum=a[b][c].total}this.setMaxTicks()},setExtremes:function(a,b,c,d,e){var f=this,g=f.chart,c=p(c,!0),e=r(e,{min:a,max:b});C(f,"setExtremes",e,function(){f.userMin=a;f.userMax=b;f.isDirtyExtremes=!0;c&&g.redraw(d)})},zoom:function(a,b){this.allowZoomOutside||(t(this.dataMin)&&a<=this.dataMin&&(a=v),t(this.dataMax)&&b>=this.dataMax&&(b=v));this.displayBtn=
+a!==v||b!==v;this.setExtremes(a,b,!1,v,{trigger:"zoom"});return!0},setAxisSize:function(){var a=this.chart,b=this.options,c=b.offsetLeft||0,d=b.offsetRight||0,e=this.horiz,f,g;this.left=g=p(b.left,a.plotLeft+c);this.top=f=p(b.top,a.plotTop);this.width=c=p(b.width,a.plotWidth-c+d);this.height=b=p(b.height,a.plotHeight);this.bottom=a.chartHeight-b-f;this.right=a.chartWidth-c-g;this.len=u(e?c:b,0);this.pos=e?g:f},getExtremes:function(){var a=this.isLog;return{min:a?ia(ea(this.min)):this.min,max:a?ia(ea(this.max)):
+this.max,dataMin:this.dataMin,dataMax:this.dataMax,userMin:this.userMin,userMax:this.userMax}},getThreshold:function(a){var b=this.isLog,c=b?ea(this.min):this.min,b=b?ea(this.max):this.max;c>a||a===null?a=c:b<a&&(a=b);return this.translate(a,0,1,0,1)},addPlotBand:function(a){this.addPlotBandOrLine(a,"plotBands")},addPlotLine:function(a){this.addPlotBandOrLine(a,"plotLines")},addPlotBandOrLine:function(a,b){var c=(new tb(this,a)).render(),d=this.userOptions;b&&(d[b]=d[b]||[],d[b].push(a));this.plotLinesAndBands.push(c);
+return c},autoLabelAlign:function(a){a=(p(a,0)-this.side*90+720)%360;return a>15&&a<165?"right":a>195&&a<345?"left":"center"},getOffset:function(){var a=this,b=a.chart,c=b.renderer,d=a.options,e=a.tickPositions,f=a.ticks,g=a.horiz,h=a.side,i=b.inverted?[1,0,3,2][h]:h,j,k=0,l,m=0,o=d.title,q=d.labels,ka=0,D=b.axisOffset,F=b.clipOffset,s=[-1,1,1,-1][h],r,w=1,x=p(q.maxStaggerLines,5),Ga,G,H,B;a.hasData=j=a.hasVisibleSeries||t(a.min)&&t(a.max)&&!!e;a.showAxis=b=j||p(d.showEmpty,!0);a.staggerLines=a.horiz&&
+q.staggerLines;if(!a.axisGroup)a.gridGroup=c.g("grid").attr({zIndex:d.gridZIndex||1}).add(),a.axisGroup=c.g("axis").attr({zIndex:d.zIndex||2}).add(),a.labelGroup=c.g("axis-labels").attr({zIndex:q.zIndex||7}).add();if(j||a.isLinked){a.labelAlign=p(q.align||a.autoLabelAlign(q.rotation));n(e,function(b){f[b]?f[b].addLabel():f[b]=new La(a,b)});if(a.horiz&&!a.staggerLines&&x&&!q.rotation){for(r=a.reversed?[].concat(e).reverse():e;w<x;){j=[];Ga=!1;for(q=0;q<r.length;q++)G=r[q],H=(H=f[G].label&&f[G].label.bBox)?
+H.width:0,B=q%w,H&&(G=a.translate(G),j[B]!==v&&G<j[B]&&(Ga=!0),j[B]=G+H);if(Ga)w++;else break}if(w>1)a.staggerLines=w}n(e,function(b){if(h===0||h===2||{1:"left",3:"right"}[h]===a.labelAlign)ka=u(f[b].getLabelSize(),ka)});if(a.staggerLines)ka*=a.staggerLines,a.labelOffset=ka}else for(r in f)f[r].destroy(),delete f[r];if(o&&o.text&&o.enabled!==!1){if(!a.axisTitle)a.axisTitle=c.text(o.text,0,0,o.useHTML).attr({zIndex:7,rotation:o.rotation||0,align:o.textAlign||{low:"left",middle:"center",high:"right"}[o.align]}).css(o.style).add(a.axisGroup),
+a.axisTitle.isNew=!0;if(b)k=a.axisTitle.getBBox()[g?"height":"width"],m=p(o.margin,g?5:10),l=o.offset;a.axisTitle[b?"show":"hide"]()}a.offset=s*p(d.offset,D[h]);a.axisTitleMargin=p(l,ka+m+(h!==2&&ka&&s*d.labels[g?"y":"x"]));D[h]=u(D[h],a.axisTitleMargin+k+s*a.offset);F[i]=u(F[i],d.lineWidth)},getLinePath:function(a){var b=this.chart,c=this.opposite,d=this.offset,e=this.horiz,f=this.left+(c?this.width:0)+d;this.lineTop=d=b.chartHeight-this.bottom-(c?this.height:0)+d;c||(a*=-1);return b.renderer.crispLine(["M",
+e?this.left:f,e?d:this.top,"L",e?b.chartWidth-this.right:f,e?d:b.chartHeight-this.bottom],a)},getTitlePosition:function(){var a=this.horiz,b=this.left,c=this.top,d=this.len,e=this.options.title,f=a?b:c,g=this.opposite,h=this.offset,i=A(e.style.fontSize||12),d={low:f+(a?0:d),middle:f+d/2,high:f+(a?d:0)}[e.align],b=(a?c+this.height:b)+(a?1:-1)*(g?-1:1)*this.axisTitleMargin+(this.side===2?i:0);return{x:a?d:b+(g?this.width:0)+h+(e.x||0),y:a?b-(g?this.height:0)+h:d+(e.y||0)}},render:function(){var a=this,
+b=a.chart,c=b.renderer,d=a.options,e=a.isLog,f=a.isLinked,g=a.tickPositions,h=a.axisTitle,i=a.stacks,j=a.ticks,k=a.minorTicks,l=a.alternateBands,m=d.stackLabels,o=d.alternateGridColor,q=a.tickmarkOffset,p=d.lineWidth,D,F=b.hasRendered&&t(a.oldMin)&&!isNaN(a.oldMin);D=a.hasData;var u=a.showAxis,s,r;n([j,k,l],function(a){for(var b in a)a[b].isActive=!1});if(D||f)if(a.minorTickInterval&&!a.categories&&n(a.getMinorTickPositions(),function(b){k[b]||(k[b]=new La(a,b,"minor"));F&&k[b].isNew&&k[b].render(null,
+!0);k[b].render(null,!1,1)}),g.length&&(n(g.slice(1).concat([g[0]]),function(b,c){c=c===g.length-1?0:c+1;if(!f||b>=a.min&&b<=a.max)j[b]||(j[b]=new La(a,b)),F&&j[b].isNew&&j[b].render(c,!0),j[b].render(c,!1,1)}),q&&a.min===0&&(j[-1]||(j[-1]=new La(a,-1,null,!0)),j[-1].render(-1))),o&&n(g,function(b,c){if(c%2===0&&b<a.max)l[b]||(l[b]=new tb(a)),s=b+q,r=g[c+1]!==v?g[c+1]+q:a.max,l[b].options={from:e?ea(s):s,to:e?ea(r):r,color:o},l[b].render(),l[b].isActive=!0}),!a._addedPlotLB)n((d.plotLines||[]).concat(d.plotBands||
+[]),function(b){a.addPlotBandOrLine(b)}),a._addedPlotLB=!0;n([j,k,l],function(a){var c,d,e=[],f=Ca?Ca.duration||500:0,g=function(){for(d=e.length;d--;)a[e[d]]&&!a[e[d]].isActive&&(a[e[d]].destroy(),delete a[e[d]])};for(c in a)if(!a[c].isActive)a[c].render(c,!1,0),a[c].isActive=!1,e.push(c);a===l||!b.hasRendered||!f?g():f&&setTimeout(g,f)});if(p)D=a.getLinePath(p),a.axisLine?a.axisLine.animate({d:D}):a.axisLine=c.path(D).attr({stroke:d.lineColor,"stroke-width":p,zIndex:7}).add(a.axisGroup),a.axisLine[u?
+"show":"hide"]();if(h&&u)h[h.isNew?"attr":"animate"](a.getTitlePosition()),h.isNew=!1;if(m&&m.enabled){var w,x,d=a.stackTotalGroup;if(!d)a.stackTotalGroup=d=c.g("stack-labels").attr({visibility:"visible",zIndex:6}).add();d.translate(b.plotLeft,b.plotTop);for(w in i)for(x in c=i[w],c)c[x].render(d)}a.isDirty=!1},removePlotBandOrLine:function(a){for(var b=this.plotLinesAndBands,c=this.options,d=this.userOptions,e=b.length;e--;)b[e].id===a&&b[e].destroy();n([c.plotLines||[],d.plotLines||[],c.plotBands||
+[],d.plotBands||[]],function(b){for(e=b.length;e--;)b[e].id===a&&fa(b,b[e])})},setTitle:function(a,b){this.update({title:a},b)},redraw:function(){var a=this.chart.pointer;a.reset&&a.reset(!0);this.render();n(this.plotLinesAndBands,function(a){a.render()});n(this.series,function(a){a.isDirty=!0})},buildStacks:function(){this.isXAxis||n(this.series,function(a){a.setStackedPoints()})},setCategories:function(a,b){this.update({categories:a},b)},destroy:function(a){var b=this,c=b.stacks,d,e=b.plotLinesAndBands;
+a||aa(b);for(d in c)Ja(c[d]),c[d]=null;n([b.ticks,b.minorTicks,b.alternateBands],function(a){Ja(a)});for(a=e.length;a--;)e[a].destroy();n("stackTotalGroup,axisLine,axisGroup,gridGroup,labelGroup,axisTitle".split(","),function(a){b[a]&&(b[a]=b[a].destroy())})}};ub.prototype={init:function(a,b){var c=b.borderWidth,d=b.style,e=A(d.padding);this.chart=a;this.options=b;this.crosshairs=[];this.now={x:0,y:0};this.isHidden=!0;this.label=a.renderer.label("",0,0,b.shape,null,null,b.useHTML,null,"tooltip").attr({padding:e,
+fill:b.backgroundColor,"stroke-width":c,r:b.borderRadius,zIndex:8}).css(d).css({padding:0}).hide().add();Z||this.label.shadow(b.shadow);this.shared=b.shared},destroy:function(){n(this.crosshairs,function(a){a&&a.destroy()});if(this.label)this.label=this.label.destroy();clearTimeout(this.hideTimer);clearTimeout(this.tooltipTimeout)},move:function(a,b,c,d){var e=this,f=e.now,g=e.options.animation!==!1&&!e.isHidden;r(f,{x:g?(2*f.x+a)/3:a,y:g?(f.y+b)/2:b,anchorX:g?(2*f.anchorX+c)/3:c,anchorY:g?(f.anchorY+
+d)/2:d});e.label.attr(f);if(g&&(P(a-f.x)>1||P(b-f.y)>1))clearTimeout(this.tooltipTimeout),this.tooltipTimeout=setTimeout(function(){e&&e.move(a,b,c,d)},32)},hide:function(){var a=this,b;clearTimeout(this.hideTimer);if(!this.isHidden)b=this.chart.hoverPoints,this.hideTimer=setTimeout(function(){a.label.fadeOut();a.isHidden=!0},p(this.options.hideDelay,500)),b&&n(b,function(a){a.setState()}),this.chart.hoverPoints=null},hideCrosshairs:function(){n(this.crosshairs,function(a){a&&a.hide()})},getAnchor:function(a,
+b){var c,d=this.chart,e=d.inverted,f=d.plotTop,g=0,h=0,i,a=ha(a);c=a[0].tooltipPos;this.followPointer&&b&&(b.chartX===v&&(b=d.pointer.normalize(b)),c=[b.chartX-d.plotLeft,b.chartY-f]);c||(n(a,function(a){i=a.series.yAxis;g+=a.plotX;h+=(a.plotLow?(a.plotLow+a.plotHigh)/2:a.plotY)+(!e&&i?i.top-f:0)}),g/=a.length,h/=a.length,c=[e?d.plotWidth-h:g,this.shared&&!e&&a.length>1&&b?b.chartY-f:e?d.plotHeight-g:h]);return Na(c,s)},getPosition:function(a,b,c){var d=this.chart,e=d.plotLeft,f=d.plotTop,g=d.plotWidth,
+h=d.plotHeight,i=p(this.options.distance,12),j=c.plotX,c=c.plotY,d=j+e+(d.inverted?i:-a-i),k=c-b+f+15,l;d<7&&(d=e+u(j,0)+i);d+a>e+g&&(d-=d+a-(e+g),k=c-b+f-i,l=!0);k<f+5&&(k=f+5,l&&c>=k&&c<=k+b&&(k=c+f+i));k+b>f+h&&(k=u(f,f+h-b-i));return{x:d,y:k}},defaultFormatter:function(a){var b=this.points||ha(this),c=b[0].series,d;d=[c.tooltipHeaderFormatter(b[0])];n(b,function(a){c=a.series;d.push(c.tooltipFormatter&&c.tooltipFormatter(a)||a.point.tooltipFormatter(c.tooltipOptions.pointFormat))});d.push(a.options.footerFormat||
+"");return d.join("")},refresh:function(a,b){var c=this.chart,d=this.label,e=this.options,f,g,h,i={},j,k=[];j=e.formatter||this.defaultFormatter;var i=c.hoverPoints,l,m=e.crosshairs;h=this.shared;clearTimeout(this.hideTimer);this.followPointer=ha(a)[0].series.tooltipOptions.followPointer;g=this.getAnchor(a,b);f=g[0];g=g[1];h&&(!a.series||!a.series.noSharedTooltip)?(c.hoverPoints=a,i&&n(i,function(a){a.setState()}),n(a,function(a){a.setState("hover");k.push(a.getLabelConfig())}),i={x:a[0].category,
+y:a[0].y},i.points=k,a=a[0]):i=a.getLabelConfig();j=j.call(i,this);i=a.series;h=h||!i.isCartesian||i.tooltipOutsidePlot||c.isInsidePlot(f,g);j===!1||!h?this.hide():(this.isHidden&&(Wa(d),d.attr("opacity",1).show()),d.attr({text:j}),l=e.borderColor||a.color||i.color||"#606060",d.attr({stroke:l}),this.updatePosition({plotX:f,plotY:g}),this.isHidden=!1);if(m){m=ha(m);for(d=m.length;d--;)if(i=a.series,e=i[d?"yAxis":"xAxis"],m[d]&&e)if(h=d?p(a.stackY,a.y):a.x,e.isLog&&(h=ma(h)),i.modifyValue&&(h=i.modifyValue(h)),
+e=e.getPlotLinePath(h,1),this.crosshairs[d])this.crosshairs[d].attr({d:e,visibility:"visible"});else{h={"stroke-width":m[d].width||1,stroke:m[d].color||"#C0C0C0",zIndex:m[d].zIndex||2};if(m[d].dashStyle)h.dashstyle=m[d].dashStyle;this.crosshairs[d]=c.renderer.path(e).attr(h).add()}}C(c,"tooltipRefresh",{text:j,x:f+c.plotLeft,y:g+c.plotTop,borderColor:l})},updatePosition:function(a){var b=this.chart,c=this.label,c=(this.options.positioner||this.getPosition).call(this,c.width,c.height,a);this.move(s(c.x),
+s(c.y),a.plotX+b.plotLeft,a.plotY+b.plotTop)}};vb.prototype={init:function(a,b){var c=Z?"":b.chart.zoomType,d=a.inverted,e;this.options=b;this.chart=a;this.zoomX=e=/x/.test(c);this.zoomY=c=/y/.test(c);this.zoomHor=e&&!d||c&&d;this.zoomVert=c&&!d||e&&d;this.pinchDown=[];this.lastValidTouch={};if(b.tooltip.enabled)a.tooltip=new ub(a,b.tooltip);this.setDOMEvents()},normalize:function(a){var b,c,a=a||E.event;if(!a.target)a.target=a.srcElement;a=Sb(a);c=a.touches?a.touches.item(0):a;this.chartPosition=
+b=Xb(this.chart.container);return r(a,{chartX:s(p(c.pageX,c.clientX)-b.left),chartY:s(p(c.pageY,c.clientY)-b.top)})},getCoordinates:function(a){var b={xAxis:[],yAxis:[]};n(this.chart.axes,function(c){b[c.isXAxis?"xAxis":"yAxis"].push({axis:c,value:c.toValue(a[c.horiz?"chartX":"chartY"])})});return b},getIndex:function(a){var b=this.chart;return b.inverted?b.plotHeight+b.plotTop-a.chartY:a.chartX-b.plotLeft},runPointActions:function(a){var b=this.chart,c=b.series,d=b.tooltip,e,f=b.hoverPoint,g=b.hoverSeries,
+h,i,j=b.chartWidth,k=this.getIndex(a);if(d&&this.options.tooltip.shared&&(!g||!g.noSharedTooltip)){e=[];h=c.length;for(i=0;i<h;i++)if(c[i].visible&&c[i].options.enableMouseTracking!==!1&&!c[i].noSharedTooltip&&c[i].tooltipPoints.length&&(b=c[i].tooltipPoints[k],b.series))b._dist=P(k-b.clientX),j=I(j,b._dist),e.push(b);for(h=e.length;h--;)e[h]._dist>j&&e.splice(h,1);if(e.length&&e[0].clientX!==this.hoverX)d.refresh(e,a),this.hoverX=e[0].clientX}if(g&&g.tracker){if((b=g.tooltipPoints[k])&&b!==f)b.onMouseOver(a)}else d&&
+d.followPointer&&!d.isHidden&&(a=d.getAnchor([{}],a),d.updatePosition({plotX:a[0],plotY:a[1]}))},reset:function(a){var b=this.chart,c=b.hoverSeries,d=b.hoverPoint,e=b.tooltip,b=e&&e.shared?b.hoverPoints:d;(a=a&&e&&b)&&ha(b)[0].plotX===v&&(a=!1);if(a)e.refresh(b);else{if(d)d.onMouseOut();if(c)c.onMouseOut();e&&(e.hide(),e.hideCrosshairs());this.hoverX=null}},scaleGroups:function(a,b){var c=this.chart,d;n(c.series,function(e){d=a||e.getPlotBox();e.xAxis&&e.xAxis.zoomEnabled&&(e.group.attr(d),e.markerGroup&&
+(e.markerGroup.attr(d),e.markerGroup.clip(b?c.clipRect:null)),e.dataLabelsGroup&&e.dataLabelsGroup.attr(d))});c.clipRect.attr(b||c.clipBox)},pinchTranslateDirection:function(a,b,c,d,e,f,g){var h=this.chart,i=a?"x":"y",j=a?"X":"Y",k="chart"+j,l=a?"width":"height",m=h["plot"+(a?"Left":"Top")],o,q,p=1,n=h.inverted,u=h.bounds[a?"h":"v"],s=b.length===1,t=b[0][k],r=c[0][k],w=!s&&b[1][k],v=!s&&c[1][k],x,c=function(){!s&&P(t-w)>20&&(p=P(r-v)/P(t-w));q=(m-r)/p+t;o=h["plot"+(a?"Width":"Height")]/p};c();b=q;
+b<u.min?(b=u.min,x=!0):b+o>u.max&&(b=u.max-o,x=!0);x?(r-=0.8*(r-g[i][0]),s||(v-=0.8*(v-g[i][1])),c()):g[i]=[r,v];n||(f[i]=q-m,f[l]=o);f=n?1/p:p;e[l]=o;e[i]=b;d[n?a?"scaleY":"scaleX":"scale"+j]=p;d["translate"+j]=f*m+(r-f*t)},pinch:function(a){var b=this,c=b.chart,d=b.pinchDown,e=c.tooltip&&c.tooltip.options.followTouchMove,f=a.touches,g=f.length,h=b.lastValidTouch,i=b.zoomHor||b.pinchHor,j=b.zoomVert||b.pinchVert,k=i||j,l=b.selectionMarker,m={},o={};a.type==="touchstart"&&(e||k)&&a.preventDefault();
+Na(f,function(a){return b.normalize(a)});if(a.type==="touchstart")n(f,function(a,b){d[b]={chartX:a.chartX,chartY:a.chartY}}),h.x=[d[0].chartX,d[1]&&d[1].chartX],h.y=[d[0].chartY,d[1]&&d[1].chartY],n(c.axes,function(a){if(a.zoomEnabled){var b=c.bounds[a.horiz?"h":"v"],d=a.minPixelPadding,e=a.toPixels(a.dataMin),f=a.toPixels(a.dataMax),g=I(e,f),e=u(e,f);b.min=I(a.pos,g-d);b.max=u(a.pos+a.len,e+d)}});else if(d.length){if(!l)b.selectionMarker=l=r({destroy:xa},c.plotBox);i&&b.pinchTranslateDirection(!0,
+d,f,m,l,o,h);j&&b.pinchTranslateDirection(!1,d,f,m,l,o,h);b.hasPinched=k;b.scaleGroups(m,o);!k&&e&&g===1&&this.runPointActions(b.normalize(a))}},dragStart:function(a){var b=this.chart;b.mouseIsDown=a.type;b.cancelClick=!1;b.mouseDownX=this.mouseDownX=a.chartX;this.mouseDownY=a.chartY},drag:function(a){var b=this.chart,c=b.options.chart,d=a.chartX,a=a.chartY,e=this.zoomHor,f=this.zoomVert,g=b.plotLeft,h=b.plotTop,i=b.plotWidth,j=b.plotHeight,k,l=this.mouseDownX,m=this.mouseDownY;d<g?d=g:d>g+i&&(d=
+g+i);a<h?a=h:a>h+j&&(a=h+j);this.hasDragged=Math.sqrt(Math.pow(l-d,2)+Math.pow(m-a,2));if(this.hasDragged>10){k=b.isInsidePlot(l-g,m-h);if(b.hasCartesianSeries&&(this.zoomX||this.zoomY)&&k&&!this.selectionMarker)this.selectionMarker=b.renderer.rect(g,h,e?1:i,f?1:j,0).attr({fill:c.selectionMarkerFill||"rgba(69,114,167,0.25)",zIndex:7}).add();this.selectionMarker&&e&&(e=d-l,this.selectionMarker.attr({width:P(e),x:(e>0?0:e)+l}));this.selectionMarker&&f&&(e=a-m,this.selectionMarker.attr({height:P(e),
+y:(e>0?0:e)+m}));k&&!this.selectionMarker&&c.panning&&b.pan(d)}},drop:function(a){var b=this.chart,c=this.hasPinched;if(this.selectionMarker){var d={xAxis:[],yAxis:[],originalEvent:a.originalEvent||a},e=this.selectionMarker,f=e.x,g=e.y,h;if(this.hasDragged||c)n(b.axes,function(a){if(a.zoomEnabled){var b=a.horiz,c=a.toValue(b?f:g),b=a.toValue(b?f+e.width:g+e.height);!isNaN(c)&&!isNaN(b)&&(d[a.xOrY+"Axis"].push({axis:a,min:I(c,b),max:u(c,b)}),h=!0)}}),h&&C(b,"selection",d,function(a){b.zoom(r(a,c?{animation:!1}:
+null))});this.selectionMarker=this.selectionMarker.destroy();c&&this.scaleGroups()}if(b)M(b.container,{cursor:b._cursor}),b.cancelClick=this.hasDragged>10,b.mouseIsDown=this.hasDragged=this.hasPinched=!1,this.pinchDown=[]},onContainerMouseDown:function(a){a=this.normalize(a);a.preventDefault&&a.preventDefault();this.dragStart(a)},onDocumentMouseUp:function(a){this.drop(a)},onDocumentMouseMove:function(a){var b=this.chart,c=this.chartPosition,d=b.hoverSeries,a=Sb(a);c&&d&&d.isCartesian&&!b.isInsidePlot(a.pageX-
+c.left-b.plotLeft,a.pageY-c.top-b.plotTop)&&this.reset()},onContainerMouseLeave:function(){this.reset();this.chartPosition=null},onContainerMouseMove:function(a){var b=this.chart,a=this.normalize(a);a.returnValue=!1;b.mouseIsDown==="mousedown"&&this.drag(a);b.isInsidePlot(a.chartX-b.plotLeft,a.chartY-b.plotTop)&&!b.openMenu&&this.runPointActions(a)},inClass:function(a,b){for(var c;a;){if(c=w(a,"class"))if(c.indexOf(b)!==-1)return!0;else if(c.indexOf("highcharts-container")!==-1)return!1;a=a.parentNode}},
+onTrackerMouseOut:function(a){var b=this.chart.hoverSeries;if(b&&!b.options.stickyTracking&&!this.inClass(a.toElement||a.relatedTarget,"highcharts-tooltip"))b.onMouseOut()},onContainerClick:function(a){var b=this.chart,c=b.hoverPoint,d=b.plotLeft,e=b.plotTop,f=b.inverted,g,h,i,a=this.normalize(a);a.cancelBubble=!0;if(!b.cancelClick)c&&this.inClass(a.target,"highcharts-tracker")?(g=this.chartPosition,h=c.plotX,i=c.plotY,r(c,{pageX:g.left+d+(f?b.plotWidth-i:h),pageY:g.top+e+(f?b.plotHeight-h:i)}),C(c.series,
+"click",r(a,{point:c})),b.hoverPoint&&c.firePointEvent("click",a)):(r(a,this.getCoordinates(a)),b.isInsidePlot(a.chartX-d,a.chartY-e)&&C(b,"click",a))},onContainerTouchStart:function(a){var b=this.chart;a.touches.length===1?(a=this.normalize(a),b.isInsidePlot(a.chartX-b.plotLeft,a.chartY-b.plotTop)?(this.runPointActions(a),this.pinch(a)):this.reset()):a.touches.length===2&&this.pinch(a)},onContainerTouchMove:function(a){(a.touches.length===1||a.touches.length===2)&&this.pinch(a)},onDocumentTouchEnd:function(a){this.drop(a)},
+setDOMEvents:function(){var a=this,b=a.chart.container,c;this._events=c=[[b,"onmousedown","onContainerMouseDown"],[b,"onmousemove","onContainerMouseMove"],[b,"onclick","onContainerClick"],[b,"mouseleave","onContainerMouseLeave"],[z,"mousemove","onDocumentMouseMove"],[z,"mouseup","onDocumentMouseUp"]];hb&&c.push([b,"ontouchstart","onContainerTouchStart"],[b,"ontouchmove","onContainerTouchMove"],[z,"touchend","onDocumentTouchEnd"]);n(c,function(b){a["_"+b[2]]=function(c){a[b[2]](c)};b[1].indexOf("on")===
+0?b[0][b[1]]=a["_"+b[2]]:J(b[0],b[1],a["_"+b[2]])})},destroy:function(){var a=this;n(a._events,function(b){b[1].indexOf("on")===0?b[0][b[1]]=null:aa(b[0],b[1],a["_"+b[2]])});delete a._events;clearInterval(a.tooltipTimeout)}};wb.prototype={init:function(a,b){var c=this,d=b.itemStyle,e=p(b.padding,8),f=b.itemMarginTop||0;this.options=b;if(b.enabled)c.baseline=A(d.fontSize)+3+f,c.itemStyle=d,c.itemHiddenStyle=x(d,b.itemHiddenStyle),c.itemMarginTop=f,c.padding=e,c.initialItemX=e,c.initialItemY=e-5,c.maxItemWidth=
+0,c.chart=a,c.itemHeight=0,c.lastLineHeight=0,c.render(),J(c.chart,"endResize",function(){c.positionCheckboxes()})},colorizeItem:function(a,b){var c=this.options,d=a.legendItem,e=a.legendLine,f=a.legendSymbol,g=this.itemHiddenStyle.color,c=b?c.itemStyle.color:g,h=b?a.color:g,g=a.options&&a.options.marker,i={stroke:h,fill:h},j;d&&d.css({fill:c,color:c});e&&e.attr({stroke:h});if(f){if(g&&f.isMarker)for(j in g=a.convertAttribs(g),g)d=g[j],d!==v&&(i[j]=d);f.attr(i)}},positionItem:function(a){var b=this.options,
+c=b.symbolPadding,b=!b.rtl,d=a._legendItemPos,e=d[0],d=d[1],f=a.checkbox;a.legendGroup&&a.legendGroup.translate(b?e:this.legendWidth-e-2*c-4,d);if(f)f.x=e,f.y=d},destroyItem:function(a){var b=a.checkbox;n(["legendItem","legendLine","legendSymbol","legendGroup"],function(b){a[b]&&(a[b]=a[b].destroy())});b&&Ta(a.checkbox)},destroy:function(){var a=this.group,b=this.box;if(b)this.box=b.destroy();if(a)this.group=a.destroy()},positionCheckboxes:function(a){var b=this.group.alignAttr,c,d=this.clipHeight||
+this.legendHeight;if(b)c=b.translateY,n(this.allItems,function(e){var f=e.checkbox,g;f&&(g=c+f.y+(a||0)+3,M(f,{left:b.translateX+e.legendItemWidth+f.x-20+"px",top:g+"px",display:g>c-6&&g<c+d-6?"":R}))})},renderTitle:function(){var a=this.padding,b=this.options.title,c=0;if(b.text){if(!this.title)this.title=this.chart.renderer.label(b.text,a-3,a-4,null,null,null,null,null,"legend-title").attr({zIndex:1}).css(b.style).add(this.group);a=this.title.getBBox();c=a.height;this.offsetWidth=a.width;this.contentGroup.attr({translateY:c})}this.titleHeight=
+c},renderItem:function(a){var B;var b=this,c=b.chart,d=c.renderer,e=b.options,f=e.layout==="horizontal",g=e.symbolWidth,h=e.symbolPadding,i=b.itemStyle,j=b.itemHiddenStyle,k=b.padding,l=f?p(e.itemDistance,8):0,m=!e.rtl,o=e.width,q=e.itemMarginBottom||0,n=b.itemMarginTop,s=b.initialItemX,t=a.legendItem,r=a.series||a,w=r.options,v=w.showCheckbox,A=e.useHTML;if(!t&&(a.legendGroup=d.g("legend-item").attr({zIndex:1}).add(b.scrollGroup),r.drawLegendSymbol(b,a),a.legendItem=t=d.text(e.labelFormat?Aa(e.labelFormat,
+a):e.labelFormatter.call(a),m?g+h:-h,b.baseline,A).css(x(a.visible?i:j)).attr({align:m?"left":"right",zIndex:2}).add(a.legendGroup),(A?t:a.legendGroup).on("mouseover",function(){a.setState("hover");t.css(b.options.itemHoverStyle)}).on("mouseout",function(){t.css(a.visible?i:j);a.setState()}).on("click",function(b){var c=function(){a.setVisible()},b={browserEvent:b};a.firePointEvent?a.firePointEvent("legendItemClick",b,c):C(a,"legendItemClick",b,c)}),b.colorizeItem(a,a.visible),w&&v))a.checkbox=T("input",
+{type:"checkbox",checked:a.selected,defaultChecked:a.selected},e.itemCheckboxStyle,c.container),J(a.checkbox,"click",function(b){C(a,"checkboxClick",{checked:b.target.checked},function(){a.select()})});d=t.getBBox();B=a.legendItemWidth=e.itemWidth||g+h+d.width+l+(v?20:0),e=B;b.itemHeight=g=d.height;if(f&&b.itemX-s+e>(o||c.chartWidth-2*k-s))b.itemX=s,b.itemY+=n+b.lastLineHeight+q,b.lastLineHeight=0;b.maxItemWidth=u(b.maxItemWidth,e);b.lastItemY=n+b.itemY+q;b.lastLineHeight=u(g,b.lastLineHeight);a._legendItemPos=
+[b.itemX,b.itemY];f?b.itemX+=e:(b.itemY+=n+g+q,b.lastLineHeight=g);b.offsetWidth=o||u((f?b.itemX-s-l:e)+k,b.offsetWidth)},render:function(){var a=this,b=a.chart,c=b.renderer,d=a.group,e,f,g,h,i=a.box,j=a.options,k=a.padding,l=j.borderWidth,m=j.backgroundColor;a.itemX=a.initialItemX;a.itemY=a.initialItemY;a.offsetWidth=0;a.lastItemY=0;if(!d)a.group=d=c.g("legend").attr({zIndex:7}).add(),a.contentGroup=c.g().attr({zIndex:1}).add(d),a.scrollGroup=c.g().add(a.contentGroup);a.renderTitle();e=[];n(b.series,
+function(a){var b=a.options;b.showInLegend&&!t(b.linkedTo)&&(e=e.concat(a.legendItems||(b.legendType==="point"?a.data:a)))});Kb(e,function(a,b){return(a.options&&a.options.legendIndex||0)-(b.options&&b.options.legendIndex||0)});j.reversed&&e.reverse();a.allItems=e;a.display=f=!!e.length;n(e,function(b){a.renderItem(b)});g=j.width||a.offsetWidth;h=a.lastItemY+a.lastLineHeight+a.titleHeight;h=a.handleOverflow(h);if(l||m){g+=k;h+=k;if(i){if(g>0&&h>0)i[i.isNew?"attr":"animate"](i.crisp(null,null,null,
+g,h)),i.isNew=!1}else a.box=i=c.rect(0,0,g,h,j.borderRadius,l||0).attr({stroke:j.borderColor,"stroke-width":l||0,fill:m||R}).add(d).shadow(j.shadow),i.isNew=!0;i[f?"show":"hide"]()}a.legendWidth=g;a.legendHeight=h;n(e,function(b){a.positionItem(b)});f&&d.align(r({width:g,height:h},j),!0,"spacingBox");b.isResizing||this.positionCheckboxes()},handleOverflow:function(a){var b=this,c=this.chart,d=c.renderer,e=this.options,f=e.y,f=c.spacingBox.height+(e.verticalAlign==="top"?-f:f)-this.padding,g=e.maxHeight,
+h=this.clipRect,i=e.navigation,j=p(i.animation,!0),k=i.arrowSize||12,l=this.nav;e.layout==="horizontal"&&(f/=2);g&&(f=I(f,g));if(a>f&&!e.useHTML){this.clipHeight=c=f-20-this.titleHeight;this.pageCount=ja(a/c);this.currentPage=p(this.currentPage,1);this.fullHeight=a;if(!h)h=b.clipRect=d.clipRect(0,0,9999,0),b.contentGroup.clip(h);h.attr({height:c});if(!l)this.nav=l=d.g().attr({zIndex:1}).add(this.group),this.up=d.symbol("triangle",0,0,k,k).on("click",function(){b.scroll(-1,j)}).add(l),this.pager=d.text("",
+15,10).css(i.style).add(l),this.down=d.symbol("triangle-down",0,0,k,k).on("click",function(){b.scroll(1,j)}).add(l);b.scroll(0);a=f}else if(l)h.attr({height:c.chartHeight}),l.hide(),this.scrollGroup.attr({translateY:1}),this.clipHeight=0;return a},scroll:function(a,b){var c=this.pageCount,d=this.currentPage+a,e=this.clipHeight,f=this.options.navigation,g=f.activeColor,h=f.inactiveColor,f=this.pager,i=this.padding;d>c&&(d=c);if(d>0)b!==v&&Ka(b,this.chart),this.nav.attr({translateX:i,translateY:e+7+
+this.titleHeight,visibility:"visible"}),this.up.attr({fill:d===1?h:g}).css({cursor:d===1?"default":"pointer"}),f.attr({text:d+"/"+this.pageCount}),this.down.attr({x:18+this.pager.getBBox().width,fill:d===c?h:g}).css({cursor:d===c?"default":"pointer"}),e=-I(e*(d-1),this.fullHeight-e+i)+1,this.scrollGroup.animate({translateY:e}),f.attr({text:d+"/"+c}),this.currentPage=d,this.positionCheckboxes(e)}};xb.prototype={init:function(a,b){var c,d=a.series;a.series=null;c=x(O,a);c.series=a.series=d;var d=c.chart,
+e=d.margin,e=U(e)?e:[e,e,e,e];this.optionsMarginTop=p(d.marginTop,e[0]);this.optionsMarginRight=p(d.marginRight,e[1]);this.optionsMarginBottom=p(d.marginBottom,e[2]);this.optionsMarginLeft=p(d.marginLeft,e[3]);e=d.events;this.bounds={h:{},v:{}};this.callback=b;this.isResizing=0;this.options=c;this.axes=[];this.series=[];this.hasCartesianSeries=d.showAxes;var f=this,g;f.index=Ea.length;Ea.push(f);d.reflow!==!1&&J(f,"load",function(){f.initReflow()});if(e)for(g in e)J(f,g,e[g]);f.xAxis=[];f.yAxis=[];
+f.animation=Z?!1:p(d.animation,!0);f.pointCount=0;f.counters=new Jb;f.firstRender()},initSeries:function(a){var b=this.options.chart;(b=$[a.type||b.type||b.defaultSeriesType])||ua(17,!0);b=new b;b.init(this,a);return b},addSeries:function(a,b,c){var d,e=this;a&&(b=p(b,!0),C(e,"addSeries",{options:a},function(){d=e.initSeries(a);e.isDirtyLegend=!0;b&&e.redraw(c)}));return d},addAxis:function(a,b,c,d){var e=b?"xAxis":"yAxis",f=this.options;new db(this,x(a,{index:this[e].length,isX:b}));f[e]=ha(f[e]||
+{});f[e].push(a);p(c,!0)&&this.redraw(d)},isInsidePlot:function(a,b,c){var d=c?b:a,a=c?a:b;return d>=0&&d<=this.plotWidth&&a>=0&&a<=this.plotHeight},adjustTickAmounts:function(){this.options.chart.alignTicks!==!1&&n(this.axes,function(a){a.adjustTickAmount()});this.maxTicks=null},redraw:function(a){var b=this.axes,c=this.series,d=this.pointer,e=this.legend,f=this.isDirtyLegend,g,h,i=this.isDirtyBox,j=c.length,k=j,l=this.renderer,m=l.isHidden(),o=[];Ka(a,this);m&&this.cloneRenderTo();for(this.layOutTitles();k--;)if(a=
+c[k],a.options.stacking&&(g=!0,a.isDirty)){h=!0;break}if(h)for(k=j;k--;)if(a=c[k],a.options.stacking)a.isDirty=!0;n(c,function(a){a.isDirty&&a.options.legendType==="point"&&(f=!0)});if(f&&e.options.enabled)e.render(),this.isDirtyLegend=!1;g&&this.getStacks();if(this.hasCartesianSeries){if(!this.isResizing)this.maxTicks=null,n(b,function(a){a.setScale()});this.adjustTickAmounts();this.getMargins();n(b,function(a){if(a.isDirtyExtremes)a.isDirtyExtremes=!1,o.push(function(){C(a,"afterSetExtremes",a.getExtremes())});
+if(a.isDirty||i||g)a.redraw(),i=!0})}i&&this.drawChartBox();n(c,function(a){a.isDirty&&a.visible&&(!a.isCartesian||a.xAxis)&&a.redraw()});d&&d.reset&&d.reset(!0);l.draw();C(this,"redraw");m&&this.cloneRenderTo(!0);n(o,function(a){a.call()})},showLoading:function(a){var b=this.options,c=this.loadingDiv,d=b.loading;if(!c)this.loadingDiv=c=T(Ba,{className:"highcharts-loading"},r(d.style,{zIndex:10,display:R}),this.container),this.loadingSpan=T("span",null,d.labelStyle,c);this.loadingSpan.innerHTML=a||
+b.lang.loading;if(!this.loadingShown)M(c,{opacity:0,display:"",left:this.plotLeft+"px",top:this.plotTop+"px",width:this.plotWidth+"px",height:this.plotHeight+"px"}),Ab(c,{opacity:d.style.opacity},{duration:d.showDuration||0}),this.loadingShown=!0},hideLoading:function(){var a=this.options,b=this.loadingDiv;b&&Ab(b,{opacity:0},{duration:a.loading.hideDuration||100,complete:function(){M(b,{display:R})}});this.loadingShown=!1},get:function(a){var b=this.axes,c=this.series,d,e;for(d=0;d<b.length;d++)if(b[d].options.id===
+a)return b[d];for(d=0;d<c.length;d++)if(c[d].options.id===a)return c[d];for(d=0;d<c.length;d++){e=c[d].points||[];for(b=0;b<e.length;b++)if(e[b].id===a)return e[b]}return null},getAxes:function(){var a=this,b=this.options,c=b.xAxis=ha(b.xAxis||{}),b=b.yAxis=ha(b.yAxis||{});n(c,function(a,b){a.index=b;a.isX=!0});n(b,function(a,b){a.index=b});c=c.concat(b);n(c,function(b){new db(a,b)});a.adjustTickAmounts()},getSelectedPoints:function(){var a=[];n(this.series,function(b){a=a.concat(sb(b.points||[],
+function(a){return a.selected}))});return a},getSelectedSeries:function(){return sb(this.series,function(a){return a.selected})},getStacks:function(){var a=this;n(a.yAxis,function(a){if(a.stacks&&a.hasVisibleSeries)a.oldStacks=a.stacks});n(a.series,function(b){if(b.options.stacking&&(b.visible===!0||a.options.chart.ignoreHiddenSeries===!1))b.stackKey=b.type+p(b.options.stack,"")})},showResetZoom:function(){var a=this,b=O.lang,c=a.options.chart.resetZoomButton,d=c.theme,e=d.states,f=c.relativeTo===
+"chart"?null:"plotBox";this.resetZoomButton=a.renderer.button(b.resetZoom,null,null,function(){a.zoomOut()},d,e&&e.hover).attr({align:c.position.align,title:b.resetZoomTitle}).add().align(c.position,!1,f)},zoomOut:function(){var a=this;C(a,"selection",{resetSelection:!0},function(){a.zoom()})},zoom:function(a){var b,c=this.pointer,d=!1,e;!a||a.resetSelection?n(this.axes,function(a){b=a.zoom()}):n(a.xAxis.concat(a.yAxis),function(a){var e=a.axis,h=e.isXAxis;if(c[h?"zoomX":"zoomY"]||c[h?"pinchX":"pinchY"])b=
+e.zoom(a.min,a.max),e.displayBtn&&(d=!0)});e=this.resetZoomButton;if(d&&!e)this.showResetZoom();else if(!d&&U(e))this.resetZoomButton=e.destroy();b&&this.redraw(p(this.options.chart.animation,a&&a.animation,this.pointCount<100))},pan:function(a){var b=this.xAxis[0],c=this.mouseDownX,d=b.pointRange/2,e=b.getExtremes(),f=b.translate(c-a,!0)+d,c=b.translate(c+this.plotWidth-a,!0)-d;(d=this.hoverPoints)&&n(d,function(a){a.setState()});b.series.length&&f>I(e.dataMin,e.min)&&c<u(e.dataMax,e.max)&&b.setExtremes(f,
+c,!0,!1,{trigger:"pan"});this.mouseDownX=a;M(this.container,{cursor:"move"})},setTitle:function(a,b){var f;var c=this,d=c.options,e;e=d.title=x(d.title,a);f=d.subtitle=x(d.subtitle,b),d=f;n([["title",a,e],["subtitle",b,d]],function(a){var b=a[0],d=c[b],e=a[1],a=a[2];d&&e&&(c[b]=d=d.destroy());a&&a.text&&!d&&(c[b]=c.renderer.text(a.text,0,0,a.useHTML).attr({align:a.align,"class":"highcharts-"+b,zIndex:a.zIndex||4}).css(a.style).add())});c.layOutTitles()},layOutTitles:function(){var a=0,b=this.title,
+c=this.subtitle,d=this.options,e=d.title,d=d.subtitle,f=this.spacingBox.width-44;if(b&&(b.css({width:(e.width||f)+"px"}).align(r({y:15},e),!1,"spacingBox"),!e.floating&&!e.verticalAlign))a=b.getBBox().height,a>=18&&a<=25&&(a=15);c&&(c.css({width:(d.width||f)+"px"}).align(r({y:a+e.margin},d),!1,"spacingBox"),!d.floating&&!d.verticalAlign&&(a=ja(a+c.getBBox().height)));this.titleOffset=a},getChartSize:function(){var a=this.options.chart,b=this.renderToClone||this.renderTo;this.containerWidth=ib(b,"width");
+this.containerHeight=ib(b,"height");this.chartWidth=u(0,a.width||this.containerWidth||600);this.chartHeight=u(0,p(a.height,this.containerHeight>19?this.containerHeight:400))},cloneRenderTo:function(a){var b=this.renderToClone,c=this.container;a?b&&(this.renderTo.appendChild(c),Ta(b),delete this.renderToClone):(c&&c.parentNode===this.renderTo&&this.renderTo.removeChild(c),this.renderToClone=b=this.renderTo.cloneNode(0),M(b,{position:"absolute",top:"-9999px",display:"block"}),z.body.appendChild(b),
+c&&b.appendChild(c))},getContainer:function(){var a,b=this.options.chart,c,d,e;this.renderTo=a=b.renderTo;e="highcharts-"+yb++;if(da(a))this.renderTo=a=z.getElementById(a);a||ua(13,!0);c=A(w(a,"data-highcharts-chart"));!isNaN(c)&&Ea[c]&&Ea[c].destroy();w(a,"data-highcharts-chart",this.index);a.innerHTML="";a.offsetWidth||this.cloneRenderTo();this.getChartSize();c=this.chartWidth;d=this.chartHeight;this.container=a=T(Ba,{className:"highcharts-container"+(b.className?" "+b.className:""),id:e},r({position:"relative",
+overflow:"hidden",width:c+"px",height:d+"px",textAlign:"left",lineHeight:"normal",zIndex:0,"-webkit-tap-highlight-color":"rgba(0,0,0,0)"},b.style),this.renderToClone||a);this._cursor=a.style.cursor;this.renderer=b.forExport?new Fa(a,c,d,!0):new Va(a,c,d);Z&&this.renderer.create(this,a,c,d)},getMargins:function(){var a=this.options.chart,b=a.spacingTop,c=a.spacingRight,d=a.spacingBottom,a=a.spacingLeft,e,f=this.legend,g=this.optionsMarginTop,h=this.optionsMarginLeft,i=this.optionsMarginRight,j=this.optionsMarginBottom,
+k=this.options.legend,l=p(k.margin,10),m=k.x,o=k.y,q=k.align,s=k.verticalAlign,r=this.titleOffset;this.resetMargins();e=this.axisOffset;if(r&&!t(g))this.plotTop=u(this.plotTop,r+this.options.title.margin+b);if(f.display&&!k.floating)if(q==="right"){if(!t(i))this.marginRight=u(this.marginRight,f.legendWidth-m+l+c)}else if(q==="left"){if(!t(h))this.plotLeft=u(this.plotLeft,f.legendWidth+m+l+a)}else if(s==="top"){if(!t(g))this.plotTop=u(this.plotTop,f.legendHeight+o+l+b)}else if(s==="bottom"&&!t(j))this.marginBottom=
+u(this.marginBottom,f.legendHeight-o+l+d);this.extraBottomMargin&&(this.marginBottom+=this.extraBottomMargin);this.extraTopMargin&&(this.plotTop+=this.extraTopMargin);this.hasCartesianSeries&&n(this.axes,function(a){a.getOffset()});t(h)||(this.plotLeft+=e[3]);t(g)||(this.plotTop+=e[0]);t(j)||(this.marginBottom+=e[2]);t(i)||(this.marginRight+=e[1]);this.setChartSize()},initReflow:function(){function a(a){var g=c.width||ib(d,"width"),h=c.height||ib(d,"height"),a=a?a.target:E;if(!b.hasUserSize&&g&&h&&
+(a===E||a===z)){if(g!==b.containerWidth||h!==b.containerHeight)clearTimeout(e),b.reflowTimeout=e=setTimeout(function(){if(b.container)b.setSize(g,h,!1),b.hasUserSize=null},100);b.containerWidth=g;b.containerHeight=h}}var b=this,c=b.options.chart,d=b.renderTo,e;J(E,"resize",a);J(b,"destroy",function(){aa(E,"resize",a)})},setSize:function(a,b,c){var d=this,e,f,g;d.isResizing+=1;g=function(){d&&C(d,"endResize",null,function(){d.isResizing-=1})};Ka(c,d);d.oldChartHeight=d.chartHeight;d.oldChartWidth=
+d.chartWidth;if(t(a))d.chartWidth=e=u(0,s(a)),d.hasUserSize=!!e;if(t(b))d.chartHeight=f=u(0,s(b));M(d.container,{width:e+"px",height:f+"px"});d.setChartSize(!0);d.renderer.setSize(e,f,c);d.maxTicks=null;n(d.axes,function(a){a.isDirty=!0;a.setScale()});n(d.series,function(a){a.isDirty=!0});d.isDirtyLegend=!0;d.isDirtyBox=!0;d.getMargins();d.redraw(c);d.oldChartHeight=null;C(d,"resize");Ca===!1?g():setTimeout(g,Ca&&Ca.duration||500)},setChartSize:function(a){var b=this.inverted,c=this.renderer,d=this.chartWidth,
+e=this.chartHeight,f=this.options.chart,g=f.spacingTop,h=f.spacingRight,i=f.spacingBottom,j=f.spacingLeft,k=this.clipOffset,l,m,o,q;this.plotLeft=l=s(this.plotLeft);this.plotTop=m=s(this.plotTop);this.plotWidth=o=u(0,s(d-l-this.marginRight));this.plotHeight=q=u(0,s(e-m-this.marginBottom));this.plotSizeX=b?q:o;this.plotSizeY=b?o:q;this.plotBorderWidth=b=f.plotBorderWidth||0;this.spacingBox=c.spacingBox={x:j,y:g,width:d-j-h,height:e-g-i};this.plotBox=c.plotBox={x:l,y:m,width:o,height:q};c=ja(u(b,k[3])/
+2);d=ja(u(b,k[0])/2);this.clipBox={x:c,y:d,width:S(this.plotSizeX-u(b,k[1])/2-c),height:S(this.plotSizeY-u(b,k[2])/2-d)};a||n(this.axes,function(a){a.setAxisSize();a.setAxisTranslation()})},resetMargins:function(){var a=this.options.chart,b=a.spacingRight,c=a.spacingBottom,d=a.spacingLeft;this.plotTop=p(this.optionsMarginTop,a.spacingTop);this.marginRight=p(this.optionsMarginRight,b);this.marginBottom=p(this.optionsMarginBottom,c);this.plotLeft=p(this.optionsMarginLeft,d);this.axisOffset=[0,0,0,0];
+this.clipOffset=[0,0,0,0]},drawChartBox:function(){var a=this.options.chart,b=this.renderer,c=this.chartWidth,d=this.chartHeight,e=this.chartBackground,f=this.plotBackground,g=this.plotBorder,h=this.plotBGImage,i=a.borderWidth||0,j=a.backgroundColor,k=a.plotBackgroundColor,l=a.plotBackgroundImage,m=a.plotBorderWidth||0,o,q=this.plotLeft,p=this.plotTop,n=this.plotWidth,s=this.plotHeight,t=this.plotBox,u=this.clipRect,r=this.clipBox;o=i+(a.shadow?8:0);if(i||j)if(e)e.animate(e.crisp(null,null,null,c-
+o,d-o));else{e={fill:j||R};if(i)e.stroke=a.borderColor,e["stroke-width"]=i;this.chartBackground=b.rect(o/2,o/2,c-o,d-o,a.borderRadius,i).attr(e).add().shadow(a.shadow)}if(k)f?f.animate(t):this.plotBackground=b.rect(q,p,n,s,0).attr({fill:k}).add().shadow(a.plotShadow);if(l)h?h.animate(t):this.plotBGImage=b.image(l,q,p,n,s).add();u?u.animate({width:r.width,height:r.height}):this.clipRect=b.clipRect(r);if(m)g?g.animate(g.crisp(null,q,p,n,s)):this.plotBorder=b.rect(q,p,n,s,0,m).attr({stroke:a.plotBorderColor,
+"stroke-width":m,zIndex:1}).add();this.isDirtyBox=!1},propFromSeries:function(){var a=this,b=a.options.chart,c,d=a.options.series,e,f;n(["inverted","angular","polar"],function(g){c=$[b.type||b.defaultSeriesType];f=a[g]||b[g]||c&&c.prototype[g];for(e=d&&d.length;!f&&e--;)(c=$[d[e].type])&&c.prototype[g]&&(f=!0);a[g]=f})},render:function(){var a=this,b=a.axes,c=a.renderer,d=a.options,e=d.labels,f=d.credits,g;a.setTitle();a.legend=new wb(a,d.legend);a.getStacks();n(b,function(a){a.setScale()});a.getMargins();
+a.maxTicks=null;n(b,function(a){a.setTickPositions(!0);a.setMaxTicks()});a.adjustTickAmounts();a.getMargins();a.drawChartBox();a.hasCartesianSeries&&n(b,function(a){a.render()});if(!a.seriesGroup)a.seriesGroup=c.g("series-group").attr({zIndex:3}).add();n(a.series,function(a){a.translate();a.setTooltipPoints();a.render()});e.items&&n(e.items,function(b){var d=r(e.style,b.style),f=A(d.left)+a.plotLeft,g=A(d.top)+a.plotTop+12;delete d.left;delete d.top;c.text(b.html,f,g).attr({zIndex:2}).css(d).add()});
+if(f.enabled&&!a.credits)g=f.href,a.credits=c.text(f.text,0,0).on("click",function(){if(g)location.href=g}).attr({align:f.position.align,zIndex:8}).css(f.style).add().align(f.position);a.hasRendered=!0},destroy:function(){var a=this,b=a.axes,c=a.series,d=a.container,e,f=d&&d.parentNode;C(a,"destroy");Ea[a.index]=v;a.renderTo.removeAttribute("data-highcharts-chart");aa(a);for(e=b.length;e--;)b[e]=b[e].destroy();for(e=c.length;e--;)c[e]=c[e].destroy();n("title,subtitle,chartBackground,plotBackground,plotBGImage,plotBorder,seriesGroup,clipRect,credits,pointer,scroller,rangeSelector,legend,resetZoomButton,tooltip,renderer".split(","),
+function(b){var c=a[b];c&&c.destroy&&(a[b]=c.destroy())});if(d)d.innerHTML="",aa(d),f&&Ta(d);for(e in a)delete a[e]},isReadyToRender:function(){var a=this;return!Y&&E==E.top&&z.readyState!=="complete"||Z&&!E.canvg?(Z?Ub.push(function(){a.firstRender()},a.options.global.canvasToolsURL):z.attachEvent("onreadystatechange",function(){z.detachEvent("onreadystatechange",a.firstRender);z.readyState==="complete"&&a.firstRender()}),!1):!0},firstRender:function(){var a=this,b=a.options,c=a.callback;if(a.isReadyToRender())a.getContainer(),
+C(a,"init"),a.resetMargins(),a.setChartSize(),a.propFromSeries(),a.getAxes(),n(b.series||[],function(b){a.initSeries(b)}),C(a,"beforeRender"),a.pointer=new vb(a,b),a.render(),a.renderer.draw(),c&&c.apply(a,[a]),n(a.callbacks,function(b){b.apply(a,[a])}),a.cloneRenderTo(!0),C(a,"load")}};xb.prototype.callbacks=[];var Pa=function(){};Pa.prototype={init:function(a,b,c){this.series=a;this.applyOptions(b,c);this.pointAttr={};if(a.options.colorByPoint&&(b=a.options.colors||a.chart.options.colors,this.color=
+this.color||b[a.colorCounter++],a.colorCounter===b.length))a.colorCounter=0;a.chart.pointCount++;return this},applyOptions:function(a,b){var c=this.series,d=c.pointValKey,a=Pa.prototype.optionsToObject.call(this,a);r(this,a);this.options=this.options?r(this.options,a):a;if(d)this.y=this[d];if(this.x===v&&c)this.x=b===v?c.autoIncrement():b;return this},optionsToObject:function(a){var b,c=this.series,d=c.pointArrayMap||["y"],e=d.length,f=0,g=0;if(typeof a==="number"||a===null)b={y:a};else if(Ha(a)){b=
+{};if(a.length>e){c=typeof a[0];if(c==="string")b.name=a[0];else if(c==="number")b.x=a[0];f++}for(;g<e;)b[d[g++]]=a[f++]}else if(typeof a==="object"){b=a;if(a.dataLabels)c._hasPointLabels=!0;if(a.marker)c._hasPointMarkers=!0}return b},destroy:function(){var a=this.series.chart,b=a.hoverPoints,c;a.pointCount--;if(b&&(this.setState(),fa(b,this),!b.length))a.hoverPoints=null;if(this===a.hoverPoint)this.onMouseOut();if(this.graphic||this.dataLabel)aa(this),this.destroyElements();this.legendItem&&a.legend.destroyItem(this);
+for(c in this)this[c]=null},destroyElements:function(){for(var a="graphic,dataLabel,dataLabelUpper,group,connector,shadowGroup".split(","),b,c=6;c--;)b=a[c],this[b]&&(this[b]=this[b].destroy())},getLabelConfig:function(){return{x:this.category,y:this.y,key:this.name||this.category,series:this.series,point:this,percentage:this.percentage,total:this.total||this.stackTotal}},select:function(a,b){var c=this,d=c.series,e=d.chart,a=p(a,!c.selected);c.firePointEvent(a?"select":"unselect",{accumulate:b},
+function(){c.selected=c.options.selected=a;d.options.data[na(c,d.data)]=c.options;c.setState(a&&"select");b||n(e.getSelectedPoints(),function(a){if(a.selected&&a!==c)a.selected=a.options.selected=!1,d.options.data[na(a,d.data)]=a.options,a.setState(""),a.firePointEvent("unselect")})})},onMouseOver:function(a){var b=this.series,c=b.chart,d=c.tooltip,e=c.hoverPoint;if(e&&e!==this)e.onMouseOut();this.firePointEvent("mouseOver");d&&(!d.shared||b.noSharedTooltip)&&d.refresh(this,a);this.setState("hover");
+c.hoverPoint=this},onMouseOut:function(){var a=this.series.chart,b=a.hoverPoints;if(!b||na(this,b)===-1)this.firePointEvent("mouseOut"),this.setState(),a.hoverPoint=null},tooltipFormatter:function(a){var b=this.series,c=b.tooltipOptions,d=p(c.valueDecimals,""),e=c.valuePrefix||"",f=c.valueSuffix||"";n(b.pointArrayMap||["y"],function(b){b="{point."+b;if(e||f)a=a.replace(b+"}",e+b+"}"+f);a=a.replace(b+"}",b+":,."+d+"f}")});return Aa(a,{point:this,series:this.series})},update:function(a,b,c){var d=this,
+e=d.series,f=d.graphic,g,h=e.data,i=e.chart,j=e.options,b=p(b,!0);d.firePointEvent("update",{options:a},function(){d.applyOptions(a);U(a)&&(e.getAttribs(),f&&f.attr(d.pointAttr[e.state]));g=na(d,h);e.xData[g]=d.x;e.yData[g]=e.toYData?e.toYData(d):d.y;e.zData[g]=d.z;j.data[g]=d.options;e.isDirty=e.isDirtyData=i.isDirtyBox=!0;j.legendType==="point"&&i.legend.destroyItem(d);b&&i.redraw(c)})},remove:function(a,b){var c=this,d=c.series,e=d.chart,f,g=d.data;Ka(b,e);a=p(a,!0);c.firePointEvent("remove",null,
+function(){f=na(c,g);g.splice(f,1);d.options.data.splice(f,1);d.xData.splice(f,1);d.yData.splice(f,1);d.zData.splice(f,1);c.destroy();d.isDirty=!0;d.isDirtyData=!0;a&&e.redraw()})},firePointEvent:function(a,b,c){var d=this,e=this.series.options;(e.point.events[a]||d.options&&d.options.events&&d.options.events[a])&&this.importEvents();a==="click"&&e.allowPointSelect&&(c=function(a){d.select(null,a.ctrlKey||a.metaKey||a.shiftKey)});C(this,a,b,c)},importEvents:function(){if(!this.hasImportedEvents){var a=
+x(this.series.options.point,this.options).events,b;this.events=a;for(b in a)J(this,b,a[b]);this.hasImportedEvents=!0}},setState:function(a){var b=this.plotX,c=this.plotY,d=this.series,e=d.options.states,f=X[d.type].marker&&d.options.marker,g=f&&!f.enabled,h=f&&f.states[a],i=h&&h.enabled===!1,j=d.stateMarkerGraphic,k=this.marker||{},l=d.chart,m=this.pointAttr,a=a||"";if(!(a===this.state||this.selected&&a!=="select"||e[a]&&e[a].enabled===!1||a&&(i||g&&!h.enabled))){if(this.graphic)e=f&&this.graphic.symbolName&&
+m[a].r,this.graphic.attr(x(m[a],e?{x:b-e,y:c-e,width:2*e,height:2*e}:{}));else{if(a&&h)e=h.radius,k=k.symbol||d.symbol,j&&j.currentSymbol!==k&&(j=j.destroy()),j?j.attr({x:b-e,y:c-e}):(d.stateMarkerGraphic=j=l.renderer.symbol(k,b-e,c-e,2*e,2*e).attr(m[a]).add(d.markerGroup),j.currentSymbol=k);if(j)j[a&&l.isInsidePlot(b,c)?"show":"hide"]()}this.state=a}}};var Q=function(){};Q.prototype={isCartesian:!0,type:"line",pointClass:Pa,sorted:!0,requireSorting:!0,pointAttrToOptions:{stroke:"lineColor","stroke-width":"lineWidth",
+fill:"fillColor",r:"radius"},colorCounter:0,init:function(a,b){var c,d,e=a.series;this.chart=a;this.options=b=this.setOptions(b);this.bindAxes();r(this,{name:b.name,state:"",pointAttr:{},visible:b.visible!==!1,selected:b.selected===!0});if(Z)b.animation=!1;d=b.events;for(c in d)J(this,c,d[c]);if(d&&d.click||b.point&&b.point.events&&b.point.events.click||b.allowPointSelect)a.runTrackerClick=!0;this.getColor();this.getSymbol();this.setData(b.data,!1);if(this.isCartesian)a.hasCartesianSeries=!0;e.push(this);
+this._i=e.length-1;Kb(e,function(a,b){return p(a.options.index,a._i)-p(b.options.index,a._i)});n(e,function(a,b){a.index=b;a.name=a.name||"Series "+(b+1)});c=b.linkedTo;this.linkedSeries=[];if(da(c)&&(c=c===":previous"?e[this.index-1]:a.get(c)))c.linkedSeries.push(this),this.linkedParent=c},bindAxes:function(){var a=this,b=a.options,c=a.chart,d;a.isCartesian&&n(["xAxis","yAxis"],function(e){n(c[e],function(c){d=c.options;if(b[e]===d.index||b[e]!==v&&b[e]===d.id||b[e]===v&&d.index===0)c.series.push(a),
+a[e]=c,c.isDirty=!0});a[e]||ua(18,!0)})},autoIncrement:function(){var a=this.options,b=this.xIncrement,b=p(b,a.pointStart,0);this.pointInterval=p(this.pointInterval,a.pointInterval,1);this.xIncrement=b+this.pointInterval;return b},getSegments:function(){var a=-1,b=[],c,d=this.points,e=d.length;if(e)if(this.options.connectNulls){for(c=e;c--;)d[c].y===null&&d.splice(c,1);d.length&&(b=[d])}else n(d,function(c,g){c.y===null?(g>a+1&&b.push(d.slice(a+1,g)),a=g):g===e-1&&b.push(d.slice(a+1,g+1))});this.segments=
+b},setOptions:function(a){var b=this.chart.options,c=b.plotOptions,d=c[this.type];this.userOptions=a;a=x(d,c.series,a);this.tooltipOptions=x(b.tooltip,a.tooltip);d.marker===null&&delete a.marker;return a},getColor:function(){var a=this.options,b=this.userOptions,c=this.chart.options.colors,d=this.chart.counters,e;e=a.color||X[this.type].color;if(!e&&!a.colorByPoint)t(b._colorIndex)?a=b._colorIndex:(b._colorIndex=d.color,a=d.color++),e=c[a];this.color=e;d.wrapColor(c.length)},getSymbol:function(){var a=
+this.userOptions,b=this.options.marker,c=this.chart,d=c.options.symbols,c=c.counters;this.symbol=b.symbol;if(!this.symbol)t(a._symbolIndex)?a=a._symbolIndex:(a._symbolIndex=c.symbol,a=c.symbol++),this.symbol=d[a];if(/^url/.test(this.symbol))b.radius=0;c.wrapSymbol(d.length)},drawLegendSymbol:function(a){var b=this.options,c=b.marker,d=a.options,e;e=d.symbolWidth;var f=this.chart.renderer,g=this.legendGroup,a=a.baseline-s(f.fontMetrics(d.itemStyle.fontSize).b*0.3);if(b.lineWidth){d={"stroke-width":b.lineWidth};
+if(b.dashStyle)d.dashstyle=b.dashStyle;this.legendLine=f.path(["M",0,a,"L",e,a]).attr(d).add(g)}if(c&&c.enabled)b=c.radius,this.legendSymbol=e=f.symbol(this.symbol,e/2-b,a-b,2*b,2*b).add(g),e.isMarker=!0},addPoint:function(a,b,c,d){var e=this.options,f=this.data,g=this.graph,h=this.area,i=this.chart,j=this.xData,k=this.yData,l=this.zData,m=this.names,o=g&&g.shift||0,q=e.data;Ka(d,i);c&&n([g,h,this.graphNeg,this.areaNeg],function(a){if(a)a.shift=o+1});if(h)h.isArea=!0;b=p(b,!0);d={series:this};this.pointClass.prototype.applyOptions.apply(d,
+[a]);j.push(d.x);k.push(this.toYData?this.toYData(d):d.y);l.push(d.z);if(m)m[d.x]=d.name;q.push(a);e.legendType==="point"&&this.generatePoints();c&&(f[0]&&f[0].remove?f[0].remove(!1):(f.shift(),j.shift(),k.shift(),l.shift(),q.shift()));this.isDirtyData=this.isDirty=!0;b&&(this.getAttribs(),i.redraw())},setData:function(a,b){var c=this.points,d=this.options,e=this.chart,f=null,g=this.xAxis,h=g&&g.categories&&!g.categories.length?[]:null,i;this.xIncrement=null;this.pointRange=g&&g.categories?1:d.pointRange;
+this.colorCounter=0;var j=[],k=[],l=[],m=a?a.length:[];i=p(d.turboThreshold,1E3);var o=this.pointArrayMap,o=o&&o.length,q=!!this.toYData;if(i&&m>i){for(i=0;f===null&&i<m;)f=a[i],i++;if(pa(f)){f=p(d.pointStart,0);d=p(d.pointInterval,1);for(i=0;i<m;i++)j[i]=f,k[i]=a[i],f+=d;this.xIncrement=f}else if(Ha(f))if(o)for(i=0;i<m;i++)d=a[i],j[i]=d[0],k[i]=d.slice(1,o+1);else for(i=0;i<m;i++)d=a[i],j[i]=d[0],k[i]=d[1]}else for(i=0;i<m;i++)if(a[i]!==v&&(d={series:this},this.pointClass.prototype.applyOptions.apply(d,
+[a[i]]),j[i]=d.x,k[i]=q?this.toYData(d):d.y,l[i]=d.z,h&&d.name))h[d.x]=d.name;da(k[0])&&ua(14,!0);this.data=[];this.options.data=a;this.xData=j;this.yData=k;this.zData=l;this.names=h;for(i=c&&c.length||0;i--;)c[i]&&c[i].destroy&&c[i].destroy();if(g)g.minRange=g.userMinRange;this.isDirty=this.isDirtyData=e.isDirtyBox=!0;p(b,!0)&&e.redraw(!1)},remove:function(a,b){var c=this,d=c.chart,a=p(a,!0);if(!c.isRemoving)c.isRemoving=!0,C(c,"remove",null,function(){c.destroy();d.isDirtyLegend=d.isDirtyBox=!0;
+a&&d.redraw(b)});c.isRemoving=!1},processData:function(a){var b=this.xData,c=this.yData,d=b.length,e;e=0;var f,g,h=this.xAxis,i=this.options,j=i.cropThreshold,k=this.isCartesian;if(k&&!this.isDirty&&!h.isDirty&&!this.yAxis.isDirty&&!a)return!1;if(k&&this.sorted&&(!j||d>j||this.forceCrop))if(a=h.min,h=h.max,b[d-1]<a||b[0]>h)b=[],c=[];else if(b[0]<a||b[d-1]>h)e=this.cropData(this.xData,this.yData,a,h),b=e.xData,c=e.yData,e=e.start,f=!0;for(h=b.length-1;h>=0;h--)d=b[h]-b[h-1],d>0&&(g===v||d<g)?g=d:d<
+0&&this.requireSorting&&ua(15);this.cropped=f;this.cropStart=e;this.processedXData=b;this.processedYData=c;if(i.pointRange===null)this.pointRange=g||1;this.closestPointRange=g},cropData:function(a,b,c,d){var e=a.length,f=0,g=e,h;for(h=0;h<e;h++)if(a[h]>=c){f=u(0,h-1);break}for(;h<e;h++)if(a[h]>d){g=h+1;break}return{xData:a.slice(f,g),yData:b.slice(f,g),start:f,end:g}},generatePoints:function(){var a=this.options.data,b=this.data,c,d=this.processedXData,e=this.processedYData,f=this.pointClass,g=d.length,
+h=this.cropStart||0,i,j=this.hasGroupedData,k,l=[],m;if(!b&&!j)b=[],b.length=a.length,b=this.data=b;for(m=0;m<g;m++)i=h+m,j?l[m]=(new f).init(this,[d[m]].concat(ha(e[m]))):(b[i]?k=b[i]:a[i]!==v&&(b[i]=k=(new f).init(this,a[i],d[m])),l[m]=k);if(b&&(g!==(c=b.length)||j))for(m=0;m<c;m++)if(m===h&&!j&&(m+=g),b[m])b[m].destroyElements(),b[m].plotX=v;this.data=b;this.points=l},setStackedPoints:function(){if(this.options.stacking&&!(this.visible!==!0&&this.chart.options.chart.ignoreHiddenSeries!==!1)){var a=
+this.processedXData,b=this.processedYData,c=b.length,d=this.options,e=d.threshold,f=d.stack,d=d.stacking,g=this.stackKey,h="-"+g,i=this.yAxis,j=i.stacks,k=i.oldStacks,l=i.stacksMax,m,o,p,n,s,t;for(s=0;s<c;s++){o=a[s];t=b[s];n=(m=t<e)?h:g;l[n]||(l[n]=t);j[n]||(j[n]={});if(!j[n][o])k[n]&&k[n][o]?(j[n][o]=k[n][o],j[n][o].total=null):j[n][o]=new Mb(i,i.options.stackLabels,m,o,f,d);p=j[n][o];o=p.total;p.addValue(t);p.cacheExtremes(this,[o,o+t]);if(p.total>l[n]&&!m)l[n]=p.total;else if(p.total<l[n]&&m)l[n]=
+p.total}i.oldStacks={}}},getExtremes:function(){var a=this.xAxis,b=this.yAxis,c=this.stackKey,d=this.options,e=d.threshold,f=this.processedXData,g=this.processedYData,h=g.length,i=[],j=0,k=a.min,a=a.max,l,m,o;d.stacking&&(m=b.stacksMax["-"+c]||e,o=b.stacksMax[c]||e);if(!t(m)||!t(o)){for(d=0;d<h;d++)if(l=f[d],c=g[d],e=c!==null&&c!==v&&(!b.isLog||c.length||c>0),l=this.getExtremesFromAll||this.cropped||(f[d+1]||l)>=k&&(f[d-1]||l)<=a,e&&l)if(e=c.length)for(;e--;)c[e]!==null&&(i[j++]=c[e]);else i[j++]=
+c;m=p(m,Ia(i));o=p(o,ta(i))}this.dataMin=m;this.dataMax=o},translate:function(){this.processedXData||this.processData();this.generatePoints();for(var a=this.options,b=a.stacking,c=this.xAxis,d=c.categories,e=this.yAxis,f=this.points,g=f.length,h=!!this.modifyValue,i=a.pointPlacement,j=i==="between"||pa(i),k=a.threshold,a=0;a<g;a++){var l=f[a],m=l.x,o=l.y,n=l.low,u=e.stacks[(o<k?"-":"")+this.stackKey],r;if(e.isLog&&o<=0)l.y=o=null;l.plotX=c.translate(m,0,0,0,1,i);if(b&&this.visible&&u&&u[m])u=u[m],
+r=u.total,u.cum=n=u.cum-o,o=n+o,u.cum===0&&(n=p(k,e.min)),e.isLog&&n<=0&&(n=null),b==="percent"&&(n=r?n*100/r:0,o=r?o*100/r:0),l.percentage=r?l.y*100/r:0,l.total=l.stackTotal=r,l.stackY=o,u.setOffset(this.pointXOffset||0,this.barW||0);l.yBottom=t(n)?e.translate(n,0,1,0,1):null;h&&(o=this.modifyValue(o,l));l.plotY=typeof o==="number"&&o!==Infinity?s(e.translate(o,0,1,0,1)*10)/10:v;l.clientX=j?c.translate(m,0,0,0,1):l.plotX;l.negative=l.y<(k||0);l.category=d&&d[l.x]!==v?d[l.x]:l.x}this.getSegments()},
+setTooltipPoints:function(a){var b=[],c,d,e=(c=this.xAxis)?c.tooltipLen||c.len:this.chart.plotSizeX,f,g,h,i=[];if(this.options.enableMouseTracking!==!1){if(a)this.tooltipPoints=null;n(this.segments||this.points,function(a){b=b.concat(a)});c&&c.reversed&&(b=b.reverse());this.orderTooltipPoints&&this.orderTooltipPoints(b);a=b.length;for(h=0;h<a;h++){f=b[h];g=b[h+1];c=b[h-1]?d+1:0;for(d=b[h+1]?I(u(0,S((f.clientX+(g?g.wrappedClientX||g.clientX:e))/2)),e):e;c>=0&&c<=d;)i[c++]=f}this.tooltipPoints=i}},
+tooltipHeaderFormatter:function(a){var b=this.tooltipOptions,c=b.xDateFormat,d=b.dateTimeLabelFormats,e=this.xAxis,f=e&&e.options.type==="datetime",b=b.headerFormat,e=e&&e.closestPointRange,g;if(f&&!c)if(e)for(g in y){if(y[g]>=e){c=d[g];break}}else c=d.day;f&&c&&pa(a.key)&&(b=b.replace("{point.key}","{point.key:"+c+"}"));return Aa(b,{point:a,series:this})},onMouseOver:function(){var a=this.chart,b=a.hoverSeries;if(b&&b!==this)b.onMouseOut();this.options.events.mouseOver&&C(this,"mouseOver");this.setState("hover");
+a.hoverSeries=this},onMouseOut:function(){var a=this.options,b=this.chart,c=b.tooltip,d=b.hoverPoint;if(d)d.onMouseOut();this&&a.events.mouseOut&&C(this,"mouseOut");c&&!a.stickyTracking&&(!c.shared||this.noSharedTooltip)&&c.hide();this.setState();b.hoverSeries=null},animate:function(a){var b=this,c=b.chart,d=c.renderer,e;e=b.options.animation;var f=c.clipBox,g=c.inverted,h;if(e&&!U(e))e=X[b.type].animation;h="_sharedClip"+e.duration+e.easing;if(a)a=c[h],e=c[h+"m"],a||(c[h]=a=d.clipRect(r(f,{width:0})),
+c[h+"m"]=e=d.clipRect(-99,g?-c.plotLeft:-c.plotTop,99,g?c.chartWidth:c.chartHeight)),b.group.clip(a),b.markerGroup.clip(e),b.sharedClipKey=h;else{if(a=c[h])a.animate({width:c.plotSizeX},e),c[h+"m"].animate({width:c.plotSizeX+99},e);b.animate=null;b.animationTimeout=setTimeout(function(){b.afterAnimate()},e.duration)}},afterAnimate:function(){var a=this.chart,b=this.sharedClipKey,c=this.group;c&&this.options.clip!==!1&&(c.clip(a.clipRect),this.markerGroup.clip());setTimeout(function(){b&&a[b]&&(a[b]=
+a[b].destroy(),a[b+"m"]=a[b+"m"].destroy())},100)},drawPoints:function(){var a,b=this.points,c=this.chart,d,e,f,g,h,i,j,k,l=this.options.marker,m,o=this.markerGroup;if(l.enabled||this._hasPointMarkers)for(f=b.length;f--;)if(g=b[f],d=S(g.plotX),e=g.plotY,k=g.graphic,i=g.marker||{},a=l.enabled&&i.enabled===v||i.enabled,m=c.isInsidePlot(s(d),e,c.inverted),a&&e!==v&&!isNaN(e)&&g.y!==null)if(a=g.pointAttr[g.selected?"select":""],h=a.r,i=p(i.symbol,this.symbol),j=i.indexOf("url")===0,k)k.attr({visibility:m?
+Y?"inherit":"visible":"hidden"}).animate(r({x:d-h,y:e-h},k.symbolName?{width:2*h,height:2*h}:{}));else{if(m&&(h>0||j))g.graphic=c.renderer.symbol(i,d-h,e-h,2*h,2*h).attr(a).add(o)}else if(k)g.graphic=k.destroy()},convertAttribs:function(a,b,c,d){var e=this.pointAttrToOptions,f,g,h={},a=a||{},b=b||{},c=c||{},d=d||{};for(f in e)g=e[f],h[f]=p(a[g],b[f],c[f],d[f]);return h},getAttribs:function(){var a=this,b=a.options,c=X[a.type].marker?b.marker:b,d=c.states,e=d.hover,f,g=a.color,h={stroke:g,fill:g},
+i=a.points||[],j=[],k,l=a.pointAttrToOptions,m=b.negativeColor,o;b.marker?(e.radius=e.radius||c.radius+2,e.lineWidth=e.lineWidth||c.lineWidth+1):e.color=e.color||oa(e.color||g).brighten(e.brightness).get();j[""]=a.convertAttribs(c,h);n(["hover","select"],function(b){j[b]=a.convertAttribs(d[b],j[""])});a.pointAttr=j;for(g=i.length;g--;){h=i[g];if((c=h.options&&h.options.marker||h.options)&&c.enabled===!1)c.radius=0;if(h.negative&&m)h.color=h.fillColor=m;f=b.colorByPoint||h.color;if(h.options)for(o in l)t(c[l[o]])&&
+(f=!0);if(f){c=c||{};k=[];d=c.states||{};f=d.hover=d.hover||{};if(!b.marker)f.color=oa(f.color||h.color).brighten(f.brightness||e.brightness).get();k[""]=a.convertAttribs(r({color:h.color},c),j[""]);k.hover=a.convertAttribs(d.hover,j.hover,k[""]);k.select=a.convertAttribs(d.select,j.select,k[""]);if(h.negative&&b.marker&&m)k[""].fill=k.hover.fill=k.select.fill=a.convertAttribs({fillColor:m}).fill}else k=j;h.pointAttr=k}},update:function(a,b){var c=this.chart,d=this.type,a=x(this.userOptions,{animation:!1,
+index:this.index,pointStart:this.xData[0]},{data:this.options.data},a);this.remove(!1);r(this,$[a.type||d].prototype);this.init(c,a);p(b,!0)&&c.redraw(!1)},destroy:function(){var a=this,b=a.chart,c=/AppleWebKit\/533/.test(Da),d,e,f=a.data||[],g,h,i;C(a,"destroy");aa(a);n(["xAxis","yAxis"],function(b){if(i=a[b])fa(i.series,a),i.isDirty=i.forceRedraw=!0});a.legendItem&&a.chart.legend.destroyItem(a);for(e=f.length;e--;)(g=f[e])&&g.destroy&&g.destroy();a.points=null;clearTimeout(a.animationTimeout);n("area,graph,dataLabelsGroup,group,markerGroup,tracker,graphNeg,areaNeg,posClip,negClip".split(","),
+function(b){a[b]&&(d=c&&b==="group"?"hide":"destroy",a[b][d]())});if(b.hoverSeries===a)b.hoverSeries=null;fa(b.series,a);for(h in a)delete a[h]},drawDataLabels:function(){var a=this,b=a.options.dataLabels,c=a.points,d,e,f,g;if(b.enabled||a._hasPointLabels)a.dlProcessOptions&&a.dlProcessOptions(b),g=a.plotGroup("dataLabelsGroup","data-labels",a.visible?"visible":"hidden",b.zIndex||6),e=b,n(c,function(c){var i,j=c.dataLabel,k,l,m=c.connector,o=!0;d=c.options&&c.options.dataLabels;i=e.enabled||d&&d.enabled;
+if(j&&!i)c.dataLabel=j.destroy();else if(i){b=x(e,d);i=b.rotation;k=c.getLabelConfig();f=b.format?Aa(b.format,k):b.formatter.call(k,b);b.style.color=p(b.color,b.style.color,a.color,"black");if(j)if(t(f))j.attr({text:f}),o=!1;else{if(c.dataLabel=j=j.destroy(),m)c.connector=m.destroy()}else if(t(f)){j={fill:b.backgroundColor,stroke:b.borderColor,"stroke-width":b.borderWidth,r:b.borderRadius||0,rotation:i,padding:b.padding,zIndex:1};for(l in j)j[l]===v&&delete j[l];j=c.dataLabel=a.chart.renderer[i?"text":
+"label"](f,0,-999,null,null,null,b.useHTML).attr(j).css(b.style).add(g).shadow(b.shadow)}j&&a.alignDataLabel(c,j,b,null,o)}})},alignDataLabel:function(a,b,c,d,e){var f=this.chart,g=f.inverted,h=p(a.plotX,-999),i=p(a.plotY,-999),a=b.getBBox(),d=r({x:g?f.plotWidth-i:h,y:s(g?f.plotHeight-h:i),width:0,height:0},d);r(c,{width:a.width,height:a.height});c.rotation?(d={align:c.align,x:d.x+c.x+d.width/2,y:d.y+c.y+d.height/2},b[e?"attr":"animate"](d)):(b.align(c,null,d),d=b.alignAttr);b.attr({visibility:c.crop===
+!1||f.isInsidePlot(d.x,d.y)&&f.isInsidePlot(d.x+a.width,d.y+a.height)?f.renderer.isSVG?"inherit":"visible":"hidden"})},getSegmentPath:function(a){var b=this,c=[],d=b.options.step;n(a,function(e,f){var g=e.plotX,h=e.plotY,i;b.getPointSpline?c.push.apply(c,b.getPointSpline(a,e,f)):(c.push(f?"L":"M"),d&&f&&(i=a[f-1],d==="right"?c.push(i.plotX,h):d==="center"?c.push((i.plotX+g)/2,i.plotY,(i.plotX+g)/2,h):c.push(g,i.plotY)),c.push(e.plotX,e.plotY))});return c},getGraphPath:function(){var a=this,b=[],c,
+d=[];n(a.segments,function(e){c=a.getSegmentPath(e);e.length>1?b=b.concat(c):d.push(e[0])});a.singlePoints=d;return a.graphPath=b},drawGraph:function(){var a=this,b=this.options,c=[["graph",b.lineColor||this.color]],d=b.lineWidth,e=b.dashStyle,f=this.getGraphPath(),g=b.negativeColor;g&&c.push(["graphNeg",g]);n(c,function(c,g){var j=c[0],k=a[j];if(k)Wa(k),k.animate({d:f});else if(d&&f.length){k={stroke:c[1],"stroke-width":d,zIndex:1};if(e)k.dashstyle=e;a[j]=a.chart.renderer.path(f).attr(k).add(a.group).shadow(!g&&
+b.shadow)}})},clipNeg:function(){var a=this.options,b=this.chart,c=b.renderer,d=a.negativeColor||a.negativeFillColor,e,f=this.graph,g=this.area,h=this.posClip,i=this.negClip;e=b.chartWidth;var j=b.chartHeight,k=u(e,j),l=this.yAxis;if(d&&(f||g)){d=s(l.toPixels(a.threshold||0,!0));a={x:0,y:0,width:k,height:d};k={x:0,y:d,width:k,height:k};if(b.inverted)a.height=k.y=b.plotWidth-d,c.isVML&&(a={x:b.plotWidth-d-b.plotLeft,y:0,width:e,height:j},k={x:d+b.plotLeft-e,y:0,width:b.plotLeft+d,height:e});l.reversed?
+(b=k,e=a):(b=a,e=k);h?(h.animate(b),i.animate(e)):(this.posClip=h=c.clipRect(b),this.negClip=i=c.clipRect(e),f&&this.graphNeg&&(f.clip(h),this.graphNeg.clip(i)),g&&(g.clip(h),this.areaNeg.clip(i)))}},invertGroups:function(){function a(){var a={width:b.yAxis.len,height:b.xAxis.len};n(["group","markerGroup"],function(c){b[c]&&b[c].attr(a).invert()})}var b=this,c=b.chart;if(b.xAxis)J(c,"resize",a),J(b,"destroy",function(){aa(c,"resize",a)}),a(),b.invertGroups=a},plotGroup:function(a,b,c,d,e){var f=this[a],
+g=!f;g&&(this[a]=f=this.chart.renderer.g(b).attr({visibility:c,zIndex:d||0.1}).add(e));f[g?"attr":"animate"](this.getPlotBox());return f},getPlotBox:function(){return{translateX:this.xAxis?this.xAxis.left:this.chart.plotLeft,translateY:this.yAxis?this.yAxis.top:this.chart.plotTop,scaleX:1,scaleY:1}},render:function(){var a=this.chart,b,c=this.options,d=c.animation&&!!this.animate&&a.renderer.isSVG,e=this.visible?"visible":"hidden",f=c.zIndex,g=this.hasRendered,h=a.seriesGroup;b=this.plotGroup("group",
+"series",e,f,h);this.markerGroup=this.plotGroup("markerGroup","markers",e,f,h);d&&this.animate(!0);this.getAttribs();b.inverted=this.isCartesian?a.inverted:!1;this.drawGraph&&(this.drawGraph(),this.clipNeg());this.drawDataLabels();this.drawPoints();this.options.enableMouseTracking!==!1&&this.drawTracker();a.inverted&&this.invertGroups();c.clip!==!1&&!this.sharedClipKey&&!g&&b.clip(a.clipRect);d?this.animate():g||this.afterAnimate();this.isDirty=this.isDirtyData=!1;this.hasRendered=!0},redraw:function(){var a=
+this.chart,b=this.isDirtyData,c=this.group,d=this.xAxis,e=this.yAxis;c&&(a.inverted&&c.attr({width:a.plotWidth,height:a.plotHeight}),c.animate({translateX:p(d&&d.left,a.plotLeft),translateY:p(e&&e.top,a.plotTop)}));this.translate();this.setTooltipPoints(!0);this.render();b&&C(this,"updatedData")},setState:function(a){var b=this.options,c=this.graph,d=this.graphNeg,e=b.states,b=b.lineWidth,a=a||"";if(this.state!==a)this.state=a,e[a]&&e[a].enabled===!1||(a&&(b=e[a].lineWidth||b+1),c&&!c.dashstyle&&
+(a={"stroke-width":b},c.attr(a),d&&d.attr(a)))},setVisible:function(a,b){var c=this,d=c.chart,e=c.legendItem,f,g=d.options.chart.ignoreHiddenSeries,h=c.visible;f=(c.visible=a=c.userOptions.visible=a===v?!h:a)?"show":"hide";n(["group","dataLabelsGroup","markerGroup","tracker"],function(a){if(c[a])c[a][f]()});if(d.hoverSeries===c)c.onMouseOut();e&&d.legend.colorizeItem(c,a);c.isDirty=!0;c.options.stacking&&n(d.series,function(a){if(a.options.stacking&&a.visible)a.isDirty=!0});n(c.linkedSeries,function(b){b.setVisible(a,
+!1)});if(g)d.isDirtyBox=!0;b!==!1&&d.redraw();C(c,f)},show:function(){this.setVisible(!0)},hide:function(){this.setVisible(!1)},select:function(a){this.selected=a=a===v?!this.selected:a;if(this.checkbox)this.checkbox.checked=a;C(this,a?"select":"unselect")},drawTracker:function(){var a=this,b=a.options,c=b.trackByArea,d=[].concat(c?a.areaPath:a.graphPath),e=d.length,f=a.chart,g=f.pointer,h=f.renderer,i=f.options.tooltip.snap,j=a.tracker,k=b.cursor,k=k&&{cursor:k},l=a.singlePoints,m,o=function(){if(f.hoverSeries!==
+a)a.onMouseOver()};if(e&&!c)for(m=e+1;m--;)d[m]==="M"&&d.splice(m+1,0,d[m+1]-i,d[m+2],"L"),(m&&d[m]==="M"||m===e)&&d.splice(m,0,"L",d[m-2]+i,d[m-1]);for(m=0;m<l.length;m++)e=l[m],d.push("M",e.plotX-i,e.plotY,"L",e.plotX+i,e.plotY);if(j)j.attr({d:d});else if(a.tracker=j=h.path(d).attr({"class":"highcharts-tracker","stroke-linejoin":"round",visibility:a.visible?"visible":"hidden",stroke:Qb,fill:c?Qb:R,"stroke-width":b.lineWidth+(c?0:2*i),zIndex:2}).addClass("highcharts-tracker").on("mouseover",o).on("mouseout",
+function(a){g.onTrackerMouseOut(a)}).css(k).add(a.markerGroup),hb)j.on("touchstart",o)}};L=ga(Q);$.line=L;X.area=x(W,{threshold:0});L=ga(Q,{type:"area",getSegments:function(){var a=[],b=[],c=[],d=this.xAxis,e=this.yAxis,f=e.stacks[this.stackKey],g={},h,i,j=this.points,k,l,m;if(this.options.stacking&&!this.cropped){for(l=0;l<j.length;l++)g[j[l].x]=j[l];for(m in f)c.push(+m);c.sort(function(a,b){return a-b});n(c,function(a){g[a]?b.push(g[a]):(h=d.translate(a),k=f[a].percent?f[a].total?f[a].cum*100/
+f[a].total:0:f[a].cum,i=e.toPixels(k,!0),b.push({y:null,plotX:h,clientX:h,plotY:i,yBottom:i,onMouseOver:xa}))});b.length&&a.push(b)}else Q.prototype.getSegments.call(this),a=this.segments;this.segments=a},getSegmentPath:function(a){var b=Q.prototype.getSegmentPath.call(this,a),c=[].concat(b),d,e=this.options;b.length===3&&c.push("L",b[1],b[2]);if(e.stacking&&!this.closedStacks)for(d=a.length-1;d>=0;d--)d<a.length-1&&e.step&&c.push(a[d+1].plotX,a[d].yBottom),c.push(a[d].plotX,a[d].yBottom);else this.closeSegment(c,
+a);this.areaPath=this.areaPath.concat(c);return b},closeSegment:function(a,b){var c=this.yAxis.getThreshold(this.options.threshold);a.push("L",b[b.length-1].plotX,c,"L",b[0].plotX,c)},drawGraph:function(){this.areaPath=[];Q.prototype.drawGraph.apply(this);var a=this,b=this.areaPath,c=this.options,d=c.negativeColor,e=c.negativeFillColor,f=[["area",this.color,c.fillColor]];(d||e)&&f.push(["areaNeg",d,e]);n(f,function(d){var e=d[0],f=a[e];f?f.animate({d:b}):a[e]=a.chart.renderer.path(b).attr({fill:p(d[2],
+oa(d[1]).setOpacity(p(c.fillOpacity,0.75)).get()),zIndex:0}).add(a.group)})},drawLegendSymbol:function(a,b){b.legendSymbol=this.chart.renderer.rect(0,a.baseline-11,a.options.symbolWidth,12,2).attr({zIndex:3}).add(b.legendGroup)}});$.area=L;X.spline=x(W);K=ga(Q,{type:"spline",getPointSpline:function(a,b,c){var d=b.plotX,e=b.plotY,f=a[c-1],g=a[c+1],h,i,j,k;if(f&&g){a=f.plotY;j=g.plotX;var g=g.plotY,l;h=(1.5*d+f.plotX)/2.5;i=(1.5*e+a)/2.5;j=(1.5*d+j)/2.5;k=(1.5*e+g)/2.5;l=(k-i)*(j-d)/(j-h)+e-k;i+=l;
+k+=l;i>a&&i>e?(i=u(a,e),k=2*e-i):i<a&&i<e&&(i=I(a,e),k=2*e-i);k>g&&k>e?(k=u(g,e),i=2*e-k):k<g&&k<e&&(k=I(g,e),i=2*e-k);b.rightContX=j;b.rightContY=k}c?(b=["C",f.rightContX||f.plotX,f.rightContY||f.plotY,h||d,i||e,d,e],f.rightContX=f.rightContY=null):b=["M",d,e];return b}});$.spline=K;X.areaspline=x(X.area);la=L.prototype;K=ga(K,{type:"areaspline",closedStacks:!0,getSegmentPath:la.getSegmentPath,closeSegment:la.closeSegment,drawGraph:la.drawGraph,drawLegendSymbol:la.drawLegendSymbol});$.areaspline=
+K;X.column=x(W,{borderColor:"#FFFFFF",borderWidth:1,borderRadius:0,groupPadding:0.2,marker:null,pointPadding:0.1,minPointLength:0,cropThreshold:50,pointRange:null,states:{hover:{brightness:0.1,shadow:!1},select:{color:"#C0C0C0",borderColor:"#000000",shadow:!1}},dataLabels:{align:null,verticalAlign:null,y:null},stickyTracking:!1,threshold:0});K=ga(Q,{type:"column",tooltipOutsidePlot:!0,pointAttrToOptions:{stroke:"borderColor","stroke-width":"borderWidth",fill:"color",r:"borderRadius"},trackerGroups:["group",
+"dataLabelsGroup"],init:function(){Q.prototype.init.apply(this,arguments);var a=this,b=a.chart;b.hasRendered&&n(b.series,function(b){if(b.type===a.type)b.isDirty=!0})},getColumnMetrics:function(){var a=this,b=a.options,c=a.xAxis,d=a.yAxis,e=c.reversed,f,g={},h,i=0;b.grouping===!1?i=1:n(a.chart.series,function(b){var c=b.options,e=b.yAxis;if(b.type===a.type&&b.visible&&d.len===e.len&&d.pos===e.pos)c.stacking?(f=b.stackKey,g[f]===v&&(g[f]=i++),h=g[f]):c.grouping!==!1&&(h=i++),b.columnIndex=h});var c=
+I(P(c.transA)*(c.ordinalSlope||b.pointRange||c.closestPointRange||1),c.len),j=c*b.groupPadding,k=(c-2*j)/i,l=b.pointWidth,b=t(l)?(k-l)/2:k*b.pointPadding,l=p(l,k-2*b);return a.columnMetrics={width:l,offset:b+(j+((e?i-(a.columnIndex||0):a.columnIndex)||0)*k-c/2)*(e?-1:1)}},translate:function(){var a=this.chart,b=this.options,c=b.borderWidth,d=this.yAxis,e=this.translatedThreshold=d.getThreshold(b.threshold),f=p(b.minPointLength,5),b=this.getColumnMetrics(),g=b.width,h=this.barW=ja(u(g,1+2*c)),i=this.pointXOffset=
+b.offset;Q.prototype.translate.apply(this);n(this.points,function(b){var k=I(u(-999,b.plotY),d.len+999),l=p(b.yBottom,e),m=b.plotX+i,o=ja(I(k,l)),k=ja(u(k,l)-o);P(k)<f&&f&&(k=f,o=s(P(o-e)>f?l-f:e-(d.translate(b.y,0,1,0,1)<=e?f:0)));b.barX=m;b.pointWidth=g;b.shapeType="rect";b.shapeArgs=b=a.renderer.Element.prototype.crisp.call(0,c,m,o,h,k);c%2&&(b.y-=1,b.height+=1)})},getSymbol:xa,drawLegendSymbol:L.prototype.drawLegendSymbol,drawGraph:xa,drawPoints:function(){var a=this,b=a.options,c=a.chart.renderer,
+d;n(a.points,function(e){var f=e.plotY,g=e.graphic;if(f!==v&&!isNaN(f)&&e.y!==null)d=e.shapeArgs,g?(Wa(g),g.animate(x(d))):e.graphic=c[e.shapeType](d).attr(e.pointAttr[e.selected?"select":""]).add(a.group).shadow(b.shadow,null,b.stacking&&!b.borderRadius);else if(g)e.graphic=g.destroy()})},drawTracker:function(){var a=this,b=a.chart,c=b.pointer,d=a.options.cursor,e=d&&{cursor:d},f=function(c){var d=c.target,e;if(b.hoverSeries!==a)a.onMouseOver();for(;d&&!e;)e=d.point,d=d.parentNode;if(e!==v&&e!==
+b.hoverPoint)e.onMouseOver(c)};n(a.points,function(a){if(a.graphic)a.graphic.element.point=a;if(a.dataLabel)a.dataLabel.element.point=a});a._hasTracking?a._hasTracking=!0:n(a.trackerGroups,function(b){if(a[b]&&(a[b].addClass("highcharts-tracker").on("mouseover",f).on("mouseout",function(a){c.onTrackerMouseOut(a)}).css(e),hb))a[b].on("touchstart",f)})},alignDataLabel:function(a,b,c,d,e){var f=this.chart,g=f.inverted,h=a.dlBox||a.shapeArgs,i=a.below||a.plotY>p(this.translatedThreshold,f.plotSizeY),
+j=p(c.inside,!!this.options.stacking);if(h&&(d=x(h),g&&(d={x:f.plotWidth-d.y-d.height,y:f.plotHeight-d.x-d.width,width:d.height,height:d.width}),!j))g?(d.x+=i?0:d.width,d.width=0):(d.y+=i?d.height:0,d.height=0);c.align=p(c.align,!g||j?"center":i?"right":"left");c.verticalAlign=p(c.verticalAlign,g||j?"middle":i?"top":"bottom");Q.prototype.alignDataLabel.call(this,a,b,c,d,e)},animate:function(a){var b=this.yAxis,c=this.options,d=this.chart.inverted,e={};if(Y)a?(e.scaleY=0.001,a=I(b.pos+b.len,u(b.pos,
+b.toPixels(c.threshold))),d?e.translateX=a-b.len:e.translateY=a,this.group.attr(e)):(e.scaleY=1,e[d?"translateX":"translateY"]=b.pos,this.group.animate(e,this.options.animation),this.animate=null)},remove:function(){var a=this,b=a.chart;b.hasRendered&&n(b.series,function(b){if(b.type===a.type)b.isDirty=!0});Q.prototype.remove.apply(a,arguments)}});$.column=K;X.bar=x(X.column);la=ga(K,{type:"bar",inverted:!0});$.bar=la;X.scatter=x(W,{lineWidth:0,tooltip:{headerFormat:'<span style="font-size: 10px; color:{series.color}">{series.name}</span><br/>',
+pointFormat:"x: <b>{point.x}</b><br/>y: <b>{point.y}</b><br/>",followPointer:!0},stickyTracking:!1});la=ga(Q,{type:"scatter",sorted:!1,requireSorting:!1,noSharedTooltip:!0,trackerGroups:["markerGroup"],drawTracker:K.prototype.drawTracker,setTooltipPoints:xa});$.scatter=la;X.pie=x(W,{borderColor:"#FFFFFF",borderWidth:1,center:[null,null],clip:!1,colorByPoint:!0,dataLabels:{distance:30,enabled:!0,formatter:function(){return this.point.name}},ignoreHiddenPoint:!0,legendType:"point",marker:null,size:null,
+showInLegend:!1,slicedOffset:10,states:{hover:{brightness:0.1,shadow:!1}},stickyTracking:!1,tooltip:{followPointer:!0}});W={type:"pie",isCartesian:!1,pointClass:ga(Pa,{init:function(){Pa.prototype.init.apply(this,arguments);var a=this,b;if(a.y<0)a.y=null;r(a,{visible:a.visible!==!1,name:p(a.name,"Slice")});b=function(b){a.slice(b.type==="select")};J(a,"select",b);J(a,"unselect",b);return a},setVisible:function(a){var b=this,c=b.series,d=c.chart,e;b.visible=b.options.visible=a=a===v?!b.visible:a;c.options.data[na(b,
+c.data)]=b.options;e=a?"show":"hide";n(["graphic","dataLabel","connector","shadowGroup"],function(a){if(b[a])b[a][e]()});b.legendItem&&d.legend.colorizeItem(b,a);if(!c.isDirty&&c.options.ignoreHiddenPoint)c.isDirty=!0,d.redraw()},slice:function(a,b,c){var d=this.series;Ka(c,d.chart);p(b,!0);this.sliced=this.options.sliced=a=t(a)?a:!this.sliced;d.options.data[na(this,d.data)]=this.options;a=a?this.slicedTranslation:{translateX:0,translateY:0};this.graphic.animate(a);this.shadowGroup&&this.shadowGroup.animate(a)}}),
+requireSorting:!1,noSharedTooltip:!0,trackerGroups:["group","dataLabelsGroup"],pointAttrToOptions:{stroke:"borderColor","stroke-width":"borderWidth",fill:"color"},getColor:xa,animate:function(a){var b=this,c=b.points,d=b.startAngleRad;if(!a)n(c,function(a){var c=a.graphic,a=a.shapeArgs;c&&(c.attr({r:b.center[3]/2,start:d,end:d}),c.animate({r:a.r,start:a.start,end:a.end},b.options.animation))}),b.animate=null},setData:function(a,b){Q.prototype.setData.call(this,a,!1);this.processData();this.generatePoints();
+p(b,!0)&&this.chart.redraw()},generatePoints:function(){var a,b=0,c,d,e,f=this.options.ignoreHiddenPoint;Q.prototype.generatePoints.call(this);c=this.points;d=c.length;for(a=0;a<d;a++)e=c[a],b+=f&&!e.visible?0:e.y;this.total=b;for(a=0;a<d;a++)e=c[a],e.percentage=e.y/b*100,e.total=b},getCenter:function(){var a=this.options,b=this.chart,c=2*(a.slicedOffset||0),d,e=b.plotWidth-2*c,f=b.plotHeight-2*c,b=a.center,a=[p(b[0],"50%"),p(b[1],"50%"),a.size||"100%",a.innerSize||0],g=I(e,f),h;return Na(a,function(a,
+b){h=/%$/.test(a);d=b<2||b===2&&h;return(h?[e,f,g,g][b]*A(a)/100:a)+(d?c:0)})},translate:function(a){this.generatePoints();var b=0,c=this.options,d=c.slicedOffset,e=d+c.borderWidth,f,g,h,i=this.startAngleRad=Ma/180*((c.startAngle||0)%360-90),j=this.points,k=2*Ma,l=c.dataLabels.distance,c=c.ignoreHiddenPoint,m,o=j.length,n;if(!a)this.center=a=this.getCenter();this.getX=function(b,c){h=N.asin((b-a[1])/(a[2]/2+l));return a[0]+(c?-1:1)*V(h)*(a[2]/2+l)};for(m=0;m<o;m++){n=j[m];f=s((i+b*k)*1E3)/1E3;if(!c||
+n.visible)b+=n.percentage/100;g=s((i+b*k)*1E3)/1E3;n.shapeType="arc";n.shapeArgs={x:a[0],y:a[1],r:a[2]/2,innerR:a[3]/2,start:f,end:g};h=(g+f)/2;h>0.75*k&&(h-=2*Ma);n.slicedTranslation={translateX:s(V(h)*d),translateY:s(ba(h)*d)};f=V(h)*a[2]/2;g=ba(h)*a[2]/2;n.tooltipPos=[a[0]+f*0.7,a[1]+g*0.7];n.half=h<k/4?0:1;n.angle=h;e=I(e,l/2);n.labelPos=[a[0]+f+V(h)*l,a[1]+g+ba(h)*l,a[0]+f+V(h)*e,a[1]+g+ba(h)*e,a[0]+f,a[1]+g,l<0?"center":n.half?"right":"left",h]}this.setTooltipPoints()},drawGraph:null,drawPoints:function(){var a=
+this,b=a.chart.renderer,c,d,e=a.options.shadow,f,g;if(e&&!a.shadowGroup)a.shadowGroup=b.g("shadow").add(a.group);n(a.points,function(h){d=h.graphic;g=h.shapeArgs;f=h.shadowGroup;if(e&&!f)f=h.shadowGroup=b.g("shadow").add(a.shadowGroup);c=h.sliced?h.slicedTranslation:{translateX:0,translateY:0};f&&f.attr(c);d?d.animate(r(g,c)):h.graphic=d=b.arc(g).setRadialReference(a.center).attr(h.pointAttr[h.selected?"select":""]).attr({"stroke-linejoin":"round"}).attr(c).add(a.group).shadow(e,f);h.visible===!1&&
+h.setVisible(!1)})},drawDataLabels:function(){var a=this,b=a.data,c,d=a.chart,e=a.options.dataLabels,f=p(e.connectorPadding,10),g=p(e.connectorWidth,1),h=d.plotWidth,d=d.plotHeight,i,j,k=p(e.softConnector,!0),l=e.distance,m=a.center,o=m[2]/2,q=m[1],t=l>0,r,w,v,x,A=[[],[]],z,y,G,H,B,C=[0,0,0,0],I=function(a,b){return b.y-a.y},M=function(a,b){a.sort(function(a,c){return a.angle!==void 0&&(c.angle-a.angle)*b})};if(a.visible&&(e.enabled||a._hasPointLabels)){Q.prototype.drawDataLabels.apply(a);n(b,function(a){a.dataLabel&&
+A[a.half].push(a)});for(H=0;!x&&b[H];)x=b[H]&&b[H].dataLabel&&(b[H].dataLabel.getBBox().height||21),H++;for(H=2;H--;){var b=[],L=[],J=A[H],K=J.length,E;M(J,H-0.5);if(l>0){for(B=q-o-l;B<=q+o+l;B+=x)b.push(B);w=b.length;if(K>w){c=[].concat(J);c.sort(I);for(B=K;B--;)c[B].rank=B;for(B=K;B--;)J[B].rank>=w&&J.splice(B,1);K=J.length}for(B=0;B<K;B++){c=J[B];v=c.labelPos;c=9999;var O,N;for(N=0;N<w;N++)O=P(b[N]-v[1]),O<c&&(c=O,E=N);if(E<B&&b[B]!==null)E=B;else for(w<K-B+E&&b[B]!==null&&(E=w-K+B);b[E]===null;)E++;
+L.push({i:E,y:b[E]});b[E]=null}L.sort(I)}for(B=0;B<K;B++){c=J[B];v=c.labelPos;r=c.dataLabel;G=c.visible===!1?"hidden":"visible";c=v[1];if(l>0){if(w=L.pop(),E=w.i,y=w.y,c>y&&b[E+1]!==null||c<y&&b[E-1]!==null)y=c}else y=c;z=e.justify?m[0]+(H?-1:1)*(o+l):a.getX(E===0||E===b.length-1?c:y,H);r._attr={visibility:G,align:v[6]};r._pos={x:z+e.x+({left:f,right:-f}[v[6]]||0),y:y+e.y-10};r.connX=z;r.connY=y;if(this.options.size===null)w=r.width,z-w<f?C[3]=u(s(w-z+f),C[3]):z+w>h-f&&(C[1]=u(s(z+w-h+f),C[1])),y-
+x/2<0?C[0]=u(s(-y+x/2),C[0]):y+x/2>d&&(C[2]=u(s(y+x/2-d),C[2]))}}if(ta(C)===0||this.verifyDataLabelOverflow(C))this.placeDataLabels(),t&&g&&n(this.points,function(b){i=b.connector;v=b.labelPos;if((r=b.dataLabel)&&r._pos)G=r._attr.visibility,z=r.connX,y=r.connY,j=k?["M",z+(v[6]==="left"?5:-5),y,"C",z,y,2*v[2]-v[4],2*v[3]-v[5],v[2],v[3],"L",v[4],v[5]]:["M",z+(v[6]==="left"?5:-5),y,"L",v[2],v[3],"L",v[4],v[5]],i?(i.animate({d:j}),i.attr("visibility",G)):b.connector=i=a.chart.renderer.path(j).attr({"stroke-width":g,
+stroke:e.connectorColor||b.color||"#606060",visibility:G}).add(a.group);else if(i)b.connector=i.destroy()})}},verifyDataLabelOverflow:function(a){var b=this.center,c=this.options,d=c.center,e=c=c.minSize||80,f;d[0]!==null?e=u(b[2]-u(a[1],a[3]),c):(e=u(b[2]-a[1]-a[3],c),b[0]+=(a[3]-a[1])/2);d[1]!==null?e=u(I(e,b[2]-u(a[0],a[2])),c):(e=u(I(e,b[2]-a[0]-a[2]),c),b[1]+=(a[0]-a[2])/2);e<b[2]?(b[2]=e,this.translate(b),n(this.points,function(a){if(a.dataLabel)a.dataLabel._pos=null}),this.drawDataLabels()):
+f=!0;return f},placeDataLabels:function(){n(this.points,function(a){var a=a.dataLabel,b;if(a)(b=a._pos)?(a.attr(a._attr),a[a.moved?"animate":"attr"](b),a.moved=!0):a&&a.attr({y:-999})})},alignDataLabel:xa,drawTracker:K.prototype.drawTracker,drawLegendSymbol:L.prototype.drawLegendSymbol,getSymbol:xa};W=ga(Q,W);$.pie=W;r(Highcharts,{Axis:db,Chart:xb,Color:oa,Legend:wb,Pointer:vb,Point:Pa,Tick:La,Tooltip:ub,Renderer:Va,Series:Q,SVGElement:va,SVGRenderer:Fa,arrayMin:Ia,arrayMax:ta,charts:Ea,dateFormat:Xa,
+format:Aa,pathAnim:zb,getOptions:function(){return O},hasBidiBug:Vb,isTouchDevice:Ob,numberFormat:ya,seriesTypes:$,setOptions:function(a){O=x(O,a);Lb();return O},addEvent:J,removeEvent:aa,createElement:T,discardElement:Ta,css:M,each:n,extend:r,map:Na,merge:x,pick:p,splat:ha,extendClass:ga,pInt:A,wrap:Bb,svg:Y,canvas:Z,vml:!Y&&!Z,product:"Highcharts",version:"3.0.4"})})();
diff --git a/97suifang-front/assets/plugins/thickbox/images/loadingAnimation.gif b/97suifang-front/assets/plugins/thickbox/images/loadingAnimation.gif
new file mode 100644
index 0000000..92c5c30
--- /dev/null
+++ b/97suifang-front/assets/plugins/thickbox/images/loadingAnimation.gif
Binary files differ
diff --git a/97suifang-front/assets/plugins/thickbox/thickbox.css b/97suifang-front/assets/plugins/thickbox/thickbox.css
new file mode 100644
index 0000000..9fe82e3
--- /dev/null
+++ b/97suifang-front/assets/plugins/thickbox/thickbox.css
@@ -0,0 +1,135 @@
+/* ----------------------------------------------------------------------------------------------------------------*/
+/* ---------->>> global settings needed for thickbox <<<-----------------------------------------------------------*/
+/* ----------------------------------------------------------------------------------------------------------------*/
+*{padding: 0; margin: 0;}
+
+html, body {
+min-height: 100%;
+height: auto !important;
+height: 100%;
+}
+
+/* ----------------------------------------------------------------------------------------------------------------*/
+/* ---------->>> thickbox specific link and font settings <<<------------------------------------------------------*/
+/* ----------------------------------------------------------------------------------------------------------------*/
+#TB_window {
+ font: 12px Arial, Helvetica, sans-serif;
+ color: #333333;
+}
+
+#TB_secondLine {
+ font: 10px Arial, Helvetica, sans-serif;
+ color:#666666;
+}
+
+#TB_window a:link {color: #666666;}
+#TB_window a:visited {color: #666666;}
+#TB_window a:hover {color: #000;}
+#TB_window a:active {color: #666666;}
+#TB_window a:focus{color: #666666;}
+
+/* ----------------------------------------------------------------------------------------------------------------*/
+/* ---------->>> thickbox settings <<<-----------------------------------------------------------------------------*/
+/* ----------------------------------------------------------------------------------------------------------------*/
+#TB_overlay {
+ position: absolute;
+ z-index:100;
+ width: 100%;
+ height: 100%;
+ top: 0;
+ left: 0;
+ min-height:100%;
+ background-color:#000;
+ filter:alpha(opacity=60);
+ -moz-opacity: 0.6;
+ opacity: 0.6;
+}
+
+#TB_window {
+ position: absolute;
+ /*background: #ffffff;*/
+ z-index: 102;
+ color:#000000;
+ display:none;
+ /*border: 4px solid #525252;*/
+ text-align:left;
+}
+
+#TB_window img {
+ display:block;
+ margin: 15px 0 0 15px;
+ border-right: 1px solid #ccc;
+ border-bottom: 1px solid #ccc;
+ border-top: 1px solid #666;
+ border-left: 1px solid #666;
+}
+
+#TB_caption{
+ height:25px;
+ padding:7px 30px 10px 25px;
+ float:left;
+}
+
+#TB_closeWindow{
+ height:25px;
+ padding:11px 25px 10px 0;
+ float:right;
+}
+
+#TB_closeAjaxWindow{
+ padding:5px 10px 7px 0;
+ margin-bottom:1px;
+ text-align:right;
+ float:right;
+}
+
+#TB_ajaxWindowTitle{
+ float:left;
+ padding:7px 0 5px 10px;
+ margin-bottom:1px;
+}
+
+#TB_title{
+ background-color:#e8e8e8;
+ height:27px;
+}
+
+#TB_ajaxContent{
+ clear:both;
+ padding:2px 15px 15px 15px;
+ overflow:auto;
+ text-align:left;
+ line-height:1.4em;
+}
+
+#TB_ajaxContent p{
+ padding:5px 0px 5px 0px;
+}
+
+#TB_load{
+ position: absolute;
+ display:none;
+ height:100px;
+ width:100px;
+ z-index:101;
+}
+
+#TB_HideSelect{
+ z-index:99;
+ position:absolute;
+ top: 0;
+ left: 0;
+ width:100%;
+ height:100%;
+ background-color:#fff;
+ border:none;
+ filter:alpha(opacity=0);
+ -moz-opacity: 0;
+ opacity: 0;
+}
+
+#TB_iframeContent{
+ border:none;
+ clear:both;
+}
+
diff --git a/97suifang-front/assets/plugins/thickbox/thickbox.js b/97suifang-front/assets/plugins/thickbox/thickbox.js
new file mode 100644
index 0000000..c11bf76
--- /dev/null
+++ b/97suifang-front/assets/plugins/thickbox/thickbox.js
@@ -0,0 +1,286 @@
+/*
+ * Thickbox 2.0 - One Box To Rule Them All.
+ * By Cody Lindley (http://www.codylindley.com)
+ * Copyright (c) 2006 cody lindley
+ * Licensed under the MIT License:
+ * http://www.opensource.org/licenses/mit-license.php
+ * Thickbox is built on top of the very light weight jQuery library.
+ */
+
+//on page load call TB_init
+$(document).ready(TB_init);
+
+//add thickbox to href elements that have a class of .thickbox
+function TB_init(){
+ $("a.thickbox").live("click", function(){
+ if(this.href == 'javascript:void(0)'){
+ return false;
+ }
+ var t = this.title || this.name || null;
+ var g = this.rel || false;
+ TB_show(t,this.href,g);
+ this.blur();
+ return false;
+ });
+}
+
+function TB_show(caption, url, imageGroup) {//function called when the user clicks on a thickbox link
+ try {
+ if (document.getElementById("TB_HideSelect") == null) {
+ $("body").append("<iframe frameborder='no' marginheight='0' marginwidth='0' border='0' id='TB_HideSelect'></iframe><div id='TB_overlay'></div><div id='TB_window'></div>");
+ $("#TB_overlay").click(TB_remove);
+ }
+
+ if(caption==null){caption=""};
+
+ $(window).scroll(TB_position);
+
+ TB_overlaySize();
+
+ $("body").append("<div id='TB_load' class='loadingAnimation'></div>");
+ TB_load_position();
+
+ var urlString = /\.jpg|\.jpeg|\.png|\.gif|\.html|\.htm|\.php|\.cfm|\.asp|\.aspx|\.jsp|\.jst|\.rb|\.txt|\.bmp/g;
+ var urlType = url.toLowerCase().match(urlString);
+
+ if(urlType == '.jpg' || urlType == '.jpeg' || urlType == '.png' || urlType == '.gif' || urlType == '.bmp'){//code to show images
+
+ TB_PrevCaption = "";
+ TB_PrevURL = "";
+ TB_PrevHTML = "";
+ TB_NextCaption = "";
+ TB_NextURL = "";
+ TB_NextHTML = "";
+ TB_imageCount = "";
+ TB_FoundURL = false;
+ if(imageGroup){
+ TB_TempArray = $("a[@rel="+imageGroup+"]").get();
+ for (TB_Counter = 0; ((TB_Counter < TB_TempArray.length) && (TB_NextHTML == "")); TB_Counter++) {
+ var urlTypeTemp = TB_TempArray[TB_Counter].href.toLowerCase().match(urlString);
+ if (!(TB_TempArray[TB_Counter].href == url)) {
+ if (TB_FoundURL) {
+ TB_NextCaption = TB_TempArray[TB_Counter].title;
+ TB_NextURL = TB_TempArray[TB_Counter].href;
+ TB_NextHTML = "<span id='TB_next'>&nbsp;&nbsp;<a href='#'>Next &gt;</a></span>";
+ } else {
+ TB_PrevCaption = TB_TempArray[TB_Counter].title;
+ TB_PrevURL = TB_TempArray[TB_Counter].href;
+ TB_PrevHTML = "<span id='TB_prev'>&nbsp;&nbsp;<a href='#'>&lt; Prev</a></span>";
+ }
+ } else {
+ TB_FoundURL = true;
+ TB_imageCount = "Image " + (TB_Counter + 1) +" of "+ (TB_TempArray.length);
+ }
+ }
+ }
+
+ imgPreloader = new Image();
+ imgPreloader.onload = function(){
+
+ imgPreloader.onload = null;
+
+ // Resizing large images - orginal by Christian Montoya edited by me.
+ var pagesize = TB_getPageSize();
+ var x = pagesize[0] - 150;
+ var y = pagesize[1] - 150;
+ var imageWidth = imgPreloader.width;
+ var imageHeight = imgPreloader.height;
+ if (imageWidth > x) {
+ imageHeight = imageHeight * (x / imageWidth);
+ imageWidth = x;
+ if (imageHeight > y) {
+ imageWidth = imageWidth * (y / imageHeight);
+ imageHeight = y;
+ }
+ } else if (imageHeight > y) {
+ imageWidth = imageWidth * (y / imageHeight);
+ imageHeight = y;
+ if (imageWidth > x) {
+ imageHeight = imageHeight * (x / imageWidth);
+ imageWidth = x;
+ }
+ }
+ // End Resizing
+
+ TB_WIDTH = imageWidth + 30;
+ TB_HEIGHT = imageHeight + 60;
+ $("#TB_window").append("<a href='' id='TB_ImageOff' title='Close'><img id='TB_Image' src='"+url+"' width='"+imageWidth+"' height='"+imageHeight+"' alt='"+caption+"'/></a>" + "<div id='TB_caption'>"+caption+"<div id='TB_secondLine'>" + TB_imageCount + TB_PrevHTML + TB_NextHTML + "</div></div><div id='TB_closeWindow'><a href='#' id='TB_closeWindowButton' title='Close or Escape Button'>close</a></div>");
+
+ $("#TB_closeWindowButton").click(TB_remove);
+
+ if (!(TB_PrevHTML == "")) {
+ function goPrev(){
+ if($(document).unclick(goPrev)){$(document).unclick(goPrev)};
+ $("#TB_window").remove();
+ $("body").append("<div id='TB_window'></div>");
+ $(document).unkeyup();
+ TB_show(TB_PrevCaption, TB_PrevURL, imageGroup);
+ return false;
+ }
+
+ $("#TB_prev").click(goPrev);
+
+ $(document).keyup( function(e){ var key = e.keyCode; if(key == 37){goPrev()} });
+ }
+
+
+
+ if (!(TB_NextHTML == "")) {
+ function goNext(){
+ $("#TB_window").remove();
+ $("body").append("<div id='TB_window'></div>");
+ $(document).unkeyup();
+ TB_show(TB_NextCaption, TB_NextURL, imageGroup);
+ return false;
+ }
+
+ $("#TB_next").click(goNext);
+
+ $(document).keyup( function(e){ var key = e.keyCode; if(key == 39){goNext()} });
+ }
+
+ TB_position();
+ $("#TB_load").remove();
+ $("#TB_ImageOff").click(TB_remove);
+ $("#TB_window").css({display:"block"}); //for safari using css instead of show
+ }
+
+ imgPreloader.src = url;
+ }
+
+ if(urlType=='.htm'||urlType=='.html'||urlType=='.php'||urlType=='.asp'||urlType=='.aspx'||urlType=='.jsp'||urlType=='.jst'||urlType=='.rb'||urlType=='.txt'||urlType=='.cfm' || (url.indexOf('TB_inline') != -1) || (url.indexOf('TB_iframe') != -1) ){//code to show html pages
+
+ var queryString = url.replace(/^[^\?]+\??/,'');
+ var params = TB_parseQuery( queryString );
+
+// TB_WIDTH = (params['width']*1) + 30;
+// TB_HEIGHT = (params['height']*1) + 40;
+// ajaxContentW = TB_WIDTH - 30;
+// ajaxContentH = TB_HEIGHT - 45;
+ TB_WIDTH = (params['width']*1);
+ TB_HEIGHT = (params['height']*1);
+ ajaxContentW = TB_WIDTH;
+ ajaxContentH = TB_HEIGHT;
+
+ if(url.indexOf('no_title') != -1){
+ $("#TB_window").append("<div id='TB_title'><div id='TB_ajaxWindowTitle'>"+caption+"</div><div id='TB_closeAjaxWindow'><a href='#' id='TB_closeWindowButton'>close</a></div></div>");
+ TB_HEIGHT += 27; //title height
+ }
+ if(url.indexOf('TB_iframe') != -1){
+ if(url.indexOf('transfer_params') == -1){
+ urlNoQuery = url.substr(0,TB_strpos(url, "?"));
+ }else{
+ urlNoQuery = url;
+ }
+ $("#TB_window").append("<iframe frameborder='no' marginheight='0' marginwidth='0' border='0' src='"+urlNoQuery+"' id='TB_iframeContent' style='width:"+(ajaxContentW)+"px;height:"+(ajaxContentH)+"px;'></iframe>");
+ }else{
+ $("#TB_window").append("<div id='TB_ajaxContent' style='width:"+ajaxContentW+"px;height:"+ajaxContentH+"px;'></div>");
+ }
+
+ $("#TB_closeWindowButton").click(TB_remove);
+
+ if(url.indexOf('TB_inline') != -1){
+ $("#TB_ajaxContent").html($('#' + params['inlineId']).html());
+ TB_position();
+ $("#TB_load").remove();
+ $("#TB_window").css({display:"block"});
+ }else if(url.indexOf('TB_iframe') != -1){
+ TB_position();
+ $("#TB_load").remove();
+ $("#TB_window").css({display:"block"});
+ }else{
+ $("#TB_ajaxContent").load(url, function(){
+ TB_position();
+ $("#TB_load").remove();
+ $("#TB_window").css({display:"block"});
+ });
+ }
+
+ }
+
+ $(window).resize(TB_position);
+
+ } catch(e) {
+ alert( e );
+ }
+}
+
+//helper functions below
+
+function TB_remove() {
+ $("#TB_window").fadeOut("fast",function(){$('#TB_window,#TB_overlay,#TB_HideSelect').remove();});
+ $("#TB_load").remove();
+ //$(document).unkeyup();
+ return false;
+}
+
+function TB_position() {
+ var pagesize = TB_getPageSize();
+ var arrayPageScroll = TB_getPageScrollTop();
+ $("#TB_window").css({height:TB_HEIGHT+"px",width:TB_WIDTH+"px",left: ((pagesize[0] - TB_WIDTH)/2)+"px", top: (arrayPageScroll[1] + ((pagesize[1]-TB_HEIGHT)/2))+"px" });
+ TB_overlaySize();
+}
+
+function TB_overlaySize(){
+ if (window.innerHeight && window.scrollMaxY) {
+ yScroll = window.innerHeight + window.scrollMaxY;
+ } else if (document.body.scrollHeight > document.body.offsetHeight){ // all but Explorer Mac
+ yScroll = document.body.scrollHeight;
+ } else { // Explorer Mac...would also work in Explorer 6 Strict, Mozilla and Safari
+ yScroll = document.body.offsetHeight;
+ }
+ $("#TB_overlay").css("height",yScroll +"px");
+}
+
+function TB_load_position() {
+ var pagesize = TB_getPageSize();
+ var arrayPageScroll = TB_getPageScrollTop();
+
+ $("#TB_load")
+ .css({left: ((pagesize[0] - 100)/2)+"px", top: (arrayPageScroll[1] + ((pagesize[1]-100)/2))+"px" })
+ .css({display:"block"});
+}
+
+function TB_parseQuery ( query ) {
+ var Params = new Object ();
+ if ( ! query ) return Params; // return empty object
+ var Pairs = query.split(/[;&]/);
+ for ( var i = 0; i < Pairs.length; i++ ) {
+ var KeyVal = Pairs[i].split('=');
+ if ( ! KeyVal || KeyVal.length != 2 ) continue;
+ var key = unescape( KeyVal[0] );
+ var val = unescape( KeyVal[1] );
+ val = val.replace(/\+/g, ' ');
+ Params[key] = val;
+ }
+ return Params;
+}
+
+function TB_getPageScrollTop(){
+ var yScrolltop;
+ if (self.pageYOffset) {
+ yScrolltop = self.pageYOffset;
+ } else if (document.documentElement && document.documentElement.scrollTop){ // Explorer 6 Strict
+ yScrolltop = document.documentElement.scrollTop;
+ } else if (document.body) {// all other Explorers
+ yScrolltop = document.body.scrollTop;
+ }
+ arrayPageScroll = new Array('',yScrolltop)
+ return arrayPageScroll;
+}
+
+function TB_getPageSize(){
+ var de = document.documentElement;
+ var w = window.innerWidth || self.innerWidth || (de&&de.clientWidth) || document.body.clientWidth;
+ var h = window.innerHeight || self.innerHeight || (de&&de.clientHeight) || document.body.clientHeight;
+
+ arrayPageSize = new Array(w,h)
+ return arrayPageSize;
+}
+
+function TB_strpos(str, ch) {
+for (var i = 0; i < str.length; i++)
+if (str.substring(i, i+1) == ch) return i;
+return -1;
+}
+