From bbd9e65134864026bbe053daa90dd75212157fec Mon Sep 17 00:00:00 2001 From: Johannes Eckstein Date: Wed, 5 Aug 2020 16:53:07 +0200 Subject: [PATCH 1/2] revised code --- build/doctrees/environment.pickle | Bin 17387 -> 0 bytes build/doctrees/index.doctree | Bin 251048 -> 0 bytes build/html/.buildinfo | 4 - build/html/_sources/index.txt | 44 - build/html/_static/ajax-loader.gif | Bin 673 -> 0 bytes build/html/_static/alabaster.css | 591 -- build/html/_static/basic.css | 599 -- build/html/_static/comment-bright.png | Bin 3500 -> 0 bytes build/html/_static/comment-close.png | Bin 3578 -> 0 bytes build/html/_static/comment.png | Bin 3445 -> 0 bytes build/html/_static/doctools.js | 263 - build/html/_static/down-pressed.png | Bin 347 -> 0 bytes build/html/_static/down.png | Bin 347 -> 0 bytes build/html/_static/file.png | Bin 358 -> 0 bytes build/html/_static/jquery-1.11.1.js | 10308 -------------------- build/html/_static/jquery.js | 4 - build/html/_static/minus.png | Bin 173 -> 0 bytes build/html/_static/plus.png | Bin 173 -> 0 bytes build/html/_static/pygments.css | 63 - build/html/_static/searchtools.js | 622 -- build/html/_static/underscore-1.3.1.js | 999 -- build/html/_static/underscore.js | 31 - build/html/_static/up-pressed.png | Bin 345 -> 0 bytes build/html/_static/up.png | Bin 345 -> 0 bytes build/html/_static/websupport.js | 808 -- build/html/genindex.html | 550 -- build/html/index.html | 1186 --- build/html/objects.inv | 11 - build/html/py-modindex.html | 167 - build/html/search.html | 105 - build/html/searchindex.js | 1 - exa_8a_simple_car_steering_controller.py | 28 +- mubogui/__init__.py | 0 mubogui/mubostat.py | 174 - muboreport/__init__.py | 0 mubosym/mubosym_core.py | 71 +- mubosym/two_body_force_model_interface.py | 42 +- {source => sphinx_doc}/conf.py | 0 {source => sphinx_doc}/index.rst | 0 test_all.py | 49 +- 40 files changed, 96 insertions(+), 16624 deletions(-) delete mode 100644 build/doctrees/environment.pickle delete mode 100644 build/doctrees/index.doctree delete mode 100644 build/html/.buildinfo delete mode 100644 build/html/_sources/index.txt delete mode 100644 build/html/_static/ajax-loader.gif delete mode 100644 build/html/_static/alabaster.css delete mode 100644 build/html/_static/basic.css delete mode 100644 build/html/_static/comment-bright.png delete mode 100644 build/html/_static/comment-close.png delete mode 100644 build/html/_static/comment.png delete mode 100644 build/html/_static/doctools.js delete mode 100644 build/html/_static/down-pressed.png delete mode 100644 build/html/_static/down.png delete mode 100644 build/html/_static/file.png delete mode 100644 build/html/_static/jquery-1.11.1.js delete mode 100644 build/html/_static/jquery.js delete mode 100644 build/html/_static/minus.png delete mode 100644 build/html/_static/plus.png delete mode 100644 build/html/_static/pygments.css delete mode 100644 build/html/_static/searchtools.js delete mode 100644 build/html/_static/underscore-1.3.1.js delete mode 100644 build/html/_static/underscore.js delete mode 100644 build/html/_static/up-pressed.png delete mode 100644 build/html/_static/up.png delete mode 100644 build/html/_static/websupport.js delete mode 100644 build/html/genindex.html delete mode 100644 build/html/index.html delete mode 100644 build/html/objects.inv delete mode 100644 build/html/py-modindex.html delete mode 100644 build/html/search.html delete mode 100644 build/html/searchindex.js delete mode 100644 mubogui/__init__.py delete mode 100644 mubogui/mubostat.py delete mode 100644 muboreport/__init__.py rename {source => sphinx_doc}/conf.py (100%) rename {source => sphinx_doc}/index.rst (100%) diff --git a/build/doctrees/environment.pickle b/build/doctrees/environment.pickle deleted file mode 100644 index d46af727c6c975ffc6846791868d4215c088ac46..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17387 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 Y5pK)0*G)Ln7UG-H&>|P(8Wzd@4~*ONxBvhE diff --git a/build/doctrees/index.doctree b/build/doctrees/index.doctree deleted file mode 100644 index 1ec949cc38605e43b0ba897f68389d685549d0a4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 251048 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

nxW{m(8r5l{I^C!m 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 diff --git a/build/html/.buildinfo b/build/html/.buildinfo deleted file mode 100644 index a5ea845..0000000 --- a/build/html/.buildinfo +++ /dev/null @@ -1,4 +0,0 @@ -# Sphinx build info version 1 -# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done. -config: 4544016437f9e819c228145ca7fcd39f -tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/build/html/_sources/index.txt b/build/html/_sources/index.txt deleted file mode 100644 index a6d70b9..0000000 --- a/build/html/_sources/index.txt +++ /dev/null @@ -1,44 +0,0 @@ -.. mubosym documentation master file, created by - sphinx-quickstart on Thu Jun 4 18:46:39 2015. - You can adapt this file completely to your liking, but it should at least - contain the root `toctree` directive. - -Welcome to mubosym's documentation! -=================================== - -Contents: - -.. toctree:: - :maxdepth: 2 - -.. automodule:: mubosym_core - :members: - -.. automodule:: mubojoints - :members: - -.. automodule:: dbconnect - :members: - -.. automodule:: interp1d_interface - :members: - -.. automodule:: symTools - :members: - -.. automodule:: one_body_force_model_interface - :members: - -.. automodule:: simple_tire_model_interface - :members: - -.. automodule:: vpython_3d - :members: - -Indices and tables -================== - -* :ref:`genindex` -* :ref:`modindex` -* :ref:`search` - diff --git a/build/html/_static/ajax-loader.gif b/build/html/_static/ajax-loader.gif deleted file mode 100644 index 61faf8cab23993bd3e1560bff0668bd628642330..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 673 zcmZ?wbhEHb6krfw_{6~Q|Nno%(3)e{?)x>&1u}A`t?OF7Z|1gRivOgXi&7IyQd1Pl zGfOfQ60;I3a`F>X^fL3(@);C=vM_KlFfb_o=k{|A33hf2a5d61U}gjg=>Rd%XaNQW zW@Cw{|b%Y*pl8F?4B9 zlo4Fz*0kZGJabY|>}Okf0}CCg{u4`zEPY^pV?j2@h+|igy0+Kz6p;@SpM4s6)XEMg z#3Y4GX>Hjlml5ftdH$4x0JGdn8~MX(U~_^d!Hi)=HU{V%g+mi8#UGbE-*ao8f#h+S z2a0-5+vc7MU$e-NhmBjLIC1v|)9+Im8x1yacJ7{^tLX(ZhYi^rpmXm0`@ku9b53aN zEXH@Y3JaztblgpxbJt{AtE1ad1Ca>{v$rwwvK(>{m~Gf_=-Ro7Fk{#;i~+{{>QtvI yb2P8Zac~?~=sRA>$6{!(^3;ZP0TPFR(G_-UDU(8Jl0?(IXu$~#4A!880|o%~Al1tN diff --git a/build/html/_static/alabaster.css b/build/html/_static/alabaster.css deleted file mode 100644 index 0857c04..0000000 --- a/build/html/_static/alabaster.css +++ /dev/null @@ -1,591 +0,0 @@ - - - - - - - - - - - - - - - - - - - - -@import url("basic.css"); - -/* -- page layout ----------------------------------------------------------- */ - -body { - font-family: 'goudy old style', 'minion pro', 'bell mt', Georgia, 'Hiragino Mincho Pro', serif; - font-size: 17px; - background-color: white; - color: #000; - margin: 0; - padding: 0; -} - -div.document { - width: 940px; - margin: 30px auto 0 auto; -} - -div.documentwrapper { - float: left; - width: 100%; -} - -div.bodywrapper { - margin: 0 0 0 220px; -} - -div.sphinxsidebar { - width: 220px; -} - -hr { - border: 1px solid #B1B4B6; -} - -div.body { - background-color: #ffffff; - color: #3E4349; - padding: 0 30px 0 30px; -} - -div.footer { - width: 940px; - margin: 20px auto 30px auto; - font-size: 14px; - color: #888; - text-align: right; -} - -div.footer a { - color: #888; -} - -div.related { - display: none; -} - -div.sphinxsidebar a { - color: #444; - text-decoration: none; - border-bottom: 1px dotted #999; -} - -div.sphinxsidebar a:hover { - border-bottom: 1px solid #999; -} - -div.sphinxsidebar { - font-size: 14px; - line-height: 1.5; -} - -div.sphinxsidebarwrapper { - padding: 18px 10px; -} - -div.sphinxsidebarwrapper p.logo { - padding: 0; - margin: -10px 0 0 0px; - text-align: center; -} - -div.sphinxsidebarwrapper h1.logo { - margin-top: -10px; - text-align: center; - margin-bottom: 5px; - text-align: left; -} - -div.sphinxsidebarwrapper h1.logo-name { - margin-top: 0px; -} - -div.sphinxsidebarwrapper p.blurb { - margin-top: 0; - font-style: normal; -} - -div.sphinxsidebar h3, -div.sphinxsidebar h4 { - font-family: 'Garamond', 'Georgia', serif; - color: #444; - font-size: 24px; - font-weight: normal; - margin: 0 0 5px 0; - padding: 0; -} - -div.sphinxsidebar h4 { - font-size: 20px; -} - -div.sphinxsidebar h3 a { - color: #444; -} - -div.sphinxsidebar p.logo a, -div.sphinxsidebar h3 a, -div.sphinxsidebar p.logo a:hover, -div.sphinxsidebar h3 a:hover { - border: none; -} - -div.sphinxsidebar p { - color: #555; - margin: 10px 0; -} - -div.sphinxsidebar ul { - margin: 10px 0; - padding: 0; - color: #000; -} - -div.sphinxsidebar ul li.toctree-l1 > a { - font-size: 120%; -} - -div.sphinxsidebar ul li.toctree-l2 > a { - font-size: 110%; -} - -div.sphinxsidebar input { - border: 1px solid #CCC; - font-family: 'goudy old style', 'minion pro', 'bell mt', Georgia, 'Hiragino Mincho Pro', serif; - font-size: 1em; -} - -div.sphinxsidebar hr { - border: none; - height: 1px; - color: #999; - background: #999; - - text-align: left; - margin-left: 0; - width: 50%; -} - -/* -- body styles ----------------------------------------------------------- */ - -a { - color: #004B6B; - text-decoration: underline; -} - -a:hover { - color: #6D4100; - text-decoration: underline; -} - -div.body h1, -div.body h2, -div.body h3, -div.body h4, -div.body h5, -div.body h6 { - font-family: 'Garamond', 'Georgia', serif; - font-weight: normal; - margin: 30px 0px 10px 0px; - padding: 0; -} - -div.body h1 { margin-top: 0; padding-top: 0; font-size: 240%; } -div.body h2 { font-size: 180%; } -div.body h3 { font-size: 150%; } -div.body h4 { font-size: 130%; } -div.body h5 { font-size: 100%; } -div.body h6 { font-size: 100%; } - -a.headerlink { - color: #DDD; - padding: 0 4px; - text-decoration: none; -} - -a.headerlink:hover { - color: #444; - background: #EAEAEA; -} - -div.body p, div.body dd, div.body li { - line-height: 1.4em; -} - -div.admonition { - margin: 20px 0px; - padding: 10px 30px; - background-color: #FCC; - border: 1px solid #FAA; -} - -div.admonition tt.xref, div.admonition a tt { - border-bottom: 1px solid #fafafa; -} - -dd div.admonition { - margin-left: -60px; - padding-left: 60px; -} - -div.admonition p.admonition-title { - font-family: 'Garamond', 'Georgia', serif; - font-weight: normal; - font-size: 24px; - margin: 0 0 10px 0; - padding: 0; - line-height: 1; -} - -div.admonition p.last { - margin-bottom: 0; -} - -div.highlight { - background-color: white; -} - -dt:target, .highlight { - background: #FAF3E8; -} - -div.note { - background-color: #EEE; - border: 1px solid #CCC; -} - -div.seealso { - background-color: #EEE; - border: 1px solid #CCC; -} - -div.topic { - background-color: #eee; -} - -p.admonition-title { - display: inline; -} - -p.admonition-title:after { - content: ":"; -} - -pre, tt, code { - font-family: 'Consolas', 'Menlo', 'Deja Vu Sans Mono', 'Bitstream Vera Sans Mono', monospace; - font-size: 0.9em; -} - -img.screenshot { -} - -tt.descname, tt.descclassname, code.descname, code.descclassname { - font-size: 0.95em; -} - -tt.descname, code.descname { - padding-right: 0.08em; -} - -img.screenshot { - -moz-box-shadow: 2px 2px 4px #eee; - -webkit-box-shadow: 2px 2px 4px #eee; - box-shadow: 2px 2px 4px #eee; -} - -table.docutils { - border: 1px solid #888; - -moz-box-shadow: 2px 2px 4px #eee; - -webkit-box-shadow: 2px 2px 4px #eee; - box-shadow: 2px 2px 4px #eee; -} - -table.docutils td, table.docutils th { - border: 1px solid #888; - padding: 0.25em 0.7em; -} - -table.field-list, table.footnote { - border: none; - -moz-box-shadow: none; - -webkit-box-shadow: none; - box-shadow: none; -} - -table.footnote { - margin: 15px 0; - width: 100%; - border: 1px solid #EEE; - background: #FDFDFD; - font-size: 0.9em; -} - -table.footnote + table.footnote { - margin-top: -15px; - border-top: none; -} - -table.field-list th { - padding: 0 0.8em 0 0; -} - -table.field-list td { - padding: 0; -} - -table.footnote td.label { - width: 0px; - padding: 0.3em 0 0.3em 0.5em; -} - -table.footnote td { - padding: 0.3em 0.5em; -} - -dl { - margin: 0; - padding: 0; -} - -dl dd { - margin-left: 30px; -} - -blockquote { - margin: 0 0 0 30px; - padding: 0; -} - -ul, ol { - margin: 10px 0 10px 30px; - padding: 0; -} - -pre { - background: #EEE; - padding: 7px 30px; - margin: 15px 0px; - line-height: 1.3em; -} - -dl pre, blockquote pre, li pre { - margin-left: -60px; - padding-left: 60px; -} - -dl dl pre { - margin-left: -90px; - padding-left: 90px; -} - -tt, code { - background-color: #ecf0f3; - color: #222; - /* padding: 1px 2px; */ -} - -tt.xref, code.xref, a tt { - background-color: #FBFBFB; - border-bottom: 1px solid white; -} - -a.reference { - text-decoration: none; - border-bottom: 1px dotted #004B6B; -} - -a.reference:hover { - border-bottom: 1px solid #6D4100; -} - -a.footnote-reference { - text-decoration: none; - font-size: 0.7em; - vertical-align: top; - border-bottom: 1px dotted #004B6B; -} - -a.footnote-reference:hover { - border-bottom: 1px solid #6D4100; -} - -a:hover tt, a:hover code { - background: #EEE; -} - - -@media screen and (max-width: 870px) { - - div.sphinxsidebar { - display: none; - } - - div.document { - width: 100%; - - } - - div.documentwrapper { - margin-left: 0; - margin-top: 0; - margin-right: 0; - margin-bottom: 0; - } - - div.bodywrapper { - margin-top: 0; - margin-right: 0; - margin-bottom: 0; - margin-left: 0; - } - - ul { - margin-left: 0; - } - - .document { - width: auto; - } - - .footer { - width: auto; - } - - .bodywrapper { - margin: 0; - } - - .footer { - width: auto; - } - - .github { - display: none; - } - - - -} - - - -@media screen and (max-width: 875px) { - - body { - margin: 0; - padding: 20px 30px; - } - - div.documentwrapper { - float: none; - background: white; - } - - div.sphinxsidebar { - display: block; - float: none; - width: 102.5%; - margin: 50px -30px -20px -30px; - padding: 10px 20px; - background: #333; - color: #FFF; - } - - div.sphinxsidebar h3, div.sphinxsidebar h4, div.sphinxsidebar p, - div.sphinxsidebar h3 a { - color: white; - } - - div.sphinxsidebar a { - color: #AAA; - } - - div.sphinxsidebar p.logo { - display: none; - } - - div.document { - width: 100%; - margin: 0; - } - - div.related { - display: block; - margin: 0; - padding: 10px 0 20px 0; - } - - div.related ul, - div.related ul li { - margin: 0; - padding: 0; - } - - div.footer { - display: none; - } - - div.bodywrapper { - margin: 0; - } - - div.body { - min-height: 0; - padding: 0; - } - - .rtd_doc_footer { - display: none; - } - - .document { - width: auto; - } - - .footer { - width: auto; - } - - .footer { - width: auto; - } - - .github { - display: none; - } -} - - -/* misc. */ - -.revsys-inline { - display: none!important; -} - -/* Make nested-list/multi-paragraph items look better in Releases changelog - * pages. Without this, docutils' magical list fuckery causes inconsistent - * formatting between different release sub-lists. - */ -div#changelog > div.section > ul > li > p:only-child { - margin-bottom: 0; -} - -/* Hide fugly table cell borders in ..bibliography:: directive output */ -table.docutils.citation, table.docutils.citation td, table.docutils.citation th { - border: none; - /* Below needed in some edge cases; if not applied, bottom shadows appear */ - -moz-box-shadow: none; - -webkit-box-shadow: none; - box-shadow: none; -} \ No newline at end of file diff --git a/build/html/_static/basic.css b/build/html/_static/basic.css deleted file mode 100644 index 9fa77d8..0000000 --- a/build/html/_static/basic.css +++ /dev/null @@ -1,599 +0,0 @@ -/* - * basic.css - * ~~~~~~~~~ - * - * Sphinx stylesheet -- basic theme. - * - * :copyright: Copyright 2007-2015 by the Sphinx team, see AUTHORS. - * :license: BSD, see LICENSE for details. - * - */ - -/* -- main layout ----------------------------------------------------------- */ - -div.clearer { - clear: both; -} - -/* -- relbar ---------------------------------------------------------------- */ - -div.related { - width: 100%; - font-size: 90%; -} - -div.related h3 { - display: none; -} - -div.related ul { - margin: 0; - padding: 0 0 0 10px; - list-style: none; -} - -div.related li { - display: inline; -} - -div.related li.right { - float: right; - margin-right: 5px; -} - -/* -- sidebar --------------------------------------------------------------- */ - -div.sphinxsidebarwrapper { - padding: 10px 5px 0 10px; -} - -div.sphinxsidebar { - float: left; - width: 230px; - margin-left: -100%; - font-size: 90%; -} - -div.sphinxsidebar ul { - list-style: none; -} - -div.sphinxsidebar ul ul, -div.sphinxsidebar ul.want-points { - margin-left: 20px; - list-style: square; -} - -div.sphinxsidebar ul ul { - margin-top: 0; - margin-bottom: 0; -} - -div.sphinxsidebar form { - margin-top: 10px; -} - -div.sphinxsidebar input { - border: 1px solid #98dbcc; - font-family: sans-serif; - font-size: 1em; -} - -div.sphinxsidebar #searchbox input[type="text"] { - width: 170px; -} - -div.sphinxsidebar #searchbox input[type="submit"] { - width: 30px; -} - -img { - border: 0; - max-width: 100%; -} - -/* -- search page ----------------------------------------------------------- */ - -ul.search { - margin: 10px 0 0 20px; - padding: 0; -} - -ul.search li { - padding: 5px 0 5px 20px; - background-image: url(file.png); - background-repeat: no-repeat; - background-position: 0 7px; -} - -ul.search li a { - font-weight: bold; -} - -ul.search li div.context { - color: #888; - margin: 2px 0 0 30px; - text-align: left; -} - -ul.keywordmatches li.goodmatch a { - font-weight: bold; -} - -/* -- index page ------------------------------------------------------------ */ - -table.contentstable { - width: 90%; -} - -table.contentstable p.biglink { - line-height: 150%; -} - -a.biglink { - font-size: 1.3em; -} - -span.linkdescr { - font-style: italic; - padding-top: 5px; - font-size: 90%; -} - -/* -- general index --------------------------------------------------------- */ - -table.indextable { - width: 100%; -} - -table.indextable td { - text-align: left; - vertical-align: top; -} - -table.indextable dl, table.indextable dd { - margin-top: 0; - margin-bottom: 0; -} - -table.indextable tr.pcap { - height: 10px; -} - -table.indextable tr.cap { - margin-top: 10px; - background-color: #f2f2f2; -} - -img.toggler { - margin-right: 3px; - margin-top: 3px; - cursor: pointer; -} - -div.modindex-jumpbox { - border-top: 1px solid #ddd; - border-bottom: 1px solid #ddd; - margin: 1em 0 1em 0; - padding: 0.4em; -} - -div.genindex-jumpbox { - border-top: 1px solid #ddd; - border-bottom: 1px solid #ddd; - margin: 1em 0 1em 0; - padding: 0.4em; -} - -/* -- general body styles --------------------------------------------------- */ - -a.headerlink { - visibility: hidden; -} - -h1:hover > a.headerlink, -h2:hover > a.headerlink, -h3:hover > a.headerlink, -h4:hover > a.headerlink, -h5:hover > a.headerlink, -h6:hover > a.headerlink, -dt:hover > a.headerlink, -caption:hover > a.headerlink, -p.caption:hover > a.headerlink, -div.code-block-caption:hover > a.headerlink { - visibility: visible; -} - -div.body p.caption { - text-align: inherit; -} - -div.body td { - text-align: left; -} - -.field-list ul { - padding-left: 1em; -} - -.first { - margin-top: 0 !important; -} - -p.rubric { - margin-top: 30px; - font-weight: bold; -} - -img.align-left, .figure.align-left, object.align-left { - clear: left; - float: left; - margin-right: 1em; -} - -img.align-right, .figure.align-right, object.align-right { - clear: right; - float: right; - margin-left: 1em; -} - -img.align-center, .figure.align-center, object.align-center { - display: block; - margin-left: auto; - margin-right: auto; -} - -.align-left { - text-align: left; -} - -.align-center { - text-align: center; -} - -.align-right { - text-align: right; -} - -/* -- sidebars -------------------------------------------------------------- */ - -div.sidebar { - margin: 0 0 0.5em 1em; - border: 1px solid #ddb; - padding: 7px 7px 0 7px; - background-color: #ffe; - width: 40%; - float: right; -} - -p.sidebar-title { - font-weight: bold; -} - -/* -- topics ---------------------------------------------------------------- */ - -div.topic { - border: 1px solid #ccc; - padding: 7px 7px 0 7px; - margin: 10px 0 10px 0; -} - -p.topic-title { - font-size: 1.1em; - font-weight: bold; - margin-top: 10px; -} - -/* -- admonitions ----------------------------------------------------------- */ - -div.admonition { - margin-top: 10px; - margin-bottom: 10px; - padding: 7px; -} - -div.admonition dt { - font-weight: bold; -} - -div.admonition dl { - margin-bottom: 0; -} - -p.admonition-title { - margin: 0px 10px 5px 0px; - font-weight: bold; -} - -div.body p.centered { - text-align: center; - margin-top: 25px; -} - -/* -- tables ---------------------------------------------------------------- */ - -table.docutils { - border: 0; - border-collapse: collapse; -} - -table caption span.caption-number { - font-style: italic; -} - -table caption span.caption-text { -} - -table.docutils td, table.docutils th { - padding: 1px 8px 1px 5px; - border-top: 0; - border-left: 0; - border-right: 0; - border-bottom: 1px solid #aaa; -} - -table.field-list td, table.field-list th { - border: 0 !important; -} - -table.footnote td, table.footnote th { - border: 0 !important; -} - -th { - text-align: left; - padding-right: 5px; -} - -table.citation { - border-left: solid 1px gray; - margin-left: 1px; -} - -table.citation td { - border-bottom: none; -} - -/* -- figures --------------------------------------------------------------- */ - -div.figure { - margin: 0.5em; - padding: 0.5em; -} - -div.figure p.caption { - padding: 0.3em; -} - -div.figure p.caption span.caption-number { - font-style: italic; -} - -div.figure p.caption span.caption-text { -} - - -/* -- other body styles ----------------------------------------------------- */ - -ol.arabic { - list-style: decimal; -} - -ol.loweralpha { - list-style: lower-alpha; -} - -ol.upperalpha { - list-style: upper-alpha; -} - -ol.lowerroman { - list-style: lower-roman; -} - -ol.upperroman { - list-style: upper-roman; -} - -dl { - margin-bottom: 15px; -} - -dd p { - margin-top: 0px; -} - -dd ul, dd table { - margin-bottom: 10px; -} - -dd { - margin-top: 3px; - margin-bottom: 10px; - margin-left: 30px; -} - -dt:target, .highlighted { - background-color: #fbe54e; -} - -dl.glossary dt { - font-weight: bold; - font-size: 1.1em; -} - -.field-list ul { - margin: 0; - padding-left: 1em; -} - -.field-list p { - margin: 0; -} - -.optional { - font-size: 1.3em; -} - -.sig-paren { - font-size: larger; -} - -.versionmodified { - font-style: italic; -} - -.system-message { - background-color: #fda; - padding: 5px; - border: 3px solid red; -} - -.footnote:target { - background-color: #ffa; -} - -.line-block { - display: block; - margin-top: 1em; - margin-bottom: 1em; -} - -.line-block .line-block { - margin-top: 0; - margin-bottom: 0; - margin-left: 1.5em; -} - -.guilabel, .menuselection { - font-family: sans-serif; -} - -.accelerator { - text-decoration: underline; -} - -.classifier { - font-style: oblique; -} - -abbr, acronym { - border-bottom: dotted 1px; - cursor: help; -} - -/* -- code displays --------------------------------------------------------- */ - -pre { - overflow: auto; - overflow-y: hidden; /* fixes display issues on Chrome browsers */ -} - -td.linenos pre { - padding: 5px 0px; - border: 0; - background-color: transparent; - color: #aaa; -} - -table.highlighttable { - margin-left: 0.5em; -} - -table.highlighttable td { - padding: 0 0.5em 0 0.5em; -} - -div.code-block-caption { - padding: 2px 5px; - font-size: small; -} - -div.code-block-caption code { - background-color: transparent; -} - -div.code-block-caption + div > div.highlight > pre { - margin-top: 0; -} - -div.code-block-caption span.caption-number { - padding: 0.1em 0.3em; - font-style: italic; -} - -div.code-block-caption span.caption-text { -} - -div.literal-block-wrapper { - padding: 1em 1em 0; -} - -div.literal-block-wrapper div.highlight { - margin: 0; -} - -code.descname { - background-color: transparent; - font-weight: bold; - font-size: 1.2em; -} - -code.descclassname { - background-color: transparent; -} - -code.xref, a code { - background-color: transparent; - font-weight: bold; -} - -h1 code, h2 code, h3 code, h4 code, h5 code, h6 code { - background-color: transparent; -} - -.viewcode-link { - float: right; -} - -.viewcode-back { - float: right; - font-family: sans-serif; -} - -div.viewcode-block:target { - margin: -1px -10px; - padding: 0 10px; -} - -/* -- math display ---------------------------------------------------------- */ - -img.math { - vertical-align: middle; -} - -div.body div.math p { - text-align: center; -} - -span.eqno { - float: right; -} - -/* -- printout stylesheet --------------------------------------------------- */ - -@media print { - div.document, - div.documentwrapper, - div.bodywrapper { - margin: 0 !important; - width: 100%; - } - - div.sphinxsidebar, - div.related, - div.footer, - #top-link { - display: none; - } -} \ No newline at end of file diff --git a/build/html/_static/comment-bright.png b/build/html/_static/comment-bright.png deleted file mode 100644 index 551517b8c83b76f734ff791f847829a760ad1903..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3500 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 A2LJ#7 diff --git a/build/html/_static/comment.png b/build/html/_static/comment.png deleted file mode 100644 index 92feb52b8824c6b0f59b658b1196c61de9162a95..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3445 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 Xn!ZpXD%P(H00000NkvXXu0mjf= 0 && !jQuery(node.parentNode).hasClass(className)) { - var span = document.createElement("span"); - span.className = className; - span.appendChild(document.createTextNode(val.substr(pos, text.length))); - node.parentNode.insertBefore(span, node.parentNode.insertBefore( - document.createTextNode(val.substr(pos + text.length)), - node.nextSibling)); - node.nodeValue = val.substr(0, pos); - } - } - else if (!jQuery(node).is("button, select, textarea")) { - jQuery.each(node.childNodes, function() { - highlight(this); - }); - } - } - return this.each(function() { - highlight(this); - }); -}; - -/* - * backward compatibility for jQuery.browser - * This will be supported until firefox bug is fixed. - */ -if (!jQuery.browser) { - jQuery.uaMatch = function(ua) { - ua = ua.toLowerCase(); - - var match = /(chrome)[ \/]([\w.]+)/.exec(ua) || - /(webkit)[ \/]([\w.]+)/.exec(ua) || - /(opera)(?:.*version|)[ \/]([\w.]+)/.exec(ua) || - /(msie) ([\w.]+)/.exec(ua) || - ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec(ua) || - []; - - return { - browser: match[ 1 ] || "", - version: match[ 2 ] || "0" - }; - }; - jQuery.browser = {}; - jQuery.browser[jQuery.uaMatch(navigator.userAgent).browser] = true; -} - -/** - * Small JavaScript module for the documentation. - */ -var Documentation = { - - init : function() { - this.fixFirefoxAnchorBug(); - this.highlightSearchWords(); - this.initIndexTable(); - }, - - /** - * i18n support - */ - TRANSLATIONS : {}, - PLURAL_EXPR : function(n) { return n == 1 ? 0 : 1; }, - LOCALE : 'unknown', - - // gettext and ngettext don't access this so that the functions - // can safely bound to a different name (_ = Documentation.gettext) - gettext : function(string) { - var translated = Documentation.TRANSLATIONS[string]; - if (typeof translated == 'undefined') - return string; - return (typeof translated == 'string') ? translated : translated[0]; - }, - - ngettext : function(singular, plural, n) { - var translated = Documentation.TRANSLATIONS[singular]; - if (typeof translated == 'undefined') - return (n == 1) ? singular : plural; - return translated[Documentation.PLURALEXPR(n)]; - }, - - addTranslations : function(catalog) { - for (var key in catalog.messages) - this.TRANSLATIONS[key] = catalog.messages[key]; - this.PLURAL_EXPR = new Function('n', 'return +(' + catalog.plural_expr + ')'); - this.LOCALE = catalog.locale; - }, - - /** - * add context elements like header anchor links - */ - addContextElements : function() { - $('div[id] > :header:first').each(function() { - $('\u00B6'). - attr('href', '#' + this.id). - attr('title', _('Permalink to this headline')). - appendTo(this); - }); - $('dt[id]').each(function() { - $('\u00B6'). - attr('href', '#' + this.id). - attr('title', _('Permalink to this definition')). - appendTo(this); - }); - }, - - /** - * workaround a firefox stupidity - * see: https://bugzilla.mozilla.org/show_bug.cgi?id=645075 - */ - fixFirefoxAnchorBug : function() { - if (document.location.hash) - window.setTimeout(function() { - document.location.href += ''; - }, 10); - }, - - /** - * highlight the search words provided in the url in the text - */ - highlightSearchWords : function() { - var params = $.getQueryParameters(); - var terms = (params.highlight) ? params.highlight[0].split(/\s+/) : []; - if (terms.length) { - var body = $('div.body'); - if (!body.length) { - body = $('body'); - } - window.setTimeout(function() { - $.each(terms, function() { - body.highlightText(this.toLowerCase(), 'highlighted'); - }); - }, 10); - $('

') - .appendTo($('#searchbox')); - } - }, - - /** - * init the domain index toggle buttons - */ - initIndexTable : function() { - var togglers = $('img.toggler').click(function() { - var src = $(this).attr('src'); - var idnum = $(this).attr('id').substr(7); - $('tr.cg-' + idnum).toggle(); - if (src.substr(-9) == 'minus.png') - $(this).attr('src', src.substr(0, src.length-9) + 'plus.png'); - else - $(this).attr('src', src.substr(0, src.length-8) + 'minus.png'); - }).css('display', ''); - if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) { - togglers.click(); - } - }, - - /** - * helper function to hide the search marks again - */ - hideSearchWords : function() { - $('#searchbox .highlight-link').fadeOut(300); - $('span.highlighted').removeClass('highlighted'); - }, - - /** - * make the url absolute - */ - makeURL : function(relativeURL) { - return DOCUMENTATION_OPTIONS.URL_ROOT + '/' + relativeURL; - }, - - /** - * get the current relative url - */ - getCurrentURL : function() { - var path = document.location.pathname; - var parts = path.split(/\//); - $.each(DOCUMENTATION_OPTIONS.URL_ROOT.split(/\//), function() { - if (this == '..') - parts.pop(); - }); - var url = parts.join('/'); - return path.substring(url.lastIndexOf('/') + 1, path.length - 1); - } -}; - -// quick alias for translations -_ = Documentation.gettext; - -$(document).ready(function() { - Documentation.init(); -}); diff --git a/build/html/_static/down-pressed.png b/build/html/_static/down-pressed.png deleted file mode 100644 index 7c30d004b71b32bb2fc06b3bd4dc8278baab0946..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 347 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJV{wqX6T`Z5GB1G~&H|6fVxZ#d zAk65bF}ngN$X?><>&kwMor^(NtW3yF87Slz;1l8sq&LUMQwy<>&kwMol#tg zK_ydLmzem(vK1>2TzUEGl*lj!N<7$PCrdoWV0 z$w0*Ap!bZ4if7h;-yfL#MC0e;t{xY+$l~DX2EWYIPet1cohf^BdG+jXhtuq&W-0|c zKPmlKv-7OTjb}T)7@fTGd9y~u4{g8An;)c2U=w=nwQ7}zVDc>n+a diff --git a/build/html/_static/file.png b/build/html/_static/file.png deleted file mode 100644 index 254c60bfbe2715ae2edca48ebccfd074deb8031d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 358 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJXMsm#F#`j)FbFd;%$g$s6l5>) z^mS#w%FV~i&ZxO9L3Zxqw8>dd4I&zcKG){Yx14xKr0

ZQJ$m%mv17-NAAj}g)$7-<-@JMA z_U+TRK=AR}yLa#2zkmPX!-tO_KYsf3>Hq)#%qnY_1Fd8&3GxeO2wSmci|LJf=|BO- zByV>Yl`U*PX977no-U3d5|XS39sLdkFt8q|+|QqL_#ErUf6I%zFA7b%b>3$hFGGFs zc72AL|61pRJ1(+5wNdg|xP#*`gQ~lOnTFKiIjl#S3)+QV=h{~`9{M=hx#5uZ&-tIF sG!8onYS_8EFr8v&@CavkqYey&g)1epR*Fkm0PSV)boFyt=akR{044O6bN~PV diff --git a/build/html/_static/jquery-1.11.1.js b/build/html/_static/jquery-1.11.1.js deleted file mode 100644 index d4b67f7..0000000 --- a/build/html/_static/jquery-1.11.1.js +++ /dev/null @@ -1,10308 +0,0 @@ -/*! - * jQuery JavaScript Library v1.11.1 - * http://jquery.com/ - * - * Includes Sizzle.js - * http://sizzlejs.com/ - * - * Copyright 2005, 2014 jQuery Foundation, Inc. and other contributors - * Released under the MIT license - * http://jquery.org/license - * - * Date: 2014-05-01T17:42Z - */ - -(function( global, factory ) { - - if ( typeof module === "object" && typeof module.exports === "object" ) { - // For CommonJS and CommonJS-like environments where a proper window is present, - // execute the factory and get jQuery - // For environments that do not inherently posses a window with a document - // (such as Node.js), expose a jQuery-making factory as module.exports - // This accentuates the need for the creation of a real window - // e.g. var jQuery = require("jquery")(window); - // See ticket #14549 for more info - module.exports = global.document ? - factory( global, true ) : - function( w ) { - if ( !w.document ) { - throw new Error( "jQuery requires a window with a document" ); - } - return factory( w ); - }; - } else { - factory( global ); - } - -// Pass this if window is not defined yet -}(typeof window !== "undefined" ? window : this, function( window, noGlobal ) { - -// Can't do this because several apps including ASP.NET trace -// the stack via arguments.caller.callee and Firefox dies if -// you try to trace through "use strict" call chains. (#13335) -// Support: Firefox 18+ -// - -var deletedIds = []; - -var slice = deletedIds.slice; - -var concat = deletedIds.concat; - -var push = deletedIds.push; - -var indexOf = deletedIds.indexOf; - -var class2type = {}; - -var toString = class2type.toString; - -var hasOwn = class2type.hasOwnProperty; - -var support = {}; - - - -var - version = "1.11.1", - - // Define a local copy of jQuery - jQuery = function( selector, context ) { - // The jQuery object is actually just the init constructor 'enhanced' - // Need init if jQuery is called (just allow error to be thrown if not included) - return new jQuery.fn.init( selector, context ); - }, - - // Support: Android<4.1, IE<9 - // Make sure we trim BOM and NBSP - rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, - - // Matches dashed string for camelizing - rmsPrefix = /^-ms-/, - rdashAlpha = /-([\da-z])/gi, - - // Used by jQuery.camelCase as callback to replace() - fcamelCase = function( all, letter ) { - return letter.toUpperCase(); - }; - -jQuery.fn = jQuery.prototype = { - // The current version of jQuery being used - jquery: version, - - constructor: jQuery, - - // Start with an empty selector - selector: "", - - // The default length of a jQuery object is 0 - length: 0, - - toArray: function() { - return slice.call( this ); - }, - - // Get the Nth element in the matched element set OR - // Get the whole matched element set as a clean array - get: function( num ) { - return num != null ? - - // Return just the one element from the set - ( num < 0 ? this[ num + this.length ] : this[ num ] ) : - - // Return all the elements in a clean array - slice.call( this ); - }, - - // Take an array of elements and push it onto the stack - // (returning the new matched element set) - pushStack: function( elems ) { - - // Build a new jQuery matched element set - var ret = jQuery.merge( this.constructor(), elems ); - - // Add the old object onto the stack (as a reference) - ret.prevObject = this; - ret.context = this.context; - - // Return the newly-formed element set - return ret; - }, - - // Execute a callback for every element in the matched set. - // (You can seed the arguments with an array of args, but this is - // only used internally.) - each: function( callback, args ) { - return jQuery.each( this, callback, args ); - }, - - map: function( callback ) { - return this.pushStack( jQuery.map(this, function( elem, i ) { - return callback.call( elem, i, elem ); - })); - }, - - slice: function() { - return this.pushStack( slice.apply( this, arguments ) ); - }, - - first: function() { - return this.eq( 0 ); - }, - - last: function() { - return this.eq( -1 ); - }, - - eq: function( i ) { - var len = this.length, - j = +i + ( i < 0 ? len : 0 ); - return this.pushStack( j >= 0 && j < len ? [ this[j] ] : [] ); - }, - - end: function() { - return this.prevObject || this.constructor(null); - }, - - // For internal use only. - // Behaves like an Array's method, not like a jQuery method. - push: push, - sort: deletedIds.sort, - splice: deletedIds.splice -}; - -jQuery.extend = jQuery.fn.extend = function() { - var src, copyIsArray, copy, name, options, clone, - target = arguments[0] || {}, - i = 1, - length = arguments.length, - deep = false; - - // Handle a deep copy situation - if ( typeof target === "boolean" ) { - deep = target; - - // skip the boolean and the target - target = arguments[ i ] || {}; - i++; - } - - // Handle case when target is a string or something (possible in deep copy) - if ( typeof target !== "object" && !jQuery.isFunction(target) ) { - target = {}; - } - - // extend jQuery itself if only one argument is passed - if ( i === length ) { - target = this; - i--; - } - - for ( ; i < length; i++ ) { - // Only deal with non-null/undefined values - if ( (options = arguments[ i ]) != null ) { - // Extend the base object - for ( name in options ) { - src = target[ name ]; - copy = options[ name ]; - - // Prevent never-ending loop - if ( target === copy ) { - continue; - } - - // Recurse if we're merging plain objects or arrays - if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) { - if ( copyIsArray ) { - copyIsArray = false; - clone = src && jQuery.isArray(src) ? src : []; - - } else { - clone = src && jQuery.isPlainObject(src) ? src : {}; - } - - // Never move original objects, clone them - target[ name ] = jQuery.extend( deep, clone, copy ); - - // Don't bring in undefined values - } else if ( copy !== undefined ) { - target[ name ] = copy; - } - } - } - } - - // Return the modified object - return target; -}; - -jQuery.extend({ - // Unique for each copy of jQuery on the page - expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ), - - // Assume jQuery is ready without the ready module - isReady: true, - - error: function( msg ) { - throw new Error( msg ); - }, - - noop: function() {}, - - // See test/unit/core.js for details concerning isFunction. - // Since version 1.3, DOM methods and functions like alert - // aren't supported. They return false on IE (#2968). - isFunction: function( obj ) { - return jQuery.type(obj) === "function"; - }, - - isArray: Array.isArray || function( obj ) { - return jQuery.type(obj) === "array"; - }, - - isWindow: function( obj ) { - /* jshint eqeqeq: false */ - return obj != null && obj == obj.window; - }, - - isNumeric: function( obj ) { - // parseFloat NaNs numeric-cast false positives (null|true|false|"") - // ...but misinterprets leading-number strings, particularly hex literals ("0x...") - // subtraction forces infinities to NaN - return !jQuery.isArray( obj ) && obj - parseFloat( obj ) >= 0; - }, - - isEmptyObject: function( obj ) { - var name; - for ( name in obj ) { - return false; - } - return true; - }, - - isPlainObject: function( obj ) { - var key; - - // Must be an Object. - // Because of IE, we also have to check the presence of the constructor property. - // Make sure that DOM nodes and window objects don't pass through, as well - if ( !obj || jQuery.type(obj) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { - return false; - } - - try { - // Not own constructor property must be Object - if ( obj.constructor && - !hasOwn.call(obj, "constructor") && - !hasOwn.call(obj.constructor.prototype, "isPrototypeOf") ) { - return false; - } - } catch ( e ) { - // IE8,9 Will throw exceptions on certain host objects #9897 - return false; - } - - // Support: IE<9 - // Handle iteration over inherited properties before own properties. - if ( support.ownLast ) { - for ( key in obj ) { - return hasOwn.call( obj, key ); - } - } - - // Own properties are enumerated firstly, so to speed up, - // if last one is own, then all properties are own. - for ( key in obj ) {} - - return key === undefined || hasOwn.call( obj, key ); - }, - - type: function( obj ) { - if ( obj == null ) { - return obj + ""; - } - return typeof obj === "object" || typeof obj === "function" ? - class2type[ toString.call(obj) ] || "object" : - typeof obj; - }, - - // Evaluates a script in a global context - // Workarounds based on findings by Jim Driscoll - // http://weblogs.java.net/blog/driscoll/archive/2009/09/08/eval-javascript-global-context - globalEval: function( data ) { - if ( data && jQuery.trim( data ) ) { - // We use execScript on Internet Explorer - // We use an anonymous function so that context is window - // rather than jQuery in Firefox - ( window.execScript || function( data ) { - window[ "eval" ].call( window, data ); - } )( data ); - } - }, - - // Convert dashed to camelCase; used by the css and data modules - // Microsoft forgot to hump their vendor prefix (#9572) - camelCase: function( string ) { - return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); - }, - - nodeName: function( elem, name ) { - return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); - }, - - // args is for internal usage only - each: function( obj, callback, args ) { - var value, - i = 0, - length = obj.length, - isArray = isArraylike( obj ); - - if ( args ) { - if ( isArray ) { - for ( ; i < length; i++ ) { - value = callback.apply( obj[ i ], args ); - - if ( value === false ) { - break; - } - } - } else { - for ( i in obj ) { - value = callback.apply( obj[ i ], args ); - - if ( value === false ) { - break; - } - } - } - - // A special, fast, case for the most common use of each - } else { - if ( isArray ) { - for ( ; i < length; i++ ) { - value = callback.call( obj[ i ], i, obj[ i ] ); - - if ( value === false ) { - break; - } - } - } else { - for ( i in obj ) { - value = callback.call( obj[ i ], i, obj[ i ] ); - - if ( value === false ) { - break; - } - } - } - } - - return obj; - }, - - // Support: Android<4.1, IE<9 - trim: function( text ) { - return text == null ? - "" : - ( text + "" ).replace( rtrim, "" ); - }, - - // results is for internal usage only - makeArray: function( arr, results ) { - var ret = results || []; - - if ( arr != null ) { - if ( isArraylike( Object(arr) ) ) { - jQuery.merge( ret, - typeof arr === "string" ? - [ arr ] : arr - ); - } else { - push.call( ret, arr ); - } - } - - return ret; - }, - - inArray: function( elem, arr, i ) { - var len; - - if ( arr ) { - if ( indexOf ) { - return indexOf.call( arr, elem, i ); - } - - len = arr.length; - i = i ? i < 0 ? Math.max( 0, len + i ) : i : 0; - - for ( ; i < len; i++ ) { - // Skip accessing in sparse arrays - if ( i in arr && arr[ i ] === elem ) { - return i; - } - } - } - - return -1; - }, - - merge: function( first, second ) { - var len = +second.length, - j = 0, - i = first.length; - - while ( j < len ) { - first[ i++ ] = second[ j++ ]; - } - - // Support: IE<9 - // Workaround casting of .length to NaN on otherwise arraylike objects (e.g., NodeLists) - if ( len !== len ) { - while ( second[j] !== undefined ) { - first[ i++ ] = second[ j++ ]; - } - } - - first.length = i; - - return first; - }, - - grep: function( elems, callback, invert ) { - var callbackInverse, - matches = [], - i = 0, - length = elems.length, - callbackExpect = !invert; - - // Go through the array, only saving the items - // that pass the validator function - for ( ; i < length; i++ ) { - callbackInverse = !callback( elems[ i ], i ); - if ( callbackInverse !== callbackExpect ) { - matches.push( elems[ i ] ); - } - } - - return matches; - }, - - // arg is for internal usage only - map: function( elems, callback, arg ) { - var value, - i = 0, - length = elems.length, - isArray = isArraylike( elems ), - ret = []; - - // Go through the array, translating each of the items to their new values - if ( isArray ) { - for ( ; i < length; i++ ) { - value = callback( elems[ i ], i, arg ); - - if ( value != null ) { - ret.push( value ); - } - } - - // Go through every key on the object, - } else { - for ( i in elems ) { - value = callback( elems[ i ], i, arg ); - - if ( value != null ) { - ret.push( value ); - } - } - } - - // Flatten any nested arrays - return concat.apply( [], ret ); - }, - - // A global GUID counter for objects - guid: 1, - - // Bind a function to a context, optionally partially applying any - // arguments. - proxy: function( fn, context ) { - var args, proxy, tmp; - - if ( typeof context === "string" ) { - tmp = fn[ context ]; - context = fn; - fn = tmp; - } - - // Quick check to determine if target is callable, in the spec - // this throws a TypeError, but we will just return undefined. - if ( !jQuery.isFunction( fn ) ) { - return undefined; - } - - // Simulated bind - args = slice.call( arguments, 2 ); - proxy = function() { - return fn.apply( context || this, args.concat( slice.call( arguments ) ) ); - }; - - // Set the guid of unique handler to the same of original handler, so it can be removed - proxy.guid = fn.guid = fn.guid || jQuery.guid++; - - return proxy; - }, - - now: function() { - return +( new Date() ); - }, - - // jQuery.support is not used in Core but other projects attach their - // properties to it so it needs to exist. - support: support -}); - -// Populate the class2type map -jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(i, name) { - class2type[ "[object " + name + "]" ] = name.toLowerCase(); -}); - -function isArraylike( obj ) { - var length = obj.length, - type = jQuery.type( obj ); - - if ( type === "function" || jQuery.isWindow( obj ) ) { - return false; - } - - if ( obj.nodeType === 1 && length ) { - return true; - } - - return type === "array" || length === 0 || - typeof length === "number" && length > 0 && ( length - 1 ) in obj; -} -var Sizzle = -/*! - * Sizzle CSS Selector Engine v1.10.19 - * http://sizzlejs.com/ - * - * Copyright 2013 jQuery Foundation, Inc. and other contributors - * Released under the MIT license - * http://jquery.org/license - * - * Date: 2014-04-18 - */ -(function( window ) { - -var i, - support, - Expr, - getText, - isXML, - tokenize, - compile, - select, - outermostContext, - sortInput, - hasDuplicate, - - // Local document vars - setDocument, - document, - docElem, - documentIsHTML, - rbuggyQSA, - rbuggyMatches, - matches, - contains, - - // Instance-specific data - expando = "sizzle" + -(new Date()), - preferredDoc = window.document, - dirruns = 0, - done = 0, - classCache = createCache(), - tokenCache = createCache(), - compilerCache = createCache(), - sortOrder = function( a, b ) { - if ( a === b ) { - hasDuplicate = true; - } - return 0; - }, - - // General-purpose constants - strundefined = typeof undefined, - MAX_NEGATIVE = 1 << 31, - - // Instance methods - hasOwn = ({}).hasOwnProperty, - arr = [], - pop = arr.pop, - push_native = arr.push, - push = arr.push, - slice = arr.slice, - // Use a stripped-down indexOf if we can't use a native one - indexOf = arr.indexOf || function( elem ) { - var i = 0, - len = this.length; - for ( ; i < len; i++ ) { - if ( this[i] === elem ) { - return i; - } - } - return -1; - }, - - booleans = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped", - - // Regular expressions - - // Whitespace characters http://www.w3.org/TR/css3-selectors/#whitespace - whitespace = "[\\x20\\t\\r\\n\\f]", - // http://www.w3.org/TR/css3-syntax/#characters - characterEncoding = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+", - - // Loosely modeled on CSS identifier characters - // An unquoted value should be a CSS identifier http://www.w3.org/TR/css3-selectors/#attribute-selectors - // Proper syntax: http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier - identifier = characterEncoding.replace( "w", "w#" ), - - // Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors - attributes = "\\[" + whitespace + "*(" + characterEncoding + ")(?:" + whitespace + - // Operator (capture 2) - "*([*^$|!~]?=)" + whitespace + - // "Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]" - "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" + whitespace + - "*\\]", - - pseudos = ":(" + characterEncoding + ")(?:\\((" + - // To reduce the number of selectors needing tokenize in the preFilter, prefer arguments: - // 1. quoted (capture 3; capture 4 or capture 5) - "('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|" + - // 2. simple (capture 6) - "((?:\\\\.|[^\\\\()[\\]]|" + attributes + ")*)|" + - // 3. anything else (capture 2) - ".*" + - ")\\)|)", - - // Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter - rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + whitespace + "+$", "g" ), - - rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ), - rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + "*" ), - - rattributeQuotes = new RegExp( "=" + whitespace + "*([^\\]'\"]*?)" + whitespace + "*\\]", "g" ), - - rpseudo = new RegExp( pseudos ), - ridentifier = new RegExp( "^" + identifier + "$" ), - - matchExpr = { - "ID": new RegExp( "^#(" + characterEncoding + ")" ), - "CLASS": new RegExp( "^\\.(" + characterEncoding + ")" ), - "TAG": new RegExp( "^(" + characterEncoding.replace( "w", "w*" ) + ")" ), - "ATTR": new RegExp( "^" + attributes ), - "PSEUDO": new RegExp( "^" + pseudos ), - "CHILD": new RegExp( "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + whitespace + - "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" + whitespace + - "*(\\d+)|))" + whitespace + "*\\)|)", "i" ), - "bool": new RegExp( "^(?:" + booleans + ")$", "i" ), - // For use in libraries implementing .is() - // We use this for POS matching in `select` - "needsContext": new RegExp( "^" + whitespace + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + - whitespace + "*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i" ) - }, - - rinputs = /^(?:input|select|textarea|button)$/i, - rheader = /^h\d$/i, - - rnative = /^[^{]+\{\s*\[native \w/, - - // Easily-parseable/retrievable ID or TAG or CLASS selectors - rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, - - rsibling = /[+~]/, - rescape = /'|\\/g, - - // CSS escapes http://www.w3.org/TR/CSS21/syndata.html#escaped-characters - runescape = new RegExp( "\\\\([\\da-f]{1,6}" + whitespace + "?|(" + whitespace + ")|.)", "ig" ), - funescape = function( _, escaped, escapedWhitespace ) { - var high = "0x" + escaped - 0x10000; - // NaN means non-codepoint - // Support: Firefox<24 - // Workaround erroneous numeric interpretation of +"0x" - return high !== high || escapedWhitespace ? - escaped : - high < 0 ? - // BMP codepoint - String.fromCharCode( high + 0x10000 ) : - // Supplemental Plane codepoint (surrogate pair) - String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 ); - }; - -// Optimize for push.apply( _, NodeList ) -try { - push.apply( - (arr = slice.call( preferredDoc.childNodes )), - preferredDoc.childNodes - ); - // Support: Android<4.0 - // Detect silently failing push.apply - arr[ preferredDoc.childNodes.length ].nodeType; -} catch ( e ) { - push = { apply: arr.length ? - - // Leverage slice if possible - function( target, els ) { - push_native.apply( target, slice.call(els) ); - } : - - // Support: IE<9 - // Otherwise append directly - function( target, els ) { - var j = target.length, - i = 0; - // Can't trust NodeList.length - while ( (target[j++] = els[i++]) ) {} - target.length = j - 1; - } - }; -} - -function Sizzle( selector, context, results, seed ) { - var match, elem, m, nodeType, - // QSA vars - i, groups, old, nid, newContext, newSelector; - - if ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) { - setDocument( context ); - } - - context = context || document; - results = results || []; - - if ( !selector || typeof selector !== "string" ) { - return results; - } - - if ( (nodeType = context.nodeType) !== 1 && nodeType !== 9 ) { - return []; - } - - if ( documentIsHTML && !seed ) { - - // Shortcuts - if ( (match = rquickExpr.exec( selector )) ) { - // Speed-up: Sizzle("#ID") - if ( (m = match[1]) ) { - if ( nodeType === 9 ) { - elem = context.getElementById( m ); - // Check parentNode to catch when Blackberry 4.6 returns - // nodes that are no longer in the document (jQuery #6963) - if ( elem && elem.parentNode ) { - // Handle the case where IE, Opera, and Webkit return items - // by name instead of ID - if ( elem.id === m ) { - results.push( elem ); - return results; - } - } else { - return results; - } - } else { - // Context is not a document - if ( context.ownerDocument && (elem = context.ownerDocument.getElementById( m )) && - contains( context, elem ) && elem.id === m ) { - results.push( elem ); - return results; - } - } - - // Speed-up: Sizzle("TAG") - } else if ( match[2] ) { - push.apply( results, context.getElementsByTagName( selector ) ); - return results; - - // Speed-up: Sizzle(".CLASS") - } else if ( (m = match[3]) && support.getElementsByClassName && context.getElementsByClassName ) { - push.apply( results, context.getElementsByClassName( m ) ); - return results; - } - } - - // QSA path - if ( support.qsa && (!rbuggyQSA || !rbuggyQSA.test( selector )) ) { - nid = old = expando; - newContext = context; - newSelector = nodeType === 9 && selector; - - // qSA works strangely on Element-rooted queries - // We can work around this by specifying an extra ID on the root - // and working up from there (Thanks to Andrew Dupont for the technique) - // IE 8 doesn't work on object elements - if ( nodeType === 1 && context.nodeName.toLowerCase() !== "object" ) { - groups = tokenize( selector ); - - if ( (old = context.getAttribute("id")) ) { - nid = old.replace( rescape, "\\$&" ); - } else { - context.setAttribute( "id", nid ); - } - nid = "[id='" + nid + "'] "; - - i = groups.length; - while ( i-- ) { - groups[i] = nid + toSelector( groups[i] ); - } - newContext = rsibling.test( selector ) && testContext( context.parentNode ) || context; - newSelector = groups.join(","); - } - - if ( newSelector ) { - try { - push.apply( results, - newContext.querySelectorAll( newSelector ) - ); - return results; - } catch(qsaError) { - } finally { - if ( !old ) { - context.removeAttribute("id"); - } - } - } - } - } - - // All others - return select( selector.replace( rtrim, "$1" ), context, results, seed ); -} - -/** - * Create key-value caches of limited size - * @returns {Function(string, Object)} Returns the Object data after storing it on itself with - * property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength) - * deleting the oldest entry - */ -function createCache() { - var keys = []; - - function cache( key, value ) { - // Use (key + " ") to avoid collision with native prototype properties (see Issue #157) - if ( keys.push( key + " " ) > Expr.cacheLength ) { - // Only keep the most recent entries - delete cache[ keys.shift() ]; - } - return (cache[ key + " " ] = value); - } - return cache; -} - -/** - * Mark a function for special use by Sizzle - * @param {Function} fn The function to mark - */ -function markFunction( fn ) { - fn[ expando ] = true; - return fn; -} - -/** - * Support testing using an element - * @param {Function} fn Passed the created div and expects a boolean result - */ -function assert( fn ) { - var div = document.createElement("div"); - - try { - return !!fn( div ); - } catch (e) { - return false; - } finally { - // Remove from its parent by default - if ( div.parentNode ) { - div.parentNode.removeChild( div ); - } - // release memory in IE - div = null; - } -} - -/** - * Adds the same handler for all of the specified attrs - * @param {String} attrs Pipe-separated list of attributes - * @param {Function} handler The method that will be applied - */ -function addHandle( attrs, handler ) { - var arr = attrs.split("|"), - i = attrs.length; - - while ( i-- ) { - Expr.attrHandle[ arr[i] ] = handler; - } -} - -/** - * Checks document order of two siblings - * @param {Element} a - * @param {Element} b - * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b - */ -function siblingCheck( a, b ) { - var cur = b && a, - diff = cur && a.nodeType === 1 && b.nodeType === 1 && - ( ~b.sourceIndex || MAX_NEGATIVE ) - - ( ~a.sourceIndex || MAX_NEGATIVE ); - - // Use IE sourceIndex if available on both nodes - if ( diff ) { - return diff; - } - - // Check if b follows a - if ( cur ) { - while ( (cur = cur.nextSibling) ) { - if ( cur === b ) { - return -1; - } - } - } - - return a ? 1 : -1; -} - -/** - * Returns a function to use in pseudos for input types - * @param {String} type - */ -function createInputPseudo( type ) { - return function( elem ) { - var name = elem.nodeName.toLowerCase(); - return name === "input" && elem.type === type; - }; -} - -/** - * Returns a function to use in pseudos for buttons - * @param {String} type - */ -function createButtonPseudo( type ) { - return function( elem ) { - var name = elem.nodeName.toLowerCase(); - return (name === "input" || name === "button") && elem.type === type; - }; -} - -/** - * Returns a function to use in pseudos for positionals - * @param {Function} fn - */ -function createPositionalPseudo( fn ) { - return markFunction(function( argument ) { - argument = +argument; - return markFunction(function( seed, matches ) { - var j, - matchIndexes = fn( [], seed.length, argument ), - i = matchIndexes.length; - - // Match elements found at the specified indexes - while ( i-- ) { - if ( seed[ (j = matchIndexes[i]) ] ) { - seed[j] = !(matches[j] = seed[j]); - } - } - }); - }); -} - -/** - * Checks a node for validity as a Sizzle context - * @param {Element|Object=} context - * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value - */ -function testContext( context ) { - return context && typeof context.getElementsByTagName !== strundefined && context; -} - -// Expose support vars for convenience -support = Sizzle.support = {}; - -/** - * Detects XML nodes - * @param {Element|Object} elem An element or a document - * @returns {Boolean} True iff elem is a non-HTML XML node - */ -isXML = Sizzle.isXML = function( elem ) { - // documentElement is verified for cases where it doesn't yet exist - // (such as loading iframes in IE - #4833) - var documentElement = elem && (elem.ownerDocument || elem).documentElement; - return documentElement ? documentElement.nodeName !== "HTML" : false; -}; - -/** - * Sets document-related variables once based on the current document - * @param {Element|Object} [doc] An element or document object to use to set the document - * @returns {Object} Returns the current document - */ -setDocument = Sizzle.setDocument = function( node ) { - var hasCompare, - doc = node ? node.ownerDocument || node : preferredDoc, - parent = doc.defaultView; - - // If no document and documentElement is available, return - if ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) { - return document; - } - - // Set our document - document = doc; - docElem = doc.documentElement; - - // Support tests - documentIsHTML = !isXML( doc ); - - // Support: IE>8 - // If iframe document is assigned to "document" variable and if iframe has been reloaded, - // IE will throw "permission denied" error when accessing "document" variable, see jQuery #13936 - // IE6-8 do not support the defaultView property so parent will be undefined - if ( parent && parent !== parent.top ) { - // IE11 does not have attachEvent, so all must suffer - if ( parent.addEventListener ) { - parent.addEventListener( "unload", function() { - setDocument(); - }, false ); - } else if ( parent.attachEvent ) { - parent.attachEvent( "onunload", function() { - setDocument(); - }); - } - } - - /* Attributes - ---------------------------------------------------------------------- */ - - // Support: IE<8 - // Verify that getAttribute really returns attributes and not properties (excepting IE8 booleans) - support.attributes = assert(function( div ) { - div.className = "i"; - return !div.getAttribute("className"); - }); - - /* getElement(s)By* - ---------------------------------------------------------------------- */ - - // Check if getElementsByTagName("*") returns only elements - support.getElementsByTagName = assert(function( div ) { - div.appendChild( doc.createComment("") ); - return !div.getElementsByTagName("*").length; - }); - - // Check if getElementsByClassName can be trusted - support.getElementsByClassName = rnative.test( doc.getElementsByClassName ) && assert(function( div ) { - div.innerHTML = "

"; - - // Support: Safari<4 - // Catch class over-caching - div.firstChild.className = "i"; - // Support: Opera<10 - // Catch gEBCN failure to find non-leading classes - return div.getElementsByClassName("i").length === 2; - }); - - // Support: IE<10 - // Check if getElementById returns elements by name - // The broken getElementById methods don't pick up programatically-set names, - // so use a roundabout getElementsByName test - support.getById = assert(function( div ) { - docElem.appendChild( div ).id = expando; - return !doc.getElementsByName || !doc.getElementsByName( expando ).length; - }); - - // ID find and filter - if ( support.getById ) { - Expr.find["ID"] = function( id, context ) { - if ( typeof context.getElementById !== strundefined && documentIsHTML ) { - var m = context.getElementById( id ); - // Check parentNode to catch when Blackberry 4.6 returns - // nodes that are no longer in the document #6963 - return m && m.parentNode ? [ m ] : []; - } - }; - Expr.filter["ID"] = function( id ) { - var attrId = id.replace( runescape, funescape ); - return function( elem ) { - return elem.getAttribute("id") === attrId; - }; - }; - } else { - // Support: IE6/7 - // getElementById is not reliable as a find shortcut - delete Expr.find["ID"]; - - Expr.filter["ID"] = function( id ) { - var attrId = id.replace( runescape, funescape ); - return function( elem ) { - var node = typeof elem.getAttributeNode !== strundefined && elem.getAttributeNode("id"); - return node && node.value === attrId; - }; - }; - } - - // Tag - Expr.find["TAG"] = support.getElementsByTagName ? - function( tag, context ) { - if ( typeof context.getElementsByTagName !== strundefined ) { - return context.getElementsByTagName( tag ); - } - } : - function( tag, context ) { - var elem, - tmp = [], - i = 0, - results = context.getElementsByTagName( tag ); - - // Filter out possible comments - if ( tag === "*" ) { - while ( (elem = results[i++]) ) { - if ( elem.nodeType === 1 ) { - tmp.push( elem ); - } - } - - return tmp; - } - return results; - }; - - // Class - Expr.find["CLASS"] = support.getElementsByClassName && function( className, context ) { - if ( typeof context.getElementsByClassName !== strundefined && documentIsHTML ) { - return context.getElementsByClassName( className ); - } - }; - - /* QSA/matchesSelector - ---------------------------------------------------------------------- */ - - // QSA and matchesSelector support - - // matchesSelector(:active) reports false when true (IE9/Opera 11.5) - rbuggyMatches = []; - - // qSa(:focus) reports false when true (Chrome 21) - // We allow this because of a bug in IE8/9 that throws an error - // whenever `document.activeElement` is accessed on an iframe - // So, we allow :focus to pass through QSA all the time to avoid the IE error - // See http://bugs.jquery.com/ticket/13378 - rbuggyQSA = []; - - if ( (support.qsa = rnative.test( doc.querySelectorAll )) ) { - // Build QSA regex - // Regex strategy adopted from Diego Perini - assert(function( div ) { - // Select is set to empty string on purpose - // This is to test IE's treatment of not explicitly - // setting a boolean content attribute, - // since its presence should be enough - // http://bugs.jquery.com/ticket/12359 - div.innerHTML = ""; - - // Support: IE8, Opera 11-12.16 - // Nothing should be selected when empty strings follow ^= or $= or *= - // The test attribute must be unknown in Opera but "safe" for WinRT - // http://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section - if ( div.querySelectorAll("[msallowclip^='']").length ) { - rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" ); - } - - // Support: IE8 - // Boolean attributes and "value" are not treated correctly - if ( !div.querySelectorAll("[selected]").length ) { - rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" ); - } - - // Webkit/Opera - :checked should return selected option elements - // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked - // IE8 throws error here and will not see later tests - if ( !div.querySelectorAll(":checked").length ) { - rbuggyQSA.push(":checked"); - } - }); - - assert(function( div ) { - // Support: Windows 8 Native Apps - // The type and name attributes are restricted during .innerHTML assignment - var input = doc.createElement("input"); - input.setAttribute( "type", "hidden" ); - div.appendChild( input ).setAttribute( "name", "D" ); - - // Support: IE8 - // Enforce case-sensitivity of name attribute - if ( div.querySelectorAll("[name=d]").length ) { - rbuggyQSA.push( "name" + whitespace + "*[*^$|!~]?=" ); - } - - // FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled) - // IE8 throws error here and will not see later tests - if ( !div.querySelectorAll(":enabled").length ) { - rbuggyQSA.push( ":enabled", ":disabled" ); - } - - // Opera 10-11 does not throw on post-comma invalid pseudos - div.querySelectorAll("*,:x"); - rbuggyQSA.push(",.*:"); - }); - } - - if ( (support.matchesSelector = rnative.test( (matches = docElem.matches || - docElem.webkitMatchesSelector || - docElem.mozMatchesSelector || - docElem.oMatchesSelector || - docElem.msMatchesSelector) )) ) { - - assert(function( div ) { - // Check to see if it's possible to do matchesSelector - // on a disconnected node (IE 9) - support.disconnectedMatch = matches.call( div, "div" ); - - // This should fail with an exception - // Gecko does not error, returns false instead - matches.call( div, "[s!='']:x" ); - rbuggyMatches.push( "!=", pseudos ); - }); - } - - rbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join("|") ); - rbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join("|") ); - - /* Contains - ---------------------------------------------------------------------- */ - hasCompare = rnative.test( docElem.compareDocumentPosition ); - - // Element contains another - // Purposefully does not implement inclusive descendent - // As in, an element does not contain itself - contains = hasCompare || rnative.test( docElem.contains ) ? - function( a, b ) { - var adown = a.nodeType === 9 ? a.documentElement : a, - bup = b && b.parentNode; - return a === bup || !!( bup && bup.nodeType === 1 && ( - adown.contains ? - adown.contains( bup ) : - a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16 - )); - } : - function( a, b ) { - if ( b ) { - while ( (b = b.parentNode) ) { - if ( b === a ) { - return true; - } - } - } - return false; - }; - - /* Sorting - ---------------------------------------------------------------------- */ - - // Document order sorting - sortOrder = hasCompare ? - function( a, b ) { - - // Flag for duplicate removal - if ( a === b ) { - hasDuplicate = true; - return 0; - } - - // Sort on method existence if only one input has compareDocumentPosition - var compare = !a.compareDocumentPosition - !b.compareDocumentPosition; - if ( compare ) { - return compare; - } - - // Calculate position if both inputs belong to the same document - compare = ( a.ownerDocument || a ) === ( b.ownerDocument || b ) ? - a.compareDocumentPosition( b ) : - - // Otherwise we know they are disconnected - 1; - - // Disconnected nodes - if ( compare & 1 || - (!support.sortDetached && b.compareDocumentPosition( a ) === compare) ) { - - // Choose the first element that is related to our preferred document - if ( a === doc || a.ownerDocument === preferredDoc && contains(preferredDoc, a) ) { - return -1; - } - if ( b === doc || b.ownerDocument === preferredDoc && contains(preferredDoc, b) ) { - return 1; - } - - // Maintain original order - return sortInput ? - ( indexOf.call( sortInput, a ) - indexOf.call( sortInput, b ) ) : - 0; - } - - return compare & 4 ? -1 : 1; - } : - function( a, b ) { - // Exit early if the nodes are identical - if ( a === b ) { - hasDuplicate = true; - return 0; - } - - var cur, - i = 0, - aup = a.parentNode, - bup = b.parentNode, - ap = [ a ], - bp = [ b ]; - - // Parentless nodes are either documents or disconnected - if ( !aup || !bup ) { - return a === doc ? -1 : - b === doc ? 1 : - aup ? -1 : - bup ? 1 : - sortInput ? - ( indexOf.call( sortInput, a ) - indexOf.call( sortInput, b ) ) : - 0; - - // If the nodes are siblings, we can do a quick check - } else if ( aup === bup ) { - return siblingCheck( a, b ); - } - - // Otherwise we need full lists of their ancestors for comparison - cur = a; - while ( (cur = cur.parentNode) ) { - ap.unshift( cur ); - } - cur = b; - while ( (cur = cur.parentNode) ) { - bp.unshift( cur ); - } - - // Walk down the tree looking for a discrepancy - while ( ap[i] === bp[i] ) { - i++; - } - - return i ? - // Do a sibling check if the nodes have a common ancestor - siblingCheck( ap[i], bp[i] ) : - - // Otherwise nodes in our document sort first - ap[i] === preferredDoc ? -1 : - bp[i] === preferredDoc ? 1 : - 0; - }; - - return doc; -}; - -Sizzle.matches = function( expr, elements ) { - return Sizzle( expr, null, null, elements ); -}; - -Sizzle.matchesSelector = function( elem, expr ) { - // Set document vars if needed - if ( ( elem.ownerDocument || elem ) !== document ) { - setDocument( elem ); - } - - // Make sure that attribute selectors are quoted - expr = expr.replace( rattributeQuotes, "='$1']" ); - - if ( support.matchesSelector && documentIsHTML && - ( !rbuggyMatches || !rbuggyMatches.test( expr ) ) && - ( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) { - - try { - var ret = matches.call( elem, expr ); - - // IE 9's matchesSelector returns false on disconnected nodes - if ( ret || support.disconnectedMatch || - // As well, disconnected nodes are said to be in a document - // fragment in IE 9 - elem.document && elem.document.nodeType !== 11 ) { - return ret; - } - } catch(e) {} - } - - return Sizzle( expr, document, null, [ elem ] ).length > 0; -}; - -Sizzle.contains = function( context, elem ) { - // Set document vars if needed - if ( ( context.ownerDocument || context ) !== document ) { - setDocument( context ); - } - return contains( context, elem ); -}; - -Sizzle.attr = function( elem, name ) { - // Set document vars if needed - if ( ( elem.ownerDocument || elem ) !== document ) { - setDocument( elem ); - } - - var fn = Expr.attrHandle[ name.toLowerCase() ], - // Don't get fooled by Object.prototype properties (jQuery #13807) - val = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ? - fn( elem, name, !documentIsHTML ) : - undefined; - - return val !== undefined ? - val : - support.attributes || !documentIsHTML ? - elem.getAttribute( name ) : - (val = elem.getAttributeNode(name)) && val.specified ? - val.value : - null; -}; - -Sizzle.error = function( msg ) { - throw new Error( "Syntax error, unrecognized expression: " + msg ); -}; - -/** - * Document sorting and removing duplicates - * @param {ArrayLike} results - */ -Sizzle.uniqueSort = function( results ) { - var elem, - duplicates = [], - j = 0, - i = 0; - - // Unless we *know* we can detect duplicates, assume their presence - hasDuplicate = !support.detectDuplicates; - sortInput = !support.sortStable && results.slice( 0 ); - results.sort( sortOrder ); - - if ( hasDuplicate ) { - while ( (elem = results[i++]) ) { - if ( elem === results[ i ] ) { - j = duplicates.push( i ); - } - } - while ( j-- ) { - results.splice( duplicates[ j ], 1 ); - } - } - - // Clear input after sorting to release objects - // See https://github.com/jquery/sizzle/pull/225 - sortInput = null; - - return results; -}; - -/** - * Utility function for retrieving the text value of an array of DOM nodes - * @param {Array|Element} elem - */ -getText = Sizzle.getText = function( elem ) { - var node, - ret = "", - i = 0, - nodeType = elem.nodeType; - - if ( !nodeType ) { - // If no nodeType, this is expected to be an array - while ( (node = elem[i++]) ) { - // Do not traverse comment nodes - ret += getText( node ); - } - } else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) { - // Use textContent for elements - // innerText usage removed for consistency of new lines (jQuery #11153) - if ( typeof elem.textContent === "string" ) { - return elem.textContent; - } else { - // Traverse its children - for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { - ret += getText( elem ); - } - } - } else if ( nodeType === 3 || nodeType === 4 ) { - return elem.nodeValue; - } - // Do not include comment or processing instruction nodes - - return ret; -}; - -Expr = Sizzle.selectors = { - - // Can be adjusted by the user - cacheLength: 50, - - createPseudo: markFunction, - - match: matchExpr, - - attrHandle: {}, - - find: {}, - - relative: { - ">": { dir: "parentNode", first: true }, - " ": { dir: "parentNode" }, - "+": { dir: "previousSibling", first: true }, - "~": { dir: "previousSibling" } - }, - - preFilter: { - "ATTR": function( match ) { - match[1] = match[1].replace( runescape, funescape ); - - // Move the given value to match[3] whether quoted or unquoted - match[3] = ( match[3] || match[4] || match[5] || "" ).replace( runescape, funescape ); - - if ( match[2] === "~=" ) { - match[3] = " " + match[3] + " "; - } - - return match.slice( 0, 4 ); - }, - - "CHILD": function( match ) { - /* matches from matchExpr["CHILD"] - 1 type (only|nth|...) - 2 what (child|of-type) - 3 argument (even|odd|\d*|\d*n([+-]\d+)?|...) - 4 xn-component of xn+y argument ([+-]?\d*n|) - 5 sign of xn-component - 6 x of xn-component - 7 sign of y-component - 8 y of y-component - */ - match[1] = match[1].toLowerCase(); - - if ( match[1].slice( 0, 3 ) === "nth" ) { - // nth-* requires argument - if ( !match[3] ) { - Sizzle.error( match[0] ); - } - - // numeric x and y parameters for Expr.filter.CHILD - // remember that false/true cast respectively to 0/1 - match[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === "even" || match[3] === "odd" ) ); - match[5] = +( ( match[7] + match[8] ) || match[3] === "odd" ); - - // other types prohibit arguments - } else if ( match[3] ) { - Sizzle.error( match[0] ); - } - - return match; - }, - - "PSEUDO": function( match ) { - var excess, - unquoted = !match[6] && match[2]; - - if ( matchExpr["CHILD"].test( match[0] ) ) { - return null; - } - - // Accept quoted arguments as-is - if ( match[3] ) { - match[2] = match[4] || match[5] || ""; - - // Strip excess characters from unquoted arguments - } else if ( unquoted && rpseudo.test( unquoted ) && - // Get excess from tokenize (recursively) - (excess = tokenize( unquoted, true )) && - // advance to the next closing parenthesis - (excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length) ) { - - // excess is a negative index - match[0] = match[0].slice( 0, excess ); - match[2] = unquoted.slice( 0, excess ); - } - - // Return only captures needed by the pseudo filter method (type and argument) - return match.slice( 0, 3 ); - } - }, - - filter: { - - "TAG": function( nodeNameSelector ) { - var nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase(); - return nodeNameSelector === "*" ? - function() { return true; } : - function( elem ) { - return elem.nodeName && elem.nodeName.toLowerCase() === nodeName; - }; - }, - - "CLASS": function( className ) { - var pattern = classCache[ className + " " ]; - - return pattern || - (pattern = new RegExp( "(^|" + whitespace + ")" + className + "(" + whitespace + "|$)" )) && - classCache( className, function( elem ) { - return pattern.test( typeof elem.className === "string" && elem.className || typeof elem.getAttribute !== strundefined && elem.getAttribute("class") || "" ); - }); - }, - - "ATTR": function( name, operator, check ) { - return function( elem ) { - var result = Sizzle.attr( elem, name ); - - if ( result == null ) { - return operator === "!="; - } - if ( !operator ) { - return true; - } - - result += ""; - - return operator === "=" ? result === check : - operator === "!=" ? result !== check : - operator === "^=" ? check && result.indexOf( check ) === 0 : - operator === "*=" ? check && result.indexOf( check ) > -1 : - operator === "$=" ? check && result.slice( -check.length ) === check : - operator === "~=" ? ( " " + result + " " ).indexOf( check ) > -1 : - operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" : - false; - }; - }, - - "CHILD": function( type, what, argument, first, last ) { - var simple = type.slice( 0, 3 ) !== "nth", - forward = type.slice( -4 ) !== "last", - ofType = what === "of-type"; - - return first === 1 && last === 0 ? - - // Shortcut for :nth-*(n) - function( elem ) { - return !!elem.parentNode; - } : - - function( elem, context, xml ) { - var cache, outerCache, node, diff, nodeIndex, start, - dir = simple !== forward ? "nextSibling" : "previousSibling", - parent = elem.parentNode, - name = ofType && elem.nodeName.toLowerCase(), - useCache = !xml && !ofType; - - if ( parent ) { - - // :(first|last|only)-(child|of-type) - if ( simple ) { - while ( dir ) { - node = elem; - while ( (node = node[ dir ]) ) { - if ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) { - return false; - } - } - // Reverse direction for :only-* (if we haven't yet done so) - start = dir = type === "only" && !start && "nextSibling"; - } - return true; - } - - start = [ forward ? parent.firstChild : parent.lastChild ]; - - // non-xml :nth-child(...) stores cache data on `parent` - if ( forward && useCache ) { - // Seek `elem` from a previously-cached index - outerCache = parent[ expando ] || (parent[ expando ] = {}); - cache = outerCache[ type ] || []; - nodeIndex = cache[0] === dirruns && cache[1]; - diff = cache[0] === dirruns && cache[2]; - node = nodeIndex && parent.childNodes[ nodeIndex ]; - - while ( (node = ++nodeIndex && node && node[ dir ] || - - // Fallback to seeking `elem` from the start - (diff = nodeIndex = 0) || start.pop()) ) { - - // When found, cache indexes on `parent` and break - if ( node.nodeType === 1 && ++diff && node === elem ) { - outerCache[ type ] = [ dirruns, nodeIndex, diff ]; - break; - } - } - - // Use previously-cached element index if available - } else if ( useCache && (cache = (elem[ expando ] || (elem[ expando ] = {}))[ type ]) && cache[0] === dirruns ) { - diff = cache[1]; - - // xml :nth-child(...) or :nth-last-child(...) or :nth(-last)?-of-type(...) - } else { - // Use the same loop as above to seek `elem` from the start - while ( (node = ++nodeIndex && node && node[ dir ] || - (diff = nodeIndex = 0) || start.pop()) ) { - - if ( ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) && ++diff ) { - // Cache the index of each encountered element - if ( useCache ) { - (node[ expando ] || (node[ expando ] = {}))[ type ] = [ dirruns, diff ]; - } - - if ( node === elem ) { - break; - } - } - } - } - - // Incorporate the offset, then check against cycle size - diff -= last; - return diff === first || ( diff % first === 0 && diff / first >= 0 ); - } - }; - }, - - "PSEUDO": function( pseudo, argument ) { - // pseudo-class names are case-insensitive - // http://www.w3.org/TR/selectors/#pseudo-classes - // Prioritize by case sensitivity in case custom pseudos are added with uppercase letters - // Remember that setFilters inherits from pseudos - var args, - fn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] || - Sizzle.error( "unsupported pseudo: " + pseudo ); - - // The user may use createPseudo to indicate that - // arguments are needed to create the filter function - // just as Sizzle does - if ( fn[ expando ] ) { - return fn( argument ); - } - - // But maintain support for old signatures - if ( fn.length > 1 ) { - args = [ pseudo, pseudo, "", argument ]; - return Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ? - markFunction(function( seed, matches ) { - var idx, - matched = fn( seed, argument ), - i = matched.length; - while ( i-- ) { - idx = indexOf.call( seed, matched[i] ); - seed[ idx ] = !( matches[ idx ] = matched[i] ); - } - }) : - function( elem ) { - return fn( elem, 0, args ); - }; - } - - return fn; - } - }, - - pseudos: { - // Potentially complex pseudos - "not": markFunction(function( selector ) { - // Trim the selector passed to compile - // to avoid treating leading and trailing - // spaces as combinators - var input = [], - results = [], - matcher = compile( selector.replace( rtrim, "$1" ) ); - - return matcher[ expando ] ? - markFunction(function( seed, matches, context, xml ) { - var elem, - unmatched = matcher( seed, null, xml, [] ), - i = seed.length; - - // Match elements unmatched by `matcher` - while ( i-- ) { - if ( (elem = unmatched[i]) ) { - seed[i] = !(matches[i] = elem); - } - } - }) : - function( elem, context, xml ) { - input[0] = elem; - matcher( input, null, xml, results ); - return !results.pop(); - }; - }), - - "has": markFunction(function( selector ) { - return function( elem ) { - return Sizzle( selector, elem ).length > 0; - }; - }), - - "contains": markFunction(function( text ) { - return function( elem ) { - return ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1; - }; - }), - - // "Whether an element is represented by a :lang() selector - // is based solely on the element's language value - // being equal to the identifier C, - // or beginning with the identifier C immediately followed by "-". - // The matching of C against the element's language value is performed case-insensitively. - // The identifier C does not have to be a valid language name." - // http://www.w3.org/TR/selectors/#lang-pseudo - "lang": markFunction( function( lang ) { - // lang value must be a valid identifier - if ( !ridentifier.test(lang || "") ) { - Sizzle.error( "unsupported lang: " + lang ); - } - lang = lang.replace( runescape, funescape ).toLowerCase(); - return function( elem ) { - var elemLang; - do { - if ( (elemLang = documentIsHTML ? - elem.lang : - elem.getAttribute("xml:lang") || elem.getAttribute("lang")) ) { - - elemLang = elemLang.toLowerCase(); - return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0; - } - } while ( (elem = elem.parentNode) && elem.nodeType === 1 ); - return false; - }; - }), - - // Miscellaneous - "target": function( elem ) { - var hash = window.location && window.location.hash; - return hash && hash.slice( 1 ) === elem.id; - }, - - "root": function( elem ) { - return elem === docElem; - }, - - "focus": function( elem ) { - return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex); - }, - - // Boolean properties - "enabled": function( elem ) { - return elem.disabled === false; - }, - - "disabled": function( elem ) { - return elem.disabled === true; - }, - - "checked": function( elem ) { - // In CSS3, :checked should return both checked and selected elements - // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked - var nodeName = elem.nodeName.toLowerCase(); - return (nodeName === "input" && !!elem.checked) || (nodeName === "option" && !!elem.selected); - }, - - "selected": function( elem ) { - // Accessing this property makes selected-by-default - // options in Safari work properly - if ( elem.parentNode ) { - elem.parentNode.selectedIndex; - } - - return elem.selected === true; - }, - - // Contents - "empty": function( elem ) { - // http://www.w3.org/TR/selectors/#empty-pseudo - // :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5), - // but not by others (comment: 8; processing instruction: 7; etc.) - // nodeType < 6 works because attributes (2) do not appear as children - for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { - if ( elem.nodeType < 6 ) { - return false; - } - } - return true; - }, - - "parent": function( elem ) { - return !Expr.pseudos["empty"]( elem ); - }, - - // Element/input types - "header": function( elem ) { - return rheader.test( elem.nodeName ); - }, - - "input": function( elem ) { - return rinputs.test( elem.nodeName ); - }, - - "button": function( elem ) { - var name = elem.nodeName.toLowerCase(); - return name === "input" && elem.type === "button" || name === "button"; - }, - - "text": function( elem ) { - var attr; - return elem.nodeName.toLowerCase() === "input" && - elem.type === "text" && - - // Support: IE<8 - // New HTML5 attribute values (e.g., "search") appear with elem.type === "text" - ( (attr = elem.getAttribute("type")) == null || attr.toLowerCase() === "text" ); - }, - - // Position-in-collection - "first": createPositionalPseudo(function() { - return [ 0 ]; - }), - - "last": createPositionalPseudo(function( matchIndexes, length ) { - return [ length - 1 ]; - }), - - "eq": createPositionalPseudo(function( matchIndexes, length, argument ) { - return [ argument < 0 ? argument + length : argument ]; - }), - - "even": createPositionalPseudo(function( matchIndexes, length ) { - var i = 0; - for ( ; i < length; i += 2 ) { - matchIndexes.push( i ); - } - return matchIndexes; - }), - - "odd": createPositionalPseudo(function( matchIndexes, length ) { - var i = 1; - for ( ; i < length; i += 2 ) { - matchIndexes.push( i ); - } - return matchIndexes; - }), - - "lt": createPositionalPseudo(function( matchIndexes, length, argument ) { - var i = argument < 0 ? argument + length : argument; - for ( ; --i >= 0; ) { - matchIndexes.push( i ); - } - return matchIndexes; - }), - - "gt": createPositionalPseudo(function( matchIndexes, length, argument ) { - var i = argument < 0 ? argument + length : argument; - for ( ; ++i < length; ) { - matchIndexes.push( i ); - } - return matchIndexes; - }) - } -}; - -Expr.pseudos["nth"] = Expr.pseudos["eq"]; - -// Add button/input type pseudos -for ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) { - Expr.pseudos[ i ] = createInputPseudo( i ); -} -for ( i in { submit: true, reset: true } ) { - Expr.pseudos[ i ] = createButtonPseudo( i ); -} - -// Easy API for creating new setFilters -function setFilters() {} -setFilters.prototype = Expr.filters = Expr.pseudos; -Expr.setFilters = new setFilters(); - -tokenize = Sizzle.tokenize = function( selector, parseOnly ) { - var matched, match, tokens, type, - soFar, groups, preFilters, - cached = tokenCache[ selector + " " ]; - - if ( cached ) { - return parseOnly ? 0 : cached.slice( 0 ); - } - - soFar = selector; - groups = []; - preFilters = Expr.preFilter; - - while ( soFar ) { - - // Comma and first run - if ( !matched || (match = rcomma.exec( soFar )) ) { - if ( match ) { - // Don't consume trailing commas as valid - soFar = soFar.slice( match[0].length ) || soFar; - } - groups.push( (tokens = []) ); - } - - matched = false; - - // Combinators - if ( (match = rcombinators.exec( soFar )) ) { - matched = match.shift(); - tokens.push({ - value: matched, - // Cast descendant combinators to space - type: match[0].replace( rtrim, " " ) - }); - soFar = soFar.slice( matched.length ); - } - - // Filters - for ( type in Expr.filter ) { - if ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] || - (match = preFilters[ type ]( match ))) ) { - matched = match.shift(); - tokens.push({ - value: matched, - type: type, - matches: match - }); - soFar = soFar.slice( matched.length ); - } - } - - if ( !matched ) { - break; - } - } - - // Return the length of the invalid excess - // if we're just parsing - // Otherwise, throw an error or return tokens - return parseOnly ? - soFar.length : - soFar ? - Sizzle.error( selector ) : - // Cache the tokens - tokenCache( selector, groups ).slice( 0 ); -}; - -function toSelector( tokens ) { - var i = 0, - len = tokens.length, - selector = ""; - for ( ; i < len; i++ ) { - selector += tokens[i].value; - } - return selector; -} - -function addCombinator( matcher, combinator, base ) { - var dir = combinator.dir, - checkNonElements = base && dir === "parentNode", - doneName = done++; - - return combinator.first ? - // Check against closest ancestor/preceding element - function( elem, context, xml ) { - while ( (elem = elem[ dir ]) ) { - if ( elem.nodeType === 1 || checkNonElements ) { - return matcher( elem, context, xml ); - } - } - } : - - // Check against all ancestor/preceding elements - function( elem, context, xml ) { - var oldCache, outerCache, - newCache = [ dirruns, doneName ]; - - // We can't set arbitrary data on XML nodes, so they don't benefit from dir caching - if ( xml ) { - while ( (elem = elem[ dir ]) ) { - if ( elem.nodeType === 1 || checkNonElements ) { - if ( matcher( elem, context, xml ) ) { - return true; - } - } - } - } else { - while ( (elem = elem[ dir ]) ) { - if ( elem.nodeType === 1 || checkNonElements ) { - outerCache = elem[ expando ] || (elem[ expando ] = {}); - if ( (oldCache = outerCache[ dir ]) && - oldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) { - - // Assign to newCache so results back-propagate to previous elements - return (newCache[ 2 ] = oldCache[ 2 ]); - } else { - // Reuse newcache so results back-propagate to previous elements - outerCache[ dir ] = newCache; - - // A match means we're done; a fail means we have to keep checking - if ( (newCache[ 2 ] = matcher( elem, context, xml )) ) { - return true; - } - } - } - } - } - }; -} - -function elementMatcher( matchers ) { - return matchers.length > 1 ? - function( elem, context, xml ) { - var i = matchers.length; - while ( i-- ) { - if ( !matchers[i]( elem, context, xml ) ) { - return false; - } - } - return true; - } : - matchers[0]; -} - -function multipleContexts( selector, contexts, results ) { - var i = 0, - len = contexts.length; - for ( ; i < len; i++ ) { - Sizzle( selector, contexts[i], results ); - } - return results; -} - -function condense( unmatched, map, filter, context, xml ) { - var elem, - newUnmatched = [], - i = 0, - len = unmatched.length, - mapped = map != null; - - for ( ; i < len; i++ ) { - if ( (elem = unmatched[i]) ) { - if ( !filter || filter( elem, context, xml ) ) { - newUnmatched.push( elem ); - if ( mapped ) { - map.push( i ); - } - } - } - } - - return newUnmatched; -} - -function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) { - if ( postFilter && !postFilter[ expando ] ) { - postFilter = setMatcher( postFilter ); - } - if ( postFinder && !postFinder[ expando ] ) { - postFinder = setMatcher( postFinder, postSelector ); - } - return markFunction(function( seed, results, context, xml ) { - var temp, i, elem, - preMap = [], - postMap = [], - preexisting = results.length, - - // Get initial elements from seed or context - elems = seed || multipleContexts( selector || "*", context.nodeType ? [ context ] : context, [] ), - - // Prefilter to get matcher input, preserving a map for seed-results synchronization - matcherIn = preFilter && ( seed || !selector ) ? - condense( elems, preMap, preFilter, context, xml ) : - elems, - - matcherOut = matcher ? - // If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results, - postFinder || ( seed ? preFilter : preexisting || postFilter ) ? - - // ...intermediate processing is necessary - [] : - - // ...otherwise use results directly - results : - matcherIn; - - // Find primary matches - if ( matcher ) { - matcher( matcherIn, matcherOut, context, xml ); - } - - // Apply postFilter - if ( postFilter ) { - temp = condense( matcherOut, postMap ); - postFilter( temp, [], context, xml ); - - // Un-match failing elements by moving them back to matcherIn - i = temp.length; - while ( i-- ) { - if ( (elem = temp[i]) ) { - matcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem); - } - } - } - - if ( seed ) { - if ( postFinder || preFilter ) { - if ( postFinder ) { - // Get the final matcherOut by condensing this intermediate into postFinder contexts - temp = []; - i = matcherOut.length; - while ( i-- ) { - if ( (elem = matcherOut[i]) ) { - // Restore matcherIn since elem is not yet a final match - temp.push( (matcherIn[i] = elem) ); - } - } - postFinder( null, (matcherOut = []), temp, xml ); - } - - // Move matched elements from seed to results to keep them synchronized - i = matcherOut.length; - while ( i-- ) { - if ( (elem = matcherOut[i]) && - (temp = postFinder ? indexOf.call( seed, elem ) : preMap[i]) > -1 ) { - - seed[temp] = !(results[temp] = elem); - } - } - } - - // Add elements to results, through postFinder if defined - } else { - matcherOut = condense( - matcherOut === results ? - matcherOut.splice( preexisting, matcherOut.length ) : - matcherOut - ); - if ( postFinder ) { - postFinder( null, results, matcherOut, xml ); - } else { - push.apply( results, matcherOut ); - } - } - }); -} - -function matcherFromTokens( tokens ) { - var checkContext, matcher, j, - len = tokens.length, - leadingRelative = Expr.relative[ tokens[0].type ], - implicitRelative = leadingRelative || Expr.relative[" "], - i = leadingRelative ? 1 : 0, - - // The foundational matcher ensures that elements are reachable from top-level context(s) - matchContext = addCombinator( function( elem ) { - return elem === checkContext; - }, implicitRelative, true ), - matchAnyContext = addCombinator( function( elem ) { - return indexOf.call( checkContext, elem ) > -1; - }, implicitRelative, true ), - matchers = [ function( elem, context, xml ) { - return ( !leadingRelative && ( xml || context !== outermostContext ) ) || ( - (checkContext = context).nodeType ? - matchContext( elem, context, xml ) : - matchAnyContext( elem, context, xml ) ); - } ]; - - for ( ; i < len; i++ ) { - if ( (matcher = Expr.relative[ tokens[i].type ]) ) { - matchers = [ addCombinator(elementMatcher( matchers ), matcher) ]; - } else { - matcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches ); - - // Return special upon seeing a positional matcher - if ( matcher[ expando ] ) { - // Find the next relative operator (if any) for proper handling - j = ++i; - for ( ; j < len; j++ ) { - if ( Expr.relative[ tokens[j].type ] ) { - break; - } - } - return setMatcher( - i > 1 && elementMatcher( matchers ), - i > 1 && toSelector( - // If the preceding token was a descendant combinator, insert an implicit any-element `*` - tokens.slice( 0, i - 1 ).concat({ value: tokens[ i - 2 ].type === " " ? "*" : "" }) - ).replace( rtrim, "$1" ), - matcher, - i < j && matcherFromTokens( tokens.slice( i, j ) ), - j < len && matcherFromTokens( (tokens = tokens.slice( j )) ), - j < len && toSelector( tokens ) - ); - } - matchers.push( matcher ); - } - } - - return elementMatcher( matchers ); -} - -function matcherFromGroupMatchers( elementMatchers, setMatchers ) { - var bySet = setMatchers.length > 0, - byElement = elementMatchers.length > 0, - superMatcher = function( seed, context, xml, results, outermost ) { - var elem, j, matcher, - matchedCount = 0, - i = "0", - unmatched = seed && [], - setMatched = [], - contextBackup = outermostContext, - // We must always have either seed elements or outermost context - elems = seed || byElement && Expr.find["TAG"]( "*", outermost ), - // Use integer dirruns iff this is the outermost matcher - dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1), - len = elems.length; - - if ( outermost ) { - outermostContext = context !== document && context; - } - - // Add elements passing elementMatchers directly to results - // Keep `i` a string if there are no elements so `matchedCount` will be "00" below - // Support: IE<9, Safari - // Tolerate NodeList properties (IE: "length"; Safari: ) matching elements by id - for ( ; i !== len && (elem = elems[i]) != null; i++ ) { - if ( byElement && elem ) { - j = 0; - while ( (matcher = elementMatchers[j++]) ) { - if ( matcher( elem, context, xml ) ) { - results.push( elem ); - break; - } - } - if ( outermost ) { - dirruns = dirrunsUnique; - } - } - - // Track unmatched elements for set filters - if ( bySet ) { - // They will have gone through all possible matchers - if ( (elem = !matcher && elem) ) { - matchedCount--; - } - - // Lengthen the array for every element, matched or not - if ( seed ) { - unmatched.push( elem ); - } - } - } - - // Apply set filters to unmatched elements - matchedCount += i; - if ( bySet && i !== matchedCount ) { - j = 0; - while ( (matcher = setMatchers[j++]) ) { - matcher( unmatched, setMatched, context, xml ); - } - - if ( seed ) { - // Reintegrate element matches to eliminate the need for sorting - if ( matchedCount > 0 ) { - while ( i-- ) { - if ( !(unmatched[i] || setMatched[i]) ) { - setMatched[i] = pop.call( results ); - } - } - } - - // Discard index placeholder values to get only actual matches - setMatched = condense( setMatched ); - } - - // Add matches to results - push.apply( results, setMatched ); - - // Seedless set matches succeeding multiple successful matchers stipulate sorting - if ( outermost && !seed && setMatched.length > 0 && - ( matchedCount + setMatchers.length ) > 1 ) { - - Sizzle.uniqueSort( results ); - } - } - - // Override manipulation of globals by nested matchers - if ( outermost ) { - dirruns = dirrunsUnique; - outermostContext = contextBackup; - } - - return unmatched; - }; - - return bySet ? - markFunction( superMatcher ) : - superMatcher; -} - -compile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) { - var i, - setMatchers = [], - elementMatchers = [], - cached = compilerCache[ selector + " " ]; - - if ( !cached ) { - // Generate a function of recursive functions that can be used to check each element - if ( !match ) { - match = tokenize( selector ); - } - i = match.length; - while ( i-- ) { - cached = matcherFromTokens( match[i] ); - if ( cached[ expando ] ) { - setMatchers.push( cached ); - } else { - elementMatchers.push( cached ); - } - } - - // Cache the compiled function - cached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) ); - - // Save selector and tokenization - cached.selector = selector; - } - return cached; -}; - -/** - * A low-level selection function that works with Sizzle's compiled - * selector functions - * @param {String|Function} selector A selector or a pre-compiled - * selector function built with Sizzle.compile - * @param {Element} context - * @param {Array} [results] - * @param {Array} [seed] A set of elements to match against - */ -select = Sizzle.select = function( selector, context, results, seed ) { - var i, tokens, token, type, find, - compiled = typeof selector === "function" && selector, - match = !seed && tokenize( (selector = compiled.selector || selector) ); - - results = results || []; - - // Try to minimize operations if there is no seed and only one group - if ( match.length === 1 ) { - - // Take a shortcut and set the context if the root selector is an ID - tokens = match[0] = match[0].slice( 0 ); - if ( tokens.length > 2 && (token = tokens[0]).type === "ID" && - support.getById && context.nodeType === 9 && documentIsHTML && - Expr.relative[ tokens[1].type ] ) { - - context = ( Expr.find["ID"]( token.matches[0].replace(runescape, funescape), context ) || [] )[0]; - if ( !context ) { - return results; - - // Precompiled matchers will still verify ancestry, so step up a level - } else if ( compiled ) { - context = context.parentNode; - } - - selector = selector.slice( tokens.shift().value.length ); - } - - // Fetch a seed set for right-to-left matching - i = matchExpr["needsContext"].test( selector ) ? 0 : tokens.length; - while ( i-- ) { - token = tokens[i]; - - // Abort if we hit a combinator - if ( Expr.relative[ (type = token.type) ] ) { - break; - } - if ( (find = Expr.find[ type ]) ) { - // Search, expanding context for leading sibling combinators - if ( (seed = find( - token.matches[0].replace( runescape, funescape ), - rsibling.test( tokens[0].type ) && testContext( context.parentNode ) || context - )) ) { - - // If seed is empty or no tokens remain, we can return early - tokens.splice( i, 1 ); - selector = seed.length && toSelector( tokens ); - if ( !selector ) { - push.apply( results, seed ); - return results; - } - - break; - } - } - } - } - - // Compile and execute a filtering function if one is not provided - // Provide `match` to avoid retokenization if we modified the selector above - ( compiled || compile( selector, match ) )( - seed, - context, - !documentIsHTML, - results, - rsibling.test( selector ) && testContext( context.parentNode ) || context - ); - return results; -}; - -// One-time assignments - -// Sort stability -support.sortStable = expando.split("").sort( sortOrder ).join("") === expando; - -// Support: Chrome<14 -// Always assume duplicates if they aren't passed to the comparison function -support.detectDuplicates = !!hasDuplicate; - -// Initialize against the default document -setDocument(); - -// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27) -// Detached nodes confoundingly follow *each other* -support.sortDetached = assert(function( div1 ) { - // Should return 1, but returns 4 (following) - return div1.compareDocumentPosition( document.createElement("div") ) & 1; -}); - -// Support: IE<8 -// Prevent attribute/property "interpolation" -// http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx -if ( !assert(function( div ) { - div.innerHTML = ""; - return div.firstChild.getAttribute("href") === "#" ; -}) ) { - addHandle( "type|href|height|width", function( elem, name, isXML ) { - if ( !isXML ) { - return elem.getAttribute( name, name.toLowerCase() === "type" ? 1 : 2 ); - } - }); -} - -// Support: IE<9 -// Use defaultValue in place of getAttribute("value") -if ( !support.attributes || !assert(function( div ) { - div.innerHTML = ""; - div.firstChild.setAttribute( "value", "" ); - return div.firstChild.getAttribute( "value" ) === ""; -}) ) { - addHandle( "value", function( elem, name, isXML ) { - if ( !isXML && elem.nodeName.toLowerCase() === "input" ) { - return elem.defaultValue; - } - }); -} - -// Support: IE<9 -// Use getAttributeNode to fetch booleans when getAttribute lies -if ( !assert(function( div ) { - return div.getAttribute("disabled") == null; -}) ) { - addHandle( booleans, function( elem, name, isXML ) { - var val; - if ( !isXML ) { - return elem[ name ] === true ? name.toLowerCase() : - (val = elem.getAttributeNode( name )) && val.specified ? - val.value : - null; - } - }); -} - -return Sizzle; - -})( window ); - - - -jQuery.find = Sizzle; -jQuery.expr = Sizzle.selectors; -jQuery.expr[":"] = jQuery.expr.pseudos; -jQuery.unique = Sizzle.uniqueSort; -jQuery.text = Sizzle.getText; -jQuery.isXMLDoc = Sizzle.isXML; -jQuery.contains = Sizzle.contains; - - - -var rneedsContext = jQuery.expr.match.needsContext; - -var rsingleTag = (/^<(\w+)\s*\/?>(?:<\/\1>|)$/); - - - -var risSimple = /^.[^:#\[\.,]*$/; - -// Implement the identical functionality for filter and not -function winnow( elements, qualifier, not ) { - if ( jQuery.isFunction( qualifier ) ) { - return jQuery.grep( elements, function( elem, i ) { - /* jshint -W018 */ - return !!qualifier.call( elem, i, elem ) !== not; - }); - - } - - if ( qualifier.nodeType ) { - return jQuery.grep( elements, function( elem ) { - return ( elem === qualifier ) !== not; - }); - - } - - if ( typeof qualifier === "string" ) { - if ( risSimple.test( qualifier ) ) { - return jQuery.filter( qualifier, elements, not ); - } - - qualifier = jQuery.filter( qualifier, elements ); - } - - return jQuery.grep( elements, function( elem ) { - return ( jQuery.inArray( elem, qualifier ) >= 0 ) !== not; - }); -} - -jQuery.filter = function( expr, elems, not ) { - var elem = elems[ 0 ]; - - if ( not ) { - expr = ":not(" + expr + ")"; - } - - return elems.length === 1 && elem.nodeType === 1 ? - jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [] : - jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) { - return elem.nodeType === 1; - })); -}; - -jQuery.fn.extend({ - find: function( selector ) { - var i, - ret = [], - self = this, - len = self.length; - - if ( typeof selector !== "string" ) { - return this.pushStack( jQuery( selector ).filter(function() { - for ( i = 0; i < len; i++ ) { - if ( jQuery.contains( self[ i ], this ) ) { - return true; - } - } - }) ); - } - - for ( i = 0; i < len; i++ ) { - jQuery.find( selector, self[ i ], ret ); - } - - // Needed because $( selector, context ) becomes $( context ).find( selector ) - ret = this.pushStack( len > 1 ? jQuery.unique( ret ) : ret ); - ret.selector = this.selector ? this.selector + " " + selector : selector; - return ret; - }, - filter: function( selector ) { - return this.pushStack( winnow(this, selector || [], false) ); - }, - not: function( selector ) { - return this.pushStack( winnow(this, selector || [], true) ); - }, - is: function( selector ) { - return !!winnow( - this, - - // If this is a positional/relative selector, check membership in the returned set - // so $("p:first").is("p:last") won't return true for a doc with two "p". - typeof selector === "string" && rneedsContext.test( selector ) ? - jQuery( selector ) : - selector || [], - false - ).length; - } -}); - - -// Initialize a jQuery object - - -// A central reference to the root jQuery(document) -var rootjQuery, - - // Use the correct document accordingly with window argument (sandbox) - document = window.document, - - // A simple way to check for HTML strings - // Prioritize #id over to avoid XSS via location.hash (#9521) - // Strict HTML recognition (#11290: must start with <) - rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/, - - init = jQuery.fn.init = function( selector, context ) { - var match, elem; - - // HANDLE: $(""), $(null), $(undefined), $(false) - if ( !selector ) { - return this; - } - - // Handle HTML strings - if ( typeof selector === "string" ) { - if ( selector.charAt(0) === "<" && selector.charAt( selector.length - 1 ) === ">" && selector.length >= 3 ) { - // Assume that strings that start and end with <> are HTML and skip the regex check - match = [ null, selector, null ]; - - } else { - match = rquickExpr.exec( selector ); - } - - // Match html or make sure no context is specified for #id - if ( match && (match[1] || !context) ) { - - // HANDLE: $(html) -> $(array) - if ( match[1] ) { - context = context instanceof jQuery ? context[0] : context; - - // scripts is true for back-compat - // Intentionally let the error be thrown if parseHTML is not present - jQuery.merge( this, jQuery.parseHTML( - match[1], - context && context.nodeType ? context.ownerDocument || context : document, - true - ) ); - - // HANDLE: $(html, props) - if ( rsingleTag.test( match[1] ) && jQuery.isPlainObject( context ) ) { - for ( match in context ) { - // Properties of context are called as methods if possible - if ( jQuery.isFunction( this[ match ] ) ) { - this[ match ]( context[ match ] ); - - // ...and otherwise set as attributes - } else { - this.attr( match, context[ match ] ); - } - } - } - - return this; - - // HANDLE: $(#id) - } else { - elem = document.getElementById( match[2] ); - - // Check parentNode to catch when Blackberry 4.6 returns - // nodes that are no longer in the document #6963 - if ( elem && elem.parentNode ) { - // Handle the case where IE and Opera return items - // by name instead of ID - if ( elem.id !== match[2] ) { - return rootjQuery.find( selector ); - } - - // Otherwise, we inject the element directly into the jQuery object - this.length = 1; - this[0] = elem; - } - - this.context = document; - this.selector = selector; - return this; - } - - // HANDLE: $(expr, $(...)) - } else if ( !context || context.jquery ) { - return ( context || rootjQuery ).find( selector ); - - // HANDLE: $(expr, context) - // (which is just equivalent to: $(context).find(expr) - } else { - return this.constructor( context ).find( selector ); - } - - // HANDLE: $(DOMElement) - } else if ( selector.nodeType ) { - this.context = this[0] = selector; - this.length = 1; - return this; - - // HANDLE: $(function) - // Shortcut for document ready - } else if ( jQuery.isFunction( selector ) ) { - return typeof rootjQuery.ready !== "undefined" ? - rootjQuery.ready( selector ) : - // Execute immediately if ready is not present - selector( jQuery ); - } - - if ( selector.selector !== undefined ) { - this.selector = selector.selector; - this.context = selector.context; - } - - return jQuery.makeArray( selector, this ); - }; - -// Give the init function the jQuery prototype for later instantiation -init.prototype = jQuery.fn; - -// Initialize central reference -rootjQuery = jQuery( document ); - - -var rparentsprev = /^(?:parents|prev(?:Until|All))/, - // methods guaranteed to produce a unique set when starting from a unique set - guaranteedUnique = { - children: true, - contents: true, - next: true, - prev: true - }; - -jQuery.extend({ - dir: function( elem, dir, until ) { - var matched = [], - cur = elem[ dir ]; - - while ( cur && cur.nodeType !== 9 && (until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until )) ) { - if ( cur.nodeType === 1 ) { - matched.push( cur ); - } - cur = cur[dir]; - } - return matched; - }, - - sibling: function( n, elem ) { - var r = []; - - for ( ; n; n = n.nextSibling ) { - if ( n.nodeType === 1 && n !== elem ) { - r.push( n ); - } - } - - return r; - } -}); - -jQuery.fn.extend({ - has: function( target ) { - var i, - targets = jQuery( target, this ), - len = targets.length; - - return this.filter(function() { - for ( i = 0; i < len; i++ ) { - if ( jQuery.contains( this, targets[i] ) ) { - return true; - } - } - }); - }, - - closest: function( selectors, context ) { - var cur, - i = 0, - l = this.length, - matched = [], - pos = rneedsContext.test( selectors ) || typeof selectors !== "string" ? - jQuery( selectors, context || this.context ) : - 0; - - for ( ; i < l; i++ ) { - for ( cur = this[i]; cur && cur !== context; cur = cur.parentNode ) { - // Always skip document fragments - if ( cur.nodeType < 11 && (pos ? - pos.index(cur) > -1 : - - // Don't pass non-elements to Sizzle - cur.nodeType === 1 && - jQuery.find.matchesSelector(cur, selectors)) ) { - - matched.push( cur ); - break; - } - } - } - - return this.pushStack( matched.length > 1 ? jQuery.unique( matched ) : matched ); - }, - - // Determine the position of an element within - // the matched set of elements - index: function( elem ) { - - // No argument, return index in parent - if ( !elem ) { - return ( this[0] && this[0].parentNode ) ? this.first().prevAll().length : -1; - } - - // index in selector - if ( typeof elem === "string" ) { - return jQuery.inArray( this[0], jQuery( elem ) ); - } - - // Locate the position of the desired element - return jQuery.inArray( - // If it receives a jQuery object, the first element is used - elem.jquery ? elem[0] : elem, this ); - }, - - add: function( selector, context ) { - return this.pushStack( - jQuery.unique( - jQuery.merge( this.get(), jQuery( selector, context ) ) - ) - ); - }, - - addBack: function( selector ) { - return this.add( selector == null ? - this.prevObject : this.prevObject.filter(selector) - ); - } -}); - -function sibling( cur, dir ) { - do { - cur = cur[ dir ]; - } while ( cur && cur.nodeType !== 1 ); - - return cur; -} - -jQuery.each({ - parent: function( elem ) { - var parent = elem.parentNode; - return parent && parent.nodeType !== 11 ? parent : null; - }, - parents: function( elem ) { - return jQuery.dir( elem, "parentNode" ); - }, - parentsUntil: function( elem, i, until ) { - return jQuery.dir( elem, "parentNode", until ); - }, - next: function( elem ) { - return sibling( elem, "nextSibling" ); - }, - prev: function( elem ) { - return sibling( elem, "previousSibling" ); - }, - nextAll: function( elem ) { - return jQuery.dir( elem, "nextSibling" ); - }, - prevAll: function( elem ) { - return jQuery.dir( elem, "previousSibling" ); - }, - nextUntil: function( elem, i, until ) { - return jQuery.dir( elem, "nextSibling", until ); - }, - prevUntil: function( elem, i, until ) { - return jQuery.dir( elem, "previousSibling", until ); - }, - siblings: function( elem ) { - return jQuery.sibling( ( elem.parentNode || {} ).firstChild, elem ); - }, - children: function( elem ) { - return jQuery.sibling( elem.firstChild ); - }, - contents: function( elem ) { - return jQuery.nodeName( elem, "iframe" ) ? - elem.contentDocument || elem.contentWindow.document : - jQuery.merge( [], elem.childNodes ); - } -}, function( name, fn ) { - jQuery.fn[ name ] = function( until, selector ) { - var ret = jQuery.map( this, fn, until ); - - if ( name.slice( -5 ) !== "Until" ) { - selector = until; - } - - if ( selector && typeof selector === "string" ) { - ret = jQuery.filter( selector, ret ); - } - - if ( this.length > 1 ) { - // Remove duplicates - if ( !guaranteedUnique[ name ] ) { - ret = jQuery.unique( ret ); - } - - // Reverse order for parents* and prev-derivatives - if ( rparentsprev.test( name ) ) { - ret = ret.reverse(); - } - } - - return this.pushStack( ret ); - }; -}); -var rnotwhite = (/\S+/g); - - - -// String to Object options format cache -var optionsCache = {}; - -// Convert String-formatted options into Object-formatted ones and store in cache -function createOptions( options ) { - var object = optionsCache[ options ] = {}; - jQuery.each( options.match( rnotwhite ) || [], function( _, flag ) { - object[ flag ] = true; - }); - return object; -} - -/* - * Create a callback list using the following parameters: - * - * options: an optional list of space-separated options that will change how - * the callback list behaves or a more traditional option object - * - * By default a callback list will act like an event callback list and can be - * "fired" multiple times. - * - * Possible options: - * - * once: will ensure the callback list can only be fired once (like a Deferred) - * - * memory: will keep track of previous values and will call any callback added - * after the list has been fired right away with the latest "memorized" - * values (like a Deferred) - * - * unique: will ensure a callback can only be added once (no duplicate in the list) - * - * stopOnFalse: interrupt callings when a callback returns false - * - */ -jQuery.Callbacks = function( options ) { - - // Convert options from String-formatted to Object-formatted if needed - // (we check in cache first) - options = typeof options === "string" ? - ( optionsCache[ options ] || createOptions( options ) ) : - jQuery.extend( {}, options ); - - var // Flag to know if list is currently firing - firing, - // Last fire value (for non-forgettable lists) - memory, - // Flag to know if list was already fired - fired, - // End of the loop when firing - firingLength, - // Index of currently firing callback (modified by remove if needed) - firingIndex, - // First callback to fire (used internally by add and fireWith) - firingStart, - // Actual callback list - list = [], - // Stack of fire calls for repeatable lists - stack = !options.once && [], - // Fire callbacks - fire = function( data ) { - memory = options.memory && data; - fired = true; - firingIndex = firingStart || 0; - firingStart = 0; - firingLength = list.length; - firing = true; - for ( ; list && firingIndex < firingLength; firingIndex++ ) { - if ( list[ firingIndex ].apply( data[ 0 ], data[ 1 ] ) === false && options.stopOnFalse ) { - memory = false; // To prevent further calls using add - break; - } - } - firing = false; - if ( list ) { - if ( stack ) { - if ( stack.length ) { - fire( stack.shift() ); - } - } else if ( memory ) { - list = []; - } else { - self.disable(); - } - } - }, - // Actual Callbacks object - self = { - // Add a callback or a collection of callbacks to the list - add: function() { - if ( list ) { - // First, we save the current length - var start = list.length; - (function add( args ) { - jQuery.each( args, function( _, arg ) { - var type = jQuery.type( arg ); - if ( type === "function" ) { - if ( !options.unique || !self.has( arg ) ) { - list.push( arg ); - } - } else if ( arg && arg.length && type !== "string" ) { - // Inspect recursively - add( arg ); - } - }); - })( arguments ); - // Do we need to add the callbacks to the - // current firing batch? - if ( firing ) { - firingLength = list.length; - // With memory, if we're not firing then - // we should call right away - } else if ( memory ) { - firingStart = start; - fire( memory ); - } - } - return this; - }, - // Remove a callback from the list - remove: function() { - if ( list ) { - jQuery.each( arguments, function( _, arg ) { - var index; - while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { - list.splice( index, 1 ); - // Handle firing indexes - if ( firing ) { - if ( index <= firingLength ) { - firingLength--; - } - if ( index <= firingIndex ) { - firingIndex--; - } - } - } - }); - } - return this; - }, - // Check if a given callback is in the list. - // If no argument is given, return whether or not list has callbacks attached. - has: function( fn ) { - return fn ? jQuery.inArray( fn, list ) > -1 : !!( list && list.length ); - }, - // Remove all callbacks from the list - empty: function() { - list = []; - firingLength = 0; - return this; - }, - // Have the list do nothing anymore - disable: function() { - list = stack = memory = undefined; - return this; - }, - // Is it disabled? - disabled: function() { - return !list; - }, - // Lock the list in its current state - lock: function() { - stack = undefined; - if ( !memory ) { - self.disable(); - } - return this; - }, - // Is it locked? - locked: function() { - return !stack; - }, - // Call all callbacks with the given context and arguments - fireWith: function( context, args ) { - if ( list && ( !fired || stack ) ) { - args = args || []; - args = [ context, args.slice ? args.slice() : args ]; - if ( firing ) { - stack.push( args ); - } else { - fire( args ); - } - } - return this; - }, - // Call all the callbacks with the given arguments - fire: function() { - self.fireWith( this, arguments ); - return this; - }, - // To know if the callbacks have already been called at least once - fired: function() { - return !!fired; - } - }; - - return self; -}; - - -jQuery.extend({ - - Deferred: function( func ) { - var tuples = [ - // action, add listener, listener list, final state - [ "resolve", "done", jQuery.Callbacks("once memory"), "resolved" ], - [ "reject", "fail", jQuery.Callbacks("once memory"), "rejected" ], - [ "notify", "progress", jQuery.Callbacks("memory") ] - ], - state = "pending", - promise = { - state: function() { - return state; - }, - always: function() { - deferred.done( arguments ).fail( arguments ); - return this; - }, - then: function( /* fnDone, fnFail, fnProgress */ ) { - var fns = arguments; - return jQuery.Deferred(function( newDefer ) { - jQuery.each( tuples, function( i, tuple ) { - var fn = jQuery.isFunction( fns[ i ] ) && fns[ i ]; - // deferred[ done | fail | progress ] for forwarding actions to newDefer - deferred[ tuple[1] ](function() { - var returned = fn && fn.apply( this, arguments ); - if ( returned && jQuery.isFunction( returned.promise ) ) { - returned.promise() - .done( newDefer.resolve ) - .fail( newDefer.reject ) - .progress( newDefer.notify ); - } else { - newDefer[ tuple[ 0 ] + "With" ]( this === promise ? newDefer.promise() : this, fn ? [ returned ] : arguments ); - } - }); - }); - fns = null; - }).promise(); - }, - // Get a promise for this deferred - // If obj is provided, the promise aspect is added to the object - promise: function( obj ) { - return obj != null ? jQuery.extend( obj, promise ) : promise; - } - }, - deferred = {}; - - // Keep pipe for back-compat - promise.pipe = promise.then; - - // Add list-specific methods - jQuery.each( tuples, function( i, tuple ) { - var list = tuple[ 2 ], - stateString = tuple[ 3 ]; - - // promise[ done | fail | progress ] = list.add - promise[ tuple[1] ] = list.add; - - // Handle state - if ( stateString ) { - list.add(function() { - // state = [ resolved | rejected ] - state = stateString; - - // [ reject_list | resolve_list ].disable; progress_list.lock - }, tuples[ i ^ 1 ][ 2 ].disable, tuples[ 2 ][ 2 ].lock ); - } - - // deferred[ resolve | reject | notify ] - deferred[ tuple[0] ] = function() { - deferred[ tuple[0] + "With" ]( this === deferred ? promise : this, arguments ); - return this; - }; - deferred[ tuple[0] + "With" ] = list.fireWith; - }); - - // Make the deferred a promise - promise.promise( deferred ); - - // Call given func if any - if ( func ) { - func.call( deferred, deferred ); - } - - // All done! - return deferred; - }, - - // Deferred helper - when: function( subordinate /* , ..., subordinateN */ ) { - var i = 0, - resolveValues = slice.call( arguments ), - length = resolveValues.length, - - // the count of uncompleted subordinates - remaining = length !== 1 || ( subordinate && jQuery.isFunction( subordinate.promise ) ) ? length : 0, - - // the master Deferred. If resolveValues consist of only a single Deferred, just use that. - deferred = remaining === 1 ? subordinate : jQuery.Deferred(), - - // Update function for both resolve and progress values - updateFunc = function( i, contexts, values ) { - return function( value ) { - contexts[ i ] = this; - values[ i ] = arguments.length > 1 ? slice.call( arguments ) : value; - if ( values === progressValues ) { - deferred.notifyWith( contexts, values ); - - } else if ( !(--remaining) ) { - deferred.resolveWith( contexts, values ); - } - }; - }, - - progressValues, progressContexts, resolveContexts; - - // add listeners to Deferred subordinates; treat others as resolved - if ( length > 1 ) { - progressValues = new Array( length ); - progressContexts = new Array( length ); - resolveContexts = new Array( length ); - for ( ; i < length; i++ ) { - if ( resolveValues[ i ] && jQuery.isFunction( resolveValues[ i ].promise ) ) { - resolveValues[ i ].promise() - .done( updateFunc( i, resolveContexts, resolveValues ) ) - .fail( deferred.reject ) - .progress( updateFunc( i, progressContexts, progressValues ) ); - } else { - --remaining; - } - } - } - - // if we're not waiting on anything, resolve the master - if ( !remaining ) { - deferred.resolveWith( resolveContexts, resolveValues ); - } - - return deferred.promise(); - } -}); - - -// The deferred used on DOM ready -var readyList; - -jQuery.fn.ready = function( fn ) { - // Add the callback - jQuery.ready.promise().done( fn ); - - return this; -}; - -jQuery.extend({ - // Is the DOM ready to be used? Set to true once it occurs. - isReady: false, - - // A counter to track how many items to wait for before - // the ready event fires. See #6781 - readyWait: 1, - - // Hold (or release) the ready event - holdReady: function( hold ) { - if ( hold ) { - jQuery.readyWait++; - } else { - jQuery.ready( true ); - } - }, - - // Handle when the DOM is ready - ready: function( wait ) { - - // Abort if there are pending holds or we're already ready - if ( wait === true ? --jQuery.readyWait : jQuery.isReady ) { - return; - } - - // Make sure body exists, at least, in case IE gets a little overzealous (ticket #5443). - if ( !document.body ) { - return setTimeout( jQuery.ready ); - } - - // Remember that the DOM is ready - jQuery.isReady = true; - - // If a normal DOM Ready event fired, decrement, and wait if need be - if ( wait !== true && --jQuery.readyWait > 0 ) { - return; - } - - // If there are functions bound, to execute - readyList.resolveWith( document, [ jQuery ] ); - - // Trigger any bound ready events - if ( jQuery.fn.triggerHandler ) { - jQuery( document ).triggerHandler( "ready" ); - jQuery( document ).off( "ready" ); - } - } -}); - -/** - * Clean-up method for dom ready events - */ -function detach() { - if ( document.addEventListener ) { - document.removeEventListener( "DOMContentLoaded", completed, false ); - window.removeEventListener( "load", completed, false ); - - } else { - document.detachEvent( "onreadystatechange", completed ); - window.detachEvent( "onload", completed ); - } -} - -/** - * The ready event handler and self cleanup method - */ -function completed() { - // readyState === "complete" is good enough for us to call the dom ready in oldIE - if ( document.addEventListener || event.type === "load" || document.readyState === "complete" ) { - detach(); - jQuery.ready(); - } -} - -jQuery.ready.promise = function( obj ) { - if ( !readyList ) { - - readyList = jQuery.Deferred(); - - // Catch cases where $(document).ready() is called after the browser event has already occurred. - // we once tried to use readyState "interactive" here, but it caused issues like the one - // discovered by ChrisS here: http://bugs.jquery.com/ticket/12282#comment:15 - if ( document.readyState === "complete" ) { - // Handle it asynchronously to allow scripts the opportunity to delay ready - setTimeout( jQuery.ready ); - - // Standards-based browsers support DOMContentLoaded - } else if ( document.addEventListener ) { - // Use the handy event callback - document.addEventListener( "DOMContentLoaded", completed, false ); - - // A fallback to window.onload, that will always work - window.addEventListener( "load", completed, false ); - - // If IE event model is used - } else { - // Ensure firing before onload, maybe late but safe also for iframes - document.attachEvent( "onreadystatechange", completed ); - - // A fallback to window.onload, that will always work - window.attachEvent( "onload", completed ); - - // If IE and not a frame - // continually check to see if the document is ready - var top = false; - - try { - top = window.frameElement == null && document.documentElement; - } catch(e) {} - - if ( top && top.doScroll ) { - (function doScrollCheck() { - if ( !jQuery.isReady ) { - - try { - // Use the trick by Diego Perini - // http://javascript.nwbox.com/IEContentLoaded/ - top.doScroll("left"); - } catch(e) { - return setTimeout( doScrollCheck, 50 ); - } - - // detach all dom ready events - detach(); - - // and execute any waiting functions - jQuery.ready(); - } - })(); - } - } - } - return readyList.promise( obj ); -}; - - -var strundefined = typeof undefined; - - - -// Support: IE<9 -// Iteration over object's inherited properties before its own -var i; -for ( i in jQuery( support ) ) { - break; -} -support.ownLast = i !== "0"; - -// Note: most support tests are defined in their respective modules. -// false until the test is run -support.inlineBlockNeedsLayout = false; - -// Execute ASAP in case we need to set body.style.zoom -jQuery(function() { - // Minified: var a,b,c,d - var val, div, body, container; - - body = document.getElementsByTagName( "body" )[ 0 ]; - if ( !body || !body.style ) { - // Return for frameset docs that don't have a body - return; - } - - // Setup - div = document.createElement( "div" ); - container = document.createElement( "div" ); - container.style.cssText = "position:absolute;border:0;width:0;height:0;top:0;left:-9999px"; - body.appendChild( container ).appendChild( div ); - - if ( typeof div.style.zoom !== strundefined ) { - // Support: IE<8 - // Check if natively block-level elements act like inline-block - // elements when setting their display to 'inline' and giving - // them layout - div.style.cssText = "display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1"; - - support.inlineBlockNeedsLayout = val = div.offsetWidth === 3; - if ( val ) { - // Prevent IE 6 from affecting layout for positioned elements #11048 - // Prevent IE from shrinking the body in IE 7 mode #12869 - // Support: IE<8 - body.style.zoom = 1; - } - } - - body.removeChild( container ); -}); - - - - -(function() { - var div = document.createElement( "div" ); - - // Execute the test only if not already executed in another module. - if (support.deleteExpando == null) { - // Support: IE<9 - support.deleteExpando = true; - try { - delete div.test; - } catch( e ) { - support.deleteExpando = false; - } - } - - // Null elements to avoid leaks in IE. - div = null; -})(); - - -/** - * Determines whether an object can have data - */ -jQuery.acceptData = function( elem ) { - var noData = jQuery.noData[ (elem.nodeName + " ").toLowerCase() ], - nodeType = +elem.nodeType || 1; - - // Do not set data on non-element DOM nodes because it will not be cleared (#8335). - return nodeType !== 1 && nodeType !== 9 ? - false : - - // Nodes accept data unless otherwise specified; rejection can be conditional - !noData || noData !== true && elem.getAttribute("classid") === noData; -}; - - -var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, - rmultiDash = /([A-Z])/g; - -function dataAttr( elem, key, data ) { - // If nothing was found internally, try to fetch any - // data from the HTML5 data-* attribute - if ( data === undefined && elem.nodeType === 1 ) { - - var name = "data-" + key.replace( rmultiDash, "-$1" ).toLowerCase(); - - data = elem.getAttribute( name ); - - if ( typeof data === "string" ) { - try { - data = data === "true" ? true : - data === "false" ? false : - data === "null" ? null : - // Only convert to a number if it doesn't change the string - +data + "" === data ? +data : - rbrace.test( data ) ? jQuery.parseJSON( data ) : - data; - } catch( e ) {} - - // Make sure we set the data so it isn't changed later - jQuery.data( elem, key, data ); - - } else { - data = undefined; - } - } - - return data; -} - -// checks a cache object for emptiness -function isEmptyDataObject( obj ) { - var name; - for ( name in obj ) { - - // if the public data object is empty, the private is still empty - if ( name === "data" && jQuery.isEmptyObject( obj[name] ) ) { - continue; - } - if ( name !== "toJSON" ) { - return false; - } - } - - return true; -} - -function internalData( elem, name, data, pvt /* Internal Use Only */ ) { - if ( !jQuery.acceptData( elem ) ) { - return; - } - - var ret, thisCache, - internalKey = jQuery.expando, - - // We have to handle DOM nodes and JS objects differently because IE6-7 - // can't GC object references properly across the DOM-JS boundary - isNode = elem.nodeType, - - // Only DOM nodes need the global jQuery cache; JS object data is - // attached directly to the object so GC can occur automatically - cache = isNode ? jQuery.cache : elem, - - // Only defining an ID for JS objects if its cache already exists allows - // the code to shortcut on the same path as a DOM node with no cache - id = isNode ? elem[ internalKey ] : elem[ internalKey ] && internalKey; - - // Avoid doing any more work than we need to when trying to get data on an - // object that has no data at all - if ( (!id || !cache[id] || (!pvt && !cache[id].data)) && data === undefined && typeof name === "string" ) { - return; - } - - if ( !id ) { - // Only DOM nodes need a new unique ID for each element since their data - // ends up in the global cache - if ( isNode ) { - id = elem[ internalKey ] = deletedIds.pop() || jQuery.guid++; - } else { - id = internalKey; - } - } - - if ( !cache[ id ] ) { - // Avoid exposing jQuery metadata on plain JS objects when the object - // is serialized using JSON.stringify - cache[ id ] = isNode ? {} : { toJSON: jQuery.noop }; - } - - // An object can be passed to jQuery.data instead of a key/value pair; this gets - // shallow copied over onto the existing cache - if ( typeof name === "object" || typeof name === "function" ) { - if ( pvt ) { - cache[ id ] = jQuery.extend( cache[ id ], name ); - } else { - cache[ id ].data = jQuery.extend( cache[ id ].data, name ); - } - } - - thisCache = cache[ id ]; - - // jQuery data() is stored in a separate object inside the object's internal data - // cache in order to avoid key collisions between internal data and user-defined - // data. - if ( !pvt ) { - if ( !thisCache.data ) { - thisCache.data = {}; - } - - thisCache = thisCache.data; - } - - if ( data !== undefined ) { - thisCache[ jQuery.camelCase( name ) ] = data; - } - - // Check for both converted-to-camel and non-converted data property names - // If a data property was specified - if ( typeof name === "string" ) { - - // First Try to find as-is property data - ret = thisCache[ name ]; - - // Test for null|undefined property data - if ( ret == null ) { - - // Try to find the camelCased property - ret = thisCache[ jQuery.camelCase( name ) ]; - } - } else { - ret = thisCache; - } - - return ret; -} - -function internalRemoveData( elem, name, pvt ) { - if ( !jQuery.acceptData( elem ) ) { - return; - } - - var thisCache, i, - isNode = elem.nodeType, - - // See jQuery.data for more information - cache = isNode ? jQuery.cache : elem, - id = isNode ? elem[ jQuery.expando ] : jQuery.expando; - - // If there is already no cache entry for this object, there is no - // purpose in continuing - if ( !cache[ id ] ) { - return; - } - - if ( name ) { - - thisCache = pvt ? cache[ id ] : cache[ id ].data; - - if ( thisCache ) { - - // Support array or space separated string names for data keys - if ( !jQuery.isArray( name ) ) { - - // try the string as a key before any manipulation - if ( name in thisCache ) { - name = [ name ]; - } else { - - // split the camel cased version by spaces unless a key with the spaces exists - name = jQuery.camelCase( name ); - if ( name in thisCache ) { - name = [ name ]; - } else { - name = name.split(" "); - } - } - } else { - // If "name" is an array of keys... - // When data is initially created, via ("key", "val") signature, - // keys will be converted to camelCase. - // Since there is no way to tell _how_ a key was added, remove - // both plain key and camelCase key. #12786 - // This will only penalize the array argument path. - name = name.concat( jQuery.map( name, jQuery.camelCase ) ); - } - - i = name.length; - while ( i-- ) { - delete thisCache[ name[i] ]; - } - - // If there is no data left in the cache, we want to continue - // and let the cache object itself get destroyed - if ( pvt ? !isEmptyDataObject(thisCache) : !jQuery.isEmptyObject(thisCache) ) { - return; - } - } - } - - // See jQuery.data for more information - if ( !pvt ) { - delete cache[ id ].data; - - // Don't destroy the parent cache unless the internal data object - // had been the only thing left in it - if ( !isEmptyDataObject( cache[ id ] ) ) { - return; - } - } - - // Destroy the cache - if ( isNode ) { - jQuery.cleanData( [ elem ], true ); - - // Use delete when supported for expandos or `cache` is not a window per isWindow (#10080) - /* jshint eqeqeq: false */ - } else if ( support.deleteExpando || cache != cache.window ) { - /* jshint eqeqeq: true */ - delete cache[ id ]; - - // When all else fails, null - } else { - cache[ id ] = null; - } -} - -jQuery.extend({ - cache: {}, - - // The following elements (space-suffixed to avoid Object.prototype collisions) - // throw uncatchable exceptions if you attempt to set expando properties - noData: { - "applet ": true, - "embed ": true, - // ...but Flash objects (which have this classid) *can* handle expandos - "object ": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" - }, - - hasData: function( elem ) { - elem = elem.nodeType ? jQuery.cache[ elem[jQuery.expando] ] : elem[ jQuery.expando ]; - return !!elem && !isEmptyDataObject( elem ); - }, - - data: function( elem, name, data ) { - return internalData( elem, name, data ); - }, - - removeData: function( elem, name ) { - return internalRemoveData( elem, name ); - }, - - // For internal use only. - _data: function( elem, name, data ) { - return internalData( elem, name, data, true ); - }, - - _removeData: function( elem, name ) { - return internalRemoveData( elem, name, true ); - } -}); - -jQuery.fn.extend({ - data: function( key, value ) { - var i, name, data, - elem = this[0], - attrs = elem && elem.attributes; - - // Special expections of .data basically thwart jQuery.access, - // so implement the relevant behavior ourselves - - // Gets all values - if ( key === undefined ) { - if ( this.length ) { - data = jQuery.data( elem ); - - if ( elem.nodeType === 1 && !jQuery._data( elem, "parsedAttrs" ) ) { - i = attrs.length; - while ( i-- ) { - - // Support: IE11+ - // The attrs elements can be null (#14894) - if ( attrs[ i ] ) { - name = attrs[ i ].name; - if ( name.indexOf( "data-" ) === 0 ) { - name = jQuery.camelCase( name.slice(5) ); - dataAttr( elem, name, data[ name ] ); - } - } - } - jQuery._data( elem, "parsedAttrs", true ); - } - } - - return data; - } - - // Sets multiple values - if ( typeof key === "object" ) { - return this.each(function() { - jQuery.data( this, key ); - }); - } - - return arguments.length > 1 ? - - // Sets one value - this.each(function() { - jQuery.data( this, key, value ); - }) : - - // Gets one value - // Try to fetch any internally stored data first - elem ? dataAttr( elem, key, jQuery.data( elem, key ) ) : undefined; - }, - - removeData: function( key ) { - return this.each(function() { - jQuery.removeData( this, key ); - }); - } -}); - - -jQuery.extend({ - queue: function( elem, type, data ) { - var queue; - - if ( elem ) { - type = ( type || "fx" ) + "queue"; - queue = jQuery._data( elem, type ); - - // Speed up dequeue by getting out quickly if this is just a lookup - if ( data ) { - if ( !queue || jQuery.isArray(data) ) { - queue = jQuery._data( elem, type, jQuery.makeArray(data) ); - } else { - queue.push( data ); - } - } - return queue || []; - } - }, - - dequeue: function( elem, type ) { - type = type || "fx"; - - var queue = jQuery.queue( elem, type ), - startLength = queue.length, - fn = queue.shift(), - hooks = jQuery._queueHooks( elem, type ), - next = function() { - jQuery.dequeue( elem, type ); - }; - - // If the fx queue is dequeued, always remove the progress sentinel - if ( fn === "inprogress" ) { - fn = queue.shift(); - startLength--; - } - - if ( fn ) { - - // Add a progress sentinel to prevent the fx queue from being - // automatically dequeued - if ( type === "fx" ) { - queue.unshift( "inprogress" ); - } - - // clear up the last queue stop function - delete hooks.stop; - fn.call( elem, next, hooks ); - } - - if ( !startLength && hooks ) { - hooks.empty.fire(); - } - }, - - // not intended for public consumption - generates a queueHooks object, or returns the current one - _queueHooks: function( elem, type ) { - var key = type + "queueHooks"; - return jQuery._data( elem, key ) || jQuery._data( elem, key, { - empty: jQuery.Callbacks("once memory").add(function() { - jQuery._removeData( elem, type + "queue" ); - jQuery._removeData( elem, key ); - }) - }); - } -}); - -jQuery.fn.extend({ - queue: function( type, data ) { - var setter = 2; - - if ( typeof type !== "string" ) { - data = type; - type = "fx"; - setter--; - } - - if ( arguments.length < setter ) { - return jQuery.queue( this[0], type ); - } - - return data === undefined ? - this : - this.each(function() { - var queue = jQuery.queue( this, type, data ); - - // ensure a hooks for this queue - jQuery._queueHooks( this, type ); - - if ( type === "fx" && queue[0] !== "inprogress" ) { - jQuery.dequeue( this, type ); - } - }); - }, - dequeue: function( type ) { - return this.each(function() { - jQuery.dequeue( this, type ); - }); - }, - clearQueue: function( type ) { - return this.queue( type || "fx", [] ); - }, - // Get a promise resolved when queues of a certain type - // are emptied (fx is the type by default) - promise: function( type, obj ) { - var tmp, - count = 1, - defer = jQuery.Deferred(), - elements = this, - i = this.length, - resolve = function() { - if ( !( --count ) ) { - defer.resolveWith( elements, [ elements ] ); - } - }; - - if ( typeof type !== "string" ) { - obj = type; - type = undefined; - } - type = type || "fx"; - - while ( i-- ) { - tmp = jQuery._data( elements[ i ], type + "queueHooks" ); - if ( tmp && tmp.empty ) { - count++; - tmp.empty.add( resolve ); - } - } - resolve(); - return defer.promise( obj ); - } -}); -var pnum = (/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/).source; - -var cssExpand = [ "Top", "Right", "Bottom", "Left" ]; - -var isHidden = function( elem, el ) { - // isHidden might be called from jQuery#filter function; - // in that case, element will be second argument - elem = el || elem; - return jQuery.css( elem, "display" ) === "none" || !jQuery.contains( elem.ownerDocument, elem ); - }; - - - -// Multifunctional method to get and set values of a collection -// The value/s can optionally be executed if it's a function -var access = jQuery.access = function( elems, fn, key, value, chainable, emptyGet, raw ) { - var i = 0, - length = elems.length, - bulk = key == null; - - // Sets many values - if ( jQuery.type( key ) === "object" ) { - chainable = true; - for ( i in key ) { - jQuery.access( elems, fn, i, key[i], true, emptyGet, raw ); - } - - // Sets one value - } else if ( value !== undefined ) { - chainable = true; - - if ( !jQuery.isFunction( value ) ) { - raw = true; - } - - if ( bulk ) { - // Bulk operations run against the entire set - if ( raw ) { - fn.call( elems, value ); - fn = null; - - // ...except when executing function values - } else { - bulk = fn; - fn = function( elem, key, value ) { - return bulk.call( jQuery( elem ), value ); - }; - } - } - - if ( fn ) { - for ( ; i < length; i++ ) { - fn( elems[i], key, raw ? value : value.call( elems[i], i, fn( elems[i], key ) ) ); - } - } - } - - return chainable ? - elems : - - // Gets - bulk ? - fn.call( elems ) : - length ? fn( elems[0], key ) : emptyGet; -}; -var rcheckableType = (/^(?:checkbox|radio)$/i); - - - -(function() { - // Minified: var a,b,c - var input = document.createElement( "input" ), - div = document.createElement( "div" ), - fragment = document.createDocumentFragment(); - - // Setup - div.innerHTML = "
a"; - - // IE strips leading whitespace when .innerHTML is used - support.leadingWhitespace = div.firstChild.nodeType === 3; - - // Make sure that tbody elements aren't automatically inserted - // IE will insert them into empty tables - support.tbody = !div.getElementsByTagName( "tbody" ).length; - - // Make sure that link elements get serialized correctly by innerHTML - // This requires a wrapper element in IE - support.htmlSerialize = !!div.getElementsByTagName( "link" ).length; - - // Makes sure cloning an html5 element does not cause problems - // Where outerHTML is undefined, this still works - support.html5Clone = - document.createElement( "nav" ).cloneNode( true ).outerHTML !== "<:nav>"; - - // Check if a disconnected checkbox will retain its checked - // value of true after appended to the DOM (IE6/7) - input.type = "checkbox"; - input.checked = true; - fragment.appendChild( input ); - support.appendChecked = input.checked; - - // Make sure textarea (and checkbox) defaultValue is properly cloned - // Support: IE6-IE11+ - div.innerHTML = ""; - support.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue; - - // #11217 - WebKit loses check when the name is after the checked attribute - fragment.appendChild( div ); - div.innerHTML = ""; - - // Support: Safari 5.1, iOS 5.1, Android 4.x, Android 2.3 - // old WebKit doesn't clone checked state correctly in fragments - support.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked; - - // Support: IE<9 - // Opera does not clone events (and typeof div.attachEvent === undefined). - // IE9-10 clones events bound via attachEvent, but they don't trigger with .click() - support.noCloneEvent = true; - if ( div.attachEvent ) { - div.attachEvent( "onclick", function() { - support.noCloneEvent = false; - }); - - div.cloneNode( true ).click(); - } - - // Execute the test only if not already executed in another module. - if (support.deleteExpando == null) { - // Support: IE<9 - support.deleteExpando = true; - try { - delete div.test; - } catch( e ) { - support.deleteExpando = false; - } - } -})(); - - -(function() { - var i, eventName, - div = document.createElement( "div" ); - - // Support: IE<9 (lack submit/change bubble), Firefox 23+ (lack focusin event) - for ( i in { submit: true, change: true, focusin: true }) { - eventName = "on" + i; - - if ( !(support[ i + "Bubbles" ] = eventName in window) ) { - // Beware of CSP restrictions (https://developer.mozilla.org/en/Security/CSP) - div.setAttribute( eventName, "t" ); - support[ i + "Bubbles" ] = div.attributes[ eventName ].expando === false; - } - } - - // Null elements to avoid leaks in IE. - div = null; -})(); - - -var rformElems = /^(?:input|select|textarea)$/i, - rkeyEvent = /^key/, - rmouseEvent = /^(?:mouse|pointer|contextmenu)|click/, - rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, - rtypenamespace = /^([^.]*)(?:\.(.+)|)$/; - -function returnTrue() { - return true; -} - -function returnFalse() { - return false; -} - -function safeActiveElement() { - try { - return document.activeElement; - } catch ( err ) { } -} - -/* - * Helper functions for managing events -- not part of the public interface. - * Props to Dean Edwards' addEvent library for many of the ideas. - */ -jQuery.event = { - - global: {}, - - add: function( elem, types, handler, data, selector ) { - var tmp, events, t, handleObjIn, - special, eventHandle, handleObj, - handlers, type, namespaces, origType, - elemData = jQuery._data( elem ); - - // Don't attach events to noData or text/comment nodes (but allow plain objects) - if ( !elemData ) { - return; - } - - // Caller can pass in an object of custom data in lieu of the handler - if ( handler.handler ) { - handleObjIn = handler; - handler = handleObjIn.handler; - selector = handleObjIn.selector; - } - - // Make sure that the handler has a unique ID, used to find/remove it later - if ( !handler.guid ) { - handler.guid = jQuery.guid++; - } - - // Init the element's event structure and main handler, if this is the first - if ( !(events = elemData.events) ) { - events = elemData.events = {}; - } - if ( !(eventHandle = elemData.handle) ) { - eventHandle = elemData.handle = function( e ) { - // Discard the second event of a jQuery.event.trigger() and - // when an event is called after a page has unloaded - return typeof jQuery !== strundefined && (!e || jQuery.event.triggered !== e.type) ? - jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : - undefined; - }; - // Add elem as a property of the handle fn to prevent a memory leak with IE non-native events - eventHandle.elem = elem; - } - - // Handle multiple events separated by a space - types = ( types || "" ).match( rnotwhite ) || [ "" ]; - t = types.length; - while ( t-- ) { - tmp = rtypenamespace.exec( types[t] ) || []; - type = origType = tmp[1]; - namespaces = ( tmp[2] || "" ).split( "." ).sort(); - - // There *must* be a type, no attaching namespace-only handlers - if ( !type ) { - continue; - } - - // If event changes its type, use the special event handlers for the changed type - special = jQuery.event.special[ type ] || {}; - - // If selector defined, determine special event api type, otherwise given type - type = ( selector ? special.delegateType : special.bindType ) || type; - - // Update special based on newly reset type - special = jQuery.event.special[ type ] || {}; - - // handleObj is passed to all event handlers - handleObj = jQuery.extend({ - type: type, - origType: origType, - data: data, - handler: handler, - guid: handler.guid, - selector: selector, - needsContext: selector && jQuery.expr.match.needsContext.test( selector ), - namespace: namespaces.join(".") - }, handleObjIn ); - - // Init the event handler queue if we're the first - if ( !(handlers = events[ type ]) ) { - handlers = events[ type ] = []; - handlers.delegateCount = 0; - - // Only use addEventListener/attachEvent if the special events handler returns false - if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { - // Bind the global event handler to the element - if ( elem.addEventListener ) { - elem.addEventListener( type, eventHandle, false ); - - } else if ( elem.attachEvent ) { - elem.attachEvent( "on" + type, eventHandle ); - } - } - } - - if ( special.add ) { - special.add.call( elem, handleObj ); - - if ( !handleObj.handler.guid ) { - handleObj.handler.guid = handler.guid; - } - } - - // Add to the element's handler list, delegates in front - if ( selector ) { - handlers.splice( handlers.delegateCount++, 0, handleObj ); - } else { - handlers.push( handleObj ); - } - - // Keep track of which events have ever been used, for event optimization - jQuery.event.global[ type ] = true; - } - - // Nullify elem to prevent memory leaks in IE - elem = null; - }, - - // Detach an event or set of events from an element - remove: function( elem, types, handler, selector, mappedTypes ) { - var j, handleObj, tmp, - origCount, t, events, - special, handlers, type, - namespaces, origType, - elemData = jQuery.hasData( elem ) && jQuery._data( elem ); - - if ( !elemData || !(events = elemData.events) ) { - return; - } - - // Once for each type.namespace in types; type may be omitted - types = ( types || "" ).match( rnotwhite ) || [ "" ]; - t = types.length; - while ( t-- ) { - tmp = rtypenamespace.exec( types[t] ) || []; - type = origType = tmp[1]; - namespaces = ( tmp[2] || "" ).split( "." ).sort(); - - // Unbind all events (on this namespace, if provided) for the element - if ( !type ) { - for ( type in events ) { - jQuery.event.remove( elem, type + types[ t ], handler, selector, true ); - } - continue; - } - - special = jQuery.event.special[ type ] || {}; - type = ( selector ? special.delegateType : special.bindType ) || type; - handlers = events[ type ] || []; - tmp = tmp[2] && new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ); - - // Remove matching events - origCount = j = handlers.length; - while ( j-- ) { - handleObj = handlers[ j ]; - - if ( ( mappedTypes || origType === handleObj.origType ) && - ( !handler || handler.guid === handleObj.guid ) && - ( !tmp || tmp.test( handleObj.namespace ) ) && - ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) { - handlers.splice( j, 1 ); - - if ( handleObj.selector ) { - handlers.delegateCount--; - } - if ( special.remove ) { - special.remove.call( elem, handleObj ); - } - } - } - - // Remove generic event handler if we removed something and no more handlers exist - // (avoids potential for endless recursion during removal of special event handlers) - if ( origCount && !handlers.length ) { - if ( !special.teardown || special.teardown.call( elem, namespaces, elemData.handle ) === false ) { - jQuery.removeEvent( elem, type, elemData.handle ); - } - - delete events[ type ]; - } - } - - // Remove the expando if it's no longer used - if ( jQuery.isEmptyObject( events ) ) { - delete elemData.handle; - - // removeData also checks for emptiness and clears the expando if empty - // so use it instead of delete - jQuery._removeData( elem, "events" ); - } - }, - - trigger: function( event, data, elem, onlyHandlers ) { - var handle, ontype, cur, - bubbleType, special, tmp, i, - eventPath = [ elem || document ], - type = hasOwn.call( event, "type" ) ? event.type : event, - namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : []; - - cur = tmp = elem = elem || document; - - // Don't do events on text and comment nodes - if ( elem.nodeType === 3 || elem.nodeType === 8 ) { - return; - } - - // focus/blur morphs to focusin/out; ensure we're not firing them right now - if ( rfocusMorph.test( type + jQuery.event.triggered ) ) { - return; - } - - if ( type.indexOf(".") >= 0 ) { - // Namespaced trigger; create a regexp to match event type in handle() - namespaces = type.split("."); - type = namespaces.shift(); - namespaces.sort(); - } - ontype = type.indexOf(":") < 0 && "on" + type; - - // Caller can pass in a jQuery.Event object, Object, or just an event type string - event = event[ jQuery.expando ] ? - event : - new jQuery.Event( type, typeof event === "object" && event ); - - // Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true) - event.isTrigger = onlyHandlers ? 2 : 3; - event.namespace = namespaces.join("."); - event.namespace_re = event.namespace ? - new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) : - null; - - // Clean up the event in case it is being reused - event.result = undefined; - if ( !event.target ) { - event.target = elem; - } - - // Clone any incoming data and prepend the event, creating the handler arg list - data = data == null ? - [ event ] : - jQuery.makeArray( data, [ event ] ); - - // Allow special events to draw outside the lines - special = jQuery.event.special[ type ] || {}; - if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) { - return; - } - - // Determine event propagation path in advance, per W3C events spec (#9951) - // Bubble up to document, then to window; watch for a global ownerDocument var (#9724) - if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) { - - bubbleType = special.delegateType || type; - if ( !rfocusMorph.test( bubbleType + type ) ) { - cur = cur.parentNode; - } - for ( ; cur; cur = cur.parentNode ) { - eventPath.push( cur ); - tmp = cur; - } - - // Only add window if we got to document (e.g., not plain obj or detached DOM) - if ( tmp === (elem.ownerDocument || document) ) { - eventPath.push( tmp.defaultView || tmp.parentWindow || window ); - } - } - - // Fire handlers on the event path - i = 0; - while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) { - - event.type = i > 1 ? - bubbleType : - special.bindType || type; - - // jQuery handler - handle = ( jQuery._data( cur, "events" ) || {} )[ event.type ] && jQuery._data( cur, "handle" ); - if ( handle ) { - handle.apply( cur, data ); - } - - // Native handler - handle = ontype && cur[ ontype ]; - if ( handle && handle.apply && jQuery.acceptData( cur ) ) { - event.result = handle.apply( cur, data ); - if ( event.result === false ) { - event.preventDefault(); - } - } - } - event.type = type; - - // If nobody prevented the default action, do it now - if ( !onlyHandlers && !event.isDefaultPrevented() ) { - - if ( (!special._default || special._default.apply( eventPath.pop(), data ) === false) && - jQuery.acceptData( elem ) ) { - - // Call a native DOM method on the target with the same name name as the event. - // Can't use an .isFunction() check here because IE6/7 fails that test. - // Don't do default actions on window, that's where global variables be (#6170) - if ( ontype && elem[ type ] && !jQuery.isWindow( elem ) ) { - - // Don't re-trigger an onFOO event when we call its FOO() method - tmp = elem[ ontype ]; - - if ( tmp ) { - elem[ ontype ] = null; - } - - // Prevent re-triggering of the same event, since we already bubbled it above - jQuery.event.triggered = type; - try { - elem[ type ](); - } catch ( e ) { - // IE<9 dies on focus/blur to hidden element (#1486,#12518) - // only reproducible on winXP IE8 native, not IE9 in IE8 mode - } - jQuery.event.triggered = undefined; - - if ( tmp ) { - elem[ ontype ] = tmp; - } - } - } - } - - return event.result; - }, - - dispatch: function( event ) { - - // Make a writable jQuery.Event from the native event object - event = jQuery.event.fix( event ); - - var i, ret, handleObj, matched, j, - handlerQueue = [], - args = slice.call( arguments ), - handlers = ( jQuery._data( this, "events" ) || {} )[ event.type ] || [], - special = jQuery.event.special[ event.type ] || {}; - - // Use the fix-ed jQuery.Event rather than the (read-only) native event - args[0] = event; - event.delegateTarget = this; - - // Call the preDispatch hook for the mapped type, and let it bail if desired - if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) { - return; - } - - // Determine handlers - handlerQueue = jQuery.event.handlers.call( this, event, handlers ); - - // Run delegates first; they may want to stop propagation beneath us - i = 0; - while ( (matched = handlerQueue[ i++ ]) && !event.isPropagationStopped() ) { - event.currentTarget = matched.elem; - - j = 0; - while ( (handleObj = matched.handlers[ j++ ]) && !event.isImmediatePropagationStopped() ) { - - // Triggered event must either 1) have no namespace, or - // 2) have namespace(s) a subset or equal to those in the bound event (both can have no namespace). - if ( !event.namespace_re || event.namespace_re.test( handleObj.namespace ) ) { - - event.handleObj = handleObj; - event.data = handleObj.data; - - ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || handleObj.handler ) - .apply( matched.elem, args ); - - if ( ret !== undefined ) { - if ( (event.result = ret) === false ) { - event.preventDefault(); - event.stopPropagation(); - } - } - } - } - } - - // Call the postDispatch hook for the mapped type - if ( special.postDispatch ) { - special.postDispatch.call( this, event ); - } - - return event.result; - }, - - handlers: function( event, handlers ) { - var sel, handleObj, matches, i, - handlerQueue = [], - delegateCount = handlers.delegateCount, - cur = event.target; - - // Find delegate handlers - // Black-hole SVG instance trees (#13180) - // Avoid non-left-click bubbling in Firefox (#3861) - if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) { - - /* jshint eqeqeq: false */ - for ( ; cur != this; cur = cur.parentNode || this ) { - /* jshint eqeqeq: true */ - - // Don't check non-elements (#13208) - // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) - if ( cur.nodeType === 1 && (cur.disabled !== true || event.type !== "click") ) { - matches = []; - for ( i = 0; i < delegateCount; i++ ) { - handleObj = handlers[ i ]; - - // Don't conflict with Object.prototype properties (#13203) - sel = handleObj.selector + " "; - - if ( matches[ sel ] === undefined ) { - matches[ sel ] = handleObj.needsContext ? - jQuery( sel, this ).index( cur ) >= 0 : - jQuery.find( sel, this, null, [ cur ] ).length; - } - if ( matches[ sel ] ) { - matches.push( handleObj ); - } - } - if ( matches.length ) { - handlerQueue.push({ elem: cur, handlers: matches }); - } - } - } - } - - // Add the remaining (directly-bound) handlers - if ( delegateCount < handlers.length ) { - handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) }); - } - - return handlerQueue; - }, - - fix: function( event ) { - if ( event[ jQuery.expando ] ) { - return event; - } - - // Create a writable copy of the event object and normalize some properties - var i, prop, copy, - type = event.type, - originalEvent = event, - fixHook = this.fixHooks[ type ]; - - if ( !fixHook ) { - this.fixHooks[ type ] = fixHook = - rmouseEvent.test( type ) ? this.mouseHooks : - rkeyEvent.test( type ) ? this.keyHooks : - {}; - } - copy = fixHook.props ? this.props.concat( fixHook.props ) : this.props; - - event = new jQuery.Event( originalEvent ); - - i = copy.length; - while ( i-- ) { - prop = copy[ i ]; - event[ prop ] = originalEvent[ prop ]; - } - - // Support: IE<9 - // Fix target property (#1925) - if ( !event.target ) { - event.target = originalEvent.srcElement || document; - } - - // Support: Chrome 23+, Safari? - // Target should not be a text node (#504, #13143) - if ( event.target.nodeType === 3 ) { - event.target = event.target.parentNode; - } - - // Support: IE<9 - // For mouse/key events, metaKey==false if it's undefined (#3368, #11328) - event.metaKey = !!event.metaKey; - - return fixHook.filter ? fixHook.filter( event, originalEvent ) : event; - }, - - // Includes some event props shared by KeyEvent and MouseEvent - props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), - - fixHooks: {}, - - keyHooks: { - props: "char charCode key keyCode".split(" "), - filter: function( event, original ) { - - // Add which for key events - if ( event.which == null ) { - event.which = original.charCode != null ? original.charCode : original.keyCode; - } - - return event; - } - }, - - mouseHooks: { - props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "), - filter: function( event, original ) { - var body, eventDoc, doc, - button = original.button, - fromElement = original.fromElement; - - // Calculate pageX/Y if missing and clientX/Y available - if ( event.pageX == null && original.clientX != null ) { - eventDoc = event.target.ownerDocument || document; - doc = eventDoc.documentElement; - body = eventDoc.body; - - event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft || body && body.clientLeft || 0 ); - event.pageY = original.clientY + ( doc && doc.scrollTop || body && body.scrollTop || 0 ) - ( doc && doc.clientTop || body && body.clientTop || 0 ); - } - - // Add relatedTarget, if necessary - if ( !event.relatedTarget && fromElement ) { - event.relatedTarget = fromElement === event.target ? original.toElement : fromElement; - } - - // Add which for click: 1 === left; 2 === middle; 3 === right - // Note: button is not normalized, so don't use it - if ( !event.which && button !== undefined ) { - event.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) ); - } - - return event; - } - }, - - special: { - load: { - // Prevent triggered image.load events from bubbling to window.load - noBubble: true - }, - focus: { - // Fire native event if possible so blur/focus sequence is correct - trigger: function() { - if ( this !== safeActiveElement() && this.focus ) { - try { - this.focus(); - return false; - } catch ( e ) { - // Support: IE<9 - // If we error on focus to hidden element (#1486, #12518), - // let .trigger() run the handlers - } - } - }, - delegateType: "focusin" - }, - blur: { - trigger: function() { - if ( this === safeActiveElement() && this.blur ) { - this.blur(); - return false; - } - }, - delegateType: "focusout" - }, - click: { - // For checkbox, fire native event so checked state will be right - trigger: function() { - if ( jQuery.nodeName( this, "input" ) && this.type === "checkbox" && this.click ) { - this.click(); - return false; - } - }, - - // For cross-browser consistency, don't fire native .click() on links - _default: function( event ) { - return jQuery.nodeName( event.target, "a" ); - } - }, - - beforeunload: { - postDispatch: function( event ) { - - // Support: Firefox 20+ - // Firefox doesn't alert if the returnValue field is not set. - if ( event.result !== undefined && event.originalEvent ) { - event.originalEvent.returnValue = event.result; - } - } - } - }, - - simulate: function( type, elem, event, bubble ) { - // Piggyback on a donor event to simulate a different one. - // Fake originalEvent to avoid donor's stopPropagation, but if the - // simulated event prevents default then we do the same on the donor. - var e = jQuery.extend( - new jQuery.Event(), - event, - { - type: type, - isSimulated: true, - originalEvent: {} - } - ); - if ( bubble ) { - jQuery.event.trigger( e, null, elem ); - } else { - jQuery.event.dispatch.call( elem, e ); - } - if ( e.isDefaultPrevented() ) { - event.preventDefault(); - } - } -}; - -jQuery.removeEvent = document.removeEventListener ? - function( elem, type, handle ) { - if ( elem.removeEventListener ) { - elem.removeEventListener( type, handle, false ); - } - } : - function( elem, type, handle ) { - var name = "on" + type; - - if ( elem.detachEvent ) { - - // #8545, #7054, preventing memory leaks for custom events in IE6-8 - // detachEvent needed property on element, by name of that event, to properly expose it to GC - if ( typeof elem[ name ] === strundefined ) { - elem[ name ] = null; - } - - elem.detachEvent( name, handle ); - } - }; - -jQuery.Event = function( src, props ) { - // Allow instantiation without the 'new' keyword - if ( !(this instanceof jQuery.Event) ) { - return new jQuery.Event( src, props ); - } - - // Event object - if ( src && src.type ) { - this.originalEvent = src; - this.type = src.type; - - // Events bubbling up the document may have been marked as prevented - // by a handler lower down the tree; reflect the correct value. - this.isDefaultPrevented = src.defaultPrevented || - src.defaultPrevented === undefined && - // Support: IE < 9, Android < 4.0 - src.returnValue === false ? - returnTrue : - returnFalse; - - // Event type - } else { - this.type = src; - } - - // Put explicitly provided properties onto the event object - if ( props ) { - jQuery.extend( this, props ); - } - - // Create a timestamp if incoming event doesn't have one - this.timeStamp = src && src.timeStamp || jQuery.now(); - - // Mark it as fixed - this[ jQuery.expando ] = true; -}; - -// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding -// http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html -jQuery.Event.prototype = { - isDefaultPrevented: returnFalse, - isPropagationStopped: returnFalse, - isImmediatePropagationStopped: returnFalse, - - preventDefault: function() { - var e = this.originalEvent; - - this.isDefaultPrevented = returnTrue; - if ( !e ) { - return; - } - - // If preventDefault exists, run it on the original event - if ( e.preventDefault ) { - e.preventDefault(); - - // Support: IE - // Otherwise set the returnValue property of the original event to false - } else { - e.returnValue = false; - } - }, - stopPropagation: function() { - var e = this.originalEvent; - - this.isPropagationStopped = returnTrue; - if ( !e ) { - return; - } - // If stopPropagation exists, run it on the original event - if ( e.stopPropagation ) { - e.stopPropagation(); - } - - // Support: IE - // Set the cancelBubble property of the original event to true - e.cancelBubble = true; - }, - stopImmediatePropagation: function() { - var e = this.originalEvent; - - this.isImmediatePropagationStopped = returnTrue; - - if ( e && e.stopImmediatePropagation ) { - e.stopImmediatePropagation(); - } - - this.stopPropagation(); - } -}; - -// Create mouseenter/leave events using mouseover/out and event-time checks -jQuery.each({ - mouseenter: "mouseover", - mouseleave: "mouseout", - pointerenter: "pointerover", - pointerleave: "pointerout" -}, function( orig, fix ) { - jQuery.event.special[ orig ] = { - delegateType: fix, - bindType: fix, - - handle: function( event ) { - var ret, - target = this, - related = event.relatedTarget, - handleObj = event.handleObj; - - // For mousenter/leave call the handler if related is outside the target. - // NB: No relatedTarget if the mouse left/entered the browser window - if ( !related || (related !== target && !jQuery.contains( target, related )) ) { - event.type = handleObj.origType; - ret = handleObj.handler.apply( this, arguments ); - event.type = fix; - } - return ret; - } - }; -}); - -// IE submit delegation -if ( !support.submitBubbles ) { - - jQuery.event.special.submit = { - setup: function() { - // Only need this for delegated form submit events - if ( jQuery.nodeName( this, "form" ) ) { - return false; - } - - // Lazy-add a submit handler when a descendant form may potentially be submitted - jQuery.event.add( this, "click._submit keypress._submit", function( e ) { - // Node name check avoids a VML-related crash in IE (#9807) - var elem = e.target, - form = jQuery.nodeName( elem, "input" ) || jQuery.nodeName( elem, "button" ) ? elem.form : undefined; - if ( form && !jQuery._data( form, "submitBubbles" ) ) { - jQuery.event.add( form, "submit._submit", function( event ) { - event._submit_bubble = true; - }); - jQuery._data( form, "submitBubbles", true ); - } - }); - // return undefined since we don't need an event listener - }, - - postDispatch: function( event ) { - // If form was submitted by the user, bubble the event up the tree - if ( event._submit_bubble ) { - delete event._submit_bubble; - if ( this.parentNode && !event.isTrigger ) { - jQuery.event.simulate( "submit", this.parentNode, event, true ); - } - } - }, - - teardown: function() { - // Only need this for delegated form submit events - if ( jQuery.nodeName( this, "form" ) ) { - return false; - } - - // Remove delegated handlers; cleanData eventually reaps submit handlers attached above - jQuery.event.remove( this, "._submit" ); - } - }; -} - -// IE change delegation and checkbox/radio fix -if ( !support.changeBubbles ) { - - jQuery.event.special.change = { - - setup: function() { - - if ( rformElems.test( this.nodeName ) ) { - // IE doesn't fire change on a check/radio until blur; trigger it on click - // after a propertychange. Eat the blur-change in special.change.handle. - // This still fires onchange a second time for check/radio after blur. - if ( this.type === "checkbox" || this.type === "radio" ) { - jQuery.event.add( this, "propertychange._change", function( event ) { - if ( event.originalEvent.propertyName === "checked" ) { - this._just_changed = true; - } - }); - jQuery.event.add( this, "click._change", function( event ) { - if ( this._just_changed && !event.isTrigger ) { - this._just_changed = false; - } - // Allow triggered, simulated change events (#11500) - jQuery.event.simulate( "change", this, event, true ); - }); - } - return false; - } - // Delegated event; lazy-add a change handler on descendant inputs - jQuery.event.add( this, "beforeactivate._change", function( e ) { - var elem = e.target; - - if ( rformElems.test( elem.nodeName ) && !jQuery._data( elem, "changeBubbles" ) ) { - jQuery.event.add( elem, "change._change", function( event ) { - if ( this.parentNode && !event.isSimulated && !event.isTrigger ) { - jQuery.event.simulate( "change", this.parentNode, event, true ); - } - }); - jQuery._data( elem, "changeBubbles", true ); - } - }); - }, - - handle: function( event ) { - var elem = event.target; - - // Swallow native change events from checkbox/radio, we already triggered them above - if ( this !== elem || event.isSimulated || event.isTrigger || (elem.type !== "radio" && elem.type !== "checkbox") ) { - return event.handleObj.handler.apply( this, arguments ); - } - }, - - teardown: function() { - jQuery.event.remove( this, "._change" ); - - return !rformElems.test( this.nodeName ); - } - }; -} - -// Create "bubbling" focus and blur events -if ( !support.focusinBubbles ) { - jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { - - // Attach a single capturing handler on the document while someone wants focusin/focusout - var handler = function( event ) { - jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ), true ); - }; - - jQuery.event.special[ fix ] = { - setup: function() { - var doc = this.ownerDocument || this, - attaches = jQuery._data( doc, fix ); - - if ( !attaches ) { - doc.addEventListener( orig, handler, true ); - } - jQuery._data( doc, fix, ( attaches || 0 ) + 1 ); - }, - teardown: function() { - var doc = this.ownerDocument || this, - attaches = jQuery._data( doc, fix ) - 1; - - if ( !attaches ) { - doc.removeEventListener( orig, handler, true ); - jQuery._removeData( doc, fix ); - } else { - jQuery._data( doc, fix, attaches ); - } - } - }; - }); -} - -jQuery.fn.extend({ - - on: function( types, selector, data, fn, /*INTERNAL*/ one ) { - var type, origFn; - - // Types can be a map of types/handlers - if ( typeof types === "object" ) { - // ( types-Object, selector, data ) - if ( typeof selector !== "string" ) { - // ( types-Object, data ) - data = data || selector; - selector = undefined; - } - for ( type in types ) { - this.on( type, selector, data, types[ type ], one ); - } - return this; - } - - if ( data == null && fn == null ) { - // ( types, fn ) - fn = selector; - data = selector = undefined; - } else if ( fn == null ) { - if ( typeof selector === "string" ) { - // ( types, selector, fn ) - fn = data; - data = undefined; - } else { - // ( types, data, fn ) - fn = data; - data = selector; - selector = undefined; - } - } - if ( fn === false ) { - fn = returnFalse; - } else if ( !fn ) { - return this; - } - - if ( one === 1 ) { - origFn = fn; - fn = function( event ) { - // Can use an empty set, since event contains the info - jQuery().off( event ); - return origFn.apply( this, arguments ); - }; - // Use same guid so caller can remove using origFn - fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); - } - return this.each( function() { - jQuery.event.add( this, types, fn, data, selector ); - }); - }, - one: function( types, selector, data, fn ) { - return this.on( types, selector, data, fn, 1 ); - }, - off: function( types, selector, fn ) { - var handleObj, type; - if ( types && types.preventDefault && types.handleObj ) { - // ( event ) dispatched jQuery.Event - handleObj = types.handleObj; - jQuery( types.delegateTarget ).off( - handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, - handleObj.selector, - handleObj.handler - ); - return this; - } - if ( typeof types === "object" ) { - // ( types-object [, selector] ) - for ( type in types ) { - this.off( type, selector, types[ type ] ); - } - return this; - } - if ( selector === false || typeof selector === "function" ) { - // ( types [, fn] ) - fn = selector; - selector = undefined; - } - if ( fn === false ) { - fn = returnFalse; - } - return this.each(function() { - jQuery.event.remove( this, types, fn, selector ); - }); - }, - - trigger: function( type, data ) { - return this.each(function() { - jQuery.event.trigger( type, data, this ); - }); - }, - triggerHandler: function( type, data ) { - var elem = this[0]; - if ( elem ) { - return jQuery.event.trigger( type, data, elem, true ); - } - } -}); - - -function createSafeFragment( document ) { - var list = nodeNames.split( "|" ), - safeFrag = document.createDocumentFragment(); - - if ( safeFrag.createElement ) { - while ( list.length ) { - safeFrag.createElement( - list.pop() - ); - } - } - return safeFrag; -} - -var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|" + - "header|hgroup|mark|meter|nav|output|progress|section|summary|time|video", - rinlinejQuery = / jQuery\d+="(?:null|\d+)"/g, - rnoshimcache = new RegExp("<(?:" + nodeNames + ")[\\s/>]", "i"), - rleadingWhitespace = /^\s+/, - rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi, - rtagName = /<([\w:]+)/, - rtbody = /\s*$/g, - - // We have to close these tags to support XHTML (#13200) - wrapMap = { - option: [ 1, "" ], - legend: [ 1, "
", "
" ], - area: [ 1, "", "" ], - param: [ 1, "", "" ], - thead: [ 1, "", "
" ], - tr: [ 2, "", "
" ], - col: [ 2, "", "
" ], - td: [ 3, "", "
" ], - - // IE6-8 can't serialize link, script, style, or any html5 (NoScope) tags, - // unless wrapped in a div with non-breaking characters in front of it. - _default: support.htmlSerialize ? [ 0, "", "" ] : [ 1, "X
", "
" ] - }, - safeFragment = createSafeFragment( document ), - fragmentDiv = safeFragment.appendChild( document.createElement("div") ); - -wrapMap.optgroup = wrapMap.option; -wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; -wrapMap.th = wrapMap.td; - -function getAll( context, tag ) { - var elems, elem, - i = 0, - found = typeof context.getElementsByTagName !== strundefined ? context.getElementsByTagName( tag || "*" ) : - typeof context.querySelectorAll !== strundefined ? context.querySelectorAll( tag || "*" ) : - undefined; - - if ( !found ) { - for ( found = [], elems = context.childNodes || context; (elem = elems[i]) != null; i++ ) { - if ( !tag || jQuery.nodeName( elem, tag ) ) { - found.push( elem ); - } else { - jQuery.merge( found, getAll( elem, tag ) ); - } - } - } - - return tag === undefined || tag && jQuery.nodeName( context, tag ) ? - jQuery.merge( [ context ], found ) : - found; -} - -// Used in buildFragment, fixes the defaultChecked property -function fixDefaultChecked( elem ) { - if ( rcheckableType.test( elem.type ) ) { - elem.defaultChecked = elem.checked; - } -} - -// Support: IE<8 -// Manipulating tables requires a tbody -function manipulationTarget( elem, content ) { - return jQuery.nodeName( elem, "table" ) && - jQuery.nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ? - - elem.getElementsByTagName("tbody")[0] || - elem.appendChild( elem.ownerDocument.createElement("tbody") ) : - elem; -} - -// Replace/restore the type attribute of script elements for safe DOM manipulation -function disableScript( elem ) { - elem.type = (jQuery.find.attr( elem, "type" ) !== null) + "/" + elem.type; - return elem; -} -function restoreScript( elem ) { - var match = rscriptTypeMasked.exec( elem.type ); - if ( match ) { - elem.type = match[1]; - } else { - elem.removeAttribute("type"); - } - return elem; -} - -// Mark scripts as having already been evaluated -function setGlobalEval( elems, refElements ) { - var elem, - i = 0; - for ( ; (elem = elems[i]) != null; i++ ) { - jQuery._data( elem, "globalEval", !refElements || jQuery._data( refElements[i], "globalEval" ) ); - } -} - -function cloneCopyEvent( src, dest ) { - - if ( dest.nodeType !== 1 || !jQuery.hasData( src ) ) { - return; - } - - var type, i, l, - oldData = jQuery._data( src ), - curData = jQuery._data( dest, oldData ), - events = oldData.events; - - if ( events ) { - delete curData.handle; - curData.events = {}; - - for ( type in events ) { - for ( i = 0, l = events[ type ].length; i < l; i++ ) { - jQuery.event.add( dest, type, events[ type ][ i ] ); - } - } - } - - // make the cloned public data object a copy from the original - if ( curData.data ) { - curData.data = jQuery.extend( {}, curData.data ); - } -} - -function fixCloneNodeIssues( src, dest ) { - var nodeName, e, data; - - // We do not need to do anything for non-Elements - if ( dest.nodeType !== 1 ) { - return; - } - - nodeName = dest.nodeName.toLowerCase(); - - // IE6-8 copies events bound via attachEvent when using cloneNode. - if ( !support.noCloneEvent && dest[ jQuery.expando ] ) { - data = jQuery._data( dest ); - - for ( e in data.events ) { - jQuery.removeEvent( dest, e, data.handle ); - } - - // Event data gets referenced instead of copied if the expando gets copied too - dest.removeAttribute( jQuery.expando ); - } - - // IE blanks contents when cloning scripts, and tries to evaluate newly-set text - if ( nodeName === "script" && dest.text !== src.text ) { - disableScript( dest ).text = src.text; - restoreScript( dest ); - - // IE6-10 improperly clones children of object elements using classid. - // IE10 throws NoModificationAllowedError if parent is null, #12132. - } else if ( nodeName === "object" ) { - if ( dest.parentNode ) { - dest.outerHTML = src.outerHTML; - } - - // This path appears unavoidable for IE9. When cloning an object - // element in IE9, the outerHTML strategy above is not sufficient. - // If the src has innerHTML and the destination does not, - // copy the src.innerHTML into the dest.innerHTML. #10324 - if ( support.html5Clone && ( src.innerHTML && !jQuery.trim(dest.innerHTML) ) ) { - dest.innerHTML = src.innerHTML; - } - - } else if ( nodeName === "input" && rcheckableType.test( src.type ) ) { - // IE6-8 fails to persist the checked state of a cloned checkbox - // or radio button. Worse, IE6-7 fail to give the cloned element - // a checked appearance if the defaultChecked value isn't also set - - dest.defaultChecked = dest.checked = src.checked; - - // IE6-7 get confused and end up setting the value of a cloned - // checkbox/radio button to an empty string instead of "on" - if ( dest.value !== src.value ) { - dest.value = src.value; - } - - // IE6-8 fails to return the selected option to the default selected - // state when cloning options - } else if ( nodeName === "option" ) { - dest.defaultSelected = dest.selected = src.defaultSelected; - - // IE6-8 fails to set the defaultValue to the correct value when - // cloning other types of input fields - } else if ( nodeName === "input" || nodeName === "textarea" ) { - dest.defaultValue = src.defaultValue; - } -} - -jQuery.extend({ - clone: function( elem, dataAndEvents, deepDataAndEvents ) { - var destElements, node, clone, i, srcElements, - inPage = jQuery.contains( elem.ownerDocument, elem ); - - if ( support.html5Clone || jQuery.isXMLDoc(elem) || !rnoshimcache.test( "<" + elem.nodeName + ">" ) ) { - clone = elem.cloneNode( true ); - - // IE<=8 does not properly clone detached, unknown element nodes - } else { - fragmentDiv.innerHTML = elem.outerHTML; - fragmentDiv.removeChild( clone = fragmentDiv.firstChild ); - } - - if ( (!support.noCloneEvent || !support.noCloneChecked) && - (elem.nodeType === 1 || elem.nodeType === 11) && !jQuery.isXMLDoc(elem) ) { - - // We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2 - destElements = getAll( clone ); - srcElements = getAll( elem ); - - // Fix all IE cloning issues - for ( i = 0; (node = srcElements[i]) != null; ++i ) { - // Ensure that the destination node is not null; Fixes #9587 - if ( destElements[i] ) { - fixCloneNodeIssues( node, destElements[i] ); - } - } - } - - // Copy the events from the original to the clone - if ( dataAndEvents ) { - if ( deepDataAndEvents ) { - srcElements = srcElements || getAll( elem ); - destElements = destElements || getAll( clone ); - - for ( i = 0; (node = srcElements[i]) != null; i++ ) { - cloneCopyEvent( node, destElements[i] ); - } - } else { - cloneCopyEvent( elem, clone ); - } - } - - // Preserve script evaluation history - destElements = getAll( clone, "script" ); - if ( destElements.length > 0 ) { - setGlobalEval( destElements, !inPage && getAll( elem, "script" ) ); - } - - destElements = srcElements = node = null; - - // Return the cloned set - return clone; - }, - - buildFragment: function( elems, context, scripts, selection ) { - var j, elem, contains, - tmp, tag, tbody, wrap, - l = elems.length, - - // Ensure a safe fragment - safe = createSafeFragment( context ), - - nodes = [], - i = 0; - - for ( ; i < l; i++ ) { - elem = elems[ i ]; - - if ( elem || elem === 0 ) { - - // Add nodes directly - if ( jQuery.type( elem ) === "object" ) { - jQuery.merge( nodes, elem.nodeType ? [ elem ] : elem ); - - // Convert non-html into a text node - } else if ( !rhtml.test( elem ) ) { - nodes.push( context.createTextNode( elem ) ); - - // Convert html into DOM nodes - } else { - tmp = tmp || safe.appendChild( context.createElement("div") ); - - // Deserialize a standard representation - tag = (rtagName.exec( elem ) || [ "", "" ])[ 1 ].toLowerCase(); - wrap = wrapMap[ tag ] || wrapMap._default; - - tmp.innerHTML = wrap[1] + elem.replace( rxhtmlTag, "<$1>" ) + wrap[2]; - - // Descend through wrappers to the right content - j = wrap[0]; - while ( j-- ) { - tmp = tmp.lastChild; - } - - // Manually add leading whitespace removed by IE - if ( !support.leadingWhitespace && rleadingWhitespace.test( elem ) ) { - nodes.push( context.createTextNode( rleadingWhitespace.exec( elem )[0] ) ); - } - - // Remove IE's autoinserted from table fragments - if ( !support.tbody ) { - - // String was a , *may* have spurious - elem = tag === "table" && !rtbody.test( elem ) ? - tmp.firstChild : - - // String was a bare or - wrap[1] === "
" && !rtbody.test( elem ) ? - tmp : - 0; - - j = elem && elem.childNodes.length; - while ( j-- ) { - if ( jQuery.nodeName( (tbody = elem.childNodes[j]), "tbody" ) && !tbody.childNodes.length ) { - elem.removeChild( tbody ); - } - } - } - - jQuery.merge( nodes, tmp.childNodes ); - - // Fix #12392 for WebKit and IE > 9 - tmp.textContent = ""; - - // Fix #12392 for oldIE - while ( tmp.firstChild ) { - tmp.removeChild( tmp.firstChild ); - } - - // Remember the top-level container for proper cleanup - tmp = safe.lastChild; - } - } - } - - // Fix #11356: Clear elements from fragment - if ( tmp ) { - safe.removeChild( tmp ); - } - - // Reset defaultChecked for any radios and checkboxes - // about to be appended to the DOM in IE 6/7 (#8060) - if ( !support.appendChecked ) { - jQuery.grep( getAll( nodes, "input" ), fixDefaultChecked ); - } - - i = 0; - while ( (elem = nodes[ i++ ]) ) { - - // #4087 - If origin and destination elements are the same, and this is - // that element, do not do anything - if ( selection && jQuery.inArray( elem, selection ) !== -1 ) { - continue; - } - - contains = jQuery.contains( elem.ownerDocument, elem ); - - // Append to fragment - tmp = getAll( safe.appendChild( elem ), "script" ); - - // Preserve script evaluation history - if ( contains ) { - setGlobalEval( tmp ); - } - - // Capture executables - if ( scripts ) { - j = 0; - while ( (elem = tmp[ j++ ]) ) { - if ( rscriptType.test( elem.type || "" ) ) { - scripts.push( elem ); - } - } - } - } - - tmp = null; - - return safe; - }, - - cleanData: function( elems, /* internal */ acceptData ) { - var elem, type, id, data, - i = 0, - internalKey = jQuery.expando, - cache = jQuery.cache, - deleteExpando = support.deleteExpando, - special = jQuery.event.special; - - for ( ; (elem = elems[i]) != null; i++ ) { - if ( acceptData || jQuery.acceptData( elem ) ) { - - id = elem[ internalKey ]; - data = id && cache[ id ]; - - if ( data ) { - if ( data.events ) { - for ( type in data.events ) { - if ( special[ type ] ) { - jQuery.event.remove( elem, type ); - - // This is a shortcut to avoid jQuery.event.remove's overhead - } else { - jQuery.removeEvent( elem, type, data.handle ); - } - } - } - - // Remove cache only if it was not already removed by jQuery.event.remove - if ( cache[ id ] ) { - - delete cache[ id ]; - - // IE does not allow us to delete expando properties from nodes, - // nor does it have a removeAttribute function on Document nodes; - // we must handle all of these cases - if ( deleteExpando ) { - delete elem[ internalKey ]; - - } else if ( typeof elem.removeAttribute !== strundefined ) { - elem.removeAttribute( internalKey ); - - } else { - elem[ internalKey ] = null; - } - - deletedIds.push( id ); - } - } - } - } - } -}); - -jQuery.fn.extend({ - text: function( value ) { - return access( this, function( value ) { - return value === undefined ? - jQuery.text( this ) : - this.empty().append( ( this[0] && this[0].ownerDocument || document ).createTextNode( value ) ); - }, null, value, arguments.length ); - }, - - append: function() { - return this.domManip( arguments, function( elem ) { - if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { - var target = manipulationTarget( this, elem ); - target.appendChild( elem ); - } - }); - }, - - prepend: function() { - return this.domManip( arguments, function( elem ) { - if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { - var target = manipulationTarget( this, elem ); - target.insertBefore( elem, target.firstChild ); - } - }); - }, - - before: function() { - return this.domManip( arguments, function( elem ) { - if ( this.parentNode ) { - this.parentNode.insertBefore( elem, this ); - } - }); - }, - - after: function() { - return this.domManip( arguments, function( elem ) { - if ( this.parentNode ) { - this.parentNode.insertBefore( elem, this.nextSibling ); - } - }); - }, - - remove: function( selector, keepData /* Internal Use Only */ ) { - var elem, - elems = selector ? jQuery.filter( selector, this ) : this, - i = 0; - - for ( ; (elem = elems[i]) != null; i++ ) { - - if ( !keepData && elem.nodeType === 1 ) { - jQuery.cleanData( getAll( elem ) ); - } - - if ( elem.parentNode ) { - if ( keepData && jQuery.contains( elem.ownerDocument, elem ) ) { - setGlobalEval( getAll( elem, "script" ) ); - } - elem.parentNode.removeChild( elem ); - } - } - - return this; - }, - - empty: function() { - var elem, - i = 0; - - for ( ; (elem = this[i]) != null; i++ ) { - // Remove element nodes and prevent memory leaks - if ( elem.nodeType === 1 ) { - jQuery.cleanData( getAll( elem, false ) ); - } - - // Remove any remaining nodes - while ( elem.firstChild ) { - elem.removeChild( elem.firstChild ); - } - - // If this is a select, ensure that it displays empty (#12336) - // Support: IE<9 - if ( elem.options && jQuery.nodeName( elem, "select" ) ) { - elem.options.length = 0; - } - } - - return this; - }, - - clone: function( dataAndEvents, deepDataAndEvents ) { - dataAndEvents = dataAndEvents == null ? false : dataAndEvents; - deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents; - - return this.map(function() { - return jQuery.clone( this, dataAndEvents, deepDataAndEvents ); - }); - }, - - html: function( value ) { - return access( this, function( value ) { - var elem = this[ 0 ] || {}, - i = 0, - l = this.length; - - if ( value === undefined ) { - return elem.nodeType === 1 ? - elem.innerHTML.replace( rinlinejQuery, "" ) : - undefined; - } - - // See if we can take a shortcut and just use innerHTML - if ( typeof value === "string" && !rnoInnerhtml.test( value ) && - ( support.htmlSerialize || !rnoshimcache.test( value ) ) && - ( support.leadingWhitespace || !rleadingWhitespace.test( value ) ) && - !wrapMap[ (rtagName.exec( value ) || [ "", "" ])[ 1 ].toLowerCase() ] ) { - - value = value.replace( rxhtmlTag, "<$1>" ); - - try { - for (; i < l; i++ ) { - // Remove element nodes and prevent memory leaks - elem = this[i] || {}; - if ( elem.nodeType === 1 ) { - jQuery.cleanData( getAll( elem, false ) ); - elem.innerHTML = value; - } - } - - elem = 0; - - // If using innerHTML throws an exception, use the fallback method - } catch(e) {} - } - - if ( elem ) { - this.empty().append( value ); - } - }, null, value, arguments.length ); - }, - - replaceWith: function() { - var arg = arguments[ 0 ]; - - // Make the changes, replacing each context element with the new content - this.domManip( arguments, function( elem ) { - arg = this.parentNode; - - jQuery.cleanData( getAll( this ) ); - - if ( arg ) { - arg.replaceChild( elem, this ); - } - }); - - // Force removal if there was no new content (e.g., from empty arguments) - return arg && (arg.length || arg.nodeType) ? this : this.remove(); - }, - - detach: function( selector ) { - return this.remove( selector, true ); - }, - - domManip: function( args, callback ) { - - // Flatten any nested arrays - args = concat.apply( [], args ); - - var first, node, hasScripts, - scripts, doc, fragment, - i = 0, - l = this.length, - set = this, - iNoClone = l - 1, - value = args[0], - isFunction = jQuery.isFunction( value ); - - // We can't cloneNode fragments that contain checked, in WebKit - if ( isFunction || - ( l > 1 && typeof value === "string" && - !support.checkClone && rchecked.test( value ) ) ) { - return this.each(function( index ) { - var self = set.eq( index ); - if ( isFunction ) { - args[0] = value.call( this, index, self.html() ); - } - self.domManip( args, callback ); - }); - } - - if ( l ) { - fragment = jQuery.buildFragment( args, this[ 0 ].ownerDocument, false, this ); - first = fragment.firstChild; - - if ( fragment.childNodes.length === 1 ) { - fragment = first; - } - - if ( first ) { - scripts = jQuery.map( getAll( fragment, "script" ), disableScript ); - hasScripts = scripts.length; - - // Use the original fragment for the last item instead of the first because it can end up - // being emptied incorrectly in certain situations (#8070). - for ( ; i < l; i++ ) { - node = fragment; - - if ( i !== iNoClone ) { - node = jQuery.clone( node, true, true ); - - // Keep references to cloned scripts for later restoration - if ( hasScripts ) { - jQuery.merge( scripts, getAll( node, "script" ) ); - } - } - - callback.call( this[i], node, i ); - } - - if ( hasScripts ) { - doc = scripts[ scripts.length - 1 ].ownerDocument; - - // Reenable scripts - jQuery.map( scripts, restoreScript ); - - // Evaluate executable scripts on first document insertion - for ( i = 0; i < hasScripts; i++ ) { - node = scripts[ i ]; - if ( rscriptType.test( node.type || "" ) && - !jQuery._data( node, "globalEval" ) && jQuery.contains( doc, node ) ) { - - if ( node.src ) { - // Optional AJAX dependency, but won't run scripts if not present - if ( jQuery._evalUrl ) { - jQuery._evalUrl( node.src ); - } - } else { - jQuery.globalEval( ( node.text || node.textContent || node.innerHTML || "" ).replace( rcleanScript, "" ) ); - } - } - } - } - - // Fix #11809: Avoid leaking memory - fragment = first = null; - } - } - - return this; - } -}); - -jQuery.each({ - appendTo: "append", - prependTo: "prepend", - insertBefore: "before", - insertAfter: "after", - replaceAll: "replaceWith" -}, function( name, original ) { - jQuery.fn[ name ] = function( selector ) { - var elems, - i = 0, - ret = [], - insert = jQuery( selector ), - last = insert.length - 1; - - for ( ; i <= last; i++ ) { - elems = i === last ? this : this.clone(true); - jQuery( insert[i] )[ original ]( elems ); - - // Modern browsers can apply jQuery collections as arrays, but oldIE needs a .get() - push.apply( ret, elems.get() ); - } - - return this.pushStack( ret ); - }; -}); - - -var iframe, - elemdisplay = {}; - -/** - * Retrieve the actual display of a element - * @param {String} name nodeName of the element - * @param {Object} doc Document object - */ -// Called only from within defaultDisplay -function actualDisplay( name, doc ) { - var style, - elem = jQuery( doc.createElement( name ) ).appendTo( doc.body ), - - // getDefaultComputedStyle might be reliably used only on attached element - display = window.getDefaultComputedStyle && ( style = window.getDefaultComputedStyle( elem[ 0 ] ) ) ? - - // Use of this method is a temporary fix (more like optmization) until something better comes along, - // since it was removed from specification and supported only in FF - style.display : jQuery.css( elem[ 0 ], "display" ); - - // We don't have any data stored on the element, - // so use "detach" method as fast way to get rid of the element - elem.detach(); - - return display; -} - -/** - * Try to determine the default display value of an element - * @param {String} nodeName - */ -function defaultDisplay( nodeName ) { - var doc = document, - display = elemdisplay[ nodeName ]; - - if ( !display ) { - display = actualDisplay( nodeName, doc ); - - // If the simple way fails, read from inside an iframe - if ( display === "none" || !display ) { - - // Use the already-created iframe if possible - iframe = (iframe || jQuery( "